From 7b5b3dbc1d57e384f880aa8e6b156167046afe65 Mon Sep 17 00:00:00 2001 From: Thomas von Deyen Date: Fri, 12 Jan 2024 12:32:04 +0100 Subject: [PATCH 1/6] Use title attribute for link_to_dialog tooltip If a `title` is passed as `html_options` to `link_to_dialog` helper we use that to create a `sl-tooltip`. This way we can progresivly enhance Alchemy extensions and modules to use the new UI Tooltips instead of titles but keep downwards compatibility. --- app/helpers/alchemy/admin/base_helper.rb | 17 ++++++++++++----- .../admin/partials/_toolbar_button.html.erb | 1 - spec/helpers/alchemy/admin/base_helper_spec.rb | 16 ++++++++++++++++ 3 files changed, 28 insertions(+), 6 deletions(-) diff --git a/app/helpers/alchemy/admin/base_helper.rb b/app/helpers/alchemy/admin/base_helper.rb index 8557571da1..79c1f105c9 100644 --- a/app/helpers/alchemy/admin/base_helper.rb +++ b/app/helpers/alchemy/admin/base_helper.rb @@ -54,11 +54,18 @@ def current_alchemy_user_name def link_to_dialog(content, url, options = {}, html_options = {}) default_options = {modal: true} options = default_options.merge(options) - link_to content, url, - html_options.merge( - "data-dialog-options" => options.to_json, - :is => "alchemy-dialog-link" - ) + if html_options[:title] + tooltip = html_options.delete(:title) + end + anchor = link_to(content, url, html_options.merge( + "data-dialog-options" => options.to_json, + :is => "alchemy-dialog-link" + )) + if tooltip + content_tag("sl-tooltip", anchor, content: tooltip) + else + anchor + end end # Used for translations selector in Alchemy cockpit user settings. diff --git a/app/views/alchemy/admin/partials/_toolbar_button.html.erb b/app/views/alchemy/admin/partials/_toolbar_button.html.erb index bcc1e1204a..1a66d0d1e6 100644 --- a/app/views/alchemy/admin/partials/_toolbar_button.html.erb +++ b/app/views/alchemy/admin/partials/_toolbar_button.html.erb @@ -7,7 +7,6 @@ options[:dialog_options], { class: ["icon_button", options[:active] && "active"].compact, - title: options[:title], "data-alchemy-hotkey" => options[:hotkey] }.merge(options[:link_options]) ) %> diff --git a/spec/helpers/alchemy/admin/base_helper_spec.rb b/spec/helpers/alchemy/admin/base_helper_spec.rb index 81bf791786..3dc8658fa2 100644 --- a/spec/helpers/alchemy/admin/base_helper_spec.rb +++ b/spec/helpers/alchemy/admin/base_helper_spec.rb @@ -19,6 +19,22 @@ module Alchemy link = helper.link_to_dialog("Open", admin_dashboard_path, {}, {id: "my-link"}) expect(link).to have_css("a#my-link") end + + context "with title in html options" do + it "passes html title to sl-tooltip" do + link = helper.link_to_dialog("Open", admin_dashboard_path, {}, {title: "Open Me"}) + expect(link).to have_css("sl-tooltip[content='Open Me']") + expect(link).to_not have_css("a[title='Open Me']") + end + end + + context "without title in html options" do + it "has no sl-toolip" do + link = helper.link_to_dialog("Open", admin_dashboard_path, {}, {}) + expect(link).to_not have_css("sl-tooltip") + expect(link).to_not have_css("a[title]") + end + end end describe "#toolbar_button" do From d2f4f53a9da065b08e83145726108e4de8cdc2d4 Mon Sep 17 00:00:00 2001 From: Thomas von Deyen Date: Fri, 12 Jan 2024 15:19:38 +0100 Subject: [PATCH 2/6] Fix leave admin icon --- app/views/layouts/alchemy/admin.html.erb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/views/layouts/alchemy/admin.html.erb b/app/views/layouts/alchemy/admin.html.erb index dcbc372f7d..29fc1bdaad 100644 --- a/app/views/layouts/alchemy/admin.html.erb +++ b/app/views/layouts/alchemy/admin.html.erb @@ -55,7 +55,7 @@ }, {'data-alchemy-hotkey' => 'alt+q'}) %> <% else %> <%= link_to(alchemy.root_path) do %> - + <% end %> <% end %> From d476d0fbd9766cb98e43fb1549b6da44503d3585 Mon Sep 17 00:00:00 2001 From: Thomas von Deyen Date: Fri, 12 Jan 2024 21:26:12 +0100 Subject: [PATCH 3/6] Fix click_button_with_tooltip test helper Make it work with buttons nested in a form as well, like the delete button. --- lib/alchemy/test_support/capybara_helpers.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/alchemy/test_support/capybara_helpers.rb b/lib/alchemy/test_support/capybara_helpers.rb index 1587606ac3..4ccdd4c5d1 100644 --- a/lib/alchemy/test_support/capybara_helpers.rb +++ b/lib/alchemy/test_support/capybara_helpers.rb @@ -47,7 +47,7 @@ def select2_search(value, options) end def click_button_with_tooltip(content) - find(%([content="#{content}"] > button)).click + find(%([content="#{content}"] button)).click end def click_link_with_tooltip(content) From 3f4ba757d7993bb0c38c4b06af94c01c686ff3c4 Mon Sep 17 00:00:00 2001 From: Thomas von Deyen Date: Fri, 12 Jan 2024 15:31:10 +0100 Subject: [PATCH 4/6] Use title attribute for delete_button tooltip If a `title` is passed as `html_options` to `delete_button` helper we use that to create a `sl-tooltip`. This way we can progresivly enhance Alchemy extensions and modules to use the new UI Tooltips instead of titles but keep downwards compatibility. --- app/helpers/alchemy/admin/base_helper.rb | 16 +++++++++----- .../admin/resources_integration_spec.rb | 2 +- .../helpers/alchemy/admin/base_helper_spec.rb | 22 +++++++++++++++++++ 3 files changed, 34 insertions(+), 6 deletions(-) diff --git a/app/helpers/alchemy/admin/base_helper.rb b/app/helpers/alchemy/admin/base_helper.rb index 79c1f105c9..84569e1e65 100644 --- a/app/helpers/alchemy/admin/base_helper.rb +++ b/app/helpers/alchemy/admin/base_helper.rb @@ -201,16 +201,22 @@ def delete_button(url, options = {}, html_options = {}) message: Alchemy.t("Are you sure?"), icon: "delete-bin-2" }.merge(options) - button_with_confirm( + + if html_options[:title] + tooltip = html_options.delete(:title) + end + button = button_with_confirm( render_icon(options[:icon]), - url, { - message: options[:message] - }, { + url, options, { method: "delete", - title: options[:title], class: "icon_button #{html_options.delete(:class)}".strip }.merge(html_options) ) + if tooltip + content_tag("sl-tooltip", button, content: tooltip) + else + button + end end # (internal) Renders translated Module Names for html title element. diff --git a/spec/features/admin/resources_integration_spec.rb b/spec/features/admin/resources_integration_spec.rb index e78c2a9d15..de43c713e1 100644 --- a/spec/features/admin/resources_integration_spec.rb +++ b/spec/features/admin/resources_integration_spec.rb @@ -273,7 +273,7 @@ second_event visit "/admin/events" within("tr", text: "My second Event") do - click_on "Delete" + click_button_with_tooltip "Delete" end end diff --git a/spec/helpers/alchemy/admin/base_helper_spec.rb b/spec/helpers/alchemy/admin/base_helper_spec.rb index 3dc8658fa2..51fecba78c 100644 --- a/spec/helpers/alchemy/admin/base_helper_spec.rb +++ b/spec/helpers/alchemy/admin/base_helper_spec.rb @@ -149,6 +149,28 @@ module Alchemy it "returns a form tag with method=delete" do is_expected.to have_selector('form input[name="_method"][value="delete"]') end + + context "with title in html options" do + subject(:button) do + delete_button("/admin/pages", {}, {title: "Open Me"}) + end + + it "passes html title to sl-tooltip" do + expect(button).to have_css("sl-tooltip[content='Open Me']") + expect(button).to_not have_css("button[title='Open Me']") + end + end + + context "without title in html options" do + subject(:button) do + delete_button("/admin/pages", {}, {}) + end + + it "has no sl-toolip" do + expect(button).to_not have_css("sl-tooltip") + expect(button).to_not have_css("button[title]") + end + end end describe "#alchemy_datepicker" do From 11fccadb1bf874b8ed76bb47a5c468323be541ab Mon Sep 17 00:00:00 2001 From: Thomas von Deyen Date: Fri, 12 Jan 2024 15:31:30 +0100 Subject: [PATCH 5/6] Fix create menu button tooltip placement --- app/views/alchemy/admin/nodes/index.html.erb | 1 + 1 file changed, 1 insertion(+) diff --git a/app/views/alchemy/admin/nodes/index.html.erb b/app/views/alchemy/admin/nodes/index.html.erb index 2f65d89030..36e9849feb 100644 --- a/app/views/alchemy/admin/nodes/index.html.erb +++ b/app/views/alchemy/admin/nodes/index.html.erb @@ -11,6 +11,7 @@ label: Alchemy.t(:create_menu), url: alchemy.new_admin_node_path, hotkey: 'alt+n', + tooltip_placement: "top-start", dialog_options: { title: Alchemy.t(:create_menu), size: '450x120' From 281fc48e350cab0c65a64c9a40f726e7bbc758a7 Mon Sep 17 00:00:00 2001 From: Thomas von Deyen Date: Sun, 14 Jan 2024 21:17:00 +0100 Subject: [PATCH 6/6] Fix width of js_filter_field in tags edit dialog We changed the selector for form fields inside of forms in dialogs to support tooltips in 69cbb1dfed60c67e5135d23d7a07926120f878ab --- app/assets/stylesheets/alchemy/filter_field.scss | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/app/assets/stylesheets/alchemy/filter_field.scss b/app/assets/stylesheets/alchemy/filter_field.scss index 7a9ba47de5..a6e8b7f2f2 100644 --- a/app/assets/stylesheets/alchemy/filter_field.scss +++ b/app/assets/stylesheets/alchemy/filter_field.scss @@ -14,6 +14,11 @@ padding-left: 28px; padding-right: 24px; margin: 0; + + .input & { + float: none; + width: 100%; + } } .js_filter_field_clear {