playbook_ui 14.11.1.pre.alpha.PLAY17445539 → 14.11.1.pre.alpha.hfhbrakemanplaybook5370

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 (76) 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_date_picker/date_picker.html.erb +6 -2
  6. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_default_date.md +1 -1
  7. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_list_rails.html.erb +9 -3
  8. data/app/pb_kits/playbook/pb_draggable/docs/example.yml +0 -1
  9. data/app/pb_kits/playbook/pb_drawer/_drawer.scss +177 -154
  10. data/app/pb_kits/playbook/pb_drawer/_drawer.tsx +264 -162
  11. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_borders.jsx +45 -3
  12. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_breakpoints.jsx +1 -0
  13. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_default.jsx +16 -9
  14. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_menu.jsx +19 -44
  15. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_menu.md +3 -21
  16. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_overlay.jsx +21 -16
  17. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_sizes.jsx +19 -2
  18. data/app/pb_kits/playbook/pb_drawer/docs/example.yml +1 -2
  19. data/app/pb_kits/playbook/pb_drawer/docs/index.js +0 -1
  20. data/app/pb_kits/playbook/pb_drawer/drawer.test.jsx +5 -5
  21. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_subtle_variant.md +1 -1
  22. data/app/pb_kits/playbook/pb_dropdown/dropdown.html.erb +12 -7
  23. data/app/pb_kits/playbook/pb_dropdown/dropdown_container.html.erb +14 -9
  24. data/app/pb_kits/playbook/pb_dropdown/dropdown_option.html.erb +11 -6
  25. data/app/pb_kits/playbook/pb_dropdown/dropdown_trigger.html.erb +14 -8
  26. data/app/pb_kits/playbook/pb_list/item.html.erb +8 -30
  27. data/app/pb_kits/playbook/pb_list/item.rb +0 -7
  28. data/app/pb_kits/playbook/pb_list/list.html.erb +11 -31
  29. data/app/pb_kits/playbook/pb_list/list.rb +0 -4
  30. data/app/pb_kits/playbook/pb_loading_inline/_loading_inline.tsx +1 -6
  31. data/app/pb_kits/playbook/pb_phone_number_input/_phone_number_input.tsx +12 -30
  32. data/app/pb_kits/playbook/pb_phone_number_input/docs/example.yml +1 -3
  33. data/app/pb_kits/playbook/pb_phone_number_input/docs/index.js +0 -1
  34. data/app/pb_kits/playbook/pb_phone_number_input/phone_number_input.rb +0 -3
  35. data/app/pb_kits/playbook/pb_phone_number_input/phone_number_input.test.js +1 -20
  36. data/app/pb_kits/playbook/pb_radio/_radio.scss +8 -12
  37. data/app/pb_kits/playbook/pb_radio/docs/_radio_custom_children.jsx +3 -8
  38. data/app/pb_kits/playbook/pb_selectable_list/selectable_list.html.erb +3 -17
  39. data/app/pb_kits/playbook/pb_selectable_list/selectable_list.rb +0 -3
  40. data/app/pb_kits/playbook/pb_selectable_list/selectable_list_item.html.erb +4 -11
  41. data/app/pb_kits/playbook/pb_selectable_list/selectable_list_item.rb +0 -3
  42. data/app/pb_kits/playbook/pb_table/_table.tsx +3 -2
  43. data/app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns_rails.md +2 -2
  44. data/app/pb_kits/playbook/pb_table/docs/example.yml +0 -2
  45. data/app/pb_kits/playbook/pb_table/index.ts +34 -93
  46. data/app/pb_kits/playbook/pb_table/styles/_scroll.scss +5 -6
  47. data/app/pb_kits/playbook/pb_table/table.html.erb +1 -1
  48. data/app/pb_kits/playbook/pb_table/table.rb +2 -17
  49. data/app/pb_kits/playbook/pb_timeline/_timeline.scss +30 -30
  50. data/dist/chunks/{_typeahead-vFuUQM5F.js → _typeahead-BNULwihE.js} +2 -2
  51. data/dist/chunks/_weekday_stacked-BKWemDAe.js +45 -0
  52. data/dist/chunks/{lib-OFT985dg.js → lib-B7sgJtGS.js} +2 -2
  53. data/dist/chunks/{pb_form_validation-CrsXd1-Y.js → pb_form_validation-C5Cc0-1v.js} +1 -1
  54. data/dist/chunks/vendor.js +1 -1
  55. data/dist/playbook-doc.js +1 -1
  56. data/dist/playbook-rails-react-bindings.js +1 -1
  57. data/dist/playbook-rails.js +1 -1
  58. data/dist/playbook.css +1 -1
  59. data/lib/playbook/version.rb +1 -1
  60. metadata +6 -21
  61. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_list_rails.md +0 -5
  62. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_selectable_list_rails.html.erb +0 -38
  63. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_selectable_list_rails.md +0 -3
  64. data/app/pb_kits/playbook/pb_drawer/context.ts +0 -11
  65. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_behavior.jsx +0 -38
  66. data/app/pb_kits/playbook/pb_drawer/hooks/useBreakpoint.tsx +0 -73
  67. data/app/pb_kits/playbook/pb_drawer/hooks/useDrawerAnimation.tsx +0 -21
  68. data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_format.html.erb +0 -15
  69. data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_format.jsx +0 -24
  70. data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_format.md +0 -1
  71. data/app/pb_kits/playbook/pb_table/docs/_table_sticky_columns.html.erb +0 -74
  72. data/app/pb_kits/playbook/pb_table/docs/_table_sticky_columns_rails.md +0 -3
  73. data/app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns.html.erb +0 -74
  74. data/app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns_rails.md +0 -3
  75. data/app/pb_kits/playbook/pb_table/utilities/addDataTitle.ts +0 -22
  76. data/dist/chunks/_weekday_stacked-DG3A22sS.js +0 -45
@@ -2,5 +2,5 @@
2
2
 
3
3
  module Playbook
4
4
  PREVIOUS_VERSION = "14.11.1"
5
- VERSION = "14.11.1.pre.alpha.PLAY17445539"
5
+ VERSION = "14.11.1.pre.alpha.hfhbrakemanplaybook5370"
6
6
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: playbook_ui
3
3
  version: !ruby/object:Gem::Version
4
- version: 14.11.1.pre.alpha.PLAY17445539
4
+ version: 14.11.1.pre.alpha.hfhbrakemanplaybook5370
5
5
  platform: ruby
6
6
  authors:
7
7
  - Power UX
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2025-01-22 00:00:00.000000000 Z
12
+ date: 2025-01-14 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: actionpack
@@ -1146,11 +1146,8 @@ files:
1146
1146
  - app/pb_kits/playbook/pb_draggable/docs/_draggable_with_list.jsx
1147
1147
  - app/pb_kits/playbook/pb_draggable/docs/_draggable_with_list.md
1148
1148
  - app/pb_kits/playbook/pb_draggable/docs/_draggable_with_list_rails.html.erb
1149
- - app/pb_kits/playbook/pb_draggable/docs/_draggable_with_list_rails.md
1150
1149
  - app/pb_kits/playbook/pb_draggable/docs/_draggable_with_selectable_list.jsx
1151
1150
  - app/pb_kits/playbook/pb_draggable/docs/_draggable_with_selectable_list.md
1152
- - app/pb_kits/playbook/pb_draggable/docs/_draggable_with_selectable_list_rails.html.erb
1153
- - app/pb_kits/playbook/pb_draggable/docs/_draggable_with_selectable_list_rails.md
1154
1151
  - app/pb_kits/playbook/pb_draggable/docs/example.yml
1155
1152
  - app/pb_kits/playbook/pb_draggable/docs/index.js
1156
1153
  - app/pb_kits/playbook/pb_draggable/draggable.html.erb
@@ -1167,8 +1164,6 @@ files:
1167
1164
  - app/pb_kits/playbook/pb_drawer/_drawer.scss
1168
1165
  - app/pb_kits/playbook/pb_drawer/_drawer.tsx
1169
1166
  - app/pb_kits/playbook/pb_drawer/_drawer_context.tsx
1170
- - app/pb_kits/playbook/pb_drawer/context.ts
1171
- - app/pb_kits/playbook/pb_drawer/docs/_drawer_behavior.jsx
1172
1167
  - app/pb_kits/playbook/pb_drawer/docs/_drawer_borders.jsx
1173
1168
  - app/pb_kits/playbook/pb_drawer/docs/_drawer_breakpoints.jsx
1174
1169
  - app/pb_kits/playbook/pb_drawer/docs/_drawer_default.html.erb
@@ -1182,8 +1177,6 @@ files:
1182
1177
  - app/pb_kits/playbook/pb_drawer/drawer.html.erb
1183
1178
  - app/pb_kits/playbook/pb_drawer/drawer.rb
1184
1179
  - app/pb_kits/playbook/pb_drawer/drawer.test.jsx
1185
- - app/pb_kits/playbook/pb_drawer/hooks/useBreakpoint.tsx
1186
- - app/pb_kits/playbook/pb_drawer/hooks/useDrawerAnimation.tsx
1187
1180
  - app/pb_kits/playbook/pb_dropdown/_dropdown.scss
1188
1181
  - app/pb_kits/playbook/pb_dropdown/_dropdown.tsx
1189
1182
  - app/pb_kits/playbook/pb_dropdown/context/index.tsx
@@ -2161,9 +2154,6 @@ files:
2161
2154
  - app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_default.html.erb
2162
2155
  - app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_default.jsx
2163
2156
  - app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_default.md
2164
- - app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_format.html.erb
2165
- - app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_format.jsx
2166
- - app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_format.md
2167
2157
  - app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_initial_country.html.erb
2168
2158
  - app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_initial_country.jsx
2169
2159
  - app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_initial_country.md
@@ -2669,17 +2659,13 @@ files:
2669
2659
  - app/pb_kits/playbook/pb_table/docs/_table_sticky.html.erb
2670
2660
  - app/pb_kits/playbook/pb_table/docs/_table_sticky.jsx
2671
2661
  - app/pb_kits/playbook/pb_table/docs/_table_sticky.md
2672
- - app/pb_kits/playbook/pb_table/docs/_table_sticky_columns.html.erb
2673
2662
  - app/pb_kits/playbook/pb_table/docs/_table_sticky_columns.jsx
2674
- - app/pb_kits/playbook/pb_table/docs/_table_sticky_columns_rails.md
2675
2663
  - app/pb_kits/playbook/pb_table/docs/_table_sticky_columns_react.md
2676
2664
  - app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns.html.erb
2677
2665
  - app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns.jsx
2678
2666
  - app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns_rails.md
2679
2667
  - app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns_react.md
2680
- - app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns.html.erb
2681
2668
  - app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns.jsx
2682
- - app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns_rails.md
2683
2669
  - app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns_react.md
2684
2670
  - app/pb_kits/playbook/pb_table/docs/_table_striped.html.erb
2685
2671
  - app/pb_kits/playbook/pb_table/docs/_table_striped.jsx
@@ -2757,7 +2743,6 @@ files:
2757
2743
  - app/pb_kits/playbook/pb_table/table_header.rb
2758
2744
  - app/pb_kits/playbook/pb_table/table_row.html.erb
2759
2745
  - app/pb_kits/playbook/pb_table/table_row.rb
2760
- - app/pb_kits/playbook/pb_table/utilities/addDataTitle.ts
2761
2746
  - app/pb_kits/playbook/pb_text_input/_text_input.scss
2762
2747
  - app/pb_kits/playbook/pb_text_input/_text_input.tsx
2763
2748
  - app/pb_kits/playbook/pb_text_input/add_on.html.erb
@@ -3266,11 +3251,11 @@ files:
3266
3251
  - app/pb_kits/playbook/utilities/test/globalProps/truncate.test.js
3267
3252
  - app/pb_kits/playbook/utilities/text.ts
3268
3253
  - app/pb_kits/playbook/utilities/validEmojiChecker.ts
3269
- - dist/chunks/_typeahead-vFuUQM5F.js
3270
- - dist/chunks/_weekday_stacked-DG3A22sS.js
3254
+ - dist/chunks/_typeahead-BNULwihE.js
3255
+ - dist/chunks/_weekday_stacked-BKWemDAe.js
3271
3256
  - dist/chunks/lazysizes-B7xYodB-.js
3272
- - dist/chunks/lib-OFT985dg.js
3273
- - dist/chunks/pb_form_validation-CrsXd1-Y.js
3257
+ - dist/chunks/lib-B7sgJtGS.js
3258
+ - dist/chunks/pb_form_validation-C5Cc0-1v.js
3274
3259
  - dist/chunks/vendor.js
3275
3260
  - dist/menu.yml
3276
3261
  - dist/playbook-doc.js
@@ -1,5 +0,0 @@
1
- For a simplified version of the Draggable API for the List kit, you can do the following:
2
-
3
- The List kit is optimized to work with the draggable kit. To enable drag, use the `enable_drag` prop on List kit with an array of the included items AND `drag_id` prop on ListItems. You will also need to include the `items` prop containing your array of listed items for the Draggable API.
4
-
5
- An additional optional boolean prop (set to true by default) of `drag_handle` is also available on ListItem kit to show the drag handle icon.
@@ -1,38 +0,0 @@
1
- <%= pb_rails("selectable_list",
2
- props: {
3
- enable_drag: true,
4
- variant: "radio",
5
- items: [
6
- { drag_id: "41",
7
- text: "Task 1",
8
- input_options: {
9
- value: "1",
10
- name: "radio-name",
11
- }
12
- },
13
- { drag_id: "42",
14
- text: "Task 2",
15
- checked: true,
16
- input_options: {
17
- value: "2",
18
- name: "radio-name",
19
- }
20
- },
21
- { drag_id: "43",
22
- text: "Task 3",
23
- input_options: {
24
- value: "3",
25
- name: "radio-name",
26
- }
27
- },
28
- { drag_id: "44",
29
- text: "Task 4",
30
- input_options: {
31
- value: "4",
32
- name: "radio-name",
33
- }
34
- }
35
- ]
36
- }
37
- )
38
- %>
@@ -1,3 +0,0 @@
1
- For a simplified version of the Draggable API for the SelectableList kit, you can do the following:
2
-
3
- The SelectableList kit is optimized to work with the draggable kit. To enable drag, use the `enable_drag` prop on SelectableList kit AND `drag_id` prop within the SelectableList kit prop. An additional optional boolean prop (set to true by default) of `drag_handle` is also available on SelectableList kit to show the drag handle icon.
@@ -1,11 +0,0 @@
1
- import React from 'react'
2
-
3
- const noop = (): void => void 0
4
-
5
- type DrawerContextType = {
6
- onClose: () => void
7
- }
8
-
9
- export const DrawerContext = React.createContext<DrawerContextType>({
10
- onClose: noop,
11
- })
@@ -1,38 +0,0 @@
1
- import React, { useState } from "react"
2
- import { Button, Drawer, Flex } from "playbook-ui"
3
-
4
- const useDrawer = (visible = false) => {
5
- const [opened, setOpened] = useState(visible)
6
- const toggle = () => setOpened(!opened)
7
-
8
- return [opened, toggle]
9
- }
10
-
11
- const DrawerBehavior = () => {
12
- const [drawerOpen, toggleDrawerOpen] = useDrawer()
13
-
14
- return (
15
- <>
16
- <Flex wrap>
17
- <Button id='sm'
18
- marginRight='md'
19
- onClick={toggleDrawerOpen}
20
- >
21
- {"Push Behavior"}
22
- </Button>
23
- </Flex>
24
- <Flex>
25
- <Drawer
26
- behavior={"push"}
27
- onClose={toggleDrawerOpen}
28
- opened={drawerOpen}
29
- size={"lg"}
30
- >
31
- Test me (Push Behavior)
32
- </Drawer>
33
- </Flex>
34
- </>
35
- )
36
- }
37
-
38
- export default DrawerBehavior
@@ -1,73 +0,0 @@
1
- import { useState, useEffect } from 'react'
2
-
3
- export const breakpointValues = {
4
- none: 0,
5
- xs: 575,
6
- sm: 768,
7
- md: 992,
8
- lg: 1200,
9
- xl: 1400,
10
- } as const
11
-
12
- type BreakpointSize = keyof typeof breakpointValues
13
-
14
- interface UseBreakpointProps {
15
- openBreakpoint?: BreakpointSize
16
- closeBreakpoint?: BreakpointSize
17
- triggerId?: string
18
- }
19
-
20
- export const useBreakpoint = ({
21
- openBreakpoint = 'none',
22
- closeBreakpoint = 'none',
23
- triggerId
24
- }: UseBreakpointProps) => {
25
- const [isOpenBreakpointOpen, setIsOpenBreakpointOpen] = useState(false)
26
- const [isUserClosed, setIsUserClosed] = useState(false)
27
-
28
- useEffect(() => {
29
- if (openBreakpoint === 'none' && closeBreakpoint === 'none') return
30
-
31
- const handleResize = () => {
32
- const width = window.innerWidth
33
-
34
- if (openBreakpoint !== 'none') {
35
- const openBreakpointWidth = breakpointValues[openBreakpoint]
36
- if (width >= openBreakpointWidth) {
37
- setIsOpenBreakpointOpen(true)
38
- } else {
39
- setIsOpenBreakpointOpen(false)
40
- setIsUserClosed(false)
41
- }
42
- }
43
-
44
- if (closeBreakpoint !== 'none') {
45
- const closeBreakpointWidth = breakpointValues[closeBreakpoint]
46
- if (width < closeBreakpointWidth) {
47
- setIsOpenBreakpointOpen(false)
48
- } else {
49
- setIsOpenBreakpointOpen(true)
50
- }
51
- }
52
-
53
- // Handle menu button visibility
54
- if (triggerId) {
55
- const menuButton = document.getElementById(triggerId)
56
- if (menuButton) {
57
- menuButton.style.display = isOpenBreakpointOpen ? 'none' : ''
58
- }
59
- }
60
- }
61
-
62
- window.addEventListener('resize', handleResize)
63
- handleResize()
64
-
65
- return () => window.removeEventListener('resize', handleResize)
66
- }, [openBreakpoint, closeBreakpoint, triggerId, isOpenBreakpointOpen])
67
-
68
- return {
69
- isOpenBreakpointOpen,
70
- isUserClosed,
71
- setIsUserClosed
72
- }
73
- }
@@ -1,21 +0,0 @@
1
- import { useState, useEffect } from 'react'
2
-
3
- export const useDrawerAnimation = (isOpen: boolean) => {
4
- const [animationState, setAnimationState] = useState('')
5
-
6
- useEffect(() => {
7
- if (isOpen) {
8
- setAnimationState('afterOpen')
9
- } else if (!isOpen && animationState === 'afterOpen') {
10
- setAnimationState('beforeClose')
11
- setTimeout(() => {
12
- setAnimationState('')
13
- }, 200)
14
- }
15
- }, [isOpen])
16
-
17
- return {
18
- animationState,
19
- isVisible: isOpen || animationState === 'beforeClose'
20
- }
21
- }
@@ -1,15 +0,0 @@
1
- <%= pb_rails("phone_number_input", props: {
2
- id: "phone_number_input",
3
- format_as_you_type: true
4
- }) %>
5
-
6
- <%= pb_rails("button", props: {id: "clickable", text: "Save Phone Number"}) %>
7
-
8
- <%= javascript_tag do %>
9
- document.querySelector('#clickable').addEventListener('click', () => {
10
- const formattedPhoneNumber = document.querySelector('#phone_number_input').value
11
- const unformattedPhoneNumber = formattedPhoneNumber.replace(/\D/g, "")
12
-
13
- alert(`Formatted: ${formattedPhoneNumber}. Unformatted: ${unformattedPhoneNumber}`)
14
- })
15
- <% end %>
@@ -1,24 +0,0 @@
1
- import React, { useState } from "react";
2
- import { PhoneNumberInput, Body } from "playbook-ui";
3
-
4
- const PhoneNumberInputFormat = (props) => {
5
- const [phoneNumber, setPhoneNumber] = useState("");
6
-
7
- const handleOnChange = ({ number }) => {
8
- setPhoneNumber(number);
9
- };
10
-
11
- return (
12
- <>
13
- <PhoneNumberInput
14
- formatAsYouType
15
- id="format"
16
- onChange={handleOnChange}
17
- {...props}
18
- />
19
- {phoneNumber && <Body>Unformatted number: {phoneNumber}</Body>}
20
- </>
21
- );
22
- };
23
-
24
- export default PhoneNumberInputFormat;
@@ -1 +0,0 @@
1
- NOTE: the `number` in the React `onChange` event will not include formatting (no spaces, dashes, and parentheses). For Rails, the `value` will include formatting and its value must be sanitized manually.
@@ -1,74 +0,0 @@
1
- <%= pb_rails("table", props: { size: "md", responsive: "scroll", sticky_left_column: ["a"], sticky_right_column: ["b"] }) do %>
2
- <thead>
3
- <tr>
4
- <th id="a">Column 1</th>
5
- <th>Column 2</th>
6
- <th>Column 3</th>
7
- <th>Column 4</th>
8
- <th>Column 5</th>
9
- <th>Column 6</th>
10
- <th>Column 7</th>
11
- <th>Column 8</th>
12
- <th>Column 9</th>
13
- <th>Column 10</th>
14
- <th>Column 11</th>
15
- <th>Column 12</th>
16
- <th>Column 13</th>
17
- <th>Column 14</th>
18
- <th id="b">Column 15</th>
19
- </tr>
20
- </thead>
21
- <tbody>
22
- <tr>
23
- <td id="a">Value 1</td>
24
- <td>Value 2</td>
25
- <td>Value 3</td>
26
- <td>Value 4</td>
27
- <td>Value 5</td>
28
- <td>Value 6</td>
29
- <td>Value 7</td>
30
- <td>Value 8</td>
31
- <td>Value 9</td>
32
- <td>Value 10</td>
33
- <td>Value 11</td>
34
- <td>Value 12</td>
35
- <td>Value 13</td>
36
- <td>Value 14</td>
37
- <td id="b">Value 15</td>
38
- </tr>
39
- <tr>
40
- <td id="a">Value 1</td>
41
- <td>Value 2</td>
42
- <td>Value 3</td>
43
- <td>Value 4</td>
44
- <td>Value 5</td>
45
- <td>Value 6</td>
46
- <td>Value 7</td>
47
- <td>Value 8</td>
48
- <td>Value 9</td>
49
- <td>Value 10</td>
50
- <td>Value 11</td>
51
- <td>Value 12</td>
52
- <td>Value 13</td>
53
- <td>Value 14</td>
54
- <td id="b">Value 15</td>
55
- </tr>
56
- <tr>
57
- <td id="a">Value 1</td>
58
- <td>Value 2</td>
59
- <td>Value 3</td>
60
- <td>Value 4</td>
61
- <td>Value 5</td>
62
- <td>Value 6</td>
63
- <td>Value 7</td>
64
- <td>Value 8</td>
65
- <td>Value 9</td>
66
- <td>Value 10</td>
67
- <td>Value 11</td>
68
- <td>Value 12</td>
69
- <td>Value 13</td>
70
- <td>Value 14</td>
71
- <td id="b">Value 15</td>
72
- </tr>
73
- </tbody>
74
- <% end %>
@@ -1,3 +0,0 @@
1
- The `sticky_left_column` and `sticky_right_column` props can be used together on the same table as needed.
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 props.
@@ -1,74 +0,0 @@
1
- <%= pb_rails("table", props: { size: "md", responsive: "scroll", sticky_right_column: ["13", "14", "15"] }) do %>
2
- <thead>
3
- <tr>
4
- <th>Column 1</th>
5
- <th>Column 2</th>
6
- <th>Column 3</th>
7
- <th>Column 4</th>
8
- <th>Column 5</th>
9
- <th>Column 6</th>
10
- <th>Column 7</th>
11
- <th>Column 8</th>
12
- <th>Column 9</th>
13
- <th>Column 10</th>
14
- <th>Column 11</th>
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>
19
- </tr>
20
- </thead>
21
- <tbody>
22
- <tr>
23
- <td>Value 1</td>
24
- <td>Value 2</td>
25
- <td>Value 3</td>
26
- <td>Value 4</td>
27
- <td>Value 5</td>
28
- <td>Value 6</td>
29
- <td>Value 7</td>
30
- <td>Value 8</td>
31
- <td>Value 9</td>
32
- <td>Value 10</td>
33
- <td>Value 11</td>
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>
38
- </tr>
39
- <tr>
40
- <td>Value 1</td>
41
- <td>Value 2</td>
42
- <td>Value 3</td>
43
- <td>Value 4</td>
44
- <td>Value 5</td>
45
- <td>Value 6</td>
46
- <td>Value 7</td>
47
- <td>Value 8</td>
48
- <td>Value 9</td>
49
- <td>Value 10</td>
50
- <td>Value 11</td>
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>
55
- </tr>
56
- <tr>
57
- <td>Value 1</td>
58
- <td>Value 2</td>
59
- <td>Value 3</td>
60
- <td>Value 4</td>
61
- <td>Value 5</td>
62
- <td>Value 6</td>
63
- <td>Value 7</td>
64
- <td>Value 8</td>
65
- <td>Value 9</td>
66
- <td>Value 10</td>
67
- <td>Value 11</td>
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>
72
- </tr>
73
- </tbody>
74
- <% end %>
@@ -1,3 +0,0 @@
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 ids you want to be sticky. Make sure to add the corresponding id to the `<th>` and `<td>`.
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_right_column` prop.
@@ -1,22 +0,0 @@
1
- export const addDataTitle = () => {
2
- const tables = document.querySelectorAll('.table-responsive-collapse');
3
- // Each Table
4
- [].forEach.call(tables, (table: HTMLTableElement) => {
5
- // Header Titles
6
- const headers: string[] = [];
7
- [].forEach.call(table.querySelectorAll('th'), (header: HTMLTableCellElement) => {
8
- const colSpan = header.colSpan
9
- for (let i = 0; i < colSpan; i++) {
10
- headers.push(header.textContent.replace(/\r?\n|\r/, ''));
11
- }
12
- });
13
- // for each row in tbody
14
- [].forEach.call(table.querySelectorAll('tbody tr'), (row: HTMLTableRowElement) => {
15
- // for each cell
16
- [].forEach.call(row.cells, (cell: HTMLTableCellElement, headerIndex: number) => {
17
- // apply the attribute
18
- cell.setAttribute('data-title', headers[headerIndex])
19
- })
20
- })
21
- });
22
- }