FIX: Refactor to prevent themes affecting core stylesheets (#7029)
If a theme setting contained invalid SCSS, it would cause an error 500 on the site, with no way to recover. This commit stops loading theme settings in the core stylesheets, and instead only loads the color scheme variables. This change also makes `common/foundation/variables.scss` available to themes without an explicit import.
This commit is contained in:
parent
9ade04b709
commit
7878e5007a
|
@ -64,7 +64,7 @@ $line-height-large: 1.4; // Normal or small text
|
||||||
// These files don't actually exist. They're injected by Stylesheet::Compiler.
|
// These files don't actually exist. They're injected by Stylesheet::Compiler.
|
||||||
// --------------------------------------------------
|
// --------------------------------------------------
|
||||||
|
|
||||||
@import "theme_variables";
|
@import "theme_colors";
|
||||||
@import "plugins_variables";
|
@import "plugins_variables";
|
||||||
@import "common/foundation/math";
|
@import "common/foundation/math";
|
||||||
|
|
||||||
|
|
|
@ -261,7 +261,7 @@ class ThemeField < ActiveRecord::Base
|
||||||
def ensure_scss_compiles!
|
def ensure_scss_compiles!
|
||||||
if ThemeField.scss_fields.include?(self.name)
|
if ThemeField.scss_fields.include?(self.name)
|
||||||
begin
|
begin
|
||||||
Stylesheet::Compiler.compile("@import \"theme_variables\"; @import \"theme_field\";",
|
Stylesheet::Compiler.compile("@import \"common/foundation/variables\"; @import \"theme_variables\"; @import \"theme_field\";",
|
||||||
"theme.scss",
|
"theme.scss",
|
||||||
theme_field: self.value.dup,
|
theme_field: self.value.dup,
|
||||||
theme: self.theme
|
theme: self.theme
|
||||||
|
|
|
@ -10,7 +10,7 @@ module Stylesheet
|
||||||
|
|
||||||
if Importer.special_imports[asset.to_s]
|
if Importer.special_imports[asset.to_s]
|
||||||
filename = "theme.scss"
|
filename = "theme.scss"
|
||||||
file = "@import \"theme_variables\"; @import \"#{asset}\";"
|
file = "@import \"common/foundation/variables\"; @import \"theme_variables\"; @import \"#{asset}\";"
|
||||||
else
|
else
|
||||||
filename = "#{asset}.scss"
|
filename = "#{asset}.scss"
|
||||||
path = "#{ASSET_ROOT}/#{filename}"
|
path = "#{ASSET_ROOT}/#{filename}"
|
||||||
|
|
|
@ -33,12 +33,19 @@ module Stylesheet
|
||||||
import_files(DiscoursePluginRegistry.sass_variables)
|
import_files(DiscoursePluginRegistry.sass_variables)
|
||||||
end
|
end
|
||||||
|
|
||||||
register_import "theme_variables" do
|
register_import "theme_colors" do
|
||||||
contents = ""
|
contents = ""
|
||||||
colors = (@theme_id && theme.color_scheme) ? theme.color_scheme.resolved_colors : ColorScheme.base_colors
|
colors = (@theme_id && theme.color_scheme) ? theme.color_scheme.resolved_colors : ColorScheme.base_colors
|
||||||
colors.each do |n, hex|
|
colors.each do |n, hex|
|
||||||
contents << "$#{n}: ##{hex} !default;\n"
|
contents << "$#{n}: ##{hex} !default;\n"
|
||||||
end
|
end
|
||||||
|
contents
|
||||||
|
|
||||||
|
Import.new("theme_colors.scss", source: contents)
|
||||||
|
end
|
||||||
|
|
||||||
|
register_import "theme_variables" do
|
||||||
|
contents = ""
|
||||||
|
|
||||||
theme&.all_theme_variables&.each do |field|
|
theme&.all_theme_variables&.each do |field|
|
||||||
if field.type_id == ThemeField.types[:theme_upload_var]
|
if field.type_id == ThemeField.types[:theme_upload_var]
|
||||||
|
|
|
@ -290,7 +290,7 @@ HTML
|
||||||
theme.reload
|
theme.reload
|
||||||
expect(theme.theme_fields.find_by(name: :scss).error).to eq(nil)
|
expect(theme.theme_fields.find_by(name: :scss).error).to eq(nil)
|
||||||
|
|
||||||
scss, _map = Stylesheet::Compiler.compile('@import "theme_variables"; @import "desktop_theme"; ', "theme.scss", theme_id: theme.id)
|
scss, _map = Stylesheet::Compiler.compile('@import "common/foundation/variables"; @import "theme_variables"; @import "desktop_theme"; ', "theme.scss", theme_id: theme.id)
|
||||||
expect(scss).to include(upload.url)
|
expect(scss).to include(upload.url)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue