2015-07-29 18:54:33 +02:00
|
|
|
module ThemeHelper
|
2020-05-06 13:36:43 +02:00
|
|
|
ATTRIBUTE_MAP = {
|
|
|
|
'primary_color' => 'primary',
|
|
|
|
'primary_text' => 'primary-text',
|
|
|
|
'danger_color' => 'danger',
|
|
|
|
'danger_text' => 'danger-text',
|
|
|
|
'warning_color' => 'warning',
|
|
|
|
'warning_text' => 'warning-text',
|
|
|
|
'info_color' => 'info',
|
|
|
|
'info_text' => 'info-text',
|
|
|
|
'success_color' => 'success',
|
|
|
|
'success_text' => 'success-text',
|
|
|
|
'dark_color' => 'dark',
|
|
|
|
'dark_text' => 'dark-text',
|
|
|
|
'light_color' => 'light',
|
|
|
|
'light_text' => 'light-text',
|
|
|
|
'raised_background' => 'raised-bg',
|
|
|
|
'raised_accent' => 'raised-accent',
|
|
|
|
'background_color' => 'background',
|
|
|
|
'body_text' => 'body-text',
|
|
|
|
'input_color' => 'input-bg',
|
|
|
|
'input_text' => 'input-text',
|
2022-11-14 23:13:22 +01:00
|
|
|
'input_placeholder' => 'input-placeholder',
|
2020-05-06 13:36:43 +02:00
|
|
|
'muted_text' => 'muted-text'
|
|
|
|
}.freeze
|
2020-05-03 17:28:41 +02:00
|
|
|
|
2020-05-06 13:36:43 +02:00
|
|
|
def render_theme
|
2020-05-03 17:28:41 +02:00
|
|
|
theme = get_active_theme
|
|
|
|
|
2020-05-06 13:36:43 +02:00
|
|
|
return unless theme
|
2020-05-03 17:28:41 +02:00
|
|
|
|
|
|
|
body = ":root {\n"
|
|
|
|
|
2020-05-06 13:36:43 +02:00
|
|
|
theme.attributes.each do |k, v|
|
|
|
|
next unless ATTRIBUTE_MAP.key?(k)
|
2020-05-03 17:28:41 +02:00
|
|
|
|
2022-11-14 23:13:22 +01:00
|
|
|
if k.include? 'text' or k.include? 'placeholder'
|
2020-05-06 13:36:43 +02:00
|
|
|
hex = get_hex_color_from_theme_value(v)
|
|
|
|
body += "\t--#{ATTRIBUTE_MAP[k]}: #{get_decimal_triplet_from_hex(hex)};\n"
|
|
|
|
else
|
|
|
|
body += "\t--#{ATTRIBUTE_MAP[k]}: ##{get_hex_color_from_theme_value(v)};\n"
|
|
|
|
end
|
2020-05-03 17:28:41 +02:00
|
|
|
end
|
2021-04-04 16:23:11 +02:00
|
|
|
body += "\t--turbolinks-progress-color: ##{lighten(theme.primary_color)}\n"
|
2020-05-06 13:36:43 +02:00
|
|
|
|
2021-06-19 21:37:04 +02:00
|
|
|
body += '}'
|
2020-05-06 13:36:43 +02:00
|
|
|
|
2020-05-09 02:07:58 +02:00
|
|
|
content_tag(:style, body)
|
2020-05-03 17:28:41 +02:00
|
|
|
end
|
|
|
|
|
2021-06-19 21:37:04 +02:00
|
|
|
def theme_color
|
|
|
|
theme = get_active_theme
|
|
|
|
if theme
|
2021-08-13 01:23:07 +02:00
|
|
|
theme.theme_color
|
2021-06-19 21:37:04 +02:00
|
|
|
else
|
|
|
|
'#5e35b1'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2021-08-06 00:36:20 +02:00
|
|
|
def mobile_theme_color
|
|
|
|
theme = get_active_theme
|
|
|
|
if theme
|
2021-08-13 01:23:07 +02:00
|
|
|
theme.mobile_theme_color
|
2021-08-06 00:36:20 +02:00
|
|
|
else
|
|
|
|
'#f0edf4'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-05-03 17:28:41 +02:00
|
|
|
def get_active_theme
|
2020-05-05 20:17:49 +02:00
|
|
|
if @user&.theme
|
2020-05-03 17:28:41 +02:00
|
|
|
if user_signed_in?
|
2020-05-05 20:17:49 +02:00
|
|
|
if current_user&.show_foreign_themes?
|
|
|
|
@user.theme
|
|
|
|
else
|
|
|
|
current_user&.theme
|
|
|
|
end
|
2020-05-03 17:28:41 +02:00
|
|
|
else
|
|
|
|
@user.theme
|
|
|
|
end
|
2021-12-30 01:41:27 +01:00
|
|
|
elsif @answer&.user&.theme
|
|
|
|
if user_signed_in?
|
|
|
|
if current_user&.show_foreign_themes?
|
|
|
|
@answer.user.theme
|
|
|
|
else
|
|
|
|
current_user&.theme
|
|
|
|
end
|
|
|
|
else
|
|
|
|
@answer.user.theme
|
|
|
|
end
|
2020-05-05 20:17:49 +02:00
|
|
|
elsif current_user&.theme
|
|
|
|
current_user.theme
|
2020-05-03 17:28:41 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def get_hex_color_from_theme_value(value)
|
2021-06-19 21:37:04 +02:00
|
|
|
("0000000#{value.to_s(16)}")[-6, 6]
|
2020-05-03 17:28:41 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
def get_decimal_triplet_from_hex(value)
|
|
|
|
hexes = value.split(/(.{2})/).reject { |c| c.empty? }
|
2021-06-19 21:37:04 +02:00
|
|
|
hexes.map(&:hex).join(', ')
|
2020-05-03 17:28:41 +02:00
|
|
|
end
|
2021-04-04 16:23:11 +02:00
|
|
|
|
|
|
|
def rgb_values_from_hex(value)
|
|
|
|
[
|
|
|
|
(value & 0xFF0000) >> 16, # R
|
|
|
|
(value & 0x00FF00) >> 8, # G
|
|
|
|
value & 0x0000FF # B
|
|
|
|
]
|
|
|
|
end
|
|
|
|
|
|
|
|
def rgb_to_hex(rgb_values)
|
|
|
|
rgb_values.map.with_index { |v, i| v << (2 - i) * 8 }.reduce(&:+).to_s(16)
|
|
|
|
end
|
|
|
|
|
|
|
|
def lighten(value, amount = 0.25)
|
|
|
|
rgb_to_hex(rgb_values_from_hex(value).map { |v| [(v + 255 * amount).round, 255].min })
|
|
|
|
end
|
2015-07-29 18:54:33 +02:00
|
|
|
end
|