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}
  • ; })}
); } 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()); } }