import Page from './Page'; import LinkButton from '../../common/components/LinkButton'; import Button from '../../common/components/Button'; import Dropdown from '../../common/components/Dropdown'; import Separator from '../../common/components/Separator'; import AddExtensionModal from './AddExtensionModal'; import LoadingModal from './LoadingModal'; import ItemList from '../../common/utils/ItemList'; import icon from '../../common/helpers/icon'; import listItems from '../../common/helpers/listItems'; export default class ExtensionsPage extends Page { view() { return (
{Button.component({ children: app.translator.trans('core.admin.extensions.add_button'), icon: 'fas fa-plus', className: 'Button Button--primary', onclick: () => app.modal.show(new AddExtensionModal()), })}
    {Object.keys(app.data.extensions).map((id) => { const extension = app.data.extensions[id]; const controls = this.controlItems(extension.id).toArray(); return (
  • {extension.icon ? icon(extension.icon.name) : ''} {controls.length ? ( {controls} ) : ( '' )}
    {extension.version}
    {extension.description}
  • ); })}
); } controlItems(name) { const items = new ItemList(); const enabled = this.isEnabled(name); if (app.extensionSettings[name]) { items.add( 'settings', Button.component({ icon: 'fas fa-cog', children: app.translator.trans('core.admin.extensions.settings_button'), onclick: app.extensionSettings[name], }) ); } if (!enabled) { items.add( 'uninstall', Button.component({ icon: 'far fa-trash-alt', children: app.translator.trans('core.admin.extensions.uninstall_button'), onclick: () => { app .request({ url: app.forum.attribute('apiUrl') + '/extensions/' + name, method: 'DELETE', }) .then(() => window.location.reload()); app.modal.show(new LoadingModal()); }, }) ); } return items; } isEnabled(name) { const enabled = JSON.parse(app.data.settings.extensions_enabled); return enabled.indexOf(name) !== -1; } toggle(id) { const enabled = this.isEnabled(id); app .request({ url: app.forum.attribute('apiUrl') + '/extensions/' + id, method: 'PATCH', data: { enabled: !enabled }, }) .then(() => { if (!enabled) localStorage.setItem('enabledExtension', id); window.location.reload(); }); app.modal.show(new LoadingModal()); } }