UX: Admin setting page consistency - Fonts (#30564)

Create a basic config page that only contains font-related settings, to replace the setting filtered view linked to from "Font style" in the admin sidebar.
This commit is contained in:
Gary Pendergast 2025-01-06 15:05:40 +11:00 committed by GitHub
parent b07e7cc70f
commit 01ceeae2d6
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
9 changed files with 44 additions and 4 deletions

View File

@ -0,0 +1,3 @@
import AdminAreaSettingsBaseController from "admin/controllers/admin-area-settings-base";
export default class AdminConfigFontsController extends AdminAreaSettingsBaseController {}

View File

@ -0,0 +1,8 @@
import DiscourseRoute from "discourse/routes/discourse";
import { i18n } from "discourse-i18n";
export default class AdminConfigFontsRoute extends DiscourseRoute {
titleToken() {
return i18n("admin.appearance.sidebar_link.font_style");
}
}

View File

@ -262,6 +262,9 @@ export default function () {
this.route("settings"); this.route("settings");
} }
); );
this.route("fonts", function () {
this.route("settings", { path: "/" });
});
} }
); );

View File

@ -0,0 +1,21 @@
<DPageHeader
@titleLabel={{i18n "admin.config.font_style.title"}}
@descriptionLabel={{i18n "admin.config.font_style.header_description"}}
>
<:breadcrumbs>
<DBreadcrumbsItem @path="/admin" @label={{i18n "admin_title"}} />
<DBreadcrumbsItem
@path="/admin/config/fonts"
@label={{i18n "admin.config.font_style.title"}}
/>
</:breadcrumbs>
</DPageHeader>
<div class="admin-config-page__main-area">
<AdminAreaSettings
@area="fonts"
@path="/admin/config/fonts"
@filter={{this.filter}}
@adminSettingsFilterChangedCallback={{this.adminSettingsFilterChangedCallback}}
/>
</div>

View File

@ -102,9 +102,7 @@ export const ADMIN_NAV_MAP = [
links: [ links: [
{ {
name: "admin_font_style", name: "admin_font_style",
route: "adminSiteSettingsCategory", route: "adminConfig.fonts.settings",
routeModels: ["all_results"],
query: { filter: "font" },
label: "admin.appearance.sidebar_link.font_style", label: "admin.appearance.sidebar_link.font_style",
icon: "italic", icon: "italic",
}, },

View File

@ -1,7 +1,7 @@
# frozen_string_literal: true # frozen_string_literal: true
class SiteSetting < ActiveRecord::Base class SiteSetting < ActiveRecord::Base
VALID_AREAS = %w[about embedding emojis flags notifications permalinks] VALID_AREAS = %w[about embedding emojis flags fonts notifications permalinks]
extend GlobalPath extend GlobalPath
extend SiteSettingExtension extend SiteSettingExtension

View File

@ -5134,6 +5134,9 @@ en:
all: "All reports" all: "All reports"
config: config:
font_style:
title: "Font style"
header_description: "Customize the font styles used by your themes."
login_and_authentication: login_and_authentication:
title: "Login and authentication" title: "Login and authentication"
header_description: "Configure how users log in and authenticate, secrets and keys, OAuth2 providers, and more." header_description: "Configure how users log in and authenticate, secrets and keys, OAuth2 providers, and more."

View File

@ -393,6 +393,7 @@ Discourse::Application.routes.draw do
namespace :config, constraints: StaffConstraint.new do namespace :config, constraints: StaffConstraint.new do
resources :site_settings, only: %i[index] resources :site_settings, only: %i[index]
get "fonts" => "site_settings#index"
get "login-and-authentication" => "site_settings#index" get "login-and-authentication" => "site_settings#index"
get "notifications" => "site_settings#index" get "notifications" => "site_settings#index"

View File

@ -406,10 +406,12 @@ basic:
default: "arial" default: "arial"
enum: "BaseFontSetting" enum: "BaseFontSetting"
refresh: true refresh: true
area: "fonts"
heading_font: heading_font:
default: "arial" default: "arial"
enum: "BaseFontSetting" enum: "BaseFontSetting"
refresh: true refresh: true
area: "fonts"
enable_sitemap: enable_sitemap:
default: true default: true
sitemap_page_size: sitemap_page_size:
@ -3144,6 +3146,7 @@ user_preferences:
- normal - normal
- larger - larger
- largest - largest
area: "fonts"
default_title_count_mode: default_title_count_mode:
type: enum type: enum