Use CSS instead of server requests for image format in pet styles form

Instead of offering a form to request a different format, we just
render both in the HTML, and use CSS to swap between the two. Love to
see the `:has` filter come through for us!
This commit is contained in:
Emi Matchu 2025-01-02 19:04:48 -08:00
parent 7f62417294
commit 5be35591c2
2 changed files with 26 additions and 22 deletions

View file

@ -1,5 +1,4 @@
@import "../partials/clean/constants" @import "../partials/clean/constants"
@import "../partials/context_button"
support-outfit-viewer support-outfit-viewer
display: flex display: flex
@ -39,8 +38,16 @@ support-outfit-viewer
input[type=radio] input[type=radio]
margin: 0 margin: 0
[type=submit] .outfit-viewer-area
+context-button > [data-format=png]
display: none
&:has(input[value=png]:checked)
.outfit-viewer-area
> [data-format=svg]
display: none
> [data-format=png]
display: block
> table > table
flex: 0 0 auto flex: 0 0 auto

View file

@ -1,24 +1,21 @@
= content_tag "support-outfit-viewer", **html_options do = content_tag "support-outfit-viewer", **html_options do
= turbo_frame_tag "support-outfit-viewer-preview" do
%div %div
-# Render an outfit viewer in a magnifier. Use SVG by default for clarity, .outfit-viewer-area
-# but also offer an option to switch to PNG if it looks wrong. %magic-magnifier{"data-format": "svg"}
%magic-magnifier = outfit_viewer outfit, preferred_image_format: :svg
= outfit_viewer outfit, %magic-magnifier{"data-format": "png"}
preferred_image_format: params[:preferred_image_format] == "png" ? :png : :svg = outfit_viewer outfit, preferred_image_format: :png
= form_with method: :get, class: "outfit-viewer-controls" do |f| = form_with method: :get, class: "outfit-viewer-controls" do |f|
%fieldset %fieldset
%legend Format %legend Format
%label %label
= f.radio_button "preferred_image_format", "svg", = f.radio_button "preferred_image_format", "svg",
checked: params[:preferred_image_format] != "png" checked: true
SVG SVG
%label %label
= f.radio_button "preferred_image_format", "png", = f.radio_button "preferred_image_format", "png"
checked: params[:preferred_image_format] == "png"
PNG PNG
= f.submit "Update"
%table %table
%thead %thead