From 1c7c0dc9d741ffa36a8e0541e87db7c0296ea58a Mon Sep 17 00:00:00 2001 From: Thomas von Deyen Date: Thu, 29 Feb 2024 08:24:12 +0100 Subject: [PATCH] Fix datepicker in resource forms The attribute that the `` custom element needs to init the appropriate Datepickr type is called `input-type` and not a `data-` attribute anymore. (cherry picked from commit 5791a1310d66cff37ec28ab692e2589a0cf42323) --- lib/alchemy/forms/builder.rb | 2 +- lib/alchemy/resources_helper.rb | 7 +------ spec/features/admin/resources_integration_spec.rb | 10 +++++----- spec/libraries/forms/builder_spec.rb | 2 +- spec/libraries/resources_helper_spec.rb | 15 +++------------ 5 files changed, 11 insertions(+), 25 deletions(-) diff --git a/lib/alchemy/forms/builder.rb b/lib/alchemy/forms/builder.rb index a82548fa7b..f63db56843 100644 --- a/lib/alchemy/forms/builder.rb +++ b/lib/alchemy/forms/builder.rb @@ -40,7 +40,7 @@ def datepicker(attribute_name, options = {}) }.merge(options[:input_html] || {}) date_field = input attribute_name, as: :string, input_html: input_options - template.content_tag("alchemy-datepicker", date_field, type: type) + template.content_tag("alchemy-datepicker", date_field, "input-type" => type) end # Renders a simple_form input that displays a richtext editor diff --git a/lib/alchemy/resources_helper.rb b/lib/alchemy/resources_helper.rb index 4da59f265f..102e3946c4 100644 --- a/lib/alchemy/resources_helper.rb +++ b/lib/alchemy/resources_helper.rb @@ -107,12 +107,7 @@ def resource_attribute_field_options(attribute) when "boolean" options when "date", "time", "datetime" - options.merge( - as: "string", - input_html: { - data: {datepicker_type: input_type} - } - ) + options.merge(as: input_type) when "text" options.merge(as: "text", input_html: {rows: 4}) else diff --git a/spec/features/admin/resources_integration_spec.rb b/spec/features/admin/resources_integration_spec.rb index de43c713e1..d993bec491 100644 --- a/spec/features/admin/resources_integration_spec.rb +++ b/spec/features/admin/resources_integration_spec.rb @@ -176,12 +176,12 @@ it "renders an input field according to the attribute's type" do visit "/admin/events/new" expect(page).to have_selector('input#event_name[type="text"]') - expect(page).to have_selector('input#event_starts_at[data-datepicker-type="datetime"]') - expect(page).to have_selector('input#event_ends_at[data-datepicker-type="datetime"]') + expect(page).to have_selector('alchemy-datepicker[input-type="datetime"] input#event_starts_at') + expect(page).to have_selector('alchemy-datepicker[input-type="datetime"] input#event_ends_at') expect(page).to have_selector("textarea#event_description") expect(page).to have_selector('input#event_published[type="checkbox"]') - expect(page).to have_selector('input#event_lunch_starts_at[data-datepicker-type="time"]') - expect(page).to have_selector('input#event_lunch_ends_at[data-datepicker-type="time"]') + expect(page).to have_selector('alchemy-datepicker[input-type="time"] input#event_lunch_starts_at') + expect(page).to have_selector('alchemy-datepicker[input-type="time"] input#event_lunch_ends_at') end it "should have a select box for associated models" do @@ -202,7 +202,7 @@ describe "date fields" do it "have date picker" do visit "/admin/bookings/new" - expect(page).to have_selector('input#booking_from[data-datepicker-type="date"]') + expect(page).to have_selector('alchemy-datepicker[input-type="date"] input#booking_from') end end end diff --git a/spec/libraries/forms/builder_spec.rb b/spec/libraries/forms/builder_spec.rb index d4f8e705ca..243b16e7e8 100644 --- a/spec/libraries/forms/builder_spec.rb +++ b/spec/libraries/forms/builder_spec.rb @@ -8,7 +8,7 @@ shared_examples_for "datepicker expect" do it "has the alchemy-datepicker" do - expect(template).to receive(:content_tag).with("alchemy-datepicker", "", {type: type}) + expect(template).to receive(:content_tag).with("alchemy-datepicker", "", {"input-type" => type}) subject end diff --git a/spec/libraries/resources_helper_spec.rb b/spec/libraries/resources_helper_spec.rb index 3f0c72ff92..0077cb5736 100644 --- a/spec/libraries/resources_helper_spec.rb +++ b/spec/libraries/resources_helper_spec.rb @@ -284,10 +284,7 @@ def resource_handler is_expected.to match( hash_including( hint: nil, - as: "string", - input_html: { - data: {datepicker_type: "date"} - } + as: "date" ) ) end @@ -304,10 +301,7 @@ def resource_handler is_expected.to match( hash_including( hint: nil, - as: "string", - input_html: { - data: {datepicker_type: "datetime"} - } + as: "datetime" ) ) end @@ -324,10 +318,7 @@ def resource_handler is_expected.to match( hash_including( hint: nil, - as: "string", - input_html: { - data: {datepicker_type: "time"} - } + as: "time" ) ) end