mirror of
https://github.com/flarum/framework.git
synced 2025-02-21 11:04:41 +08:00

- All custom JS variables are now preloaded into the `app.data` object, rather than directly on the `app` object. This means that admin settings are available in `app.data.settings` rather than `app.settings`, etc. - Cleaner route handler generation - Renamed ConfigureClientView to ConfigureWebApp, though the former still exists and is deprecated - Partial fix for #881 (strips ?nojs=1 from URL if possible, so that refreshing will attempt to load JS version again)
115 lines
4.0 KiB
JavaScript
115 lines
4.0 KiB
JavaScript
import Page from 'flarum/components/Page';
|
|
import LinkButton from 'flarum/components/LinkButton';
|
|
import Button from 'flarum/components/Button';
|
|
import Dropdown from 'flarum/components/Dropdown';
|
|
import Separator from 'flarum/components/Separator';
|
|
import AddExtensionModal from 'flarum/components/AddExtensionModal';
|
|
import LoadingModal from 'flarum/components/LoadingModal';
|
|
import ItemList from 'flarum/utils/ItemList';
|
|
import icon from 'flarum/helpers/icon';
|
|
import listItems from 'flarum/helpers/listItems';
|
|
|
|
export default class ExtensionsPage extends Page {
|
|
view() {
|
|
return (
|
|
<div className="ExtensionsPage">
|
|
<div className="ExtensionsPage-header">
|
|
<div className="container">
|
|
{Button.component({
|
|
children: app.translator.trans('core.admin.extensions.add_button'),
|
|
icon: 'plus',
|
|
className: 'Button Button--primary',
|
|
onclick: () => app.modal.show(new AddExtensionModal())
|
|
})}
|
|
</div>
|
|
</div>
|
|
|
|
<div className="ExtensionsPage-list">
|
|
<div className="container">
|
|
<ul className="ExtensionList">
|
|
{Object.keys(app.data.extensions)
|
|
.map(id => {
|
|
const extension = app.data.extensions[id];
|
|
const controls = this.controlItems(extension.id).toArray();
|
|
|
|
return <li className={'ExtensionListItem ' + (!this.isEnabled(extension.id) ? 'disabled' : '')}>
|
|
<div className="ExtensionListItem-content">
|
|
<span className="ExtensionListItem-icon ExtensionIcon" style={extension.icon}>
|
|
{extension.icon ? icon(extension.icon.name) : ''}
|
|
</span>
|
|
{controls.length ? (
|
|
<Dropdown
|
|
className="ExtensionListItem-controls"
|
|
buttonClassName="Button Button--icon Button--flat"
|
|
menuClassName="Dropdown-menu--right"
|
|
icon="ellipsis-h">
|
|
{controls}
|
|
</Dropdown>
|
|
) : ''}
|
|
<label className="ExtensionListItem-title">
|
|
<input type="checkbox" checked={this.isEnabled(extension.id)} onclick={this.toggle.bind(this, extension.id)}/> {' '}
|
|
{extension.extra['flarum-extension'].title}
|
|
</label>
|
|
<div className="ExtensionListItem-version">{extension.version}</div>
|
|
</div>
|
|
</li>;
|
|
})}
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
controlItems(name) {
|
|
const items = new ItemList();
|
|
const enabled = this.isEnabled(name);
|
|
|
|
if (app.extensionSettings[name]) {
|
|
items.add('settings', Button.component({
|
|
icon: 'cog',
|
|
children: app.translator.trans('core.admin.extensions.settings_button'),
|
|
onclick: app.extensionSettings[name]
|
|
}));
|
|
}
|
|
|
|
if (!enabled) {
|
|
items.add('uninstall', Button.component({
|
|
icon: 'trash-o',
|
|
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());
|
|
}
|
|
}
|