@lumx/react 3.1.1 → 3.1.3-alpha.0

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 (500) hide show
  1. package/{dist/CONTRIBUTING.md → CONTRIBUTING.md} +0 -0
  2. package/{dist/LICENSE.md → LICENSE.md} +0 -0
  3. package/{dist/_internal → _internal}/ClickAwayProvider.js +0 -0
  4. package/{dist/_internal → _internal}/ClickAwayProvider.js.map +0 -0
  5. package/{dist/_internal → _internal}/types.d.ts +1 -1
  6. package/{dist/index.d.ts → index.d.ts} +5 -5
  7. package/{dist/index.js → index.js} +4 -4
  8. package/{dist/index.js.map → index.js.map} +1 -1
  9. package/package.json +3 -3
  10. package/src/components/expansion-panel/ExpansionPanel.stories.tsx +65 -0
  11. package/src/components/expansion-panel/ExpansionPanel.test.tsx +2 -2
  12. package/src/components/expansion-panel/ExpansionPanel.tsx +8 -8
  13. package/{dist/utils → utils}/index.d.ts +0 -0
  14. package/{dist/utils → utils}/index.js +0 -0
  15. package/{dist/utils → utils}/index.js.map +0 -0
  16. package/dist/README.md +0 -38
  17. package/dist/package.json +0 -117
  18. package/dist/src/components/alert-dialog/AlertDialog.stories.tsx +0 -196
  19. package/dist/src/components/alert-dialog/AlertDialog.test.tsx +0 -43
  20. package/dist/src/components/alert-dialog/AlertDialog.tsx +0 -185
  21. package/dist/src/components/alert-dialog/__snapshots__/AlertDialog.test.tsx.snap +0 -551
  22. package/dist/src/components/alert-dialog/index.ts +0 -1
  23. package/dist/src/components/autocomplete/Autocomplete.stories.tsx +0 -70
  24. package/dist/src/components/autocomplete/Autocomplete.test.tsx +0 -181
  25. package/dist/src/components/autocomplete/Autocomplete.tsx +0 -292
  26. package/dist/src/components/autocomplete/AutocompleteMultiple.stories.tsx +0 -170
  27. package/dist/src/components/autocomplete/AutocompleteMultiple.test.tsx +0 -94
  28. package/dist/src/components/autocomplete/AutocompleteMultiple.tsx +0 -156
  29. package/dist/src/components/autocomplete/__mockData__/index.ts +0 -34
  30. package/dist/src/components/autocomplete/__snapshots__/Autocomplete.test.tsx.snap +0 -213
  31. package/dist/src/components/autocomplete/__snapshots__/AutocompleteMultiple.test.tsx.snap +0 -88
  32. package/dist/src/components/autocomplete/index.ts +0 -2
  33. package/dist/src/components/avatar/Avatar.stories.tsx +0 -92
  34. package/dist/src/components/avatar/Avatar.test.tsx +0 -39
  35. package/dist/src/components/avatar/Avatar.tsx +0 -112
  36. package/dist/src/components/avatar/__snapshots__/Avatar.test.tsx.snap +0 -681
  37. package/dist/src/components/avatar/index.ts +0 -1
  38. package/dist/src/components/badge/Badge.stories.tsx +0 -45
  39. package/dist/src/components/badge/Badge.test.tsx +0 -91
  40. package/dist/src/components/badge/Badge.tsx +0 -55
  41. package/dist/src/components/badge/__snapshots__/Badge.test.tsx.snap +0 -11
  42. package/dist/src/components/badge/index.ts +0 -1
  43. package/dist/src/components/button/Button.stories.tsx +0 -156
  44. package/dist/src/components/button/Button.test.tsx +0 -152
  45. package/dist/src/components/button/Button.tsx +0 -81
  46. package/dist/src/components/button/ButtonGroup.test.tsx +0 -66
  47. package/dist/src/components/button/ButtonGroup.tsx +0 -46
  48. package/dist/src/components/button/ButtonRoot.test.tsx +0 -203
  49. package/dist/src/components/button/ButtonRoot.tsx +0 -190
  50. package/dist/src/components/button/IconButton.test.tsx +0 -103
  51. package/dist/src/components/button/IconButton.tsx +0 -80
  52. package/dist/src/components/button/__snapshots__/Button.test.tsx.snap +0 -96
  53. package/dist/src/components/button/__snapshots__/ButtonGroup.test.tsx.snap +0 -22
  54. package/dist/src/components/button/__snapshots__/ButtonRoot.test.tsx.snap +0 -160
  55. package/dist/src/components/button/__snapshots__/IconButton.test.tsx.snap +0 -83
  56. package/dist/src/components/button/index.ts +0 -4
  57. package/dist/src/components/checkbox/Checkbox.stories.tsx +0 -37
  58. package/dist/src/components/checkbox/Checkbox.test.tsx +0 -114
  59. package/dist/src/components/checkbox/Checkbox.tsx +0 -145
  60. package/dist/src/components/checkbox/__snapshots__/Checkbox.test.tsx.snap +0 -141
  61. package/dist/src/components/checkbox/index.ts +0 -1
  62. package/dist/src/components/chip/Chip.stories.tsx +0 -21
  63. package/dist/src/components/chip/Chip.test.tsx +0 -199
  64. package/dist/src/components/chip/Chip.tsx +0 -154
  65. package/dist/src/components/chip/ChipGroup.test.tsx +0 -29
  66. package/dist/src/components/chip/ChipGroup.tsx +0 -62
  67. package/dist/src/components/chip/__snapshots__/Chip.test.tsx.snap +0 -12
  68. package/dist/src/components/chip/__snapshots__/ChipGroup.test.tsx.snap +0 -29
  69. package/dist/src/components/chip/index.ts +0 -2
  70. package/dist/src/components/comment-block/CommentBlock.stories.tsx +0 -30
  71. package/dist/src/components/comment-block/CommentBlock.test.tsx +0 -28
  72. package/dist/src/components/comment-block/CommentBlock.tsx +0 -174
  73. package/dist/src/components/comment-block/__snapshots__/CommentBlock.test.tsx.snap +0 -92
  74. package/dist/src/components/comment-block/index.ts +0 -1
  75. package/dist/src/components/date-picker/DatePicker.test.tsx +0 -41
  76. package/dist/src/components/date-picker/DatePicker.tsx +0 -56
  77. package/dist/src/components/date-picker/DatePickerControlled.test.tsx +0 -44
  78. package/dist/src/components/date-picker/DatePickerControlled.tsx +0 -128
  79. package/dist/src/components/date-picker/DatePickerField.stories.tsx +0 -93
  80. package/dist/src/components/date-picker/DatePickerField.test.tsx +0 -47
  81. package/dist/src/components/date-picker/DatePickerField.tsx +0 -141
  82. package/dist/src/components/date-picker/__snapshots__/DatePicker.test.tsx.snap +0 -22
  83. package/dist/src/components/date-picker/__snapshots__/DatePickerControlled.test.tsx.snap +0 -597
  84. package/dist/src/components/date-picker/__snapshots__/DatePickerField.test.tsx.snap +0 -43
  85. package/dist/src/components/date-picker/constants.ts +0 -11
  86. package/dist/src/components/date-picker/index.ts +0 -4
  87. package/dist/src/components/date-picker/types.ts +0 -28
  88. package/dist/src/components/dialog/Dialog.stories.tsx +0 -426
  89. package/dist/src/components/dialog/Dialog.test.tsx +0 -93
  90. package/dist/src/components/dialog/Dialog.tsx +0 -263
  91. package/dist/src/components/dialog/__snapshots__/Dialog.test.tsx.snap +0 -960
  92. package/dist/src/components/dialog/index.ts +0 -1
  93. package/dist/src/components/divider/Divider.test.tsx +0 -93
  94. package/dist/src/components/divider/Divider.tsx +0 -51
  95. package/dist/src/components/divider/__snapshots__/Divider.test.tsx.snap +0 -9
  96. package/dist/src/components/divider/index.ts +0 -1
  97. package/dist/src/components/drag-handle/DragHandle.tsx +0 -50
  98. package/dist/src/components/drag-handle/index.ts +0 -1
  99. package/dist/src/components/dropdown/Dropdown.stories.tsx +0 -216
  100. package/dist/src/components/dropdown/Dropdown.test.tsx +0 -97
  101. package/dist/src/components/dropdown/Dropdown.tsx +0 -184
  102. package/dist/src/components/dropdown/__snapshots__/Dropdown.test.tsx.snap +0 -35
  103. package/dist/src/components/dropdown/index.ts +0 -1
  104. package/dist/src/components/expansion-panel/ExpansionPanel.test.tsx +0 -116
  105. package/dist/src/components/expansion-panel/ExpansionPanel.tsx +0 -170
  106. package/dist/src/components/expansion-panel/index.ts +0 -1
  107. package/dist/src/components/flag/Flag.stories.tsx +0 -23
  108. package/dist/src/components/flag/Flag.test.tsx +0 -86
  109. package/dist/src/components/flag/Flag.tsx +0 -47
  110. package/dist/src/components/flag/__snapshots__/Flag.test.tsx.snap +0 -133
  111. package/dist/src/components/flag/index.ts +0 -1
  112. package/dist/src/components/flex-box/FlexBox.stories.tsx +0 -245
  113. package/dist/src/components/flex-box/FlexBox.test.tsx +0 -65
  114. package/dist/src/components/flex-box/FlexBox.tsx +0 -98
  115. package/dist/src/components/flex-box/__snapshots__/FlexBox.test.tsx.snap +0 -492
  116. package/dist/src/components/flex-box/index.ts +0 -1
  117. package/dist/src/components/generic-block/GenericBlock.stories.jsx +0 -128
  118. package/dist/src/components/generic-block/GenericBlock.test.tsx +0 -152
  119. package/dist/src/components/generic-block/GenericBlock.tsx +0 -222
  120. package/dist/src/components/generic-block/constants.ts +0 -9
  121. package/dist/src/components/generic-block/index.ts +0 -2
  122. package/dist/src/components/grid/Grid.tsx +0 -73
  123. package/dist/src/components/grid/GridItem.tsx +0 -54
  124. package/dist/src/components/grid/index.ts +0 -2
  125. package/dist/src/components/grid-column/GridColumn.stories.jsx +0 -56
  126. package/dist/src/components/grid-column/GridColumn.test.jsx +0 -58
  127. package/dist/src/components/grid-column/GridColumn.tsx +0 -90
  128. package/dist/src/components/grid-column/index.ts +0 -1
  129. package/dist/src/components/heading/Heading.stories.tsx +0 -108
  130. package/dist/src/components/heading/Heading.test.tsx +0 -82
  131. package/dist/src/components/heading/Heading.tsx +0 -63
  132. package/dist/src/components/heading/HeadingLevelProvider.tsx +0 -30
  133. package/dist/src/components/heading/constants.ts +0 -16
  134. package/dist/src/components/heading/context.tsx +0 -13
  135. package/dist/src/components/heading/index.ts +0 -3
  136. package/dist/src/components/heading/useHeadingLevel.tsx +0 -8
  137. package/dist/src/components/icon/Icon.stories.tsx +0 -76
  138. package/dist/src/components/icon/Icon.test.tsx +0 -102
  139. package/dist/src/components/icon/Icon.tsx +0 -121
  140. package/dist/src/components/icon/__snapshots__/Icon.test.tsx.snap +0 -49
  141. package/dist/src/components/icon/index.ts +0 -1
  142. package/dist/src/components/image-block/ImageBlock.stories.tsx +0 -52
  143. package/dist/src/components/image-block/ImageBlock.test.tsx +0 -28
  144. package/dist/src/components/image-block/ImageBlock.tsx +0 -151
  145. package/dist/src/components/image-block/__snapshots__/ImageBlock.test.tsx.snap +0 -64
  146. package/dist/src/components/image-block/index.ts +0 -1
  147. package/dist/src/components/index.ts +0 -176
  148. package/dist/src/components/inline-list/InlineList.stories.tsx +0 -40
  149. package/dist/src/components/inline-list/InlineList.test.tsx +0 -41
  150. package/dist/src/components/inline-list/InlineList.tsx +0 -82
  151. package/dist/src/components/inline-list/index.ts +0 -1
  152. package/dist/src/components/input-helper/InputHelper.stories.tsx +0 -29
  153. package/dist/src/components/input-helper/InputHelper.test.tsx +0 -107
  154. package/dist/src/components/input-helper/InputHelper.tsx +0 -61
  155. package/dist/src/components/input-helper/__snapshots__/InputHelper.test.tsx.snap +0 -9
  156. package/dist/src/components/input-helper/constants.ts +0 -11
  157. package/dist/src/components/input-helper/index.ts +0 -1
  158. package/dist/src/components/input-label/InputLabel.stories.tsx +0 -15
  159. package/dist/src/components/input-label/InputLabel.test.tsx +0 -86
  160. package/dist/src/components/input-label/InputLabel.tsx +0 -59
  161. package/dist/src/components/input-label/__snapshots__/InputLabel.test.tsx.snap +0 -10
  162. package/dist/src/components/input-label/index.ts +0 -1
  163. package/dist/src/components/lightbox/Lightbox.stories.tsx +0 -83
  164. package/dist/src/components/lightbox/Lightbox.test.tsx +0 -30
  165. package/dist/src/components/lightbox/Lightbox.tsx +0 -153
  166. package/dist/src/components/lightbox/__snapshots__/Lightbox.test.tsx.snap +0 -194
  167. package/dist/src/components/lightbox/index.ts +0 -1
  168. package/dist/src/components/link/Link.stories.tsx +0 -141
  169. package/dist/src/components/link/Link.test.tsx +0 -60
  170. package/dist/src/components/link/Link.tsx +0 -156
  171. package/dist/src/components/link/__snapshots__/Link.test.tsx.snap +0 -29
  172. package/dist/src/components/link/index.ts +0 -1
  173. package/dist/src/components/link-preview/LinkPreview.stories.tsx +0 -88
  174. package/dist/src/components/link-preview/LinkPreview.test.tsx +0 -102
  175. package/dist/src/components/link-preview/LinkPreview.tsx +0 -158
  176. package/dist/src/components/link-preview/index.ts +0 -1
  177. package/dist/src/components/list/List.stories.tsx +0 -141
  178. package/dist/src/components/list/List.test.tsx +0 -29
  179. package/dist/src/components/list/List.tsx +0 -94
  180. package/dist/src/components/list/ListDivider.stories.tsx +0 -7
  181. package/dist/src/components/list/ListDivider.test.tsx +0 -29
  182. package/dist/src/components/list/ListDivider.tsx +0 -42
  183. package/dist/src/components/list/ListItem.stories.tsx +0 -62
  184. package/dist/src/components/list/ListItem.test.tsx +0 -29
  185. package/dist/src/components/list/ListItem.tsx +0 -154
  186. package/dist/src/components/list/ListSubheader.stories.tsx +0 -8
  187. package/dist/src/components/list/ListSubheader.test.tsx +0 -29
  188. package/dist/src/components/list/ListSubheader.tsx +0 -43
  189. package/dist/src/components/list/__snapshots__/List.test.tsx.snap +0 -360
  190. package/dist/src/components/list/__snapshots__/ListDivider.test.tsx.snap +0 -7
  191. package/dist/src/components/list/__snapshots__/ListItem.test.tsx.snap +0 -160
  192. package/dist/src/components/list/__snapshots__/ListSubheader.test.tsx.snap +0 -9
  193. package/dist/src/components/list/index.ts +0 -4
  194. package/dist/src/components/list/useInteractiveList.tsx +0 -202
  195. package/dist/src/components/message/Message.stories.tsx +0 -27
  196. package/dist/src/components/message/Message.test.tsx +0 -76
  197. package/dist/src/components/message/Message.tsx +0 -74
  198. package/dist/src/components/message/__snapshots__/Message.test.tsx.snap +0 -15
  199. package/dist/src/components/message/index.ts +0 -1
  200. package/dist/src/components/mosaic/Mosaic.stories.tsx +0 -85
  201. package/dist/src/components/mosaic/Mosaic.test.tsx +0 -120
  202. package/dist/src/components/mosaic/Mosaic.tsx +0 -95
  203. package/dist/src/components/mosaic/__snapshots__/Mosaic.test.tsx.snap +0 -357
  204. package/dist/src/components/mosaic/index.ts +0 -1
  205. package/dist/src/components/notification/Notification.test.tsx +0 -108
  206. package/dist/src/components/notification/Notification.tsx +0 -130
  207. package/dist/src/components/notification/Notifications.stories.tsx +0 -77
  208. package/dist/src/components/notification/__snapshots__/Notification.test.tsx.snap +0 -34
  209. package/dist/src/components/notification/constants.ts +0 -28
  210. package/dist/src/components/notification/index.ts +0 -1
  211. package/dist/src/components/popover/Popover.stories.tsx +0 -386
  212. package/dist/src/components/popover/Popover.test.tsx +0 -30
  213. package/dist/src/components/popover/Popover.tsx +0 -382
  214. package/dist/src/components/popover/__snapshots__/Popover.test.tsx.snap +0 -343
  215. package/dist/src/components/popover/index.ts +0 -1
  216. package/dist/src/components/popover-dialog/PopoverDialog.stories.tsx +0 -75
  217. package/dist/src/components/popover-dialog/PopoverDialog.test.tsx +0 -65
  218. package/dist/src/components/popover-dialog/PopoverDialog.tsx +0 -65
  219. package/dist/src/components/popover-dialog/index.tsx +0 -1
  220. package/dist/src/components/post-block/PostBlock.test.tsx +0 -28
  221. package/dist/src/components/post-block/PostBlock.tsx +0 -123
  222. package/dist/src/components/post-block/__snapshots__/PostBlock.test.tsx.snap +0 -139
  223. package/dist/src/components/post-block/index.ts +0 -1
  224. package/dist/src/components/progress/Progress.tsx +0 -68
  225. package/dist/src/components/progress/ProgressCircular.stories.tsx +0 -18
  226. package/dist/src/components/progress/ProgressCircular.test.tsx +0 -49
  227. package/dist/src/components/progress/ProgressCircular.tsx +0 -68
  228. package/dist/src/components/progress/ProgressLinear.stories.tsx +0 -8
  229. package/dist/src/components/progress/ProgressLinear.test.tsx +0 -37
  230. package/dist/src/components/progress/ProgressLinear.tsx +0 -52
  231. package/dist/src/components/progress/index.ts +0 -3
  232. package/dist/src/components/progress-tracker/ProgressTracker.stories.tsx +0 -145
  233. package/dist/src/components/progress-tracker/ProgressTracker.test.tsx +0 -57
  234. package/dist/src/components/progress-tracker/ProgressTracker.tsx +0 -89
  235. package/dist/src/components/progress-tracker/ProgressTrackerProvider.test.tsx +0 -42
  236. package/dist/src/components/progress-tracker/ProgressTrackerProvider.tsx +0 -66
  237. package/dist/src/components/progress-tracker/ProgressTrackerStep.test.tsx +0 -128
  238. package/dist/src/components/progress-tracker/ProgressTrackerStep.tsx +0 -159
  239. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.test.tsx +0 -73
  240. package/dist/src/components/progress-tracker/ProgressTrackerStepPanel.tsx +0 -67
  241. package/dist/src/components/progress-tracker/__snapshots__/ProgressTracker.test.tsx.snap +0 -41
  242. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStep.test.tsx.snap +0 -141
  243. package/dist/src/components/progress-tracker/__snapshots__/ProgressTrackerStepPanel.test.tsx.snap +0 -25
  244. package/dist/src/components/progress-tracker/index.ts +0 -4
  245. package/dist/src/components/radio-button/RadioButton.stories.tsx +0 -28
  246. package/dist/src/components/radio-button/RadioButton.test.tsx +0 -123
  247. package/dist/src/components/radio-button/RadioButton.tsx +0 -141
  248. package/dist/src/components/radio-button/RadioGroup.stories.tsx +0 -42
  249. package/dist/src/components/radio-button/RadioGroup.test.tsx +0 -77
  250. package/dist/src/components/radio-button/RadioGroup.tsx +0 -52
  251. package/dist/src/components/radio-button/__snapshots__/RadioButton.test.tsx.snap +0 -113
  252. package/dist/src/components/radio-button/__snapshots__/RadioGroup.test.tsx.snap +0 -26
  253. package/dist/src/components/radio-button/index.ts +0 -2
  254. package/dist/src/components/select/Select.stories.tsx +0 -399
  255. package/dist/src/components/select/Select.test.tsx +0 -359
  256. package/dist/src/components/select/Select.tsx +0 -193
  257. package/dist/src/components/select/SelectMultiple.stories.tsx +0 -227
  258. package/dist/src/components/select/SelectMultiple.test.tsx +0 -405
  259. package/dist/src/components/select/SelectMultiple.tsx +0 -198
  260. package/dist/src/components/select/WithSelectContext.tsx +0 -143
  261. package/dist/src/components/select/__snapshots__/Select.test.tsx.snap +0 -43
  262. package/dist/src/components/select/__snapshots__/SelectMultiple.test.tsx.snap +0 -87
  263. package/dist/src/components/select/constants.ts +0 -53
  264. package/dist/src/components/select/index.ts +0 -2
  265. package/dist/src/components/side-navigation/SideNavigation.stories.tsx +0 -191
  266. package/dist/src/components/side-navigation/SideNavigation.test.tsx +0 -52
  267. package/dist/src/components/side-navigation/SideNavigation.tsx +0 -54
  268. package/dist/src/components/side-navigation/SideNavigationItem.test.tsx +0 -175
  269. package/dist/src/components/side-navigation/SideNavigationItem.tsx +0 -162
  270. package/dist/src/components/side-navigation/__snapshots__/SideNavigation.test.tsx.snap +0 -7
  271. package/dist/src/components/side-navigation/__snapshots__/SideNavigationItem.test.tsx.snap +0 -30
  272. package/dist/src/components/side-navigation/index.ts +0 -2
  273. package/dist/src/components/skeleton/SkeletonCircle.stories.tsx +0 -25
  274. package/dist/src/components/skeleton/SkeletonCircle.test.tsx +0 -28
  275. package/dist/src/components/skeleton/SkeletonCircle.tsx +0 -52
  276. package/dist/src/components/skeleton/SkeletonRectangle.stories.tsx +0 -107
  277. package/dist/src/components/skeleton/SkeletonRectangle.test.tsx +0 -28
  278. package/dist/src/components/skeleton/SkeletonRectangle.tsx +0 -78
  279. package/dist/src/components/skeleton/SkeletonTypography.stories.tsx +0 -26
  280. package/dist/src/components/skeleton/SkeletonTypography.test.tsx +0 -28
  281. package/dist/src/components/skeleton/SkeletonTypography.tsx +0 -57
  282. package/dist/src/components/skeleton/__snapshots__/SkeletonCircle.test.tsx.snap +0 -54
  283. package/dist/src/components/skeleton/__snapshots__/SkeletonRectangle.test.tsx.snap +0 -177
  284. package/dist/src/components/skeleton/__snapshots__/SkeletonTypography.test.tsx.snap +0 -174
  285. package/dist/src/components/skeleton/index.ts +0 -3
  286. package/dist/src/components/slider/Slider.stories.tsx +0 -29
  287. package/dist/src/components/slider/Slider.test.tsx +0 -31
  288. package/dist/src/components/slider/Slider.tsx +0 -299
  289. package/dist/src/components/slider/__snapshots__/Slider.test.tsx.snap +0 -122
  290. package/dist/src/components/slider/index.ts +0 -2
  291. package/dist/src/components/slideshow/Slides.tsx +0 -124
  292. package/dist/src/components/slideshow/Slideshow.stories.tsx +0 -212
  293. package/dist/src/components/slideshow/Slideshow.test.tsx +0 -39
  294. package/dist/src/components/slideshow/Slideshow.tsx +0 -170
  295. package/dist/src/components/slideshow/SlideshowControls.stories.tsx +0 -112
  296. package/dist/src/components/slideshow/SlideshowControls.tsx +0 -241
  297. package/dist/src/components/slideshow/SlideshowItem.tsx +0 -52
  298. package/dist/src/components/slideshow/SlideshowItemGroup.tsx +0 -64
  299. package/dist/src/components/slideshow/__snapshots__/Slideshow.test.tsx.snap +0 -157
  300. package/dist/src/components/slideshow/constants.ts +0 -24
  301. package/dist/src/components/slideshow/index.ts +0 -4
  302. package/dist/src/components/slideshow/useKeyNavigate.ts +0 -28
  303. package/dist/src/components/slideshow/usePaginationVisibleRange.ts +0 -37
  304. package/dist/src/components/slideshow/useSlideFocusManagement.tsx +0 -92
  305. package/dist/src/components/slideshow/useSwipeNavigate.ts +0 -18
  306. package/dist/src/components/switch/Switch.stories.tsx +0 -36
  307. package/dist/src/components/switch/Switch.test.tsx +0 -189
  308. package/dist/src/components/switch/Switch.tsx +0 -141
  309. package/dist/src/components/switch/__snapshots__/Switch.test.tsx.snap +0 -179
  310. package/dist/src/components/switch/index.ts +0 -1
  311. package/dist/src/components/table/Table.test.tsx +0 -28
  312. package/dist/src/components/table/Table.tsx +0 -59
  313. package/dist/src/components/table/TableBody.test.tsx +0 -22
  314. package/dist/src/components/table/TableBody.tsx +0 -44
  315. package/dist/src/components/table/TableCell.test.tsx +0 -23
  316. package/dist/src/components/table/TableCell.tsx +0 -125
  317. package/dist/src/components/table/TableHeader.test.tsx +0 -22
  318. package/dist/src/components/table/TableHeader.tsx +0 -50
  319. package/dist/src/components/table/TableRow.test.tsx +0 -22
  320. package/dist/src/components/table/TableRow.tsx +0 -68
  321. package/dist/src/components/table/__snapshots__/Table.test.tsx.snap +0 -263
  322. package/dist/src/components/table/index.ts +0 -5
  323. package/dist/src/components/tabs/Tab.test.tsx +0 -116
  324. package/dist/src/components/tabs/Tab.tsx +0 -120
  325. package/dist/src/components/tabs/TabList.test.tsx +0 -80
  326. package/dist/src/components/tabs/TabList.tsx +0 -82
  327. package/dist/src/components/tabs/TabPanel.test.tsx +0 -74
  328. package/dist/src/components/tabs/TabPanel.tsx +0 -65
  329. package/dist/src/components/tabs/TabProvider.test.tsx +0 -42
  330. package/dist/src/components/tabs/TabProvider.tsx +0 -59
  331. package/dist/src/components/tabs/Tabs.stories.tsx +0 -134
  332. package/dist/src/components/tabs/__snapshots__/Tab.test.tsx.snap +0 -62
  333. package/dist/src/components/tabs/__snapshots__/TabList.test.tsx.snap +0 -22
  334. package/dist/src/components/tabs/__snapshots__/TabPanel.test.tsx.snap +0 -25
  335. package/dist/src/components/tabs/index.ts +0 -4
  336. package/dist/src/components/tabs/state.ts +0 -116
  337. package/dist/src/components/tabs/test.mocks.ts +0 -33
  338. package/dist/src/components/text/Text.stories.jsx +0 -75
  339. package/dist/src/components/text/Text.test.tsx +0 -108
  340. package/dist/src/components/text/Text.tsx +0 -121
  341. package/dist/src/components/text/index.ts +0 -1
  342. package/dist/src/components/text-field/TextField.stories.tsx +0 -169
  343. package/dist/src/components/text-field/TextField.test.tsx +0 -171
  344. package/dist/src/components/text-field/TextField.tsx +0 -432
  345. package/dist/src/components/text-field/__snapshots__/TextField.test.tsx.snap +0 -42
  346. package/dist/src/components/text-field/index.ts +0 -1
  347. package/dist/src/components/thumbnail/Thumbnail.stories.tsx +0 -510
  348. package/dist/src/components/thumbnail/Thumbnail.test.tsx +0 -46
  349. package/dist/src/components/thumbnail/Thumbnail.tsx +0 -222
  350. package/dist/src/components/thumbnail/__snapshots__/Thumbnail.test.tsx.snap +0 -130
  351. package/dist/src/components/thumbnail/index.ts +0 -3
  352. package/dist/src/components/thumbnail/types.ts +0 -39
  353. package/dist/src/components/thumbnail/useFocusPointStyle.test.ts +0 -92
  354. package/dist/src/components/thumbnail/useFocusPointStyle.tsx +0 -111
  355. package/dist/src/components/thumbnail/useImageLoad.ts +0 -40
  356. package/dist/src/components/toolbar/Toolbar.tsx +0 -67
  357. package/dist/src/components/toolbar/index.ts +0 -1
  358. package/dist/src/components/tooltip/Tooltip.stories.tsx +0 -172
  359. package/dist/src/components/tooltip/Tooltip.test.tsx +0 -105
  360. package/dist/src/components/tooltip/Tooltip.tsx +0 -122
  361. package/dist/src/components/tooltip/__snapshots__/Tooltip.test.tsx.snap +0 -233
  362. package/dist/src/components/tooltip/index.ts +0 -1
  363. package/dist/src/components/tooltip/useInjectTooltipRef.tsx +0 -44
  364. package/dist/src/components/tooltip/useTooltipOpen.tsx +0 -113
  365. package/dist/src/components/uploader/Uploader.test.tsx +0 -87
  366. package/dist/src/components/uploader/Uploader.tsx +0 -105
  367. package/dist/src/components/uploader/__snapshots__/Uploader.test.tsx.snap +0 -14
  368. package/dist/src/components/uploader/index.ts +0 -1
  369. package/dist/src/components/user-block/UserBlock.stories.tsx +0 -76
  370. package/dist/src/components/user-block/UserBlock.test.tsx +0 -38
  371. package/dist/src/components/user-block/UserBlock.tsx +0 -179
  372. package/dist/src/components/user-block/__snapshots__/UserBlock.test.tsx.snap +0 -362
  373. package/dist/src/components/user-block/index.ts +0 -1
  374. package/dist/src/constants.ts +0 -17
  375. package/dist/src/hooks/useBooleanState.tsx +0 -13
  376. package/dist/src/hooks/useCallbackOnEscape.ts +0 -34
  377. package/dist/src/hooks/useChipGroupNavigation.tsx +0 -75
  378. package/dist/src/hooks/useClickAway.tsx +0 -47
  379. package/dist/src/hooks/useDisableBodyScroll.ts +0 -28
  380. package/dist/src/hooks/useEventCallback.tsx +0 -17
  381. package/dist/src/hooks/useFocus.tsx +0 -21
  382. package/dist/src/hooks/useFocusTrap.ts +0 -85
  383. package/dist/src/hooks/useFocusWithin.ts +0 -33
  384. package/dist/src/hooks/useInfiniteScroll.tsx +0 -60
  385. package/dist/src/hooks/useIntersectionObserver.tsx +0 -43
  386. package/dist/src/hooks/useInterval.tsx +0 -31
  387. package/dist/src/hooks/useKeyboardListNavigation.tsx +0 -204
  388. package/dist/src/hooks/useListenFocus.tsx +0 -26
  389. package/dist/src/hooks/useOnResize.ts +0 -41
  390. package/dist/src/hooks/useRovingTabIndex.tsx +0 -90
  391. package/dist/src/hooks/useSlideshowControls.ts +0 -243
  392. package/dist/src/hooks/useStopPropagation.ts +0 -21
  393. package/dist/src/hooks/useTransitionVisibility.ts +0 -54
  394. package/dist/src/index.ts +0 -58
  395. package/dist/src/stories/chromaticForceScreenSize.tsx +0 -7
  396. package/dist/src/stories/generated/Autocomplete/Demos.stories.tsx +0 -7
  397. package/dist/src/stories/generated/Avatar/Demos.stories.tsx +0 -7
  398. package/dist/src/stories/generated/Badge/Demos.stories.tsx +0 -9
  399. package/dist/src/stories/generated/Button/Demos.stories.tsx +0 -11
  400. package/dist/src/stories/generated/Checkbox/Demos.stories.tsx +0 -6
  401. package/dist/src/stories/generated/Chip/Demos.stories.tsx +0 -11
  402. package/dist/src/stories/generated/CommentBlock/Demos.stories.tsx +0 -8
  403. package/dist/src/stories/generated/DatePicker/Demos.stories.tsx +0 -8
  404. package/dist/src/stories/generated/Dialog/Demos.stories.tsx +0 -10
  405. package/dist/src/stories/generated/Divider/Demos.stories.tsx +0 -6
  406. package/dist/src/stories/generated/Dropdown/Demos.stories.tsx +0 -8
  407. package/dist/src/stories/generated/ExpansionPanel/Demos.stories.tsx +0 -9
  408. package/dist/src/stories/generated/Flag/Demos.stories.tsx +0 -6
  409. package/dist/src/stories/generated/GenericBlock/Demos.stories.tsx +0 -8
  410. package/dist/src/stories/generated/Heading/Demos.stories.tsx +0 -6
  411. package/dist/src/stories/generated/Icon/Demos.stories.tsx +0 -8
  412. package/dist/src/stories/generated/ImageBlock/Demos.stories.tsx +0 -9
  413. package/dist/src/stories/generated/Lightbox/Demos.stories.tsx +0 -6
  414. package/dist/src/stories/generated/Link/Demos.stories.tsx +0 -8
  415. package/dist/src/stories/generated/LinkPreview/Demos.stories.tsx +0 -7
  416. package/dist/src/stories/generated/List/Demos.stories.tsx +0 -11
  417. package/dist/src/stories/generated/Message/Demos.stories.tsx +0 -10
  418. package/dist/src/stories/generated/Mosaic/Demos.stories.tsx +0 -9
  419. package/dist/src/stories/generated/Notification/Demos.stories.tsx +0 -6
  420. package/dist/src/stories/generated/Popover/Demos.stories.tsx +0 -11
  421. package/dist/src/stories/generated/PopoverDialog/Demos.stories.tsx +0 -6
  422. package/dist/src/stories/generated/PostBlock/Demos.stories.tsx +0 -6
  423. package/dist/src/stories/generated/Progress/Demos.stories.tsx +0 -7
  424. package/dist/src/stories/generated/ProgressTracker/Demos.stories.tsx +0 -9
  425. package/dist/src/stories/generated/RadioButton/Demos.stories.tsx +0 -6
  426. package/dist/src/stories/generated/Select/Demos.stories.tsx +0 -14
  427. package/dist/src/stories/generated/SideNavigation/Demos.stories.tsx +0 -10
  428. package/dist/src/stories/generated/Skeleton/Demos.stories.tsx +0 -9
  429. package/dist/src/stories/generated/Slider/Demos.stories.tsx +0 -9
  430. package/dist/src/stories/generated/Slideshow/Demos.stories.tsx +0 -8
  431. package/dist/src/stories/generated/Switch/Demos.stories.tsx +0 -6
  432. package/dist/src/stories/generated/Table/Demos.stories.tsx +0 -6
  433. package/dist/src/stories/generated/Tabs/Demos.stories.tsx +0 -8
  434. package/dist/src/stories/generated/TextField/Demos.stories.tsx +0 -19
  435. package/dist/src/stories/generated/Thumbnail/Demos.stories.tsx +0 -12
  436. package/dist/src/stories/generated/Toolbar/Demos.stories.tsx +0 -10
  437. package/dist/src/stories/generated/Tooltip/Demos.stories.tsx +0 -8
  438. package/dist/src/stories/generated/Uploader/Demos.stories.tsx +0 -8
  439. package/dist/src/stories/generated/UserBlock/Demos.stories.tsx +0 -10
  440. package/dist/src/stories/knobs/buttonKnob.ts +0 -9
  441. package/dist/src/stories/knobs/emphasisKnob.ts +0 -8
  442. package/dist/src/stories/knobs/enumKnob.ts +0 -14
  443. package/dist/src/stories/knobs/focusKnob.ts +0 -3
  444. package/dist/src/stories/knobs/image.ts +0 -69
  445. package/dist/src/stories/knobs/lorem.ts +0 -59
  446. package/dist/src/stories/knobs/sizeKnob.ts +0 -5
  447. package/dist/src/stories/knobs/thumbnailsKnob.ts +0 -9
  448. package/dist/src/stories/utils/CustomLink.tsx +0 -7
  449. package/dist/src/stories/withResizableBox.tsx +0 -18
  450. package/dist/src/testing/utils/commonTestsSuite.ts +0 -71
  451. package/dist/src/testing/utils/commonTestsSuiteRTL.ts +0 -55
  452. package/dist/src/testing/utils/index.ts +0 -4
  453. package/dist/src/testing/utils/itShouldRenderStories.tsx +0 -103
  454. package/dist/src/testing/utils/queries.ts +0 -19
  455. package/dist/src/untypped-modules.d.ts +0 -7
  456. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.stories.jsx +0 -58
  457. package/dist/src/utils/ClickAwayProvider/ClickAwayProvider.tsx +0 -65
  458. package/dist/src/utils/ClickAwayProvider/index.ts +0 -1
  459. package/dist/src/utils/MaterialThemeSwitcher/MaterialThemeSwitcher.tsx +0 -54
  460. package/dist/src/utils/MaterialThemeSwitcher/index.ts +0 -1
  461. package/dist/src/utils/browserDoesNotSupportHover.test.js +0 -24
  462. package/dist/src/utils/browserDoesNotSupportHover.ts +0 -2
  463. package/dist/src/utils/clamp.ts +0 -17
  464. package/dist/src/utils/className.ts +0 -44
  465. package/dist/src/utils/event.ts +0 -1
  466. package/dist/src/utils/flattenChildren.test.tsx +0 -58
  467. package/dist/src/utils/flattenChildren.ts +0 -27
  468. package/dist/src/utils/focus/constants.ts +0 -5
  469. package/dist/src/utils/focus/getFirstAndLastFocusable.test.ts +0 -134
  470. package/dist/src/utils/focus/getFirstAndLastFocusable.ts +0 -21
  471. package/dist/src/utils/focus/getFocusableElements.test.ts +0 -151
  472. package/dist/src/utils/focus/getFocusableElements.ts +0 -7
  473. package/dist/src/utils/index.ts +0 -5
  474. package/dist/src/utils/isInternetExplorer.ts +0 -15
  475. package/dist/src/utils/makeListenerTowerContext.ts +0 -32
  476. package/dist/src/utils/mergeRefs.ts +0 -22
  477. package/dist/src/utils/partitionMulti.ts +0 -28
  478. package/dist/src/utils/renderLink.tsx +0 -17
  479. package/dist/src/utils/type.ts +0 -113
  480. package/dist/src/utils/userHasReducedMotion.ts +0 -7
  481. package/dist/src/utils/utils.test.ts +0 -48
  482. package/jest/__mocks__/@storybook/addon-actions.js +0 -3
  483. package/jest/__mocks__/@storybook/addon-knobs.js +0 -6
  484. package/jest/__mocks__/emptyFileMockTransformer.js +0 -8
  485. package/jest/__mocks__/emptyModuleMock.js +0 -1
  486. package/jest/configure.js +0 -6
  487. package/jest/index.js +0 -36
  488. package/jest/transform.js +0 -6
  489. package/rollup.config.js +0 -98
  490. package/storybook/build +0 -4
  491. package/storybook/generate-demo-stories.js +0 -59
  492. package/storybook/main.js +0 -67
  493. package/storybook/package.json +0 -13
  494. package/storybook/preview.js +0 -11
  495. package/storybook/start +0 -4
  496. package/storybook/story-block/StoryBlock.tsx +0 -49
  497. package/storybook/story-block/decorator.jsx +0 -7
  498. package/storybook/story-block/index.scss +0 -27
  499. package/storybook/yarn.lock +0 -13192
  500. package/tsconfig.json +0 -3
@@ -1,222 +0,0 @@
1
- import React, {
2
- CSSProperties,
3
- forwardRef,
4
- ImgHTMLAttributes,
5
- KeyboardEventHandler,
6
- MouseEventHandler,
7
- ReactElement,
8
- ReactNode,
9
- Ref,
10
- useState,
11
- } from 'react';
12
- import classNames from 'classnames';
13
-
14
- import { AspectRatio, HorizontalAlignment, Icon, Size, Theme } from '@lumx/react';
15
-
16
- import { Comp, Falsy, GenericProps, HasTheme } from '@lumx/react/utils/type';
17
- import { getRootClassName, handleBasicClasses } from '@lumx/react/utils/className';
18
-
19
- import { mdiImageBroken } from '@lumx/icons';
20
- import { mergeRefs } from '@lumx/react/utils/mergeRefs';
21
- import { useImageLoad } from '@lumx/react/components/thumbnail/useImageLoad';
22
- import { useFocusPointStyle } from '@lumx/react/components/thumbnail/useFocusPointStyle';
23
- import { FocusPoint, ThumbnailSize, ThumbnailVariant } from './types';
24
-
25
- type ImgHTMLProps = ImgHTMLAttributes<HTMLImageElement>;
26
-
27
- /**
28
- * Defines the props of the component.
29
- */
30
- export interface ThumbnailProps extends GenericProps, HasTheme {
31
- /** Alignment of the thumbnail in it's parent (requires flex parent). */
32
- align?: HorizontalAlignment;
33
- /** Image alternative text. */
34
- alt: string;
35
- /** Image aspect ratio. */
36
- aspectRatio?: AspectRatio;
37
- /** Badge. */
38
- badge?: ReactElement | Falsy;
39
- /** Image cross origin resource policy. */
40
- crossOrigin?: ImgHTMLProps['crossOrigin'];
41
- /** Fallback icon (SVG path) or react node when image fails to load. */
42
- fallback?: string | ReactNode;
43
- /** Whether the thumbnail should fill it's parent size (requires flex parent) or not. */
44
- fillHeight?: boolean;
45
- /** Apply relative vertical and horizontal shift (from -1 to 1) on the image position inside the thumbnail. */
46
- focusPoint?: FocusPoint;
47
- /** Image URL. */
48
- image: string;
49
- /** Props to inject into the native <img> element. */
50
- imgProps?: ImgHTMLProps;
51
- /** Reference to the native <img> element. */
52
- imgRef?: Ref<HTMLImageElement>;
53
- /** Set to true to force the display of the loading skeleton. */
54
- isLoading?: boolean;
55
- /** Size variant of the component. */
56
- size?: ThumbnailSize;
57
- /** Image loading mode. */
58
- loading?: ImgHTMLProps['loading'];
59
- /** On click callback. */
60
- onClick?: MouseEventHandler<HTMLDivElement>;
61
- /** On key press callback. */
62
- onKeyPress?: KeyboardEventHandler<HTMLDivElement>;
63
- /** Variant of the component. */
64
- variant?: ThumbnailVariant;
65
- /** Props to pass to the link wrapping the thumbnail. */
66
- linkProps?: React.DetailedHTMLProps<React.AnchorHTMLAttributes<HTMLAnchorElement>, HTMLAnchorElement>;
67
- /** Custom react component for the link (can be used to inject react router Link). */
68
- linkAs?: 'a' | any;
69
- }
70
-
71
- /**
72
- * Component display name.
73
- */
74
- const COMPONENT_NAME = 'Thumbnail';
75
-
76
- /**
77
- * Component default class name and class prefix.
78
- */
79
- const CLASSNAME = getRootClassName(COMPONENT_NAME);
80
-
81
- /**
82
- * Component default props.
83
- */
84
- const DEFAULT_PROPS: Partial<ThumbnailProps> = {
85
- fallback: mdiImageBroken,
86
- loading: 'lazy',
87
- theme: Theme.light,
88
- };
89
-
90
- /**
91
- * Thumbnail component.
92
- *
93
- * @param props Component props.
94
- * @param ref Component ref.
95
- * @return React element.
96
- */
97
- export const Thumbnail: Comp<ThumbnailProps> = forwardRef((props, ref) => {
98
- const {
99
- align,
100
- alt,
101
- aspectRatio = AspectRatio.original,
102
- badge,
103
- className,
104
- crossOrigin,
105
- fallback,
106
- fillHeight,
107
- // `focusPoint` needs to be here to remove it from `forwardedProps`.
108
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
109
- focusPoint,
110
- image,
111
- imgProps,
112
- imgRef: propImgRef,
113
- isLoading: isLoadingProp,
114
- loading,
115
- size,
116
- theme,
117
- variant,
118
- linkProps,
119
- linkAs,
120
- ...forwardedProps
121
- } = props;
122
- const [imgElement, setImgElement] = useState<HTMLImageElement>();
123
-
124
- // Image loading state.
125
- const loadingState = useImageLoad(image, imgElement);
126
- const isLoaded = loadingState === 'isLoaded';
127
- const isLoading = isLoadingProp || loadingState === 'isLoading';
128
- const hasError = loadingState === 'hasError';
129
-
130
- // Focus point.
131
- const focusPointStyle = useFocusPointStyle(props, imgElement, isLoaded);
132
-
133
- const hasIconErrorFallback = hasError && typeof fallback === 'string';
134
- const hasCustomErrorFallback = hasError && !hasIconErrorFallback;
135
- const imageErrorStyle: CSSProperties = {};
136
- if (hasIconErrorFallback) {
137
- // Keep the image layout on icon fallback.
138
- imageErrorStyle.visibility = 'hidden';
139
- } else if (hasCustomErrorFallback) {
140
- // Remove the image on custom fallback.
141
- imageErrorStyle.display = 'none';
142
- }
143
-
144
- const isLink = Boolean(linkProps?.href || linkAs);
145
- const isButton = !!forwardedProps.onClick;
146
- const isClickable = isButton || isLink;
147
-
148
- let Wrapper: any = 'div';
149
- const wrapperProps = { ...forwardedProps };
150
- if (isLink) {
151
- Wrapper = linkAs || 'a';
152
- Object.assign(wrapperProps, linkProps);
153
- } else if (isButton) {
154
- Wrapper = 'button';
155
- wrapperProps.type = forwardedProps.type || 'button';
156
- wrapperProps['aria-label'] = forwardedProps['aria-label'] || alt;
157
- }
158
-
159
- return (
160
- <Wrapper
161
- {...wrapperProps}
162
- ref={ref}
163
- className={classNames(
164
- linkProps?.className,
165
- className,
166
- handleBasicClasses({
167
- align,
168
- aspectRatio,
169
- prefix: CLASSNAME,
170
- size,
171
- theme,
172
- variant,
173
- isClickable,
174
- hasError,
175
- hasIconErrorFallback,
176
- hasCustomErrorFallback,
177
- isLoading,
178
- hasBadge: !!badge,
179
- }),
180
- fillHeight && `${CLASSNAME}--fill-height`,
181
- )}
182
- >
183
- <div className={`${CLASSNAME}__background`}>
184
- <img
185
- {...imgProps}
186
- style={{
187
- ...imgProps?.style,
188
- ...imageErrorStyle,
189
- ...focusPointStyle,
190
- }}
191
- ref={mergeRefs(setImgElement, propImgRef)}
192
- className={classNames(
193
- handleBasicClasses({
194
- prefix: `${CLASSNAME}__image`,
195
- isLoading,
196
- hasDefinedSize: Boolean(imgProps?.height && imgProps.width),
197
- }),
198
- imgProps?.className,
199
- )}
200
- crossOrigin={crossOrigin}
201
- src={image}
202
- alt={alt}
203
- loading={loading}
204
- />
205
- {!isLoading && hasError && (
206
- <div className={`${CLASSNAME}__fallback`}>
207
- {hasIconErrorFallback ? (
208
- <Icon icon={fallback as string} size={Size.xxs} theme={theme} />
209
- ) : (
210
- fallback
211
- )}
212
- </div>
213
- )}
214
- </div>
215
- {badge &&
216
- React.cloneElement(badge, { className: classNames(`${CLASSNAME}__badge`, badge.props.className) })}
217
- </Wrapper>
218
- );
219
- });
220
- Thumbnail.displayName = COMPONENT_NAME;
221
- Thumbnail.className = CLASSNAME;
222
- Thumbnail.defaultProps = DEFAULT_PROPS;
@@ -1,130 +0,0 @@
1
- // Jest Snapshot v1, https://goo.gl/fbAQLP
2
-
3
- exports[`<Thumbnail> Snapshots and structure should render story 'Clickable' 1`] = `
4
- <button
5
- aria-label="Click me"
6
- className="lumx-thumbnail lumx-thumbnail--aspect-ratio-original lumx-thumbnail--size-xxl lumx-thumbnail--theme-light lumx-thumbnail--is-clickable lumx-thumbnail--is-loading"
7
- onClick={[Function]}
8
- type="button"
9
- >
10
- <div
11
- className="lumx-thumbnail__background"
12
- >
13
- <img
14
- alt="Click me"
15
- className="lumx-thumbnail__image lumx-thumbnail__image--is-loading"
16
- loading="lazy"
17
- src="/demo-assets/landscape1.jpg"
18
- style={{}}
19
- />
20
- </div>
21
- </button>
22
- `;
23
-
24
- exports[`<Thumbnail> Snapshots and structure should render story 'ClickableCustomLink' 1`] = `
25
- <CustomLink
26
- className="custom-class-name lumx-thumbnail lumx-thumbnail--aspect-ratio-original lumx-thumbnail--size-xxl lumx-thumbnail--theme-light lumx-thumbnail--is-clickable lumx-thumbnail--is-loading"
27
- href="https://google.fr"
28
- >
29
- <div
30
- className="lumx-thumbnail__background"
31
- >
32
- <img
33
- alt="Click me"
34
- className="lumx-thumbnail__image lumx-thumbnail__image--is-loading"
35
- loading="lazy"
36
- src="/demo-assets/landscape1.jpg"
37
- style={{}}
38
- />
39
- </div>
40
- </CustomLink>
41
- `;
42
-
43
- exports[`<Thumbnail> Snapshots and structure should render story 'ClickableLink' 1`] = `
44
- <a
45
- className="lumx-thumbnail lumx-thumbnail--aspect-ratio-original lumx-thumbnail--size-xxl lumx-thumbnail--theme-light lumx-thumbnail--is-clickable lumx-thumbnail--is-loading"
46
- href="https://google.fr"
47
- >
48
- <div
49
- className="lumx-thumbnail__background"
50
- >
51
- <img
52
- alt="Click me"
53
- className="lumx-thumbnail__image lumx-thumbnail__image--is-loading"
54
- loading="lazy"
55
- src="/demo-assets/landscape1.jpg"
56
- style={{}}
57
- />
58
- </div>
59
- </a>
60
- `;
61
-
62
- exports[`<Thumbnail> Snapshots and structure should render story 'Default' 1`] = `
63
- <div
64
- className="lumx-thumbnail lumx-thumbnail--aspect-ratio-original lumx-thumbnail--theme-light lumx-thumbnail--variant-squared lumx-thumbnail--is-loading"
65
- >
66
- <div
67
- className="lumx-thumbnail__background"
68
- >
69
- <img
70
- alt="Image alt text"
71
- className="lumx-thumbnail__image lumx-thumbnail__image--is-loading"
72
- loading="lazy"
73
- src="/demo-assets/landscape1.jpg"
74
- style={{}}
75
- />
76
- </div>
77
- </div>
78
- `;
79
-
80
- exports[`<Thumbnail> Snapshots and structure should render story 'WithBadge' 1`] = `
81
- <div
82
- className="lumx-thumbnail lumx-thumbnail--aspect-ratio-square lumx-thumbnail--size-l lumx-thumbnail--theme-light lumx-thumbnail--variant-rounded lumx-thumbnail--is-loading lumx-thumbnail--has-badge"
83
- >
84
- <div
85
- className="lumx-thumbnail__background"
86
- >
87
- <img
88
- alt="Image alt text"
89
- className="lumx-thumbnail__image lumx-thumbnail__image--is-loading"
90
- loading="lazy"
91
- src="/demo-assets/landscape1.jpg"
92
- style={{}}
93
- />
94
- </div>
95
- <Badge
96
- className="lumx-thumbnail__badge"
97
- color="primary"
98
- >
99
- <Icon
100
- icon="M4 2A2 2 0 0 0 2 4V12H4V8H6V12H8V4A2 2 0 0 0 6 2H4M4 4H6V6H4M22 15.5V14A2 2 0 0 0 20 12H16V22H20A2 2 0 0 0 22 20V18.5A1.54 1.54 0 0 0 20.5 17A1.54 1.54 0 0 0 22 15.5M20 20H18V18H20V20M20 16H18V14H20M5.79 21.61L4.21 20.39L18.21 2.39L19.79 3.61Z"
101
- />
102
- </Badge>
103
- </div>
104
- `;
105
-
106
- exports[`<Thumbnail> Snapshots and structure should render story 'WithCustomImageClassName' 1`] = `
107
- <div
108
- className="lumx-thumbnail lumx-thumbnail--aspect-ratio-square lumx-thumbnail--size-l lumx-thumbnail--theme-light lumx-thumbnail--variant-rounded lumx-thumbnail--is-loading lumx-thumbnail--has-badge"
109
- >
110
- <div
111
- className="lumx-thumbnail__background"
112
- >
113
- <img
114
- alt="Image alt text"
115
- className="lumx-thumbnail__image lumx-thumbnail__image--is-loading custom-image-class-name"
116
- loading="lazy"
117
- src="/demo-assets/landscape1.jpg"
118
- style={{}}
119
- />
120
- </div>
121
- <Badge
122
- className="lumx-thumbnail__badge"
123
- color="primary"
124
- >
125
- <Icon
126
- icon="M4 2A2 2 0 0 0 2 4V12H4V8H6V12H8V4A2 2 0 0 0 6 2H4M4 4H6V6H4M22 15.5V14A2 2 0 0 0 20 12H16V22H20A2 2 0 0 0 22 20V18.5A1.54 1.54 0 0 0 20.5 17A1.54 1.54 0 0 0 22 15.5M20 20H18V18H20V20M20 16H18V14H20M5.79 21.61L4.21 20.39L18.21 2.39L19.79 3.61Z"
127
- />
128
- </Badge>
129
- </div>
130
- `;
@@ -1,3 +0,0 @@
1
- export * from './Thumbnail';
2
- export * from './types';
3
- export { useFocusPointStyle } from '@lumx/react/components/thumbnail/useFocusPointStyle';
@@ -1,39 +0,0 @@
1
- import React from 'react';
2
- import { AspectRatio, Size } from '@lumx/react';
3
- import { ValueOf } from '@lumx/react/utils/type';
4
-
5
- /**
6
- * Focal point using vertical alignment, horizontal alignment or coordinates (from -1 to 1).
7
- */
8
- export type FocusPoint = { x?: number; y?: number };
9
-
10
- /**
11
- * Loading attribute is not yet supported in typescript, so we need
12
- * to add it in order to avoid a ts error.
13
- * https://github.com/typescript-cheatsheets/react-typescript-cheatsheet/blob/master/ADVANCED.md#adding-non-standard-attributes
14
- */
15
- declare module 'react' {
16
- interface ImgHTMLAttributes<T> extends React.HTMLAttributes<T> {
17
- loading?: 'eager' | 'lazy';
18
- }
19
- }
20
-
21
- /**
22
- * All available aspect ratios.
23
- * @deprecated
24
- */
25
- export const ThumbnailAspectRatio: Record<string, AspectRatio> = { ...AspectRatio };
26
-
27
- /**
28
- * Thumbnail sizes.
29
- */
30
- export type ThumbnailSize = Extract<Size, 'xxs' | 'xs' | 's' | 'm' | 'l' | 'xl' | 'xxl'>;
31
-
32
- /**
33
- * Thumbnail variants.
34
- */
35
- export const ThumbnailVariant = {
36
- squared: 'squared',
37
- rounded: 'rounded',
38
- } as const;
39
- export type ThumbnailVariant = ValueOf<typeof ThumbnailVariant>;
@@ -1,92 +0,0 @@
1
- import { shiftPosition } from './useFocusPointStyle';
2
-
3
- describe('shiftPosition', () => {
4
- it('should always return 0% if the imageSize fits the containerSize', () => {
5
- expect(
6
- shiftPosition({
7
- scale: 1.5,
8
- focusPoint: 0,
9
- imageSize: 1200,
10
- containerSize: 800,
11
- }),
12
- ).toEqual(0);
13
- expect(
14
- shiftPosition({
15
- scale: 1,
16
- focusPoint: 0.27,
17
- imageSize: 1000,
18
- containerSize: 1000,
19
- }),
20
- ).toEqual(0);
21
- expect(
22
- shiftPosition({
23
- scale: 3,
24
- focusPoint: 0.5,
25
- imageSize: 1200,
26
- containerSize: 400,
27
- }),
28
- ).toEqual(0);
29
- expect(
30
- shiftPosition({
31
- scale: 2.4,
32
- focusPoint: 1,
33
- imageSize: 1200,
34
- containerSize: 500,
35
- }),
36
- ).toEqual(0);
37
- });
38
-
39
- describe('with bigger side than container ', () => {
40
- // This use case will come, for example, if you have an image in width 100%
41
- // but the image after being resized to keep the ratio is higher than the container.
42
- // Then we are calculating the y shift.
43
-
44
- const image = { width: 1000, height: 1200 };
45
- const container = { width: 1000, height: 300 };
46
- // scale is always the minimum scale ratio. Here imagewidth/containerwidth.
47
- const scale = image.width / container.width; // 1
48
- it('should return 0% if focusPoint equals 0', () => {
49
- expect(
50
- shiftPosition({
51
- scale,
52
- focusPoint: 0,
53
- imageSize: image.height,
54
- containerSize: container.height,
55
- }),
56
- ).toEqual(0);
57
- });
58
-
59
- it('should return 100% if focusPoint equals 1', () => {
60
- expect(
61
- shiftPosition({
62
- scale,
63
- focusPoint: 1,
64
- imageSize: image.height,
65
- containerSize: container.height,
66
- }),
67
- ).toEqual(100);
68
- });
69
-
70
- it('should return 50% if focusPoint equals 0.5', () => {
71
- expect(
72
- shiftPosition({
73
- scale,
74
- focusPoint: 0.5,
75
- imageSize: image.height,
76
- containerSize: container.height,
77
- }),
78
- ).toEqual(50);
79
- });
80
-
81
- it('should return 16% if focusPoint equals 0.25', () => {
82
- expect(
83
- shiftPosition({
84
- scale,
85
- focusPoint: 0.25,
86
- imageSize: image.height,
87
- containerSize: container.height,
88
- }),
89
- ).toEqual(16);
90
- });
91
- });
92
- });
@@ -1,111 +0,0 @@
1
- import { CSSProperties, useEffect, useMemo, useState } from 'react';
2
- import { AspectRatio } from '@lumx/react/components';
3
- import { ThumbnailProps } from '@lumx/react/components/thumbnail/Thumbnail';
4
-
5
- // Calculate shift to center the focus point in the container.
6
- export function shiftPosition({
7
- scale,
8
- focusPoint,
9
- imageSize,
10
- containerSize,
11
- }: {
12
- scale: number;
13
- focusPoint: number;
14
- imageSize: number;
15
- containerSize: number;
16
- }) {
17
- const scaledSize = imageSize / scale;
18
- if (scaledSize === containerSize) return 0;
19
-
20
- const scaledFocusHeight = focusPoint * scaledSize;
21
- const startFocus = scaledFocusHeight - containerSize / 2;
22
- const shift = startFocus / (scaledSize - containerSize);
23
-
24
- return Math.floor(Math.max(Math.min(shift, 1), 0) * 100);
25
- }
26
-
27
- type Size = { width: number; height: number };
28
-
29
- // Compute CSS properties to apply the focus point.
30
- export const useFocusPointStyle = (
31
- { image, aspectRatio, focusPoint, imgProps: { width, height } = {} }: ThumbnailProps,
32
- element: HTMLImageElement | undefined,
33
- isLoaded: boolean,
34
- ): CSSProperties => {
35
- // Get natural image size from imgProps or img element.
36
- const imageSize: Size | undefined = useMemo(() => {
37
- // Focus point is not applicable => exit early
38
- if (!image || aspectRatio === AspectRatio.original || (!focusPoint?.x && !focusPoint?.y)) return undefined;
39
- if (typeof width === 'number' && typeof height === 'number') return { width, height };
40
- if (element && isLoaded) return { width: element.naturalWidth, height: element.naturalHeight };
41
- return undefined;
42
- }, [aspectRatio, element, focusPoint?.x, focusPoint?.y, height, image, isLoaded, width]);
43
-
44
- // Get container size (dependant on imageSize).
45
- const [containerSize, setContainerSize] = useState<Size | undefined>(undefined);
46
- useEffect(
47
- function updateContainerSize() {
48
- const cWidth = element?.offsetWidth;
49
- const cHeight = element?.offsetHeight;
50
- if (cWidth && cHeight) {
51
- // Update only if needed.
52
- setContainerSize((oldContainerSize) =>
53
- oldContainerSize?.width === cWidth && oldContainerSize.height === cHeight
54
- ? oldContainerSize
55
- : { width: cWidth, height: cHeight },
56
- );
57
- } else if (imageSize) {
58
- // Wait for a render (in case the container size is dependent on the image size).
59
- requestAnimationFrame(updateContainerSize);
60
- }
61
- },
62
- [element?.offsetHeight, element?.offsetWidth, imageSize],
63
- );
64
-
65
- // Compute style.
66
- const [style, setStyle] = useState<CSSProperties>({});
67
- useEffect(() => {
68
- // Focus point is not applicable => exit early
69
- if (!image || aspectRatio === AspectRatio.original || (!focusPoint?.x && !focusPoint?.y)) {
70
- return;
71
- }
72
- if (!element || !imageSize) {
73
- // Focus point can be computed but now right now (image size unknown).
74
- setStyle({ visibility: 'hidden' });
75
- return;
76
- }
77
- if (!containerSize) {
78
- // Missing container size abort focus point compute.
79
- setStyle({});
80
- return;
81
- }
82
-
83
- const heightScale = imageSize.height / containerSize.height;
84
- const widthScale = imageSize.width / containerSize.width;
85
- const scale = Math.min(widthScale, heightScale);
86
-
87
- // Focus Y relative to the top (instead of the center)
88
- const focusPointFromTop = Math.abs((focusPoint?.y || 0) - 1) / 2;
89
- const y = shiftPosition({
90
- scale,
91
- focusPoint: focusPointFromTop,
92
- imageSize: imageSize.height,
93
- containerSize: containerSize.height,
94
- });
95
-
96
- // Focus X relative to the left (instead of the center)
97
- const focusPointFromLeft = Math.abs((focusPoint?.x || 0) + 1) / 2;
98
- const x = shiftPosition({
99
- scale,
100
- focusPoint: focusPointFromLeft,
101
- imageSize: imageSize.width,
102
- containerSize: containerSize.width,
103
- });
104
-
105
- const objectPosition = `${x}% ${y}%`;
106
- // Update only if needed.
107
- setStyle((oldStyle) => (oldStyle.objectPosition === objectPosition ? oldStyle : { objectPosition }));
108
- }, [aspectRatio, containerSize, element, focusPoint?.x, focusPoint?.y, image, imageSize]);
109
-
110
- return style;
111
- };
@@ -1,40 +0,0 @@
1
- import { useEffect, useState } from 'react';
2
-
3
- export type LoadingState = 'isLoading' | 'isLoaded' | 'hasError';
4
-
5
- function getState(img: HTMLImageElement | null | undefined, event?: Event) {
6
- // Error event occurred or image loaded empty.
7
- if (event?.type === 'error' || (img?.complete && (img?.naturalWidth === 0 || img?.naturalHeight === 0))) {
8
- return 'hasError';
9
- }
10
- // Image is undefined or incomplete.
11
- if (!img || !img.complete) {
12
- return 'isLoading';
13
- }
14
- // Else loaded.
15
- return 'isLoaded';
16
- }
17
-
18
- export function useImageLoad(imageURL: string, imgRef?: HTMLImageElement): LoadingState {
19
- const [state, setState] = useState<LoadingState>(getState(imgRef));
20
-
21
- // Update state when changing image URL or DOM reference.
22
- useEffect(() => {
23
- setState(getState(imgRef));
24
- }, [imageURL, imgRef]);
25
-
26
- // Listen to `load` and `error` event on image
27
- useEffect(() => {
28
- const img = imgRef;
29
- if (!img) return undefined;
30
- const update = (event?: Event) => setState(getState(img, event));
31
- img.addEventListener('load', update);
32
- img.addEventListener('error', update);
33
- return () => {
34
- img.removeEventListener('load', update);
35
- img.removeEventListener('error', update);
36
- };
37
- }, [imgRef, imgRef?.src]);
38
-
39
- return state;
40
- }