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.
- checksums.yaml +4 -4
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sort_control.md +2 -2
- data/app/pb_kits/playbook/pb_button/button.html.erb +3 -2
- data/app/pb_kits/playbook/pb_checkbox/checkbox.html.erb +6 -1
- data/app/pb_kits/playbook/pb_collapsible/collapsible.html.erb +1 -3
- data/app/pb_kits/playbook/pb_collapsible/collapsible.rb +0 -3
- data/app/pb_kits/playbook/pb_date_picker/date_picker.html.erb +6 -2
- data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_default_date.md +1 -1
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_list_rails.html.erb +9 -3
- data/app/pb_kits/playbook/pb_draggable/docs/example.yml +0 -1
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_subtle_variant.md +1 -1
- data/app/pb_kits/playbook/pb_dropdown/dropdown.html.erb +12 -7
- data/app/pb_kits/playbook/pb_dropdown/dropdown_container.html.erb +14 -9
- data/app/pb_kits/playbook/pb_dropdown/dropdown_option.html.erb +11 -6
- data/app/pb_kits/playbook/pb_dropdown/dropdown_trigger.html.erb +14 -8
- data/app/pb_kits/playbook/pb_list/item.html.erb +8 -30
- data/app/pb_kits/playbook/pb_list/item.rb +0 -7
- data/app/pb_kits/playbook/pb_list/list.html.erb +11 -31
- data/app/pb_kits/playbook/pb_list/list.rb +0 -4
- data/app/pb_kits/playbook/pb_loading_inline/_loading_inline.tsx +1 -6
- data/app/pb_kits/playbook/pb_map/_map.scss +3 -0
- data/app/pb_kits/playbook/pb_map/docs/_map_default.jsx +4 -4
- data/app/pb_kits/playbook/pb_map/docs/_map_with_custom_button.jsx +7 -7
- data/app/pb_kits/playbook/pb_map/docs/_map_with_plugin.jsx +5 -5
- data/app/pb_kits/playbook/pb_phone_number_input/_phone_number_input.tsx +12 -30
- data/app/pb_kits/playbook/pb_phone_number_input/docs/example.yml +1 -3
- data/app/pb_kits/playbook/pb_phone_number_input/docs/index.js +0 -1
- data/app/pb_kits/playbook/pb_phone_number_input/phone_number_input.rb +0 -3
- data/app/pb_kits/playbook/pb_phone_number_input/phone_number_input.test.js +1 -20
- data/app/pb_kits/playbook/pb_radio/_radio.scss +8 -12
- data/app/pb_kits/playbook/pb_radio/docs/_radio_custom_children.jsx +3 -8
- data/app/pb_kits/playbook/pb_selectable_list/selectable_list.html.erb +3 -17
- data/app/pb_kits/playbook/pb_selectable_list/selectable_list.rb +0 -3
- data/app/pb_kits/playbook/pb_selectable_list/selectable_list_item.html.erb +4 -11
- data/app/pb_kits/playbook/pb_selectable_list/selectable_list_item.rb +0 -3
- data/app/pb_kits/playbook/pb_table/_table.tsx +3 -2
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns_rails.md +2 -2
- data/app/pb_kits/playbook/pb_table/docs/example.yml +0 -3
- data/app/pb_kits/playbook/pb_table/index.ts +88 -187
- data/app/pb_kits/playbook/pb_table/styles/_collapsible.scss +0 -12
- data/app/pb_kits/playbook/pb_table/table.html.erb +1 -1
- data/app/pb_kits/playbook/pb_table/table.rb +2 -17
- data/app/pb_kits/playbook/pb_table/table_row.html.erb +1 -20
- data/app/pb_kits/playbook/pb_table/table_row.rb +0 -5
- data/app/pb_kits/playbook/pb_timeline/_timeline.scss +30 -30
- data/dist/chunks/{_typeahead-DjGX1O4K.js → _typeahead-BNULwihE.js} +2 -2
- data/dist/chunks/_weekday_stacked-BKWemDAe.js +45 -0
- data/dist/chunks/{lib-kMuhBuU7.js → lib-B7sgJtGS.js} +2 -2
- data/dist/chunks/{pb_form_validation-DBJ0wZuS.js → pb_form_validation-C5Cc0-1v.js} +1 -1
- data/dist/chunks/vendor.js +1 -1
- data/dist/playbook-doc.js +1 -1
- 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 +1 -1
- metadata +7 -34
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_list_rails.md +0 -5
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_selectable_list_rails.html.erb +0 -38
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_selectable_list_rails.md +0 -3
- data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_format.html.erb +0 -15
- data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_format.jsx +0 -24
- data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_format.md +0 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_columns.html.erb +0 -74
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_columns_rails.md +0 -3
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns.html.erb +0 -74
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns_rails.md +0 -3
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible.html.erb +0 -47
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_rails.md +0 -2
- data/app/pb_kits/playbook/pb_table/utilities/addDataTitle.ts +0 -22
- data/dist/chunks/_weekday_stacked-s8bX_aFg.js +0 -45
- /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
|
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^=
|
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:
|
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*=
|
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 $
|
83
|
+
border: 6px solid $primary;
|
85
84
|
}
|
86
85
|
}
|
87
86
|
|
@@ -104,10 +103,10 @@
|
|
104
103
|
}
|
105
104
|
}
|
106
105
|
|
107
|
-
@media (hover:
|
106
|
+
@media (hover:hover) {
|
108
107
|
&:hover {
|
109
108
|
.pb_radio_button {
|
110
|
-
background-color: rgba($white
|
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
|
-
|
8
|
-
|
9
|
-
<%= pb_rails("
|
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 %>
|
@@ -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
|
-
|
199
|
+
const instance = new PbTable()
|
200
|
+
instance.connect()
|
200
201
|
}, [])
|
201
202
|
|
202
203
|
return (
|
@@ -1,3 +1,3 @@
|
|
1
|
-
The `
|
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 `
|
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
|
-
|
8
|
-
|
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
|
-
|
34
|
-
|
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
|
-
|
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
|
-
|
85
|
-
|
86
|
-
|
33
|
+
// New sticky columns logic
|
34
|
+
this.initStickyLeftColumns();
|
35
|
+
}
|
87
36
|
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
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
|
-
|
143
|
-
|
64
|
+
private handleStickyLeftColumns(): void {
|
65
|
+
let accumulatedWidth = 0;
|
144
66
|
|
145
|
-
|
146
|
-
|
147
|
-
|
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 (
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
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
|
-
|
191
|
-
|
83
|
+
|
84
|
+
accumulatedWidth += (header as HTMLElement).offsetWidth;
|
192
85
|
}
|
193
|
-
});
|
194
|
-
}
|
195
|
-
}
|
196
86
|
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
|
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
|
-
|
204
|
-
|
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
|
+
}
|
@@ -4,7 +4,7 @@
|
|
4
4
|
<% responsive_class = nil %>
|
5
5
|
<% end %>
|
6
6
|
|
7
|
-
<%= content_tag(:div, class: responsive_class
|
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
|
-
|
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-
|
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
|