Skip to content

Commit

Permalink
fix: tabs persistence when tab name have spaces
Browse files Browse the repository at this point in the history
  • Loading branch information
Paul-Bob committed Dec 21, 2023
1 parent b74d542 commit 679b425
Show file tree
Hide file tree
Showing 4 changed files with 29 additions and 8 deletions.
6 changes: 2 additions & 4 deletions app/components/avo/tab_group_component.rb
Expand Up @@ -7,6 +7,8 @@ class Avo::TabGroupComponent < Avo::BaseComponent
attr_reader :form
attr_reader :resource

delegate :group_param, to: :@group

def initialize(resource:, group:, index:, form:, params:, view:)
@resource = resource
@group = group
Expand All @@ -26,10 +28,6 @@ def tabs_have_content?
visible_tabs.present?
end

def group_param
group.id
end

def active_tab_name
CGI.unescape(params[group_param] || group.visible_items&.first&.name)
end
Expand Down
5 changes: 1 addition & 4 deletions app/components/avo/tab_switcher_component.rb
Expand Up @@ -12,6 +12,7 @@ class Avo::TabSwitcherComponent < Avo::BaseComponent
attr_reader :resource

delegate :white_panel_classes, to: :helpers
delegate :group_param, to: :@group

def initialize(resource:, group:, current_tab:, active_tab_name:, view:)
@active_tab_name = active_tab_name
Expand Down Expand Up @@ -48,10 +49,6 @@ def current_one?(tab)

private

def group_param
"tab-group_#{group.id}"
end

def tab_param_missing?
params[group_param].blank?
end
Expand Down
4 changes: 4 additions & 0 deletions lib/avo/resources/items/tab_group.rb
Expand Up @@ -37,6 +37,10 @@ def turbo_frame_id
"#{Avo::Resources::Items::TabGroup.to_s.parameterize} #{index}".parameterize
end

def group_param
"tab-group_#{id}"
end

class Builder
include Avo::Concerns::BorrowItemsHolder

Expand Down
22 changes: 22 additions & 0 deletions spec/system/avo/tabs_spec.rb
Expand Up @@ -140,4 +140,26 @@
find('a[data-selected="true"][data-tabs-tab-name-param="Posts"]')
end
end

describe "tabs with names that have spaces" do
it "keeps tab on reload" do
visit avo.resources_user_path user

find('a[data-selected="true"][data-tabs-tab-name-param="Fish"]')
find('a[data-selected="false"][data-tabs-tab-name-param="Projects"]').click
find('a[data-selected="false"][data-tabs-tab-name-param="Team memberships"]')

refresh

find('a[data-selected="false"][data-tabs-tab-name-param="Fish"]')
find('a[data-selected="true"][data-tabs-tab-name-param="Projects"]')
find('a[data-selected="false"][data-tabs-tab-name-param="Team memberships"]').click

refresh

find('a[data-selected="false"][data-tabs-tab-name-param="Fish"]')
find('a[data-selected="false"][data-tabs-tab-name-param="Projects"]')
find('a[data-selected="true"][data-tabs-tab-name-param="Team memberships"]')
end
end
end

0 comments on commit 679b425

Please sign in to comment.