mirror of
https://github.com/zulip/zulip-desktop.git
synced 2025-10-23 16:13:37 +00:00
Changes - * New setting nav item for connected organizations. * All new page for adding a new server. * Minor UI changes in setting page. * Update default height, width of the main window. * Fix webview showing outline. * Hide Server nav item in setting page. Fixes #340.
68 lines
1.4 KiB
JavaScript
68 lines
1.4 KiB
JavaScript
'use strict';
|
|
|
|
const BaseComponent = require(__dirname + '/../../components/base.js');
|
|
|
|
class PreferenceNav extends BaseComponent {
|
|
constructor(props) {
|
|
super();
|
|
|
|
this.props = props;
|
|
|
|
this.navItems = ['General', 'Network', 'AddServer', 'Organizations', 'Shortcuts'];
|
|
|
|
this.init();
|
|
}
|
|
|
|
template() {
|
|
let navItemsTemplate = '';
|
|
for (const navItem of this.navItems) {
|
|
navItemsTemplate += `<div class="nav" id="nav-${navItem}">${navItem}</div>`;
|
|
}
|
|
|
|
return `
|
|
<div>
|
|
<div id="settings-header">Settings</div>
|
|
<div id="nav-container">${navItemsTemplate}</div>
|
|
</div>
|
|
`;
|
|
}
|
|
|
|
init() {
|
|
this.$el = this.generateNodeFromTemplate(this.template());
|
|
this.props.$root.appendChild(this.$el);
|
|
|
|
this.registerListeners();
|
|
}
|
|
|
|
registerListeners() {
|
|
for (const navItem of this.navItems) {
|
|
const $item = document.getElementById(`nav-${navItem}`);
|
|
$item.addEventListener('click', () => {
|
|
this.props.onItemSelected(navItem);
|
|
});
|
|
}
|
|
}
|
|
|
|
select(navItemToSelect) {
|
|
for (const navItem of this.navItems) {
|
|
if (navItem === navItemToSelect) {
|
|
this.activate(navItem);
|
|
} else {
|
|
this.deactivate(navItem);
|
|
}
|
|
}
|
|
}
|
|
|
|
activate(navItem) {
|
|
const $item = document.getElementById(`nav-${navItem}`);
|
|
$item.classList.add('active');
|
|
}
|
|
|
|
deactivate(navItem) {
|
|
const $item = document.getElementById(`nav-${navItem}`);
|
|
$item.classList.remove('active');
|
|
}
|
|
}
|
|
|
|
module.exports = PreferenceNav;
|