mirror of
https://github.com/discourse/discourse.git
synced 2025-06-23 21:31:35 +08:00
DEV: Remove branding and styling steps from wizard (#32797)
https://github.com/discourse/discourse/pull/32797
This commit is contained in:
@ -13,8 +13,6 @@ class Wizard
|
||||
|
||||
append_introduction_step
|
||||
append_privacy_step
|
||||
append_styling_step
|
||||
append_branding_step
|
||||
append_ready_step
|
||||
|
||||
DiscourseEvent.trigger(:build_wizard, @wizard)
|
||||
@ -119,191 +117,6 @@ class Wizard
|
||||
end
|
||||
end
|
||||
|
||||
def append_branding_step
|
||||
@wizard.append_step("branding") do |step|
|
||||
step.emoji = "framed_picture"
|
||||
step.add_field(id: "logo", type: "image", value: SiteSetting.site_logo_url)
|
||||
step.add_field(id: "logo_small", type: "image", value: SiteSetting.site_logo_small_url)
|
||||
|
||||
step.on_update do |updater|
|
||||
if SiteSetting.site_logo_url != updater.fields[:logo] ||
|
||||
SiteSetting.site_logo_small_url != updater.fields[:logo_small]
|
||||
updater.apply_settings(:logo, :logo_small)
|
||||
updater.refresh_required = true
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
def append_styling_step
|
||||
@wizard.append_step("styling") do |step|
|
||||
step.emoji = "art"
|
||||
default_theme = Theme.find_default
|
||||
default_theme_override = SiteSetting.exists?(name: "default_theme_id")
|
||||
|
||||
base_scheme = default_theme&.color_scheme&.base_scheme_id
|
||||
color_scheme_name = default_theme&.color_scheme&.name
|
||||
|
||||
scheme_id =
|
||||
default_theme_override ? (base_scheme || color_scheme_name) : ColorScheme::LIGHT_THEME_ID
|
||||
|
||||
themes =
|
||||
step.add_field(
|
||||
id: "color_scheme",
|
||||
type: "dropdown",
|
||||
required: !default_theme_override,
|
||||
value: scheme_id || ColorScheme::LIGHT_THEME_ID,
|
||||
show_in_sidebar: true,
|
||||
)
|
||||
|
||||
# fix for the case when base_scheme is nil
|
||||
if scheme_id && default_theme_override && base_scheme.nil?
|
||||
scheme = default_theme.color_scheme
|
||||
themes.add_choice(scheme_id, data: { colors: scheme.colors_hashes })
|
||||
end
|
||||
|
||||
ColorScheme.base_color_scheme_colors.each do |t|
|
||||
themes.add_choice(t[:id], data: { colors: t[:colors] })
|
||||
end
|
||||
|
||||
if SiteSetting.base_font != SiteSetting.heading_font
|
||||
body_font =
|
||||
step.add_field(
|
||||
id: "body_font",
|
||||
type: "dropdown",
|
||||
value: SiteSetting.base_font,
|
||||
show_in_sidebar: true,
|
||||
)
|
||||
|
||||
heading_font =
|
||||
step.add_field(
|
||||
id: "heading_font",
|
||||
type: "dropdown",
|
||||
value: SiteSetting.heading_font,
|
||||
show_in_sidebar: true,
|
||||
)
|
||||
else
|
||||
site_font =
|
||||
step.add_field(
|
||||
id: "site_font",
|
||||
type: "dropdown",
|
||||
value: SiteSetting.base_font,
|
||||
show_in_sidebar: true,
|
||||
)
|
||||
end
|
||||
|
||||
allowed_fonts = WIZARD_FONTS
|
||||
allowed_fonts << SiteSetting.base_font if !allowed_fonts.include?(SiteSetting.base_font)
|
||||
if !allowed_fonts.include?(SiteSetting.heading_font)
|
||||
allowed_fonts << SiteSetting.heading_font
|
||||
end
|
||||
|
||||
DiscourseFonts
|
||||
.fonts
|
||||
.select do |font|
|
||||
# We only want to display certain fonts in the wizard, others will be accessible
|
||||
# in site settings.
|
||||
allowed_fonts.include?(font[:key])
|
||||
end
|
||||
.sort_by { |font| font[:name] }
|
||||
.each do |font|
|
||||
body_font&.add_choice(font[:key], label: font[:name])
|
||||
heading_font&.add_choice(font[:key], label: font[:name])
|
||||
site_font&.add_choice(font[:key], label: font[:name])
|
||||
end
|
||||
|
||||
current =
|
||||
(
|
||||
if SiteSetting.homepage == "categories"
|
||||
SiteSetting.desktop_category_page_style
|
||||
else
|
||||
SiteSetting.homepage
|
||||
end
|
||||
)
|
||||
style =
|
||||
step.add_field(
|
||||
id: "homepage_style",
|
||||
type: "dropdown",
|
||||
required: false,
|
||||
value: current,
|
||||
show_in_sidebar: true,
|
||||
)
|
||||
|
||||
# When changing these options, also consider the Dropdown component
|
||||
# for the wizard, we have special logic to add a "Custom" category for
|
||||
# unsupported options.
|
||||
style.add_choice("latest")
|
||||
style.add_choice("hot")
|
||||
# Subset of CategoryPageStyle, we don't want to show all the options here.
|
||||
style.add_choice("categories_boxes")
|
||||
|
||||
step.add_field(id: "styling_preview", type: "styling-preview")
|
||||
|
||||
step.on_update do |updater|
|
||||
if updater.fields[:site_font].present?
|
||||
updater.update_setting(:base_font, updater.fields[:site_font])
|
||||
updater.update_setting(:heading_font, updater.fields[:site_font])
|
||||
else
|
||||
updater.update_setting(:base_font, updater.fields[:body_font])
|
||||
updater.update_setting(:heading_font, updater.fields[:heading_font])
|
||||
end
|
||||
|
||||
top_menu = SiteSetting.top_menu_map
|
||||
if !updater.fields[:homepage_style].include?("categories") &&
|
||||
!updater.fields[:homepage_style].include?("category")
|
||||
if top_menu.first != updater.fields[:homepage_style]
|
||||
top_menu.delete(updater.fields[:homepage_style])
|
||||
top_menu.insert(0, updater.fields[:homepage_style])
|
||||
end
|
||||
else
|
||||
top_menu.delete("categories")
|
||||
top_menu.insert(0, "categories")
|
||||
updater.update_setting(:desktop_category_page_style, updater.fields[:homepage_style])
|
||||
end
|
||||
updater.update_setting(:top_menu, top_menu.join("|"))
|
||||
|
||||
scheme_name = ((updater.fields[:color_scheme] || "") || ColorScheme::LIGHT_THEME_ID)
|
||||
|
||||
if updater.setting_changed?(:base_font) || updater.setting_changed?(:heading_font)
|
||||
updater.refresh_required = true
|
||||
end
|
||||
|
||||
next unless scheme_name.present? && ColorScheme.is_base?(scheme_name)
|
||||
|
||||
name = I18n.t("color_schemes.#{scheme_name.downcase.gsub(" ", "_")}_theme_name")
|
||||
|
||||
scheme = ColorScheme.find_by(base_scheme_id: scheme_name, via_wizard: true)
|
||||
scheme ||=
|
||||
ColorScheme.create_from_base(name: name, via_wizard: true, base_scheme_id: scheme_name)
|
||||
|
||||
theme_changed = false
|
||||
if default_theme
|
||||
if default_theme.color_scheme_id != scheme.id
|
||||
default_theme.color_scheme_id = scheme.id
|
||||
default_theme.save!
|
||||
theme_changed = true
|
||||
end
|
||||
else
|
||||
theme =
|
||||
Theme.create!(
|
||||
name: I18n.t("color_schemes.default_theme_name"),
|
||||
user_id: @wizard.user.id,
|
||||
color_scheme_id: scheme.id,
|
||||
)
|
||||
|
||||
theme.set_default!
|
||||
theme_changed = true
|
||||
end
|
||||
|
||||
updater.update_setting(:default_dark_mode_color_scheme_id, -1) if scheme.is_dark?
|
||||
|
||||
if updater.setting_changed?(:default_dark_mode_color_scheme_id) || theme_changed
|
||||
updater.refresh_required = true
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
def replace_setting_value(updater, raw, field_name)
|
||||
old_value = SiteSetting.get(field_name)
|
||||
old_value = field_name if old_value.blank?
|
||||
|
Reference in New Issue
Block a user