mirror of
https://github.com/discourse/discourse.git
synced 2025-02-06 23:00:46 +08:00
![Martin Brennan](/assets/img/avatar_default.png)
This commit finalises the admin setting page consistency efforts by: * Converting all route templates into .gjs * Adding `@hideTabs={{true}}` for all the page headers so we don't show a border line when it's not needed * Introduce `@showBreadcrumb` and default to true for AdminAreaSettings, for all these pages the Settings part of the breadcrumb is redundant
89 lines
2.6 KiB
Plaintext
89 lines
2.6 KiB
Plaintext
import Component from "@glimmer/component";
|
|
import { tracked } from "@glimmer/tracking";
|
|
import { action } from "@ember/object";
|
|
import { service } from "@ember/service";
|
|
import ConditionalLoadingSpinner from "discourse/components/conditional-loading-spinner";
|
|
import DBreadcrumbsItem from "discourse/components/d-breadcrumbs-item";
|
|
import { ajax } from "discourse/lib/ajax";
|
|
import { bind } from "discourse-common/utils/decorators";
|
|
import { i18n } from "discourse-i18n";
|
|
import AdminConfigAreaEmptyList from "admin/components/admin-config-area-empty-list";
|
|
import AdminFilteredSiteSettings from "admin/components/admin-filtered-site-settings";
|
|
import SiteSetting from "admin/models/site-setting";
|
|
|
|
export default class AdminAreaSettings extends Component {
|
|
@service siteSettings;
|
|
@service router;
|
|
@tracked settings = [];
|
|
@tracked filter = "";
|
|
@tracked loading = false;
|
|
@tracked showBreadcrumb = this.args.showBreadcrumb ?? true;
|
|
|
|
constructor() {
|
|
super(...arguments);
|
|
this.#loadSettings();
|
|
}
|
|
|
|
get showSettings() {
|
|
return !this.loading && this.settings.length > 0;
|
|
}
|
|
|
|
@bind
|
|
async #loadSettings() {
|
|
this.loading = true;
|
|
this.filter = this.args.filter;
|
|
try {
|
|
const result = await ajax("/admin/config/site_settings.json", {
|
|
data: {
|
|
filter_area: this.args.area,
|
|
plugin: this.args.plugin,
|
|
categories: this.args.categories,
|
|
},
|
|
});
|
|
this.settings = [
|
|
{
|
|
name: "All",
|
|
nameKey: "all_results",
|
|
siteSettings: result.site_settings.map((setting) =>
|
|
SiteSetting.create(setting)
|
|
),
|
|
},
|
|
];
|
|
} catch (error) {
|
|
// eslint-disable-next-line no-console
|
|
console.warn(`Failed to load settings with error: ${error}`);
|
|
} finally {
|
|
this.loading = false;
|
|
}
|
|
}
|
|
|
|
@action
|
|
adminSettingsFilterChangedCallback(filterData) {
|
|
this.args.adminSettingsFilterChangedCallback(filterData.filter);
|
|
}
|
|
|
|
<template>
|
|
{{#if this.showBreadcrumb}}
|
|
<DBreadcrumbsItem @path={{@path}} @label={{i18n "settings"}} />
|
|
{{/if}}
|
|
|
|
<div
|
|
class="content-body admin-config-area__settings admin-detail pull-left"
|
|
>
|
|
{{#if this.showSettings}}
|
|
<AdminFilteredSiteSettings
|
|
@initialFilter={{this.filter}}
|
|
@onFilterChanged={{this.adminSettingsFilterChangedCallback}}
|
|
@settings={{this.settings}}
|
|
/>
|
|
{{else}}
|
|
<ConditionalLoadingSpinner @condition={{this.loading}}>
|
|
<AdminConfigAreaEmptyList
|
|
@emptyLabelTranslated={{i18n "admin.settings.not_found"}}
|
|
/>
|
|
</ConditionalLoadingSpinner>
|
|
{{/if}}
|
|
</div>
|
|
</template>
|
|
}
|