mirror of
https://github.com/zulip/zulip-desktop.git
synced 2025-11-02 13:03:22 +00:00
51 lines
1.2 KiB
TypeScript
51 lines
1.2 KiB
TypeScript
'use strict';
|
|
|
|
import { ipcRenderer } from 'electron';
|
|
|
|
import BaseComponent = require('../../components/base');
|
|
|
|
class BaseSection extends BaseComponent {
|
|
// TODO: TypeScript - Here props should be object type
|
|
generateSettingOption(props: any): void {
|
|
const {$element, disabled, value, clickHandler} = props;
|
|
|
|
$element.innerHTML = '';
|
|
|
|
const $optionControl = this.generateNodeFromTemplate(this.generateOptionTemplate(value, disabled));
|
|
$element.append($optionControl);
|
|
|
|
if (!disabled) {
|
|
$optionControl.addEventListener('click', clickHandler);
|
|
}
|
|
}
|
|
|
|
generateOptionTemplate(settingOption: boolean, disabled: boolean): string {
|
|
const label = disabled ? `<label class="disallowed" title="Setting locked by system administrator."/>` : `<label/>`;
|
|
if (settingOption) {
|
|
return `
|
|
<div class="action">
|
|
<div class="switch">
|
|
<input class="toggle toggle-round" type="checkbox" checked disabled>
|
|
${label}
|
|
</div>
|
|
</div>
|
|
`;
|
|
} else {
|
|
return `
|
|
<div class="action">
|
|
<div class="switch">
|
|
<input class="toggle toggle-round" type="checkbox">
|
|
${label}
|
|
</div>
|
|
</div>
|
|
`;
|
|
}
|
|
}
|
|
|
|
reloadApp(): void {
|
|
ipcRenderer.send('forward-message', 'reload-viewer');
|
|
}
|
|
}
|
|
|
|
export = BaseSection;
|