@lumx/react 3.20.1-alpha.2 → 3.20.1-alpha.20

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 (697) hide show
  1. package/CONTRIBUTING.md +1 -5
  2. package/README.md +0 -2
  3. package/_internal/Button-1f227024.js +98 -0
  4. package/_internal/Button-1f227024.js.map +1 -0
  5. package/_internal/ButtonRoot-823f3e9c.js +117 -0
  6. package/_internal/ButtonRoot-823f3e9c.js.map +1 -0
  7. package/_internal/Chip-a34f6905.js +146 -0
  8. package/_internal/Chip-a34f6905.js.map +1 -0
  9. package/_internal/ClickAwayProvider-7093ba23.js +95 -0
  10. package/_internal/ClickAwayProvider-7093ba23.js.map +1 -0
  11. package/_internal/DisabledStateContext-ea04260d.js +29 -0
  12. package/_internal/DisabledStateContext-ea04260d.js.map +1 -0
  13. package/_internal/HeadingLevelProvider-ebdcb0c7.js +61 -0
  14. package/_internal/HeadingLevelProvider-ebdcb0c7.js.map +1 -0
  15. package/_internal/IconButton-f4df224c.js +77 -0
  16. package/_internal/IconButton-f4df224c.js.map +1 -0
  17. package/_internal/ImageCaption-8134a3aa.js +75 -0
  18. package/_internal/ImageCaption-8134a3aa.js.map +1 -0
  19. package/_internal/List-54237e0e.js +793 -0
  20. package/_internal/List-54237e0e.js.map +1 -0
  21. package/_internal/PopoverDialog-e0967e5f.js +655 -0
  22. package/_internal/PopoverDialog-e0967e5f.js.map +1 -0
  23. package/_internal/Portal-3f86608e.js +45 -0
  24. package/_internal/Portal-3f86608e.js.map +1 -0
  25. package/_internal/RawClickable-2c2b6a89.js +52 -0
  26. package/_internal/RawClickable-2c2b6a89.js.map +1 -0
  27. package/_internal/Slides-b7a67f32.js +678 -0
  28. package/_internal/Slides-b7a67f32.js.map +1 -0
  29. package/_internal/ThemeContext-3181f000.js +14 -0
  30. package/_internal/ThemeContext-3181f000.js.map +1 -0
  31. package/_internal/Thumbnail-b5dea0af.js +313 -0
  32. package/_internal/Thumbnail-b5dea0af.js.map +1 -0
  33. package/_internal/components/alert-dialog-b284b191.js +162 -0
  34. package/_internal/components/alert-dialog-b284b191.js.map +1 -0
  35. package/_internal/components/autocomplete-8d3f37ea.js +261 -0
  36. package/_internal/components/autocomplete-8d3f37ea.js.map +1 -0
  37. package/_internal/components/avatar-5fc70e00.js +83 -0
  38. package/_internal/components/avatar-5fc70e00.js.map +1 -0
  39. package/_internal/components/badge-8390e590.js +81 -0
  40. package/_internal/components/badge-8390e590.js.map +1 -0
  41. package/_internal/components/button-e3c7f2eb.js +47 -0
  42. package/_internal/components/button-e3c7f2eb.js.map +1 -0
  43. package/_internal/components/checkbox-d1ca9748.js +140 -0
  44. package/_internal/components/checkbox-d1ca9748.js.map +1 -0
  45. package/_internal/components/chip-e40c5521.js +102 -0
  46. package/_internal/components/chip-e40c5521.js.map +1 -0
  47. package/_internal/components/comment-block-a3cf7b9b.js +138 -0
  48. package/_internal/components/comment-block-a3cf7b9b.js.map +1 -0
  49. package/_internal/components/date-picker-6c1b14e4.js +2 -0
  50. package/_internal/components/date-picker-6c1b14e4.js.map +1 -0
  51. package/_internal/components/dialog-ebdb9500.js +238 -0
  52. package/_internal/components/dialog-ebdb9500.js.map +1 -0
  53. package/_internal/components/divider-116af6b9.js +50 -0
  54. package/_internal/components/divider-116af6b9.js.map +1 -0
  55. package/_internal/components/drag-handle-5215cd21.js +51 -0
  56. package/_internal/components/drag-handle-5215cd21.js.map +1 -0
  57. package/_internal/components/dropdown-0baed51b.js +147 -0
  58. package/_internal/components/dropdown-0baed51b.js.map +1 -0
  59. package/_internal/components/expansion-panel-5533a680.js +167 -0
  60. package/_internal/components/expansion-panel-5533a680.js.map +1 -0
  61. package/_internal/components/flag-8d4a7e72.js +59 -0
  62. package/_internal/components/flag-8d4a7e72.js.map +1 -0
  63. package/_internal/components/flex-box-55144e5f.js +56 -0
  64. package/_internal/components/flex-box-55144e5f.js.map +1 -0
  65. package/_internal/components/generic-block-ff0509ee.js +124 -0
  66. package/_internal/components/generic-block-ff0509ee.js.map +1 -0
  67. package/_internal/components/grid-6f1b5a41.js +104 -0
  68. package/_internal/components/grid-6f1b5a41.js.map +1 -0
  69. package/_internal/components/grid-column-f01df853.js +59 -0
  70. package/_internal/components/grid-column-f01df853.js.map +1 -0
  71. package/_internal/components/heading-89239843.js +53 -0
  72. package/_internal/components/heading-89239843.js.map +1 -0
  73. package/_internal/components/icon-b708cca4.js +102 -0
  74. package/_internal/components/icon-b708cca4.js.map +1 -0
  75. package/_internal/components/image-block-7938422d.js +110 -0
  76. package/_internal/components/image-block-7938422d.js.map +1 -0
  77. package/_internal/components/image-lightbox-58331704.js +756 -0
  78. package/_internal/components/image-lightbox-58331704.js.map +1 -0
  79. package/_internal/components/inline-list-e6f19a98.js +74 -0
  80. package/_internal/components/inline-list-e6f19a98.js.map +1 -0
  81. package/_internal/components/input-helper-64153099.js +71 -0
  82. package/_internal/components/input-helper-64153099.js.map +1 -0
  83. package/_internal/components/input-label-2feb0bb0.js +59 -0
  84. package/_internal/components/input-label-2feb0bb0.js.map +1 -0
  85. package/_internal/components/lightbox-570ad9e5.js +155 -0
  86. package/_internal/components/lightbox-570ad9e5.js.map +1 -0
  87. package/_internal/components/link-91f76477.js +72 -0
  88. package/_internal/components/link-91f76477.js.map +1 -0
  89. package/_internal/components/link-preview-fdd8d738.js +117 -0
  90. package/_internal/components/link-preview-fdd8d738.js.map +1 -0
  91. package/_internal/components/list-b08d8423.js +71 -0
  92. package/_internal/components/list-b08d8423.js.map +1 -0
  93. package/_internal/components/message-29cb9181.js +96 -0
  94. package/_internal/components/message-29cb9181.js.map +1 -0
  95. package/_internal/components/mosaic-cdb9f563.js +95 -0
  96. package/_internal/components/mosaic-cdb9f563.js.map +1 -0
  97. package/_internal/components/navigation-8b7d9bd8.js +225 -0
  98. package/_internal/components/navigation-8b7d9bd8.js.map +1 -0
  99. package/_internal/components/notification-a45fda96.js +145 -0
  100. package/_internal/components/notification-a45fda96.js.map +1 -0
  101. package/_internal/components/popover-65bfbc57.js +3 -0
  102. package/_internal/components/popover-65bfbc57.js.map +1 -0
  103. package/_internal/components/post-block-52e58dd5.js +109 -0
  104. package/_internal/components/post-block-52e58dd5.js.map +1 -0
  105. package/_internal/components/progress-f39c3fa2.js +182 -0
  106. package/_internal/components/progress-f39c3fa2.js.map +1 -0
  107. package/_internal/components/progress-tracker-512d7a08.js +305 -0
  108. package/_internal/components/progress-tracker-512d7a08.js.map +1 -0
  109. package/_internal/components/radio-button-559a4863.js +149 -0
  110. package/_internal/components/radio-button-559a4863.js.map +1 -0
  111. package/_internal/components/select-48d4fa8c.js +454 -0
  112. package/_internal/components/select-48d4fa8c.js.map +1 -0
  113. package/_internal/components/side-navigation-f9bc5b4e.js +165 -0
  114. package/_internal/components/side-navigation-f9bc5b4e.js.map +1 -0
  115. package/_internal/components/skeleton-c66516ee.js +166 -0
  116. package/_internal/components/skeleton-c66516ee.js.map +1 -0
  117. package/_internal/components/slider-efbfbc45.js +311 -0
  118. package/_internal/components/slider-efbfbc45.js.map +1 -0
  119. package/_internal/components/slideshow-dd312470.js +151 -0
  120. package/_internal/components/slideshow-dd312470.js.map +1 -0
  121. package/_internal/components/switch-769a2a04.js +122 -0
  122. package/_internal/components/switch-769a2a04.js.map +1 -0
  123. package/_internal/components/table-8617b1ba.js +294 -0
  124. package/_internal/components/table-8617b1ba.js.map +1 -0
  125. package/_internal/components/tabs-884c57b6.js +298 -0
  126. package/_internal/components/tabs-884c57b6.js.map +1 -0
  127. package/_internal/components/text-c7b1e079.js +2 -0
  128. package/_internal/components/text-c7b1e079.js.map +1 -0
  129. package/_internal/components/text-field-478acd86.js +359 -0
  130. package/_internal/components/text-field-478acd86.js.map +1 -0
  131. package/_internal/components/thumbnail-310a4c4b.js +42 -0
  132. package/_internal/components/thumbnail-310a4c4b.js.map +1 -0
  133. package/_internal/components/toolbar-a43533a2.js +61 -0
  134. package/_internal/components/toolbar-a43533a2.js.map +1 -0
  135. package/_internal/components/tooltip-2885ab2e.js +327 -0
  136. package/_internal/components/tooltip-2885ab2e.js.map +1 -0
  137. package/_internal/components/uploader-1e7f5bbb.js +153 -0
  138. package/_internal/components/uploader-1e7f5bbb.js.map +1 -0
  139. package/_internal/components/user-block-68a51ed0.js +145 -0
  140. package/_internal/components/user-block-68a51ed0.js.map +1 -0
  141. package/_internal/constants-b9e57936.js +2155 -0
  142. package/_internal/constants-b9e57936.js.map +1 -0
  143. package/_internal/constants-d0e3f49e.js +24 -0
  144. package/_internal/constants-d0e3f49e.js.map +1 -0
  145. package/_internal/context-9d1336a1.js +19 -0
  146. package/_internal/context-9d1336a1.js.map +1 -0
  147. package/_internal/forwardRef-15f62847.js +70 -0
  148. package/_internal/forwardRef-15f62847.js.map +1 -0
  149. package/_internal/getFocusableElements-230173a8.js +13 -0
  150. package/_internal/getFocusableElements-230173a8.js.map +1 -0
  151. package/_internal/index-9df37c0d.js +436 -0
  152. package/_internal/index-9df37c0d.js.map +1 -0
  153. package/_internal/index-a9c5cd69.js +117 -0
  154. package/_internal/index-a9c5cd69.js.map +1 -0
  155. package/_internal/isComponent-78df9309.js +20 -0
  156. package/_internal/isComponent-78df9309.js.map +1 -0
  157. package/_internal/isComponentType-e806b848.js +9 -0
  158. package/_internal/isComponentType-e806b848.js.map +1 -0
  159. package/_internal/mergeRefs-f0d7d6ea.js +30 -0
  160. package/_internal/mergeRefs-f0d7d6ea.js.map +1 -0
  161. package/{src/utils/partitionMulti.ts → _internal/partitionMulti-4daccdd5.js} +5 -9
  162. package/_internal/partitionMulti-4daccdd5.js.map +1 -0
  163. package/_internal/state-db358714.js +130 -0
  164. package/_internal/state-db358714.js.map +1 -0
  165. package/_internal/useBooleanState-2a3d237c.js +12 -0
  166. package/_internal/useBooleanState-2a3d237c.js.map +1 -0
  167. package/_internal/useCallbackOnEscape-ea4d9eb4.js +62 -0
  168. package/_internal/useCallbackOnEscape-ea4d9eb4.js.map +1 -0
  169. package/_internal/useDisableBodyScroll-36bd7352.js +219 -0
  170. package/_internal/useDisableBodyScroll-36bd7352.js.map +1 -0
  171. package/_internal/useDisableStateProps-69e16b7c.js +36 -0
  172. package/_internal/useDisableStateProps-69e16b7c.js.map +1 -0
  173. package/_internal/useFocusTrap-c3c6378b.js +112 -0
  174. package/_internal/useFocusTrap-c3c6378b.js.map +1 -0
  175. package/_internal/useId-3a1facc0.js +18 -0
  176. package/_internal/useId-3a1facc0.js.map +1 -0
  177. package/_internal/useRovingTabIndex-7daf0f24.js +77 -0
  178. package/_internal/useRovingTabIndex-7daf0f24.js.map +1 -0
  179. package/_internal/useTransitionVisibility-321fdbfa.js +50 -0
  180. package/_internal/useTransitionVisibility-321fdbfa.js.map +1 -0
  181. package/_internal/wrapChildrenIconWithSpaces-c1faaae4.js +20 -0
  182. package/_internal/wrapChildrenIconWithSpaces-c1faaae4.js.map +1 -0
  183. package/index.d.ts +42 -387
  184. package/index.js +65 -14526
  185. package/index.js.map +1 -1
  186. package/package.json +11 -21
  187. package/utils/index.d.ts +7 -7
  188. package/utils/index.js +3 -1
  189. package/utils/index.js.map +1 -1
  190. package/_internal/Falsy.d.ts +0 -7
  191. package/_internal/index.js +0 -229
  192. package/_internal/index.js.map +0 -1
  193. package/src/components/alert-dialog/AlertDialog.stories.tsx +0 -127
  194. package/src/components/alert-dialog/AlertDialog.test.tsx +0 -35
  195. package/src/components/alert-dialog/AlertDialog.tsx +0 -189
  196. package/src/components/alert-dialog/index.ts +0 -1
  197. package/src/components/autocomplete/Autocomplete.stories.tsx +0 -75
  198. package/src/components/autocomplete/Autocomplete.test.tsx +0 -101
  199. package/src/components/autocomplete/Autocomplete.tsx +0 -294
  200. package/src/components/autocomplete/AutocompleteMultiple.stories.tsx +0 -167
  201. package/src/components/autocomplete/AutocompleteMultiple.test.tsx +0 -63
  202. package/src/components/autocomplete/AutocompleteMultiple.tsx +0 -156
  203. package/src/components/autocomplete/__mockData__/index.ts +0 -39
  204. package/src/components/autocomplete/index.ts +0 -2
  205. package/src/components/avatar/Avatar.stories.tsx +0 -121
  206. package/src/components/avatar/Avatar.test.tsx +0 -34
  207. package/src/components/avatar/Avatar.tsx +0 -114
  208. package/src/components/avatar/index.ts +0 -1
  209. package/src/components/badge/Badge.stories.tsx +0 -70
  210. package/src/components/badge/Badge.test.tsx +0 -47
  211. package/src/components/badge/Badge.tsx +0 -58
  212. package/src/components/badge/BadgeWrapper.stories.tsx +0 -76
  213. package/src/components/badge/BadgeWrapper.test.tsx +0 -49
  214. package/src/components/badge/BadgeWrapper.tsx +0 -37
  215. package/src/components/badge/index.ts +0 -2
  216. package/src/components/button/Button.stories.tsx +0 -356
  217. package/src/components/button/Button.test.tsx +0 -127
  218. package/src/components/button/Button.tsx +0 -103
  219. package/src/components/button/ButtonGroup.stories.tsx +0 -54
  220. package/src/components/button/ButtonGroup.test.tsx +0 -43
  221. package/src/components/button/ButtonGroup.tsx +0 -52
  222. package/src/components/button/ButtonRoot.tsx +0 -193
  223. package/src/components/button/IconButton.stories.tsx +0 -52
  224. package/src/components/button/IconButton.test.tsx +0 -68
  225. package/src/components/button/IconButton.tsx +0 -93
  226. package/src/components/button/index.ts +0 -4
  227. package/src/components/checkbox/Checkbox.stories.tsx +0 -64
  228. package/src/components/checkbox/Checkbox.test.tsx +0 -156
  229. package/src/components/checkbox/Checkbox.tsx +0 -164
  230. package/src/components/checkbox/index.ts +0 -1
  231. package/src/components/chip/Chip.stories.tsx +0 -166
  232. package/src/components/chip/Chip.test.tsx +0 -243
  233. package/src/components/chip/Chip.tsx +0 -168
  234. package/src/components/chip/ChipGroup.stories.tsx +0 -49
  235. package/src/components/chip/ChipGroup.test.tsx +0 -39
  236. package/src/components/chip/ChipGroup.tsx +0 -60
  237. package/src/components/chip/index.ts +0 -2
  238. package/src/components/comment-block/CommentBlock.stories.tsx +0 -92
  239. package/src/components/comment-block/CommentBlock.test.tsx +0 -29
  240. package/src/components/comment-block/CommentBlock.tsx +0 -172
  241. package/src/components/comment-block/index.ts +0 -1
  242. package/src/components/date-picker/DatePicker.stories.tsx +0 -118
  243. package/src/components/date-picker/DatePicker.test.tsx +0 -36
  244. package/src/components/date-picker/DatePicker.tsx +0 -52
  245. package/src/components/date-picker/DatePickerControlled.test.tsx +0 -93
  246. package/src/components/date-picker/DatePickerControlled.tsx +0 -259
  247. package/src/components/date-picker/DatePickerField.stories.tsx +0 -100
  248. package/src/components/date-picker/DatePickerField.test.tsx +0 -72
  249. package/src/components/date-picker/DatePickerField.tsx +0 -135
  250. package/src/components/date-picker/constants.ts +0 -11
  251. package/src/components/date-picker/index.ts +0 -4
  252. package/src/components/date-picker/types.ts +0 -28
  253. package/src/components/dialog/Dialog.stories.tsx +0 -318
  254. package/src/components/dialog/Dialog.test.tsx +0 -99
  255. package/src/components/dialog/Dialog.tsx +0 -288
  256. package/src/components/dialog/index.ts +0 -1
  257. package/src/components/divider/Divider.test.tsx +0 -53
  258. package/src/components/divider/Divider.tsx +0 -52
  259. package/src/components/divider/index.ts +0 -1
  260. package/src/components/drag-handle/DragHandle.test.tsx +0 -38
  261. package/src/components/drag-handle/DragHandle.tsx +0 -53
  262. package/src/components/drag-handle/index.ts +0 -1
  263. package/src/components/dropdown/Dropdown.stories.tsx +0 -31
  264. package/src/components/dropdown/Dropdown.test.tsx +0 -66
  265. package/src/components/dropdown/Dropdown.tsx +0 -186
  266. package/src/components/dropdown/index.ts +0 -1
  267. package/src/components/expansion-panel/ExpansionPanel.stories.tsx +0 -91
  268. package/src/components/expansion-panel/ExpansionPanel.test.tsx +0 -186
  269. package/src/components/expansion-panel/ExpansionPanel.tsx +0 -195
  270. package/src/components/expansion-panel/index.ts +0 -1
  271. package/src/components/flag/Flag.stories.tsx +0 -48
  272. package/src/components/flag/Flag.test.tsx +0 -64
  273. package/src/components/flag/Flag.tsx +0 -54
  274. package/src/components/flag/index.ts +0 -1
  275. package/src/components/flex-box/FlexBox.stories.tsx +0 -158
  276. package/src/components/flex-box/FlexBox.test.tsx +0 -25
  277. package/src/components/flex-box/FlexBox.tsx +0 -100
  278. package/src/components/flex-box/index.ts +0 -1
  279. package/src/components/generic-block/GenericBlock.stories.jsx +0 -128
  280. package/src/components/generic-block/GenericBlock.test.tsx +0 -156
  281. package/src/components/generic-block/GenericBlock.tsx +0 -225
  282. package/src/components/generic-block/constants.ts +0 -9
  283. package/src/components/generic-block/index.ts +0 -2
  284. package/src/components/grid/Grid.tsx +0 -85
  285. package/src/components/grid/GridItem.tsx +0 -57
  286. package/src/components/grid/index.ts +0 -2
  287. package/src/components/grid-column/GridColumn.stories.tsx +0 -46
  288. package/src/components/grid-column/GridColumn.test.jsx +0 -58
  289. package/src/components/grid-column/GridColumn.tsx +0 -83
  290. package/src/components/grid-column/index.ts +0 -1
  291. package/src/components/heading/Heading.stories.tsx +0 -70
  292. package/src/components/heading/Heading.test.tsx +0 -84
  293. package/src/components/heading/Heading.tsx +0 -67
  294. package/src/components/heading/HeadingLevelProvider.tsx +0 -30
  295. package/src/components/heading/constants.ts +0 -16
  296. package/src/components/heading/context.tsx +0 -13
  297. package/src/components/heading/index.ts +0 -3
  298. package/src/components/heading/useHeadingLevel.tsx +0 -8
  299. package/src/components/icon/Icon.stories.tsx +0 -47
  300. package/src/components/icon/Icon.test.tsx +0 -44
  301. package/src/components/icon/Icon.tsx +0 -24
  302. package/src/components/icon/index.ts +0 -1
  303. package/src/components/image-block/ImageBlock.stories.tsx +0 -119
  304. package/src/components/image-block/ImageBlock.test.tsx +0 -59
  305. package/src/components/image-block/ImageBlock.tsx +0 -142
  306. package/src/components/image-block/ImageCaption.tsx +0 -115
  307. package/src/components/image-block/index.ts +0 -1
  308. package/src/components/image-lightbox/ImageLightbox.stories.tsx +0 -161
  309. package/src/components/image-lightbox/ImageLightbox.test.tsx +0 -252
  310. package/src/components/image-lightbox/ImageLightbox.tsx +0 -90
  311. package/src/components/image-lightbox/constants.ts +0 -11
  312. package/src/components/image-lightbox/index.ts +0 -2
  313. package/src/components/image-lightbox/internal/ImageSlide.tsx +0 -107
  314. package/src/components/image-lightbox/internal/ImageSlideshow.tsx +0 -164
  315. package/src/components/image-lightbox/internal/useAnimateScroll.ts +0 -55
  316. package/src/components/image-lightbox/internal/usePointerZoom.ts +0 -148
  317. package/src/components/image-lightbox/types.ts +0 -50
  318. package/src/components/image-lightbox/useImageLightbox.tsx +0 -141
  319. package/src/components/inline-list/InlineList.stories.tsx +0 -78
  320. package/src/components/inline-list/InlineList.test.tsx +0 -54
  321. package/src/components/inline-list/InlineList.tsx +0 -96
  322. package/src/components/inline-list/index.ts +0 -1
  323. package/src/components/input-helper/InputHelper.stories.tsx +0 -35
  324. package/src/components/input-helper/InputHelper.test.tsx +0 -57
  325. package/src/components/input-helper/InputHelper.tsx +0 -65
  326. package/src/components/input-helper/constants.ts +0 -11
  327. package/src/components/input-helper/index.ts +0 -1
  328. package/src/components/input-label/InputLabel.stories.tsx +0 -47
  329. package/src/components/input-label/InputLabel.test.tsx +0 -61
  330. package/src/components/input-label/InputLabel.tsx +0 -69
  331. package/src/components/input-label/index.ts +0 -1
  332. package/src/components/lightbox/Lightbox.stories.tsx +0 -101
  333. package/src/components/lightbox/Lightbox.test.tsx +0 -55
  334. package/src/components/lightbox/Lightbox.tsx +0 -180
  335. package/src/components/lightbox/index.ts +0 -1
  336. package/src/components/link/Link.stories.tsx +0 -196
  337. package/src/components/link/Link.test.tsx +0 -127
  338. package/src/components/link/Link.tsx +0 -119
  339. package/src/components/link/index.ts +0 -1
  340. package/src/components/link-preview/LinkPreview.stories.tsx +0 -61
  341. package/src/components/link-preview/LinkPreview.test.tsx +0 -107
  342. package/src/components/link-preview/LinkPreview.tsx +0 -160
  343. package/src/components/link-preview/index.ts +0 -1
  344. package/src/components/list/List.stories.tsx +0 -116
  345. package/src/components/list/List.test.tsx +0 -20
  346. package/src/components/list/List.tsx +0 -104
  347. package/src/components/list/ListDivider.stories.tsx +0 -12
  348. package/src/components/list/ListDivider.test.tsx +0 -24
  349. package/src/components/list/ListDivider.tsx +0 -37
  350. package/src/components/list/ListItem.stories.tsx +0 -66
  351. package/src/components/list/ListItem.test.tsx +0 -95
  352. package/src/components/list/ListItem.tsx +0 -157
  353. package/src/components/list/ListSubheader.stories.tsx +0 -11
  354. package/src/components/list/ListSubheader.test.tsx +0 -23
  355. package/src/components/list/ListSubheader.tsx +0 -44
  356. package/src/components/list/index.ts +0 -4
  357. package/src/components/list/useInteractiveList.tsx +0 -202
  358. package/src/components/message/Message.stories.tsx +0 -72
  359. package/src/components/message/Message.test.tsx +0 -77
  360. package/src/components/message/Message.tsx +0 -100
  361. package/src/components/message/index.ts +0 -1
  362. package/src/components/mosaic/Mosaic.stories.tsx +0 -89
  363. package/src/components/mosaic/Mosaic.test.tsx +0 -79
  364. package/src/components/mosaic/Mosaic.tsx +0 -98
  365. package/src/components/mosaic/index.ts +0 -1
  366. package/src/components/navigation/Navigation.stories.tsx +0 -236
  367. package/src/components/navigation/Navigation.test.tsx +0 -67
  368. package/src/components/navigation/Navigation.tsx +0 -81
  369. package/src/components/navigation/NavigationItem.test.tsx +0 -37
  370. package/src/components/navigation/NavigationItem.tsx +0 -86
  371. package/src/components/navigation/NavigationSection.test.tsx +0 -139
  372. package/src/components/navigation/NavigationSection.tsx +0 -107
  373. package/src/components/navigation/context.tsx +0 -7
  374. package/src/components/navigation/index.ts +0 -1
  375. package/src/components/notification/Notification.test.tsx +0 -95
  376. package/src/components/notification/Notification.tsx +0 -138
  377. package/src/components/notification/Notifications.stories.tsx +0 -92
  378. package/src/components/notification/constants.ts +0 -28
  379. package/src/components/notification/index.ts +0 -1
  380. package/src/components/popover/Popover.stories.tsx +0 -264
  381. package/src/components/popover/Popover.test.tsx +0 -64
  382. package/src/components/popover/Popover.tsx +0 -201
  383. package/src/components/popover/constants.ts +0 -62
  384. package/src/components/popover/index.ts +0 -3
  385. package/src/components/popover/usePopoverStyle.tsx +0 -184
  386. package/src/components/popover/useRestoreFocusOnClose.tsx +0 -47
  387. package/src/components/popover-dialog/PopoverDialog.stories.tsx +0 -64
  388. package/src/components/popover-dialog/PopoverDialog.test.tsx +0 -140
  389. package/src/components/popover-dialog/PopoverDialog.tsx +0 -76
  390. package/src/components/popover-dialog/index.tsx +0 -1
  391. package/src/components/post-block/PostBlock.test.tsx +0 -29
  392. package/src/components/post-block/PostBlock.tsx +0 -122
  393. package/src/components/post-block/index.ts +0 -1
  394. package/src/components/progress/Progress.tsx +0 -70
  395. package/src/components/progress/ProgressCircular.stories.tsx +0 -44
  396. package/src/components/progress/ProgressCircular.test.tsx +0 -48
  397. package/src/components/progress/ProgressCircular.tsx +0 -84
  398. package/src/components/progress/ProgressLinear.stories.tsx +0 -12
  399. package/src/components/progress/ProgressLinear.test.tsx +0 -32
  400. package/src/components/progress/ProgressLinear.tsx +0 -52
  401. package/src/components/progress/index.ts +0 -3
  402. package/src/components/progress-tracker/ProgressTracker.stories.tsx +0 -145
  403. package/src/components/progress-tracker/ProgressTracker.test.tsx +0 -44
  404. package/src/components/progress-tracker/ProgressTracker.tsx +0 -87
  405. package/src/components/progress-tracker/ProgressTrackerProvider.test.tsx +0 -67
  406. package/src/components/progress-tracker/ProgressTrackerProvider.tsx +0 -67
  407. package/src/components/progress-tracker/ProgressTrackerStep.test.tsx +0 -38
  408. package/src/components/progress-tracker/ProgressTrackerStep.tsx +0 -159
  409. package/src/components/progress-tracker/ProgressTrackerStepPanel.test.tsx +0 -36
  410. package/src/components/progress-tracker/ProgressTrackerStepPanel.tsx +0 -69
  411. package/src/components/progress-tracker/index.ts +0 -4
  412. package/src/components/radio-button/RadioButton.stories.tsx +0 -71
  413. package/src/components/radio-button/RadioButton.test.tsx +0 -145
  414. package/src/components/radio-button/RadioButton.tsx +0 -143
  415. package/src/components/radio-button/RadioGroup.stories.tsx +0 -39
  416. package/src/components/radio-button/RadioGroup.test.tsx +0 -31
  417. package/src/components/radio-button/RadioGroup.tsx +0 -44
  418. package/src/components/radio-button/index.ts +0 -2
  419. package/src/components/select/Select.stories.tsx +0 -385
  420. package/src/components/select/Select.test.tsx +0 -200
  421. package/src/components/select/Select.tsx +0 -199
  422. package/src/components/select/SelectMultiple.stories.tsx +0 -315
  423. package/src/components/select/SelectMultiple.test.tsx +0 -215
  424. package/src/components/select/SelectMultiple.tsx +0 -206
  425. package/src/components/select/WithSelectContext.tsx +0 -147
  426. package/src/components/select/constants.ts +0 -55
  427. package/src/components/select/index.ts +0 -2
  428. package/src/components/side-navigation/SideNavigation.stories.tsx +0 -191
  429. package/src/components/side-navigation/SideNavigation.test.tsx +0 -39
  430. package/src/components/side-navigation/SideNavigation.tsx +0 -52
  431. package/src/components/side-navigation/SideNavigationItem.stories.tsx +0 -133
  432. package/src/components/side-navigation/SideNavigationItem.test.tsx +0 -138
  433. package/src/components/side-navigation/SideNavigationItem.tsx +0 -170
  434. package/src/components/side-navigation/index.ts +0 -2
  435. package/src/components/skeleton/SkeletonCircle.stories.tsx +0 -41
  436. package/src/components/skeleton/SkeletonCircle.test.tsx +0 -29
  437. package/src/components/skeleton/SkeletonCircle.tsx +0 -54
  438. package/src/components/skeleton/SkeletonRectangle.stories.tsx +0 -82
  439. package/src/components/skeleton/SkeletonRectangle.test.tsx +0 -29
  440. package/src/components/skeleton/SkeletonRectangle.tsx +0 -90
  441. package/src/components/skeleton/SkeletonTypography.stories.tsx +0 -21
  442. package/src/components/skeleton/SkeletonTypography.test.tsx +0 -29
  443. package/src/components/skeleton/SkeletonTypography.tsx +0 -59
  444. package/src/components/skeleton/index.ts +0 -3
  445. package/src/components/slider/Slider.stories.tsx +0 -45
  446. package/src/components/slider/Slider.test.tsx +0 -31
  447. package/src/components/slider/Slider.tsx +0 -299
  448. package/src/components/slider/index.ts +0 -2
  449. package/src/components/slideshow/Slides.tsx +0 -130
  450. package/src/components/slideshow/Slideshow.stories.tsx +0 -180
  451. package/src/components/slideshow/Slideshow.test.tsx +0 -37
  452. package/src/components/slideshow/Slideshow.tsx +0 -173
  453. package/src/components/slideshow/SlideshowControls.stories.tsx +0 -102
  454. package/src/components/slideshow/SlideshowControls.tsx +0 -243
  455. package/src/components/slideshow/SlideshowItem.tsx +0 -46
  456. package/src/components/slideshow/SlideshowItemGroup.tsx +0 -60
  457. package/src/components/slideshow/constants.ts +0 -24
  458. package/src/components/slideshow/index.ts +0 -4
  459. package/src/components/slideshow/useKeyNavigate.ts +0 -28
  460. package/src/components/slideshow/usePaginationVisibleRange.ts +0 -37
  461. package/src/components/slideshow/useSlideFocusManagement.tsx +0 -92
  462. package/src/components/slideshow/useSwipeNavigate.ts +0 -18
  463. package/src/components/switch/Switch.stories.tsx +0 -49
  464. package/src/components/switch/Switch.test.tsx +0 -146
  465. package/src/components/switch/Switch.tsx +0 -145
  466. package/src/components/switch/index.ts +0 -1
  467. package/src/components/table/Table.test.tsx +0 -31
  468. package/src/components/table/Table.tsx +0 -61
  469. package/src/components/table/TableBody.test.tsx +0 -32
  470. package/src/components/table/TableBody.tsx +0 -44
  471. package/src/components/table/TableCell.test.tsx +0 -74
  472. package/src/components/table/TableCell.tsx +0 -132
  473. package/src/components/table/TableHeader.test.tsx +0 -32
  474. package/src/components/table/TableHeader.tsx +0 -50
  475. package/src/components/table/TableRow.test.tsx +0 -42
  476. package/src/components/table/TableRow.tsx +0 -73
  477. package/src/components/table/index.ts +0 -5
  478. package/src/components/tabs/Tab.test.tsx +0 -52
  479. package/src/components/tabs/Tab.tsx +0 -133
  480. package/src/components/tabs/TabList.test.tsx +0 -51
  481. package/src/components/tabs/TabList.tsx +0 -94
  482. package/src/components/tabs/TabPanel.test.tsx +0 -39
  483. package/src/components/tabs/TabPanel.tsx +0 -69
  484. package/src/components/tabs/TabProvider.test.tsx +0 -163
  485. package/src/components/tabs/TabProvider.tsx +0 -67
  486. package/src/components/tabs/Tabs.stories.tsx +0 -170
  487. package/src/components/tabs/index.ts +0 -4
  488. package/src/components/tabs/state.ts +0 -114
  489. package/src/components/tabs/test-utils.ts +0 -39
  490. package/src/components/text/Text.stories.tsx +0 -177
  491. package/src/components/text/Text.test.tsx +0 -94
  492. package/src/components/text/Text.tsx +0 -141
  493. package/src/components/text/index.ts +0 -1
  494. package/src/components/text-field/TextField.stories.tsx +0 -180
  495. package/src/components/text-field/TextField.test.tsx +0 -299
  496. package/src/components/text-field/TextField.tsx +0 -493
  497. package/src/components/text-field/index.ts +0 -1
  498. package/src/components/thumbnail/Thumbnail.stories.tsx +0 -448
  499. package/src/components/thumbnail/Thumbnail.test.tsx +0 -66
  500. package/src/components/thumbnail/Thumbnail.tsx +0 -248
  501. package/src/components/thumbnail/index.ts +0 -3
  502. package/src/components/thumbnail/types.ts +0 -48
  503. package/src/components/thumbnail/useFocusPointStyle.test.ts +0 -92
  504. package/src/components/thumbnail/useFocusPointStyle.tsx +0 -107
  505. package/src/components/thumbnail/useImageLoad.ts +0 -40
  506. package/src/components/toolbar/Toolbar.tsx +0 -68
  507. package/src/components/toolbar/index.ts +0 -1
  508. package/src/components/tooltip/Tooltip.stories.tsx +0 -117
  509. package/src/components/tooltip/Tooltip.test.tsx +0 -411
  510. package/src/components/tooltip/Tooltip.tsx +0 -165
  511. package/src/components/tooltip/constants.ts +0 -8
  512. package/src/components/tooltip/context.tsx +0 -17
  513. package/src/components/tooltip/index.ts +0 -1
  514. package/src/components/tooltip/useInjectTooltipRef.tsx +0 -55
  515. package/src/components/tooltip/useTooltipOpen.tsx +0 -143
  516. package/src/components/uploader/Uploader.stories.tsx +0 -109
  517. package/src/components/uploader/Uploader.test.tsx +0 -148
  518. package/src/components/uploader/Uploader.tsx +0 -177
  519. package/src/components/uploader/index.ts +0 -1
  520. package/src/components/user-block/UserBlock.stories.tsx +0 -135
  521. package/src/components/user-block/UserBlock.test.tsx +0 -108
  522. package/src/components/user-block/UserBlock.tsx +0 -193
  523. package/src/components/user-block/index.ts +0 -1
  524. package/src/constants.ts +0 -27
  525. package/src/hooks/useBooleanState.tsx +0 -13
  526. package/src/hooks/useCallbackOnEscape.ts +0 -34
  527. package/src/hooks/useChipGroupNavigation.tsx +0 -75
  528. package/src/hooks/useClickAway.tsx +0 -48
  529. package/src/hooks/useDisableBodyScroll.ts +0 -28
  530. package/src/hooks/useEventCallback.tsx +0 -17
  531. package/src/hooks/useFocus.tsx +0 -21
  532. package/src/hooks/useFocusTrap.ts +0 -93
  533. package/src/hooks/useFocusWithin.ts +0 -33
  534. package/src/hooks/useId.test.tsx +0 -23
  535. package/src/hooks/useId.ts +0 -15
  536. package/src/hooks/useImageSize.ts +0 -17
  537. package/src/hooks/useInfiniteScroll.tsx +0 -60
  538. package/src/hooks/useIntersectionObserver.tsx +0 -43
  539. package/src/hooks/useInterval.tsx +0 -31
  540. package/src/hooks/useKeyboardListNavigation.tsx +0 -204
  541. package/src/hooks/useListenFocus.tsx +0 -26
  542. package/src/hooks/useOverflowTooltipLabel.tsx +0 -32
  543. package/src/hooks/usePopper.ts +0 -12
  544. package/src/hooks/usePreviousValue.ts +0 -13
  545. package/src/hooks/useRovingTabIndex.tsx +0 -90
  546. package/src/hooks/useSizeOnWindowResize.ts +0 -30
  547. package/src/hooks/useSlideshowControls.ts +0 -246
  548. package/src/hooks/useStopPropagation.ts +0 -21
  549. package/src/hooks/useTransitionVisibility.ts +0 -48
  550. package/src/index.ts +0 -63
  551. package/src/stories/controls/color.ts +0 -7
  552. package/src/stories/controls/element.ts +0 -6
  553. package/src/stories/controls/focusPoint.ts +0 -1
  554. package/src/stories/controls/icons.ts +0 -126
  555. package/src/stories/controls/image.ts +0 -84
  556. package/src/stories/controls/selectArgType.ts +0 -8
  557. package/src/stories/controls/theme.ts +0 -3
  558. package/src/stories/controls/typography.ts +0 -5
  559. package/src/stories/controls/withUndefined.ts +0 -1
  560. package/src/stories/decorators/withChromaticForceScreenSize.tsx +0 -8
  561. package/src/stories/decorators/withCombinations.tsx +0 -132
  562. package/src/stories/decorators/withNestedProps.tsx +0 -23
  563. package/src/stories/decorators/withResizableBox.tsx +0 -21
  564. package/src/stories/decorators/withThemedBackground.tsx +0 -18
  565. package/src/stories/decorators/withValueOnChange.tsx +0 -18
  566. package/src/stories/decorators/withWrapper.tsx +0 -21
  567. package/src/stories/generated/Autocomplete/Demos.stories.tsx +0 -7
  568. package/src/stories/generated/Avatar/Demos.stories.tsx +0 -7
  569. package/src/stories/generated/Badge/Demos.stories.tsx +0 -9
  570. package/src/stories/generated/Button/Demos.stories.tsx +0 -11
  571. package/src/stories/generated/Checkbox/Demos.stories.tsx +0 -6
  572. package/src/stories/generated/Chip/Demos.stories.tsx +0 -11
  573. package/src/stories/generated/CommentBlock/Demos.stories.tsx +0 -8
  574. package/src/stories/generated/DatePicker/Demos.stories.tsx +0 -8
  575. package/src/stories/generated/Dialog/Demos.stories.tsx +0 -10
  576. package/src/stories/generated/Divider/Demos.stories.tsx +0 -6
  577. package/src/stories/generated/Dropdown/Demos.stories.tsx +0 -8
  578. package/src/stories/generated/ExpansionPanel/Demos.stories.tsx +0 -9
  579. package/src/stories/generated/Flag/Demos.stories.tsx +0 -6
  580. package/src/stories/generated/GenericBlock/Demos.stories.tsx +0 -8
  581. package/src/stories/generated/Heading/Demos.stories.tsx +0 -6
  582. package/src/stories/generated/Icon/Demos.stories.tsx +0 -8
  583. package/src/stories/generated/ImageBlock/Demos.stories.tsx +0 -9
  584. package/src/stories/generated/ImageLightbox/Demos.stories.tsx +0 -6
  585. package/src/stories/generated/Lightbox/Demos.stories.tsx +0 -6
  586. package/src/stories/generated/LinkPreview/Demos.stories.tsx +0 -7
  587. package/src/stories/generated/List/Demos.stories.tsx +0 -11
  588. package/src/stories/generated/Message/Demos.stories.tsx +0 -11
  589. package/src/stories/generated/Mosaic/Demos.stories.tsx +0 -10
  590. package/src/stories/generated/Notification/Demos.stories.tsx +0 -6
  591. package/src/stories/generated/Popover/Demos.stories.tsx +0 -11
  592. package/src/stories/generated/PopoverDialog/Demos.stories.tsx +0 -6
  593. package/src/stories/generated/PostBlock/Demos.stories.tsx +0 -6
  594. package/src/stories/generated/Progress/Demos.stories.tsx +0 -7
  595. package/src/stories/generated/ProgressTracker/Demos.stories.tsx +0 -9
  596. package/src/stories/generated/RadioButton/Demos.stories.tsx +0 -6
  597. package/src/stories/generated/Select/Demos.stories.tsx +0 -14
  598. package/src/stories/generated/SideNavigation/Demos.stories.tsx +0 -10
  599. package/src/stories/generated/Skeleton/Demos.stories.tsx +0 -9
  600. package/src/stories/generated/Slider/Demos.stories.tsx +0 -9
  601. package/src/stories/generated/Slideshow/Demos.stories.tsx +0 -8
  602. package/src/stories/generated/Switch/Demos.stories.tsx +0 -6
  603. package/src/stories/generated/Table/Demos.stories.tsx +0 -7
  604. package/src/stories/generated/Tabs/Demos.stories.tsx +0 -8
  605. package/src/stories/generated/TextField/Demos.stories.tsx +0 -20
  606. package/src/stories/generated/Thumbnail/Demos.stories.tsx +0 -12
  607. package/src/stories/generated/Toolbar/Demos.stories.tsx +0 -10
  608. package/src/stories/generated/Tooltip/Demos.stories.tsx +0 -8
  609. package/src/stories/generated/Uploader/Demos.stories.tsx +0 -8
  610. package/src/stories/generated/UserBlock/Demos.stories.tsx +0 -11
  611. package/src/stories/utils/CustomLink.tsx +0 -13
  612. package/src/stories/utils/concatPath.tsx +0 -17
  613. package/src/stories/utils/disableArgTypes.ts +0 -3
  614. package/src/stories/utils/initDemoShadowDOMPortal.ts +0 -10
  615. package/src/stories/utils/lorem.ts +0 -59
  616. package/src/stories/utils/theming.tsx +0 -166
  617. package/src/stories/utils/toFlattenProps.ts +0 -28
  618. package/src/stories/utils/withCategory.ts +0 -12
  619. package/src/testing/utils/ThemeSentinel.tsx +0 -11
  620. package/src/testing/utils/commonTestsSuiteRTL.tsx +0 -193
  621. package/src/testing/utils/index.ts +0 -1
  622. package/src/testing/utils/queries.ts +0 -19
  623. package/src/untypped-modules.d.ts +0 -5
  624. package/src/utils/ClickAwayProvider/ClickAwayProvider.stories.jsx +0 -70
  625. package/src/utils/ClickAwayProvider/ClickAwayProvider.tsx +0 -69
  626. package/src/utils/ClickAwayProvider/index.ts +0 -1
  627. package/src/utils/MaterialThemeSwitcher/MaterialThemeSwitcher.tsx +0 -54
  628. package/src/utils/MaterialThemeSwitcher/index.ts +0 -1
  629. package/src/utils/Portal/Portal.test.tsx +0 -32
  630. package/src/utils/Portal/Portal.tsx +0 -33
  631. package/src/utils/Portal/PortalProvider.stories.jsx +0 -23
  632. package/src/utils/Portal/PortalProvider.test.tsx +0 -73
  633. package/src/utils/Portal/PortalProvider.tsx +0 -24
  634. package/src/utils/Portal/index.tsx +0 -2
  635. package/src/utils/browser/DOM/findImage.tsx +0 -3
  636. package/src/utils/browser/DOM/startViewTransition.ts +0 -68
  637. package/src/utils/browser/focus/constants.ts +0 -7
  638. package/src/utils/browser/focus/getFirstAndLastFocusable.test.ts +0 -134
  639. package/src/utils/browser/focus/getFirstAndLastFocusable.ts +0 -21
  640. package/src/utils/browser/focus/getFocusableElements.test.ts +0 -151
  641. package/src/utils/browser/focus/getFocusableElements.ts +0 -7
  642. package/src/utils/browser/isFocusVisible.ts +0 -9
  643. package/src/utils/browser/isHoverNotSupported.test.js +0 -24
  644. package/src/utils/browser/isHoverNotSupported.ts +0 -2
  645. package/src/utils/browser/isReducedMotion.ts +0 -6
  646. package/src/utils/date/addMonthResetDay.test.ts +0 -13
  647. package/src/utils/date/addMonthResetDay.ts +0 -9
  648. package/src/utils/date/formatDayNumber.test.ts +0 -12
  649. package/src/utils/date/formatDayNumber.ts +0 -5
  650. package/src/utils/date/getFirstDayOfWeek.test.ts +0 -20
  651. package/src/utils/date/getFirstDayOfWeek.ts +0 -59
  652. package/src/utils/date/getMonthCalendar.test.ts +0 -127
  653. package/src/utils/date/getMonthCalendar.ts +0 -69
  654. package/src/utils/date/getWeekDays.test.ts +0 -48
  655. package/src/utils/date/getWeekDays.ts +0 -34
  656. package/src/utils/date/getYearDisplayName.test.ts +0 -20
  657. package/src/utils/date/getYearDisplayName.ts +0 -12
  658. package/src/utils/date/isDateValid.test.ts +0 -15
  659. package/src/utils/date/isDateValid.ts +0 -4
  660. package/src/utils/date/isSameDay.test.ts +0 -37
  661. package/src/utils/date/isSameDay.ts +0 -11
  662. package/src/utils/disabled/DisabledStateContext.tsx +0 -29
  663. package/src/utils/disabled/DisabledStateProvider.stories.tsx +0 -94
  664. package/src/utils/disabled/index.ts +0 -2
  665. package/src/utils/disabled/useDisableStateProps.test.tsx +0 -74
  666. package/src/utils/disabled/useDisableStateProps.tsx +0 -37
  667. package/src/utils/function/makeListenerTowerContext.ts +0 -32
  668. package/src/utils/index.ts +0 -7
  669. package/src/utils/locale/getCurrentLocale.ts +0 -4
  670. package/src/utils/locale/parseLocale.test.ts +0 -17
  671. package/src/utils/locale/parseLocale.ts +0 -23
  672. package/src/utils/locale/types.ts +0 -8
  673. package/src/utils/number/clamp.ts +0 -17
  674. package/src/utils/object/isEqual.test.ts +0 -25
  675. package/src/utils/object/isEqual.ts +0 -11
  676. package/src/utils/partitionMulti.test.ts +0 -27
  677. package/src/utils/react/OnBeforeUnmount.tsx +0 -20
  678. package/src/utils/react/flattenChildren.ts +0 -32
  679. package/src/utils/react/forwardRef.ts +0 -11
  680. package/src/utils/react/forwardRefPolymorphic.ts +0 -9
  681. package/src/utils/react/mergeRefs.ts +0 -33
  682. package/src/utils/react/renderButtonOrLink.tsx +0 -16
  683. package/src/utils/react/renderLink.tsx +0 -17
  684. package/src/utils/react/skipRender.tsx +0 -18
  685. package/src/utils/react/unref.ts +0 -7
  686. package/src/utils/react/wrapChildrenIconWithSpaces.test.tsx +0 -37
  687. package/src/utils/react/wrapChildrenIconWithSpaces.tsx +0 -22
  688. package/src/utils/theme/ThemeContext.ts +0 -16
  689. package/src/utils/theme/invertTheme.ts +0 -4
  690. package/src/utils/type/Comp.ts +0 -14
  691. package/src/utils/type/ComponentRef.ts +0 -16
  692. package/src/utils/type/HasAriaDisabled.ts +0 -6
  693. package/src/utils/type/HasPolymorphicAs.ts +0 -8
  694. package/src/utils/type/MaybeElementOrRef.ts +0 -6
  695. package/src/utils/type/index.ts +0 -8
  696. package/src/utils/type/isComponent.ts +0 -33
  697. package/src/utils/type/isComponentType.ts +0 -9
@@ -0,0 +1,167 @@
1
+ import React__default, { Children, useRef } from 'react';
2
+ import { f as forwardRef, c as classNames } from '../forwardRef-15f62847.js';
3
+ import { mdiChevronUp, mdiChevronDown } from '@lumx/icons';
4
+ import isEmpty from 'lodash/isEmpty';
5
+ import { i as isComponent } from '../isComponent-78df9309.js';
6
+ import { getRootClassName, handleBasicClasses } from '@lumx/core/js/utils/className';
7
+ import { p as partitionMulti } from '../partitionMulti-4daccdd5.js';
8
+ import { u as useTheme } from '../ThemeContext-3181f000.js';
9
+ import { I as IS_BROWSER } from '../constants-d0e3f49e.js';
10
+ import { jsx, jsxs } from 'react/jsx-runtime';
11
+ import { DragHandle } from './drag-handle-5215cd21.js';
12
+ import { Theme, ColorPalette, Emphasis } from '@lumx/core/js/constants';
13
+ import { I as IconButton } from '../IconButton-f4df224c.js';
14
+
15
+ /**
16
+ * Component display name.
17
+ */
18
+ const COMPONENT_NAME = 'ExpansionPanel';
19
+
20
+ /**
21
+ * Component default class name and class prefix.
22
+ */
23
+ const CLASSNAME = getRootClassName(COMPONENT_NAME);
24
+
25
+ /**
26
+ * Component default props.
27
+ */
28
+ const DEFAULT_PROPS = {
29
+ closeMode: 'unmount'
30
+ };
31
+ const isDragHandle = isComponent(DragHandle);
32
+ const isHeader = isComponent('header');
33
+ const isFooter = isComponent('footer');
34
+
35
+ /**
36
+ * ExpansionPanel component.
37
+ *
38
+ * @param props Component props.
39
+ * @param ref Component ref.
40
+ * @return React element.
41
+ */
42
+ const ExpansionPanel = forwardRef((props, ref) => {
43
+ const defaultTheme = useTheme() || Theme.light;
44
+ const {
45
+ className,
46
+ closeMode = DEFAULT_PROPS.closeMode,
47
+ children: anyChildren,
48
+ hasBackground,
49
+ hasHeaderDivider,
50
+ isOpen,
51
+ label,
52
+ onClose,
53
+ onOpen,
54
+ onToggleOpen,
55
+ theme = defaultTheme,
56
+ toggleButtonProps,
57
+ ...forwardedProps
58
+ } = props;
59
+ const children = Children.toArray(anyChildren);
60
+
61
+ // Partition children by types.
62
+ const [[dragHandle], [header], [footer], content] = partitionMulti(children, [isDragHandle, isHeader, isFooter]);
63
+
64
+ // Either take the header in children or create one with the label.
65
+ const headerProps = /*#__PURE__*/React__default.isValidElement(header) ? header.props : {};
66
+ const headerContent = !isEmpty(headerProps.children) ? headerProps.children : /*#__PURE__*/jsx("span", {
67
+ className: `${CLASSNAME}__label`,
68
+ children: label
69
+ });
70
+ const toggleOpen = event => {
71
+ const shouldOpen = !isOpen;
72
+ if (onOpen && shouldOpen) {
73
+ onOpen(event);
74
+ }
75
+ if (onClose && !shouldOpen) {
76
+ onClose(event);
77
+ }
78
+ if (onToggleOpen) {
79
+ onToggleOpen(shouldOpen, event);
80
+ }
81
+ };
82
+ const color = theme === Theme.dark ? ColorPalette.light : ColorPalette.dark;
83
+ const rootClassName = classNames(className, handleBasicClasses({
84
+ hasBackground,
85
+ hasHeader: Boolean(!isEmpty(headerProps.children)),
86
+ hasHeaderDivider,
87
+ isClose: !isOpen,
88
+ isDraggable: Boolean(dragHandle),
89
+ isOpen,
90
+ prefix: CLASSNAME,
91
+ theme
92
+ }));
93
+ const wrapperRef = useRef(null);
94
+
95
+ // Children stay visible while the open/close transition is running
96
+ const [isChildrenVisible, setChildrenVisible] = React__default.useState(isOpen);
97
+ const isOpenRef = React__default.useRef(isOpen);
98
+ React__default.useEffect(() => {
99
+ if (isOpen || closeMode === 'hide') {
100
+ setChildrenVisible(true);
101
+ } else if (!IS_BROWSER) {
102
+ // Outside a browser we can't wait for the transition
103
+ setChildrenVisible(false);
104
+ }
105
+ isOpenRef.current = isOpen;
106
+ }, [closeMode, isOpen]);
107
+
108
+ // Change children's visibility on the transition end
109
+ React__default.useEffect(() => {
110
+ const {
111
+ current: wrapper
112
+ } = wrapperRef;
113
+ if (!IS_BROWSER || !wrapper) {
114
+ return undefined;
115
+ }
116
+ const onTransitionEnd = () => {
117
+ setChildrenVisible(isOpenRef.current || closeMode === 'hide');
118
+ };
119
+ wrapper.addEventListener('transitionend', onTransitionEnd);
120
+ return () => wrapper.removeEventListener('transitionend', onTransitionEnd);
121
+ }, [closeMode]);
122
+ return /*#__PURE__*/jsxs("section", {
123
+ ref: ref,
124
+ ...forwardedProps,
125
+ className: rootClassName,
126
+ children: [/*#__PURE__*/jsxs("header", {
127
+ className: `${CLASSNAME}__header`,
128
+ onClick: toggleOpen,
129
+ children: [dragHandle && /*#__PURE__*/jsx("div", {
130
+ className: `${CLASSNAME}__header-drag`,
131
+ children: dragHandle
132
+ }), /*#__PURE__*/jsx("div", {
133
+ ...headerProps,
134
+ className: `${CLASSNAME}__header-content`,
135
+ children: headerContent
136
+ }), /*#__PURE__*/jsx("div", {
137
+ className: `${CLASSNAME}__header-toggle`,
138
+ children: /*#__PURE__*/jsx(IconButton, {
139
+ ...toggleButtonProps,
140
+ color: color,
141
+ emphasis: Emphasis.low,
142
+ icon: isOpen ? mdiChevronUp : mdiChevronDown,
143
+ "aria-expanded": isOpen || 'false'
144
+ })
145
+ })]
146
+ }), /*#__PURE__*/jsx("div", {
147
+ className: `${CLASSNAME}__wrapper`,
148
+ ref: wrapperRef,
149
+ children: (isOpen || isChildrenVisible) && /*#__PURE__*/jsxs("div", {
150
+ className: `${CLASSNAME}__container`,
151
+ children: [/*#__PURE__*/jsx("div", {
152
+ className: `${CLASSNAME}__content`,
153
+ children: content
154
+ }), footer && /*#__PURE__*/jsx("div", {
155
+ className: `${CLASSNAME}__footer`,
156
+ children: footer
157
+ })]
158
+ })
159
+ })]
160
+ });
161
+ });
162
+ ExpansionPanel.displayName = COMPONENT_NAME;
163
+ ExpansionPanel.className = CLASSNAME;
164
+ ExpansionPanel.defaultProps = DEFAULT_PROPS;
165
+
166
+ export { ExpansionPanel };
167
+ //# sourceMappingURL=expansion-panel-5533a680.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"expansion-panel-5533a680.js","sources":["../../../src/components/expansion-panel/ExpansionPanel.tsx"],"sourcesContent":["import React, { Children, PropsWithChildren, ReactNode, useRef } from 'react';\n\nimport classNames from 'classnames';\n\nimport { mdiChevronDown, mdiChevronUp } from '@lumx/icons';\n\nimport isEmpty from 'lodash/isEmpty';\n\nimport { ColorPalette, DragHandle, Emphasis, IconButton, IconButtonProps, Theme } from '@lumx/react';\nimport { GenericProps, HasCloseMode, HasTheme, isComponent } from '@lumx/react/utils/type';\nimport { getRootClassName, handleBasicClasses } from '@lumx/core/js/utils/className';\nimport { partitionMulti } from '@lumx/react/utils/partitionMulti';\nimport { useTheme } from '@lumx/react/utils/theme/ThemeContext';\nimport { forwardRef } from '@lumx/react/utils/react/forwardRef';\nimport { IS_BROWSER } from '@lumx/react/constants';\n\n/**\n * Defines the props of the component.\n */\nexport interface ExpansionPanelProps extends GenericProps, HasCloseMode, HasTheme {\n /** Whether the expansion panel has a background. */\n hasBackground?: boolean;\n /** Whether the header has a divider. */\n hasHeaderDivider?: boolean;\n /** Whether the component is open or not. */\n isOpen?: boolean;\n /** Label text (overwritten if a `<header>` is provided in the children). */\n label?: string;\n /** On open callback. */\n onOpen?: (event: React.MouseEvent) => void;\n /** On close callback. */\n onClose?: (event: React.MouseEvent) => void;\n /** Props to pass to the toggle button (minus those already set by the ExpansionPanel props). */\n toggleButtonProps: Pick<IconButtonProps, 'label'> &\n Omit<IconButtonProps, 'label' | 'onClick' | 'icon' | 'emphasis' | 'color'>;\n /** On toggle open or close callback. */\n onToggleOpen?(shouldOpen: boolean, event: React.MouseEvent): void;\n /** Children */\n children?: React.ReactNode;\n}\n\n/**\n * Component display name.\n */\nconst COMPONENT_NAME = 'ExpansionPanel';\n\n/**\n * Component default class name and class prefix.\n */\nconst CLASSNAME = getRootClassName(COMPONENT_NAME);\n\n/**\n * Component default props.\n */\nconst DEFAULT_PROPS: Partial<ExpansionPanelProps> = {\n closeMode: 'unmount',\n};\n\nconst isDragHandle = isComponent(DragHandle);\nconst isHeader = isComponent('header');\nconst isFooter = isComponent('footer');\n\n/**\n * ExpansionPanel component.\n *\n * @param props Component props.\n * @param ref Component ref.\n * @return React element.\n */\nexport const ExpansionPanel = forwardRef<ExpansionPanelProps, HTMLDivElement>((props, ref) => {\n const defaultTheme = useTheme() || Theme.light;\n const {\n className,\n closeMode = DEFAULT_PROPS.closeMode,\n children: anyChildren,\n hasBackground,\n hasHeaderDivider,\n isOpen,\n label,\n onClose,\n onOpen,\n onToggleOpen,\n theme = defaultTheme,\n toggleButtonProps,\n ...forwardedProps\n } = props;\n\n const children: ReactNode[] = Children.toArray(anyChildren);\n\n // Partition children by types.\n const [[dragHandle], [header], [footer], content] = partitionMulti(children, [isDragHandle, isHeader, isFooter]);\n\n // Either take the header in children or create one with the label.\n const headerProps: PropsWithChildren<any> = React.isValidElement(header) ? header.props : {};\n const headerContent = !isEmpty(headerProps.children) ? (\n headerProps.children\n ) : (\n <span className={`${CLASSNAME}__label`}>{label}</span>\n );\n\n const toggleOpen = (event: React.MouseEvent) => {\n const shouldOpen = !isOpen;\n\n if (onOpen && shouldOpen) {\n onOpen(event);\n }\n if (onClose && !shouldOpen) {\n onClose(event);\n }\n if (onToggleOpen) {\n onToggleOpen(shouldOpen, event);\n }\n };\n\n const color = theme === Theme.dark ? ColorPalette.light : ColorPalette.dark;\n\n const rootClassName = classNames(\n className,\n handleBasicClasses({\n hasBackground,\n hasHeader: Boolean(!isEmpty(headerProps.children)),\n hasHeaderDivider,\n isClose: !isOpen,\n isDraggable: Boolean(dragHandle),\n isOpen,\n prefix: CLASSNAME,\n theme,\n }),\n );\n\n const wrapperRef = useRef<HTMLDivElement>(null);\n\n // Children stay visible while the open/close transition is running\n const [isChildrenVisible, setChildrenVisible] = React.useState(isOpen);\n\n const isOpenRef = React.useRef(isOpen);\n React.useEffect(() => {\n if (isOpen || closeMode === 'hide') {\n setChildrenVisible(true);\n } else if (!IS_BROWSER) {\n // Outside a browser we can't wait for the transition\n setChildrenVisible(false);\n }\n isOpenRef.current = isOpen;\n }, [closeMode, isOpen]);\n\n // Change children's visibility on the transition end\n React.useEffect(() => {\n const { current: wrapper } = wrapperRef;\n if (!IS_BROWSER || !wrapper) {\n return undefined;\n }\n const onTransitionEnd = () => {\n setChildrenVisible(isOpenRef.current || closeMode === 'hide');\n };\n wrapper.addEventListener('transitionend', onTransitionEnd);\n return () => wrapper.removeEventListener('transitionend', onTransitionEnd);\n }, [closeMode]);\n\n return (\n <section ref={ref} {...forwardedProps} className={rootClassName}>\n {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events,jsx-a11y/no-static-element-interactions */}\n <header className={`${CLASSNAME}__header`} onClick={toggleOpen}>\n {dragHandle && <div className={`${CLASSNAME}__header-drag`}>{dragHandle}</div>}\n\n <div {...headerProps} className={`${CLASSNAME}__header-content`}>\n {headerContent}\n </div>\n\n <div className={`${CLASSNAME}__header-toggle`}>\n <IconButton\n {...toggleButtonProps}\n color={color}\n emphasis={Emphasis.low}\n icon={isOpen ? mdiChevronUp : mdiChevronDown}\n aria-expanded={isOpen || 'false'}\n />\n </div>\n </header>\n\n <div className={`${CLASSNAME}__wrapper`} ref={wrapperRef}>\n {(isOpen || isChildrenVisible) && (\n <div className={`${CLASSNAME}__container`}>\n <div className={`${CLASSNAME}__content`}>{content}</div>\n\n {footer && <div className={`${CLASSNAME}__footer`}>{footer}</div>}\n </div>\n )}\n </div>\n </section>\n );\n});\nExpansionPanel.displayName = COMPONENT_NAME;\nExpansionPanel.className = CLASSNAME;\nExpansionPanel.defaultProps = DEFAULT_PROPS;\n"],"names":["COMPONENT_NAME","CLASSNAME","getRootClassName","DEFAULT_PROPS","closeMode","isDragHandle","isComponent","DragHandle","isHeader","isFooter","ExpansionPanel","forwardRef","props","ref","defaultTheme","useTheme","Theme","light","className","children","anyChildren","hasBackground","hasHeaderDivider","isOpen","label","onClose","onOpen","onToggleOpen","theme","toggleButtonProps","forwardedProps","Children","toArray","dragHandle","header","footer","content","partitionMulti","headerProps","React","isValidElement","headerContent","isEmpty","_jsx","toggleOpen","event","shouldOpen","color","dark","ColorPalette","rootClassName","classNames","handleBasicClasses","hasHeader","Boolean","isClose","isDraggable","prefix","wrapperRef","useRef","isChildrenVisible","setChildrenVisible","useState","isOpenRef","useEffect","IS_BROWSER","current","wrapper","undefined","onTransitionEnd","addEventListener","removeEventListener","_jsxs","onClick","IconButton","emphasis","Emphasis","low","icon","mdiChevronUp","mdiChevronDown","displayName","defaultProps"],"mappings":"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"}
@@ -0,0 +1,59 @@
1
+ import { f as forwardRef, c as classNames } from '../forwardRef-15f62847.js';
2
+ import { getRootClassName, handleBasicClasses } from '@lumx/core/js/utils/className';
3
+ import { u as useTheme } from '../ThemeContext-3181f000.js';
4
+ import { jsxs, jsx } from 'react/jsx-runtime';
5
+ import { Theme, ColorPalette, Size } from '@lumx/core/js/constants';
6
+ import { Icon } from './icon-b708cca4.js';
7
+ import { T as Text } from '../index-a9c5cd69.js';
8
+
9
+ const COMPONENT_NAME = 'Flag';
10
+ const CLASSNAME = getRootClassName(COMPONENT_NAME);
11
+ const DEFAULT_PROPS = {};
12
+
13
+ /**
14
+ * Flag component.
15
+ *
16
+ * @param props Component props.
17
+ * @param ref Component ref.
18
+ * @return React element.
19
+ */
20
+ const Flag = forwardRef((props, ref) => {
21
+ const defaultTheme = useTheme() || Theme.light;
22
+ const {
23
+ label,
24
+ icon,
25
+ color,
26
+ className,
27
+ theme = defaultTheme,
28
+ truncate,
29
+ ...forwardedProps
30
+ } = props;
31
+ const flagColor = color || (theme === Theme.light ? ColorPalette.dark : ColorPalette.light);
32
+ const isTruncated = !!truncate;
33
+ return /*#__PURE__*/jsxs("div", {
34
+ ...forwardedProps,
35
+ className: classNames(className, handleBasicClasses({
36
+ prefix: CLASSNAME,
37
+ color: flagColor,
38
+ isTruncated
39
+ })),
40
+ ref: ref,
41
+ children: [icon && /*#__PURE__*/jsx(Icon, {
42
+ icon: icon,
43
+ size: Size.xxs,
44
+ className: `${CLASSNAME}__icon`
45
+ }), /*#__PURE__*/jsx(Text, {
46
+ as: "span",
47
+ truncate: isTruncated,
48
+ typography: "overline",
49
+ className: `${CLASSNAME}__label`,
50
+ children: label
51
+ })]
52
+ });
53
+ });
54
+ Flag.displayName = COMPONENT_NAME;
55
+ Flag.className = CLASSNAME;
56
+ Flag.defaultProps = DEFAULT_PROPS;
57
+
58
+ export { Flag };
59
+ //# sourceMappingURL=flag-8d4a7e72.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"flag-8d4a7e72.js","sources":["../../../src/components/flag/Flag.tsx"],"sourcesContent":["import classNames from 'classnames';\n\nimport { ColorPalette, Icon, Size, Theme, Text } from '@lumx/react';\nimport { GenericProps, HasTheme } from '@lumx/react/utils/type';\nimport { getRootClassName, handleBasicClasses } from '@lumx/core/js/utils/className';\nimport { useTheme } from '@lumx/react/utils/theme/ThemeContext';\nimport { forwardRef } from '@lumx/react/utils/react/forwardRef';\n\nexport interface FlagProps extends GenericProps, HasTheme {\n /** Color of the component. */\n color?: ColorPalette;\n /** Icon to use before the label. */\n icon?: string;\n /** Text label of the flag. */\n label: React.ReactNode;\n /** Enable text truncate on overflow */\n truncate?: boolean;\n}\n\nconst COMPONENT_NAME = 'Flag';\nconst CLASSNAME = getRootClassName(COMPONENT_NAME);\nconst DEFAULT_PROPS: Partial<FlagProps> = {};\n\n/**\n * Flag component.\n *\n * @param props Component props.\n * @param ref Component ref.\n * @return React element.\n */\nexport const Flag = forwardRef<FlagProps, HTMLDivElement>((props, ref) => {\n const defaultTheme = useTheme() || Theme.light;\n const { label, icon, color, className, theme = defaultTheme, truncate, ...forwardedProps } = props;\n const flagColor = color || (theme === Theme.light ? ColorPalette.dark : ColorPalette.light);\n const isTruncated = !!truncate;\n\n return (\n <div\n {...forwardedProps}\n className={classNames(className, handleBasicClasses({ prefix: CLASSNAME, color: flagColor, isTruncated }))}\n ref={ref}\n >\n {icon && <Icon icon={icon} size={Size.xxs} className={`${CLASSNAME}__icon`} />}\n <Text as=\"span\" truncate={isTruncated} typography=\"overline\" className={`${CLASSNAME}__label`}>\n {label}\n </Text>\n </div>\n );\n});\nFlag.displayName = COMPONENT_NAME;\nFlag.className = CLASSNAME;\nFlag.defaultProps = DEFAULT_PROPS;\n"],"names":["COMPONENT_NAME","CLASSNAME","getRootClassName","DEFAULT_PROPS","Flag","forwardRef","props","ref","defaultTheme","useTheme","Theme","light","label","icon","color","className","theme","truncate","forwardedProps","flagColor","ColorPalette","dark","isTruncated","_jsxs","classNames","handleBasicClasses","prefix","children","_jsx","Icon","size","Size","xxs","Text","as","typography","displayName","defaultProps"],"mappings":";;;;;;;;AAmBA,MAAMA,cAAc,GAAG,MAAM,CAAA;AAC7B,MAAMC,SAAS,GAAGC,gBAAgB,CAACF,cAAc,CAAC,CAAA;AAClD,MAAMG,aAAiC,GAAG,EAAE,CAAA;;AAE5C;AACA;AACA;AACA;AACA;AACA;AACA;AACO,MAAMC,IAAI,GAAGC,UAAU,CAA4B,CAACC,KAAK,EAAEC,GAAG,KAAK;EACtE,MAAMC,YAAY,GAAGC,QAAQ,EAAE,IAAIC,KAAK,CAACC,KAAK,CAAA;EAC9C,MAAM;IAAEC,KAAK;IAAEC,IAAI;IAAEC,KAAK;IAAEC,SAAS;AAAEC,IAAAA,KAAK,GAAGR,YAAY;IAAES,QAAQ;IAAE,GAAGC,cAAAA;AAAe,GAAC,GAAGZ,KAAK,CAAA;AAClG,EAAA,MAAMa,SAAS,GAAGL,KAAK,KAAKE,KAAK,KAAKN,KAAK,CAACC,KAAK,GAAGS,YAAY,CAACC,IAAI,GAAGD,YAAY,CAACT,KAAK,CAAC,CAAA;AAC3F,EAAA,MAAMW,WAAW,GAAG,CAAC,CAACL,QAAQ,CAAA;AAE9B,EAAA,oBACIM,IAAA,CAAA,KAAA,EAAA;AAAA,IAAA,GACQL,cAAc;AAClBH,IAAAA,SAAS,EAAES,UAAU,CAACT,SAAS,EAAEU,kBAAkB,CAAC;AAAEC,MAAAA,MAAM,EAAEzB,SAAS;AAAEa,MAAAA,KAAK,EAAEK,SAAS;AAAEG,MAAAA,WAAAA;AAAY,KAAC,CAAC,CAAE;AAC3Gf,IAAAA,GAAG,EAAEA,GAAI;AAAAoB,IAAAA,QAAA,EAERd,CAAAA,IAAI,iBAAIe,GAAA,CAACC,IAAI,EAAA;AAAChB,MAAAA,IAAI,EAAEA,IAAK;MAACiB,IAAI,EAAEC,IAAI,CAACC,GAAI;MAACjB,SAAS,EAAE,GAAGd,SAAS,CAAA,MAAA,CAAA;AAAS,KAAE,CAAC,eAC9E2B,GAAA,CAACK,IAAI,EAAA;AAACC,MAAAA,EAAE,EAAC,MAAM;AAACjB,MAAAA,QAAQ,EAAEK,WAAY;AAACa,MAAAA,UAAU,EAAC,UAAU;MAACpB,SAAS,EAAE,CAAGd,EAAAA,SAAS,CAAU,OAAA,CAAA;AAAA0B,MAAAA,QAAA,EACzFf,KAAAA;AAAK,KACJ,CAAC,CAAA;AAAA,GACN,CAAC,CAAA;AAEd,CAAC,EAAC;AACFR,IAAI,CAACgC,WAAW,GAAGpC,cAAc,CAAA;AACjCI,IAAI,CAACW,SAAS,GAAGd,SAAS,CAAA;AAC1BG,IAAI,CAACiC,YAAY,GAAGlC,aAAa;;;;"}
@@ -0,0 +1,56 @@
1
+ import { f as forwardRef, c as classNames } from '../forwardRef-15f62847.js';
2
+ import castArray from 'lodash/castArray';
3
+ import { Orientation } from '@lumx/core/js/constants';
4
+ import { getRootClassName, handleBasicClasses } from '@lumx/core/js/utils/className';
5
+ import { jsx } from 'react/jsx-runtime';
6
+
7
+ /**
8
+ * Component display name.
9
+ */
10
+ const COMPONENT_NAME = 'FlexBox';
11
+
12
+ /**
13
+ * Component default class name and class prefix.
14
+ */
15
+ const CLASSNAME = getRootClassName(COMPONENT_NAME);
16
+
17
+ /**
18
+ * FlexBox component.
19
+ *
20
+ * @param props Component props.
21
+ * @param ref Component ref.
22
+ * @return React element.
23
+ */
24
+ const FlexBox = forwardRef((props, ref) => {
25
+ const {
26
+ as: Component = 'div',
27
+ children,
28
+ className,
29
+ fillSpace,
30
+ gap,
31
+ hAlign,
32
+ marginAuto,
33
+ noShrink,
34
+ orientation,
35
+ vAlign,
36
+ wrap,
37
+ ...forwardedProps
38
+ } = props;
39
+ return /*#__PURE__*/jsx(Component, {
40
+ ref: ref,
41
+ ...forwardedProps,
42
+ className: classNames(className, handleBasicClasses({
43
+ prefix: CLASSNAME,
44
+ orientation: orientation ?? (wrap || hAlign || vAlign ? Orientation.horizontal : null),
45
+ vAlign,
46
+ hAlign,
47
+ gap
48
+ }), wrap && `${CLASSNAME}--wrap`, fillSpace && `${CLASSNAME}--fill-space`, noShrink && `${CLASSNAME}--no-shrink`, marginAuto && castArray(marginAuto).map(align => `${CLASSNAME}--margin-auto-${align}`)),
49
+ children: children
50
+ });
51
+ });
52
+ FlexBox.displayName = COMPONENT_NAME;
53
+ FlexBox.className = CLASSNAME;
54
+
55
+ export { FlexBox };
56
+ //# sourceMappingURL=flex-box-55144e5f.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"flex-box-55144e5f.js","sources":["../../../src/components/flex-box/FlexBox.tsx"],"sourcesContent":["import { ReactNode } from 'react';\n\nimport classNames from 'classnames';\nimport castArray from 'lodash/castArray';\n\nimport { Alignment, Orientation, HorizontalAlignment, Size, VerticalAlignment } from '@lumx/core/js/constants';\nimport { GenericProps } from '@lumx/react/utils/type';\nimport { getRootClassName, handleBasicClasses } from '@lumx/core/js/utils/className';\nimport { forwardRef } from '@lumx/react/utils/react/forwardRef';\n\nexport type MarginAutoAlignment = Extract<Alignment, 'top' | 'bottom' | 'right' | 'left'>;\nexport type GapSize = Extract<Size, 'tiny' | 'regular' | 'medium' | 'big' | 'huge'>;\ntype SpaceAlignment = Extract<Alignment, 'space-between' | 'space-evenly' | 'space-around'>;\nexport type FlexVerticalAlignment = VerticalAlignment | SpaceAlignment;\nexport type FlexHorizontalAlignment = HorizontalAlignment | SpaceAlignment;\n\n/**\n * Defines the props of the component.\n */\nexport interface FlexBoxProps extends GenericProps {\n /** Customize the root element. */\n as?: React.ElementType;\n /** Children elements. */\n children?: ReactNode;\n /** Whether the \"content filling space\" is enabled or not. */\n fillSpace?: boolean;\n /** Gap space between flexbox items. */\n gap?: GapSize;\n /** Flex horizontal alignment. */\n hAlign?: FlexVerticalAlignment;\n /** Whether the \"auto margin\" is enabled all around or not. */\n marginAuto?: MarginAutoAlignment | MarginAutoAlignment[];\n /** Whether the \"content shrink\" is disabled or not. */\n noShrink?: boolean;\n /** Flex direction. */\n orientation?: Orientation;\n /** Flex vertical alignment. */\n vAlign?: FlexHorizontalAlignment;\n /** Whether the \"flex wrap\" is enabled or not. */\n wrap?: boolean;\n}\n\n/**\n * Component display name.\n */\nconst COMPONENT_NAME = 'FlexBox';\n\n/**\n * Component default class name and class prefix.\n */\nconst CLASSNAME = getRootClassName(COMPONENT_NAME);\n\n/**\n * FlexBox component.\n *\n * @param props Component props.\n * @param ref Component ref.\n * @return React element.\n */\nexport const FlexBox = forwardRef<FlexBoxProps, HTMLDivElement>((props, ref) => {\n const {\n as: Component = 'div',\n children,\n className,\n fillSpace,\n gap,\n hAlign,\n marginAuto,\n noShrink,\n orientation,\n vAlign,\n wrap,\n ...forwardedProps\n } = props;\n\n return (\n <Component\n ref={ref}\n {...forwardedProps}\n className={classNames(\n className,\n handleBasicClasses({\n prefix: CLASSNAME,\n orientation: orientation ?? (wrap || hAlign || vAlign ? Orientation.horizontal : null),\n vAlign,\n hAlign,\n gap,\n }),\n wrap && `${CLASSNAME}--wrap`,\n fillSpace && `${CLASSNAME}--fill-space`,\n noShrink && `${CLASSNAME}--no-shrink`,\n marginAuto && castArray(marginAuto).map((align) => `${CLASSNAME}--margin-auto-${align}`),\n )}\n >\n {children}\n </Component>\n );\n});\nFlexBox.displayName = COMPONENT_NAME;\nFlexBox.className = CLASSNAME;\n"],"names":["COMPONENT_NAME","CLASSNAME","getRootClassName","FlexBox","forwardRef","props","ref","as","Component","children","className","fillSpace","gap","hAlign","marginAuto","noShrink","orientation","vAlign","wrap","forwardedProps","_jsx","classNames","handleBasicClasses","prefix","Orientation","horizontal","castArray","map","align","displayName"],"mappings":";;;;;;AA0CA;AACA;AACA;AACA,MAAMA,cAAc,GAAG,SAAS,CAAA;;AAEhC;AACA;AACA;AACA,MAAMC,SAAS,GAAGC,gBAAgB,CAACF,cAAc,CAAC,CAAA;;AAElD;AACA;AACA;AACA;AACA;AACA;AACA;AACO,MAAMG,OAAO,GAAGC,UAAU,CAA+B,CAACC,KAAK,EAAEC,GAAG,KAAK;EAC5E,MAAM;IACFC,EAAE,EAAEC,SAAS,GAAG,KAAK;IACrBC,QAAQ;IACRC,SAAS;IACTC,SAAS;IACTC,GAAG;IACHC,MAAM;IACNC,UAAU;IACVC,QAAQ;IACRC,WAAW;IACXC,MAAM;IACNC,IAAI;IACJ,GAAGC,cAAAA;AACP,GAAC,GAAGd,KAAK,CAAA;EAET,oBACIe,GAAA,CAACZ,SAAS,EAAA;AACNF,IAAAA,GAAG,EAAEA,GAAI;AAAA,IAAA,GACLa,cAAc;AAClBT,IAAAA,SAAS,EAAEW,UAAU,CACjBX,SAAS,EACTY,kBAAkB,CAAC;AACfC,MAAAA,MAAM,EAAEtB,SAAS;AACjBe,MAAAA,WAAW,EAAEA,WAAW,KAAKE,IAAI,IAAIL,MAAM,IAAII,MAAM,GAAGO,WAAW,CAACC,UAAU,GAAG,IAAI,CAAC;MACtFR,MAAM;MACNJ,MAAM;AACND,MAAAA,GAAAA;AACJ,KAAC,CAAC,EACFM,IAAI,IAAI,CAAA,EAAGjB,SAAS,CAAQ,MAAA,CAAA,EAC5BU,SAAS,IAAI,GAAGV,SAAS,CAAA,YAAA,CAAc,EACvCc,QAAQ,IAAI,CAAGd,EAAAA,SAAS,CAAa,WAAA,CAAA,EACrCa,UAAU,IAAIY,SAAS,CAACZ,UAAU,CAAC,CAACa,GAAG,CAAEC,KAAK,IAAK,CAAG3B,EAAAA,SAAS,iBAAiB2B,KAAK,CAAA,CAAE,CAC3F,CAAE;AAAAnB,IAAAA,QAAA,EAEDA,QAAAA;AAAQ,GACF,CAAC,CAAA;AAEpB,CAAC,EAAC;AACFN,OAAO,CAAC0B,WAAW,GAAG7B,cAAc,CAAA;AACpCG,OAAO,CAACO,SAAS,GAAGT,SAAS;;;;"}
@@ -0,0 +1,124 @@
1
+ import React__default, { Children } from 'react';
2
+ import { f as forwardRef, c as classNames } from '../forwardRef-15f62847.js';
3
+ import isEmpty from 'lodash/isEmpty';
4
+ import noop from 'lodash/noop';
5
+ import { i as isComponentType } from '../isComponentType-e806b848.js';
6
+ import { getRootClassName } from '@lumx/core/js/utils/className';
7
+ import { p as partitionMulti } from '../partitionMulti-4daccdd5.js';
8
+ import { jsxs } from 'react/jsx-runtime';
9
+ import { Size, Orientation } from '@lumx/core/js/constants';
10
+ import { FlexBox } from './flex-box-55144e5f.js';
11
+ import pick from 'lodash/pick';
12
+
13
+ /**
14
+ * Component display name.
15
+ */
16
+ const COMPONENT_NAME = 'GenericBlock';
17
+
18
+ /**
19
+ * Component default class name and class prefix.
20
+ */
21
+ const CLASSNAME = getRootClassName(COMPONENT_NAME);
22
+
23
+ /**
24
+ * Component default props.
25
+ */
26
+ const DEFAULT_PROPS = {
27
+ gap: Size.big,
28
+ orientation: Orientation.horizontal
29
+ };
30
+ const Figure = noop.bind({});
31
+ const isFigure = isComponentType(Figure);
32
+ const Content = noop.bind({});
33
+ const isContent = isComponentType(Content);
34
+ const Actions = noop.bind({});
35
+ const isActions = isComponentType(Actions);
36
+
37
+ /**
38
+ * The GenericBlock is a layout component made of 3 sections that can be
39
+ * displayed either horizontally of vertically with the same gap between each section.
40
+ *
41
+ * The sections are:
42
+ * - `Figure` => A visual element to display before the main content.
43
+ * - `Content` => The main content displayed
44
+ * - `Actions` => One or more actions to set after the element.
45
+ *
46
+ * @see https://www.figma.com/file/lzzrQmsfaXRaOyRfoEogPZ/DS%3A-playground?node-id=1%3A4076
47
+ */
48
+ const BaseGenericBlock = forwardRef((props, ref) => {
49
+ const {
50
+ className,
51
+ figure,
52
+ figureProps,
53
+ children,
54
+ actions,
55
+ actionsProps,
56
+ gap = DEFAULT_PROPS.gap,
57
+ orientation = DEFAULT_PROPS.orientation,
58
+ contentProps,
59
+ ...forwardedProps
60
+ } = props;
61
+ const sections = React__default.useMemo(() => {
62
+ // Split children by section type
63
+ const [[figureChild], [contentChild], [actionsChild], ...otherChildren] = partitionMulti(Children.toArray(children), [isFigure, isContent, isActions]);
64
+ return {
65
+ figureChild,
66
+ figureChildProps: figureChild?.props,
67
+ contentChild,
68
+ contentChildProps: contentChild?.props,
69
+ actionsChild,
70
+ actionsChildProps: actionsChild?.props,
71
+ otherChildren: otherChildren.filter(child => !isEmpty(child))
72
+ };
73
+ }, [children]);
74
+ return /*#__PURE__*/jsxs(FlexBox, {
75
+ ref: ref,
76
+ className: classNames(className, CLASSNAME),
77
+ gap: gap,
78
+ orientation: orientation,
79
+ ...forwardedProps,
80
+ children: [(figure || sections.figureChildProps?.children) && /*#__PURE__*/jsxs(FlexBox, {
81
+ ref: sections.figureChild?.ref,
82
+ vAlign: forwardedProps.vAlign,
83
+ hAlign: forwardedProps.hAlign,
84
+ ...figureProps,
85
+ ...sections.figureChildProps,
86
+ className: classNames(figureProps?.className, sections.figureChildProps?.className, `${CLASSNAME}__figure`),
87
+ children: [figure, sections.figureChildProps?.children]
88
+ }), (sections.contentChildProps?.children || sections.otherChildren.length > 0) && /*#__PURE__*/jsxs(FlexBox, {
89
+ ref: sections.contentChild?.ref,
90
+ orientation: Orientation.vertical,
91
+ fillSpace: true,
92
+ vAlign: forwardedProps.vAlign,
93
+ hAlign: forwardedProps.hAlign,
94
+ ...contentProps,
95
+ ...sections.contentChildProps,
96
+ className: classNames(contentProps?.className, sections.contentChildProps?.className, `${CLASSNAME}__content`),
97
+ children: [sections.contentChildProps?.children, sections.otherChildren]
98
+ }), (actions || sections.actionsChildProps?.children) && /*#__PURE__*/jsxs(FlexBox, {
99
+ ref: sections.actionsChild?.ref,
100
+ vAlign: forwardedProps.vAlign,
101
+ hAlign: forwardedProps.hAlign,
102
+ ...actionsProps,
103
+ ...sections.actionsChildProps,
104
+ className: classNames(actionsProps?.className, sections.actionsChildProps?.className, `${CLASSNAME}__actions`),
105
+ children: [actions, sections.actionsChildProps?.children]
106
+ })]
107
+ });
108
+ });
109
+ BaseGenericBlock.displayName = COMPONENT_NAME;
110
+ BaseGenericBlock.className = CLASSNAME;
111
+ BaseGenericBlock.defaultProps = DEFAULT_PROPS;
112
+ const GenericBlock = Object.assign(BaseGenericBlock, {
113
+ Figure,
114
+ Content,
115
+ Actions
116
+ });
117
+
118
+ /**
119
+ * Accepted gap sizes for the generic block.
120
+ */
121
+ const GenericBlockGapSize = pick(Size, ['tiny', 'regular', 'medium', 'big', 'huge']);
122
+
123
+ export { GenericBlock, GenericBlockGapSize };
124
+ //# sourceMappingURL=generic-block-ff0509ee.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generic-block-ff0509ee.js","sources":["../../../src/components/generic-block/GenericBlock.tsx","../../../src/components/generic-block/constants.ts"],"sourcesContent":["import React, { Children, ReactElement, ReactNode } from 'react';\n\nimport classNames from 'classnames';\nimport isEmpty from 'lodash/isEmpty';\nimport noop from 'lodash/noop';\n\nimport { Comp, isComponentType } from '@lumx/react/utils/type';\nimport { getRootClassName } from '@lumx/core/js/utils/className';\nimport { partitionMulti } from '@lumx/react/utils/partitionMulti';\nimport { Orientation, Size, FlexBox, FlexBoxProps } from '@lumx/react';\nimport { GenericBlockGapSize } from '@lumx/react/components/generic-block/constants';\nimport { forwardRef } from '@lumx/react/utils/react/forwardRef';\n\nexport interface GenericBlockProps extends FlexBoxProps {\n /**\n * Component to use as visual element.\n */\n figure?: ReactNode;\n /**\n * Actions to set after the main content.\n */\n actions?: ReactNode;\n /**\n * Main content to display or sections components\n * ({@see GenericBlock.Figure}, {@see GenericBlock.Content} & {@see GenericBlock.Actions})\n */\n children: ReactNode;\n /**\n * Orientation of the 3 sections\n */\n orientation?: FlexBoxProps['orientation'];\n /**\n * Horizontal alignment.\n */\n hAlign?: FlexBoxProps['hAlign'];\n /**\n * Vertical alignment.\n */\n vAlign?: FlexBoxProps['vAlign'];\n /**\n * The props to forward to the content.\n * By default, the content will have the same alignment as wrapper.\n */\n contentProps?: Omit<FlexBoxProps, 'children'>;\n /**\n * props to forward to the actions element.\n */\n actionsProps?: Omit<FlexBoxProps, 'children'>;\n /**\n * props to forward to the figure element.\n */\n figureProps?: Omit<FlexBoxProps, 'children'>;\n /**\n * Gap space between sections.\n */\n gap?: GenericBlockGapSize;\n}\n\n/**\n * Component display name.\n */\nconst COMPONENT_NAME = 'GenericBlock';\n\n/**\n * Component default class name and class prefix.\n */\nconst CLASSNAME = getRootClassName(COMPONENT_NAME);\n\n/**\n * Component default props.\n */\nconst DEFAULT_PROPS: Partial<GenericBlockProps> = {\n gap: Size.big,\n orientation: Orientation.horizontal,\n};\n\ntype BaseGenericBlock = Comp<GenericBlockProps, HTMLDivElement>;\n\ninterface GenericBlockSectionProps extends FlexBoxProps {\n /**\n * Gap space between items.\n */\n gap?: GenericBlockGapSize;\n}\n\ninterface GenericBlock extends BaseGenericBlock {\n /**\n * Use `GenericBlock.Figure` component as children of the `GenericBlock` component as an alternative way to inject\n * the \"figure\" section of the block (instead of using `figure` and `figureProps` props).\n */\n Figure: Comp<GenericBlockSectionProps>;\n /**\n * Use `GenericBlock.Content` component as children of the `GenericBlock` component as an alternative way to inject\n * the \"content\" section of the block (instead of using `content` and `contentProps` props).\n */\n Content: Comp<GenericBlockSectionProps>;\n /**\n * Use `GenericBlock.Actions` component as children of the `GenericBlock` component as an alternative way to inject\n * the \"actions\" section of the block (instead of using `actions` and `actionsProps` props).\n */\n Actions: Comp<GenericBlockSectionProps>;\n}\n\nconst Figure = noop.bind({}) as Comp<FlexBoxProps>;\nconst isFigure = isComponentType(Figure);\n\nconst Content = noop.bind({}) as Comp<FlexBoxProps>;\nconst isContent = isComponentType(Content);\n\nconst Actions = noop.bind({}) as Comp<FlexBoxProps>;\nconst isActions = isComponentType(Actions);\n\n/**\n * The GenericBlock is a layout component made of 3 sections that can be\n * displayed either horizontally of vertically with the same gap between each section.\n *\n * The sections are:\n * - `Figure` => A visual element to display before the main content.\n * - `Content` => The main content displayed\n * - `Actions` => One or more actions to set after the element.\n *\n * @see https://www.figma.com/file/lzzrQmsfaXRaOyRfoEogPZ/DS%3A-playground?node-id=1%3A4076\n */\nconst BaseGenericBlock: BaseGenericBlock = forwardRef((props, ref) => {\n const {\n className,\n figure,\n figureProps,\n children,\n actions,\n actionsProps,\n gap = DEFAULT_PROPS.gap,\n orientation = DEFAULT_PROPS.orientation,\n contentProps,\n ...forwardedProps\n } = props;\n\n const sections = React.useMemo(() => {\n // Split children by section type\n const [[figureChild], [contentChild], [actionsChild], ...otherChildren] = partitionMulti(\n Children.toArray(children),\n [isFigure, isContent, isActions],\n );\n return {\n figureChild,\n figureChildProps: (figureChild as ReactElement)?.props,\n contentChild,\n contentChildProps: (contentChild as ReactElement)?.props,\n actionsChild,\n actionsChildProps: (actionsChild as ReactElement)?.props,\n otherChildren: otherChildren.filter((child) => !isEmpty(child)),\n };\n }, [children]);\n\n return (\n <FlexBox\n ref={ref}\n className={classNames(className, CLASSNAME)}\n gap={gap}\n orientation={orientation}\n {...forwardedProps}\n >\n {(figure || sections.figureChildProps?.children) && (\n <FlexBox\n ref={(sections.figureChild as any)?.ref}\n vAlign={forwardedProps.vAlign}\n hAlign={forwardedProps.hAlign}\n {...figureProps}\n {...sections.figureChildProps}\n className={classNames(\n figureProps?.className,\n sections.figureChildProps?.className,\n `${CLASSNAME}__figure`,\n )}\n >\n {figure}\n {sections.figureChildProps?.children}\n </FlexBox>\n )}\n\n {(sections.contentChildProps?.children || sections.otherChildren.length > 0) && (\n <FlexBox\n ref={(sections.contentChild as any)?.ref}\n orientation={Orientation.vertical}\n fillSpace\n vAlign={forwardedProps.vAlign}\n hAlign={forwardedProps.hAlign}\n {...contentProps}\n {...sections.contentChildProps}\n className={classNames(\n contentProps?.className,\n sections.contentChildProps?.className,\n `${CLASSNAME}__content`,\n )}\n >\n {sections.contentChildProps?.children}\n {sections.otherChildren}\n </FlexBox>\n )}\n\n {(actions || sections.actionsChildProps?.children) && (\n <FlexBox\n ref={(sections.actionsChild as any)?.ref}\n vAlign={forwardedProps.vAlign}\n hAlign={forwardedProps.hAlign}\n {...actionsProps}\n {...sections.actionsChildProps}\n className={classNames(\n actionsProps?.className,\n sections.actionsChildProps?.className,\n `${CLASSNAME}__actions`,\n )}\n >\n {actions}\n {sections.actionsChildProps?.children}\n </FlexBox>\n )}\n </FlexBox>\n );\n});\nBaseGenericBlock.displayName = COMPONENT_NAME;\nBaseGenericBlock.className = CLASSNAME;\nBaseGenericBlock.defaultProps = DEFAULT_PROPS;\n\nexport const GenericBlock: GenericBlock = Object.assign(BaseGenericBlock, { Figure, Content, Actions });\n","import pick from 'lodash/pick';\nimport { Size } from '@lumx/react';\nimport { ValueOf } from '@lumx/react/utils/type';\n\n/**\n * Accepted gap sizes for the generic block.\n */\nexport const GenericBlockGapSize = pick(Size, ['tiny', 'regular', 'medium', 'big', 'huge']);\nexport type GenericBlockGapSize = ValueOf<typeof GenericBlockGapSize>;\n"],"names":["COMPONENT_NAME","CLASSNAME","getRootClassName","DEFAULT_PROPS","gap","Size","big","orientation","Orientation","horizontal","Figure","noop","bind","isFigure","isComponentType","Content","isContent","Actions","isActions","BaseGenericBlock","forwardRef","props","ref","className","figure","figureProps","children","actions","actionsProps","contentProps","forwardedProps","sections","React","useMemo","figureChild","contentChild","actionsChild","otherChildren","partitionMulti","Children","toArray","figureChildProps","contentChildProps","actionsChildProps","filter","child","isEmpty","_jsxs","FlexBox","classNames","vAlign","hAlign","length","vertical","fillSpace","displayName","defaultProps","GenericBlock","Object","assign","GenericBlockGapSize","pick"],"mappings":"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"}
@@ -0,0 +1,104 @@
1
+ import { f as forwardRef, c as classNames } from '../forwardRef-15f62847.js';
2
+ import { getRootClassName, handleBasicClasses } from '@lumx/core/js/utils/className';
3
+ import { jsx } from 'react/jsx-runtime';
4
+ import { Orientation } from '@lumx/core/js/constants';
5
+
6
+ /**
7
+ * Component display name.
8
+ */
9
+ const COMPONENT_NAME$1 = 'Grid';
10
+
11
+ /**
12
+ * Component default class name and class prefix.
13
+ */
14
+ const CLASSNAME$1 = getRootClassName(COMPONENT_NAME$1);
15
+
16
+ /**
17
+ * Component default props.
18
+ */
19
+ const DEFAULT_PROPS = {
20
+ orientation: Orientation.horizontal,
21
+ wrap: 'nowrap'
22
+ };
23
+
24
+ /**
25
+ * Grid component.
26
+ *
27
+ * @param props Component props.
28
+ * @param ref Component ref.
29
+ * @return React element.
30
+ */
31
+ const Grid = forwardRef((props, ref) => {
32
+ const {
33
+ children,
34
+ className,
35
+ gutter,
36
+ hAlign,
37
+ orientation = DEFAULT_PROPS.orientation,
38
+ vAlign,
39
+ wrap = DEFAULT_PROPS.wrap,
40
+ ...forwardedProps
41
+ } = props;
42
+ return /*#__PURE__*/jsx("div", {
43
+ ref: ref,
44
+ ...forwardedProps,
45
+ className: classNames(className, `${CLASSNAME$1}-container`, {
46
+ [`${CLASSNAME$1}--h-align-${hAlign}`]: hAlign
47
+ }, {
48
+ [`${CLASSNAME$1}--v-align-${vAlign}`]: vAlign
49
+ }, handleBasicClasses({
50
+ prefix: CLASSNAME$1,
51
+ orientation,
52
+ wrap,
53
+ gutter
54
+ })),
55
+ children: children
56
+ });
57
+ });
58
+ Grid.displayName = COMPONENT_NAME$1;
59
+ Grid.className = CLASSNAME$1;
60
+ Grid.defaultProps = DEFAULT_PROPS;
61
+
62
+ /**
63
+ * Component display name.
64
+ */
65
+ const COMPONENT_NAME = 'GridItem';
66
+
67
+ /**
68
+ * Component default class name and class prefix.
69
+ */
70
+ const CLASSNAME = getRootClassName(COMPONENT_NAME);
71
+
72
+ /**
73
+ * GridItem component.
74
+ *
75
+ * @param props Component props.
76
+ * @param ref Component ref.
77
+ * @return React element.
78
+ */
79
+ const GridItem = forwardRef((props, ref) => {
80
+ const {
81
+ children,
82
+ className,
83
+ width,
84
+ align,
85
+ order,
86
+ ...forwardedProps
87
+ } = props;
88
+ return /*#__PURE__*/jsx("div", {
89
+ ref: ref,
90
+ ...forwardedProps,
91
+ className: classNames(className, handleBasicClasses({
92
+ prefix: CLASSNAME,
93
+ width,
94
+ order,
95
+ align
96
+ })),
97
+ children: children
98
+ });
99
+ });
100
+ GridItem.displayName = COMPONENT_NAME;
101
+ GridItem.className = CLASSNAME;
102
+
103
+ export { Grid, GridItem };
104
+ //# sourceMappingURL=grid-6f1b5a41.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"grid-6f1b5a41.js","sources":["../../../src/components/grid/Grid.tsx","../../../src/components/grid/GridItem.tsx"],"sourcesContent":["import classNames from 'classnames';\n\nimport { Alignment, Orientation, Size } from '@lumx/react';\nimport { GenericProps } from '@lumx/react/utils/type';\nimport { getRootClassName, handleBasicClasses } from '@lumx/core/js/utils/className';\nimport { forwardRef } from '@lumx/react/utils/react/forwardRef';\n\ntype GridGutterSize = Extract<Size, 'regular' | 'big' | 'huge'>;\n\n/**\n * Defines the props of the component.\n */\nexport interface GridProps extends GenericProps {\n /** Orientation. */\n orientation?: Orientation;\n /** Whether the children are wrapped or not. */\n wrap?: string;\n /** Vertical alignment. */\n vAlign?: Alignment;\n /** Horizontal alignment. */\n hAlign?: Alignment;\n /** Gutter size. */\n gutter?: GridGutterSize;\n /** Children */\n children?: React.ReactNode;\n}\n\n/**\n * Component display name.\n */\nconst COMPONENT_NAME = 'Grid';\n\n/**\n * Component default class name and class prefix.\n */\nconst CLASSNAME = getRootClassName(COMPONENT_NAME);\n\n/**\n * Component default props.\n */\nconst DEFAULT_PROPS: Partial<GridProps> = {\n orientation: Orientation.horizontal,\n wrap: 'nowrap',\n};\n\n/**\n * Grid component.\n *\n * @param props Component props.\n * @param ref Component ref.\n * @return React element.\n */\nexport const Grid = forwardRef<GridProps, HTMLDivElement>((props, ref) => {\n const {\n children,\n className,\n gutter,\n hAlign,\n orientation = DEFAULT_PROPS.orientation,\n vAlign,\n wrap = DEFAULT_PROPS.wrap,\n ...forwardedProps\n } = props;\n\n return (\n <div\n ref={ref}\n {...forwardedProps}\n className={classNames(\n className,\n `${CLASSNAME}-container`,\n { [`${CLASSNAME}--h-align-${hAlign}`]: hAlign },\n { [`${CLASSNAME}--v-align-${vAlign}`]: vAlign },\n handleBasicClasses({ prefix: CLASSNAME, orientation, wrap, gutter }),\n )}\n >\n {children}\n </div>\n );\n});\nGrid.displayName = COMPONENT_NAME;\nGrid.className = CLASSNAME;\nGrid.defaultProps = DEFAULT_PROPS;\n","import classNames from 'classnames';\n\nimport { Alignment } from '@lumx/react';\nimport { GenericProps } from '@lumx/react/utils/type';\nimport { getRootClassName, handleBasicClasses } from '@lumx/core/js/utils/className';\nimport { forwardRef } from '@lumx/react/utils/react/forwardRef';\n\ntype Columns = '1' | '2' | '3' | '4' | '5' | '6' | '7' | '8' | '9' | '10' | '11' | '12';\n\n/**\n * Defines the props of the component.\n */\nexport interface GridItemProps extends GenericProps {\n /** Alignment. */\n align?: Alignment;\n /** Order. */\n order?: Columns;\n /** Width. */\n width?: Columns;\n /** Children */\n children?: React.ReactNode;\n}\n\n/**\n * Component display name.\n */\nconst COMPONENT_NAME = 'GridItem';\n\n/**\n * Component default class name and class prefix.\n */\nconst CLASSNAME = getRootClassName(COMPONENT_NAME);\n\n/**\n * GridItem component.\n *\n * @param props Component props.\n * @param ref Component ref.\n * @return React element.\n */\nexport const GridItem = forwardRef<GridItemProps, HTMLDivElement>((props, ref) => {\n const { children, className, width, align, order, ...forwardedProps } = props;\n\n return (\n <div\n ref={ref}\n {...forwardedProps}\n className={classNames(className, handleBasicClasses({ prefix: CLASSNAME, width, order, align }))}\n >\n {children}\n </div>\n );\n});\nGridItem.displayName = COMPONENT_NAME;\nGridItem.className = CLASSNAME;\n"],"names":["COMPONENT_NAME","CLASSNAME","getRootClassName","DEFAULT_PROPS","orientation","Orientation","horizontal","wrap","Grid","forwardRef","props","ref","children","className","gutter","hAlign","vAlign","forwardedProps","_jsx","classNames","handleBasicClasses","prefix","displayName","defaultProps","GridItem","width","align","order"],"mappings":";;;;;AA2BA;AACA;AACA;AACA,MAAMA,gBAAc,GAAG,MAAM,CAAA;;AAE7B;AACA;AACA;AACA,MAAMC,WAAS,GAAGC,gBAAgB,CAACF,gBAAc,CAAC,CAAA;;AAElD;AACA;AACA;AACA,MAAMG,aAAiC,GAAG;EACtCC,WAAW,EAAEC,WAAW,CAACC,UAAU;AACnCC,EAAAA,IAAI,EAAE,QAAA;AACV,CAAC,CAAA;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACO,MAAMC,IAAI,GAAGC,UAAU,CAA4B,CAACC,KAAK,EAAEC,GAAG,KAAK;EACtE,MAAM;IACFC,QAAQ;IACRC,SAAS;IACTC,MAAM;IACNC,MAAM;IACNX,WAAW,GAAGD,aAAa,CAACC,WAAW;IACvCY,MAAM;IACNT,IAAI,GAAGJ,aAAa,CAACI,IAAI;IACzB,GAAGU,cAAAA;AACP,GAAC,GAAGP,KAAK,CAAA;AAET,EAAA,oBACIQ,GAAA,CAAA,KAAA,EAAA;AACIP,IAAAA,GAAG,EAAEA,GAAI;AAAA,IAAA,GACLM,cAAc;IAClBJ,SAAS,EAAEM,UAAU,CACjBN,SAAS,EACT,CAAGZ,EAAAA,WAAS,YAAY,EACxB;AAAE,MAAA,CAAC,CAAGA,EAAAA,WAAS,CAAac,UAAAA,EAAAA,MAAM,EAAE,GAAGA,MAAAA;AAAO,KAAC,EAC/C;AAAE,MAAA,CAAC,CAAGd,EAAAA,WAAS,CAAae,UAAAA,EAAAA,MAAM,EAAE,GAAGA,MAAAA;KAAQ,EAC/CI,kBAAkB,CAAC;AAAEC,MAAAA,MAAM,EAAEpB,WAAS;MAAEG,WAAW;MAAEG,IAAI;AAAEO,MAAAA,MAAAA;AAAO,KAAC,CACvE,CAAE;AAAAF,IAAAA,QAAA,EAEDA,QAAAA;AAAQ,GACR,CAAC,CAAA;AAEd,CAAC,EAAC;AACFJ,IAAI,CAACc,WAAW,GAAGtB,gBAAc,CAAA;AACjCQ,IAAI,CAACK,SAAS,GAAGZ,WAAS,CAAA;AAC1BO,IAAI,CAACe,YAAY,GAAGpB,aAAa;;AC3DjC;AACA;AACA;AACA,MAAMH,cAAc,GAAG,UAAU,CAAA;;AAEjC;AACA;AACA;AACA,MAAMC,SAAS,GAAGC,gBAAgB,CAACF,cAAc,CAAC,CAAA;;AAElD;AACA;AACA;AACA;AACA;AACA;AACA;AACO,MAAMwB,QAAQ,GAAGf,UAAU,CAAgC,CAACC,KAAK,EAAEC,GAAG,KAAK;EAC9E,MAAM;IAAEC,QAAQ;IAAEC,SAAS;IAAEY,KAAK;IAAEC,KAAK;IAAEC,KAAK;IAAE,GAAGV,cAAAA;AAAe,GAAC,GAAGP,KAAK,CAAA;AAE7E,EAAA,oBACIQ,GAAA,CAAA,KAAA,EAAA;AACIP,IAAAA,GAAG,EAAEA,GAAI;AAAA,IAAA,GACLM,cAAc;AAClBJ,IAAAA,SAAS,EAAEM,UAAU,CAACN,SAAS,EAAEO,kBAAkB,CAAC;AAAEC,MAAAA,MAAM,EAAEpB,SAAS;MAAEwB,KAAK;MAAEE,KAAK;AAAED,MAAAA,KAAAA;AAAM,KAAC,CAAC,CAAE;AAAAd,IAAAA,QAAA,EAEhGA,QAAAA;AAAQ,GACR,CAAC,CAAA;AAEd,CAAC,EAAC;AACFY,QAAQ,CAACF,WAAW,GAAGtB,cAAc,CAAA;AACrCwB,QAAQ,CAACX,SAAS,GAAGZ,SAAS;;;;"}