playbook_ui 14.17.0.pre.rc.1 → 14.18.0.pre.alpha.PLAY2037selectinlinecareterror7490

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 (269) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/pb_advanced_table/Components/RegularTableView.tsx +23 -3
  3. data/app/pb_kits/playbook/pb_advanced_table/Components/TableHeaderCell.tsx +67 -3
  4. data/app/pb_kits/playbook/pb_advanced_table/Hooks/useTableActions.ts +1 -2
  5. data/app/pb_kits/playbook/pb_advanced_table/Utilities/ExpansionControlHelpers.tsx +29 -19
  6. data/app/pb_kits/playbook/pb_advanced_table/Utilities/types.ts +1 -1
  7. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +429 -137
  8. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +97 -3
  9. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.rb +6 -1
  10. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.test.jsx +20 -7
  11. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_border_color.jsx +80 -0
  12. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_border_color.md +3 -0
  13. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_border_color_rails.html.erb +58 -0
  14. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_border_color_rails.md +3 -0
  15. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_expand_by_depth.jsx +66 -0
  16. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_expand_by_depth.md +10 -0
  17. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_fullscreen.jsx +90 -0
  18. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_fullscreen.md +3 -0
  19. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sticky_columns.jsx +58 -0
  20. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sticky_columns.md +6 -0
  21. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sticky_columns_and_header.jsx +64 -0
  22. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sticky_columns_and_header.md +8 -0
  23. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sticky_header.jsx +55 -0
  24. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sticky_header.md +3 -0
  25. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sticky_header_rails.html.erb +33 -0
  26. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sticky_header_rails.md +3 -0
  27. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props.html.erb +1 -1
  28. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props.jsx +1 -2
  29. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_rails.md +2 -2
  30. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_react.md +1 -1
  31. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_sticky_header_rails.md +6 -2
  32. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_sticky_header_react.md +6 -2
  33. data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +11 -4
  34. data/app/pb_kits/playbook/pb_advanced_table/docs/index.js +7 -1
  35. data/app/pb_kits/playbook/pb_advanced_table/index.js +7 -0
  36. data/app/pb_kits/playbook/pb_advanced_table/scss_partials/advanced_table_sticky_mixin.scss +97 -0
  37. data/app/pb_kits/playbook/pb_advanced_table/table_row.html.erb +1 -1
  38. data/app/pb_kits/playbook/pb_background/_background.scss +26 -0
  39. data/app/pb_kits/playbook/pb_background/_background.tsx +5 -3
  40. data/app/pb_kits/playbook/pb_background/background.test.js +5 -0
  41. data/app/pb_kits/playbook/pb_background/docs/_background_overlay.jsx +35 -0
  42. data/app/pb_kits/playbook/pb_background/docs/_background_overlay.md +1 -0
  43. data/app/pb_kits/playbook/pb_background/docs/example.yml +1 -0
  44. data/app/pb_kits/playbook/pb_background/docs/index.js +1 -0
  45. data/app/pb_kits/playbook/pb_circle_chart/_circle_chart.tsx +1 -1
  46. data/app/pb_kits/playbook/pb_circle_chart/circleChart.test.js +2 -2
  47. data/app/pb_kits/playbook/pb_circle_chart/circleChartTheme.ts +53 -0
  48. data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_block.html.erb +2 -2
  49. data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_block.jsx +1 -1
  50. data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_colors.html.erb +1 -1
  51. data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_colors.jsx +1 -1
  52. data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_custom_tooltip.html.erb +1 -1
  53. data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_custom_tooltip.jsx +1 -1
  54. data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_default.html.erb +1 -1
  55. data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_default.jsx +1 -1
  56. data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_legend_position.html.erb +1 -1
  57. data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_legend_position.jsx +1 -1
  58. data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_live_data.jsx +2 -2
  59. data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_pb_styles.jsx +38 -0
  60. data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_pb_styles.md +1 -0
  61. data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_rounded.html.erb +1 -1
  62. data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_rounded.jsx +1 -1
  63. data/app/pb_kits/playbook/pb_circle_chart/docs/example.yml +2 -3
  64. data/app/pb_kits/playbook/pb_circle_chart/docs/index.js +2 -1
  65. data/app/pb_kits/playbook/pb_circle_icon_button/_circle_icon_button.scss +39 -1
  66. data/app/pb_kits/playbook/pb_circle_icon_button/_circle_icon_button.tsx +4 -0
  67. data/app/pb_kits/playbook/pb_circle_icon_button/circle_icon_button.rb +9 -1
  68. data/app/pb_kits/playbook/pb_circle_icon_button/circle_icon_button.test.js +14 -0
  69. data/app/pb_kits/playbook/pb_circle_icon_button/docs/_circle_icon_button_size.html.erb +28 -0
  70. data/app/pb_kits/playbook/pb_circle_icon_button/docs/_circle_icon_button_size.jsx +42 -0
  71. data/app/pb_kits/playbook/pb_circle_icon_button/docs/_circle_icon_button_size.md +1 -0
  72. data/app/pb_kits/playbook/pb_circle_icon_button/docs/example.yml +2 -0
  73. data/app/pb_kits/playbook/pb_circle_icon_button/docs/index.js +1 -0
  74. data/app/pb_kits/playbook/pb_collapsible/__snapshots__/collapsible.test.js.snap +14 -7
  75. data/app/pb_kits/playbook/pb_contact/contact.test.js +7 -7
  76. data/app/pb_kits/playbook/pb_copy_button/_copy_button.tsx +19 -45
  77. data/app/pb_kits/playbook/pb_copy_button/docs/_copy_button_hook.jsx +54 -0
  78. data/app/pb_kits/playbook/pb_copy_button/docs/_copy_button_hook.md +3 -0
  79. data/app/pb_kits/playbook/pb_copy_button/docs/_copy_button_hook_rails.html.erb +14 -0
  80. data/app/pb_kits/playbook/pb_copy_button/docs/_copy_button_hook_rails.md +3 -0
  81. data/app/pb_kits/playbook/pb_copy_button/docs/example.yml +2 -0
  82. data/app/pb_kits/playbook/pb_copy_button/docs/index.js +2 -1
  83. data/app/pb_kits/playbook/pb_copy_button/index.js +46 -20
  84. data/app/pb_kits/playbook/pb_copy_button/usePBCopy.ts +45 -0
  85. data/app/pb_kits/playbook/pb_date_picker/_date_picker.tsx +12 -0
  86. data/app/pb_kits/playbook/pb_date_picker/date_picker.rb +12 -0
  87. data/app/pb_kits/playbook/pb_date_picker/date_picker_helper.ts +50 -1
  88. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_error.html.erb +2 -2
  89. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_error.jsx +4 -1
  90. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_quick_pick_rails.md +4 -0
  91. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_quick_pick_range_limit.md +1 -1
  92. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_quick_pick_react.md +5 -1
  93. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_range_pattern.jsx +34 -0
  94. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_range_pattern.md +14 -0
  95. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_range_pattern_rails.html.erb +20 -0
  96. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_range_pattern_rails.md +14 -0
  97. data/app/pb_kits/playbook/pb_date_picker/docs/example.yml +2 -0
  98. data/app/pb_kits/playbook/pb_date_picker/docs/index.js +1 -0
  99. data/app/pb_kits/playbook/pb_date_picker/plugins/quickPick.tsx +10 -0
  100. data/app/pb_kits/playbook/pb_date_range_inline/date_range_inline.test.js +2 -2
  101. data/app/pb_kits/playbook/pb_date_range_stacked/date_range_stacked.test.js +1 -1
  102. data/app/pb_kits/playbook/pb_dialog/dialog.html.erb +10 -1
  103. data/app/pb_kits/playbook/pb_dialog/dialog.rb +2 -0
  104. data/app/pb_kits/playbook/pb_dialog/docs/_dialog_turbo_frames.html.erb +117 -0
  105. data/app/pb_kits/playbook/pb_dialog/docs/_dialog_turbo_frames_rails.md +9 -0
  106. data/app/pb_kits/playbook/pb_dialog/docs/example.yml +1 -0
  107. data/app/pb_kits/playbook/pb_dialog/index.js +106 -14
  108. data/app/pb_kits/playbook/pb_draggable/_draggable.scss +43 -20
  109. data/app/pb_kits/playbook/pb_draggable/context/index.tsx +58 -17
  110. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones.html.erb +43 -0
  111. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones.jsx +102 -105
  112. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones_colors.html.erb +55 -0
  113. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones_colors.jsx +50 -48
  114. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones_colors_rails.md +1 -0
  115. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones_colors_react.md +1 -0
  116. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones_line.jsx +110 -0
  117. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones_line.md +5 -0
  118. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones_react.md +5 -0
  119. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_event_listeners.html.erb +42 -0
  120. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_event_listeners.md +1 -0
  121. data/app/pb_kits/playbook/pb_draggable/docs/{_draggable_with_table_react.jsx → _draggable_with_table.jsx} +1 -1
  122. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_table_react.md +3 -1
  123. data/app/pb_kits/playbook/pb_draggable/docs/example.yml +12 -7
  124. data/app/pb_kits/playbook/pb_draggable/docs/index.js +4 -1
  125. data/app/pb_kits/playbook/pb_draggable/draggable.rb +9 -1
  126. data/app/pb_kits/playbook/pb_draggable/draggable.test.jsx +71 -3
  127. data/app/pb_kits/playbook/pb_draggable/index.js +139 -142
  128. data/app/pb_kits/playbook/pb_draggable/subcomponents/DraggableContainer.tsx +4 -3
  129. data/app/pb_kits/playbook/pb_dropdown/_dropdown.tsx +1 -1
  130. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_error.html.erb +5 -2
  131. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_error.jsx +4 -1
  132. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete.jsx +6 -6
  133. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_and_custom_display.jsx +6 -6
  134. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.jsx +6 -6
  135. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display_rails.html.erb +8 -8
  136. data/app/pb_kits/playbook/pb_dropdown/dropdown.test.jsx +3 -3
  137. data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownOption.tsx +1 -1
  138. data/app/pb_kits/playbook/pb_filter/docs/_filter_within_turbo_frames.html.erb +41 -0
  139. data/app/pb_kits/playbook/pb_filter/docs/_filter_within_turbo_frames.md +1 -0
  140. data/app/pb_kits/playbook/pb_filter/docs/example.yml +1 -0
  141. data/app/pb_kits/playbook/pb_form_group/_error_state_mixin.scss +22 -18
  142. data/app/pb_kits/playbook/pb_form_group/_form_group.scss +45 -3
  143. data/app/pb_kits/playbook/pb_form_group/docs/_form_group_select.html.erb +15 -5
  144. data/app/pb_kits/playbook/pb_form_group/docs/_form_group_select.jsx +39 -6
  145. data/app/pb_kits/playbook/pb_gauge/docs/_gauge_pb_styles.jsx +30 -0
  146. data/app/pb_kits/playbook/pb_gauge/docs/_gauge_pb_styles.md +1 -0
  147. data/app/pb_kits/playbook/pb_gauge/docs/example.yml +1 -0
  148. data/app/pb_kits/playbook/pb_gauge/docs/index.js +1 -0
  149. data/app/pb_kits/playbook/pb_gauge/gaugeTheme.ts +85 -0
  150. data/app/pb_kits/playbook/pb_icon/icon.test.js +9 -9
  151. data/app/pb_kits/playbook/pb_icon_circle/icon_circle.test.js +1 -1
  152. data/app/pb_kits/playbook/pb_icon_stat_value/icon_stat_value.test.js +1 -1
  153. data/app/pb_kits/playbook/pb_icon_value/icon_value.test.js +1 -1
  154. data/app/pb_kits/playbook/pb_label_value/label_value.test.js +1 -1
  155. data/app/pb_kits/playbook/pb_layout/_layout.scss +127 -0
  156. data/app/pb_kits/playbook/pb_layout/_layout.tsx +47 -7
  157. data/app/pb_kits/playbook/pb_layout/docs/_layout_bracket.jsx +394 -0
  158. data/app/pb_kits/playbook/pb_layout/docs/_layout_bracket.md +5 -0
  159. data/app/pb_kits/playbook/pb_layout/docs/example.yml +1 -0
  160. data/app/pb_kits/playbook/pb_layout/docs/index.js +1 -0
  161. data/app/pb_kits/playbook/pb_layout/layout.test.js +4 -0
  162. data/app/pb_kits/playbook/pb_layout/subcomponents/_game.tsx +121 -0
  163. data/app/pb_kits/playbook/pb_layout/subcomponents/_participant.tsx +79 -0
  164. data/app/pb_kits/playbook/pb_layout/subcomponents/_round.tsx +74 -0
  165. data/app/pb_kits/playbook/pb_line_graph/docs/_line_graph_pb_styles.jsx +52 -0
  166. data/app/pb_kits/playbook/pb_line_graph/docs/_line_graph_pb_styles.md +1 -0
  167. data/app/pb_kits/playbook/pb_line_graph/docs/example.yml +1 -0
  168. data/app/pb_kits/playbook/pb_line_graph/docs/index.js +1 -0
  169. data/app/pb_kits/playbook/pb_line_graph/lineGraphTheme.ts +110 -0
  170. data/app/pb_kits/playbook/pb_link/link.test.jsx +2 -2
  171. data/app/pb_kits/playbook/pb_nav/_nav_item.test.js +5 -3
  172. data/app/pb_kits/playbook/pb_overlay/_overlay.scss +83 -22
  173. data/app/pb_kits/playbook/pb_overlay/_overlay.tsx +39 -7
  174. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_color.jsx +63 -0
  175. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_color.md +3 -0
  176. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_default.md +1 -7
  177. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_fullscreen_background.jsx +49 -0
  178. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_fullscreen_background.md +1 -0
  179. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_fullscreen_opacity.jsx +81 -0
  180. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_fullscreen_opacity.md +1 -0
  181. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_gradient_opacity.jsx +39 -0
  182. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_gradient_opacity.md +1 -0
  183. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_layout.jsx +40 -0
  184. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_layout.md +5 -0
  185. data/app/pb_kits/playbook/pb_overlay/docs/example.yml +5 -0
  186. data/app/pb_kits/playbook/pb_overlay/docs/index.js +5 -0
  187. data/app/pb_kits/playbook/pb_overlay/overlay.test.jsx +39 -1
  188. data/app/pb_kits/playbook/pb_phone_number_input/_phone_number_input.scss +13 -0
  189. data/app/pb_kits/playbook/pb_phone_number_input/_phone_number_input.tsx +3 -1
  190. data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_country_search.html.erb +10 -0
  191. data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_country_search.jsx +20 -0
  192. data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_country_search.md +1 -0
  193. data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_validation.jsx +8 -1
  194. data/app/pb_kits/playbook/pb_phone_number_input/docs/example.yml +2 -0
  195. data/app/pb_kits/playbook/pb_phone_number_input/docs/index.js +1 -0
  196. data/app/pb_kits/playbook/pb_phone_number_input/phone_number_input.rb +3 -0
  197. data/app/pb_kits/playbook/pb_phone_number_input/phone_number_input.test.js +19 -0
  198. data/app/pb_kits/playbook/pb_popover/docs/_popover_append_to.html.erb +46 -0
  199. data/app/pb_kits/playbook/pb_popover/docs/_popover_append_to.md +1 -0
  200. data/app/pb_kits/playbook/pb_popover/docs/example.yml +1 -0
  201. data/app/pb_kits/playbook/pb_popover/index.ts +13 -1
  202. data/app/pb_kits/playbook/pb_popover/popover.rb +2 -0
  203. data/app/pb_kits/playbook/pb_section_separator/docs/_section_separator_vertical.md +1 -0
  204. data/app/pb_kits/playbook/pb_select/_select.scss +10 -0
  205. data/app/pb_kits/playbook/pb_select/docs/_select_error.html.erb +1 -1
  206. data/app/pb_kits/playbook/pb_select/docs/_select_error.jsx +7 -2
  207. data/app/pb_kits/playbook/pb_stat_change/stat_change.test.js +8 -4
  208. data/app/pb_kits/playbook/pb_table/_table.tsx +2 -2
  209. data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_rows.md +3 -1
  210. data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_rows_rails.md +3 -1
  211. data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_table.md +3 -1
  212. data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_table_rails.md +3 -1
  213. data/app/pb_kits/playbook/pb_table/docs/_table_with_header_style_borderless.html.erb +34 -0
  214. data/app/pb_kits/playbook/pb_table/docs/_table_with_header_style_borderless_rails.md +1 -0
  215. data/app/pb_kits/playbook/pb_table/docs/_table_with_header_style_floating.html.erb +36 -0
  216. data/app/pb_kits/playbook/pb_table/docs/_table_with_header_style_floating_rails.md +1 -0
  217. data/app/pb_kits/playbook/pb_table/docs/_table_with_header_style_floating_react.md +1 -1
  218. data/app/pb_kits/playbook/pb_table/docs/example.yml +2 -0
  219. data/app/pb_kits/playbook/pb_table/styles/_collapsible.scss +1 -1
  220. data/app/pb_kits/playbook/pb_table/styles/_headers.scss +19 -7
  221. data/app/pb_kits/playbook/pb_table/styles/_striped.scss +3 -3
  222. data/app/pb_kits/playbook/pb_table/table.rb +13 -1
  223. data/app/pb_kits/playbook/pb_table/table_header.rb +13 -1
  224. data/app/pb_kits/playbook/pb_text_input/_text_input.tsx +13 -5
  225. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_error.html.erb +1 -1
  226. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_error.jsx +9 -1
  227. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_sanitize.jsx +94 -0
  228. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_sanitize.md +1 -0
  229. data/app/pb_kits/playbook/pb_text_input/docs/example.yml +2 -0
  230. data/app/pb_kits/playbook/pb_text_input/docs/index.js +1 -0
  231. data/app/pb_kits/playbook/pb_text_input/inputMask.ts +8 -1
  232. data/app/pb_kits/playbook/pb_textarea/docs/_textarea_error.html.erb +5 -1
  233. data/app/pb_kits/playbook/pb_textarea/docs/_textarea_error.jsx +7 -1
  234. data/app/pb_kits/playbook/pb_tooltip/tooltip.html.erb +2 -5
  235. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_error_state.html.erb +8 -1
  236. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_error_state.jsx +6 -2
  237. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_highlight.jsx +4 -4
  238. data/app/pb_kits/playbook/pb_typeahead/typeahead.html.erb +2 -5
  239. data/app/pb_kits/playbook/pb_user/user.html.erb +1 -6
  240. data/app/pb_kits/playbook/pb_user_badge/user_badge.html.erb +1 -6
  241. data/dist/chunks/_typeahead-D8CsVBZO.js +22 -0
  242. data/dist/chunks/_weekday_stacked-D3oLTSkH.js +45 -0
  243. data/dist/chunks/lib-BmTAc7Nc.js +29 -0
  244. data/dist/chunks/{pb_form_validation-BvNy9Bd6.js → pb_form_validation-BWjy4bFn.js} +1 -1
  245. data/dist/chunks/vendor.js +1 -1
  246. data/dist/menu.yml +2 -2
  247. data/dist/playbook-doc.js +19 -1
  248. data/dist/playbook-rails-react-bindings.js +1 -1
  249. data/dist/playbook-rails.js +1 -1
  250. data/dist/playbook.css +1 -1
  251. data/lib/playbook/kit_base.rb +4 -4
  252. data/lib/playbook/version.rb +2 -2
  253. metadata +98 -20
  254. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones.md +0 -5
  255. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones_colors.md +0 -1
  256. data/dist/chunks/_typeahead-Djo6qCne.js +0 -22
  257. data/dist/chunks/_weekday_stacked-DIIHW0OV.js +0 -45
  258. data/dist/chunks/lib-BGzBzFZX.js +0 -29
  259. /data/app/pb_kits/playbook/pb_draggable/docs/{_draggable_default_rails.html.erb → _draggable_default.html.erb} +0 -0
  260. /data/app/pb_kits/playbook/pb_draggable/docs/{_draggable_default.md → _draggable_default_react.md} +0 -0
  261. /data/app/pb_kits/playbook/pb_draggable/docs/{_draggable_multiple_containers_rails.html.erb → _draggable_multiple_containers.html.erb} +0 -0
  262. /data/app/pb_kits/playbook/pb_draggable/docs/{_draggable_multiple_containers.md → _draggable_multiple_containers_react.md} +0 -0
  263. /data/app/pb_kits/playbook/pb_draggable/docs/{_draggable_with_cards_rails.html.erb → _draggable_with_cards.html.erb} +0 -0
  264. /data/app/pb_kits/playbook/pb_draggable/docs/{_draggable_with_cards.md → _draggable_with_cards_react.md} +0 -0
  265. /data/app/pb_kits/playbook/pb_draggable/docs/{_draggable_with_list_rails.html.erb → _draggable_with_list.html.erb} +0 -0
  266. /data/app/pb_kits/playbook/pb_draggable/docs/{_draggable_with_list.md → _draggable_with_list_react.md} +0 -0
  267. /data/app/pb_kits/playbook/pb_draggable/docs/{_draggable_with_selectable_list_rails.html.erb → _draggable_with_selectable_list.html.erb} +0 -0
  268. /data/app/pb_kits/playbook/pb_draggable/docs/{_draggable_with_selectable_list.md → _draggable_with_selectable_list_react.md} +0 -0
  269. /data/app/pb_kits/playbook/pb_draggable/docs/{_draggable_with_table.md → _draggable_with_table_rails.md} +0 -0
@@ -0,0 +1,121 @@
1
+ import React from 'react'
2
+ import classnames from 'classnames'
3
+
4
+ import { GlobalProps, globalProps, globalInlineProps } from '../../utilities/globalProps'
5
+
6
+ import Card from '../../pb_card/_card'
7
+ import SectionSeparator from '../../pb_section_separator/_section_separator'
8
+ import Body from '../../pb_body/_body'
9
+ import Flex from '../../pb_flex/_flex'
10
+
11
+ type LayoutGameProps = {
12
+ children: React.ReactNode[] | React.ReactNode,
13
+ className?: string,
14
+ numberOfRounds: number,
15
+ numberOfGames: number,
16
+ lastRoundWithSelf?: number,
17
+ isOdd: boolean,
18
+ } & GlobalProps
19
+
20
+ // Game component (modeled after Item)
21
+ const Game = (props: LayoutGameProps) => {
22
+ const { children, className, numberOfRounds, numberOfGames, isOdd, lastRoundWithSelf } = props
23
+ const dynamicInlineProps = globalInlineProps(props)
24
+
25
+ const numberOfChildren = Array.isArray(children) ? children.length : 0
26
+
27
+ const isMultiple = Array.isArray(children)
28
+
29
+ let ratio = 0
30
+ let exponent
31
+ let currentRound = numberOfRounds
32
+ if (numberOfGames > 1) {
33
+ exponent = (numberOfRounds) - Math.log2(numberOfGames) - 1
34
+ ratio = 2 ** exponent
35
+
36
+ currentRound = exponent + 1
37
+ }
38
+
39
+ let hasWinner = false
40
+ const hasLastWinnerAndSelf = lastRoundWithSelf === currentRound
41
+ if (numberOfChildren === 2) {
42
+ const [firstChildWithoutProps, secondChildWithoutProps] = React.Children.toArray(children)
43
+
44
+ const firstChild = React.isValidElement(firstChildWithoutProps) ? React.cloneElement(firstChildWithoutProps, { hasLastWinnerAndSelf }) : firstChildWithoutProps
45
+ const secondChild = React.isValidElement(secondChildWithoutProps) ? React.cloneElement(secondChildWithoutProps, { hasLastWinnerAndSelf }) : secondChildWithoutProps
46
+
47
+ if (React.isValidElement(firstChild) && React.isValidElement(secondChild)) {
48
+ if (
49
+ firstChild?.props && typeof firstChild.props === 'object' && 'winner' in firstChild.props ||
50
+ secondChild?.props && typeof secondChild.props === 'object' && 'winner' in secondChild.props
51
+ ) {
52
+ hasWinner = true
53
+ }
54
+ return (
55
+ <div
56
+ className={classnames('layout_game', globalProps(props), className)}
57
+ style={dynamicInlineProps}
58
+ >
59
+ <Card
60
+ marginY="xs"
61
+ overflow="hidden"
62
+ padding="none"
63
+ shadow="deep"
64
+ >
65
+ <Card.Body padding="none">{firstChild}</Card.Body>
66
+ <SectionSeparator className="game_separator"/>
67
+ <Card.Body padding="none">{secondChild}</Card.Body>
68
+ </Card>
69
+ {isOdd && numberOfGames > 1 &&
70
+ <div
71
+ className="half_box"
72
+ style={{ height: `calc(${ratio} * 100% + 4px)` }}
73
+ />
74
+ }
75
+ {numberOfGames > 1 && hasWinner &&
76
+ <div className="polygon_node" />
77
+ }
78
+ </div>
79
+ )
80
+ }
81
+ }
82
+
83
+ return (
84
+ <div
85
+ className={classnames('layout_game', globalProps(props), className)}
86
+ style={dynamicInlineProps}
87
+ >
88
+ {((!isMultiple && children) || numberOfChildren >= 1) ? (
89
+ children
90
+ ) : (
91
+ <div className="layout_tbd">
92
+ <Card
93
+ marginY="xs"
94
+ padding="none"
95
+ shadow="deep"
96
+ >
97
+ <Card.Body padding="xs">
98
+ <Body color="light">
99
+ To be determined...
100
+ </Body>
101
+ </Card.Body>
102
+ <SectionSeparator className="game_separator"/>
103
+ <Card.Body padding="xs">
104
+ <Body color="light">
105
+ To be determined...
106
+ </Body>
107
+ </Card.Body>
108
+ </Card>
109
+ </div>
110
+ )}
111
+ {isOdd && numberOfGames > 1 &&
112
+ <div
113
+ className="half_box"
114
+ style={{ height: `calc(${ratio} * 100% + 4px)` }}
115
+ />
116
+ }
117
+ </div>
118
+ )
119
+ }
120
+
121
+ export default Game
@@ -0,0 +1,79 @@
1
+ import React from 'react'
2
+ import classnames from 'classnames'
3
+
4
+ import { buildCss } from '../../utilities/props'
5
+ import { GlobalProps, globalProps, globalInlineProps } from '../../utilities/globalProps'
6
+
7
+ import Avatar from "../../pb_avatar/_avatar";
8
+ import Body from "../../pb_body/_body";
9
+ import Flex from "../../pb_flex/_flex";
10
+ import Badge from "../../pb_badge/_badge";
11
+ import Detail from "../../pb_detail/_detail";
12
+ import Background from "../../pb_background/_background";
13
+
14
+ type LayoutParticipantProps = {
15
+ className?: string,
16
+ name?: string,
17
+ territory?: string,
18
+ points?: string,
19
+ rank?: string,
20
+ avatar?: string,
21
+ winner?: boolean,
22
+ self?: boolean,
23
+ } & GlobalProps
24
+
25
+ export const Participant = (props: LayoutParticipantProps) => {
26
+ const { className, name = 'To be determined...', territory = '', points, rank, avatar, winner, self, hasLastWinnerAndSelf } = props
27
+ const dynamicInlineProps = globalInlineProps(props)
28
+ const isLastWinnerAndSelf = hasLastWinnerAndSelf && self && winner
29
+ const classes = classnames(buildCss('layout_participant', winner ? 'winner' : '', self ? 'self' : '', isLastWinnerAndSelf ? 'last' : ''), globalProps(props), className)
30
+ return (
31
+ <Background
32
+ backgroundColor={winner ? "success_subtle" : "white"}
33
+ className={classes}
34
+ padding="xs"
35
+ style={dynamicInlineProps}
36
+ >
37
+ <Flex justify="between">
38
+ <Avatar
39
+ imageUrl={avatar}
40
+ marginRight="sm"
41
+ name={name}
42
+ size="sm"
43
+ />
44
+ <Body flexGrow={1}>
45
+ <Flex justify="between">
46
+ <Body
47
+ color={winner && !isLastWinnerAndSelf ? "success" : "default"}
48
+ truncate={1}
49
+ >
50
+ {winner ? <strong>{name}{self ? ' (You)' : ''}</strong> : name + (self && !isLastWinnerAndSelf ? ' (You)' : '')}
51
+ </Body>
52
+ <Body
53
+ color={winner && !isLastWinnerAndSelf ? "success" : "light"}
54
+ display="flex"
55
+ >
56
+ {points && (<>
57
+ <strong>{points}</strong>
58
+ <Detail
59
+ color={winner && !isLastWinnerAndSelf ? "success" : "light"}
60
+ text="pts"
61
+ />
62
+ </>)}
63
+ </Body>
64
+ </Flex>
65
+ <Body color="light">
66
+ {territory}
67
+ &nbsp;
68
+ <Badge
69
+ text={rank}
70
+ variant={winner && !isLastWinnerAndSelf ? "success" : self ? "notification" : "neutral"}
71
+ />
72
+ </Body>
73
+ </Body>
74
+ </Flex>
75
+ </Background>
76
+ )
77
+ }
78
+
79
+ export default Participant
@@ -0,0 +1,74 @@
1
+ import React from 'react'
2
+ import classnames from 'classnames'
3
+
4
+ import { GlobalProps, globalProps, globalInlineProps } from '../../utilities/globalProps'
5
+
6
+ type LayoutRoundLabelProps = {
7
+ children: React.ReactNode[] | React.ReactNode,
8
+ className?: string,
9
+ } & GlobalProps
10
+
11
+ export const RoundLabel = (props: LayoutRoundLabelProps) => {
12
+ const { children, className } = props
13
+ const dynamicInlineProps = globalInlineProps(props)
14
+ return (
15
+ <div
16
+ className={classnames('layout_round_label', className)}
17
+ style={dynamicInlineProps}
18
+ >
19
+ {children}
20
+ </div>
21
+ )
22
+ }
23
+
24
+ type LayoutRoundProps = {
25
+ children: React.ReactNode[] | React.ReactNode,
26
+ className?: string,
27
+ numberOfRounds: number,
28
+ lastRoundWithSelf: number,
29
+ } & GlobalProps
30
+
31
+ export const Round = (props: LayoutRoundProps) => {
32
+ const { children, className, numberOfRounds, lastRoundWithSelf } = props
33
+ const dynamicInlineProps = globalInlineProps(props)
34
+ const numberOfChildren = Array.isArray(children) ? children.length : 0
35
+
36
+ const childrenWithProps = Array.isArray(children)
37
+ ? children.map((child, index) =>
38
+ React.isValidElement(child)
39
+ ? React.cloneElement(child, {
40
+ numberOfRounds,
41
+ numberOfGames: numberOfChildren,
42
+ isOdd: index % 2 === 0,
43
+ key: `child_${index}`,
44
+ lastRoundWithSelf
45
+ })
46
+ : child
47
+ )
48
+ : React.isValidElement(children)
49
+ ? React.cloneElement(children, {
50
+ numberOfRounds,
51
+ numberOfGames: numberOfChildren,
52
+ lastRoundWithSelf
53
+ })
54
+ : children
55
+
56
+ const rightConnectors = Array.from({ length: numberOfChildren / 2 }, (_, index) => (
57
+ <div
58
+ className="right_connector"
59
+ key={`right_connector_${index}`}
60
+ />
61
+ ))
62
+
63
+ return (
64
+ <>
65
+ <div
66
+ className={classnames('layout_round', globalProps(props), className)}
67
+ style={dynamicInlineProps}
68
+ >
69
+ {childrenWithProps}
70
+ </div>
71
+ <div className="connector_container">{rightConnectors}</div>
72
+ </>
73
+ )
74
+ }
@@ -0,0 +1,52 @@
1
+ import React from 'react'
2
+ import lineGraphTheme from '../lineGraphTheme'
3
+ import Highcharts from "highcharts"
4
+ import HighchartsReact from "highcharts-react-official"
5
+
6
+ const data = [{
7
+ name: 'Installation',
8
+ data: [43934, 52503, 57177, 69658, 97031, 119931, 137133, 154175],
9
+ }, {
10
+ name: 'Manufacturing',
11
+ data: [24916, 24064, 29742, 29851, 32490, 30282, 38121, 40434],
12
+ }, {
13
+ name: 'Sales & Distribution',
14
+ data: [11744, 17722, 16005, 19771, 20185, 24377, 32147, 39387],
15
+ }, {
16
+ name: 'Project Development',
17
+ data: [null, null, 7988, 12169, 15112, 22452, 34400, 34227],
18
+ }, {
19
+ name: 'Other',
20
+ data: [12908, 5948, 8105, 11248, 8989, 11816, 18274, 18111],
21
+ }]
22
+
23
+ const categories = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']
24
+
25
+ const baseOptions = {
26
+ series: data,
27
+ title: { text: "Solar Employment Growth by Sector, 2010-2016" },
28
+ subtitle: { text: "Source: thesolarfoundation.com" },
29
+ xAxis: {
30
+ categories: categories,
31
+ },
32
+ yAxis: {
33
+ title: {
34
+ text: "Number of Employees",
35
+ },
36
+ },
37
+ }
38
+
39
+ const LineGraphPbStyles = () => {
40
+ const options = Highcharts.merge({}, lineGraphTheme, baseOptions)
41
+
42
+ return(
43
+ <div>
44
+ <HighchartsReact
45
+ highcharts={Highcharts}
46
+ options={options}
47
+ />
48
+ </div>
49
+ )
50
+ }
51
+
52
+ export default LineGraphPbStyles
@@ -0,0 +1 @@
1
+ You don't need to use the Line Graph Kit to apply Playbook styles to your Highcharts line graph. Just import lineGraphTheme.ts and merge it with your graph options—Playbook’s styling will apply automatically.
@@ -11,6 +11,7 @@ examples:
11
11
 
12
12
  react:
13
13
  - line_graph_default: Default
14
+ - line_graph_pb_styles: Playbook Styles
14
15
  - line_graph_legend: Legend
15
16
  - line_graph_legend_position: Legend Position
16
17
  - line_graph_legend_nonclickable: Legend Nonclickable
@@ -4,3 +4,4 @@ export { default as LineGraphLegendPosition } from './_line_graph_legend_positio
4
4
  export { default as LineGraphLegendNonclickable } from './_line_graph_legend_nonclickable.jsx'
5
5
  export { default as LineGraphHeight } from './_line_graph_height.jsx'
6
6
  export { default as LineGraphColors } from './_line_graph_colors.jsx'
7
+ export { default as LineGraphPbStyles } from './_line_graph_pb_styles.jsx'
@@ -0,0 +1,110 @@
1
+ import colors from '../tokens/exports/_colors.module.scss'
2
+ import typography from '../tokens/exports/_typography.module.scss'
3
+
4
+ const lineGraphTheme = {
5
+ title: {
6
+ text: "",
7
+ style: {
8
+ color: colors.text_lt_default,
9
+ fontFamily: typography.font_family_base,
10
+ fontWeight: typography.bold,
11
+ fontSize: typography.heading_3,
12
+ },
13
+ },
14
+ subtitle: {
15
+ text: "" ,
16
+ style: {
17
+ fontFamily: typography.font_family_base,
18
+ color: colors.text_lt_light,
19
+ fontWeight: typography.regular,
20
+ fontSize: typography.text_base,
21
+ },
22
+ },
23
+ chart: {
24
+ type: "line",
25
+ },
26
+ tooltip: {
27
+ backgroundColor: {
28
+ linearGradient: { x1: 0, y1: 0, x2: 0, y2: 1 },
29
+ stops: [
30
+ [0, colors.bg_dark],
31
+ [1, colors.bg_dark],
32
+ ],
33
+ },
34
+ followPointer: true,
35
+ shadow: false,
36
+ borderWidth: 0,
37
+ borderRadius: 10,
38
+ style: {
39
+ fontFamily: typography.font_family_base,
40
+ color: colors.text_dk_default,
41
+ fontWeight: typography.regular,
42
+ fontSize: typography.text_smaller,
43
+ },
44
+ },
45
+ plotOptions: {
46
+ line: {
47
+ dataLabels: {
48
+ enabled: false,
49
+ },
50
+ },
51
+ },
52
+ credits: { enabled: false },
53
+ legend: { enabled: false },
54
+ colors: [
55
+ colors.data_1,
56
+ colors.data_2,
57
+ colors.data_3,
58
+ colors.data_4,
59
+ colors.data_5,
60
+ colors.data_6,
61
+ colors.data_7,
62
+ ],
63
+ xAxis: {
64
+ gridLineWidth: 0,
65
+ lineColor: colors.border_light,
66
+ tickColor: colors.border_light,
67
+ labels: {
68
+ style: {
69
+ fontFamily: typography.font_family_base,
70
+ color: colors.text_lt_lighter,
71
+ fontWeight: typography.bold,
72
+ fontSize: typography.text_smaller,
73
+ },
74
+ },
75
+ title: {
76
+ style: {
77
+ color: colors.text_lt_default,
78
+ fontFamily: typography.font_family_base,
79
+ fontWeight: typography.regular,
80
+ fontSize: typography.heading_4,
81
+ },
82
+ },
83
+ },
84
+ yAxis: {
85
+ alternateGridColor: undefined as string | undefined,
86
+ minorTickInterval: null as number | null,
87
+ gridLineColor: colors.border_light,
88
+ minorGridLineColor: colors.border_light,
89
+ lineWidth: 0,
90
+ tickWidth: 0,
91
+ labels: {
92
+ style: {
93
+ fontFamily: typography.font_family_base,
94
+ color: colors.text_lt_lighter,
95
+ fontWeight: typography.bold,
96
+ fontSize: typography.text_smaller,
97
+ },
98
+ },
99
+ title: {
100
+ style: {
101
+ fontFamily: typography.font_family_base,
102
+ color: colors.text_lt_lighter,
103
+ fontWeight: typography.bold,
104
+ fontSize: typography.text_smaller,
105
+ },
106
+ },
107
+ },
108
+ }
109
+
110
+ export default lineGraphTheme;
@@ -73,7 +73,7 @@ test('adds icon', () => {
73
73
 
74
74
  const kit = screen.getByTestId('icon-test')
75
75
 
76
- const icon = kit.querySelector('.pb_icon_kit')
76
+ const icon = kit.querySelector('.pb_custom_icon')
77
77
  expect(icon).toBeInTheDocument();
78
78
  })
79
79
 
@@ -87,7 +87,7 @@ test('adds icon right', () => {
87
87
 
88
88
  const kit = screen.getByTestId('icon-right-test')
89
89
 
90
- const icon = kit.querySelector('.pb_icon_kit')
90
+ const icon = kit.querySelector('.pb_custom_icon')
91
91
  expect(icon).toBeInTheDocument();
92
92
  })
93
93
 
@@ -95,11 +95,13 @@ test('should not have a left border', () => {
95
95
  test('should have a right icon', () => {
96
96
  render(<NavDefault iconRight="angle-down" />)
97
97
  const kit = screen.getByTestId(itemTestId)
98
- expect(kit).toContainHTML('<i class="pb_icon_kit far pb_nav_list_item_icon_right fa-fw fa-angle-down" />')
98
+ const icon = kit.querySelector(".pb_custom_icon.pb_nav_list_item_icon_right")
99
+ expect(icon).toBeInTheDocument()
99
100
  })
100
101
 
101
102
  test('should have a left icon', () => {
102
- render(<NavDefault iconLeft="users-class" />)
103
+ render(<NavDefault iconLeft="angle-up" />)
103
104
  const kit = screen.getByTestId(itemTestId)
104
- expect(kit).toContainHTML('<i class="pb_icon_kit far pb_nav_list_item_icon_left fa-fw fa-users-class" />')
105
+ const icon = kit.querySelector(".pb_custom_icon.pb_nav_list_item_icon_left")
106
+ expect(icon).toBeInTheDocument()
105
107
  })
@@ -18,34 +18,39 @@ $overlay_colors: (
18
18
  card_dark: $card_dark,
19
19
  bg_dark: $bg_dark,
20
20
  bg_light: $bg_light,
21
+ black: $black,
22
+ white: $white,
23
+ success: $success,
24
+ error: $error
21
25
  );
22
26
 
23
- @mixin overlay($direction, $size, $color) {
27
+ @mixin overlay($direction, $size, $color, $apply_gradient: true) {
24
28
  display: block;
25
29
  position: absolute;
26
30
  pointer-events: none;
27
31
  z-index: 1;
28
32
  content: "";
29
33
 
30
- @if $direction == "left" {
31
- inset: 0 auto 0 0;
32
- background: linear-gradient(to right, $color 0%, transparent 100%);
33
- width: $size;
34
- }
35
- @if $direction == "right" {
36
- inset: 0 0 0 auto;
37
- background: linear-gradient(to left, $color 0%, transparent 100%);
38
- width: $size;
39
- }
40
- @if $direction == "top" {
41
- inset: 0 0 auto 0;
42
- background: linear-gradient(to bottom, $color 0%, transparent 100%);
43
- height: $size;
44
- }
45
- @if $direction == "bottom" {
46
- inset: auto 0 0 0;
47
- background: linear-gradient(to top, $color 0%, transparent 100%);
48
- height: $size;
34
+ @if $apply_gradient {
35
+ @if $direction == "left" {
36
+ inset: 0 auto 0 0;
37
+ background: linear-gradient(to right, $color 0%, transparent 100%);
38
+ width: $size;
39
+ } @else if $direction == "right" {
40
+ inset: 0 0 0 auto;
41
+ background: linear-gradient(to left, $color 0%, transparent 100%);
42
+ width: $size;
43
+ } @else if $direction == "top" {
44
+ inset: 0 0 auto 0;
45
+ background: linear-gradient(to bottom, $color 0%, transparent 100%);
46
+ height: $size;
47
+ } @else if $direction == "bottom" {
48
+ inset: auto 0 0 0;
49
+ background: linear-gradient(to top, $color 0%, transparent 100%);
50
+ height: $size;
51
+ }
52
+ } @else {
53
+ background: $color;
49
54
  }
50
55
  }
51
56
 
@@ -69,7 +74,7 @@ $overlay_colors: (
69
74
  pointer-events: none;
70
75
  z-index: 1;
71
76
  }
72
-
77
+
73
78
  &.overlay-hide-scrollbar {
74
79
  & [class*="overflow_x_auto"],
75
80
  & [class*="overflow_y_auto"],
@@ -77,9 +82,65 @@ $overlay_colors: (
77
82
  &::-webkit-scrollbar {
78
83
  display: none !important;
79
84
  }
80
-
85
+
81
86
  -ms-overflow-style: none !important;
82
87
  scrollbar-width: none !important;
83
88
  }
84
89
  }
90
+
91
+ &.overlay-full-screen {
92
+ position: fixed;
93
+ top: 0;
94
+ left: 0;
95
+ right: 0;
96
+ bottom: 0;
97
+ width: 100vw;
98
+ height: 100vh;
99
+ z-index: 9999;
100
+
101
+ &.no_gradient {
102
+ @each $color_name, $color in $overlay_colors {
103
+ &[data-overlay-color="#{$color_name}"] {
104
+ &::before {
105
+ content: "";
106
+ position: absolute;
107
+ top: 0;
108
+ left: 0;
109
+ right: 0;
110
+ bottom: 0;
111
+ background: $color;
112
+ pointer-events: none;
113
+ }
114
+ }
115
+ }
116
+ }
117
+
118
+ @each $key, $value in $opacity {
119
+ &.#{$key}::before {
120
+ opacity: $value;
121
+ }
122
+ }
123
+ }
124
+
125
+ &.no_gradient {
126
+ @each $color_name, $color in $overlay_colors {
127
+ .overlay_#{$color_name} {
128
+ @each $name, $size in $overlay_sizes {
129
+ @each $position in $overlay_positions {
130
+ &_#{$position}_#{$name} {
131
+ @include overlay($position, $size, $color, false);
132
+ }
133
+ }
134
+ }
135
+ }
136
+ }
137
+
138
+ @each $key, $value in $opacity {
139
+ &.#{$key} {
140
+ [class^=overlay] {
141
+ opacity: $value;
142
+ }
143
+ }
144
+ }
145
+ }
85
146
  }