playbook_ui 14.21.2 → 14.22.0.pre.alpha.PLAY2248railstooltipclicktoopen8667
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/app/pb_kits/playbook/_playbook.scss +0 -1
- data/app/pb_kits/playbook/pb_advanced_table/Components/CustomCell.tsx +11 -9
- data/app/pb_kits/playbook/pb_advanced_table/Components/RegularTableView.tsx +20 -4
- data/app/pb_kits/playbook/pb_advanced_table/Components/SubRowHeaderRow.tsx +32 -11
- data/app/pb_kits/playbook/pb_advanced_table/Components/TableHeaderCell.tsx +25 -5
- data/app/pb_kits/playbook/pb_advanced_table/Components/VirtualizedTableView.tsx +36 -16
- data/app/pb_kits/playbook/pb_advanced_table/Context/AdvancedTableContext.tsx +18 -5
- data/app/pb_kits/playbook/pb_advanced_table/Hooks/useTableActions.ts +37 -17
- data/app/pb_kits/playbook/pb_advanced_table/Hooks/useTableState.ts +32 -7
- data/app/pb_kits/playbook/pb_advanced_table/SubKits/TableBody.tsx +3 -0
- data/app/pb_kits/playbook/pb_advanced_table/SubKits/TableHeader.tsx +91 -40
- data/app/pb_kits/playbook/pb_advanced_table/Utilities/CellRendererUtils.tsx +4 -1
- data/app/pb_kits/playbook/pb_advanced_table/Utilities/ColumnStylingHelper.ts +15 -0
- data/app/pb_kits/playbook/pb_advanced_table/Utilities/TableContainerStyles.ts +3 -2
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +68 -6
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +42 -18
- data/app/pb_kits/playbook/pb_advanced_table/advanced_table.test.jsx +105 -2
- data/app/pb_kits/playbook/pb_advanced_table/advanced_table_action_bar.js +36 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta_sort.html.erb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta_subrow_headers.html.erb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_border_color_rails.html.erb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling.jsx +51 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling.md +7 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_column_headers.jsx +77 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_column_headers.md +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_column_headers_rails.html.erb +63 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_column_headers_rails.md +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_rails.html.erb +38 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_rails.md +7 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_custom_sort.jsx +65 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_custom_sort.md +5 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_infinite_scroll.md +3 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_loading.html.erb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_pinned_rows.jsx +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_pinned_rows_react.md +5 -3
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_row_styling.jsx +64 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_row_styling.md +7 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_actions.jsx +2 -2
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_actions_rails.html.erb +3 -2
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_sticky_header.html.erb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header.jsx +69 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header.md +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +8 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/index.js +6 -0
- data/app/pb_kits/playbook/pb_advanced_table/flat_advanced_table.js +60 -84
- data/app/pb_kits/playbook/pb_advanced_table/index.js +125 -213
- data/app/pb_kits/playbook/pb_advanced_table/scss_partials/advanced_table_sticky_mixin.scss +16 -1
- data/app/pb_kits/playbook/pb_advanced_table/table_action_bar.html.erb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/table_header.html.erb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/table_header.rb +5 -0
- data/app/pb_kits/playbook/pb_advanced_table/table_row.html.erb +3 -3
- data/app/pb_kits/playbook/pb_advanced_table/table_row.rb +33 -0
- data/app/pb_kits/playbook/pb_contact/contact.test.js +2 -2
- data/app/pb_kits/playbook/pb_dashboard/pbChartsDarkTheme.ts +1 -39
- data/app/pb_kits/playbook/pb_dashboard/pbChartsLightTheme.ts +1 -39
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_blank_selection.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_blank_selection.jsx +7 -4
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_clear_selection.jsx +6 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default.jsx +6 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default_rails.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default_value.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default_value.jsx +7 -4
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_error.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_error.jsx +7 -4
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select.jsx +19 -10
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_display.jsx +19 -10
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_display_rails.html.erb +10 -10
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_rails.html.erb +10 -10
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_autocomplete.html.erb +10 -10
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_autocomplete.jsx +20 -11
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_custom_options.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_custom_options.jsx +8 -8
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_default.html.erb +10 -10
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_default.jsx +23 -14
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_separators_hidden.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_separators_hidden.jsx +6 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_subcomponent_structure.jsx +6 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_subcomponent_structure_rails.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_subtle_variant.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_subtle_variant.jsx +6 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete.jsx +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_with_subcomponents.html.erb +4 -4
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_with_subcomponents.jsx +4 -4
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.jsx +4 -4
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display_rails.html.erb +4 -4
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_icon_options.html.erb +52 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_icon_options.jsx +99 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_icon_options_rails.md +1 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_icon_options_react.md +1 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_options.jsx +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_options_rails.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_padding.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_padding.jsx +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_radio_options.html.erb +28 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_radio_options.jsx +47 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_radio_options_rails.md +1 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_radio_options_react.md +1 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_trigger.jsx +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_trigger_rails.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_external_control.jsx +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_label.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_label.jsx +6 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_search.jsx +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_search_rails.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/docs/example.yml +4 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/index.js +3 -1
- data/app/pb_kits/playbook/pb_filter/Filter/FilterSection.tsx +49 -0
- data/app/pb_kits/playbook/pb_filter/Filter/FilterSidebar.tsx +69 -0
- data/app/pb_kits/playbook/pb_filter/Filter/index.tsx +13 -0
- data/app/pb_kits/playbook/pb_filter/_filter.scss +4 -0
- data/app/pb_kits/playbook/pb_filter/docs/_filter_sidebar.jsx +224 -0
- data/app/pb_kits/playbook/pb_filter/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_filter/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_filter/filter.test.js +2 -2
- data/app/pb_kits/playbook/pb_table/_table.tsx +4 -4
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_columns.html.erb +8 -8
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_columns.jsx +8 -8
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_columns_rails.md +1 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_columns_react.md +1 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns.html.erb +12 -12
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns.jsx +12 -12
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns_rails.md +2 -2
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns_react.md +3 -3
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns.html.erb +12 -12
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns.jsx +12 -12
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns_rails.md +2 -2
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns_react.md +3 -3
- data/app/pb_kits/playbook/pb_table/index.ts +4 -4
- data/app/pb_kits/playbook/pb_table/styles/_table-card.scss +11 -0
- data/app/pb_kits/playbook/pb_table/styles/_vertical_border.scss +4 -0
- data/app/pb_kits/playbook/pb_tooltip/_tooltip.tsx +34 -22
- data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_click_open.html.erb +14 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_click_open.jsx +25 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_click_open_rails.md +1 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_click_open_react.md +1 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_tooltip/index.js +59 -36
- data/app/pb_kits/playbook/pb_tooltip/tooltip.rb +9 -2
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_preserve_input.html.erb +18 -0
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_preserve_input_rails.md +1 -0
- data/app/pb_kits/playbook/pb_typeahead/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_typeahead/typeahead.rb +3 -0
- data/dist/chunks/_typeahead-CJa1XdQQ.js +22 -0
- data/dist/chunks/_weekday_stacked-DEFOs-MK.js +45 -0
- data/dist/chunks/lazysizes-B7xYodB-.js +1 -0
- data/dist/chunks/lib-LHsP11gB.js +29 -0
- data/dist/chunks/{pb_form_validation-DyvJ8iPe.js → pb_form_validation-BHrTZlH7.js} +1 -1
- data/dist/chunks/vendor.js +1 -1
- data/dist/menu.yml +0 -9
- data/dist/playbook-doc.js +3 -3
- data/dist/playbook-rails-react-bindings.js +1 -1
- data/dist/playbook-rails.js +1 -1
- data/dist/playbook.css +1 -1
- data/lib/playbook/version.rb +2 -2
- metadata +42 -31
- data/app/pb_kits/playbook/pb_treemap_chart/_treemap_chart.scss +0 -14
- data/app/pb_kits/playbook/pb_treemap_chart/_treemap_chart.tsx +0 -119
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_description.md +0 -5
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_colors.html.erb +0 -37
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_colors.jsx +0 -48
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_colors.md +0 -2
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_default.html.erb +0 -37
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_default.jsx +0 -47
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_default.md +0 -3
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_drillable.html.erb +0 -79
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_drillable.jsx +0 -90
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_drillable.md +0 -1
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_grouped_data.html.erb +0 -54
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_grouped_data.jsx +0 -65
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_grouped_data.md +0 -3
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_tooltip.html.erb +0 -37
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_tooltip.jsx +0 -48
- data/app/pb_kits/playbook/pb_treemap_chart/docs/_treemap_chart_tooltip.md +0 -3
- data/app/pb_kits/playbook/pb_treemap_chart/docs/example.yml +0 -15
- data/app/pb_kits/playbook/pb_treemap_chart/docs/index.js +0 -5
- data/app/pb_kits/playbook/pb_treemap_chart/treemapChart.test.js +0 -63
- data/app/pb_kits/playbook/pb_treemap_chart/treemap_chart.html.erb +0 -1
- data/app/pb_kits/playbook/pb_treemap_chart/treemap_chart.rb +0 -48
- data/dist/chunks/_typeahead-BlPRej0F.js +0 -22
- data/dist/chunks/_weekday_stacked-CzxoxxCR.js +0 -45
- data/dist/chunks/lazysizes-DHz07jlL.js +0 -1
- data/dist/chunks/lib-D4vXIZF5.js +0 -29
- /data/app/pb_kits/playbook/pb_typeahead/docs/{_typeahead_preserve_input.md → _typeahead_preserve_input_react.md} +0 -0
| @@ -0,0 +1,224 @@ | |
| 1 | 
            +
            import React, { useState } from 'react'
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            import Filter from '../../pb_filter/_filter'
         | 
| 4 | 
            +
            import Select from '../../pb_select/_select'
         | 
| 5 | 
            +
            import TextInput from '../../pb_text_input/_text_input'
         | 
| 6 | 
            +
            import useCollapsible from '../../pb_collapsible/useCollapsible'
         | 
| 7 | 
            +
            import SectionSeparator from '../../pb_section_separator/_section_separator'
         | 
| 8 | 
            +
            import Checkbox from '../../pb_checkbox/_checkbox'
         | 
| 9 | 
            +
            import Flex from '../../pb_flex/_flex'
         | 
| 10 | 
            +
            import Table from '../../pb_table/_table'
         | 
| 11 | 
            +
            import Caption from '../../pb_caption/_caption'
         | 
| 12 | 
            +
            import Icon from '../../pb_icon/_icon'
         | 
| 13 | 
            +
             | 
| 14 | 
            +
            const people = [
         | 
| 15 | 
            +
              { name: 'Hera Syndulla', territory: 'A galaxy far far away, like really far away...', products: ['Insulation'] },
         | 
| 16 | 
            +
              { name: 'Kanan Jarrus', territory: 'USA', products: ['Siding', 'Roofing', 'Gutters'] },
         | 
| 17 | 
            +
              { name: 'C1-10P', territory: 'USA', products: ['Roofing'] },
         | 
| 18 | 
            +
              { name: 'Anakin Skywalker', territory: 'A galaxy far far away, like really far away...', products: ['Doors', 'Windows', 'Solar'] },
         | 
| 19 | 
            +
              { name: 'Leia Organa', territory: 'Canada', products: ['Windows', 'Doors'] },
         | 
| 20 | 
            +
              { name: 'Luke Skywalker', territory: 'Brazil', products: ['Solar', 'Roofing'] },
         | 
| 21 | 
            +
              { name: 'Padmé Amidala', territory: 'Philippines', products: ['Siding', 'Gutters'] },
         | 
| 22 | 
            +
              { name: 'Obi-Wan Kenobi', territory: 'USA', products: ['Windows', 'Siding'] },
         | 
| 23 | 
            +
              { name: 'Ahsoka Tano', territory: 'Canada', products: ['Insulation', 'Solar'] },
         | 
| 24 | 
            +
              { name: 'Boba Fett', territory: 'Brazil', products: ['Roofing', 'Gutters'] },
         | 
| 25 | 
            +
              { name: 'Mace Windu', territory: 'Philippines', products: ['Doors', 'Siding'] },
         | 
| 26 | 
            +
              { name: 'Grogu', territory: 'A galaxy far far away, like really far away...', products: ['Insulation'] },
         | 
| 27 | 
            +
              { name: 'Sabine Wren', territory: 'Canada', products: ['Solar', 'Doors'] },
         | 
| 28 | 
            +
              { name: 'C-3PO', territory: 'Brazil', products: ['Windows'] },
         | 
| 29 | 
            +
              { name: 'R2-D2', territory: 'Philippines', products: ['Doors', 'Gutters'] },
         | 
| 30 | 
            +
            ]
         | 
| 31 | 
            +
             | 
| 32 | 
            +
            const FilterSidebar = (props) => {
         | 
| 33 | 
            +
              const [name, setName] = useState('')
         | 
| 34 | 
            +
              const [ territory, setTerritory ] = useState('')
         | 
| 35 | 
            +
              const [ products, setProducts ] = useState({})
         | 
| 36 | 
            +
              const handleUpdateName = ({ target }) => {
         | 
| 37 | 
            +
                setName(target.value)
         | 
| 38 | 
            +
              }
         | 
| 39 | 
            +
              const handleUpdateTerritory = ({ target }) => {
         | 
| 40 | 
            +
                setTerritory(target.value)
         | 
| 41 | 
            +
              }
         | 
| 42 | 
            +
              const handleCheckboxChange = ({ target }) => {
         | 
| 43 | 
            +
                setProducts(prev => ({
         | 
| 44 | 
            +
                  ...prev,
         | 
| 45 | 
            +
                  [target.name]: !prev[target.name],
         | 
| 46 | 
            +
                }))
         | 
| 47 | 
            +
              }
         | 
| 48 | 
            +
              const [isCollapsed, setIsCollapsed] = useCollapsible(true)
         | 
| 49 | 
            +
              const [isProductsCollapsed, setIsProductsCollapsed] = useCollapsible(true)
         | 
| 50 | 
            +
              const options = [
         | 
| 51 | 
            +
                { value: 'USA' },
         | 
| 52 | 
            +
                { value: 'Canada' },
         | 
| 53 | 
            +
                { value: 'Brazil' },
         | 
| 54 | 
            +
                { value: 'Philippines' },
         | 
| 55 | 
            +
                { value: 'A galaxy far far away, like really far away...' },
         | 
| 56 | 
            +
              ]
         | 
| 57 | 
            +
             | 
| 58 | 
            +
              const filteredPeople = people.filter((person) => {
         | 
| 59 | 
            +
                const matchesName = person.name.toLowerCase().includes(name.toLowerCase())
         | 
| 60 | 
            +
             | 
| 61 | 
            +
                const matchesTerritory = territory === '' ? true : person.territory === territory
         | 
| 62 | 
            +
             | 
| 63 | 
            +
                const matchesProducts = Object.values(products).every((product) => !product) ? true : person.products.some(product => products[product])
         | 
| 64 | 
            +
             | 
| 65 | 
            +
                return matchesName && matchesTerritory && matchesProducts
         | 
| 66 | 
            +
              })
         | 
| 67 | 
            +
             | 
| 68 | 
            +
              return (
         | 
| 69 | 
            +
                <>
         | 
| 70 | 
            +
                  <Flex>
         | 
| 71 | 
            +
                    <Filter
         | 
| 72 | 
            +
                        isCollapsed={isCollapsed}
         | 
| 73 | 
            +
                        marginRight="xs"
         | 
| 74 | 
            +
                        onCollapse={() => setIsCollapsed(!isCollapsed)}
         | 
| 75 | 
            +
                        results={filteredPeople.length}
         | 
| 76 | 
            +
                        sortOptions={{
         | 
| 77 | 
            +
                          popularity: 'Popularity',
         | 
| 78 | 
            +
                          // eslint-disable-next-line
         | 
| 79 | 
            +
                          manager_title: 'Manager\'s Title',
         | 
| 80 | 
            +
                          // eslint-disable-next-line
         | 
| 81 | 
            +
                          manager_name: 'Manager\'s Name',
         | 
| 82 | 
            +
                        }}
         | 
| 83 | 
            +
                        sortValue={[{ name: 'popularity', dir: 'desc' }]}
         | 
| 84 | 
            +
                        variant="sidebar"
         | 
| 85 | 
            +
                        width="xs"
         | 
| 86 | 
            +
                        {...props}
         | 
| 87 | 
            +
                    >
         | 
| 88 | 
            +
                      <Filter.Section
         | 
| 89 | 
            +
                          collapsed={isCollapsed}
         | 
| 90 | 
            +
                          headerText="Full Name"
         | 
| 91 | 
            +
                      >
         | 
| 92 | 
            +
                        <TextInput
         | 
| 93 | 
            +
                            onChange={handleUpdateName}
         | 
| 94 | 
            +
                            placeholder="Enter name"
         | 
| 95 | 
            +
                            value={name}
         | 
| 96 | 
            +
                            {...props}
         | 
| 97 | 
            +
                        />
         | 
| 98 | 
            +
                      </Filter.Section>
         | 
| 99 | 
            +
                      <SectionSeparator />
         | 
| 100 | 
            +
                      <Filter.Section
         | 
| 101 | 
            +
                          collapsed={isCollapsed}
         | 
| 102 | 
            +
                          collapsible
         | 
| 103 | 
            +
                          headerText="Territory"
         | 
| 104 | 
            +
                      >
         | 
| 105 | 
            +
                        <Select
         | 
| 106 | 
            +
                            blankSelection="Select One..."
         | 
| 107 | 
            +
                            name="location"
         | 
| 108 | 
            +
                            onChange={handleUpdateTerritory}
         | 
| 109 | 
            +
                            options={options}
         | 
| 110 | 
            +
                            {...props}
         | 
| 111 | 
            +
                        />
         | 
| 112 | 
            +
                      </Filter.Section>
         | 
| 113 | 
            +
                      <SectionSeparator />
         | 
| 114 | 
            +
                      <Filter.Section
         | 
| 115 | 
            +
                          collapsed={isCollapsed}
         | 
| 116 | 
            +
                          collapsible
         | 
| 117 | 
            +
                          headerText="Products"
         | 
| 118 | 
            +
                      >
         | 
| 119 | 
            +
                        <div>
         | 
| 120 | 
            +
                          <Checkbox
         | 
| 121 | 
            +
                              marginBottom="sm"
         | 
| 122 | 
            +
                              name="Doors"
         | 
| 123 | 
            +
                              onChange={handleCheckboxChange}
         | 
| 124 | 
            +
                              text="Doors"
         | 
| 125 | 
            +
                          />
         | 
| 126 | 
            +
                        </div>
         | 
| 127 | 
            +
                        <div>
         | 
| 128 | 
            +
                          <Checkbox
         | 
| 129 | 
            +
                              marginBottom="sm"
         | 
| 130 | 
            +
                              name="Windows"
         | 
| 131 | 
            +
                              onChange={handleCheckboxChange}
         | 
| 132 | 
            +
                              text="Windows"
         | 
| 133 | 
            +
                          />
         | 
| 134 | 
            +
                        </div>
         | 
| 135 | 
            +
                        <div>
         | 
| 136 | 
            +
                          <Checkbox
         | 
| 137 | 
            +
                              marginBottom="sm"
         | 
| 138 | 
            +
                              name="Siding"
         | 
| 139 | 
            +
                              onChange={handleCheckboxChange}
         | 
| 140 | 
            +
                              text="Siding"
         | 
| 141 | 
            +
                          />
         | 
| 142 | 
            +
                        </div>
         | 
| 143 | 
            +
                        {!isProductsCollapsed &&
         | 
| 144 | 
            +
                          <>
         | 
| 145 | 
            +
                            <div>
         | 
| 146 | 
            +
                              <Checkbox
         | 
| 147 | 
            +
                                  checked={products["Roofing"]}
         | 
| 148 | 
            +
                                  marginBottom="sm"
         | 
| 149 | 
            +
                                  name="Roofing"
         | 
| 150 | 
            +
                                  onChange={handleCheckboxChange}
         | 
| 151 | 
            +
                                  text="Roofing"
         | 
| 152 | 
            +
                              />
         | 
| 153 | 
            +
                            </div>
         | 
| 154 | 
            +
                            <div>
         | 
| 155 | 
            +
                              <Checkbox
         | 
| 156 | 
            +
                                  checked={products["Gutters"]}
         | 
| 157 | 
            +
                                  marginBottom="sm"
         | 
| 158 | 
            +
                                  name="Gutters"
         | 
| 159 | 
            +
                                  onChange={handleCheckboxChange}
         | 
| 160 | 
            +
                                  text="Gutters"
         | 
| 161 | 
            +
                              />
         | 
| 162 | 
            +
                            </div>
         | 
| 163 | 
            +
                            <div>
         | 
| 164 | 
            +
                              <Checkbox
         | 
| 165 | 
            +
                                  checked={products["Solar"]}
         | 
| 166 | 
            +
                                  marginBottom="sm"
         | 
| 167 | 
            +
                                  name="Solar"
         | 
| 168 | 
            +
                                  onChange={handleCheckboxChange}
         | 
| 169 | 
            +
                                  text="Solar"
         | 
| 170 | 
            +
                              />
         | 
| 171 | 
            +
                            </div>
         | 
| 172 | 
            +
                            <div>
         | 
| 173 | 
            +
                              <Checkbox
         | 
| 174 | 
            +
                                  checked={products["Insulation"]}
         | 
| 175 | 
            +
                                  marginBottom="sm"
         | 
| 176 | 
            +
                                  name="Insulation"
         | 
| 177 | 
            +
                                  onChange={handleCheckboxChange}
         | 
| 178 | 
            +
                                  text="Insulation"
         | 
| 179 | 
            +
                              />
         | 
| 180 | 
            +
                            </div>
         | 
| 181 | 
            +
                          </>
         | 
| 182 | 
            +
                        }
         | 
| 183 | 
            +
                        <div onClick={() => setIsProductsCollapsed(!isProductsCollapsed)}>
         | 
| 184 | 
            +
                          <Flex
         | 
| 185 | 
            +
                              cursor="pointer"
         | 
| 186 | 
            +
                              marginBottom="sm"
         | 
| 187 | 
            +
                          >
         | 
| 188 | 
            +
                            <Caption
         | 
| 189 | 
            +
                                color="link"
         | 
| 190 | 
            +
                                marginRight="xxs"
         | 
| 191 | 
            +
                                size="xs"
         | 
| 192 | 
            +
                                text={isProductsCollapsed ? "Show More" : "Show Less"}
         | 
| 193 | 
            +
                            />
         | 
| 194 | 
            +
                            <Icon
         | 
| 195 | 
            +
                                icon={isProductsCollapsed ? "chevron-down" : "chevron-up"}
         | 
| 196 | 
            +
                            />
         | 
| 197 | 
            +
                          </Flex>
         | 
| 198 | 
            +
                        </div>
         | 
| 199 | 
            +
                      </Filter.Section>
         | 
| 200 | 
            +
                    </Filter>
         | 
| 201 | 
            +
                    <Table
         | 
| 202 | 
            +
                        size="sm"
         | 
| 203 | 
            +
                    >
         | 
| 204 | 
            +
                      <thead>
         | 
| 205 | 
            +
                        <tr>
         | 
| 206 | 
            +
                          <th>{'Name'}</th>
         | 
| 207 | 
            +
                          <th>{'Territory'}</th>
         | 
| 208 | 
            +
                          <th>{'Products'}</th>
         | 
| 209 | 
            +
                        </tr>
         | 
| 210 | 
            +
                      </thead>
         | 
| 211 | 
            +
                      <tbody>
         | 
| 212 | 
            +
                        {filteredPeople.map((person) => (<tr key={person.name}>
         | 
| 213 | 
            +
                          <td>{ person.name }</td>
         | 
| 214 | 
            +
                          <td>{ person.territory }</td>
         | 
| 215 | 
            +
                          <td>{ person.products.join(", ") }</td>
         | 
| 216 | 
            +
                        </tr>))}
         | 
| 217 | 
            +
                      </tbody>
         | 
| 218 | 
            +
                    </Table>
         | 
| 219 | 
            +
                  </Flex>
         | 
| 220 | 
            +
                </>
         | 
| 221 | 
            +
              )
         | 
| 222 | 
            +
            }
         | 
| 223 | 
            +
             | 
| 224 | 
            +
            export default FilterSidebar
         | 
| @@ -8,3 +8,4 @@ export { default as FilterMaxWidth } from './_filter_max_width.jsx' | |
| 8 8 | 
             
            export { default as FilterMaxHeight } from './_filter_max_height.jsx'
         | 
| 9 9 | 
             
            export { default as FilterPlacement } from './_filter_placement.jsx'
         | 
| 10 10 | 
             
            export { default as FilterPopoverProps } from './_filter_popover_props.jsx'
         | 
| 11 | 
            +
            export { default as FilterSidebar } from './_filter_sidebar.jsx'
         | 
| @@ -58,12 +58,12 @@ function FilterTest(props) { | |
| 58 58 | 
             
            }
         | 
| 59 59 |  | 
| 60 60 | 
             
            test("triggers popover on filter button click", () => {
         | 
| 61 | 
            -
              render(<FilterTest data={{ testid: "render-test" }}/>);
         | 
| 61 | 
            +
              const { container } = render(<FilterTest data={{ testid: "render-test" }}/>);
         | 
| 62 62 |  | 
| 63 63 | 
             
              const btn = screen.getAllByRole("button")[0];
         | 
| 64 64 |  | 
| 65 65 | 
             
              // checks if the sort menu rendered
         | 
| 66 | 
            -
              expect( | 
| 66 | 
            +
              expect(container.querySelector('.pb_custom_icon')).toBeInTheDocument()
         | 
| 67 67 | 
             
              expect(screen.getByText('Popularity')).toBeInTheDocument() // check if filter/sort is rendered 
         | 
| 68 68 |  | 
| 69 69 | 
             
              // hits the filter button and triggers popover
         | 
| @@ -104,8 +104,8 @@ const Table = (props: TableProps): React.ReactElement => { | |
| 104 104 |  | 
| 105 105 | 
             
                        stickyLeftColumn.forEach((colId, index) => {
         | 
| 106 106 | 
             
                            const isLastColumn = index === stickyLeftColumn.length - 1;
         | 
| 107 | 
            -
                            const header = document.querySelector(`th[id="${colId}"]`);
         | 
| 108 | 
            -
                            const cells = document.querySelectorAll(`td[id="${colId}"]`);
         | 
| 107 | 
            +
                            const header = document.querySelector(`th[data-sticky-id="${colId}"]`);
         | 
| 108 | 
            +
                            const cells = document.querySelectorAll(`td[data-sticky-id="${colId}"]`);
         | 
| 109 109 |  | 
| 110 110 | 
             
                            if (header) {
         | 
| 111 111 | 
             
                                header.classList.add('sticky');
         | 
| @@ -155,8 +155,8 @@ const Table = (props: TableProps): React.ReactElement => { | |
| 155 155 |  | 
| 156 156 | 
             
                        stickyRightColumnReversed.forEach((colId, index) => {
         | 
| 157 157 | 
             
                            const isLastColumn = index === stickyRightColumn.length - 1;
         | 
| 158 | 
            -
                            const header = document.querySelector(`th[id="${colId}"]`);
         | 
| 159 | 
            -
                            const cells = document.querySelectorAll(`td[id="${colId}"]`);
         | 
| 158 | 
            +
                            const header = document.querySelector(`th[data-sticky-id="${colId}"]`);
         | 
| 159 | 
            +
                            const cells = document.querySelectorAll(`td[data-sticky-id="${colId}"]`);
         | 
| 160 160 |  | 
| 161 161 | 
             
                            if (header) {
         | 
| 162 162 | 
             
                                header.classList.add('sticky');
         | 
| @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            <%= pb_rails("table", props: { size: "md", responsive: "scroll", sticky_left_column: ["a"], sticky_right_column: ["b"] }) do %>
         | 
| 2 2 | 
             
              <thead>
         | 
| 3 3 | 
             
                <tr>
         | 
| 4 | 
            -
                  <th id="a">Column 1</th>
         | 
| 4 | 
            +
                  <th data-sticky-id="a">Column 1</th>
         | 
| 5 5 | 
             
                  <th>Column 2</th>
         | 
| 6 6 | 
             
                  <th>Column 3</th>
         | 
| 7 7 | 
             
                  <th>Column 4</th>
         | 
| @@ -15,12 +15,12 @@ | |
| 15 15 | 
             
                  <th>Column 12</th>
         | 
| 16 16 | 
             
                  <th>Column 13</th>
         | 
| 17 17 | 
             
                  <th>Column 14</th>
         | 
| 18 | 
            -
                  <th id="b">Column 15</th>
         | 
| 18 | 
            +
                  <th data-sticky-id="b">Column 15</th>
         | 
| 19 19 | 
             
                </tr>
         | 
| 20 20 | 
             
              </thead>
         | 
| 21 21 | 
             
              <tbody>
         | 
| 22 22 | 
             
                <tr>
         | 
| 23 | 
            -
                  <td id="a">Value 1</td>
         | 
| 23 | 
            +
                  <td data-sticky-id="a">Value 1</td>
         | 
| 24 24 | 
             
                  <td>Value 2</td>
         | 
| 25 25 | 
             
                  <td>Value 3</td>
         | 
| 26 26 | 
             
                  <td>Value 4</td>
         | 
| @@ -34,10 +34,10 @@ | |
| 34 34 | 
             
                  <td>Value 12</td>
         | 
| 35 35 | 
             
                  <td>Value 13</td>
         | 
| 36 36 | 
             
                  <td>Value 14</td>
         | 
| 37 | 
            -
                  <td id="b">Value 15</td>
         | 
| 37 | 
            +
                  <td data-sticky-id="b">Value 15</td>
         | 
| 38 38 | 
             
                </tr>
         | 
| 39 39 | 
             
                <tr>
         | 
| 40 | 
            -
                  <td id="a">Value 1</td>
         | 
| 40 | 
            +
                  <td data-sticky-id="a">Value 1</td>
         | 
| 41 41 | 
             
                  <td>Value 2</td>
         | 
| 42 42 | 
             
                  <td>Value 3</td>
         | 
| 43 43 | 
             
                  <td>Value 4</td>
         | 
| @@ -51,10 +51,10 @@ | |
| 51 51 | 
             
                  <td>Value 12</td>
         | 
| 52 52 | 
             
                  <td>Value 13</td>
         | 
| 53 53 | 
             
                  <td>Value 14</td>
         | 
| 54 | 
            -
                  <td id="b">Value 15</td>
         | 
| 54 | 
            +
                  <td data-sticky-id="b">Value 15</td>
         | 
| 55 55 | 
             
                </tr>
         | 
| 56 56 | 
             
                <tr>
         | 
| 57 | 
            -
                  <td id="a">Value 1</td>
         | 
| 57 | 
            +
                  <td data-sticky-id="a">Value 1</td>
         | 
| 58 58 | 
             
                  <td>Value 2</td>
         | 
| 59 59 | 
             
                  <td>Value 3</td>
         | 
| 60 60 | 
             
                  <td>Value 4</td>
         | 
| @@ -68,7 +68,7 @@ | |
| 68 68 | 
             
                  <td>Value 12</td>
         | 
| 69 69 | 
             
                  <td>Value 13</td>
         | 
| 70 70 | 
             
                  <td>Value 14</td>
         | 
| 71 | 
            -
                  <td id="b">Value 15</td>
         | 
| 71 | 
            +
                  <td data-sticky-id="b">Value 15</td>
         | 
| 72 72 | 
             
                </tr>
         | 
| 73 73 | 
             
              </tbody>
         | 
| 74 74 | 
             
            <% end %>
         | 
| @@ -11,7 +11,7 @@ const TableStickyColumns = () => { | |
| 11 11 | 
             
                    >
         | 
| 12 12 | 
             
                        <thead>
         | 
| 13 13 | 
             
                            <tr>
         | 
| 14 | 
            -
                                <th id="a">{'Column 1'}</th>
         | 
| 14 | 
            +
                                <th data-sticky-id="a">{'Column 1'}</th>
         | 
| 15 15 | 
             
                                <th>{'Column 2'}</th>
         | 
| 16 16 | 
             
                                <th>{'Column 3'}</th>
         | 
| 17 17 | 
             
                                <th>{'Column 4'}</th>
         | 
| @@ -25,12 +25,12 @@ const TableStickyColumns = () => { | |
| 25 25 | 
             
                                <th>{'Column 12'}</th>
         | 
| 26 26 | 
             
                                <th>{'Column 13'}</th>
         | 
| 27 27 | 
             
                                <th>{'Column 14'}</th>
         | 
| 28 | 
            -
                                <th id="b">{'Column 15'}</th>
         | 
| 28 | 
            +
                                <th data-sticky-id="b">{'Column 15'}</th>
         | 
| 29 29 | 
             
                            </tr>
         | 
| 30 30 | 
             
                        </thead>
         | 
| 31 31 | 
             
                        <tbody>
         | 
| 32 32 | 
             
                            <tr>
         | 
| 33 | 
            -
                                <td id="a">{'Value 1'}</td>
         | 
| 33 | 
            +
                                <td data-sticky-id="a">{'Value 1'}</td>
         | 
| 34 34 | 
             
                                <td>{'Value 2'}</td>
         | 
| 35 35 | 
             
                                <td>{'Value 3'}</td>
         | 
| 36 36 | 
             
                                <td>{'Value 4'}</td>
         | 
| @@ -44,10 +44,10 @@ const TableStickyColumns = () => { | |
| 44 44 | 
             
                                <td>{'Value 12'}</td>
         | 
| 45 45 | 
             
                                <td>{'Value 13'}</td>
         | 
| 46 46 | 
             
                                <td>{'Value 14'}</td>
         | 
| 47 | 
            -
                                <td id="b">{'Value 15'}</td>
         | 
| 47 | 
            +
                                <td data-sticky-id="b">{'Value 15'}</td>
         | 
| 48 48 | 
             
                            </tr>
         | 
| 49 49 | 
             
                            <tr>
         | 
| 50 | 
            -
                                <td id="a">{'Value 1'}</td>
         | 
| 50 | 
            +
                                <td data-sticky-id="a">{'Value 1'}</td>
         | 
| 51 51 | 
             
                                <td>{'Value 2'}</td>
         | 
| 52 52 | 
             
                                <td>{'Value 3'}</td>
         | 
| 53 53 | 
             
                                <td>{'Value 4'}</td>
         | 
| @@ -61,10 +61,10 @@ const TableStickyColumns = () => { | |
| 61 61 | 
             
                                <td>{'Value 12'}</td>
         | 
| 62 62 | 
             
                                <td>{'Value 13'}</td>
         | 
| 63 63 | 
             
                                <td>{'Value 14'}</td>
         | 
| 64 | 
            -
                                <td id="b">{'Value 15'}</td>
         | 
| 64 | 
            +
                                <td data-sticky-id="b">{'Value 15'}</td>
         | 
| 65 65 | 
             
                            </tr>
         | 
| 66 66 | 
             
                            <tr>
         | 
| 67 | 
            -
                                <td id="a">{'Value 1'}</td>
         | 
| 67 | 
            +
                                <td data-sticky-id="a">{'Value 1'}</td>
         | 
| 68 68 | 
             
                                <td>{'Value 2'}</td>
         | 
| 69 69 | 
             
                                <td>{'Value 3'}</td>
         | 
| 70 70 | 
             
                                <td>{'Value 4'}</td>
         | 
| @@ -78,7 +78,7 @@ const TableStickyColumns = () => { | |
| 78 78 | 
             
                                <td>{'Value 12'}</td>
         | 
| 79 79 | 
             
                                <td>{'Value 13'}</td>
         | 
| 80 80 | 
             
                                <td>{'Value 14'}</td>
         | 
| 81 | 
            -
                                <td id="b">{'Value 15'}</td>
         | 
| 81 | 
            +
                                <td data-sticky-id="b">{'Value 15'}</td>
         | 
| 82 82 | 
             
                            </tr>
         | 
| 83 83 | 
             
                        </tbody>
         | 
| 84 84 | 
             
                    </Table>
         | 
| @@ -1,3 +1,3 @@ | |
| 1 1 | 
             
            The `sticky_left_column` and `sticky_right_column` props can be used together on the same table as needed.
         | 
| 2 2 |  | 
| 3 | 
            -
            Please ensure that unique  | 
| 3 | 
            +
            Please ensure that unique `data-sticky-id`s are used for all columns across multiple tables. Using the same columns `data-sticky-id`s on multiple tables can lead to issues when using props.
         | 
| @@ -1,3 +1,3 @@ | |
| 1 1 | 
             
            The `stickyLeftColumn` and `stickyRightColumn` props can be used together on the same table as needed.
         | 
| 2 2 |  | 
| 3 | 
            -
            Please ensure that unique  | 
| 3 | 
            +
            Please ensure that unique `data-sticky-id`s are used for all columns across multiple tables. Using the same columns `data-sticky-id`s on multiple tables can lead to issues when using props.
         | 
| @@ -1,9 +1,9 @@ | |
| 1 1 | 
             
            <%= pb_rails("table", props: { size: "md", responsive: "scroll", sticky_left_column: ["1", "2", "3"] }) do %>
         | 
| 2 2 | 
             
              <thead>
         | 
| 3 3 | 
             
                <tr>
         | 
| 4 | 
            -
                  <th id="1">Column 1</th>
         | 
| 5 | 
            -
                  <th id="2">Column 2</th>
         | 
| 6 | 
            -
                  <th id="3">Column 3</th>
         | 
| 4 | 
            +
                  <th data-sticky-id="1">Column 1</th>
         | 
| 5 | 
            +
                  <th data-sticky-id="2">Column 2</th>
         | 
| 6 | 
            +
                  <th data-sticky-id="3">Column 3</th>
         | 
| 7 7 | 
             
                  <th>Column 4</th>
         | 
| 8 8 | 
             
                  <th>Column 5</th>
         | 
| 9 9 | 
             
                  <th>Column 6</th>
         | 
| @@ -20,9 +20,9 @@ | |
| 20 20 | 
             
              </thead>
         | 
| 21 21 | 
             
              <tbody>
         | 
| 22 22 | 
             
                <tr>
         | 
| 23 | 
            -
                  <td id="1">Value 1</td>
         | 
| 24 | 
            -
                  <td id="2">Value 2</td>
         | 
| 25 | 
            -
                  <td id="3">Value 3</td>
         | 
| 23 | 
            +
                  <td data-sticky-id="1">Value 1</td>
         | 
| 24 | 
            +
                  <td data-sticky-id="2">Value 2</td>
         | 
| 25 | 
            +
                  <td data-sticky-id="3">Value 3</td>
         | 
| 26 26 | 
             
                  <td>Value 4</td>
         | 
| 27 27 | 
             
                  <td>Value 5</td>
         | 
| 28 28 | 
             
                  <td>Value 6</td>
         | 
| @@ -38,9 +38,9 @@ | |
| 38 38 |  | 
| 39 39 | 
             
                </tr>
         | 
| 40 40 | 
             
                <tr>
         | 
| 41 | 
            -
                  <td id="1">Value 1</td>
         | 
| 42 | 
            -
                  <td id="2">Value 2</td>
         | 
| 43 | 
            -
                  <td id="3">Value 3</td>
         | 
| 41 | 
            +
                  <td data-sticky-id="1">Value 1</td>
         | 
| 42 | 
            +
                  <td data-sticky-id="2">Value 2</td>
         | 
| 43 | 
            +
                  <td data-sticky-id="3">Value 3</td>
         | 
| 44 44 | 
             
                  <td>Value 4</td>
         | 
| 45 45 | 
             
                  <td>Value 5</td>
         | 
| 46 46 | 
             
                  <td>Value 6</td>
         | 
| @@ -56,9 +56,9 @@ | |
| 56 56 |  | 
| 57 57 | 
             
                </tr>
         | 
| 58 58 | 
             
                <tr>
         | 
| 59 | 
            -
                  <td id="1">Value 1</td>
         | 
| 60 | 
            -
                  <td id="2">Value 2</td>
         | 
| 61 | 
            -
                  <td id="3">Value 3</td>
         | 
| 59 | 
            +
                  <td data-sticky-id="1">Value 1</td>
         | 
| 60 | 
            +
                  <td data-sticky-id="2">Value 2</td>
         | 
| 61 | 
            +
                  <td data-sticky-id="3">Value 3</td>
         | 
| 62 62 | 
             
                  <td>Value 4</td>
         | 
| 63 63 | 
             
                  <td>Value 5</td>
         | 
| 64 64 | 
             
                  <td>Value 6</td>
         | 
| @@ -10,9 +10,9 @@ const TableStickyLeftColumns = () => { | |
| 10 10 | 
             
                    >
         | 
| 11 11 | 
             
                        <thead>
         | 
| 12 12 | 
             
                            <tr>
         | 
| 13 | 
            -
                                <th id="1">{'Column 1'}</th>
         | 
| 14 | 
            -
                                <th id="2">{'Column 2'}</th>
         | 
| 15 | 
            -
                                <th id="3">{'Column 3'}</th>
         | 
| 13 | 
            +
                                <th data-sticky-id="1">{'Column 1'}</th>
         | 
| 14 | 
            +
                                <th data-sticky-id="2">{'Column 2'}</th>
         | 
| 15 | 
            +
                                <th data-sticky-id="3">{'Column 3'}</th>
         | 
| 16 16 | 
             
                                <th>{'Column 4'}</th>
         | 
| 17 17 | 
             
                                <th>{'Column 5'}</th>
         | 
| 18 18 | 
             
                                <th>{'Column 6'}</th>
         | 
| @@ -29,9 +29,9 @@ const TableStickyLeftColumns = () => { | |
| 29 29 | 
             
                        </thead>
         | 
| 30 30 | 
             
                        <tbody>
         | 
| 31 31 | 
             
                            <tr>
         | 
| 32 | 
            -
                                <td id="1">{'Value 1'}</td>
         | 
| 33 | 
            -
                                <td id="2">{'Value 2'}</td>
         | 
| 34 | 
            -
                                <td id="3">{'Value 3'}</td>
         | 
| 32 | 
            +
                                <td data-sticky-id="1">{'Value 1'}</td>
         | 
| 33 | 
            +
                                <td data-sticky-id="2">{'Value 2'}</td>
         | 
| 34 | 
            +
                                <td data-sticky-id="3">{'Value 3'}</td>
         | 
| 35 35 | 
             
                                <td>{'Value 4'}</td>
         | 
| 36 36 | 
             
                                <td>{'Value 5'}</td>
         | 
| 37 37 | 
             
                                <td>{'Value 6'}</td>
         | 
| @@ -46,9 +46,9 @@ const TableStickyLeftColumns = () => { | |
| 46 46 | 
             
                                <td>{'Value 15'}</td>
         | 
| 47 47 | 
             
                            </tr>
         | 
| 48 48 | 
             
                            <tr>
         | 
| 49 | 
            -
                                <td id="1">{'Value 1'}</td>
         | 
| 50 | 
            -
                                <td id="2">{'Value 2'}</td>
         | 
| 51 | 
            -
                                <td id="3">{'Value 3'}</td>
         | 
| 49 | 
            +
                                <td data-sticky-id="1">{'Value 1'}</td>
         | 
| 50 | 
            +
                                <td data-sticky-id="2">{'Value 2'}</td>
         | 
| 51 | 
            +
                                <td data-sticky-id="3">{'Value 3'}</td>
         | 
| 52 52 | 
             
                                <td>{'Value 4'}</td>
         | 
| 53 53 | 
             
                                <td>{'Value 5'}</td>
         | 
| 54 54 | 
             
                                <td>{'Value 6'}</td>
         | 
| @@ -63,9 +63,9 @@ const TableStickyLeftColumns = () => { | |
| 63 63 | 
             
                                <td>{'Value 15'}</td>
         | 
| 64 64 | 
             
                            </tr>
         | 
| 65 65 | 
             
                            <tr>
         | 
| 66 | 
            -
                                <td id="1">{'Value 1'}</td>
         | 
| 67 | 
            -
                                <td id="2">{'Value 2'}</td>
         | 
| 68 | 
            -
                                <td id="3">{'Value 3'}</td>
         | 
| 66 | 
            +
                                <td data-sticky-id="1">{'Value 1'}</td>
         | 
| 67 | 
            +
                                <td data-sticky-id="2">{'Value 2'}</td>
         | 
| 68 | 
            +
                                <td data-sticky-id="3">{'Value 3'}</td>
         | 
| 69 69 | 
             
                                <td>{'Value 4'}</td>
         | 
| 70 70 | 
             
                                <td>{'Value 5'}</td>
         | 
| 71 71 | 
             
                                <td>{'Value 6'}</td>
         | 
| @@ -1,3 +1,3 @@ | |
| 1 | 
            -
            The `sticky_left_column` prop expects an array of the column  | 
| 1 | 
            +
            The `sticky_left_column` prop expects an array of the column `data-sticky-id`s you want to be sticky. Make sure to add the corresponding `data-sticky-id` to the `<th>` and `<td>`.
         | 
| 2 2 |  | 
| 3 | 
            -
            Please ensure that unique  | 
| 3 | 
            +
            Please ensure that unique `data-sticky-id`s are used for all columns across multiple tables. Using the same columns `data-sticky-id`s on multiple tables can lead to issues when using the `sticky_left_column`.
         | 
| @@ -1,5 +1,5 @@ | |
| 1 | 
            -
            The `stickyLeftColumn` prop expects an array of the column  | 
| 1 | 
            +
            The `stickyLeftColumn` prop expects an array of the column `data-sticky-id`s you want to be sticky. Make sure to add the corresponding `data-sticky-id` to the `<th>` and `<td>`.
         | 
| 2 2 |  | 
| 3 | 
            -
            If you are using the sub-component variant, then you will pass the id to `<Table.Header>` and `<Table.Cell>`
         | 
| 3 | 
            +
            If you are using the sub-component variant, then you will pass the `data-sticky-id` to `<Table.Header>` and `<Table.Cell>`
         | 
| 4 4 |  | 
| 5 | 
            -
            Please ensure that unique  | 
| 5 | 
            +
            Please ensure that unique `data-sticky-id`s are used for all columns across multiple tables. Using the same columns `data-sticky-id`s on multiple tables can lead to issues when using `stickyLeftColumn` prop.
         | 
| @@ -13,9 +13,9 @@ | |
| 13 13 | 
             
                  <th>Column 10</th>
         | 
| 14 14 | 
             
                  <th>Column 11</th>
         | 
| 15 15 | 
             
                  <th>Column 12</th>
         | 
| 16 | 
            -
                  <th id="13">Column 13</th>
         | 
| 17 | 
            -
                  <th id="14">Column 14</th>
         | 
| 18 | 
            -
                  <th id="15">Column 15</th>
         | 
| 16 | 
            +
                  <th data-sticky-id="13">Column 13</th>
         | 
| 17 | 
            +
                  <th data-sticky-id="14">Column 14</th>
         | 
| 18 | 
            +
                  <th data-sticky-id="15">Column 15</th>
         | 
| 19 19 | 
             
                </tr>
         | 
| 20 20 | 
             
              </thead>
         | 
| 21 21 | 
             
              <tbody>
         | 
| @@ -32,9 +32,9 @@ | |
| 32 32 | 
             
                  <td>Value 10</td>
         | 
| 33 33 | 
             
                  <td>Value 11</td>
         | 
| 34 34 | 
             
                  <td>Value 12</td>
         | 
| 35 | 
            -
                  <td id="13">Value 13</td>
         | 
| 36 | 
            -
                  <td id="14">Value 14</td>
         | 
| 37 | 
            -
                  <td id="15">Value 15</td>
         | 
| 35 | 
            +
                  <td data-sticky-id="13">Value 13</td>
         | 
| 36 | 
            +
                  <td data-sticky-id="14">Value 14</td>
         | 
| 37 | 
            +
                  <td data-sticky-id="15">Value 15</td>
         | 
| 38 38 | 
             
                </tr>
         | 
| 39 39 | 
             
                <tr>
         | 
| 40 40 | 
             
                  <td>Value 1</td>
         | 
| @@ -49,9 +49,9 @@ | |
| 49 49 | 
             
                  <td>Value 10</td>
         | 
| 50 50 | 
             
                  <td>Value 11</td>
         | 
| 51 51 | 
             
                  <td>Value 12</td>
         | 
| 52 | 
            -
                  <td id="13">Value 13</td>
         | 
| 53 | 
            -
                  <td id="14">Value 14</td>
         | 
| 54 | 
            -
                  <td id="15">Value 15</td>
         | 
| 52 | 
            +
                  <td data-sticky-id="13">Value 13</td>
         | 
| 53 | 
            +
                  <td data-sticky-id="14">Value 14</td>
         | 
| 54 | 
            +
                  <td data-sticky-id="15">Value 15</td>
         | 
| 55 55 | 
             
                </tr>
         | 
| 56 56 | 
             
                <tr>
         | 
| 57 57 | 
             
                  <td>Value 1</td>
         | 
| @@ -66,9 +66,9 @@ | |
| 66 66 | 
             
                  <td>Value 10</td>
         | 
| 67 67 | 
             
                  <td>Value 11</td>
         | 
| 68 68 | 
             
                  <td>Value 12</td>
         | 
| 69 | 
            -
                  <td id="13">Value 13</td>
         | 
| 70 | 
            -
                  <td id="14">Value 14</td>
         | 
| 71 | 
            -
                  <td id="15">Value 15</td>
         | 
| 69 | 
            +
                  <td data-sticky-id="13">Value 13</td>
         | 
| 70 | 
            +
                  <td data-sticky-id="14">Value 14</td>
         | 
| 71 | 
            +
                  <td data-sticky-id="15">Value 15</td>
         | 
| 72 72 | 
             
                </tr>
         | 
| 73 73 | 
             
              </tbody>
         | 
| 74 74 | 
             
            <% end %>
         | 
| @@ -22,9 +22,9 @@ const TableStickyRightColumns = () => { | |
| 22 22 | 
             
                                <th>{'Column 10'}</th>
         | 
| 23 23 | 
             
                                <th>{'Column 11'}</th>
         | 
| 24 24 | 
             
                                <th>{'Column 12'}</th>
         | 
| 25 | 
            -
                                <th id="13">{'Column 13'}</th>
         | 
| 26 | 
            -
                                <th id="14">{'Column 14'}</th>
         | 
| 27 | 
            -
                                <th id="15">{'Column 15'}</th>
         | 
| 25 | 
            +
                                <th data-sticky-id="13">{'Column 13'}</th>
         | 
| 26 | 
            +
                                <th data-sticky-id="14">{'Column 14'}</th>
         | 
| 27 | 
            +
                                <th data-sticky-id="15">{'Column 15'}</th>
         | 
| 28 28 | 
             
                            </tr>
         | 
| 29 29 | 
             
                        </thead>
         | 
| 30 30 | 
             
                        <tbody>
         | 
| @@ -41,9 +41,9 @@ const TableStickyRightColumns = () => { | |
| 41 41 | 
             
                                <td>{'Value 10'}</td>
         | 
| 42 42 | 
             
                                <td>{'Value 11'}</td>
         | 
| 43 43 | 
             
                                <td>{'Value 12'}</td>
         | 
| 44 | 
            -
                                <td id="13">{'Value 13'}</td>
         | 
| 45 | 
            -
                                <td id="14">{'Value 14'}</td>
         | 
| 46 | 
            -
                                <td id="15">{'Value 15'}</td>
         | 
| 44 | 
            +
                                <td data-sticky-id="13">{'Value 13'}</td>
         | 
| 45 | 
            +
                                <td data-sticky-id="14">{'Value 14'}</td>
         | 
| 46 | 
            +
                                <td data-sticky-id="15">{'Value 15'}</td>
         | 
| 47 47 | 
             
                            </tr>
         | 
| 48 48 | 
             
                            <tr>
         | 
| 49 49 | 
             
                                <td>{'Value 1'}</td>
         | 
| @@ -58,9 +58,9 @@ const TableStickyRightColumns = () => { | |
| 58 58 | 
             
                                <td>{'Value 10'}</td>
         | 
| 59 59 | 
             
                                <td>{'Value 11'}</td>
         | 
| 60 60 | 
             
                                <td>{'Value 12'}</td>
         | 
| 61 | 
            -
                                <td id="13">{'Value 13'}</td>
         | 
| 62 | 
            -
                                <td id="14">{'Value 14'}</td>
         | 
| 63 | 
            -
                                <td id="15">{'Value 15'}</td>
         | 
| 61 | 
            +
                                <td data-sticky-id="13">{'Value 13'}</td>
         | 
| 62 | 
            +
                                <td data-sticky-id="14">{'Value 14'}</td>
         | 
| 63 | 
            +
                                <td data-sticky-id="15">{'Value 15'}</td>
         | 
| 64 64 | 
             
                            </tr>
         | 
| 65 65 | 
             
                            <tr>
         | 
| 66 66 | 
             
                                <td>{'Value 1'}</td>
         | 
| @@ -75,9 +75,9 @@ const TableStickyRightColumns = () => { | |
| 75 75 | 
             
                                <td>{'Value 10'}</td>
         | 
| 76 76 | 
             
                                <td>{'Value 11'}</td>
         | 
| 77 77 | 
             
                                <td>{'Value 12'}</td>
         | 
| 78 | 
            -
                                <td id="13">{'Value 13'}</td>
         | 
| 79 | 
            -
                                <td id="14">{'Value 14'}</td>
         | 
| 80 | 
            -
                                <td id="15">{'Value 15'}</td>
         | 
| 78 | 
            +
                                <td data-sticky-id="13">{'Value 13'}</td>
         | 
| 79 | 
            +
                                <td data-sticky-id="14">{'Value 14'}</td>
         | 
| 80 | 
            +
                                <td data-sticky-id="15">{'Value 15'}</td>
         | 
| 81 81 | 
             
                            </tr>
         | 
| 82 82 | 
             
                        </tbody>
         | 
| 83 83 | 
             
                    </Table>
         | 
| @@ -1,3 +1,3 @@ | |
| 1 | 
            -
            The `sticky_right_column` prop works in the same way as the above `sticky_left_column` prop. It expects an array of the column  | 
| 1 | 
            +
            The `sticky_right_column` prop works in the same way as the above `sticky_left_column` prop. It expects an array of the column `data-sticky-id`s you want to be sticky. Make sure to add the corresponding `data-sticky-id` to the `<th>` and `<td>`.
         | 
| 2 2 |  | 
| 3 | 
            -
            Please ensure that unique  | 
| 3 | 
            +
            Please ensure that unique `data-sticky-id`s are used for all columns across multiple tables. Using the same columns `data-sticky-id`s on multiple tables can lead to issues when using the `sticky_right_column` prop.
         | 
| @@ -1,5 +1,5 @@ | |
| 1 | 
            -
            The `stickyRightColumn` prop works in the same way as the above `stickyLeftColumn` prop. It expects an array of the column  | 
| 1 | 
            +
            The `stickyRightColumn` prop works in the same way as the above `stickyLeftColumn` prop. It expects an array of the column `data-sticky-id`s you want to be sticky. Make sure to add the corresponding `data-sticky-id` to the `<th>` and `<td>`.
         | 
| 2 2 |  | 
| 3 | 
            -
            If you are using the sub-component variant, then you will pass the id to `<Table.Header>` and `<Table.Cell>`
         | 
| 3 | 
            +
            If you are using the sub-component variant, then you will pass the `data-sticky-id` to `<Table.Header>` and `<Table.Cell>`
         | 
| 4 4 |  | 
| 5 | 
            -
            Please ensure that unique  | 
| 5 | 
            +
            Please ensure that unique `data-sticky-id`s are used for all columns across multiple tables. Using the same columns `data-sticky-id`s on multiple tables can lead to issues when using the `stickyRightColumn` prop.
         |