@ainias42/react-bootstrap-mobile 1.0.1 → 1.0.3

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 (412) hide show
  1. package/.ctirc +114 -0
  2. package/.prettierrc +1 -5
  3. package/.storybook/main.ts +31 -0
  4. package/.storybook/preview.ts +36 -0
  5. package/bin/release.sh +1 -37
  6. package/bin/updatePackages.sh +3 -0
  7. package/dist/{src/Components → Components}/ActionSheet/ActionSheet.d.ts +5 -5
  8. package/dist/Components/ActionSheet/ActionSheet.stories.d.ts +9 -0
  9. package/dist/Components/Card/Card.d.ts +12 -0
  10. package/dist/Components/Card/Card.stories.d.ts +16 -0
  11. package/dist/{src/Components → Components}/Clickable/Clickable.d.ts +3 -3
  12. package/dist/Components/Colors.stories.d.ts +5 -0
  13. package/dist/Components/Dialog/AlertDialog.d.ts +8 -0
  14. package/dist/Components/Dialog/AlertDialog.stories.d.ts +14 -0
  15. package/dist/{src/Components → Components}/Dialog/ButtonDialog.d.ts +3 -3
  16. package/dist/Components/Dialog/ConfirmDialog.d.ts +9 -0
  17. package/dist/Components/Dialog/ConfirmDialog.stories.d.ts +15 -0
  18. package/dist/{src/Components → Components}/Dialog/Dialog.d.ts +2 -2
  19. package/dist/{src/Components → Components}/Dialog/DialogBackground.d.ts +2 -2
  20. package/dist/{src/Components → Components}/Dialog/DialogContainer.d.ts +3 -3
  21. package/dist/{src/Components → Components}/Dialog/DialogContext.d.ts +3 -2
  22. package/dist/{src/Components → Components}/DragAndDrop/DragItem.d.ts +2 -2
  23. package/dist/{src/Components → Components}/DragAndDrop/DropArea.d.ts +2 -2
  24. package/dist/{src/Components → Components}/FormElements/Button/Button.d.ts +8 -8
  25. package/dist/Components/FormElements/Button/Button.stories.d.ts +43 -0
  26. package/dist/Components/FormElements/CheckBox/Checkbox.d.ts +12 -0
  27. package/dist/Components/FormElements/CheckBox/Checkbox.stories.d.ts +17 -0
  28. package/dist/{src/Components → Components}/FormElements/ColorInput/ColorInput.d.ts +3 -5
  29. package/dist/Components/FormElements/ColorInput/ColorInput.stories.d.ts +8 -0
  30. package/dist/{src/Components → Components}/FormElements/Controller/ColorInputController.d.ts +1 -1
  31. package/dist/{src/Components → Components}/FormElements/Controller/FileInputController.d.ts +4 -4
  32. package/dist/Components/FormElements/Controller/HookForm.d.ts +15 -0
  33. package/dist/{src/Components → Components}/FormElements/Controller/InputController.d.ts +1 -1
  34. package/dist/{src/Components → Components}/FormElements/Controller/MultipleFileInputController.d.ts +1 -1
  35. package/dist/{src/Components → Components}/FormElements/Controller/PasswordInputController.d.ts +1 -1
  36. package/dist/{src/Components → Components}/FormElements/Controller/SelectController.d.ts +1 -1
  37. package/dist/Components/FormElements/Controller/SliderController.d.ts +5 -0
  38. package/dist/{src/Components → Components}/FormElements/Controller/SwitchController.d.ts +1 -1
  39. package/dist/{src/Components → Components}/FormElements/Controller/TextareaController.d.ts +1 -1
  40. package/dist/{src/Components → Components}/FormElements/Controller/useYupResolver.d.ts +1 -1
  41. package/dist/{src/Components → Components}/FormElements/Controller/withHookController.d.ts +3 -2
  42. package/dist/Components/FormElements/Error/FormError.d.ts +6 -0
  43. package/dist/Components/FormElements/Error/FormError.stories.d.ts +7 -0
  44. package/dist/Components/FormElements/Form.stories.d.ts +7 -0
  45. package/dist/Components/FormElements/Input/FileInput/FileInput.d.ts +13 -0
  46. package/dist/{src/Components → Components}/FormElements/Input/FileInput/MultipleFileInput.d.ts +6 -6
  47. package/dist/Components/FormElements/Input/HiddenInput.d.ts +6 -0
  48. package/dist/Components/FormElements/Input/HiddenInput.stories.d.ts +9 -0
  49. package/dist/{src/Components → Components}/FormElements/Input/Input.d.ts +4 -4
  50. package/dist/Components/FormElements/Input/Input.stories.d.ts +18 -0
  51. package/dist/{src/Components → Components}/FormElements/Input/PasswordInput/PasswordInput.d.ts +5 -4
  52. package/dist/Components/FormElements/Input/PasswordInput/PasswordInput.stories.d.ts +8 -0
  53. package/dist/{src/Components → Components}/FormElements/SearchSelectInput/SearchSelectInput.d.ts +4 -4
  54. package/dist/Components/FormElements/SearchSelectInput/SearchSelectInput.stories.d.ts +9 -0
  55. package/dist/{src/Components → Components}/FormElements/Select/Select.d.ts +4 -4
  56. package/dist/Components/FormElements/Select/Select.stories.d.ts +8 -0
  57. package/dist/{src/Components → Components}/FormElements/Slider/Slider.d.ts +4 -4
  58. package/dist/Components/FormElements/Slider/Slider.stories.d.ts +7 -0
  59. package/dist/{src/Components → Components}/FormElements/Switch/Switch.d.ts +5 -5
  60. package/dist/Components/FormElements/Switch/Switch.stories.d.ts +11 -0
  61. package/dist/{src/Components → Components}/FormElements/Textarea/Textarea.d.ts +4 -4
  62. package/dist/Components/FormElements/Textarea/Textarea.stories.d.ts +9 -0
  63. package/dist/{src/Components → Components}/FormElements/hooks/useOnChangeDone.d.ts +1 -1
  64. package/dist/{src/Components → Components}/FullScreen/FullScreen.d.ts +4 -4
  65. package/dist/{src/Components → Components}/Hooks/useClientLayoutEffect.d.ts +1 -1
  66. package/dist/{src/Components → Components}/Hooks/useComposedRef.d.ts +1 -1
  67. package/dist/{src/Components → Components}/Hooks/useDelayedState.d.ts +1 -1
  68. package/dist/{src/Components → Components}/Hooks/useInViewport.d.ts +1 -1
  69. package/dist/{src/Components → Components}/Icon/DoubleIcon.d.ts +1 -1
  70. package/dist/Components/Icon/DoubleIcon.stories.d.ts +23 -0
  71. package/dist/{src/Components → Components}/Icon/Icon.d.ts +5 -5
  72. package/dist/Components/Icon/Icon.stories.d.ts +17 -0
  73. package/dist/Components/Image/Image.d.ts +10 -0
  74. package/dist/Components/Image/Image.stories.d.ts +7 -0
  75. package/dist/{src/Components → Components}/InViewport/InViewport.d.ts +1 -1
  76. package/dist/{src/Components → Components}/Layout/Block.d.ts +4 -4
  77. package/dist/{src/Components → Components}/Layout/Container.d.ts +1 -1
  78. package/dist/{src/Components → Components}/Layout/Flex.d.ts +3 -3
  79. package/dist/{src/Components → Components}/Layout/Grid/Grid.d.ts +3 -3
  80. package/dist/{src/Components → Components}/Layout/Grid/GridItem.d.ts +1 -1
  81. package/dist/Components/Layout/Grow.d.ts +10 -0
  82. package/dist/{src/Components → Components}/Layout/Inline.d.ts +3 -3
  83. package/dist/{src/Components → Components}/Layout/InlineBlock.d.ts +3 -3
  84. package/dist/{src/Components → Components}/Layout/View.d.ts +4 -4
  85. package/dist/{src/Components → Components}/Layout/ViewWithoutListeners.d.ts +3 -3
  86. package/dist/Components/LoadingArea/LoadingArea.d.ts +9 -0
  87. package/dist/Components/LoadingArea/LoadingArea.stories.d.ts +9 -0
  88. package/dist/Components/LoadingCircle/LoadingCircle.d.ts +7 -0
  89. package/dist/Components/LoadingCircle/LoadingCircle.stories.d.ts +26 -0
  90. package/dist/{src/Components → Components}/Menu/HoverMenu.d.ts +3 -3
  91. package/dist/Components/Menu/HoverMenu.stories.d.ts +16 -0
  92. package/dist/{src/Components → Components}/Menu/Menu.d.ts +2 -2
  93. package/dist/Components/Menu/Menu.stories.d.ts +14 -0
  94. package/dist/{src/Components → Components}/Menu/MenuCloseContext.d.ts +1 -1
  95. package/dist/{src/Components → Components}/Menu/MenuDivider.d.ts +1 -1
  96. package/dist/{src/Components → Components}/Menu/MenuItem.d.ts +4 -3
  97. package/dist/Components/Menu/MenuItem.stories.d.ts +21 -0
  98. package/dist/{src/Components → Components}/Menu/Submenu.d.ts +3 -3
  99. package/dist/Components/Menu/Submenu.stories.d.ts +10 -0
  100. package/dist/{src/Components → Components}/Menu/useMenu.d.ts +2 -2
  101. package/dist/{src/Components → Components}/RbmComponentProps.d.ts +4 -4
  102. package/dist/{src/Components → Components}/SizeCalculator/SizeCalculator.d.ts +1 -1
  103. package/dist/Components/SpoilerList/Spoiler/Spoiler.d.ts +16 -0
  104. package/dist/Components/SpoilerList/Spoiler/Spoiler.stories.d.ts +7 -0
  105. package/dist/{src/Components → Components}/SpoilerList/SpoilerList.d.ts +3 -5
  106. package/dist/{src/Components → Components}/TabBar/TabBar.d.ts +4 -6
  107. package/dist/Components/TabBar/TabBar.stories.d.ts +10 -0
  108. package/dist/Components/TabBar/TabBarButton.d.ts +7 -0
  109. package/dist/{src/Components → Components}/Table/Table.d.ts +3 -3
  110. package/dist/{src/Components → Components}/Text/Heading.d.ts +2 -2
  111. package/dist/{src/Components → Components}/Text/Text.d.ts +3 -3
  112. package/dist/Components/Text/Text.stories.d.ts +35 -0
  113. package/dist/Components/Toast/Toast.d.ts +12 -0
  114. package/dist/Components/Toast/Toast.stories.d.ts +8 -0
  115. package/dist/{src/Components → Components}/Toast/ToastContainer.d.ts +2 -2
  116. package/dist/Components/TopBar/MoreButton.d.ts +7 -0
  117. package/dist/{src/Components → Components}/TopBar/TopBar.d.ts +4 -6
  118. package/dist/Components/TopBar/TopBar.stories.d.ts +7 -0
  119. package/dist/Components/TopBar/TopBarButton.d.ts +7 -0
  120. package/dist/helper/useDeepShallow.d.ts +1 -0
  121. package/dist/helper/withMemo.d.ts +3 -0
  122. package/dist/{src/helper → helper}/withRenderBrowserOnly.d.ts +1 -1
  123. package/dist/helper/withRestrictedChildren.d.ts +7 -0
  124. package/dist/index.css +36 -0
  125. package/dist/index.css.map +1 -0
  126. package/dist/index.d.ts +116 -0
  127. package/dist/index.js +5357 -0
  128. package/dist/index.js.map +1 -0
  129. package/dist/treeshakeTest.d.ts +1 -0
  130. package/eslint.config.js +17 -0
  131. package/package.json +41 -90
  132. package/react-bootstrap-mobile.scss +6 -6
  133. package/src/Components/ActionSheet/ActionSheet.stories.tsx +55 -0
  134. package/src/Components/ActionSheet/ActionSheet.tsx +37 -24
  135. package/src/Components/ActionSheet/actionSheet.module.scss +198 -0
  136. package/src/Components/Card/Card.stories.tsx +41 -0
  137. package/src/Components/Card/Card.tsx +6 -9
  138. package/src/Components/Card/card.module.scss +74 -0
  139. package/src/Components/Clickable/Clickable.tsx +73 -63
  140. package/src/Components/Clickable/clickable.module.scss +14 -0
  141. package/src/Components/Colors.stories.tsx +77 -0
  142. package/src/Components/Dialog/AlertDialog.stories.tsx +28 -0
  143. package/src/Components/Dialog/AlertDialog.tsx +10 -9
  144. package/src/Components/Dialog/ButtonDialog.tsx +15 -13
  145. package/src/Components/Dialog/ConfirmDialog.stories.tsx +29 -0
  146. package/src/Components/Dialog/ConfirmDialog.tsx +11 -9
  147. package/src/Components/Dialog/Dialog.tsx +10 -10
  148. package/src/Components/Dialog/DialogBackground.tsx +32 -21
  149. package/src/Components/Dialog/DialogContainer.tsx +23 -18
  150. package/src/Components/Dialog/DialogContext.ts +7 -6
  151. package/src/Components/Dialog/{buttonDialog.scss → buttonDialog.module.scss} +29 -21
  152. package/src/Components/Dialog/dialog.module.scss +30 -0
  153. package/src/Components/Dialog/dialogBackground.module.scss +17 -0
  154. package/src/Components/Dialog/useAlertDialog.ts +3 -3
  155. package/src/Components/Dialog/useConfirmDialog.ts +3 -3
  156. package/src/Components/DragAndDrop/DragItem.tsx +7 -6
  157. package/src/Components/DragAndDrop/DropArea.tsx +5 -4
  158. package/src/Components/Flavor.ts +4 -4
  159. package/src/Components/FormElements/Button/Button.stories.tsx +79 -0
  160. package/src/Components/FormElements/Button/Button.tsx +49 -36
  161. package/src/Components/FormElements/Button/ButtonType.ts +2 -2
  162. package/src/Components/FormElements/Button/button.module.scss +87 -0
  163. package/src/Components/FormElements/CheckBox/Checkbox.stories.tsx +50 -0
  164. package/src/Components/FormElements/CheckBox/Checkbox.tsx +13 -14
  165. package/src/Components/FormElements/CheckBox/{checkbox.scss → checkbox.module.scss} +30 -11
  166. package/src/Components/FormElements/ColorInput/ColorInput.stories.tsx +24 -0
  167. package/src/Components/FormElements/ColorInput/ColorInput.tsx +55 -59
  168. package/src/Components/FormElements/ColorInput/{colorInput.scss → colorInput.module.scss} +17 -19
  169. package/src/Components/FormElements/ColorInput/sharedSelectedColor.ts +19 -10
  170. package/src/Components/FormElements/Controller/ColorInputController.ts +3 -3
  171. package/src/Components/FormElements/Controller/FileInputController.tsx +29 -20
  172. package/src/Components/FormElements/Controller/HookForm.tsx +128 -24
  173. package/src/Components/FormElements/Controller/InputController.ts +3 -3
  174. package/src/Components/FormElements/Controller/MultipleFileInputController.ts +2 -3
  175. package/src/Components/FormElements/Controller/PasswordInputController.ts +3 -3
  176. package/src/Components/FormElements/Controller/SelectController.ts +3 -3
  177. package/src/Components/FormElements/Controller/SendFormContext.ts +3 -3
  178. package/src/Components/FormElements/Controller/SliderController.ts +4 -0
  179. package/src/Components/FormElements/Controller/SwitchController.ts +3 -3
  180. package/src/Components/FormElements/Controller/TextareaController.ts +2 -2
  181. package/src/Components/FormElements/Controller/useYupResolver.ts +10 -8
  182. package/src/Components/FormElements/Controller/withHookController.tsx +21 -18
  183. package/src/Components/FormElements/Error/FormError.stories.tsx +16 -0
  184. package/src/Components/FormElements/Error/FormError.tsx +42 -0
  185. package/src/Components/FormElements/Error/formError.module.scss +9 -0
  186. package/src/Components/FormElements/Form.stories.tsx +16 -0
  187. package/src/Components/FormElements/Input/FileInput/FileInput.tsx +52 -32
  188. package/src/Components/FormElements/Input/FileInput/MultipleFileInput.tsx +234 -231
  189. package/src/Components/FormElements/Input/FileInput/{fileInput.scss → fileInput.module.scss} +10 -12
  190. package/src/Components/FormElements/Input/HiddenInput.stories.tsx +44 -0
  191. package/src/Components/FormElements/Input/HiddenInput.tsx +6 -8
  192. package/src/Components/FormElements/Input/Input.stories.tsx +59 -0
  193. package/src/Components/FormElements/Input/Input.tsx +173 -172
  194. package/src/Components/FormElements/Input/PasswordInput/PasswordInput.stories.tsx +31 -0
  195. package/src/Components/FormElements/Input/PasswordInput/PasswordInput.tsx +20 -16
  196. package/src/Components/FormElements/Input/input.module.scss +95 -0
  197. package/src/Components/FormElements/SearchSelectInput/SearchSelectInput.stories.tsx +49 -0
  198. package/src/Components/FormElements/SearchSelectInput/SearchSelectInput.tsx +178 -166
  199. package/src/Components/FormElements/SearchSelectInput/seachSelectInput.module.scss +112 -0
  200. package/src/Components/FormElements/Select/Select.stories.tsx +49 -0
  201. package/src/Components/FormElements/Select/Select.tsx +34 -24
  202. package/src/Components/FormElements/Select/select.module.scss +63 -0
  203. package/src/Components/FormElements/Slider/Slider.stories.tsx +15 -0
  204. package/src/Components/FormElements/Slider/Slider.tsx +29 -20
  205. package/src/Components/FormElements/Slider/slider.module.scss +93 -0
  206. package/src/Components/FormElements/Switch/Switch.stories.tsx +65 -0
  207. package/src/Components/FormElements/Switch/Switch.tsx +72 -63
  208. package/src/Components/FormElements/Switch/switch.module.scss +157 -0
  209. package/src/Components/FormElements/Textarea/Textarea.stories.tsx +37 -0
  210. package/src/Components/FormElements/Textarea/Textarea.tsx +46 -45
  211. package/src/Components/FormElements/Textarea/textarea.module.scss +34 -0
  212. package/src/Components/FormElements/hooks/useOnChangeDone.ts +6 -2
  213. package/src/Components/FullScreen/FullScreen.tsx +16 -16
  214. package/src/Components/Hooks/useBreakpoint.ts +13 -7
  215. package/src/Components/Hooks/useClientLayoutEffect.ts +1 -1
  216. package/src/Components/Hooks/useComposedRef.ts +2 -1
  217. package/src/Components/Hooks/useDebounced.ts +2 -2
  218. package/src/Components/Hooks/useDelayed.ts +2 -3
  219. package/src/Components/Hooks/useDelayedEffect.ts +3 -3
  220. package/src/Components/Hooks/useDelayedState.ts +18 -10
  221. package/src/Components/Hooks/useInViewport.ts +3 -2
  222. package/src/Components/Hooks/useKeyListener.ts +9 -6
  223. package/src/Components/Hooks/useListener.ts +4 -4
  224. package/src/Components/Hooks/useMousePosition.ts +2 -2
  225. package/src/Components/Hooks/useRerender.ts +17 -14
  226. package/src/Components/Hooks/useWindowDimensions.ts +11 -12
  227. package/src/Components/Icon/DoubleIcon.stories.tsx +38 -0
  228. package/src/Components/Icon/DoubleIcon.tsx +22 -17
  229. package/src/Components/Icon/Icon.stories.tsx +37 -0
  230. package/src/Components/Icon/Icon.tsx +39 -17
  231. package/src/Components/Icon/{icon.scss → icon.module.scss} +2 -0
  232. package/src/Components/Image/Image.stories.tsx +17 -0
  233. package/src/Components/Image/Image.tsx +7 -12
  234. package/src/Components/InViewport/InViewport.tsx +5 -6
  235. package/src/Components/Layout/Block.tsx +18 -12
  236. package/src/Components/Layout/Container.tsx +5 -6
  237. package/src/Components/Layout/Flex.tsx +17 -9
  238. package/src/Components/Layout/Grid/Grid.tsx +20 -10
  239. package/src/Components/Layout/Grid/GridItem.tsx +5 -6
  240. package/src/Components/Layout/Grid/{grid.scss → grid.module.scss} +19 -26
  241. package/src/Components/Layout/Grow.tsx +18 -8
  242. package/src/Components/Layout/Inline.tsx +15 -12
  243. package/src/Components/Layout/InlineBlock.tsx +17 -12
  244. package/src/Components/Layout/View.tsx +20 -9
  245. package/src/Components/Layout/ViewWithoutListeners.tsx +24 -15
  246. package/src/Components/Layout/container.module.scss +54 -0
  247. package/src/Components/LoadingArea/LoadingArea.stories.tsx +35 -0
  248. package/src/Components/LoadingArea/LoadingArea.tsx +10 -15
  249. package/src/Components/LoadingArea/{loadingArea.scss → loadingArea.module.scss} +8 -5
  250. package/src/Components/LoadingCircle/LoadingCircle.stories.tsx +58 -0
  251. package/src/Components/LoadingCircle/LoadingCircle.tsx +26 -13
  252. package/src/Components/LoadingCircle/{loadingCircle.scss → loadingCircle.module.scss} +14 -5
  253. package/src/Components/Menu/HoverMenu.stories.tsx +32 -0
  254. package/src/Components/Menu/HoverMenu.tsx +61 -45
  255. package/src/Components/Menu/Menu.stories.tsx +69 -0
  256. package/src/Components/Menu/Menu.tsx +67 -58
  257. package/src/Components/Menu/MenuCloseContext.ts +1 -1
  258. package/src/Components/Menu/MenuDivider.tsx +6 -6
  259. package/src/Components/Menu/MenuItem.stories.tsx +35 -0
  260. package/src/Components/Menu/MenuItem.tsx +66 -55
  261. package/src/Components/Menu/Submenu.stories.tsx +37 -0
  262. package/src/Components/Menu/Submenu.tsx +72 -58
  263. package/src/Components/Menu/{menu.scss → menu.module.scss} +23 -11
  264. package/src/Components/Menu/useMenu.ts +4 -3
  265. package/src/Components/RbmComponentProps.ts +6 -7
  266. package/src/Components/SizeCalculator/SizeCalculator.tsx +3 -3
  267. package/src/Components/SpoilerList/Spoiler/Spoiler.stories.tsx +21 -0
  268. package/src/Components/SpoilerList/Spoiler/Spoiler.tsx +49 -48
  269. package/src/Components/SpoilerList/Spoiler/{spoiler.scss → spoiler.module.scss} +46 -30
  270. package/src/Components/SpoilerList/SpoilerList.tsx +8 -12
  271. package/src/Components/SpoilerList/useSpoilerGroup.ts +2 -2
  272. package/src/Components/TabBar/TabBar.stories.tsx +32 -0
  273. package/src/Components/TabBar/TabBar.tsx +16 -18
  274. package/src/Components/TabBar/TabBarButton.tsx +13 -10
  275. package/src/Components/TabBar/tabBar.module.scss +128 -0
  276. package/src/Components/Table/Table.tsx +16 -15
  277. package/src/Components/Text/Heading.tsx +6 -7
  278. package/src/Components/Text/Text.stories.tsx +121 -0
  279. package/src/Components/Text/Text.tsx +19 -10
  280. package/src/Components/Text/{text.scss → text.module.scss} +3 -8
  281. package/src/Components/Toast/Toast.stories.tsx +25 -0
  282. package/src/Components/Toast/Toast.tsx +15 -17
  283. package/src/Components/Toast/ToastContainer.tsx +72 -54
  284. package/src/Components/Toast/ToastContext.ts +9 -3
  285. package/src/Components/Toast/toast.module.scss +65 -0
  286. package/src/Components/TopBar/MoreButton.tsx +9 -11
  287. package/src/Components/TopBar/TopBar.stories.tsx +63 -0
  288. package/src/Components/TopBar/TopBar.tsx +49 -40
  289. package/src/Components/TopBar/TopBarButton.tsx +20 -10
  290. package/src/Components/TopBar/{topBar.scss → topBar.module.scss} +40 -23
  291. package/src/Size.ts +1 -2
  292. package/src/WrongChildError.ts +1 -1
  293. package/src/helper/EmptyProps.ts +1 -1
  294. package/src/helper/nonEmptyString.ts +1 -1
  295. package/src/helper/useDeepShallow.ts +10 -0
  296. package/src/helper/withMemo.ts +7 -8
  297. package/src/helper/withRenderBrowserOnly.tsx +2 -1
  298. package/src/helper/withRestrictedChildren.tsx +11 -14
  299. package/src/index.ts +116 -0
  300. package/src/scss/_colors.scss +32 -19
  301. package/src/scss/_default.scss +5 -5
  302. package/src/scss/_flavorMixin.scss +3 -0
  303. package/src/scss/_variables.scss +19 -19
  304. package/src/scss/_vars.scss +12 -0
  305. package/src/scss/baseClasses.module.scss +23 -0
  306. package/src/scss/breakpoints.scss +79 -0
  307. package/src/treeshakeTest.ts +3 -0
  308. package/src/types/{react-table-config.d.ts → reactTableConfig.d.ts} +2 -43
  309. package/stylelint.config.mjs +4 -0
  310. package/tsconfig.build.json +7 -0
  311. package/tsconfig.json +16 -48
  312. package/webpack.config.ts +6 -0
  313. package/.eslintrc.json +0 -191
  314. package/.npnignore +0 -5
  315. package/LICENSE +0 -21
  316. package/README.md +0 -1
  317. package/babel.config.js +0 -22
  318. package/bin/build.js +0 -60
  319. package/bin/updateCopies.js +0 -94
  320. package/bootstrapReactMobile.ts +0 -119
  321. package/dist/bootstrapReactMobile.d.ts +0 -119
  322. package/dist/bootstrapReactMobile.js +0 -14043
  323. package/dist/bootstrapReactMobile.js.map +0 -1
  324. package/dist/src/Components/Card/Card.d.ts +0 -14
  325. package/dist/src/Components/Dialog/AlertDialog.d.ts +0 -10
  326. package/dist/src/Components/Dialog/ConfirmDialog.d.ts +0 -11
  327. package/dist/src/Components/FormElements/CheckBox/Checkbox.d.ts +0 -14
  328. package/dist/src/Components/FormElements/Controller/HookForm.d.ts +0 -8
  329. package/dist/src/Components/FormElements/FormError.d.ts +0 -5
  330. package/dist/src/Components/FormElements/Input/FileInput/FileInput.d.ts +0 -13
  331. package/dist/src/Components/FormElements/Input/HiddenInput.d.ts +0 -8
  332. package/dist/src/Components/Image/Image.d.ts +0 -12
  333. package/dist/src/Components/Layout/Grow.d.ts +0 -9
  334. package/dist/src/Components/List/BulletList/BulletList.d.ts +0 -8
  335. package/dist/src/Components/List/BulletList/ListItem.d.ts +0 -7
  336. package/dist/src/Components/List/InfiniteList.d.ts +0 -7
  337. package/dist/src/Components/List/List.d.ts +0 -15
  338. package/dist/src/Components/LoadingArea/LoadingArea.d.ts +0 -12
  339. package/dist/src/Components/LoadingCircle/LoadingCircle.d.ts +0 -8
  340. package/dist/src/Components/SpoilerList/Spoiler/Spoiler.d.ts +0 -18
  341. package/dist/src/Components/TabBar/TabBarButton.d.ts +0 -9
  342. package/dist/src/Components/Toast/Toast.d.ts +0 -13
  343. package/dist/src/Components/TopBar/MoreButton.d.ts +0 -9
  344. package/dist/src/Components/TopBar/TopBarButton.d.ts +0 -9
  345. package/dist/src/ListRow/ListRow.d.ts +0 -1
  346. package/dist/src/StyleProvider.d.ts +0 -2
  347. package/dist/src/helper/withMemo.d.ts +0 -3
  348. package/dist/src/helper/withRestrictedChildren.d.ts +0 -6
  349. package/scripts/getPackageJson.js +0 -25
  350. package/src/Components/ActionSheet/actionSheet.scss +0 -153
  351. package/src/Components/Card/card.scss +0 -76
  352. package/src/Components/Clickable/clickable.scss +0 -8
  353. package/src/Components/Dialog/dialog.scss +0 -30
  354. package/src/Components/Dialog/dialogBackground.scss +0 -11
  355. package/src/Components/FormElements/Button/button.scss +0 -73
  356. package/src/Components/FormElements/FormError.tsx +0 -29
  357. package/src/Components/FormElements/Input/input.scss +0 -83
  358. package/src/Components/FormElements/SearchSelectInput/seachSelectInput.scss +0 -97
  359. package/src/Components/FormElements/Select/select.scss +0 -61
  360. package/src/Components/FormElements/Slider/slider.scss +0 -92
  361. package/src/Components/FormElements/Switch/switch.scss +0 -152
  362. package/src/Components/FormElements/Textarea/textarea.scss +0 -31
  363. package/src/Components/FormElements/formError.scss +0 -4
  364. package/src/Components/Layout/container.scss +0 -12
  365. package/src/Components/List/BulletList/BulletList.tsx +0 -33
  366. package/src/Components/List/BulletList/ListItem.tsx +0 -34
  367. package/src/Components/List/InfiniteList.tsx +0 -56
  368. package/src/Components/List/List.tsx +0 -95
  369. package/src/Components/List/list.scss +0 -30
  370. package/src/Components/TabBar/tabBar.scss +0 -108
  371. package/src/Components/Toast/toast.scss +0 -55
  372. package/src/ListRow/ListRow.tsx +0 -20
  373. package/src/StyleProvider.ts +0 -4
  374. package/src/scss/_baseClasses.scss +0 -23
  375. package/src/types/isomorphic-style-loader.d.ts +0 -3
  376. package/webpack.config.js +0 -95
  377. /package/dist/{src/Components → Components}/Dialog/useAlertDialog.d.ts +0 -0
  378. /package/dist/{src/Components → Components}/Dialog/useConfirmDialog.d.ts +0 -0
  379. /package/dist/{src/Components → Components}/DragAndDrop/useStrictEnabled.d.ts +0 -0
  380. /package/dist/{src/Components → Components}/Flavor.d.ts +0 -0
  381. /package/dist/{src/Components → Components}/FormElements/Button/ButtonType.d.ts +0 -0
  382. /package/dist/{src/Components → Components}/FormElements/ColorInput/sharedSelectedColor.d.ts +0 -0
  383. /package/dist/{src/Components → Components}/FormElements/Controller/SendFormContext.d.ts +0 -0
  384. /package/dist/{src/Components → Components}/FormElements/Input/FileInput/FileType.d.ts +0 -0
  385. /package/dist/{src/Components → Components}/Hooks/useBreakpoint.d.ts +0 -0
  386. /package/dist/{src/Components → Components}/Hooks/useDebounced.d.ts +0 -0
  387. /package/dist/{src/Components → Components}/Hooks/useDelayed.d.ts +0 -0
  388. /package/dist/{src/Components → Components}/Hooks/useDelayedEffect.d.ts +0 -0
  389. /package/dist/{src/Components → Components}/Hooks/useKeyListener.d.ts +0 -0
  390. /package/dist/{src/Components → Components}/Hooks/useListener.d.ts +0 -0
  391. /package/dist/{src/Components → Components}/Hooks/useMousePosition.d.ts +0 -0
  392. /package/dist/{src/Components → Components}/Hooks/useOnMount.d.ts +0 -0
  393. /package/dist/{src/Components → Components}/Hooks/useOnce.d.ts +0 -0
  394. /package/dist/{src/Components → Components}/Hooks/useRerender.d.ts +0 -0
  395. /package/dist/{src/Components → Components}/Hooks/useWindowDimensions.d.ts +0 -0
  396. /package/dist/{src/Components → Components}/SpoilerList/useSpoilerGroup.d.ts +0 -0
  397. /package/dist/{src/Components → Components}/Toast/ToastContext.d.ts +0 -0
  398. /package/dist/{src/Size.d.ts → Size.d.ts} +0 -0
  399. /package/dist/{src/TypeHelpers.d.ts → TypeHelpers.d.ts} +0 -0
  400. /package/dist/{src/WindowContext → WindowContext}/WindowContext.d.ts +0 -0
  401. /package/dist/{src/WrongChildError.d.ts → WrongChildError.d.ts} +0 -0
  402. /package/dist/{src/helper → helper}/Characters.d.ts +0 -0
  403. /package/dist/{src/helper → helper}/DistributiveOmit.d.ts +0 -0
  404. /package/dist/{src/helper → helper}/EmptyProps.d.ts +0 -0
  405. /package/dist/{src/helper → helper}/memoComparator.d.ts +0 -0
  406. /package/dist/{src/helper → helper}/nonEmptyString.d.ts +0 -0
  407. /package/src/Components/FormElements/Input/PasswordInput/{passwordInput.scss → passwordInput.module.scss} +0 -0
  408. /package/src/Components/Image/{image.scss → image.module.scss} +0 -0
  409. /package/src/Components/InViewport/{inViewport.scss → inViewport.module.scss} +0 -0
  410. /package/src/Components/Layout/{layout.scss → layout.module.scss} +0 -0
  411. /package/src/Components/Text/{heading.scss → heading.module.scss} +0 -0
  412. /package/src/types/{scss-module.d.ts → scss.d.ts} +0 -0
@@ -0,0 +1,87 @@
1
+ @use "../../../scss/variables" as variables;
2
+ @use "../../../scss/designMixin" as mixin;
3
+ @use "../../../scss/flavorMixin" as *;
4
+ @use "../../../scss/vars" as *;
5
+
6
+ @include vars {
7
+ --button-primary-text-color: var(--text-inverse);
8
+ --button-disabled-opacity: var(--opacity-disabled);
9
+ }
10
+
11
+ @include mixin.design(variables.$material) {
12
+ --button-box-shadow-color: var(--box-shadow-color);
13
+ }
14
+
15
+ .button {
16
+ cursor: pointer;
17
+ margin: 0;
18
+ user-select: none;
19
+ text-overflow: ellipsis;
20
+ white-space: nowrap;
21
+ overflow: hidden;
22
+ text-decoration: none;
23
+ letter-spacing: 0;
24
+ vertical-align: middle;
25
+ border-radius: 3px;
26
+ transition: none;
27
+
28
+ @include flavorSelection(--button-background-color);
29
+
30
+ @include mixin.design(variables.$material) {
31
+ box-shadow: 0 2px 2px 0 var(--button-box-shadow-color),
32
+ 0 1px 5px 0 var(--button-box-shadow-color),
33
+ 0 3px 1px -2px var(--button-box-shadow-color);
34
+ min-height: 40px;
35
+ line-height: 40px;
36
+ padding: 0 16px;
37
+ text-align: center;
38
+ font-size: 14px;
39
+ text-transform: uppercase;
40
+ font-weight: 500;
41
+ }
42
+
43
+ @include mixin.design(variables.$flat) {
44
+ line-height: 32px;
45
+ padding: 4px 18px;
46
+ font-size: 17px;
47
+ }
48
+
49
+ &.primary {
50
+ background-color: var(--button-background-color);
51
+ border: 0 solid currentcolor;
52
+ color: var(--button-primary-text-color);
53
+
54
+ --text-primary-default-color: var(--button-primary-text-color);
55
+ }
56
+
57
+ &.secondary {
58
+ background-color: transparent;
59
+ border: 1px solid var(--button-background-color);
60
+ color: var(--button-background-color);
61
+
62
+ --text-primary-default-color: var(--button-background-color);
63
+ }
64
+
65
+ &.disabled {
66
+ opacity: var(--button-disabled-opacity);
67
+ cursor: default;
68
+ pointer-events: none;
69
+ }
70
+
71
+ &.small {
72
+ padding: 4px 8px;
73
+
74
+ @include mixin.design(variables.$material) {
75
+ min-height: 17px;
76
+ line-height: 17px;
77
+ }
78
+
79
+ @include mixin.design(variables.$flat) {
80
+ line-height: 17px;
81
+ }
82
+ }
83
+
84
+ &.fullWidth {
85
+ width: 100%;
86
+ }
87
+ }
@@ -0,0 +1,50 @@
1
+ import { Checkbox } from '@/Components/FormElements/CheckBox/Checkbox';
2
+ import React from 'react';
3
+ import type { Meta, StoryObj } from '@storybook/react-vite';
4
+
5
+ const meta = {
6
+ component: Checkbox,
7
+ argTypes: {},
8
+ args: {
9
+ checked: false,
10
+ label: 'Checkbox',
11
+ isLabelBeforeCheckbox: false,
12
+ error: '',
13
+ },
14
+ } satisfies Meta<typeof Checkbox>;
15
+
16
+ export default meta;
17
+
18
+ type Story = StoryObj<typeof meta>;
19
+
20
+ export const Default: Story = {
21
+ args: {},
22
+ };
23
+
24
+ export const Checked: Story = {
25
+ args: {
26
+ checked: true,
27
+ label: 'Checkbox',
28
+ isLabelBeforeCheckbox: false,
29
+ error: '',
30
+ },
31
+ };
32
+
33
+ export const WithError: Story = {
34
+ args: {
35
+ checked: true,
36
+ label: 'Checkbox',
37
+ isLabelBeforeCheckbox: false,
38
+ error: 'Error',
39
+ },
40
+ render: (args) => (
41
+ <>
42
+ <div>
43
+ <Checkbox {...args} checked={false} />
44
+ </div>
45
+ <div>
46
+ <Checkbox {...args} checked={true} />
47
+ </div>
48
+ </>
49
+ ),
50
+ };
@@ -1,12 +1,14 @@
1
1
  import * as React from 'react';
2
- import { RbmComponentProps } from '../../RbmComponentProps';
3
- import { ChangeEventHandler, InputHTMLAttributes, useCallback } from 'react';
4
- import styles from './checkbox.scss';
5
- import { withMemo } from '../../../helper/withMemo';
2
+ import { FormError } from '@/Components/FormElements/Error/FormError';
3
+ import { useCallback } from 'react';
4
+ import { useListenerWithExtractedProps } from '@/Components/Hooks/useListener';
5
+ import { withMemo } from '@/helper/withMemo';
6
6
  import classNames from 'classnames';
7
- import { Override } from '@ainias42/js-helper';
8
- import { OptionalListener, useListenerWithExtractedProps } from '../../Hooks/useListener';
9
- import { FormError } from "../FormError";
7
+ import styles from '@/Components/FormElements/CheckBox/checkbox.module.scss';
8
+ import type { ChangeEventHandler, InputHTMLAttributes } from 'react';
9
+ import type { OptionalListener } from '@/Components/Hooks/useListener';
10
+ import type { Override } from '@ainias42/js-helper';
11
+ import type { RbmComponentProps } from '@/Components/RbmComponentProps';
10
12
 
11
13
  export type CheckboxProps<OnChangeData, OnChangeCheckedData> = RbmComponentProps<
12
14
  Override<
@@ -21,7 +23,7 @@ export type CheckboxProps<OnChangeData, OnChangeCheckedData> = RbmComponentProps
21
23
  >
22
24
  >;
23
25
 
24
- function Checkbox<OnChangeData, OnChangeCheckedData>({
26
+ export const Checkbox = withMemo(function Checkbox<OnChangeData, OnChangeCheckedData>({
25
27
  children,
26
28
  label = '',
27
29
  isLabelBeforeCheckbox = false,
@@ -40,7 +42,7 @@ function Checkbox<OnChangeData, OnChangeCheckedData>({
40
42
  // Callbacks
41
43
  const [onChange, otherPropsWithoutChange] = useListenerWithExtractedProps<'onChange', OnChangeData>(
42
44
  'onChange',
43
- props
45
+ props,
44
46
  );
45
47
 
46
48
  const [onChangeChecked, otherPropsWithoutData] = useListenerWithExtractedProps<
@@ -53,7 +55,7 @@ function Checkbox<OnChangeData, OnChangeCheckedData>({
53
55
  onChangeChecked(e.target.checked);
54
56
  onChange(e);
55
57
  },
56
- [onChange, onChangeChecked]
58
+ [onChange, onChangeChecked],
57
59
  );
58
60
 
59
61
  // Effects
@@ -87,7 +89,4 @@ function Checkbox<OnChangeData, OnChangeCheckedData>({
87
89
  </label>
88
90
  </span>
89
91
  );
90
- }
91
-
92
- const tmp = withMemo(Checkbox, styles);
93
- export { tmp as Checkbox };
92
+ });
@@ -1,5 +1,20 @@
1
- @import "../../../scss/variables";
2
- @import "../../../scss/designMixin";
1
+ @use "../../../scss/variables" as variables;
2
+ @use "../../../scss/designMixin" as mixin;
3
+ @use "../../../scss/vars" as *;
4
+
5
+ @include vars {
6
+ --checkbox-checkmark-color: var(--text-inverse);
7
+ --checkbox-checked-background-color: var(--flavor-accent);
8
+ }
9
+
10
+ @include mixin.design(variables.$material) {
11
+ --checkbox-box-radius-color: var(--border-strong);
12
+ }
13
+
14
+ @include mixin.design(variables.$flat) {
15
+ --checkbox-box-radius-color: var(--border-light);
16
+ }
17
+
3
18
 
4
19
  .checkbox {
5
20
  position: relative;
@@ -37,27 +52,28 @@
37
52
  left: 0;
38
53
  }
39
54
 
40
- @include design($material) {
55
+ @include mixin.design(variables.$material) {
41
56
  width: 18px;
42
57
  min-width: 18px;
43
58
  height: 18px;
44
59
  margin: 2px;
45
60
 
46
61
  &::before {
47
- border: 2px solid var(--border-strong);
62
+ border: 2px solid var(--checkbox-box-radius-color);
48
63
  border-radius: 2px;
49
64
  transition: background-color 0.1s linear 0.2s, border-color 0.1s linear 0.2s;
50
65
  background-color: transparent;
51
66
  }
52
67
  }
53
- @include design($flat) {
68
+
69
+ @include mixin.design(variables.$flat) {
54
70
  width: 22px;
55
71
  min-width: 22px;
56
72
  height: 22px;
57
73
 
58
74
  &::before {
59
75
  background: transparent;
60
- border: 1px solid var(--border-light);
76
+ border: 1px solid var(--checkbox-box-radius-color);
61
77
  border-radius: 22px;
62
78
  }
63
79
  }
@@ -72,20 +88,21 @@
72
88
  background: transparent;
73
89
  border-radius: 0;
74
90
  transform: rotate(-45deg);
75
- border: 2px none #fff;
91
+ border: 2px none var(--checkbox-checkmark-color);
76
92
  border-bottom-style: solid;
77
93
  border-left-style: solid;
78
94
  }
79
95
 
80
96
  &::before {
81
- background-color: var(--flavor-accent);
97
+ background-color: var(--checkbox-checked-background-color);
82
98
  }
83
99
 
84
- @include design($material) {
100
+ @include mixin.design(variables.$material) {
85
101
  &::before {
86
- border: 2px solid var(--flavor-accent);
102
+ border: 2px solid var(--checkbox-checked-background-color);
87
103
  transition: background-color 0.1s linear, border-color 0.1s linear;
88
104
  }
105
+
89
106
  &::after {
90
107
  transition: transform 0.2s ease 0.2s;
91
108
  top: 5px;
@@ -94,10 +111,12 @@
94
111
 
95
112
  }
96
113
  }
97
- @include design($flat) {
114
+
115
+ @include mixin.design(variables.$flat) {
98
116
  &::before {
99
117
  border: none;
100
118
  }
119
+
101
120
  &::after {
102
121
  top: 7px;
103
122
  left: 5px;
@@ -0,0 +1,24 @@
1
+ import { ColorInput } from '@/Components/FormElements/ColorInput/ColorInput';
2
+ import type { Meta, StoryObj } from '@storybook/react-vite';
3
+
4
+ const meta = {
5
+ component: ColorInput,
6
+ } satisfies Meta<typeof ColorInput>;
7
+
8
+ export default meta;
9
+
10
+ type Story = StoryObj<typeof meta>;
11
+
12
+ export const Default: Story = {
13
+ args: {
14
+ disableAlpha: false,
15
+ },
16
+ };
17
+
18
+ export const WithLabelAndError: Story = {
19
+ args: {
20
+ label: 'Select Color',
21
+ error: 'Wrong Color',
22
+ disableAlpha: false,
23
+ },
24
+ };
@@ -1,14 +1,17 @@
1
1
  import * as React from 'react';
2
- import { useCallback, useRef, useState, MouseEvent, useMemo } from 'react';
3
- import { ColorResult, Sketch } from '@uiw/react-color';
4
- import { OptionalListener, useListener } from '../../Hooks/useListener';
5
- import { withMemo } from '../../../helper/withMemo';
6
- import styles from './colorInput.scss';
7
- import { useSharedSelectedColor } from './sharedSelectedColor';
8
- import { Menu } from "../../Menu/Menu";
9
- import { useClientLayoutEffect } from "../../Hooks/useClientLayoutEffect";
10
- import { FormError } from "../FormError";
11
- import classNames from "classnames";
2
+ import { FormError } from '@/Components/FormElements/Error/FormError';
3
+ import { Menu } from '@/Components/Menu/Menu';
4
+ import { Sketch } from '@uiw/react-color';
5
+ import { useCallback, useMemo, useRef, useState } from 'react';
6
+ import { useClientLayoutEffect } from '@/Components/Hooks/useClientLayoutEffect';
7
+ import { useListener } from '@/Components/Hooks/useListener';
8
+ import { useSharedSelectedColor } from '@/Components/FormElements/ColorInput/sharedSelectedColor';
9
+ import { withMemo } from '@/helper/withMemo';
10
+ import classNames from 'classnames';
11
+ import styles from '@/Components/FormElements/ColorInput/colorInput.module.scss';
12
+ import type { ColorResult } from '@uiw/react-color';
13
+ import type { MouseEvent } from 'react';
14
+ import type { OptionalListener } from '@/Components/Hooks/useListener';
12
15
 
13
16
  export type ColorInputProps<OnChangeData> = {
14
17
  defaultValue?: string;
@@ -20,26 +23,26 @@ export type ColorInputProps<OnChangeData> = {
20
23
  disableAlpha?: boolean;
21
24
  presetColors?: string[];
22
25
  sharedColorKey?: string;
23
- disabled?: boolean
26
+ disabled?: boolean;
24
27
  error?: string;
25
28
  className?: string;
26
29
  } & OptionalListener<'onChange', OnChangeData, ColorResult>;
27
30
 
28
- function ColorInput<OnChangeData>({
29
- defaultValue,
30
- value,
31
- label,
32
- onChangeColor,
33
- onOpen,
34
- onClose,
35
- disableAlpha,
36
- presetColors,
37
- error,
38
- sharedColorKey = "default",
39
- disabled,
31
+ export const ColorInput = withMemo(function ColorInput<OnChangeData>({
32
+ defaultValue,
33
+ value,
34
+ label,
35
+ onChangeColor,
36
+ onOpen,
37
+ onClose,
38
+ disableAlpha,
39
+ presetColors,
40
+ error,
41
+ sharedColorKey = 'default',
42
+ disabled,
40
43
  className,
41
- ...otherProps
42
- }: ColorInputProps<OnChangeData>) {
44
+ ...otherProps
45
+ }: ColorInputProps<OnChangeData>) {
43
46
  // Variables
44
47
  // useStyles(styles);
45
48
 
@@ -49,18 +52,18 @@ function ColorInput<OnChangeData>({
49
52
  // States
50
53
  const [color, setColor] = useState<string>(value ?? defaultValue ?? '#000000FF');
51
54
  const [isOpen, setIsOpen] = useState(false);
52
- const [position, setPosition] = useState({x: 0, y: 0});
55
+ const [position, setPosition] = useState({ x: 0, y: 0 });
53
56
 
54
- const {colors, addColor} = useSharedSelectedColor(sharedColorKey, presetColors);
57
+ const { colors, addColor } = useSharedSelectedColor(sharedColorKey, presetColors);
55
58
  const realIsOpen = disabled !== true && isOpen;
56
59
 
57
60
  const colVal = useMemo(() => {
58
61
  const newVal = value ?? color;
59
62
  if (disableAlpha && newVal.length === 9) {
60
- return newVal.substring(0, 7);
63
+ return newVal.slice(0, 7);
61
64
  }
62
65
  if (disableAlpha && newVal.length === 5) {
63
- return newVal.substring(0,4);
66
+ return newVal.slice(0, 4);
64
67
  }
65
68
  return newVal;
66
69
  }, [value, color, disableAlpha]);
@@ -78,17 +81,14 @@ function ColorInput<OnChangeData>({
78
81
  }
79
82
  onChangeWithData(newColor);
80
83
  },
81
- [onChangeColor, onChangeWithData]
84
+ [onChangeColor, onChangeWithData],
82
85
  );
83
86
 
84
- const onMenuClose = useCallback(
85
- () => {
86
- setIsOpen(false);
87
- addColor(colVal);
88
- onClose?.(colVal);
89
- },
90
- [addColor, colVal, onClose]
91
- );
87
+ const onMenuClose = useCallback(() => {
88
+ setIsOpen(false);
89
+ addColor(colVal);
90
+ onClose?.(colVal);
91
+ }, [addColor, colVal, onClose]);
92
92
 
93
93
  const openElement = useCallback(
94
94
  (e: MouseEvent) => {
@@ -97,10 +97,10 @@ function ColorInput<OnChangeData>({
97
97
  }
98
98
 
99
99
  setIsOpen(true);
100
- setPosition({x: e.clientX, y: e.clientY});
100
+ setPosition({ x: e.clientX, y: e.clientY });
101
101
  onOpen?.(colVal);
102
102
  },
103
- [colVal, disabled, onOpen]
103
+ [colVal, disabled, onOpen],
104
104
  );
105
105
 
106
106
  // Effects
@@ -125,25 +125,21 @@ function ColorInput<OnChangeData>({
125
125
  // Render Functions
126
126
  return (
127
127
  <>
128
- <span className={classNames(styles.colorInput, className)}>
129
- <Menu x={position.x} y={position.y} isOpen={realIsOpen} onClose={onMenuClose}>
130
- <Sketch
131
- color={colVal}
132
- onChange={onChange}
133
- disableAlpha={disableAlpha}
134
- presetColors={presetColors ?? colors}
135
- />
136
- </Menu>
137
- <span onClick={openElement} className={styles.label}>
138
- {label}
128
+ <span className={classNames(styles.colorInput, className)}>
129
+ <Menu x={position.x} y={position.y} isOpen={realIsOpen} onClose={onMenuClose}>
130
+ <Sketch
131
+ color={colVal}
132
+ onChange={onChange}
133
+ disableAlpha={disableAlpha}
134
+ presetColors={presetColors ?? colors}
135
+ />
136
+ </Menu>
137
+ <span onClick={openElement} className={styles.label}>
138
+ {label}
139
+ </span>
140
+ <span onClick={openElement} style={{ backgroundColor: colVal }} className={styles.preview} />
139
141
  </span>
140
- <span onClick={openElement} style={{backgroundColor: colVal}} className={styles.preview}/>
141
- </span>
142
- <FormError error={error}/>
142
+ <FormError error={error} />
143
143
  </>
144
144
  );
145
- }
146
-
147
- // Need ColorInputMemo for autocompletion of phpstorm
148
- const ColorInputMemo = withMemo(ColorInput, styles);
149
- export { ColorInputMemo as ColorInput };
145
+ });
@@ -1,3 +1,11 @@
1
+ @use "../../../scss/vars" as *;
2
+
3
+ @include vars {
4
+ --color-input-transparent-color-background: repeating-conic-gradient(#cccccc 0% 25%, #ffffff 0% 50%);
5
+ --color-input-modal-z-index: 9999;
6
+ --color-input-modal-background-color: var(--foreground-primary);
7
+ }
8
+
1
9
  .colorInput {
2
10
  display: flex;
3
11
 
@@ -9,36 +17,29 @@
9
17
  border: 1px solid black;
10
18
  position: relative;
11
19
 
12
- &:before {
20
+ &::before {
13
21
  content: '';
14
22
  position: absolute;
15
- top: 0;
16
- left: 0;
17
- right: 0;
18
- bottom: 0;
23
+ inset: 0;
19
24
  display: block;
20
25
  width: 100%;
21
26
  height: 100%;
22
27
  z-index: -1;
23
- background: repeating-conic-gradient(#cccccc 0% 25%, #ffffff 0% 50%);
28
+ background: var(--color-input-transparent-color-background);
24
29
  }
25
-
26
30
  }
27
31
 
28
32
  .modalContainer {
29
- z-index: 9999;
33
+ z-index: var(--color-input-modal-z-index);
30
34
  position: fixed;
31
- top: 0;
32
- left: 0;
33
- right: 0;
34
- bottom: 0;
35
+ inset: 0;
35
36
  width: 100vw;
36
37
  height: 100vh;
37
38
  overflow: auto;
38
39
 
39
40
  .modal {
40
41
  position: absolute;
41
- background-color: white;
42
+ background-color: var(--color-input-modal-background-color);
42
43
  }
43
44
  }
44
45
 
@@ -55,18 +56,15 @@
55
56
  > div {
56
57
  position: relative;
57
58
 
58
- &:before {
59
+ &::before {
59
60
  content: '';
60
61
  position: absolute;
61
- top: 0;
62
- left: 0;
63
- right: 0;
64
- bottom: 0;
62
+ inset: 0;
65
63
  display: block;
66
64
  width: 100%;
67
65
  height: 100%;
68
66
  z-index: -1;
69
- background: repeating-conic-gradient(#cccccc 0% 25%, #ffffff 0% 50%);
67
+ background: var(--color-input-transparent-color-background);
70
68
  }
71
69
  }
72
70
  }
@@ -1,13 +1,17 @@
1
- import { useCallback, useLayoutEffect, useMemo, useRef, useState } from 'react';
2
1
  import { Random } from '@ainias42/js-helper';
2
+ import { useCallback, useLayoutEffect, useMemo, useRef, useState } from 'react';
3
3
 
4
4
  const sharedSelectedColor: Record<string, { colors: string[]; updateFunctions: (() => void)[] }> = {};
5
5
 
6
- function localStorageKey (key: string) {
6
+ function localStorageKey(key: string) {
7
7
  return `sharedSelectedColor-${key}`;
8
- };
8
+ }
9
9
 
10
- export function useSharedSelectedColor(key: string|undefined, predefinedColors: string[] = [], numberSavedColors = 16) {
10
+ export function useSharedSelectedColor(
11
+ key: string | undefined,
12
+ predefinedColors: string[] = [],
13
+ numberSavedColors = 16,
14
+ ) {
11
15
  const shouldSaveToLocalStorage = typeof window !== 'undefined' && window.localStorage !== undefined && !!key;
12
16
  const [, setVersion] = useState(1);
13
17
  const innerKey = useRef(Random.getStringRandom(12));
@@ -32,24 +36,26 @@ export function useSharedSelectedColor(key: string|undefined, predefinedColors:
32
36
  }
33
37
 
34
38
  sharedSelectedColor[realKey].colors = sharedSelectedColor[realKey].colors.filter(
35
- (color) => color !== newColor
39
+ (color) => color !== newColor,
36
40
  );
37
41
  sharedSelectedColor[realKey].colors.unshift(newColor);
38
42
  if (sharedSelectedColor[realKey].colors.length > numberSavedColors) {
39
43
  sharedSelectedColor[realKey].colors.splice(numberSavedColors, 1);
40
44
  }
41
- if (shouldSaveToLocalStorage){
45
+ if (shouldSaveToLocalStorage) {
42
46
  localStorage.setItem(localStorageKey(realKey), JSON.stringify(sharedSelectedColor[realKey].colors));
43
47
  }
44
48
 
45
49
  // triggers rerender
46
- sharedSelectedColor[realKey].updateFunctions.forEach((u) => u());
50
+ for (const u of sharedSelectedColor[realKey].updateFunctions) {
51
+ u();
52
+ }
47
53
  },
48
- [numberSavedColors, predefinedColors, realKey, shouldSaveToLocalStorage]
54
+ [numberSavedColors, predefinedColors, realKey, shouldSaveToLocalStorage],
49
55
  );
50
56
 
51
57
  useLayoutEffect(() => {
52
- if (shouldSaveToLocalStorage){
58
+ if (shouldSaveToLocalStorage) {
53
59
  const savedColors = localStorage.getItem(localStorageKey(realKey));
54
60
  if (savedColors) {
55
61
  sharedSelectedColor[realKey].colors = JSON.parse(savedColors);
@@ -60,7 +66,10 @@ export function useSharedSelectedColor(key: string|undefined, predefinedColors:
60
66
 
61
67
  const realColors = useMemo(() => {
62
68
  if (predefinedColors.length > 0) {
63
- return [...predefinedColors, ...sharedSelectedColor[realKey].colors.filter(color => !predefinedColors.includes(color))].slice(0, numberSavedColors);
69
+ return [
70
+ ...predefinedColors,
71
+ ...sharedSelectedColor[realKey].colors.filter((color) => !predefinedColors.includes(color)),
72
+ ].slice(0, numberSavedColors);
64
73
  }
65
74
  return sharedSelectedColor[realKey].colors;
66
75
  }, [numberSavedColors, predefinedColors, realKey]);
@@ -1,4 +1,4 @@
1
- import { withHookController } from "./withHookController";
2
- import { ColorInput } from "../ColorInput/ColorInput";
1
+ import { ColorInput } from '@/Components/FormElements/ColorInput/ColorInput';
2
+ import { withHookController } from '@/Components/FormElements/Controller/withHookController';
3
3
 
4
- export const ColorInputController = withHookController(ColorInput, "onChangeColor");
4
+ export const ColorInputController = withHookController(ColorInput, 'onChangeColor');