mirror of
https://github.com/discourse/discourse.git
synced 2025-01-08 00:24:13 +08:00
05ee1d1aba
- These advanced fields are hidden behind an 'advanced' button, so will not affect normal use - The editor has been refactored into a component, and styling cleaned up so menu items do not overlap on small screens - Styling has been added to indicate which fields are in use for a theme - Icons have been added to identify which fields have errors
64 lines
1.8 KiB
JavaScript
64 lines
1.8 KiB
JavaScript
export default Ember.Route.extend({
|
|
model(params) {
|
|
const all = this.modelFor("adminCustomizeThemes");
|
|
const model = all.findBy("id", parseInt(params.theme_id));
|
|
return model
|
|
? {
|
|
model,
|
|
target: params.target,
|
|
field_name: params.field_name
|
|
}
|
|
: this.replaceWith("adminCustomizeThemes.index");
|
|
},
|
|
|
|
serialize(wrapper) {
|
|
return {
|
|
model: wrapper.model,
|
|
target: wrapper.target || "common",
|
|
field_name: wrapper.field_name || "scss",
|
|
theme_id: wrapper.model.get("id")
|
|
};
|
|
},
|
|
|
|
setupController(controller, wrapper) {
|
|
const fields = wrapper.model.get("fields")[wrapper.target].map(f => f.name);
|
|
if (!fields.includes(wrapper.field_name)) {
|
|
this.transitionTo(
|
|
"adminCustomizeThemes.edit",
|
|
wrapper.model.id,
|
|
wrapper.target,
|
|
fields[0]
|
|
);
|
|
return;
|
|
}
|
|
controller.set("model", wrapper.model);
|
|
controller.setTargetName(wrapper.target || "common");
|
|
controller.set("fieldName", wrapper.field_name || "scss");
|
|
this.controllerFor("adminCustomizeThemes").set("editingTheme", true);
|
|
this.set("shouldAlertUnsavedChanges", true);
|
|
},
|
|
|
|
actions: {
|
|
willTransition(transition) {
|
|
if (
|
|
this.get("controller.model.changed") &&
|
|
this.get("shouldAlertUnsavedChanges") &&
|
|
transition.intent.name !== this.routeName
|
|
) {
|
|
transition.abort();
|
|
bootbox.confirm(
|
|
I18n.t("admin.customize.theme.unsaved_changes_alert"),
|
|
I18n.t("admin.customize.theme.discard"),
|
|
I18n.t("admin.customize.theme.stay"),
|
|
result => {
|
|
if (!result) {
|
|
this.set("shouldAlertUnsavedChanges", false);
|
|
transition.retry();
|
|
}
|
|
}
|
|
);
|
|
}
|
|
}
|
|
}
|
|
});
|