playbook_ui 14.11.1.pre.alpha.pbntr703collapsiblerowsrails5536 → 14.11.1.pre.alpha.play1724darkmodeauditmap5409

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.
Files changed (71) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sort_control.md +2 -2
  3. data/app/pb_kits/playbook/pb_button/button.html.erb +3 -2
  4. data/app/pb_kits/playbook/pb_checkbox/checkbox.html.erb +6 -1
  5. data/app/pb_kits/playbook/pb_collapsible/collapsible.html.erb +1 -3
  6. data/app/pb_kits/playbook/pb_collapsible/collapsible.rb +0 -3
  7. data/app/pb_kits/playbook/pb_date_picker/date_picker.html.erb +6 -2
  8. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_default_date.md +1 -1
  9. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_list_rails.html.erb +9 -3
  10. data/app/pb_kits/playbook/pb_draggable/docs/example.yml +0 -1
  11. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_subtle_variant.md +1 -1
  12. data/app/pb_kits/playbook/pb_dropdown/dropdown.html.erb +12 -7
  13. data/app/pb_kits/playbook/pb_dropdown/dropdown_container.html.erb +14 -9
  14. data/app/pb_kits/playbook/pb_dropdown/dropdown_option.html.erb +11 -6
  15. data/app/pb_kits/playbook/pb_dropdown/dropdown_trigger.html.erb +14 -8
  16. data/app/pb_kits/playbook/pb_list/item.html.erb +8 -30
  17. data/app/pb_kits/playbook/pb_list/item.rb +0 -7
  18. data/app/pb_kits/playbook/pb_list/list.html.erb +11 -31
  19. data/app/pb_kits/playbook/pb_list/list.rb +0 -4
  20. data/app/pb_kits/playbook/pb_loading_inline/_loading_inline.tsx +1 -6
  21. data/app/pb_kits/playbook/pb_map/_map.scss +3 -0
  22. data/app/pb_kits/playbook/pb_map/docs/_map_default.jsx +4 -4
  23. data/app/pb_kits/playbook/pb_map/docs/_map_with_custom_button.jsx +7 -7
  24. data/app/pb_kits/playbook/pb_map/docs/_map_with_plugin.jsx +5 -5
  25. data/app/pb_kits/playbook/pb_phone_number_input/_phone_number_input.tsx +12 -30
  26. data/app/pb_kits/playbook/pb_phone_number_input/docs/example.yml +1 -3
  27. data/app/pb_kits/playbook/pb_phone_number_input/docs/index.js +0 -1
  28. data/app/pb_kits/playbook/pb_phone_number_input/phone_number_input.rb +0 -3
  29. data/app/pb_kits/playbook/pb_phone_number_input/phone_number_input.test.js +1 -20
  30. data/app/pb_kits/playbook/pb_radio/_radio.scss +8 -12
  31. data/app/pb_kits/playbook/pb_radio/docs/_radio_custom_children.jsx +3 -8
  32. data/app/pb_kits/playbook/pb_selectable_list/selectable_list.html.erb +3 -17
  33. data/app/pb_kits/playbook/pb_selectable_list/selectable_list.rb +0 -3
  34. data/app/pb_kits/playbook/pb_selectable_list/selectable_list_item.html.erb +4 -11
  35. data/app/pb_kits/playbook/pb_selectable_list/selectable_list_item.rb +0 -3
  36. data/app/pb_kits/playbook/pb_table/_table.tsx +3 -2
  37. data/app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns_rails.md +2 -2
  38. data/app/pb_kits/playbook/pb_table/docs/example.yml +0 -3
  39. data/app/pb_kits/playbook/pb_table/index.ts +88 -187
  40. data/app/pb_kits/playbook/pb_table/styles/_collapsible.scss +0 -12
  41. data/app/pb_kits/playbook/pb_table/table.html.erb +1 -1
  42. data/app/pb_kits/playbook/pb_table/table.rb +2 -17
  43. data/app/pb_kits/playbook/pb_table/table_row.html.erb +1 -20
  44. data/app/pb_kits/playbook/pb_table/table_row.rb +0 -5
  45. data/app/pb_kits/playbook/pb_timeline/_timeline.scss +30 -30
  46. data/dist/chunks/{_typeahead-DjGX1O4K.js → _typeahead-BNULwihE.js} +2 -2
  47. data/dist/chunks/_weekday_stacked-BKWemDAe.js +45 -0
  48. data/dist/chunks/{lib-kMuhBuU7.js → lib-B7sgJtGS.js} +2 -2
  49. data/dist/chunks/{pb_form_validation-DBJ0wZuS.js → pb_form_validation-C5Cc0-1v.js} +1 -1
  50. data/dist/chunks/vendor.js +1 -1
  51. data/dist/playbook-doc.js +1 -1
  52. data/dist/playbook-rails-react-bindings.js +1 -1
  53. data/dist/playbook-rails.js +1 -1
  54. data/dist/playbook.css +1 -1
  55. data/lib/playbook/version.rb +1 -1
  56. metadata +7 -34
  57. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_list_rails.md +0 -5
  58. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_selectable_list_rails.html.erb +0 -38
  59. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_selectable_list_rails.md +0 -3
  60. data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_format.html.erb +0 -15
  61. data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_format.jsx +0 -24
  62. data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_format.md +0 -1
  63. data/app/pb_kits/playbook/pb_table/docs/_table_sticky_columns.html.erb +0 -74
  64. data/app/pb_kits/playbook/pb_table/docs/_table_sticky_columns_rails.md +0 -3
  65. data/app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns.html.erb +0 -74
  66. data/app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns_rails.md +0 -3
  67. data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible.html.erb +0 -47
  68. data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_rails.md +0 -2
  69. data/app/pb_kits/playbook/pb_table/utilities/addDataTitle.ts +0 -22
  70. data/dist/chunks/_weekday_stacked-s8bX_aFg.js +0 -45
  71. /data/app/pb_kits/playbook/pb_table/docs/{_table_with_collapsible_react.md → _table_with_collapsible.md} +0 -0
@@ -5,4 +5,3 @@ export { default as PhoneNumberInputOnlyCountries } from './_phone_number_input_
5
5
  export { default as PhoneNumberInputValidation } from './_phone_number_input_validation'
6
6
  export { default as PhoneNumberInputClearField } from './_phone_number_input_clear_field'
7
7
  export { default as PhoneNumberInputAccessInputElement } from './_phone_number_input_access_input_element'
8
- export { default as PhoneNumberInputFormat } from './_phone_number_input_format'
@@ -21,8 +21,6 @@ module Playbook
21
21
  default: ""
22
22
  prop :value, type: Playbook::Props::String,
23
23
  default: ""
24
- prop :format_as_you_type, type: Playbook::Props::Boolean,
25
- default: false
26
24
 
27
25
  def classname
28
26
  generate_classname("pb_phone_number_input")
@@ -34,7 +32,6 @@ module Playbook
34
32
  dark: dark,
35
33
  disabled: disabled,
36
34
  error: error,
37
- formatAsYouType: format_as_you_type,
38
35
  initialCountry: initial_country,
39
36
  label: label,
40
37
  name: name,
@@ -1,5 +1,5 @@
1
1
  import React from "react";
2
- import { render, screen, act } from "../utilities/test-utils";
2
+ import { render, screen } from "../utilities/test-utils";
3
3
  import PhoneNumberInput from "./_phone_number_input";
4
4
 
5
5
  const testId = "phoneNumberInput";
@@ -120,22 +120,3 @@ test("should trigger callback", () => {
120
120
 
121
121
  expect(handleOnValidate).toBeCalledWith(true)
122
122
  });
123
-
124
- test("should format phone number as '555-555-5555' with formatAsYouType and 'us' country", () => {
125
- const props = {
126
- initialCountry: 'us',
127
- formatAsYouType: true,
128
- id: testId,
129
- };
130
-
131
- render(<PhoneNumberInput {...props} />);
132
-
133
- const input = screen.getByRole("textbox");
134
-
135
- act(() => {
136
- input.value = "5555555555";
137
- input.dispatchEvent(new Event('input', { bubbles: true }));
138
- });
139
-
140
- expect(input.value).toBe("555-555-5555");
141
- });
@@ -4,7 +4,7 @@
4
4
  @import "../pb_body/body";
5
5
  @import "../tokens/transition";
6
6
 
7
- [class^="pb_radio_kit"] {
7
+ [class^=pb_radio_kit] {
8
8
  display: inline-flex;
9
9
  cursor: pointer;
10
10
 
@@ -16,11 +16,10 @@
16
16
  border-radius: 1000px;
17
17
  border: 2px solid $border_light;
18
18
  margin-right: $space_xs;
19
- transition: background $transition_default ease,
20
- box-shadow $transition_default ease, border-color $transition_default ease;
19
+ transition: background $transition_default ease, box-shadow $transition_default ease, border-color $transition_default ease;
21
20
  }
22
21
 
23
- @media (hover: hover) {
22
+ @media (hover:hover) {
24
23
  &:hover .pb_radio_button {
25
24
  background-color: $bg_light;
26
25
  border-color: $border_light;
@@ -53,14 +52,14 @@
53
52
  }
54
53
  }
55
54
 
56
- &:disabled:checked + .pb_radio_button {
55
+ &:disabled:checked + .pb_radio_button{
57
56
  cursor: not-allowed;
58
57
  background-color: $white;
59
58
  border: 6px solid $neutral;
60
59
  }
61
60
  }
62
61
 
63
- &[class*="vertical"] {
62
+ &[class*=vertical] {
64
63
  flex-direction: column;
65
64
  align-items: center;
66
65
  .pb_radio_button {
@@ -81,7 +80,7 @@
81
80
  }
82
81
  &:checked {
83
82
  & ~ .pb_radio_button {
84
- border: 6px solid $active_dark;
83
+ border: 6px solid $primary;
85
84
  }
86
85
  }
87
86
 
@@ -104,10 +103,10 @@
104
103
  }
105
104
  }
106
105
 
107
- @media (hover: hover) {
106
+ @media (hover:hover) {
108
107
  &:hover {
109
108
  .pb_radio_button {
110
- background-color: rgba($white, 0.1);
109
+ background-color: rgba($white,.10);
111
110
  border-color: $border_dark;
112
111
  }
113
112
  }
@@ -116,9 +115,6 @@
116
115
  > .pb_radio_button {
117
116
  border-color: $error_dark;
118
117
  }
119
- > .pb_body_kit_negative {
120
- color: $error_dark;
121
- }
122
118
  }
123
119
  }
124
120
  &.error {
@@ -29,7 +29,6 @@ const RadioChildren = (props) => {
29
29
  marginBottom="none"
30
30
  minWidth="xs"
31
31
  options={options}
32
- {...props}
33
32
  />
34
33
  </Radio>
35
34
  <Radio
@@ -41,11 +40,10 @@ const RadioChildren = (props) => {
41
40
  value="Typeahead"
42
41
  {...props}
43
42
  >
44
- <Typeahead
43
+ <Typeahead
45
44
  marginBottom="none"
46
45
  minWidth="xs"
47
46
  options={options}
48
- {...props}
49
47
  />
50
48
  </Radio>
51
49
  <Radio
@@ -56,12 +54,9 @@ const RadioChildren = (props) => {
56
54
  value="Typography"
57
55
  {...props}
58
56
  >
59
- <Title
60
- text="Custom Typography"
61
- {...props}
62
- />
57
+ <Title text="Custom Typography" />
63
58
  </Radio>
64
59
  </div>
65
60
  )
66
61
  }
67
- export default RadioChildren
62
+ export default RadioChildren
@@ -4,23 +4,9 @@
4
4
  data: object.data,
5
5
  id: object.id,
6
6
  **combined_html_options) do %>
7
- <% if enable_drag %>
8
- <%= pb_rails("draggable", props: {initial_items: object.items}) do %>
9
- <%= pb_rails("draggable/draggable_container") do %>
10
- <%= pb_rails("list", props: {ordered: false}) do %>
11
- <% object.items.each do |item| %>
12
- <%= pb_rails("draggable/draggable_item", props: {drag_id: item[:drag_id]}) do %>
13
- <%= pb_rails("selectable_list/selectable_list_item", props: item.merge(variant: object.variant, id: object.get_id(item), drag_id: item[:drag_id]) )%>
14
- <% end %>
15
- <% end %>
16
- <% end %>
17
- <% end %>
18
- <% end %>
19
- <% else %>
20
- <%= pb_rails("list") do %>
21
- <% object.items.each do |item| %>
22
- <%= pb_rails("selectable_list/selectable_list_item", props: item.merge(variant: object.variant, id: object.get_id(item)) )%>
23
- <% end %>
7
+ <%= pb_rails("list") do %>
8
+ <% object.items.each do |item| %>
9
+ <%= pb_rails("selectable_list/selectable_list_item", props: item.merge(variant: object.variant, id: object.get_id(item)) )%>
24
10
  <% end %>
25
11
  <% end %>
26
12
  <% end %>
@@ -14,9 +14,6 @@ module Playbook
14
14
  prop :items, type: Playbook::Props::Array,
15
15
  default: []
16
16
 
17
- prop :enable_drag, type: Playbook::Props::Boolean,
18
- default: false
19
-
20
17
  def classname
21
18
  generate_classname("pb_selectable_list_kit")
22
19
  end
@@ -4,13 +4,6 @@
4
4
  data: object.data,
5
5
  id: object.id,
6
6
  **combined_html_options) do %>
7
- <% if object.drag_id && object.drag_handle %>
8
- <span style="vertical-align: middle;">
9
- <%= pb_rails("body") do %>
10
- <svg width="auto" height="auto" viewBox="0 0 31 25" fill="none" xmlns="http://www.w3.org/2000/svg" color="currentColor" class="pb_custom_icon svg-inline--fa vertical_align_middle svg_fw"><path d="M12.904 6.355a1.48 1.48 0 01-1.5-1.5c0-.796.656-1.5 1.5-1.5.797 0 1.5.704 1.5 1.5 0 .844-.703 1.5-1.5 1.5zm0 7.5a1.48 1.48 0 01-1.5-1.5c0-.796.656-1.5 1.5-1.5.797 0 1.5.704 1.5 1.5 0 .844-.703 1.5-1.5 1.5zm1.5 6c0 .844-.703 1.5-1.5 1.5a1.48 1.48 0 01-1.5-1.5c0-.796.656-1.5 1.5-1.5.797 0 1.5.704 1.5 1.5zm4.5-13.5a1.48 1.48 0 01-1.5-1.5c0-.796.657-1.5 1.5-1.5.797 0 1.5.704 1.5 1.5 0 .844-.703 1.5-1.5 1.5zm1.5 6c0 .844-.703 1.5-1.5 1.5a1.48 1.48 0 01-1.5-1.5c0-.796.657-1.5 1.5-1.5.797 0 1.5.704 1.5 1.5zm-1.5 9a1.48 1.48 0 01-1.5-1.5c0-.796.657-1.5 1.5-1.5.797 0 1.5.704 1.5 1.5 0 .844-.703 1.5-1.5 1.5z" fill="#242B42"></path></svg>
11
- <% end %>
12
- </span>
13
- <% end %>
14
7
  <% if object.variant == "radio"%>
15
8
  <%= pb_rails("radio", props: { text: object.text, checked: object.checked, input_options: object.input_options } ) %>
16
9
  <% if content.present? %>
@@ -26,10 +19,10 @@
26
19
  <% if object.variant == "checkbox"%>
27
20
  <script>
28
21
  var checkboxElement = document.querySelector("#<%=object.id%> input[type=checkbox]")
29
-
22
+
30
23
  checkboxElement.addEventListener("change", (evt) => {
31
24
  var listItemElement = document.querySelector("#<%=object.id%>")
32
-
25
+
33
26
  if (evt.target.checked) {
34
27
  listItemElement.classList.add("checked_item");
35
28
  } else {
@@ -41,9 +34,9 @@
41
34
  <script>
42
35
  var radioElement = document.querySelector("#<%=object.id%> input[type=radio]")
43
36
 
44
- radioElement.addEventListener("change", () => {
37
+ radioElement.addEventListener("change", () => {
45
38
  var radios = radioElement.closest("ul").querySelectorAll("input[type=radio]")
46
-
39
+
47
40
  radios.forEach((radio) => {
48
41
  if (radio.checked) {
49
42
  radio.closest("li").classList.add("checked_item");
@@ -6,9 +6,6 @@ module Playbook
6
6
  prop :tabindex
7
7
  prop :checked, type: Playbook::Props::Boolean,
8
8
  default: false
9
- prop :drag_handle, type: Playbook::Props::Boolean,
10
- default: true
11
- prop :drag_id, type: Playbook::Props::String
12
9
  prop :name, type: Playbook::Props::String
13
10
  prop :text, type: Playbook::Props::String
14
11
  prop :value, type: Playbook::Props::String
@@ -2,6 +2,7 @@ import React, { useEffect } from 'react'
2
2
  import classnames from 'classnames'
3
3
  import { buildAriaProps, buildDataProps, buildHtmlProps } from '../utilities/props'
4
4
  import { globalProps, GlobalProps, globalInlineProps } from '../utilities/globalProps'
5
+ import PbTable from '.'
5
6
  import {
6
7
  TableHead,
7
8
  TableHeader,
@@ -9,7 +10,6 @@ import {
9
10
  TableRow,
10
11
  TableCell,
11
12
  } from "./subcomponents";
12
- import { addDataTitle } from './utilities/addDataTitle'
13
13
 
14
14
  type TableProps = {
15
15
  aria?: { [key: string]: string },
@@ -196,7 +196,8 @@ const Table = (props: TableProps): React.ReactElement => {
196
196
  }, [stickyRightColumn]);
197
197
 
198
198
  useEffect(() => {
199
- addDataTitle()
199
+ const instance = new PbTable()
200
+ instance.connect()
200
201
  }, [])
201
202
 
202
203
  return (
@@ -1,3 +1,3 @@
1
- The `sticky_left_column` prop expects an array of the column ids you want to be sticky. Make sure to add the corresponding id to the `<th>` and `<td>`.
1
+ The `stickyLeftColumn` prop expects an array of the column ids you want to be sticky. Make sure to add the corresponding id to the `<th>` and `<td>`.
2
2
 
3
- Please ensure that unique ids are used for all columns across multiple tables. Using the same columns ids on multiple tables can lead to issues when using the `sticky_left_column`.
3
+ Please ensure that unique ids are used for all columns across multiple tables. Using the same columns ids on multiple tables can lead to issues when using the `stickyLeftColumn`.
@@ -5,8 +5,6 @@ examples:
5
5
  - table_lg: Large
6
6
  - table_sticky: Sticky Header
7
7
  - table_sticky_left_columns: Sticky Left Column
8
- - table_sticky_right_columns: Sticky Right Column
9
- - table_sticky_columns: Sticky Left and Right Columns
10
8
  - table_header: Table Header
11
9
  - table_alignment_row_rails: Row Alignment
12
10
  - table_alignment_column_rails: Cell Alignment
@@ -30,7 +28,6 @@ examples:
30
28
  - table_with_subcomponents_rails: Table with Sub Components (Table Elements)
31
29
  - table_with_subcomponents_as_divs: Table with Sub Components (Divs)
32
30
  - table_outer_padding: Outer Padding
33
- - table_with_collapsible: Table with Collapsible
34
31
 
35
32
  react:
36
33
  - table_sm: Small
@@ -1,207 +1,108 @@
1
1
  import PbEnhancedElement from '../pb_enhanced_element'
2
2
 
3
- const TABLE_WRAPPER_SELECTOR = "[data-pb-table-wrapper]";
4
- const TABLE_COLLAPSIBLE_WRAPPER_SELECTOR = "[data-pb-table-collapsible-wrapper]";
5
-
6
3
  export default class PbTable extends PbEnhancedElement {
7
- stickyLeftColumns: string[] = [];
8
- stickyRightColumns: string[] = [];
9
- stickyRightColumnsReversed: string[] = [];
10
-
11
- static get selector(): string {
12
- return TABLE_WRAPPER_SELECTOR;
13
- }
14
-
15
- connect() {
16
- if (this.element.classList.contains('table-responsive-collapse')) {
17
- const headers: string[] = [];
18
-
19
- [].forEach.call(this.element.querySelectorAll('th'), (header: HTMLTableCellElement) => {
20
- const colSpan = header.colSpan
21
- for (let i = 0; i < colSpan; i++) {
22
- headers.push(header.textContent.replace(/\r?\n|\r/, ''));
23
- }
24
- });
25
-
26
- [].forEach.call(this.element.querySelectorAll('tbody tr'), (row: HTMLTableRowElement) => {
27
- [].forEach.call(row.cells, (cell: HTMLTableCellElement, headerIndex: number) => {
28
- cell.setAttribute('data-title', headers[headerIndex])
29
- })
30
- })
31
- }
4
+ private stickyLeftColumns: string[] = [];
5
+ private handleStickyLeftColumnsRef: () => void;
32
6
 
33
- this.initStickyLeftColumns();
34
- this.initStickyRightColumns();
35
- this.handleCollapsibleClick();
36
- this.handleCollapsibleRow();
37
- }
38
-
39
- initStickyLeftColumns() {
40
- const table = this.element.querySelector('.sticky-left-column');
41
-
42
- if (table) {
43
- const classList = Array.from(table.classList);
44
- const stickyColumnClass = classList.find(cls => cls.startsWith('sticky-left-columns-ids-'));
45
-
46
- if (stickyColumnClass) {
47
- this.stickyLeftColumns = stickyColumnClass
48
- .replace('sticky-left-columns-ids-', '')
49
- .split('-');
50
-
51
- if (this.stickyLeftColumns.length > 0) {
52
- setTimeout(() => {
53
- this.handleStickyLeftColumns();
54
- window.addEventListener('resize', () => this.handleStickyLeftColumns());
55
- }, 10);
56
- }
57
- }
7
+ static get selector(): string {
8
+ return '.table-responsive-collapse'
58
9
  }
59
- }
60
-
61
- handleStickyLeftColumns() {
62
- let accumulatedWidth = 0;
63
-
64
- this.stickyLeftColumns.forEach((colId, index) => {
65
- const isLastColumn = index === this.stickyLeftColumns.length - 1;
66
- const header = this.element.querySelector(`th[id="${colId}"]`);
67
- const cells = this.element.querySelectorAll(`td[id="${colId}"]`);
68
-
69
- if (header) {
70
- header.classList.add('sticky');
71
- (header as HTMLElement).style.left = `${accumulatedWidth}px`;
72
-
73
- if (!isLastColumn) {
74
- header.classList.add('with-border-right');
75
- header.classList.remove('sticky-left-shadow');
76
- } else {
77
- header.classList.remove('with-border-right');
78
- header.classList.add('sticky-left-shadow');
79
- }
80
10
 
81
- accumulatedWidth += (header as HTMLElement).offsetWidth;
82
- }
11
+ connect(): void {
12
+ const tables = document.querySelectorAll('.table-responsive-collapse');
13
+ // Each Table
14
+ [].forEach.call(tables, (table: HTMLTableElement) => {
15
+ // Header Titles
16
+ const headers: string[] = [];
17
+ [].forEach.call(table.querySelectorAll('th'), (header: HTMLTableCellElement) => {
18
+ const colSpan = header.colSpan
19
+ for (let i = 0; i < colSpan; i++) {
20
+ headers.push(header.textContent.replace(/\r?\n|\r/, ''));
21
+ }
22
+ });
23
+ // for each row in tbody
24
+ [].forEach.call(table.querySelectorAll('tbody tr'), (row: HTMLTableRowElement) => {
25
+ // for each cell
26
+ [].forEach.call(row.cells, (cell: HTMLTableCellElement, headerIndex: number) => {
27
+ // apply the attribute
28
+ cell.setAttribute('data-title', headers[headerIndex])
29
+ })
30
+ })
31
+ });
83
32
 
84
- cells.forEach((cell) => {
85
- cell.classList.add('sticky');
86
- (cell as HTMLElement).style.left = `${accumulatedWidth - (header as HTMLElement).offsetWidth}px`;
33
+ // New sticky columns logic
34
+ this.initStickyLeftColumns();
35
+ }
87
36
 
88
- if (!isLastColumn) {
89
- cell.classList.add('with-border-right');
90
- cell.classList.remove('sticky-left-shadow');
91
- } else {
92
- cell.classList.remove('with-border-right');
93
- cell.classList.add('sticky-left-shadow');
37
+ private initStickyLeftColumns(): void {
38
+ // Find tables with sticky-left-column class
39
+ const tables = document.querySelectorAll('.sticky-left-column');
40
+
41
+ tables.forEach((table) => {
42
+ // Extract sticky left column IDs by looking at the component's class
43
+ const classList = Array.from(table.classList);
44
+
45
+ // Look for classes in the format sticky-left-column-{ids}
46
+ const stickyColumnClass = classList.find(cls => cls.startsWith('sticky-columns-'));
47
+ if (stickyColumnClass) {
48
+ // Extract the IDs from the class name
49
+ this.stickyLeftColumns = stickyColumnClass
50
+ .replace('sticky-columns-', '')
51
+ .split('-');
52
+
53
+ if (this.stickyLeftColumns.length > 0) {
54
+ setTimeout(() => {
55
+ this.handleStickyLeftColumnsRef = this.handleStickyLeftColumns.bind(this);
56
+ this.handleStickyLeftColumns();
57
+ window.addEventListener('resize', this.handleStickyLeftColumnsRef);
58
+ }, 10);
59
+ }
94
60
  }
95
61
  });
96
- });
97
- }
98
-
99
- initStickyRightColumns() {
100
- const table = this.element.querySelector('.sticky-right-column');
101
-
102
- if (table) {
103
- const classList = Array.from(table.classList);
104
- const stickyColumnClass = classList.find(cls => cls.startsWith('sticky-right-columns-ids-'));
105
-
106
- if (stickyColumnClass) {
107
- this.stickyRightColumns = stickyColumnClass
108
- .replace('sticky-right-columns-ids-', '')
109
- .split('-');
110
- this.stickyRightColumnsReversed = this.stickyRightColumns.reverse();
111
-
112
- if (this.stickyRightColumns.length > 0) {
113
- setTimeout(() => {
114
- this.handleStickyRightColumns();
115
- window.addEventListener('resize', () => this.handleStickyRightColumns());
116
- }, 10);
117
- }
118
- }
119
62
  }
120
- }
121
-
122
- handleStickyRightColumns() {
123
- let accumulatedWidth = 0;
124
-
125
- this.stickyRightColumnsReversed.forEach((colId, index) => {
126
- const isLastColumn = index === this.stickyRightColumns.length - 1;
127
- const header = this.element.querySelector(`th[id="${colId}"]`);
128
- const cells = this.element.querySelectorAll(`td[id="${colId}"]`);
129
-
130
- if (header) {
131
- header.classList.add('sticky');
132
- (header as HTMLElement).style.right = `${accumulatedWidth}px`;
133
-
134
- if (!isLastColumn) {
135
- header.classList.add('with-border-left');
136
- header.classList.remove('sticky-right-shadow');
137
- } else {
138
- header.classList.remove('with-border-right');
139
- header.classList.add('sticky-right-shadow');
140
- }
141
63
 
142
- accumulatedWidth += (header as HTMLElement).offsetWidth;
143
- }
64
+ private handleStickyLeftColumns(): void {
65
+ let accumulatedWidth = 0;
144
66
 
145
- cells.forEach((cell) => {
146
- cell.classList.add('sticky');
147
- (cell as HTMLElement).style.right = `${accumulatedWidth - (header as HTMLElement).offsetWidth}px`;
67
+ this.stickyLeftColumns.forEach((colId, index) => {
68
+ const isLastColumn = index === this.stickyLeftColumns.length - 1;
69
+ const header = document.querySelector(`th[id="${colId}"]`);
70
+ const cells = document.querySelectorAll(`td[id="${colId}"]`);
148
71
 
149
- if (!isLastColumn) {
150
- cell.classList.add('with-border-left');
151
- cell.classList.remove('sticky-right-shadow');
152
- } else {
153
- cell.classList.remove('with-border-left');
154
- cell.classList.add('sticky-right-shadow');
155
- }
156
- });
157
- });
158
- }
159
-
160
- handleCollapsibleClick() {
161
- const collapsibleElements = this.element.querySelectorAll(TABLE_COLLAPSIBLE_WRAPPER_SELECTOR);
162
- collapsibleElements.forEach((collapsibleElement) => {
163
- collapsibleElement.addEventListener('click', (event) => {
164
- document.dispatchEvent(new CustomEvent(`collapsed-toggle${(event.currentTarget as HTMLElement).id}`))
165
-
166
- const toggleElements = this.element.querySelectorAll(`.collapsible_border_toggle${(event.currentTarget as HTMLElement).id}`);
167
- toggleElements.forEach(element => {
168
- element.classList.toggle('no-border');
169
- element.classList.toggle('border-active');
170
- });
171
- })
172
- })
173
- }
174
-
175
- handleCollapsibleRow() {
176
- const collapsibleRows = this.element.querySelectorAll('.pb_table_collapsible_row');
177
- if (collapsibleRows.length > 0) {
178
- collapsibleRows.forEach((row) => {
179
- const previousRow = row.previousElementSibling;
180
-
181
- if (
182
- previousRow &&
183
- previousRow.tagName === 'TR'
184
- ) {
185
- const tdCount = previousRow.querySelectorAll('td').length;
186
- const collapsibleTd = row.querySelector('td');
187
- if (collapsibleTd) {
188
- collapsibleTd.colSpan = tdCount;
72
+ if (header) {
73
+ header.classList.add('sticky');
74
+ (header as HTMLElement).style.left = `${accumulatedWidth}px`;
75
+
76
+ if (!isLastColumn) {
77
+ header.classList.add('with-border-right');
78
+ header.classList.remove('sticky-left-shadow');
79
+ } else {
80
+ header.classList.remove('with-border-right');
81
+ header.classList.add('sticky-left-shadow');
189
82
  }
190
- } else {
191
- return
83
+
84
+ accumulatedWidth += (header as HTMLElement).offsetWidth;
192
85
  }
193
- });
194
- }
195
- }
196
86
 
197
- // Cleanup method to remove event listener
198
- disconnect() {
199
- if (this.stickyLeftColumns.length > 0) {
200
- window.removeEventListener('resize', () => this.handleStickyLeftColumns());
87
+ cells.forEach((cell) => {
88
+ cell.classList.add('sticky');
89
+ (cell as HTMLElement).style.left = `${accumulatedWidth - (header as HTMLElement).offsetWidth}px`;
90
+
91
+ if (!isLastColumn) {
92
+ cell.classList.add('with-border-right');
93
+ cell.classList.remove('sticky-left-shadow');
94
+ } else {
95
+ cell.classList.remove('with-border-right');
96
+ cell.classList.add('sticky-left-shadow');
97
+ }
98
+ });
99
+ });
201
100
  }
202
101
 
203
- if (this.stickyRightColumns.length > 0) {
204
- window.removeEventListener('resize', () => this.handleStickyRightColumns());
102
+ // Cleanup method to remove event listener
103
+ disconnect(): void {
104
+ if (this.handleStickyLeftColumnsRef) {
105
+ window.removeEventListener('resize', this.handleStickyLeftColumnsRef);
106
+ }
205
107
  }
206
- }
207
- }
108
+ }
@@ -32,16 +32,4 @@
32
32
  }
33
33
  }
34
34
  }
35
-
36
- .collapsible-tr {
37
- cursor: pointer;
38
- }
39
-
40
- .no-border {
41
- border-bottom: none !important;
42
- }
43
-
44
- .border-active {
45
- border-bottom: 1px;
46
- }
47
35
  }
@@ -4,7 +4,7 @@
4
4
  <% responsive_class = nil %>
5
5
  <% end %>
6
6
 
7
- <%= content_tag(:div, class: responsive_class, 'data-pb-table-wrapper' => true) do %>
7
+ <%= content_tag(:div, class: responsive_class) do %>
8
8
  <% if object.tag == "table" %>
9
9
  <%= content_tag(:table,
10
10
  aria: object.aria,
@@ -25,8 +25,6 @@ module Playbook
25
25
  default: false
26
26
  prop :sticky_left_column, type: Playbook::Props::Array,
27
27
  default: []
28
- prop :sticky_right_column, type: Playbook::Props::Array,
29
- default: []
30
28
  prop :vertical_border, type: Playbook::Props::Boolean,
31
29
  default: false
32
30
  prop :striped, type: Playbook::Props::Boolean,
@@ -42,7 +40,7 @@ module Playbook
42
40
  generate_classname(
43
41
  "pb_table", "table-#{size}", single_line_class, dark_class,
44
42
  disable_hover_class, container_class, data_table_class, sticky_class, sticky_left_column_class,
45
- sticky_right_column_class, collapse_class, vertical_border_class, striped_class, outer_padding_class,
43
+ collapse_class, vertical_border_class, striped_class, outer_padding_class,
46
44
  "table-responsive-#{responsive}", separator: " "
47
45
  )
48
46
  end
@@ -85,7 +83,7 @@ module Playbook
85
83
  if sticky_left_column.empty?
86
84
  nil
87
85
  else
88
- sticky_col_classname = "sticky-left-column sticky-left-columns-ids"
86
+ sticky_col_classname = "sticky-left-column sticky-columns"
89
87
  sticky_left_column.each do |id|
90
88
  sticky_col_classname += "-#{id}"
91
89
  end
@@ -94,19 +92,6 @@ module Playbook
94
92
  end
95
93
  end
96
94
 
97
- def sticky_right_column_class
98
- if sticky_right_column.empty?
99
- nil
100
- else
101
- sticky_col_classname = "sticky-right-column sticky-right-columns-ids"
102
- sticky_right_column.each do |id|
103
- sticky_col_classname += "-#{id}"
104
- end
105
-
106
- sticky_col_classname
107
- end
108
- end
109
-
110
95
  def striped_class
111
96
  striped ? "striped" : nil
112
97
  end