playbook_ui 14.21.2 → 14.22.0.pre.alpha.PLAY2254datepickerdefaultdatenullvalueturbo8531
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 +5 -2
- data/app/pb_kits/playbook/pb_advanced_table/Components/RegularTableView.tsx +20 -4
- 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 +30 -5
- 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 +63 -6
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +36 -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_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/example.yml +6 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/index.js +4 -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 +2 -2
- 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_date_picker/date_picker_helper.ts +7 -3
- 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/docs/_table_sticky_columns.html.erb +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_left_columns.html.erb +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_right_columns.html.erb +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/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.jsx +25 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_click_open.md +1 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/index.js +1 -0
- data/dist/chunks/_typeahead-d905TAE6.js +22 -0
- data/dist/chunks/_weekday_stacked-K4_gOktU.js +45 -0
- data/dist/chunks/lazysizes-B7xYodB-.js +1 -0
- data/dist/chunks/lib-CvfaRxDq.js +29 -0
- data/dist/chunks/{pb_form_validation-DyvJ8iPe.js → pb_form_validation-Ckz-Bv4i.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 +33 -30
- 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
| @@ -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>
         | 
| @@ -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`.
         | 
| @@ -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 %>
         | 
| @@ -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.
         | 
| @@ -64,8 +64,8 @@ export default class PbTable extends PbEnhancedElement { | |
| 64 64 |  | 
| 65 65 | 
             
                this.stickyLeftColumns.forEach((colId, index) => {
         | 
| 66 66 | 
             
                  const isLastColumn = index === this.stickyLeftColumns.length - 1;
         | 
| 67 | 
            -
                  const header = this.element.querySelector(`th[id="${colId}"]`);
         | 
| 68 | 
            -
                  const cells = this.element.querySelectorAll(`td[id="${colId}"]`);
         | 
| 67 | 
            +
                  const header = this.element.querySelector(`th[data-sticky-id="${colId}"]`);
         | 
| 68 | 
            +
                  const cells = this.element.querySelectorAll(`td[data-sticky-id="${colId}"]`);
         | 
| 69 69 |  | 
| 70 70 | 
             
                  if (header) {
         | 
| 71 71 | 
             
                    header.classList.add('sticky');
         | 
| @@ -125,8 +125,8 @@ export default class PbTable extends PbEnhancedElement { | |
| 125 125 |  | 
| 126 126 | 
             
                this.stickyRightColumnsReversed.forEach((colId, index) => {
         | 
| 127 127 | 
             
                  const isLastColumn = index === this.stickyRightColumns.length - 1;
         | 
| 128 | 
            -
                  const header = this.element.querySelector(`th[id="${colId}"]`);
         | 
| 129 | 
            -
                  const cells = this.element.querySelectorAll(`td[id="${colId}"]`);
         | 
| 128 | 
            +
                  const header = this.element.querySelector(`th[data-sticky-id="${colId}"]`);
         | 
| 129 | 
            +
                  const cells = this.element.querySelectorAll(`td[data-sticky-id="${colId}"]`);
         | 
| 130 130 |  | 
| 131 131 | 
             
                  if (header) {
         | 
| 132 132 | 
             
                    header.classList.add('sticky');
         | 
| @@ -22,6 +22,10 @@ | |
| 22 22 | 
             
                          border-radius: 0 4px 0 0;
         | 
| 23 23 | 
             
                          border-width: 1px 1px 1px 0;
         | 
| 24 24 | 
             
                        }
         | 
| 25 | 
            +
                        &:only-child {
         | 
| 26 | 
            +
                          border-radius: 4px 4px 0 0;
         | 
| 27 | 
            +
                          border-width: 1px 1px 1px 1px;
         | 
| 28 | 
            +
                        }
         | 
| 25 29 | 
             
                      }
         | 
| 26 30 | 
             
                    }
         | 
| 27 31 | 
             
                  }
         | 
| @@ -39,6 +43,9 @@ | |
| 39 43 | 
             
                        &:last-child {
         | 
| 40 44 | 
             
                          border-width: 0 1px 1px 0;
         | 
| 41 45 | 
             
                        }
         | 
| 46 | 
            +
                        &:only-child {
         | 
| 47 | 
            +
                          border-width: 0 1px 1px 1px;
         | 
| 48 | 
            +
                        }
         | 
| 42 49 | 
             
                      }
         | 
| 43 50 |  | 
| 44 51 | 
             
                      &:last-child {
         | 
| @@ -53,6 +60,10 @@ | |
| 53 60 | 
             
                            border-radius: 0 0 4px 0;
         | 
| 54 61 | 
             
                            border-width: 0 1px 1px 0;
         | 
| 55 62 | 
             
                          }
         | 
| 63 | 
            +
                          &:only-child {
         | 
| 64 | 
            +
                            border-radius: 0 0 4px 4px;
         | 
| 65 | 
            +
                            border-width: 0 1px 1px 1px;
         | 
| 66 | 
            +
                          }
         | 
| 56 67 | 
             
                        }
         | 
| 57 68 | 
             
                      }
         | 
| 58 69 | 
             
                    }
         | 
| @@ -4,6 +4,10 @@ | |
| 4 4 | 
             
                  border-right: 1px solid $border_light !important;
         | 
| 5 5 | 
             
                }
         | 
| 6 6 |  | 
| 7 | 
            +
                thead tr:not(:first-child) th {
         | 
| 8 | 
            +
                  border-right: 1px solid $border_light !important;
         | 
| 9 | 
            +
                }
         | 
| 10 | 
            +
                
         | 
| 7 11 | 
             
                @media screen and (min-width: $screen-xs-min) {
         | 
| 8 12 | 
             
                  tr:hover, .pb_table_tr:hover {
         | 
| 9 13 | 
             
                    td:last-child, .pb_table_td:last-child {
         | 
| @@ -9,6 +9,7 @@ import { | |
| 9 9 | 
             
              shift,
         | 
| 10 10 | 
             
              useFloating,
         | 
| 11 11 | 
             
              useHover,
         | 
| 12 | 
            +
              useClick,
         | 
| 12 13 | 
             
              useInteractions,
         | 
| 13 14 | 
             
            } from "@floating-ui/react"
         | 
| 14 15 |  | 
| @@ -23,6 +24,7 @@ type TooltipProps = { | |
| 23 24 | 
             
              aria?: { [key: string]: string },
         | 
| 24 25 | 
             
              className?: string | string[],
         | 
| 25 26 | 
             
              children: JSX.Element,
         | 
| 27 | 
            +
              useClickToOpen?: boolean,
         | 
| 26 28 | 
             
              data?: { [key: string]: string },
         | 
| 27 29 | 
             
              delay?: number | Partial<{open: number; close: number}>,
         | 
| 28 30 | 
             
              height?: string,
         | 
| @@ -46,6 +48,7 @@ const Tooltip = forwardRef((props: TooltipProps, ref: ForwardedRef<unknown>): Re | |
| 46 48 | 
             
                aria = {},
         | 
| 47 49 | 
             
                className,
         | 
| 48 50 | 
             
                children,
         | 
| 51 | 
            +
                useClickToOpen = false,
         | 
| 49 52 | 
             
                data = {},
         | 
| 50 53 | 
             
                delay = 0,
         | 
| 51 54 | 
             
                height,
         | 
| @@ -110,14 +113,21 @@ const Tooltip = forwardRef((props: TooltipProps, ref: ForwardedRef<unknown>): Re | |
| 110 113 | 
             
                placement: preferredPlacement
         | 
| 111 114 | 
             
              })
         | 
| 112 115 |  | 
| 116 | 
            +
              const hover = useHover(context, {
         | 
| 117 | 
            +
                delay,
         | 
| 118 | 
            +
                handleClose: interaction ? safePolygon({
         | 
| 119 | 
            +
                  blockPointerEvents: false
         | 
| 120 | 
            +
                }) : null,
         | 
| 121 | 
            +
                enabled: !useClickToOpen // Disable hover when useClickToOpen is true
         | 
| 122 | 
            +
              })
         | 
| 123 | 
            +
             | 
| 124 | 
            +
              const click = useClick(context, {
         | 
| 125 | 
            +
                enabled: useClickToOpen // Only enable click when useClickToOpen is true
         | 
| 126 | 
            +
              })
         | 
| 113 127 |  | 
| 114 | 
            -
              const { getFloatingProps } = useInteractions([
         | 
| 115 | 
            -
                 | 
| 116 | 
            -
             | 
| 117 | 
            -
                  handleClose: interaction ? safePolygon({
         | 
| 118 | 
            -
                    blockPointerEvents: false
         | 
| 119 | 
            -
                  }) : null
         | 
| 120 | 
            -
                })
         | 
| 128 | 
            +
              const { getFloatingProps, getReferenceProps } = useInteractions([
         | 
| 129 | 
            +
                hover,
         | 
| 130 | 
            +
                click
         | 
| 121 131 | 
             
              ])
         | 
| 122 132 |  | 
| 123 133 | 
             
              const staticSide = {
         | 
| @@ -142,22 +152,24 @@ const Tooltip = forwardRef((props: TooltipProps, ref: ForwardedRef<unknown>): Re | |
| 142 152 | 
             
              return (
         | 
| 143 153 | 
             
                <>
         | 
| 144 154 | 
             
                  <div
         | 
| 145 | 
            -
                       | 
| 146 | 
            -
             | 
| 147 | 
            -
                         | 
| 148 | 
            -
             | 
| 149 | 
            -
                          if ( | 
| 150 | 
            -
                            ref | 
| 151 | 
            -
             | 
| 152 | 
            -
                            ref | 
| 155 | 
            +
                      {...getReferenceProps({
         | 
| 156 | 
            +
                        className: `pb_tooltip_kit ${css}`,
         | 
| 157 | 
            +
                        ref: (element) => {
         | 
| 158 | 
            +
                          refs.setReference(element);
         | 
| 159 | 
            +
                          if (ref) {
         | 
| 160 | 
            +
                            if (typeof ref === "function") {
         | 
| 161 | 
            +
                              ref(element);
         | 
| 162 | 
            +
                            } else if (typeof ref === "object") {
         | 
| 163 | 
            +
                              ref.current = element;
         | 
| 164 | 
            +
                            }
         | 
| 153 165 | 
             
                          }
         | 
| 154 | 
            -
                        }
         | 
| 155 | 
            -
             | 
| 156 | 
            -
             | 
| 157 | 
            -
             | 
| 158 | 
            -
             | 
| 159 | 
            -
             | 
| 160 | 
            -
                       | 
| 166 | 
            +
                        },
         | 
| 167 | 
            +
                        role: "tooltip_trigger",
         | 
| 168 | 
            +
                        style: { display: "inline-block" },
         | 
| 169 | 
            +
                        ...ariaProps,
         | 
| 170 | 
            +
                        ...dataProps,
         | 
| 171 | 
            +
                        ...htmlProps,
         | 
| 172 | 
            +
                      })}
         | 
| 161 173 | 
             
                  >
         | 
| 162 174 | 
             
                    {children}
         | 
| 163 175 | 
             
                  </div>
         | 
| @@ -0,0 +1,25 @@ | |
| 1 | 
            +
            import React from 'react'
         | 
| 2 | 
            +
            import Button from '../../pb_button/_button'
         | 
| 3 | 
            +
            import Tooltip from '../_tooltip'
         | 
| 4 | 
            +
            import Flex from '../../pb_flex/_flex'
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            const TooltipClickOpen = (props) => {
         | 
| 7 | 
            +
              return (
         | 
| 8 | 
            +
                <Flex flexDirection='row'
         | 
| 9 | 
            +
                    gap='md'
         | 
| 10 | 
            +
                    wrap
         | 
| 11 | 
            +
                >
         | 
| 12 | 
            +
                  <Tooltip
         | 
| 13 | 
            +
                      placement='top'
         | 
| 14 | 
            +
                      text='Tooltip Opened'
         | 
| 15 | 
            +
                      useClickToOpen
         | 
| 16 | 
            +
                      zIndex={10}
         | 
| 17 | 
            +
                      {...props}
         | 
| 18 | 
            +
                  >
         | 
| 19 | 
            +
                    <Button text='Click to Open' />
         | 
| 20 | 
            +
                  </Tooltip>
         | 
| 21 | 
            +
                </Flex>
         | 
| 22 | 
            +
              )
         | 
| 23 | 
            +
            }
         | 
| 24 | 
            +
             | 
| 25 | 
            +
            export default TooltipClickOpen
         | 
| @@ -0,0 +1 @@ | |
| 1 | 
            +
            Set the prop `useClickToOpen` so that the tooltip will only appear when an item is clicked rather than hovered over.
         | 
| @@ -5,3 +5,4 @@ export { default as TooltipSizing } from './_tooltip_sizing' | |
| 5 5 | 
             
            export { default as TooltipIcon } from './_tooltip_icon'
         | 
| 6 6 | 
             
            export { default as TooltipDelay } from './_tooltip_delay'
         | 
| 7 7 | 
             
            export { default as TooltipShowTooltipReact } from './_tooltip_show_tooltip_react'
         | 
| 8 | 
            +
            export { default as TooltipClickOpen } from './_tooltip_click_open'
         |