FEATURE: Make admin sidebar keywords translateable (#26657)
This commit ensures that additional keywords for admin sidebar links (which are also stored in the admin sidebar state manager) are translated with I18n, which was discussed in https://meta.discourse.org/t/introducing-experimental-admin-sidebar-navigation/289281/58?u=martin This also changes the admin sidebar state manager keywords to not be a TrackedObject -- this is not necessary as keywords are only set once, and it was causing rendering issues because the keywords were being set at the same time they were read. Finally this adds a "theme" keyword to the "Components" link because we often refer to components as Theme Components Co-authored-by: Jarek Radosz <jradosz@gmail.com>
This commit is contained in:
parent
f3cad5f3a2
commit
99d22c85ae
|
@ -1,6 +1,5 @@
|
||||||
import { tracked } from "@glimmer/tracking";
|
import { tracked } from "@glimmer/tracking";
|
||||||
import { service } from "@ember/service";
|
import { service } from "@ember/service";
|
||||||
import PreloadStore from "discourse/lib/preload-store";
|
|
||||||
import { MAIN_PANEL } from "discourse/lib/sidebar/panels";
|
import { MAIN_PANEL } from "discourse/lib/sidebar/panels";
|
||||||
import DiscourseRoute from "discourse/routes/discourse";
|
import DiscourseRoute from "discourse/routes/discourse";
|
||||||
import I18n from "discourse-i18n";
|
import I18n from "discourse-i18n";
|
||||||
|
@ -25,13 +24,6 @@ export default class AdminRoute extends DiscourseRoute {
|
||||||
this.controllerFor("application").setProperties({
|
this.controllerFor("application").setProperties({
|
||||||
showTop: false,
|
showTop: false,
|
||||||
});
|
});
|
||||||
|
|
||||||
const visiblePlugins = PreloadStore.get("visiblePlugins");
|
|
||||||
if (visiblePlugins) {
|
|
||||||
this.adminSidebarStateManager.keywords.admin_installed_plugins = {
|
|
||||||
navigation: visiblePlugins.mapBy("name"),
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
deactivate(transition) {
|
deactivate(transition) {
|
||||||
|
|
|
@ -1,18 +1,30 @@
|
||||||
import { tracked } from "@glimmer/tracking";
|
|
||||||
import Service, { service } from "@ember/service";
|
import Service, { service } from "@ember/service";
|
||||||
import { TrackedObject } from "@ember-compat/tracked-built-ins";
|
|
||||||
import KeyValueStore from "discourse/lib/key-value-store";
|
import KeyValueStore from "discourse/lib/key-value-store";
|
||||||
import { ADMIN_PANEL } from "discourse/lib/sidebar/panels";
|
import { ADMIN_PANEL } from "discourse/lib/sidebar/panels";
|
||||||
|
|
||||||
export default class AdminSidebarStateManager extends Service {
|
export default class AdminSidebarStateManager extends Service {
|
||||||
@service sidebarState;
|
@service sidebarState;
|
||||||
@service currentUser;
|
@service currentUser;
|
||||||
@tracked keywords = new TrackedObject();
|
|
||||||
|
keywords = {};
|
||||||
|
|
||||||
STORE_NAMESPACE = "discourse_admin_sidebar_experiment_";
|
STORE_NAMESPACE = "discourse_admin_sidebar_experiment_";
|
||||||
|
|
||||||
store = new KeyValueStore(this.STORE_NAMESPACE);
|
store = new KeyValueStore(this.STORE_NAMESPACE);
|
||||||
|
|
||||||
|
setLinkKeywords(link_name, keywords) {
|
||||||
|
if (!this.keywords[link_name]) {
|
||||||
|
this.keywords[link_name] = {
|
||||||
|
navigation: keywords.map((keyword) => keyword.toLowerCase()),
|
||||||
|
};
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.keywords[link_name].navigation = keywords.map((keyword) =>
|
||||||
|
keyword.toLowerCase()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
get navConfig() {
|
get navConfig() {
|
||||||
return this.store.getObject("navConfig");
|
return this.store.getObject("navConfig");
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,8 +14,9 @@ export const ADMIN_NAV_MAP = [
|
||||||
{
|
{
|
||||||
name: "admin_whats_new",
|
name: "admin_whats_new",
|
||||||
route: "admin.whatsNew",
|
route: "admin.whatsNew",
|
||||||
label: "admin.account.sidebar_link.whats_new",
|
label: "admin.account.sidebar_link.whats_new.title",
|
||||||
icon: "gift",
|
icon: "gift",
|
||||||
|
keywords: "admin.account.sidebar_link.whats_new.keywords",
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
|
@ -159,8 +160,9 @@ export const ADMIN_NAV_MAP = [
|
||||||
name: "admin_components",
|
name: "admin_components",
|
||||||
route: "adminCustomizeThemes",
|
route: "adminCustomizeThemes",
|
||||||
routeModels: ["components"],
|
routeModels: ["components"],
|
||||||
label: "admin.appearance.sidebar_link.components",
|
label: "admin.appearance.sidebar_link.components.title",
|
||||||
icon: "puzzle-piece",
|
icon: "puzzle-piece",
|
||||||
|
keywords: "admin.appearance.sidebar_link.components.keywords",
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "admin_customize_site_texts",
|
name: "admin_customize_site_texts",
|
||||||
|
|
|
@ -239,6 +239,10 @@ function pluginAdminRouteLinks() {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function installedPluginsLinkKeywords() {
|
||||||
|
return (PreloadStore.get("visiblePlugins") || []).mapBy("name");
|
||||||
|
}
|
||||||
|
|
||||||
export default class AdminSidebarPanel extends BaseCustomSidebarPanel {
|
export default class AdminSidebarPanel extends BaseCustomSidebarPanel {
|
||||||
key = ADMIN_PANEL;
|
key = ADMIN_PANEL;
|
||||||
hidden = true;
|
hidden = true;
|
||||||
|
@ -266,6 +270,10 @@ export default class AdminSidebarPanel extends BaseCustomSidebarPanel {
|
||||||
|
|
||||||
if (!session.get("safe_mode")) {
|
if (!session.get("safe_mode")) {
|
||||||
navMap.findBy("name", "plugins").links.push(...pluginAdminRouteLinks());
|
navMap.findBy("name", "plugins").links.push(...pluginAdminRouteLinks());
|
||||||
|
this.adminSidebarStateManager.setLinkKeywords(
|
||||||
|
"admin_installed_plugins",
|
||||||
|
installedPluginsLinkKeywords()
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (siteSettings.experimental_form_templates) {
|
if (siteSettings.experimental_form_templates) {
|
||||||
|
@ -280,7 +288,10 @@ export default class AdminSidebarPanel extends BaseCustomSidebarPanel {
|
||||||
navMap.forEach((section) =>
|
navMap.forEach((section) =>
|
||||||
section.links.forEach((link) => {
|
section.links.forEach((link) => {
|
||||||
if (link.keywords) {
|
if (link.keywords) {
|
||||||
this.adminSidebarStateManager.keywords[link.name] = link.keywords;
|
this.adminSidebarStateManager.setLinkKeywords(
|
||||||
|
link.name,
|
||||||
|
I18n.t(link.keywords).split("|")
|
||||||
|
);
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
|
|
|
@ -5312,7 +5312,9 @@ en:
|
||||||
title: "Account"
|
title: "Account"
|
||||||
sidebar_link:
|
sidebar_link:
|
||||||
backups: "Backups"
|
backups: "Backups"
|
||||||
whats_new: "What's New"
|
whats_new:
|
||||||
|
title: "What's New"
|
||||||
|
keywords: "changelog|feature|release"
|
||||||
|
|
||||||
community:
|
community:
|
||||||
title: "Community"
|
title: "Community"
|
||||||
|
@ -5337,7 +5339,9 @@ en:
|
||||||
emoji: "Emoji"
|
emoji: "Emoji"
|
||||||
navigation: "Navigation"
|
navigation: "Navigation"
|
||||||
themes: "Themes"
|
themes: "Themes"
|
||||||
components: "Components"
|
components:
|
||||||
|
title: "Components"
|
||||||
|
keywords: "theme|extension"
|
||||||
site_texts: "Site Texts"
|
site_texts: "Site Texts"
|
||||||
|
|
||||||
email_settings:
|
email_settings:
|
||||||
|
|
Loading…
Reference in New Issue