mirror of
https://github.com/flarum/framework.git
synced 2025-02-19 17:21:44 +08:00
data:image/s3,"s3://crabby-images/94cbb/94cbb57df0d84bd1cbee25a6ba37820bb33959e9" alt="Toby Zerner"
- 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)
76 lines
1.4 KiB
JavaScript
76 lines
1.4 KiB
JavaScript
import Modal from 'flarum/components/Modal';
|
|
import Button from 'flarum/components/Button';
|
|
import saveSettings from 'flarum/utils/saveSettings';
|
|
|
|
export default class SettingsModal extends Modal {
|
|
init() {
|
|
this.settings = {};
|
|
this.loading = false;
|
|
}
|
|
|
|
form() {
|
|
return '';
|
|
}
|
|
|
|
content() {
|
|
return (
|
|
<div className="Modal-body">
|
|
<div className="Form">
|
|
{this.form()}
|
|
|
|
<div className="Form-group">
|
|
{this.submitButton()}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
submitButton() {
|
|
return (
|
|
<Button
|
|
type="submit"
|
|
className="Button Button--primary"
|
|
loading={this.loading}
|
|
disabled={!this.changed()}>
|
|
{app.translator.trans('core.admin.settings.submit_button')}
|
|
</Button>
|
|
);
|
|
}
|
|
|
|
setting(key, fallback = '') {
|
|
this.settings[key] = this.settings[key] || m.prop(app.data.settings[key] || fallback);
|
|
|
|
return this.settings[key];
|
|
}
|
|
|
|
dirty() {
|
|
const dirty = {};
|
|
|
|
Object.keys(this.settings).forEach(key => {
|
|
const value = this.settings[key]();
|
|
|
|
if (value !== app.data.settings[key]) {
|
|
dirty[key] = value;
|
|
}
|
|
});
|
|
|
|
return dirty;
|
|
}
|
|
|
|
changed() {
|
|
return Object.keys(this.dirty()).length;
|
|
}
|
|
|
|
onsubmit(e) {
|
|
e.preventDefault();
|
|
|
|
this.loading = true;
|
|
|
|
saveSettings(this.dirty()).then(
|
|
this.hide.bind(this),
|
|
this.loaded.bind(this)
|
|
);
|
|
}
|
|
}
|