mirror of
https://github.com/zulip/zulip-desktop.git
synced 2025-11-02 13:03:22 +00:00
71 lines
1.7 KiB
TypeScript
71 lines
1.7 KiB
TypeScript
import {htmlEscape} from 'escape-goat';
|
|
|
|
import BaseComponent from '../../components/base';
|
|
import * as t from '../../utils/translation-util';
|
|
|
|
interface PreferenceNavProps {
|
|
$root: Element;
|
|
onItemSelected: (navItem: string) => void;
|
|
}
|
|
|
|
export default class PreferenceNav extends BaseComponent {
|
|
props: PreferenceNavProps;
|
|
navItems: string[];
|
|
$el: Element;
|
|
constructor(props: PreferenceNavProps) {
|
|
super();
|
|
this.props = props;
|
|
this.navItems = ['General', 'Network', 'AddServer', 'Organizations', 'Shortcuts'];
|
|
this.init();
|
|
}
|
|
|
|
templateHTML(): string {
|
|
let navItemsHTML = '';
|
|
for (const navItem of this.navItems) {
|
|
navItemsHTML += htmlEscape`<div class="nav" id="nav-${navItem}">${t.__(navItem)}</div>`;
|
|
}
|
|
|
|
return htmlEscape`
|
|
<div>
|
|
<div id="settings-header">${t.__('Settings')}</div>
|
|
<div id="nav-container">` + navItemsHTML + htmlEscape`</div>
|
|
</div>
|
|
`;
|
|
}
|
|
|
|
init(): void {
|
|
this.$el = this.generateNodeFromHTML(this.templateHTML());
|
|
this.props.$root.append(this.$el);
|
|
this.registerListeners();
|
|
}
|
|
|
|
registerListeners(): void {
|
|
for (const navItem of this.navItems) {
|
|
const $item = document.querySelector(`#nav-${CSS.escape(navItem)}`);
|
|
$item.addEventListener('click', () => {
|
|
this.props.onItemSelected(navItem);
|
|
});
|
|
}
|
|
}
|
|
|
|
select(navItemToSelect: string): void {
|
|
for (const navItem of this.navItems) {
|
|
if (navItem === navItemToSelect) {
|
|
this.activate(navItem);
|
|
} else {
|
|
this.deactivate(navItem);
|
|
}
|
|
}
|
|
}
|
|
|
|
activate(navItem: string): void {
|
|
const $item = document.querySelector(`#nav-${CSS.escape(navItem)}`);
|
|
$item.classList.add('active');
|
|
}
|
|
|
|
deactivate(navItem: string): void {
|
|
const $item = document.querySelector(`#nav-${CSS.escape(navItem)}`);
|
|
$item.classList.remove('active');
|
|
}
|
|
}
|