playbook_ui 14.16.0.pre.rc.6 → 14.17.0.pre.alpha.PBNTR920emojipickerpoc7130

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 (170) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/pb_advanced_table/Utilities/types.ts +1 -1
  3. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +104 -2
  4. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +168 -85
  5. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.html.erb +2 -2
  6. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.rb +10 -0
  7. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.test.jsx +20 -7
  8. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_fullscreen.jsx +90 -0
  9. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_fullscreen.md +3 -0
  10. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_pagination.jsx +0 -1
  11. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows.html.erb +39 -0
  12. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_no_subrows.html.erb +33 -0
  13. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_no_subrows_rails.md +1 -0
  14. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_rails.md +6 -0
  15. data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +4 -1
  16. data/app/pb_kits/playbook/pb_advanced_table/docs/index.js +2 -1
  17. data/app/pb_kits/playbook/pb_advanced_table/index.js +1 -1
  18. data/app/pb_kits/playbook/pb_advanced_table/table_body.rb +4 -2
  19. data/app/pb_kits/playbook/pb_advanced_table/table_header.html.erb +19 -9
  20. data/app/pb_kits/playbook/pb_advanced_table/table_header.rb +38 -1
  21. data/app/pb_kits/playbook/pb_advanced_table/table_row.html.erb +49 -37
  22. data/app/pb_kits/playbook/pb_advanced_table/table_row.rb +39 -0
  23. data/app/pb_kits/playbook/pb_bar_graph/_bar_graph.tsx +1 -1
  24. data/app/pb_kits/playbook/pb_button/_button.scss +5 -5
  25. data/app/pb_kits/playbook/pb_circle_chart/_circle_chart.tsx +1 -1
  26. data/app/pb_kits/playbook/pb_collapsible/__snapshots__/collapsible.test.js.snap +14 -7
  27. data/app/pb_kits/playbook/pb_contact/contact.test.js +7 -7
  28. data/app/pb_kits/playbook/pb_date_picker/_date_picker.tsx +34 -34
  29. data/app/pb_kits/playbook/pb_date_picker/date_picker.html.erb +2 -2
  30. data/app/pb_kits/playbook/pb_date_picker/date_picker_helper.ts +16 -0
  31. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_inline.html.erb +0 -11
  32. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_inline.jsx +0 -7
  33. data/app/pb_kits/playbook/pb_date_picker/sass_partials/_inline_styles.scss +28 -24
  34. data/app/pb_kits/playbook/pb_date_range_inline/date_range_inline.test.js +2 -2
  35. data/app/pb_kits/playbook/pb_date_range_stacked/date_range_stacked.test.js +1 -1
  36. data/app/pb_kits/playbook/pb_draggable/_draggable.scss +115 -5
  37. data/app/pb_kits/playbook/pb_draggable/_draggable.tsx +6 -4
  38. data/app/pb_kits/playbook/pb_draggable/context/index.tsx +91 -24
  39. data/app/pb_kits/playbook/pb_draggable/context/types.ts +35 -28
  40. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones.jsx +184 -0
  41. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones.md +5 -0
  42. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones_colors.jsx +97 -0
  43. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones_colors.md +1 -0
  44. data/app/pb_kits/playbook/pb_draggable/draggable.test.jsx +3 -3
  45. data/app/pb_kits/playbook/pb_draggable/subcomponents/DraggableContainer.tsx +11 -2
  46. data/app/pb_kits/playbook/pb_draggable/subcomponents/DraggableItem.tsx +65 -6
  47. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_breakpoints.html.erb +3 -0
  48. data/app/pb_kits/playbook/pb_drawer/docs/example.yml +1 -0
  49. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete.jsx +6 -6
  50. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_and_custom_display.jsx +6 -6
  51. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.jsx +6 -6
  52. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display_rails.html.erb +8 -8
  53. data/app/pb_kits/playbook/pb_dropdown/dropdown.test.jsx +3 -3
  54. data/app/pb_kits/playbook/pb_filter/Filter/CurrentFilters.tsx +3 -4
  55. data/app/pb_kits/playbook/pb_filter/Filter/SortMenu.tsx +2 -2
  56. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/_fixed_confirmation_toast.scss +2 -2
  57. data/app/pb_kits/playbook/pb_form/docs/_form_form_with.html.erb +67 -0
  58. data/app/pb_kits/playbook/pb_form/docs/_form_form_with_validate.html.erb +67 -0
  59. data/app/pb_kits/playbook/pb_form/pb_form_validation.js +1 -1
  60. data/app/pb_kits/playbook/pb_form_group/_form_group.scss +22 -0
  61. data/app/pb_kits/playbook/pb_gauge/_gauge.tsx +1 -1
  62. data/app/pb_kits/playbook/pb_icon/_icon.scss +8 -1
  63. data/app/pb_kits/playbook/pb_icon/docs/_icon_color.html.erb +10 -4
  64. data/app/pb_kits/playbook/pb_icon/docs/_icon_color.jsx +49 -24
  65. data/app/pb_kits/playbook/pb_icon/icon.test.js +9 -9
  66. data/app/pb_kits/playbook/pb_icon_button/_icon_button.tsx +4 -1
  67. data/app/pb_kits/playbook/pb_icon_button/docs/_icon_button_click.jsx +13 -0
  68. data/app/pb_kits/playbook/pb_icon_button/docs/example.yml +1 -0
  69. data/app/pb_kits/playbook/pb_icon_button/docs/index.js +1 -0
  70. data/app/pb_kits/playbook/pb_icon_circle/icon_circle.test.js +1 -1
  71. data/app/pb_kits/playbook/pb_icon_stat_value/icon_stat_value.test.js +1 -1
  72. data/app/pb_kits/playbook/pb_icon_value/icon_value.test.js +1 -1
  73. data/app/pb_kits/playbook/pb_label_value/label_value.test.js +1 -1
  74. data/app/pb_kits/playbook/pb_layout/_layout.scss +58 -0
  75. data/app/pb_kits/playbook/pb_layout/_layout.tsx +20 -7
  76. data/app/pb_kits/playbook/pb_layout/docs/_layout_bracket.jsx +190 -0
  77. data/app/pb_kits/playbook/pb_layout/docs/_layout_bracket.md +5 -0
  78. data/app/pb_kits/playbook/pb_layout/docs/example.yml +1 -0
  79. data/app/pb_kits/playbook/pb_layout/docs/index.js +1 -0
  80. data/app/pb_kits/playbook/pb_layout/layout.test.js +4 -0
  81. data/app/pb_kits/playbook/pb_layout/subcomponents/_game.tsx +90 -0
  82. data/app/pb_kits/playbook/pb_layout/subcomponents/_round.tsx +57 -0
  83. data/app/pb_kits/playbook/pb_lightbox/Carousel/Slide.tsx +1 -1
  84. data/app/pb_kits/playbook/pb_lightbox/Carousel/Slides.tsx +1 -1
  85. data/app/pb_kits/playbook/pb_lightbox/Carousel/Thumbnails.tsx +1 -1
  86. data/app/pb_kits/playbook/pb_lightbox/hooks/useVisibility.js +1 -1
  87. data/app/pb_kits/playbook/pb_line_graph/_line_graph.tsx +1 -1
  88. data/app/pb_kits/playbook/pb_link/link.test.jsx +2 -2
  89. data/app/pb_kits/playbook/pb_multi_level_select/_multi_level_select.scss +23 -0
  90. data/app/pb_kits/playbook/pb_multi_level_select/_multi_level_select.tsx +28 -1
  91. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_error.html.erb +72 -0
  92. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_error.jsx +97 -0
  93. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_label.html.erb +71 -0
  94. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_label.jsx +91 -0
  95. data/app/pb_kits/playbook/pb_multi_level_select/docs/example.yml +4 -0
  96. data/app/pb_kits/playbook/pb_multi_level_select/docs/index.js +3 -1
  97. data/app/pb_kits/playbook/pb_multi_level_select/index.js +105 -0
  98. data/app/pb_kits/playbook/pb_multi_level_select/multi_level_select.rb +10 -0
  99. data/app/pb_kits/playbook/pb_nav/_nav.scss +5 -0
  100. data/app/pb_kits/playbook/pb_nav/_nav_item.test.js +5 -3
  101. data/app/pb_kits/playbook/pb_rich_text_editor/_rich_text_editor.tsx +29 -11
  102. data/app/pb_kits/playbook/pb_rich_text_editor/docs/_rich_text_editor_default.html.erb +1 -1
  103. data/app/pb_kits/playbook/pb_rich_text_editor/rich_text_editor.html.erb +4 -4
  104. data/app/pb_kits/playbook/pb_rich_text_editor/rich_text_editor.rb +2 -0
  105. data/app/pb_kits/playbook/pb_section_separator/docs/_section_separator_vertical.md +1 -0
  106. data/app/pb_kits/playbook/pb_stat_change/stat_change.test.js +8 -4
  107. data/app/pb_kits/playbook/pb_table/_table.tsx +4 -0
  108. data/app/pb_kits/playbook/pb_table/docs/_table_with_header_style_borderless.jsx +50 -0
  109. data/app/pb_kits/playbook/pb_table/docs/_table_with_header_style_borderless_react.md +1 -0
  110. data/app/pb_kits/playbook/pb_table/docs/_table_with_header_style_floating.jsx +59 -0
  111. data/app/pb_kits/playbook/pb_table/docs/_table_with_header_style_floating_react.md +1 -0
  112. data/app/pb_kits/playbook/pb_table/docs/example.yml +2 -0
  113. data/app/pb_kits/playbook/pb_table/docs/index.js +2 -0
  114. data/app/pb_kits/playbook/pb_table/styles/_headers.scss +76 -0
  115. data/app/pb_kits/playbook/pb_table/styles/_striped.scss +3 -3
  116. data/app/pb_kits/playbook/pb_table/subcomponents/_table_head.tsx +11 -1
  117. data/app/pb_kits/playbook/pb_table/subcomponents/_table_header.tsx +11 -1
  118. data/app/pb_kits/playbook/pb_table/subcomponents/_table_row.tsx +5 -0
  119. data/app/pb_kits/playbook/pb_table/table.test.js +17 -0
  120. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_emoji_picker.jsx +371 -0
  121. data/app/pb_kits/playbook/pb_text_input/docs/example.yml +1 -0
  122. data/app/pb_kits/playbook/pb_text_input/docs/index.js +1 -0
  123. data/app/pb_kits/playbook/pb_tooltip/index.js +183 -56
  124. data/app/pb_kits/playbook/pb_tooltip/tooltip.html.erb +2 -5
  125. data/app/pb_kits/playbook/pb_treemap_chart/_treemap_chart.tsx +1 -1
  126. data/app/pb_kits/playbook/pb_typeahead/_typeahead.scss +4 -0
  127. data/app/pb_kits/playbook/pb_typeahead/_typeahead.tsx +3 -0
  128. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_disabled.html.erb +19 -0
  129. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_disabled.jsx +23 -0
  130. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_highlight.jsx +4 -4
  131. data/app/pb_kits/playbook/pb_typeahead/docs/example.yml +2 -0
  132. data/app/pb_kits/playbook/pb_typeahead/docs/index.js +1 -0
  133. data/app/pb_kits/playbook/pb_typeahead/index.ts +2 -2
  134. data/app/pb_kits/playbook/pb_typeahead/typeahead.html.erb +2 -5
  135. data/app/pb_kits/playbook/pb_typeahead/typeahead.rb +3 -0
  136. data/app/pb_kits/playbook/pb_user/_user.tsx +78 -13
  137. data/app/pb_kits/playbook/pb_user/docs/_user_font_options.html.erb +22 -0
  138. data/app/pb_kits/playbook/pb_user/docs/_user_font_options.jsx +40 -0
  139. data/app/pb_kits/playbook/pb_user/docs/_user_font_options_rails.md +5 -0
  140. data/app/pb_kits/playbook/pb_user/docs/_user_font_options_react.md +5 -0
  141. data/app/pb_kits/playbook/pb_user/docs/example.yml +2 -0
  142. data/app/pb_kits/playbook/pb_user/docs/index.js +1 -0
  143. data/app/pb_kits/playbook/pb_user/user.html.erb +28 -12
  144. data/app/pb_kits/playbook/pb_user/user.rb +17 -1
  145. data/app/pb_kits/playbook/pb_user/user.test.js +182 -1
  146. data/app/pb_kits/playbook/pb_user_badge/user_badge.html.erb +1 -6
  147. data/app/pb_kits/playbook/tokens/_colors.scss +1 -4
  148. data/app/pb_kits/playbook/utilities/globalProps.ts +1 -1
  149. data/app/pb_kits/playbook/utilities/object.test.js +287 -1
  150. data/app/pb_kits/playbook/utilities/object.ts +171 -3
  151. data/app/pb_kits/playbook/utilities/text.ts +1 -1
  152. data/dist/chunks/_typeahead-7W5Ha5Td.js +22 -0
  153. data/dist/chunks/_weekday_stacked-DSKatW3m.js +45 -0
  154. data/dist/chunks/lib-BGzBzFZX.js +29 -0
  155. data/dist/chunks/{pb_form_validation-BvDxpfs-.js → pb_form_validation-BvNy9Bd6.js} +1 -1
  156. data/dist/chunks/vendor.js +1 -1
  157. data/dist/playbook-doc.js +1 -1
  158. data/dist/playbook-rails-react-bindings.js +1 -1
  159. data/dist/playbook-rails.js +1 -1
  160. data/dist/playbook.css +1 -1
  161. data/lib/playbook/forms/builder/multi_level_select_field.rb +2 -0
  162. data/lib/playbook/kit_base.rb +4 -4
  163. data/lib/playbook/version.rb +2 -2
  164. metadata +40 -9
  165. data/app/pb_kits/playbook/pb_tooltip/floating_ui.js +0 -282
  166. data/dist/chunks/_typeahead-CRAPc8k-.js +0 -22
  167. data/dist/chunks/_weekday_stacked-T0kFfioG.js +0 -45
  168. data/dist/chunks/lib-BeKPJYlk.js +0 -29
  169. /data/app/pb_kits/playbook/pb_advanced_table/docs/{_advanced_table_selectable_rows_no_subrows.md → _advanced_table_selectable_rows_no_subrows_react.md} +0 -0
  170. /data/app/pb_kits/playbook/pb_advanced_table/docs/{_advanced_table_selectable_rows.md → _advanced_table_selectable_rows_react.md} +0 -0
@@ -0,0 +1,184 @@
1
+ import React, { useState } from "react";
2
+ import Body from '../../pb_body/_body'
3
+ import Flex from '../../pb_flex/_flex'
4
+ import FlexItem from '../../pb_flex/_flex_item'
5
+ import Card from '../../pb_card/_card'
6
+ import Caption from '../../pb_caption/_caption'
7
+ import Draggable from '../../pb_draggable/_draggable'
8
+ import { DraggableProvider } from '../../pb_draggable/context'
9
+
10
+ // Initial items to be dragged
11
+ const dataShadow = [
12
+ {
13
+ id: "51",
14
+ text: "Task 1",
15
+ },
16
+ {
17
+ id: "52",
18
+ text: "Task 2",
19
+ },
20
+ {
21
+ id: "53",
22
+ text: "Task 3",
23
+ },
24
+ ];
25
+
26
+ const dataOutline = [
27
+ {
28
+ id: "61",
29
+ text: "Task 1",
30
+ },
31
+ {
32
+ id: "62",
33
+ text: "Task 2",
34
+ },
35
+ {
36
+ id: "63",
37
+ text: "Task 3",
38
+ },
39
+ ];
40
+
41
+ const dataLine = [
42
+ {
43
+ id: "71",
44
+ text: "Task 1",
45
+ },
46
+ {
47
+ id: "72",
48
+ text: "Task 2",
49
+ },
50
+ {
51
+ id: "73",
52
+ text: "Task 3",
53
+ },
54
+ ];
55
+
56
+ const DraggableDropZones = (props) => {
57
+ const [initialShadowState, setInitialShadowState] = useState(dataShadow);
58
+ const [initialOutlineState, setInitialOutlineState] = useState(dataOutline);
59
+ const [initialLineState, setInitialLineState] = useState(dataLine);
60
+
61
+ return (
62
+ <>
63
+ <Flex justify="between"
64
+ {...props}
65
+ >
66
+ <FlexItem marginRight="xl">
67
+ <DraggableProvider
68
+ dropZone={{type: "shadow"}}
69
+ initialItems={dataShadow}
70
+ onReorder={(items) => setInitialShadowState(items)}
71
+ >
72
+ <Caption
73
+ marginBottom="xs"
74
+ textAlign="center"
75
+ >
76
+ {"Shadow"}
77
+ </Caption>
78
+ <Draggable.Container
79
+ htmlOptions={{style:{ width: "200px"}}}
80
+ {...props}
81
+ >
82
+ {initialShadowState.map(({ id, text }) => (
83
+ <Card dragId={id}
84
+ draggableItem
85
+ key={id}
86
+ marginBottom="xs"
87
+ padding="xs"
88
+ {...props}
89
+ >
90
+ <Flex alignItems="stretch"
91
+ flexDirection="column"
92
+ >
93
+ <Body
94
+ text={text}
95
+ {...props}
96
+ />
97
+ </Flex>
98
+ </Card>
99
+ ))}
100
+ </Draggable.Container>
101
+ </DraggableProvider>
102
+ </FlexItem>
103
+ <FlexItem marginRight="xl">
104
+ <DraggableProvider
105
+ dropZone={{type: "outline"}}
106
+ initialItems={dataOutline}
107
+ onReorder={(items) => setInitialOutlineState(items)}
108
+ >
109
+ <Caption
110
+ marginBottom="xs"
111
+ textAlign="center"
112
+ >
113
+ {"Outline"}
114
+ </Caption>
115
+ <Draggable.Container
116
+ htmlOptions={{style:{ width: "200px"}}}
117
+ {...props}
118
+ >
119
+ {initialOutlineState.map(({ id, text }) => (
120
+ <Card
121
+ dragId={id}
122
+ draggableItem
123
+ key={id}
124
+ marginBottom="xs"
125
+ padding="xs"
126
+ {...props}
127
+ >
128
+ <Flex
129
+ alignItems="stretch"
130
+ flexDirection="column"
131
+ >
132
+ <Body
133
+ text={text}
134
+ {...props}
135
+ />
136
+ </Flex>
137
+ </Card>
138
+ ))}
139
+ </Draggable.Container>
140
+ </DraggableProvider>
141
+ </FlexItem>
142
+ <FlexItem>
143
+ <DraggableProvider
144
+ dropZone={{type: "line"}}
145
+ initialItems={dataLine}
146
+ onReorder={(items) => setInitialLineState(items)}
147
+ >
148
+ <Caption
149
+ marginBottom="xs"
150
+ textAlign="center"
151
+ >
152
+ {"Line"}
153
+ </Caption>
154
+ <Draggable.Container
155
+ htmlOptions={{style:{ width: "200px"}}}
156
+ {...props}
157
+ >
158
+ {initialLineState.map(({ id, text }) => (
159
+ <Card dragId={id}
160
+ draggableItem
161
+ key={id}
162
+ marginBottom="xs"
163
+ padding="xs"
164
+ {...props}
165
+ >
166
+ <Flex alignItems="stretch"
167
+ flexDirection="column"
168
+ >
169
+ <Body
170
+ text={text}
171
+ {...props}
172
+ />
173
+ </Flex>
174
+ </Card>
175
+ ))}
176
+ </Draggable.Container>
177
+ </DraggableProvider>
178
+ </FlexItem>
179
+ </Flex>
180
+ </>
181
+ );
182
+ };
183
+
184
+ export default DraggableDropZones;
@@ -0,0 +1,5 @@
1
+ The Draggable kit allows you to choose the style of drop zones that appear when dragging an item.
2
+
3
+ By default, the Draggable kit utilizes the "ghost" style for drop zones, but you can also choose between "shadow", "outline", and "line".
4
+
5
+ Additionally, when using the "line" style, be sure to set the proper `direction` attribute within the `dropZone` prop depending on the orentation of your draggable view. By default, this attribute is set to "vertical", but can also be used with a "horizontal" direction. The `direction` attribute only applies to the "line" style and will not affect other drop zone styles.
@@ -0,0 +1,97 @@
1
+ import React, { useState } from "react";
2
+
3
+ import Flex from '../../pb_flex/_flex'
4
+ import Image from '../../pb_image/_image'
5
+ import Caption from '../../pb_caption/_caption'
6
+ import Draggable from '../../pb_draggable/_draggable'
7
+ import { DraggableProvider } from '../../pb_draggable/context'
8
+
9
+ // Initial items to be dragged
10
+ const dataPrimary = [
11
+ {
12
+ id: "81",
13
+ url: "https://unsplash.it/500/400/?image=633",
14
+ },
15
+ {
16
+ id: "82",
17
+ url: "https://unsplash.it/500/400/?image=634",
18
+ },
19
+ {
20
+ id: "83",
21
+ url: "https://unsplash.it/500/400/?image=637",
22
+ },
23
+ ];
24
+ const dataPurple = [
25
+ {
26
+ id: "91",
27
+ url: "https://unsplash.it/500/400/?image=633",
28
+ },
29
+ {
30
+ id: "92",
31
+ url: "https://unsplash.it/500/400/?image=634",
32
+ },
33
+ {
34
+ id: "93",
35
+ url: "https://unsplash.it/500/400/?image=637",
36
+ },
37
+ ];
38
+
39
+ const DraggableDropZonesColors = (props) => {
40
+ const [initialPrimaryState, setInitialPrimaryState] = useState(dataPrimary);
41
+ const [initialPurpleState, setInitialPurpleState] = useState(dataPurple);
42
+
43
+ return (
44
+ <>
45
+ <Caption marginBottom="xs">
46
+ Primary
47
+ </Caption>
48
+ <DraggableProvider
49
+ dropZone={{type: "shadow", color: "primary"}}
50
+ initialItems={dataPrimary}
51
+ onReorder={(items) => setInitialPrimaryState(items)}
52
+ >
53
+ <Draggable.Container {...props}>
54
+ <Flex>
55
+ {initialPrimaryState.map(({ id, url }) => (
56
+ <Draggable.Item dragId={id}
57
+ key={id}
58
+ marginRight="sm"
59
+ >
60
+ <Image alt={id}
61
+ size="md"
62
+ url={url}
63
+ />
64
+ </Draggable.Item>
65
+ ))}
66
+ </Flex>
67
+ </Draggable.Container>
68
+ </DraggableProvider>
69
+ <Caption marginBottom="xs">
70
+ Purple
71
+ </Caption>
72
+ <DraggableProvider
73
+ dropZone={{type: "outline", color: "purple"}}
74
+ initialItems={dataPurple}
75
+ onReorder={(items) => setInitialPurpleState(items)}
76
+ >
77
+ <Draggable.Container {...props}>
78
+ <Flex>
79
+ {initialPurpleState.map(({ id, url }) => (
80
+ <Draggable.Item dragId={id}
81
+ key={id}
82
+ marginRight="sm"
83
+ >
84
+ <Image alt={id}
85
+ size="md"
86
+ url={url}
87
+ />
88
+ </Draggable.Item>
89
+ ))}
90
+ </Flex>
91
+ </Draggable.Container>
92
+ </DraggableProvider>
93
+ </>
94
+ );
95
+ };
96
+
97
+ export default DraggableDropZonesColors;
@@ -0,0 +1 @@
1
+ By default, the Draggable kit sets the default color of drop zones to "neutral" (or "primary" if using the "line" style.)
@@ -165,7 +165,7 @@ test("generated dragHandle with List", () => {
165
165
 
166
166
  const list = kit.querySelector(".pb_list_kit");
167
167
  expect(list).toBeInTheDocument();
168
- const dragHandle = list.querySelector(".fa-grip-dots-vertical");
168
+ const dragHandle = list.querySelector(".pb_custom_icon");
169
169
  expect(dragHandle).toBeInTheDocument();
170
170
  });
171
171
 
@@ -175,7 +175,7 @@ test("generated dragHandle with SelectableList", () => {
175
175
 
176
176
  const selectabellist = kit.querySelector(".pb_selectable_list_kit");
177
177
  expect(selectabellist).toBeInTheDocument();
178
- const dragHandle = selectabellist.querySelector(".fa-grip-dots-vertical");
178
+ const dragHandle = selectabellist.querySelector(".pb_custom_icon");
179
179
  expect(dragHandle).toBeInTheDocument();
180
180
  });
181
181
 
@@ -185,6 +185,6 @@ test("generated dragHandle with Card", () => {
185
185
 
186
186
  const card = kit.querySelector(".pb_card_kit_deselected_border_radius_md");
187
187
  expect(card).toBeInTheDocument();
188
- const dragHandle = card.querySelector(".fa-grip-dots-vertical");
188
+ const dragHandle = card.querySelector(".pb_custom_icon");
189
189
  expect(dragHandle).toBeInTheDocument();
190
190
  });
@@ -22,18 +22,27 @@ type DraggableContainerProps = {
22
22
 
23
23
  const DraggableContainer = (props: DraggableContainerProps) => {
24
24
  const { aria = {}, children, className, container, data = {}, htmlOptions = {}, id, tag="div" } = props;
25
+ const contextValues = DraggableContext();
26
+ const {
27
+ handleDragOver,
28
+ handleDrop,
29
+ activeContainer,
30
+ dropZone
31
+ } = contextValues;
25
32
 
26
- const { handleDragOver, handleDrop, activeContainer } = DraggableContext();
33
+ // Only get direction if dropZone is 'line'
34
+ const direction = dropZone === 'line' ? (contextValues.direction || 'vertical') : 'vertical';
27
35
 
28
36
  const ariaProps = buildAriaProps(aria);
29
37
  const dataProps = buildDataProps(data);
30
38
  const htmlProps = buildHtmlProps(htmlOptions);
31
-
32
39
  const Tag: React.ReactElement | any = `${tag}`;
33
40
 
34
41
  const classes = classnames(
35
42
  buildCss("pb_draggable_container"),
36
43
  `${activeContainer === container ? "active" : ""}`,
44
+ // Only add vertical class if dropZone is 'line' and direction is 'vertical'
45
+ (dropZone === 'line' && direction === 'vertical') ? 'vertical' : '',
37
46
  globalProps(props),
38
47
  className
39
48
  );
@@ -22,24 +22,82 @@ type DraggableItemProps = {
22
22
  };
23
23
 
24
24
  const DraggableItem = (props: DraggableItemProps) => {
25
- const { aria = {}, children, className, container, data = {}, htmlOptions = {}, id, dragId, tag="div" } = props;
25
+ const {
26
+ aria = {},
27
+ children,
28
+ className,
29
+ container,
30
+ data = {},
31
+ htmlOptions = {},
32
+ id,
33
+ dragId,
34
+ tag="div"
35
+ } = props;
26
36
 
27
- const { isDragging, handleDragStart, handleDragEnter, handleDragEnd } =
28
- DraggableContext();
37
+ const {
38
+ isDragging,
39
+ handleDragStart,
40
+ handleDragEnter,
41
+ handleDragEnd,
42
+ dropZone = 'ghost',
43
+ dropZoneColor = 'neutral',
44
+ direction = 'horizontal'
45
+ } = DraggableContext();
46
+
47
+ const itemRef = React.useRef<HTMLElement>(null);
29
48
 
30
49
  const ariaProps = buildAriaProps(aria);
31
50
  const dataProps = buildDataProps(data);
32
51
  const htmlProps = buildHtmlProps(htmlOptions);
33
-
34
52
  const Tag: React.ReactElement | any = `${tag}`;
35
-
53
+
36
54
  const classes = classnames(
37
55
  buildCss("pb_draggable_item"),
38
56
  `${isDragging === dragId ? "is_dragging" : ""}`,
57
+ isDragging === dragId ? `drop_zone_${dropZone}` : "",
58
+ isDragging === dragId && dropZone !== 'ghost' ? `drop_zone_color_${dropZoneColor}` : '',
39
59
  globalProps(props),
40
60
  className
41
61
  );
42
62
 
63
+ // Enhanced drag start handler that preserves dimensions
64
+ const onDragStart = (e: React.DragEvent) => {
65
+ if (dropZone !== 'ghost' && itemRef.current) {
66
+ // Create a clone for the drag image
67
+ const clone = itemRef.current.cloneNode(true) as HTMLElement;
68
+
69
+ // Remove any classes that might affect appearance
70
+ clone.className = clone.className.replace(/drop_zone_[^ ]*/g, '');
71
+ clone.className = clone.className.replace(/is_dragging/g, '');
72
+
73
+ // Get the original dimensions
74
+ const rect = itemRef.current.getBoundingClientRect();
75
+
76
+ // Ensure it's styled properly but invisible on the page
77
+ clone.style.position = 'fixed';
78
+ clone.style.top = '-9999px';
79
+ clone.style.left = '-9999px';
80
+ clone.style.width = `${rect.width}px`; // Preserve width
81
+ clone.style.height = `${rect.height}px`; // Preserve height
82
+ clone.style.opacity = '1';
83
+ clone.style.pointerEvents = 'none';
84
+
85
+ // Add to document temporarily
86
+ document.body.appendChild(clone);
87
+
88
+ // Set as drag image
89
+ e.dataTransfer.setDragImage(clone, e.clientX - rect.left, e.clientY - rect.top);
90
+
91
+ // Remove after a short delay
92
+ setTimeout(() => {
93
+ document.body.removeChild(clone);
94
+ }, 0);
95
+ }
96
+
97
+ // Call the original handler
98
+ handleDragStart(dragId, container);
99
+ };
100
+
43
101
  return (
44
102
  <Tag
45
103
  {...ariaProps}
@@ -51,7 +109,8 @@ const DraggableItem = (props: DraggableItemProps) => {
51
109
  key={dragId}
52
110
  onDragEnd={() => handleDragEnd()}
53
111
  onDragEnter={() => handleDragEnter(dragId, container)}
54
- onDragStart={() => handleDragStart(dragId, container)}
112
+ onDragStart={onDragStart}
113
+ ref={itemRef}
55
114
  >
56
115
  {children}
57
116
  </Tag>
@@ -0,0 +1,3 @@
1
+
2
+ <%= pb_rails("body", props: { text: " The breakpoint prop determines when the Drawer is always visible. Above the specified breakpoint, the Drawer remains open on the page. Below it, only the trigger element is shown, allowing you to toggle the drawer open and closed. To see this in action, click the button below and resize your window.", padding_bottom: "md" }) %>
3
+ <%= pb_rails("button", props: { text: "Open Doc Example in New Tab", new_window: true, link: "/drawer_page", margin_right: "lg" }) %>
@@ -6,6 +6,7 @@ examples:
6
6
  - drawer_menu: Within Element
7
7
  - drawer_sizes: Sizes
8
8
  - drawer_overlay: Overlay
9
+ - drawer_breakpoints: Breakpoints
9
10
  - drawer_borders: Borders
10
11
 
11
12
 
@@ -12,7 +12,7 @@ const DropdownWithAutocomplete = (props) => {
12
12
  label: "Jasper Furniss",
13
13
  value: "Jasper Furniss",
14
14
  territory: "PHL",
15
- title: "Senior UX Engineer",
15
+ title: "Lead UX Engineer",
16
16
  id: "jasper-furniss",
17
17
  status: "Offline"
18
18
  },
@@ -25,18 +25,18 @@ const DropdownWithAutocomplete = (props) => {
25
25
  status: "Away"
26
26
  },
27
27
  {
28
- label: "Jason Cypret",
29
- value: "Jason Cypret",
28
+ label: "Carlos Lima",
29
+ value: "Carlos Lima",
30
30
  territory: "PHL",
31
- title: "VP of User Experience",
32
- id: "jason-cypret",
31
+ title: "Nitro Developer",
32
+ id: "carlos-lima",
33
33
  status: "Online"
34
34
  },
35
35
  {
36
36
  label: "Courtney Long",
37
37
  value: "Courtney Long",
38
38
  territory: "PHL",
39
- title: "UX Design Mentor",
39
+ title: "Lead UX Designer",
40
40
  id: "courtney-long",
41
41
  status: "Online"
42
42
  }
@@ -15,7 +15,7 @@ const DropdownWithAutocompleteAndCustomDisplay = (props) => {
15
15
  label: "Jasper Furniss",
16
16
  value: "Jasper Furniss",
17
17
  territory: "PHL",
18
- title: "Senior UX Engineer",
18
+ title: "Lead UX Engineer",
19
19
  id: "jasper-furniss",
20
20
  status: "Offline"
21
21
  },
@@ -28,18 +28,18 @@ const DropdownWithAutocompleteAndCustomDisplay = (props) => {
28
28
  status: "Away"
29
29
  },
30
30
  {
31
- label: "Jason Cypret",
32
- value: "Jason Cypret",
31
+ label: "Carlos Lima",
32
+ value: "Carlos Lima",
33
33
  territory: "PHL",
34
- title: "VP of User Experience",
35
- id: "jason-cypret",
34
+ title: "Nitro Developer",
35
+ id: "carlos-lima",
36
36
  status: "Online"
37
37
  },
38
38
  {
39
39
  label: "Courtney Long",
40
40
  value: "Courtney Long",
41
41
  territory: "PHL",
42
- title: "UX Design Mentor",
42
+ title: "Lead UX Designer",
43
43
  id: "courtney-long",
44
44
  status: "Online"
45
45
  }
@@ -15,7 +15,7 @@ const DropdownWithCustomDisplay = (props) => {
15
15
  label: "Jasper Furniss",
16
16
  value: "Jasper Furniss",
17
17
  territory: "PHL",
18
- title: "Senior UX Engineer",
18
+ title: "Lead UX Engineer",
19
19
  id: "jasper-furniss",
20
20
  status: "Offline"
21
21
  },
@@ -28,18 +28,18 @@ const DropdownWithCustomDisplay = (props) => {
28
28
  status: "Away"
29
29
  },
30
30
  {
31
- label: "Jason Cypret",
32
- value: "Jason Cypret",
31
+ label: "Carlos Lima",
32
+ value: "Carlos Lima",
33
33
  territory: "PHL",
34
- title: "VP of User Experience",
35
- id: "jason-cypret",
34
+ title: "Nitro Developer",
35
+ id: "carlos-lima",
36
36
  status: "Online"
37
37
  },
38
38
  {
39
39
  label: "Courtney Long",
40
40
  value: "Courtney Long",
41
41
  territory: "PHL",
42
- title: "UX Design Mentor",
42
+ title: "Lead UX Designer",
43
43
  id: "courtney-long",
44
44
  status: "Online"
45
45
  }
@@ -1,10 +1,10 @@
1
1
  <%
2
- options = [
2
+ options = [
3
3
  {
4
4
  label: "Jasper Furniss",
5
5
  value: "Jasper Furniss",
6
6
  territory: "PHL",
7
- title: "Senior UX Engineer",
7
+ title: "Lead UX Engineer",
8
8
  id: "jasper-furniss",
9
9
  status: "Offline"
10
10
  },
@@ -17,22 +17,22 @@
17
17
  status: "Away"
18
18
  },
19
19
  {
20
- label: "Jason Cypret",
21
- value: "Jason Cypret",
20
+ label: "Carlos Lima",
21
+ value: "Carlos Lima",
22
22
  territory: "PHL",
23
- title: "VP of User Experience",
24
- id: "jason-cypret",
23
+ title: "Nitro Developer",
24
+ id: "carlos-lima",
25
25
  status: "Online"
26
26
  },
27
27
  {
28
28
  label: "Courtney Long",
29
29
  value: "Courtney Long",
30
30
  territory: "PHL",
31
- title: "UX Design Mentor",
31
+ title: "Lead UX Designer",
32
32
  id: "courtney-long",
33
33
  status: "Online"
34
34
  }
35
- ]
35
+ ];
36
36
 
37
37
  %>
38
38
 
@@ -95,7 +95,7 @@ test('generated customDisplay for trigger', () => {
95
95
 
96
96
  const kit = screen.getByTestId(testId)
97
97
  const trigger = kit.querySelector('.pb_dropdown_trigger')
98
- const customDisplay = trigger.querySelector('.fa-flag.pb_icon_kit.fa-fw')
98
+ const customDisplay = trigger.querySelector('.pb_custom_icon')
99
99
  expect(customDisplay).toBeInTheDocument()
100
100
  })
101
101
 
@@ -170,7 +170,7 @@ test('generated custom Trigger', () => {
170
170
  options={options}
171
171
  >
172
172
  <Dropdown.Trigger>
173
- <Icon icon="elephant" />
173
+ <Icon icon="flag" />
174
174
  </Dropdown.Trigger>
175
175
  {options.map((option) => (
176
176
  <Dropdown.Option key={option.id}
@@ -182,7 +182,7 @@ test('generated custom Trigger', () => {
182
182
 
183
183
  const kit = screen.getByTestId(testId)
184
184
  const trigger = kit.querySelector('.pb_dropdown_trigger')
185
- const customTrigger = trigger.querySelector('.fa-elephant.pb_icon_kit.fa-fw')
185
+ const customTrigger = trigger.querySelector('.pb_custom_icon')
186
186
  expect(customTrigger).toBeInTheDocument()
187
187
  })
188
188
 
@@ -1,6 +1,5 @@
1
1
  import React from 'react'
2
- import { map } from 'lodash'
3
- import { isEmpty, omitBy } from '../../utilities/object'
2
+ import { isEmpty, omitBy, map } from '../../utilities/object'
4
3
 
5
4
  import Body from '../../pb_body/_body'
6
5
  import Caption from '../../pb_caption/_caption'
@@ -46,12 +45,12 @@ const CurrentFilters = ({ dark, filters }: CurrentFiltersProps): React.ReactElem
46
45
  dark={dark}
47
46
  size={4}
48
47
  tag="h4"
49
- text={name}
48
+ text={`${name}`}
50
49
  /> :
51
50
  <div>
52
51
  <Caption
53
52
  dark={dark}
54
- text={name}
53
+ text={`${name}`}
55
54
  />
56
55
  <Title
57
56
  dark={dark}
@@ -1,5 +1,5 @@
1
1
  import React, { useState } from 'react'
2
- import { find, map, partial } from 'lodash'
2
+ import { find, partial, map } from '../../utilities/object'
3
3
 
4
4
  import Button from '../../pb_button/_button'
5
5
  import Icon from '../../pb_icon/_icon'
@@ -26,7 +26,7 @@ const directionIcon = (dir: Direction) => (
26
26
 
27
27
  const renderOptions = (options: SortOptions, value: SortValue[], handleChange: (arg0: SortValue) => void) => (
28
28
  map(options, (label, name) => {
29
- const next = nextValue(value, name)
29
+ const next = nextValue(value, String(name))
30
30
  return (
31
31
  <ListItem key={`option-${next.name}-${next.dir}`}>
32
32
  <Button