@lumx/react 3.20.1-alpha.5 → 3.20.1-alpha.50

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 (518) hide show
  1. package/CONTRIBUTING.md +1 -5
  2. package/README.md +0 -2
  3. package/_internal/{index.js → Cd8LPzmx.js} +78 -102
  4. package/_internal/Cd8LPzmx.js.map +1 -0
  5. package/index.d.ts +75 -390
  6. package/index.js +3960 -4706
  7. package/index.js.map +1 -1
  8. package/package.json +17 -36
  9. package/utils/index.d.ts +61 -8
  10. package/utils/index.js +1 -1
  11. package/_internal/Falsy.d.ts +0 -7
  12. package/_internal/index.js.map +0 -1
  13. package/src/components/alert-dialog/AlertDialog.stories.tsx +0 -127
  14. package/src/components/alert-dialog/AlertDialog.test.tsx +0 -35
  15. package/src/components/alert-dialog/AlertDialog.tsx +0 -189
  16. package/src/components/alert-dialog/index.ts +0 -1
  17. package/src/components/autocomplete/Autocomplete.stories.tsx +0 -75
  18. package/src/components/autocomplete/Autocomplete.test.tsx +0 -101
  19. package/src/components/autocomplete/Autocomplete.tsx +0 -294
  20. package/src/components/autocomplete/AutocompleteMultiple.stories.tsx +0 -167
  21. package/src/components/autocomplete/AutocompleteMultiple.test.tsx +0 -63
  22. package/src/components/autocomplete/AutocompleteMultiple.tsx +0 -156
  23. package/src/components/autocomplete/__mockData__/index.ts +0 -39
  24. package/src/components/autocomplete/index.ts +0 -2
  25. package/src/components/avatar/Avatar.stories.tsx +0 -121
  26. package/src/components/avatar/Avatar.test.tsx +0 -34
  27. package/src/components/avatar/Avatar.tsx +0 -114
  28. package/src/components/avatar/index.ts +0 -1
  29. package/src/components/badge/Badge.stories.tsx +0 -70
  30. package/src/components/badge/Badge.test.tsx +0 -47
  31. package/src/components/badge/Badge.tsx +0 -58
  32. package/src/components/badge/BadgeWrapper.stories.tsx +0 -76
  33. package/src/components/badge/BadgeWrapper.test.tsx +0 -49
  34. package/src/components/badge/BadgeWrapper.tsx +0 -37
  35. package/src/components/badge/index.ts +0 -2
  36. package/src/components/button/Button.stories.tsx +0 -356
  37. package/src/components/button/Button.test.tsx +0 -127
  38. package/src/components/button/Button.tsx +0 -103
  39. package/src/components/button/ButtonGroup.stories.tsx +0 -54
  40. package/src/components/button/ButtonGroup.test.tsx +0 -43
  41. package/src/components/button/ButtonGroup.tsx +0 -52
  42. package/src/components/button/ButtonRoot.tsx +0 -193
  43. package/src/components/button/IconButton.stories.tsx +0 -52
  44. package/src/components/button/IconButton.test.tsx +0 -68
  45. package/src/components/button/IconButton.tsx +0 -93
  46. package/src/components/button/index.ts +0 -4
  47. package/src/components/checkbox/Checkbox.stories.tsx +0 -64
  48. package/src/components/checkbox/Checkbox.test.tsx +0 -156
  49. package/src/components/checkbox/Checkbox.tsx +0 -164
  50. package/src/components/checkbox/index.ts +0 -1
  51. package/src/components/chip/Chip.stories.tsx +0 -166
  52. package/src/components/chip/Chip.test.tsx +0 -243
  53. package/src/components/chip/Chip.tsx +0 -168
  54. package/src/components/chip/ChipGroup.stories.tsx +0 -49
  55. package/src/components/chip/ChipGroup.test.tsx +0 -39
  56. package/src/components/chip/ChipGroup.tsx +0 -60
  57. package/src/components/chip/index.ts +0 -2
  58. package/src/components/comment-block/CommentBlock.stories.tsx +0 -92
  59. package/src/components/comment-block/CommentBlock.test.tsx +0 -29
  60. package/src/components/comment-block/CommentBlock.tsx +0 -172
  61. package/src/components/comment-block/index.ts +0 -1
  62. package/src/components/date-picker/DatePicker.stories.tsx +0 -118
  63. package/src/components/date-picker/DatePicker.test.tsx +0 -36
  64. package/src/components/date-picker/DatePicker.tsx +0 -52
  65. package/src/components/date-picker/DatePickerControlled.test.tsx +0 -93
  66. package/src/components/date-picker/DatePickerControlled.tsx +0 -259
  67. package/src/components/date-picker/DatePickerField.stories.tsx +0 -100
  68. package/src/components/date-picker/DatePickerField.test.tsx +0 -72
  69. package/src/components/date-picker/DatePickerField.tsx +0 -135
  70. package/src/components/date-picker/constants.ts +0 -11
  71. package/src/components/date-picker/index.ts +0 -4
  72. package/src/components/date-picker/types.ts +0 -28
  73. package/src/components/dialog/Dialog.stories.tsx +0 -318
  74. package/src/components/dialog/Dialog.test.tsx +0 -99
  75. package/src/components/dialog/Dialog.tsx +0 -288
  76. package/src/components/dialog/index.ts +0 -1
  77. package/src/components/divider/Divider.test.tsx +0 -53
  78. package/src/components/divider/Divider.tsx +0 -52
  79. package/src/components/divider/index.ts +0 -1
  80. package/src/components/drag-handle/DragHandle.test.tsx +0 -38
  81. package/src/components/drag-handle/DragHandle.tsx +0 -53
  82. package/src/components/drag-handle/index.ts +0 -1
  83. package/src/components/dropdown/Dropdown.stories.tsx +0 -31
  84. package/src/components/dropdown/Dropdown.test.tsx +0 -66
  85. package/src/components/dropdown/Dropdown.tsx +0 -186
  86. package/src/components/dropdown/index.ts +0 -1
  87. package/src/components/expansion-panel/ExpansionPanel.stories.tsx +0 -91
  88. package/src/components/expansion-panel/ExpansionPanel.test.tsx +0 -186
  89. package/src/components/expansion-panel/ExpansionPanel.tsx +0 -195
  90. package/src/components/expansion-panel/index.ts +0 -1
  91. package/src/components/flag/Flag.stories.tsx +0 -48
  92. package/src/components/flag/Flag.test.tsx +0 -64
  93. package/src/components/flag/Flag.tsx +0 -54
  94. package/src/components/flag/index.ts +0 -1
  95. package/src/components/flex-box/FlexBox.stories.tsx +0 -158
  96. package/src/components/flex-box/FlexBox.test.tsx +0 -25
  97. package/src/components/flex-box/FlexBox.tsx +0 -100
  98. package/src/components/flex-box/index.ts +0 -1
  99. package/src/components/generic-block/GenericBlock.stories.jsx +0 -128
  100. package/src/components/generic-block/GenericBlock.test.tsx +0 -156
  101. package/src/components/generic-block/GenericBlock.tsx +0 -225
  102. package/src/components/generic-block/constants.ts +0 -9
  103. package/src/components/generic-block/index.ts +0 -2
  104. package/src/components/grid/Grid.tsx +0 -85
  105. package/src/components/grid/GridItem.tsx +0 -57
  106. package/src/components/grid/index.ts +0 -2
  107. package/src/components/grid-column/GridColumn.stories.tsx +0 -46
  108. package/src/components/grid-column/GridColumn.test.jsx +0 -58
  109. package/src/components/grid-column/GridColumn.tsx +0 -83
  110. package/src/components/grid-column/index.ts +0 -1
  111. package/src/components/heading/Heading.stories.tsx +0 -70
  112. package/src/components/heading/Heading.test.tsx +0 -84
  113. package/src/components/heading/Heading.tsx +0 -67
  114. package/src/components/heading/HeadingLevelProvider.tsx +0 -30
  115. package/src/components/heading/constants.ts +0 -16
  116. package/src/components/heading/context.tsx +0 -13
  117. package/src/components/heading/index.ts +0 -3
  118. package/src/components/heading/useHeadingLevel.tsx +0 -8
  119. package/src/components/icon/Icon.stories.tsx +0 -47
  120. package/src/components/icon/Icon.test.tsx +0 -44
  121. package/src/components/icon/Icon.tsx +0 -24
  122. package/src/components/icon/index.ts +0 -1
  123. package/src/components/image-block/ImageBlock.stories.tsx +0 -119
  124. package/src/components/image-block/ImageBlock.test.tsx +0 -59
  125. package/src/components/image-block/ImageBlock.tsx +0 -142
  126. package/src/components/image-block/ImageCaption.tsx +0 -115
  127. package/src/components/image-block/index.ts +0 -1
  128. package/src/components/image-lightbox/ImageLightbox.stories.tsx +0 -161
  129. package/src/components/image-lightbox/ImageLightbox.test.tsx +0 -252
  130. package/src/components/image-lightbox/ImageLightbox.tsx +0 -90
  131. package/src/components/image-lightbox/constants.ts +0 -11
  132. package/src/components/image-lightbox/index.ts +0 -2
  133. package/src/components/image-lightbox/internal/ImageSlide.tsx +0 -107
  134. package/src/components/image-lightbox/internal/ImageSlideshow.tsx +0 -164
  135. package/src/components/image-lightbox/internal/useAnimateScroll.ts +0 -55
  136. package/src/components/image-lightbox/internal/usePointerZoom.ts +0 -148
  137. package/src/components/image-lightbox/types.ts +0 -50
  138. package/src/components/image-lightbox/useImageLightbox.tsx +0 -141
  139. package/src/components/inline-list/InlineList.stories.tsx +0 -78
  140. package/src/components/inline-list/InlineList.test.tsx +0 -54
  141. package/src/components/inline-list/InlineList.tsx +0 -96
  142. package/src/components/inline-list/index.ts +0 -1
  143. package/src/components/input-helper/InputHelper.stories.tsx +0 -35
  144. package/src/components/input-helper/InputHelper.test.tsx +0 -57
  145. package/src/components/input-helper/InputHelper.tsx +0 -65
  146. package/src/components/input-helper/constants.ts +0 -11
  147. package/src/components/input-helper/index.ts +0 -1
  148. package/src/components/input-label/InputLabel.stories.tsx +0 -47
  149. package/src/components/input-label/InputLabel.test.tsx +0 -61
  150. package/src/components/input-label/InputLabel.tsx +0 -69
  151. package/src/components/input-label/index.ts +0 -1
  152. package/src/components/lightbox/Lightbox.stories.tsx +0 -101
  153. package/src/components/lightbox/Lightbox.test.tsx +0 -55
  154. package/src/components/lightbox/Lightbox.tsx +0 -180
  155. package/src/components/lightbox/index.ts +0 -1
  156. package/src/components/link/Link.stories.tsx +0 -196
  157. package/src/components/link/Link.test.tsx +0 -127
  158. package/src/components/link/Link.tsx +0 -119
  159. package/src/components/link/index.ts +0 -1
  160. package/src/components/link-preview/LinkPreview.stories.tsx +0 -61
  161. package/src/components/link-preview/LinkPreview.test.tsx +0 -107
  162. package/src/components/link-preview/LinkPreview.tsx +0 -160
  163. package/src/components/link-preview/index.ts +0 -1
  164. package/src/components/list/List.stories.tsx +0 -116
  165. package/src/components/list/List.test.tsx +0 -20
  166. package/src/components/list/List.tsx +0 -104
  167. package/src/components/list/ListDivider.stories.tsx +0 -12
  168. package/src/components/list/ListDivider.test.tsx +0 -24
  169. package/src/components/list/ListDivider.tsx +0 -37
  170. package/src/components/list/ListItem.stories.tsx +0 -66
  171. package/src/components/list/ListItem.test.tsx +0 -95
  172. package/src/components/list/ListItem.tsx +0 -157
  173. package/src/components/list/ListSubheader.stories.tsx +0 -11
  174. package/src/components/list/ListSubheader.test.tsx +0 -23
  175. package/src/components/list/ListSubheader.tsx +0 -44
  176. package/src/components/list/index.ts +0 -4
  177. package/src/components/list/useInteractiveList.tsx +0 -202
  178. package/src/components/message/Message.stories.tsx +0 -72
  179. package/src/components/message/Message.test.tsx +0 -77
  180. package/src/components/message/Message.tsx +0 -100
  181. package/src/components/message/index.ts +0 -1
  182. package/src/components/mosaic/Mosaic.stories.tsx +0 -89
  183. package/src/components/mosaic/Mosaic.test.tsx +0 -79
  184. package/src/components/mosaic/Mosaic.tsx +0 -98
  185. package/src/components/mosaic/index.ts +0 -1
  186. package/src/components/navigation/Navigation.stories.tsx +0 -236
  187. package/src/components/navigation/Navigation.test.tsx +0 -67
  188. package/src/components/navigation/Navigation.tsx +0 -81
  189. package/src/components/navigation/NavigationItem.test.tsx +0 -37
  190. package/src/components/navigation/NavigationItem.tsx +0 -86
  191. package/src/components/navigation/NavigationSection.test.tsx +0 -139
  192. package/src/components/navigation/NavigationSection.tsx +0 -107
  193. package/src/components/navigation/context.tsx +0 -7
  194. package/src/components/navigation/index.ts +0 -1
  195. package/src/components/notification/Notification.test.tsx +0 -95
  196. package/src/components/notification/Notification.tsx +0 -138
  197. package/src/components/notification/Notifications.stories.tsx +0 -92
  198. package/src/components/notification/constants.ts +0 -28
  199. package/src/components/notification/index.ts +0 -1
  200. package/src/components/popover/Popover.stories.tsx +0 -264
  201. package/src/components/popover/Popover.test.tsx +0 -64
  202. package/src/components/popover/Popover.tsx +0 -201
  203. package/src/components/popover/constants.ts +0 -62
  204. package/src/components/popover/index.ts +0 -3
  205. package/src/components/popover/usePopoverStyle.tsx +0 -184
  206. package/src/components/popover/useRestoreFocusOnClose.tsx +0 -47
  207. package/src/components/popover-dialog/PopoverDialog.stories.tsx +0 -64
  208. package/src/components/popover-dialog/PopoverDialog.test.tsx +0 -140
  209. package/src/components/popover-dialog/PopoverDialog.tsx +0 -76
  210. package/src/components/popover-dialog/index.tsx +0 -1
  211. package/src/components/post-block/PostBlock.test.tsx +0 -29
  212. package/src/components/post-block/PostBlock.tsx +0 -122
  213. package/src/components/post-block/index.ts +0 -1
  214. package/src/components/progress/Progress.tsx +0 -70
  215. package/src/components/progress/ProgressCircular.stories.tsx +0 -44
  216. package/src/components/progress/ProgressCircular.test.tsx +0 -48
  217. package/src/components/progress/ProgressCircular.tsx +0 -84
  218. package/src/components/progress/ProgressLinear.stories.tsx +0 -12
  219. package/src/components/progress/ProgressLinear.test.tsx +0 -32
  220. package/src/components/progress/ProgressLinear.tsx +0 -52
  221. package/src/components/progress/index.ts +0 -3
  222. package/src/components/progress-tracker/ProgressTracker.stories.tsx +0 -145
  223. package/src/components/progress-tracker/ProgressTracker.test.tsx +0 -44
  224. package/src/components/progress-tracker/ProgressTracker.tsx +0 -87
  225. package/src/components/progress-tracker/ProgressTrackerProvider.test.tsx +0 -67
  226. package/src/components/progress-tracker/ProgressTrackerProvider.tsx +0 -67
  227. package/src/components/progress-tracker/ProgressTrackerStep.test.tsx +0 -38
  228. package/src/components/progress-tracker/ProgressTrackerStep.tsx +0 -159
  229. package/src/components/progress-tracker/ProgressTrackerStepPanel.test.tsx +0 -36
  230. package/src/components/progress-tracker/ProgressTrackerStepPanel.tsx +0 -69
  231. package/src/components/progress-tracker/index.ts +0 -4
  232. package/src/components/radio-button/RadioButton.stories.tsx +0 -71
  233. package/src/components/radio-button/RadioButton.test.tsx +0 -145
  234. package/src/components/radio-button/RadioButton.tsx +0 -143
  235. package/src/components/radio-button/RadioGroup.stories.tsx +0 -39
  236. package/src/components/radio-button/RadioGroup.test.tsx +0 -31
  237. package/src/components/radio-button/RadioGroup.tsx +0 -44
  238. package/src/components/radio-button/index.ts +0 -2
  239. package/src/components/select/Select.stories.tsx +0 -385
  240. package/src/components/select/Select.test.tsx +0 -200
  241. package/src/components/select/Select.tsx +0 -199
  242. package/src/components/select/SelectMultiple.stories.tsx +0 -315
  243. package/src/components/select/SelectMultiple.test.tsx +0 -215
  244. package/src/components/select/SelectMultiple.tsx +0 -206
  245. package/src/components/select/WithSelectContext.tsx +0 -147
  246. package/src/components/select/constants.ts +0 -55
  247. package/src/components/select/index.ts +0 -2
  248. package/src/components/side-navigation/SideNavigation.stories.tsx +0 -191
  249. package/src/components/side-navigation/SideNavigation.test.tsx +0 -39
  250. package/src/components/side-navigation/SideNavigation.tsx +0 -52
  251. package/src/components/side-navigation/SideNavigationItem.stories.tsx +0 -133
  252. package/src/components/side-navigation/SideNavigationItem.test.tsx +0 -138
  253. package/src/components/side-navigation/SideNavigationItem.tsx +0 -170
  254. package/src/components/side-navigation/index.ts +0 -2
  255. package/src/components/skeleton/SkeletonCircle.stories.tsx +0 -41
  256. package/src/components/skeleton/SkeletonCircle.test.tsx +0 -29
  257. package/src/components/skeleton/SkeletonCircle.tsx +0 -54
  258. package/src/components/skeleton/SkeletonRectangle.stories.tsx +0 -82
  259. package/src/components/skeleton/SkeletonRectangle.test.tsx +0 -29
  260. package/src/components/skeleton/SkeletonRectangle.tsx +0 -90
  261. package/src/components/skeleton/SkeletonTypography.stories.tsx +0 -21
  262. package/src/components/skeleton/SkeletonTypography.test.tsx +0 -29
  263. package/src/components/skeleton/SkeletonTypography.tsx +0 -59
  264. package/src/components/skeleton/index.ts +0 -3
  265. package/src/components/slider/Slider.stories.tsx +0 -45
  266. package/src/components/slider/Slider.test.tsx +0 -31
  267. package/src/components/slider/Slider.tsx +0 -299
  268. package/src/components/slider/index.ts +0 -2
  269. package/src/components/slideshow/Slides.tsx +0 -130
  270. package/src/components/slideshow/Slideshow.stories.tsx +0 -180
  271. package/src/components/slideshow/Slideshow.test.tsx +0 -37
  272. package/src/components/slideshow/Slideshow.tsx +0 -173
  273. package/src/components/slideshow/SlideshowControls.stories.tsx +0 -102
  274. package/src/components/slideshow/SlideshowControls.tsx +0 -243
  275. package/src/components/slideshow/SlideshowItem.tsx +0 -46
  276. package/src/components/slideshow/SlideshowItemGroup.tsx +0 -60
  277. package/src/components/slideshow/constants.ts +0 -24
  278. package/src/components/slideshow/index.ts +0 -4
  279. package/src/components/slideshow/useKeyNavigate.ts +0 -28
  280. package/src/components/slideshow/usePaginationVisibleRange.ts +0 -37
  281. package/src/components/slideshow/useSlideFocusManagement.tsx +0 -92
  282. package/src/components/slideshow/useSwipeNavigate.ts +0 -18
  283. package/src/components/switch/Switch.stories.tsx +0 -49
  284. package/src/components/switch/Switch.test.tsx +0 -146
  285. package/src/components/switch/Switch.tsx +0 -145
  286. package/src/components/switch/index.ts +0 -1
  287. package/src/components/table/Table.test.tsx +0 -31
  288. package/src/components/table/Table.tsx +0 -61
  289. package/src/components/table/TableBody.test.tsx +0 -32
  290. package/src/components/table/TableBody.tsx +0 -44
  291. package/src/components/table/TableCell.test.tsx +0 -74
  292. package/src/components/table/TableCell.tsx +0 -132
  293. package/src/components/table/TableHeader.test.tsx +0 -32
  294. package/src/components/table/TableHeader.tsx +0 -50
  295. package/src/components/table/TableRow.test.tsx +0 -42
  296. package/src/components/table/TableRow.tsx +0 -73
  297. package/src/components/table/index.ts +0 -5
  298. package/src/components/tabs/Tab.test.tsx +0 -52
  299. package/src/components/tabs/Tab.tsx +0 -133
  300. package/src/components/tabs/TabList.test.tsx +0 -51
  301. package/src/components/tabs/TabList.tsx +0 -94
  302. package/src/components/tabs/TabPanel.test.tsx +0 -39
  303. package/src/components/tabs/TabPanel.tsx +0 -69
  304. package/src/components/tabs/TabProvider.test.tsx +0 -163
  305. package/src/components/tabs/TabProvider.tsx +0 -67
  306. package/src/components/tabs/Tabs.stories.tsx +0 -170
  307. package/src/components/tabs/index.ts +0 -4
  308. package/src/components/tabs/state.ts +0 -114
  309. package/src/components/tabs/test-utils.ts +0 -39
  310. package/src/components/text/Text.stories.tsx +0 -177
  311. package/src/components/text/Text.test.tsx +0 -94
  312. package/src/components/text/Text.tsx +0 -141
  313. package/src/components/text/index.ts +0 -1
  314. package/src/components/text-field/TextField.stories.tsx +0 -180
  315. package/src/components/text-field/TextField.test.tsx +0 -299
  316. package/src/components/text-field/TextField.tsx +0 -493
  317. package/src/components/text-field/index.ts +0 -1
  318. package/src/components/thumbnail/Thumbnail.stories.tsx +0 -448
  319. package/src/components/thumbnail/Thumbnail.test.tsx +0 -66
  320. package/src/components/thumbnail/Thumbnail.tsx +0 -248
  321. package/src/components/thumbnail/index.ts +0 -3
  322. package/src/components/thumbnail/types.ts +0 -48
  323. package/src/components/thumbnail/useFocusPointStyle.test.ts +0 -92
  324. package/src/components/thumbnail/useFocusPointStyle.tsx +0 -107
  325. package/src/components/thumbnail/useImageLoad.ts +0 -40
  326. package/src/components/toolbar/Toolbar.tsx +0 -68
  327. package/src/components/toolbar/index.ts +0 -1
  328. package/src/components/tooltip/Tooltip.stories.tsx +0 -117
  329. package/src/components/tooltip/Tooltip.test.tsx +0 -411
  330. package/src/components/tooltip/Tooltip.tsx +0 -165
  331. package/src/components/tooltip/constants.ts +0 -8
  332. package/src/components/tooltip/context.tsx +0 -17
  333. package/src/components/tooltip/index.ts +0 -1
  334. package/src/components/tooltip/useInjectTooltipRef.tsx +0 -55
  335. package/src/components/tooltip/useTooltipOpen.tsx +0 -143
  336. package/src/components/uploader/Uploader.stories.tsx +0 -109
  337. package/src/components/uploader/Uploader.test.tsx +0 -148
  338. package/src/components/uploader/Uploader.tsx +0 -177
  339. package/src/components/uploader/index.ts +0 -1
  340. package/src/components/user-block/UserBlock.stories.tsx +0 -135
  341. package/src/components/user-block/UserBlock.test.tsx +0 -108
  342. package/src/components/user-block/UserBlock.tsx +0 -193
  343. package/src/components/user-block/index.ts +0 -1
  344. package/src/constants.ts +0 -27
  345. package/src/hooks/useBooleanState.tsx +0 -13
  346. package/src/hooks/useCallbackOnEscape.ts +0 -34
  347. package/src/hooks/useChipGroupNavigation.tsx +0 -75
  348. package/src/hooks/useClickAway.tsx +0 -48
  349. package/src/hooks/useDisableBodyScroll.ts +0 -28
  350. package/src/hooks/useEventCallback.tsx +0 -17
  351. package/src/hooks/useFocus.tsx +0 -21
  352. package/src/hooks/useFocusTrap.ts +0 -93
  353. package/src/hooks/useFocusWithin.ts +0 -33
  354. package/src/hooks/useId.test.tsx +0 -23
  355. package/src/hooks/useId.ts +0 -15
  356. package/src/hooks/useImageSize.ts +0 -17
  357. package/src/hooks/useInfiniteScroll.tsx +0 -60
  358. package/src/hooks/useIntersectionObserver.tsx +0 -43
  359. package/src/hooks/useInterval.tsx +0 -31
  360. package/src/hooks/useKeyboardListNavigation.tsx +0 -204
  361. package/src/hooks/useListenFocus.tsx +0 -26
  362. package/src/hooks/useOverflowTooltipLabel.tsx +0 -32
  363. package/src/hooks/usePopper.ts +0 -12
  364. package/src/hooks/usePreviousValue.ts +0 -13
  365. package/src/hooks/useRovingTabIndex.tsx +0 -90
  366. package/src/hooks/useSizeOnWindowResize.ts +0 -30
  367. package/src/hooks/useSlideshowControls.ts +0 -246
  368. package/src/hooks/useStopPropagation.ts +0 -21
  369. package/src/hooks/useTransitionVisibility.ts +0 -48
  370. package/src/index.ts +0 -63
  371. package/src/stories/controls/color.ts +0 -7
  372. package/src/stories/controls/element.ts +0 -6
  373. package/src/stories/controls/focusPoint.ts +0 -1
  374. package/src/stories/controls/icons.ts +0 -126
  375. package/src/stories/controls/image.ts +0 -84
  376. package/src/stories/controls/selectArgType.ts +0 -8
  377. package/src/stories/controls/theme.ts +0 -3
  378. package/src/stories/controls/typography.ts +0 -5
  379. package/src/stories/controls/withUndefined.ts +0 -1
  380. package/src/stories/decorators/withChromaticForceScreenSize.tsx +0 -8
  381. package/src/stories/decorators/withCombinations.tsx +0 -132
  382. package/src/stories/decorators/withNestedProps.tsx +0 -23
  383. package/src/stories/decorators/withResizableBox.tsx +0 -21
  384. package/src/stories/decorators/withThemedBackground.tsx +0 -18
  385. package/src/stories/decorators/withValueOnChange.tsx +0 -18
  386. package/src/stories/decorators/withWrapper.tsx +0 -21
  387. package/src/stories/generated/Autocomplete/Demos.stories.tsx +0 -7
  388. package/src/stories/generated/Avatar/Demos.stories.tsx +0 -7
  389. package/src/stories/generated/Badge/Demos.stories.tsx +0 -9
  390. package/src/stories/generated/Button/Demos.stories.tsx +0 -11
  391. package/src/stories/generated/Checkbox/Demos.stories.tsx +0 -6
  392. package/src/stories/generated/Chip/Demos.stories.tsx +0 -11
  393. package/src/stories/generated/CommentBlock/Demos.stories.tsx +0 -8
  394. package/src/stories/generated/DatePicker/Demos.stories.tsx +0 -8
  395. package/src/stories/generated/Dialog/Demos.stories.tsx +0 -10
  396. package/src/stories/generated/Divider/Demos.stories.tsx +0 -6
  397. package/src/stories/generated/Dropdown/Demos.stories.tsx +0 -8
  398. package/src/stories/generated/ExpansionPanel/Demos.stories.tsx +0 -9
  399. package/src/stories/generated/Flag/Demos.stories.tsx +0 -6
  400. package/src/stories/generated/GenericBlock/Demos.stories.tsx +0 -8
  401. package/src/stories/generated/Heading/Demos.stories.tsx +0 -6
  402. package/src/stories/generated/Icon/Demos.stories.tsx +0 -8
  403. package/src/stories/generated/ImageBlock/Demos.stories.tsx +0 -9
  404. package/src/stories/generated/ImageLightbox/Demos.stories.tsx +0 -6
  405. package/src/stories/generated/Lightbox/Demos.stories.tsx +0 -6
  406. package/src/stories/generated/LinkPreview/Demos.stories.tsx +0 -7
  407. package/src/stories/generated/List/Demos.stories.tsx +0 -11
  408. package/src/stories/generated/Message/Demos.stories.tsx +0 -11
  409. package/src/stories/generated/Mosaic/Demos.stories.tsx +0 -10
  410. package/src/stories/generated/Notification/Demos.stories.tsx +0 -6
  411. package/src/stories/generated/Popover/Demos.stories.tsx +0 -11
  412. package/src/stories/generated/PopoverDialog/Demos.stories.tsx +0 -6
  413. package/src/stories/generated/PostBlock/Demos.stories.tsx +0 -6
  414. package/src/stories/generated/Progress/Demos.stories.tsx +0 -7
  415. package/src/stories/generated/ProgressTracker/Demos.stories.tsx +0 -9
  416. package/src/stories/generated/RadioButton/Demos.stories.tsx +0 -6
  417. package/src/stories/generated/Select/Demos.stories.tsx +0 -14
  418. package/src/stories/generated/SideNavigation/Demos.stories.tsx +0 -10
  419. package/src/stories/generated/Skeleton/Demos.stories.tsx +0 -9
  420. package/src/stories/generated/Slider/Demos.stories.tsx +0 -9
  421. package/src/stories/generated/Slideshow/Demos.stories.tsx +0 -8
  422. package/src/stories/generated/Switch/Demos.stories.tsx +0 -6
  423. package/src/stories/generated/Table/Demos.stories.tsx +0 -7
  424. package/src/stories/generated/Tabs/Demos.stories.tsx +0 -8
  425. package/src/stories/generated/TextField/Demos.stories.tsx +0 -20
  426. package/src/stories/generated/Thumbnail/Demos.stories.tsx +0 -12
  427. package/src/stories/generated/Toolbar/Demos.stories.tsx +0 -10
  428. package/src/stories/generated/Tooltip/Demos.stories.tsx +0 -8
  429. package/src/stories/generated/Uploader/Demos.stories.tsx +0 -8
  430. package/src/stories/generated/UserBlock/Demos.stories.tsx +0 -11
  431. package/src/stories/utils/CustomLink.tsx +0 -13
  432. package/src/stories/utils/concatPath.tsx +0 -17
  433. package/src/stories/utils/disableArgTypes.ts +0 -3
  434. package/src/stories/utils/initDemoShadowDOMPortal.ts +0 -10
  435. package/src/stories/utils/lorem.ts +0 -59
  436. package/src/stories/utils/theming.tsx +0 -166
  437. package/src/stories/utils/toFlattenProps.ts +0 -28
  438. package/src/stories/utils/withCategory.ts +0 -12
  439. package/src/testing/utils/ThemeSentinel.tsx +0 -11
  440. package/src/testing/utils/commonTestsSuiteRTL.tsx +0 -193
  441. package/src/testing/utils/index.ts +0 -1
  442. package/src/testing/utils/queries.ts +0 -19
  443. package/src/untypped-modules.d.ts +0 -5
  444. package/src/utils/ClickAwayProvider/ClickAwayProvider.stories.jsx +0 -70
  445. package/src/utils/ClickAwayProvider/ClickAwayProvider.tsx +0 -69
  446. package/src/utils/ClickAwayProvider/index.ts +0 -1
  447. package/src/utils/MaterialThemeSwitcher/MaterialThemeSwitcher.tsx +0 -54
  448. package/src/utils/MaterialThemeSwitcher/index.ts +0 -1
  449. package/src/utils/Portal/Portal.test.tsx +0 -32
  450. package/src/utils/Portal/Portal.tsx +0 -33
  451. package/src/utils/Portal/PortalProvider.stories.jsx +0 -23
  452. package/src/utils/Portal/PortalProvider.test.tsx +0 -73
  453. package/src/utils/Portal/PortalProvider.tsx +0 -24
  454. package/src/utils/Portal/index.tsx +0 -2
  455. package/src/utils/browser/DOM/findImage.tsx +0 -3
  456. package/src/utils/browser/DOM/startViewTransition.ts +0 -68
  457. package/src/utils/browser/focus/constants.ts +0 -7
  458. package/src/utils/browser/focus/getFirstAndLastFocusable.test.ts +0 -134
  459. package/src/utils/browser/focus/getFirstAndLastFocusable.ts +0 -21
  460. package/src/utils/browser/focus/getFocusableElements.test.ts +0 -151
  461. package/src/utils/browser/focus/getFocusableElements.ts +0 -7
  462. package/src/utils/browser/isFocusVisible.ts +0 -9
  463. package/src/utils/browser/isHoverNotSupported.test.js +0 -24
  464. package/src/utils/browser/isHoverNotSupported.ts +0 -2
  465. package/src/utils/browser/isReducedMotion.ts +0 -6
  466. package/src/utils/date/addMonthResetDay.test.ts +0 -13
  467. package/src/utils/date/addMonthResetDay.ts +0 -9
  468. package/src/utils/date/formatDayNumber.test.ts +0 -12
  469. package/src/utils/date/formatDayNumber.ts +0 -5
  470. package/src/utils/date/getFirstDayOfWeek.test.ts +0 -20
  471. package/src/utils/date/getFirstDayOfWeek.ts +0 -59
  472. package/src/utils/date/getMonthCalendar.test.ts +0 -127
  473. package/src/utils/date/getMonthCalendar.ts +0 -69
  474. package/src/utils/date/getWeekDays.test.ts +0 -48
  475. package/src/utils/date/getWeekDays.ts +0 -34
  476. package/src/utils/date/getYearDisplayName.test.ts +0 -20
  477. package/src/utils/date/getYearDisplayName.ts +0 -12
  478. package/src/utils/date/isDateValid.test.ts +0 -15
  479. package/src/utils/date/isDateValid.ts +0 -4
  480. package/src/utils/date/isSameDay.test.ts +0 -37
  481. package/src/utils/date/isSameDay.ts +0 -11
  482. package/src/utils/disabled/DisabledStateContext.tsx +0 -29
  483. package/src/utils/disabled/DisabledStateProvider.stories.tsx +0 -94
  484. package/src/utils/disabled/index.ts +0 -2
  485. package/src/utils/disabled/useDisableStateProps.test.tsx +0 -74
  486. package/src/utils/disabled/useDisableStateProps.tsx +0 -37
  487. package/src/utils/function/makeListenerTowerContext.ts +0 -32
  488. package/src/utils/index.ts +0 -7
  489. package/src/utils/locale/getCurrentLocale.ts +0 -4
  490. package/src/utils/locale/parseLocale.test.ts +0 -17
  491. package/src/utils/locale/parseLocale.ts +0 -23
  492. package/src/utils/locale/types.ts +0 -8
  493. package/src/utils/number/clamp.ts +0 -17
  494. package/src/utils/object/isEqual.test.ts +0 -25
  495. package/src/utils/object/isEqual.ts +0 -11
  496. package/src/utils/partitionMulti.test.ts +0 -27
  497. package/src/utils/partitionMulti.ts +0 -29
  498. package/src/utils/react/OnBeforeUnmount.tsx +0 -20
  499. package/src/utils/react/flattenChildren.ts +0 -32
  500. package/src/utils/react/forwardRef.ts +0 -11
  501. package/src/utils/react/forwardRefPolymorphic.ts +0 -9
  502. package/src/utils/react/mergeRefs.ts +0 -33
  503. package/src/utils/react/renderButtonOrLink.tsx +0 -16
  504. package/src/utils/react/renderLink.tsx +0 -17
  505. package/src/utils/react/skipRender.tsx +0 -18
  506. package/src/utils/react/unref.ts +0 -7
  507. package/src/utils/react/wrapChildrenIconWithSpaces.test.tsx +0 -37
  508. package/src/utils/react/wrapChildrenIconWithSpaces.tsx +0 -22
  509. package/src/utils/theme/ThemeContext.ts +0 -16
  510. package/src/utils/theme/invertTheme.ts +0 -4
  511. package/src/utils/type/Comp.ts +0 -14
  512. package/src/utils/type/ComponentRef.ts +0 -16
  513. package/src/utils/type/HasAriaDisabled.ts +0 -6
  514. package/src/utils/type/HasPolymorphicAs.ts +0 -8
  515. package/src/utils/type/MaybeElementOrRef.ts +0 -6
  516. package/src/utils/type/index.ts +0 -8
  517. package/src/utils/type/isComponent.ts +0 -33
  518. package/src/utils/type/isComponentType.ts +0 -9
@@ -1,6 +0,0 @@
1
- /**
2
- * File generated when storybook is started. Do not edit directly!
3
- */
4
- export default { title: 'LumX components/radio-button/RadioButton Demos' };
5
-
6
- export { App as Default } from './default';
@@ -1,14 +0,0 @@
1
- /**
2
- * File generated when storybook is started. Do not edit directly!
3
- */
4
- export default { title: 'LumX components/select/Select Demos' };
5
-
6
- export { App as MultiSelectChip } from './multi-select-chip';
7
- export { App as MultiSelectSearch } from './multi-select-search';
8
- export { App as MultiSelect } from './multi-select';
9
- export { App as SelectChip } from './select-chip';
10
- export { App as SingleSelectSearch } from './single-select-search';
11
- export { App as SingleSelect } from './single-select';
12
- export { App as StateDisabled } from './state-disabled';
13
- export { App as StateInvalid } from './state-invalid';
14
- export { App as StateValid } from './state-valid';
@@ -1,10 +0,0 @@
1
- /**
2
- * File generated when storybook is started. Do not edit directly!
3
- */
4
- export default { title: 'LumX components/side-navigation/SideNavigation Demos' };
5
-
6
- export { App as Default } from './default';
7
- export { App as Emphasis } from './emphasis';
8
- export { App as Nested } from './nested';
9
- export { App as States } from './states';
10
- export { App as WithIcon } from './with-icon';
@@ -1,9 +0,0 @@
1
- /**
2
- * File generated when storybook is started. Do not edit directly!
3
- */
4
- export default { title: 'LumX components/skeleton/Skeleton Demos' };
5
-
6
- export { App as Animation } from './animation';
7
- export { App as Circle } from './circle';
8
- export { App as Rectangle } from './rectangle';
9
- export { App as Typography } from './typography';
@@ -1,9 +0,0 @@
1
- /**
2
- * File generated when storybook is started. Do not edit directly!
3
- */
4
- export default { title: 'LumX components/slider/Slider Demos' };
5
-
6
- export { App as Default } from './default';
7
- export { App as Precision } from './precision';
8
- export { App as Steps } from './steps';
9
- export { App as WithoutMinMax } from './without-min-max';
@@ -1,8 +0,0 @@
1
- /**
2
- * File generated when storybook is started. Do not edit directly!
3
- */
4
- export default { title: 'LumX components/slideshow/Slideshow Demos' };
5
-
6
- export { App as Auto } from './auto';
7
- export { App as Default } from './default';
8
- export { App as Group } from './group';
@@ -1,6 +0,0 @@
1
- /**
2
- * File generated when storybook is started. Do not edit directly!
3
- */
4
- export default { title: 'LumX components/switch/Switch Demos' };
5
-
6
- export { App as Default } from './default';
@@ -1,7 +0,0 @@
1
- /**
2
- * File generated when storybook is started. Do not edit directly!
3
- */
4
- export default { title: 'LumX components/table/Table Demos' };
5
-
6
- export { App as Clickable } from './clickable';
7
- export { App as Default } from './default';
@@ -1,8 +0,0 @@
1
- /**
2
- * File generated when storybook is started. Do not edit directly!
3
- */
4
- export default { title: 'LumX components/tabs/Tabs Demos' };
5
-
6
- export { App as Default } from './default';
7
- export { App as IconTabs } from './icon-tabs';
8
- export { App as LeftTabs } from './left-tabs';
@@ -1,20 +0,0 @@
1
- /**
2
- * File generated when storybook is started. Do not edit directly!
3
- */
4
- export default { title: 'LumX components/text-field/TextField Demos' };
5
-
6
- export { App as CharacterCounter } from './character-counter';
7
- export { App as Clearable } from './clearable';
8
- export { App as Default } from './default';
9
- export { App as Disabled } from './disabled';
10
- export { App as Helper } from './helper';
11
- export { App as Icon } from './icon';
12
- export { App as Invalid } from './invalid';
13
- export { App as Number } from './number';
14
- export { App as Placeholder } from './placeholder';
15
- export { App as Required } from './required';
16
- export { App as TextAreaInvalid } from './text-area-invalid';
17
- export { App as TextAreaValid } from './text-area-valid';
18
- export { App as TextArea } from './text-area';
19
- export { App as Valid } from './valid';
20
- export { App as WithChips } from './with-chips';
@@ -1,12 +0,0 @@
1
- /**
2
- * File generated when storybook is started. Do not edit directly!
3
- */
4
- export default { title: 'LumX components/thumbnail/Thumbnail Demos' };
5
-
6
- export { App as Combined } from './combined';
7
- export { App as ErrorFallback } from './error-fallback';
8
- export { App as Error } from './error';
9
- export { App as Loading } from './loading';
10
- export { App as Ratios } from './ratios';
11
- export { App as Sizes } from './sizes';
12
- export { App as Variants } from './variants';
@@ -1,10 +0,0 @@
1
- /**
2
- * File generated when storybook is started. Do not edit directly!
3
- */
4
- export default { title: 'LumX components/toolbar/Toolbar Demos' };
5
-
6
- export { App as Back } from './back';
7
- export { App as Default } from './default';
8
- export { App as Dialog } from './dialog';
9
- export { App as FileWidget } from './file-widget';
10
- export { App as MediaPicker } from './media-picker';
@@ -1,8 +0,0 @@
1
- /**
2
- * File generated when storybook is started. Do not edit directly!
3
- */
4
- export default { title: 'LumX components/tooltip/Tooltip Demos' };
5
-
6
- export { App as Default } from './default';
7
- export { App as Delay } from './delay';
8
- export { App as Placement } from './placement';
@@ -1,8 +0,0 @@
1
- /**
2
- * File generated when storybook is started. Do not edit directly!
3
- */
4
- export default { title: 'LumX components/uploader/Uploader Demos' };
5
-
6
- export { App as Avatar } from './avatar';
7
- export { App as Default } from './default';
8
- export { App as Thumbnail } from './thumbnail';
@@ -1,11 +0,0 @@
1
- /**
2
- * File generated when storybook is started. Do not edit directly!
3
- */
4
- export default { title: 'LumX components/user-block/UserBlock Demos' };
5
-
6
- export { App as Extended } from './extended';
7
- export { App as SizeL } from './size-l';
8
- export { App as SizeM } from './size-m';
9
- export { App as SizeS } from './size-s';
10
- export { App as SizeXs } from './size-xs';
11
- export { App as Vertical } from './vertical';
@@ -1,13 +0,0 @@
1
- import React from 'react';
2
-
3
- /**
4
- * Example custom link that can be used in linkAs props.
5
- */
6
- export const CustomLink = React.forwardRef<HTMLAnchorElement, { to: string; children?: React.ReactNode }>(
7
- ({ to = '#', children, ...props }, ref) => (
8
- <a ref={ref} href={to} data-custom-link {...props}>
9
- {children}
10
- </a>
11
- ),
12
- );
13
- CustomLink.displayName = 'CustomLink';
@@ -1,17 +0,0 @@
1
- export type PathPart = string | number;
2
- export type Path = PathPart | Array<PathPart>;
3
-
4
- /**
5
- * Concat flatten object path
6
- *
7
- * @example concatPath('foo', 'bar') // => 'foo.bar'
8
- * @example concatPath(['foo', 0]) // => 'foo[0]'
9
- * @example concatPath('foo', 0, ['bar']) // => 'foo[0].bar'
10
- */
11
- export const concatPath = (...prefix: Path[]) => {
12
- const [first, ...rest] = prefix.flat();
13
- return rest.reduce<string>((acc, part) => {
14
- if (typeof part === 'number') return `${acc}[${part}]`;
15
- return `${acc}.${part}`;
16
- }, String(first));
17
- };
@@ -1,3 +0,0 @@
1
- export function disableArgTypes(argTypes: string[]) {
2
- return Object.fromEntries(argTypes.map((argType) => [argType, { table: { disable: true } }]));
3
- }
@@ -1,10 +0,0 @@
1
- /** Init a demo shadow DOM to use as portal container */
2
- export const initDemoShadowDOMPortal = () => {
3
- const div = document.createElement('div');
4
- document.body.appendChild(div);
5
- const container = div.attachShadow({ mode: 'open' });
6
- const style = document.createElement('style');
7
- style.innerText = `button { color: red; }`;
8
- container.appendChild(style);
9
- return { container, teardown: () => div.remove() };
10
- };
@@ -1,59 +0,0 @@
1
- const tiny = `Lorem ipsum quisque tincidunt lobortis dui non auctor. Donec porta, ligula volutpat
2
- vehicula aliquet, dui sapien tempus felis, sed.`;
3
- const short = `${tiny} Ullamco laboris nisi ut aliquid ex ea
4
- commodi consequat. Inmensae subtilitatis, obscuris et malesuada fames. Me non paenitet nullum
5
- festiviorem excogitasse ad hoc. Cum ceteris in veneratione tui montes, nascetur mus. Etiam
6
- habebis sem dicantur magna mollis euismod. Quis aute iure reprehenderit in voluptate velit esse.
7
- Phasellus laoreet lorem vel dolor tempus vehicula. Ambitioni dedisse scripsisse iudicaretur.
8
- Paullum deliquit, ponderibus modulisque suis ratio utitur. Ab illo tempore, ab est sed
9
- immemorabili. Nec dubitamus multa iter quae et nos invenerat.`;
10
- const long = `${short} Tu quoque, Brute, fili mi, nihil
11
- timor populi, nihil! Morbi fringilla convallis sapien, id pulvinar odio volutpat. Cras mattis
12
- iudicium purus sit amet fermentum. Vivamus sagittis lacus vel augue laoreet rutrum faucibus.
13
- Quisque ut dolor gravida, placerat libero vel, euismod. Unam incolunt Belgae, aliam Aquitani,
14
- tertiam. Cras mattis iudicium purus sit amet fermentum. Prima luce, cum quibus mons aliud
15
- consensu ab eo. Vivamus sagittis lacus vel augue laoreet rutrum faucibus. Petierunt uti sibi
16
- concilium totius Galliae in diem certam indicere. Etiam habebis sem dicantur magna mollis
17
- euismod. A communi observantia non est recedendum. Ut enim ad minim veniam, quis nostrud
18
- exercitation. Paullum deliquit, ponderibus modulisque suis ratio utitur. Hi omnes lingua,
19
- institutis, legibus inter se differunt. Magna pars studiorum, prodita quaerimus. Quisque ut
20
- dolor gravida, placerat libero vel, euismod. Tityre, tu patulae recubans sub tegmine fagi dolor.
21
- Excepteur sint obcaecat cupiditat non proident culpa. Plura mihi bona sunt, inclinet, amari
22
- petere vellent. Quae vero auctorem tractata ab fiducia dicuntur. Inmensae subtilitatis, obscuris
23
- et malesuada fames. Quo usque tandem abutere, Catilina, patientia nostra? Nihilne te nocturnum
24
- praesidium Palati, nihil urbis vigiliae. Curabitur blandit tempus ardua ridiculus sed magna. Tu
25
- quoque, Brute, fili mi, nihil timor populi, nihil! Nihil hic munitissimus habendi senatus locus,
26
- nihil horum?Tu quoque, Brute, fili mi, nihil timor populi, nihil! Tityre, tu patulae recubans
27
- sub tegmine fagi dolor. Plura mihi bona sunt, inclinet, amari petere vellent. Ullamco laboris
28
- nisi ut aliquid ex ea commodi consequat. Pellentesque habitant morbi tristique senectus et
29
- netus. Salutantibus vitae elit libero, a pharetra augue. Lorem ipsum dolor sit amet, consectetur
30
- adipisici elit, sed eiusmod tempor incidunt ut labore et dolore magna aliqua. Petierunt uti sibi
31
- concilium totius Galliae in diem certam indicere. Contra legem facit qui id facit quod lex
32
- prohibet. Integer legentibus erat a ante historiarum dapibus. Petierunt uti sibi concilium
33
- totius Galliae in diem certam indicere. Ab illo tempore, ab est sed immemorabili. Nihil hic
34
- munitissimus habendi senatus locus, nihil horum? Quisque ut dolor gravida, placerat libero vel,
35
- euismod. Lorem ipsum dolor sit amet, consectetur adipisici elit, sed eiusmod tempor incidunt ut
36
- labore et dolore magna aliqua. Nec dubitamus multa iter quae et nos invenerat. Quam temere in
37
- vitiis, legem sancimus haerentia. Donec sed odio operae, eu vulputate felis rhoncus. Idque
38
- Caesaris facere voluntate liceret: sese habere. Paullum deliquit, ponderibus modulisque suis
39
- ratio utitur. Quae vero auctorem tractata ab fiducia dicuntur. Gallia est omnis divisa in partes
40
- tres, quarum. Etiam habebis sem dicantur magna mollis euismod. Fabio vel iudice vincam, sunt in
41
- culpa qui officia. Lorem ipsum dolor sit amet, consectetur adipisici elit, sed eiusmod tempor
42
- incidunt ut labore et dolore magna aliqua. Tu quoque, Brute, fili mi, nihil timor populi, nihil!
43
- Integer legentibus erat a ante historiarum dapibus. Tityre, tu patulae recubans sub tegmine fagi
44
- dolor. Ullamco laboris nisi ut aliquid ex ea commodi consequat. Idque Caesaris facere voluntate
45
- liceret: sese habere. Quid securi etiam tamquam eu fugiat nulla pariatur. Pellentesque habitant
46
- morbi tristique senectus et netus. Ut enim ad minim veniam, quis nostrud exercitation. Petierunt
47
- uti sibi concilium totius Galliae in diem certam indicere. Curabitur est gravida et libero vitae
48
- dictum. Qui ipsorum lingua Celtae, nostra Galli appellantur. Quam temere in vitiis, legem
49
- sancimus haerentia. Phasellus laoreet lorem vel dolor tempus vehicula. Ab illo tempore, ab est
50
- sed immemorabili. Praeterea iter est quasdam res quas ex communi. Quo usque tandem abutere,
51
- Catilina, patientia nostra? Non equidem invideo, miror magis posuere velit aliquet. Excepteur
52
- sint obcaecat cupiditat non proident culpa. Curabitur blandit tempus ardua ridiculus sed magna.
53
- Plura mihi bona sunt, inclinet, amari petere vellent. Quae vero auctorem tractata ab fiducia
54
- dicuntur. Me non paenitet nullum festiviorem excogitasse ad hoc. Unam incolunt Belgae, aliam
55
- Aquitani, tertiam.`;
56
-
57
- const types = { tiny, short, long } as const;
58
-
59
- export const loremIpsum = (type: keyof typeof types): string => types[type];
@@ -1,166 +0,0 @@
1
- import React from 'react';
2
- import { Predicate } from '@lumx/react/utils/type';
3
- import { FlexBox } from '@lumx/react';
4
-
5
- type Property = string | { value: string };
6
- interface PropertyTree {
7
- [key: string]: PropertyTree | Property;
8
- }
9
- type Entry = [key: string, value: string];
10
- type Variables = Record<string, string>;
11
-
12
- function asValue(prop?: PropertyTree | Property): string | undefined {
13
- if (typeof prop === 'string') {
14
- return prop;
15
- }
16
- if (typeof prop === 'object' && 'value' in prop) {
17
- return prop.value as string;
18
- }
19
- return undefined;
20
- }
21
-
22
- /** Convert property tree into a list of args entries ([key, value]) */
23
- function* toArgEntries(props: PropertyTree | Property, parent = ''): Iterable<Entry> {
24
- const value = asValue(props);
25
- if (value) {
26
- yield [parent, value];
27
- } else {
28
- for (const [key, prop] of Object.entries(props)) {
29
- const newParent = parent ? `${parent}-${key}` : key;
30
- yield* toArgEntries(prop, newParent);
31
- }
32
- }
33
- }
34
- function* parseVariableEntries(cssString: string, strict = false) {
35
- for (const line of cssString.split(/(?<=;)/)) {
36
- if (!line.trim()) continue;
37
- const match = line.match(/^\s*(--lumx[^:]+)\s*:\s*([^;]+);/m);
38
- if (!match) {
39
- if (strict) throw new Error(`Could not parse \`${line}\``);
40
- else continue;
41
- }
42
- const [, variableName, variableValue] = match;
43
- yield [variableName, variableValue];
44
- }
45
- }
46
-
47
- function VariableEditor({
48
- variable: [key, value],
49
- setVariable,
50
- defaultStyle,
51
- }: {
52
- variable: Entry;
53
- setVariable: (newVariable: Entry) => void;
54
- defaultStyle: Variables;
55
- }) {
56
- const onChange = React.useCallback<React.ChangeEventHandler<HTMLInputElement>>(
57
- (evt) => {
58
- setVariable([evt.target.name, evt.target.value]);
59
- },
60
- [setVariable],
61
- );
62
-
63
- return (
64
- <FlexBox as="label" orientation="horizontal" hAlign="center" style={{ whiteSpace: 'nowrap' }}>
65
- <span style={{ flexShrink: 0 }}>{key}</span>:
66
- <input
67
- name={key}
68
- onChange={onChange}
69
- style={{ border: 0, padding: 8, fieldSizing: 'content', display: 'inline' } as any}
70
- value={defaultStyle[key] === value ? '' : value}
71
- placeholder={value}
72
- />
73
- ;
74
- </FlexBox>
75
- );
76
- }
77
-
78
- function VariablesEditor({
79
- style,
80
- defaultStyle,
81
- setStyle,
82
- }: {
83
- style: Variables;
84
- defaultStyle: Variables;
85
- setStyle: (fn: (newStyle: Variables) => Variables) => void;
86
- }) {
87
- const setVariable = React.useCallback(
88
- ([key, value]: Entry) => {
89
- setStyle((prevStyle) => ({ ...prevStyle, [key]: value }));
90
- },
91
- [setStyle],
92
- );
93
- return (
94
- <details style={{ fontFamily: 'monospace' }} className="lumx-spacing-margin-vertical-huge">
95
- <summary className="lumx-typography-subtitle2">Edit variables</summary>
96
- {Object.entries(style).map((variable) => (
97
- <VariableEditor
98
- key={variable[0]}
99
- defaultStyle={defaultStyle}
100
- variable={variable}
101
- setVariable={setVariable}
102
- />
103
- ))}
104
- </details>
105
- );
106
- }
107
-
108
- const FILTER_PROPS = ['theme', 'emphasis', 'size'];
109
-
110
- export function withTheming<P extends PropertyTree>({
111
- properties,
112
- values,
113
- }: {
114
- properties?: P;
115
- values?: string | Partial<P>;
116
- }) {
117
- const initialStyle = values
118
- ? Object.fromEntries(
119
- typeof values === 'string'
120
- ? parseVariableEntries(values)
121
- : toArgEntries(values as PropertyTree, '--lumx'),
122
- )
123
- : [];
124
- const defaultStyle = Object.fromEntries(properties ? Array.from(toArgEntries(properties, '--lumx')) : []);
125
-
126
- const varNames = new Set(Object.keys(initialStyle).concat(Object.keys(defaultStyle)));
127
-
128
- function filteredStyles(args: any) {
129
- // Create predicate
130
- const filterArgs = Object.entries(args)
131
- .map(([argName, argValue]) => {
132
- if (typeof argValue === 'string' && FILTER_PROPS.includes(argName)) {
133
- return (varName: string) =>
134
- // Has the given arg with value
135
- varName.match(new RegExp(`${argName}-${argValue}`)) ||
136
- (argName === 'emphasis' &&
137
- (argValue === 'medium' || argValue === 'low') &&
138
- varName.match(/emphasis-selected/)) ||
139
- // Or does not have the arg at all
140
- !varName.match(new RegExp(`${argName}-\\w+`));
141
- }
142
- return false;
143
- })
144
- .filter(Boolean) as Array<Predicate<string>>;
145
- const styles = Object.fromEntries(
146
- Array.from(varNames.values())
147
- .map((varName) => {
148
- if (!filterArgs.every((filter) => filter(varName))) return null as any;
149
- return [varName, initialStyle[varName] || defaultStyle[varName]];
150
- })
151
- .filter(Boolean),
152
- );
153
- return () => styles;
154
- }
155
-
156
- return (Story: any, ctx: any) => {
157
- const [style, setStyle] = React.useState<Variables>(filteredStyles(ctx.args));
158
-
159
- return (
160
- <>
161
- <Story args={{ ...ctx.args, style: { ...ctx.args.style, ...style } }} />
162
- <VariablesEditor style={style} defaultStyle={defaultStyle} setStyle={setStyle} />
163
- </>
164
- );
165
- };
166
- }
@@ -1,28 +0,0 @@
1
- import castArray from 'lodash/castArray';
2
- import { concatPath } from './concatPath';
3
-
4
- type Props = Record<string, any>;
5
- type OneOrMoreProps = Props | Array<Props>;
6
-
7
- /**
8
- * Build a flat props object from the given nested props
9
- *
10
- * @example toFlattenProps({ foo: { bar: 4 } }) // => { 'foo.bar': 4 }
11
- * @example toFlattenProps({ foo: [{ bar: 4 }, { bar: 5 }] }) // => { 'foo[0].bar': 4, 'foo[0].bar': 5 }
12
- */
13
- export function toFlattenProps(props: { [prefix: string]: OneOrMoreProps }): Props {
14
- const out: Props = {};
15
- for (const [prefix, oneOrMoreProps] of Object.entries(props)) {
16
- const propsArray = castArray(oneOrMoreProps);
17
-
18
- for (let i = 0; i < propsArray.length; i += 1) {
19
- const path = Array.isArray(oneOrMoreProps) ? concatPath(prefix, i) : prefix;
20
- const subProps = propsArray[i];
21
-
22
- for (const [key, value] of Object.entries(subProps)) {
23
- out[concatPath(path, key)] = value;
24
- }
25
- }
26
- }
27
- return out;
28
- }
@@ -1,12 +0,0 @@
1
- import setWith from 'lodash/setWith';
2
-
3
- /**
4
- * Add table.category to the provided argTypes
5
- */
6
- export function withCategory(category: string, argTypes: Record<string, any>) {
7
- const out: typeof argTypes = {};
8
- for (const [key, value] of Object.entries(argTypes)) {
9
- out[key] = setWith({ ...value }, 'table.category', category);
10
- }
11
- return out;
12
- }
@@ -1,11 +0,0 @@
1
- import React from 'react';
2
- import { useTheme } from '@lumx/react/utils/theme/ThemeContext';
3
-
4
- const TEST_ID = 'theme-sentinel';
5
-
6
- /** Test component used as sentinel to detect the value of the theme context */
7
- export function ThemeSentinel() {
8
- const theme = useTheme();
9
- return <div data-testid={TEST_ID} className={`--theme-${theme}`} />;
10
- }
11
- ThemeSentinel.testId = TEST_ID;