From ce83418f0b1a3f7c33515c81519b92be0ff26a79 Mon Sep 17 00:00:00 2001 From: Alex Hatzenbuhler Date: Fri, 25 Apr 2025 09:15:48 -0500 Subject: [PATCH] Improve theme selection (#2152) * Improve theme selectin * Use HTML form labels and the existing auto-submit controller --- app/views/settings/preferences/show.html.erb | 45 ++++++++++---------- 1 file changed, 22 insertions(+), 23 deletions(-) diff --git a/app/views/settings/preferences/show.html.erb b/app/views/settings/preferences/show.html.erb index 99857aba..169df40a 100644 --- a/app/views/settings/preferences/show.html.erb +++ b/app/views/settings/preferences/show.html.erb @@ -42,30 +42,29 @@ <% end %> <%= settings_section title: t(".theme_title"), subtitle: t(".theme_subtitle") do %> -
- <%= styled_form_with model: @user, class: "flex flex-col md:flex-row justify-between items-center gap-4", data: { controller: "auto-submit-form" } do |form| %> +
+ <%= form_with model: @user, class: "flex flex-col md:flex-row justify-between items-center gap-4", id: "theme_form", + data: { controller: "auto-submit-form", auto_submit_form_trigger_event_value: "change" } do |form| %> <%= form.hidden_field :redirect_to, value: "preferences" %> -
- <%= image_tag("light-mode-preview.png", alt: "Light Theme Preview", class: "h-44 mb-4") %> -
- <%= form.radio_button :theme, "light", checked: @user.theme == "light", data: { auto_submit_form_target: "auto", action: "theme#updateTheme" } %> - <%= form.label :theme_light, t(".theme_light"), value: "light" %> -
-
-
- <%= image_tag("dark-mode-preview.png", alt: "Dark Theme Preview", class: "h-44 mb-4") %> -
- <%= form.radio_button :theme, "dark", checked: @user.theme == "dark", data: { auto_submit_form_target: "auto", action: "theme#updateTheme" } %> - <%= form.label :theme_dark, t(".theme_dark"), value: "dark" %> -
-
-
- <%= image_tag("system-mode-preview.png", alt: "System Theme Preview", class: "h-44 mb-4") %> -
- <%= form.radio_button :theme, "system", checked: @user.theme == "system", data: { auto_submit_form_target: "auto", action: "theme#updateTheme" } %> - <%= form.label :theme_system, t(".theme_system"), value: "system" %> -
-
+ + <% theme_option_class = "text-center transition-all duration-200 p-3 rounded-lg hover:bg-surface-hover cursor-pointer [&:has(input:checked)]:bg-surface-hover [&:has(input:checked)]:border [&:has(input:checked)]:border-primary [&:has(input:checked)]:shadow-xs" %> + + <% [ + { value: "light", image: "light-mode-preview.png" }, + { value: "dark", image: "dark-mode-preview.png" }, + { value: "system", image: "system-mode-preview.png" } + ].each do |theme| %> + <%= form.label :"theme_#{theme[:value]}", class: "group" do %> +
+ <%= image_tag(theme[:image], alt: "#{theme[:value].titleize} Theme Preview", class: "h-44 mb-2") %> +
+ <%= form.radio_button :theme, theme[:value], checked: @user.theme == theme[:value], class: "sr-only", + data: { auto_submit_form_target: "auto", autosubmit_trigger_event: "change", action: "theme#updateTheme" } %> + <%= t(".theme_#{theme[:value]}") %> +
+
+ <% end %> + <% end %> <% end %>
<% end %>