FIX: Regression in colors used by non-default theme (#12492)
eb7f0ec
caused this regression, where a non-default theme set to use
the base color scheme was resolving to the default theme's color scheme.
This commit is contained in:
parent
dc73aadbff
commit
066c59d0e3
|
@ -135,9 +135,12 @@ module Stylesheet
|
||||||
rescue
|
rescue
|
||||||
ColorScheme.base_colors
|
ColorScheme.base_colors
|
||||||
end
|
end
|
||||||
elsif (@theme_id && theme.color_scheme)
|
elsif (@theme_id && !theme.component)
|
||||||
colors = theme.color_scheme.resolved_colors
|
colors = theme&.color_scheme&.resolved_colors || ColorScheme.base_colors
|
||||||
else
|
else
|
||||||
|
# this is a slightly ugly backwards compatibility fix,
|
||||||
|
# we shouldn't be using the default theme color scheme for components
|
||||||
|
# (most components use CSS custom properties which work fine without this)
|
||||||
colors = Theme.find_by_id(SiteSetting.default_theme_id)&.color_scheme&.resolved_colors ||
|
colors = Theme.find_by_id(SiteSetting.default_theme_id)&.color_scheme&.resolved_colors ||
|
||||||
ColorScheme.base_colors
|
ColorScheme.base_colors
|
||||||
end
|
end
|
||||||
|
|
|
@ -331,6 +331,7 @@ describe Stylesheet::Manager do
|
||||||
|
|
||||||
it "uses the correct color scheme when a non-default theme is selected and it uses the base 'Light' scheme" do
|
it "uses the correct color scheme when a non-default theme is selected and it uses the base 'Light' scheme" do
|
||||||
cs = Fabricate(:color_scheme, name: 'Not This')
|
cs = Fabricate(:color_scheme, name: 'Not This')
|
||||||
|
ColorSchemeRevisor.revise(cs, colors: [{ name: "primary", hex: "CC0000" }])
|
||||||
default_theme = Fabricate(:theme, color_scheme_id: cs.id)
|
default_theme = Fabricate(:theme, color_scheme_id: cs.id)
|
||||||
SiteSetting.default_theme_id = default_theme.id
|
SiteSetting.default_theme_id = default_theme.id
|
||||||
|
|
||||||
|
@ -338,6 +339,10 @@ describe Stylesheet::Manager do
|
||||||
|
|
||||||
link = Stylesheet::Manager.color_scheme_stylesheet_link_tag(nil, "all", [user_theme.id])
|
link = Stylesheet::Manager.color_scheme_stylesheet_link_tag(nil, "all", [user_theme.id])
|
||||||
expect(link).to include("/stylesheets/color_definitions_base_")
|
expect(link).to include("/stylesheets/color_definitions_base_")
|
||||||
|
|
||||||
|
stylesheet = Stylesheet::Manager.new(:color_definitions, user_theme.id, nil).compile(force: true)
|
||||||
|
expect(stylesheet).not_to include("--primary: #c00;")
|
||||||
|
expect(stylesheet).to include("--primary: #222;") # from base scheme
|
||||||
end
|
end
|
||||||
|
|
||||||
it "uses the correct scheme when a valid scheme id is used" do
|
it "uses the correct scheme when a valid scheme id is used" do
|
||||||
|
|
Loading…
Reference in New Issue