discourse/app/assets/javascripts/admin/addon/controllers/admin-site-text/index.js
David Taylor 6081bc2249
DEV: Standardize Ember route, controller and template naming (#34417)
For historical reasons, Discourse has a customized Ember resolver. This
had a much more fuzzy implementation of 'normalize' and 'findTemplate'
functions. This leniency meant that our file naming hasn't always
matched Ember conventions.

Standardizing our naming will make things easier to understand for
developers, and will make adoption of newer ecosystem tooling easier
(e.g. route-based bundle splitting in Embroider/vite)

This commit adds deprecations to the resolver when this leniency is
used, and uses a fully bespoke codemod to rename all of the affected
routes/controllers/templates in the Discourse core repository.
Backwards-compatibility is maintained for anyone looking up the old
names in the resolver.
2025-09-25 11:27:45 +01:00

168 lines
3.7 KiB
JavaScript
Vendored

import { tracked } from "@glimmer/tracking";
import Controller from "@ember/controller";
import { action } from "@ember/object";
import { service } from "@ember/service";
import discourseDebounce from "discourse/lib/debounce";
import { disableImplicitInjections } from "discourse/lib/implicit-injections";
import ReseedModal from "admin/components/modal/reseed";
let lastSearch;
@disableImplicitInjections
export default class AdminSiteTextIndexController extends Controller {
@service router;
@service siteSettings;
@service modal;
@service store;
@tracked locale;
@tracked q;
@tracked overridden;
@tracked outdated;
@tracked untranslated;
@tracked onlySelectedLocale;
@tracked model;
@tracked searching = false;
@tracked preferred = false;
queryParams = [
"q",
"overridden",
"outdated",
"locale",
"untranslated",
"onlySelectedLocale",
];
get resolvedOverridden() {
return [true, "true"].includes(this.overridden) ?? false;
}
get resolvedOutdated() {
return [true, "true"].includes(this.outdated) ?? false;
}
get resolvedUntranslated() {
return [true, "true"].includes(this.untranslated) ?? false;
}
get resolvedOnlySelectedLocale() {
return [true, "true"].includes(this.onlySelectedLocale) ?? false;
}
get resolvedLocale() {
return this.locale ?? this.siteSettings.default_locale;
}
get showUntranslated() {
return (
this.siteSettings.admin_allow_filter_untranslated_text &&
this.resolvedLocale !== "en"
);
}
async _performSearch() {
try {
this.model = await this.store.find("site-text", {
q: this.q,
overridden: this.resolvedOverridden,
outdated: this.resolvedOutdated,
locale: this.resolvedLocale,
untranslated: this.resolvedUntranslated,
only_selected_locale: this.resolvedOnlySelectedLocale,
});
} finally {
this.searching = false;
}
}
get availableLocales() {
return this.siteSettings.available_locales;
}
get fallbackLocaleFullName() {
if (this.model.extras.fallback_locale) {
return this.availableLocales.find((l) => {
return l.value === this.model.extras.fallback_locale;
}).name;
}
}
@action
edit(siteText) {
this.router.transitionTo("adminSiteText.edit", siteText.get("id"), {
queryParams: {
locale: this.resolvedLocale,
},
});
}
@action
toggleOverridden() {
if (this.resolvedOverridden) {
this.overridden = null;
} else {
this.overridden = true;
}
this.searching = true;
discourseDebounce(this, this._performSearch, 400);
}
@action
toggleOutdated() {
if (this.resolvedOutdated) {
this.outdated = null;
} else {
this.outdated = true;
}
this.searching = true;
discourseDebounce(this, this._performSearch, 400);
}
@action
toggleUntranslated() {
if (this.resolvedUntranslated) {
this.untranslated = null;
} else {
this.untranslated = true;
}
this.searching = true;
discourseDebounce(this, this._performSearch, 400);
}
@action
toggleOnlySelectedLocale() {
if (this.resolvedOnlySelectedLocale) {
this.onlySelectedLocale = null;
} else {
this.onlySelectedLocale = true;
}
this.searching = true;
discourseDebounce(this, this._performSearch, 400);
}
@action
search() {
const q = this.q;
if (q !== lastSearch) {
this.searching = true;
discourseDebounce(this, this._performSearch, 400);
lastSearch = q;
}
}
@action
updateLocale(value) {
this.searching = true;
this.locale = value;
discourseDebounce(this, this._performSearch, 400);
}
@action
showReseedModal() {
this.modal.show(ReseedModal);
}
}