@ainias42/react-bootstrap-mobile 1.0.1 → 1.0.2

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 +40 -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
@@ -1,23 +1,29 @@
1
- import { FileInput, FileInputProps } from "../Input/FileInput/FileInput";
2
- import React, { useCallback } from "react";
3
- import { FieldPath, FieldValues, useController, useFormContext, useFormState } from "react-hook-form";
4
- import { FileType } from "../Input/FileInput/FileType";
5
- import { withMemo } from "../../../helper/withMemo";
6
-
1
+ import { FileInput } from '@/Components/FormElements/Input/FileInput/FileInput';
2
+ import { useController, useFormContext, useFormState } from 'react-hook-form';
3
+ import { withMemo } from '@/helper/withMemo';
4
+ import React, { useCallback } from 'react';
5
+ import type { FieldPath, FieldValues } from 'react-hook-form';
6
+ import type { FileInputProps } from '@/Components/FormElements/Input/FileInput/FileInput';
7
+ import type { FileType } from '@/Components/FormElements/Input/FileInput/FileType';
7
8
 
8
9
  type Props<Values extends FieldValues, Name extends FieldPath<Values> = FieldPath<Values>> = Omit<
9
10
  FileInputProps<unknown>,
10
- 'name' | 'onBlur' | 'ref' | 'value' | "__allowChildren" | "children"|"onChangeFile"|"error"
11
+ 'name' | 'onBlur' | 'ref' | 'value' | '__allowChildren' | 'children' | 'onChangeFile' | 'error'
11
12
  > & { name: Name };
12
13
 
13
- export const FileInputController = withMemo(function FileInputController<Values extends FieldValues, Name extends FieldPath<Values> = FieldPath<Values>>(
14
- {name, ...otherProps}: Props<Values, Name>,
15
- ) {
16
- const {field, fieldState} = useController({name});
17
- const {errors} = useFormState();
14
+ export const FileInputController = withMemo(function FileInputController<
15
+ Values extends FieldValues,
16
+ Name extends FieldPath<Values> = FieldPath<Values>,
17
+ >({ name, ...otherProps }: Props<Values, Name>) {
18
+ const { field, fieldState } = useController({ name });
19
+ const { errors } = useFormState();
18
20
 
19
- const {clearErrors, setError} = useFormContext();
20
- const errorMessage = fieldState.error?.message ?? errors[`${name}.src`]?.message as string|undefined ?? errors[`${name}.name`]?.message as string|undefined ?? errors[`${name}.type`]?.message as string|undefined;
21
+ const { clearErrors, setError } = useFormContext();
22
+ const errorMessage =
23
+ fieldState.error?.message ??
24
+ (errors[`${name}.src`]?.message as string | undefined) ??
25
+ (errors[`${name}.name`]?.message as string | undefined) ??
26
+ (errors[`${name}.type`]?.message as string | undefined);
21
27
 
22
28
  const internalOnChange = useCallback(
23
29
  (arg: FileType | undefined) => {
@@ -27,14 +33,17 @@ export const FileInputController = withMemo(function FileInputController<Values
27
33
  clearErrors(`${name}.type`);
28
34
  field.onChange(arg);
29
35
  },
30
- [clearErrors, field, name]
36
+ [clearErrors, field, name],
31
37
  );
32
38
 
33
- const setErrorMessage = useCallback((error: string) => {
34
- setError(name, {
35
- message: error,
36
- });
37
- }, [name, setError]);
39
+ const setErrorMessage = useCallback(
40
+ (error: string) => {
41
+ setError(name, {
42
+ message: error,
43
+ });
44
+ },
45
+ [name, setError],
46
+ );
38
47
 
39
48
  return (
40
49
  <FileInput
@@ -1,43 +1,147 @@
1
- import React, { useCallback } from 'react';
2
- import { FormProvider, FormProviderProps } from "react-hook-form";
3
- import { withMemo } from "../../../helper/withMemo";
4
- import { LoadingArea } from "../../LoadingArea/LoadingArea";
5
- import { SendFormContext } from "./SendFormContext";
1
+ import { FormError } from '@/Components/FormElements/Error/FormError';
2
+ import { FormProvider } from 'react-hook-form';
3
+ import { LoadingArea } from '@/Components/LoadingArea/LoadingArea';
4
+ import { SendFormContext } from '@/Components/FormElements/Controller/SendFormContext';
5
+ import { withMemo } from '@/helper/withMemo';
6
+ import React, { useCallback, useEffect } from 'react';
7
+ import type { Awaitable } from '@ainias42/js-helper';
8
+ import type { FieldPath, FormProviderProps, Path } from 'react-hook-form';
6
9
 
7
10
  type FieldValues = Record<string, any>;
8
- export type HookFormProps<TFieldValues extends FieldValues = FieldValues, TContext = any, TTransformedValues extends FieldValues | undefined = undefined> =
9
- FormProviderProps<TFieldValues, TContext, TTransformedValues>
10
- & {
11
- onSend?: () => void;
11
+ export type HookFormProps<
12
+ TFieldValues extends FieldValues = FieldValues,
13
+ TContext = any,
14
+ TTransformedValues extends FieldValues | undefined = undefined,
15
+ > = FormProviderProps<TFieldValues, TContext, TTransformedValues> & {
16
+ onSave?: (partialNewData: Partial<TFieldValues>, newData: TFieldValues) => Awaitable<void>;
17
+ handleErrors?: (error: unknown) => [string, { message: string }][];
18
+ onUnhandledError?: (error: unknown) => void;
19
+ isSaveOnChange?: boolean;
20
+ saveFullData?: boolean;
12
21
  };
13
22
 
14
- export const HookForm = withMemo(function HookForm<TFieldValues extends FieldValues = FieldValues, TContext = any, TTransformedValues extends FieldValues | undefined = undefined>({
15
- children,
16
- onSend,
17
- ...methods
18
- }: HookFormProps<TFieldValues, TContext, TTransformedValues>) {
23
+ export const HookForm = withMemo(function HookForm<
24
+ TFieldValues extends FieldValues = FieldValues,
25
+ TContext = any,
26
+ TTransformedValues extends FieldValues | undefined = undefined,
27
+ >({
28
+ children,
29
+ isSaveOnChange = false,
30
+ onSave,
31
+ saveFullData = false,
32
+ watch,
33
+ getValues,
34
+ setError,
35
+ trigger,
36
+ handleErrors,
37
+ onUnhandledError,
38
+ ...methods
39
+ }: HookFormProps<TFieldValues, TContext, TTransformedValues>) {
19
40
  // Refs
20
41
 
21
42
  // States/Variables/Selectors
22
-
23
- // Create an inner, as the onSend may have other attributes
24
- const innerOnSend = useCallback(() => onSend?.(), [onSend]);
43
+ const [unhanldedError, setUnhandledError] = React.useState<string | undefined>(undefined);
25
44
 
26
45
  // Dispatch
27
46
 
28
47
  // Callbacks
48
+ const handleUnhandledError = useCallback(
49
+ (error: unknown) => {
50
+ if (onUnhandledError) {
51
+ onUnhandledError(error);
52
+ } else if (typeof error === 'string') {
53
+ setUnhandledError(error);
54
+ } else {
55
+ setUnhandledError(String(error));
56
+ }
57
+ },
58
+ [onUnhandledError],
59
+ );
60
+
61
+ const handleError = useCallback(
62
+ (error: unknown) => {
63
+ const errors = handleErrors?.(error);
64
+ if (!errors) {
65
+ handleUnhandledError(error);
66
+ return;
67
+ }
68
+
69
+ const unhandledErrors: string[] = [];
70
+ const formFields = getValues();
71
+ for (const [key, errorMessage] of errors) {
72
+ const keyParts = key.split('.');
73
+ const lastKey = keyParts.at(-1);
74
+ setError(lastKey as FieldPath<TFieldValues>, errorMessage);
75
+ if (lastKey && !(lastKey in formFields)) {
76
+ unhandledErrors.push(`${lastKey}: ${errorMessage.message}`);
77
+ }
78
+ }
79
+
80
+ if (unhandledErrors.length) {
81
+ handleUnhandledError(unhandledErrors.join('\n'));
82
+ }
83
+ },
84
+ [getValues, handleErrors, handleUnhandledError, setError],
85
+ );
86
+
87
+ const checkDataAndSave = useCallback(
88
+ async (data: TFieldValues, name: Path<TFieldValues> | undefined, forceFullSave = false, throwError = false) => {
89
+ setUnhandledError(undefined);
90
+ const shouldSaveFullData = forceFullSave || saveFullData;
91
+ if (!(await trigger(shouldSaveFullData ? undefined : name))) {
92
+ return;
93
+ }
94
+
95
+ try {
96
+ if (!shouldSaveFullData) {
97
+ if (name) {
98
+ const firstPart = name.split('.')[0];
99
+ await onSave?.({ [firstPart]: data[firstPart] } as TFieldValues, data);
100
+ }
101
+ } else {
102
+ await onSave?.(data, data);
103
+ }
104
+ } catch (error) {
105
+ handleError(error);
106
+ if (throwError) {
107
+ throw error;
108
+ }
109
+ }
110
+ },
111
+ [handleError, onSave, saveFullData, trigger],
112
+ );
113
+
114
+ const innerOnSend = useCallback(
115
+ () => checkDataAndSave(getValues(), undefined, true, true),
116
+ [checkDataAndSave, getValues],
117
+ );
29
118
 
30
119
  // Effects
120
+ useEffect(() => {
121
+ if (!isSaveOnChange) {
122
+ return undefined;
123
+ }
124
+
125
+ const { unsubscribe } = watch((data, info) => {
126
+ if (info.type === 'change') {
127
+ checkDataAndSave(data as TFieldValues, info.name);
128
+ }
129
+ });
130
+ return unsubscribe;
131
+ }, [watch, checkDataAndSave, isSaveOnChange]);
31
132
 
32
133
  // Other
33
134
 
34
135
  // RenderFunctions
35
136
 
36
- return <FormProvider {...methods}>
37
- <SendFormContext.Provider value={innerOnSend}>
38
- <LoadingArea loading={methods.formState.isSubmitting} __allowChildren="all">
39
- {children}
40
- </LoadingArea>
41
- </SendFormContext.Provider>
42
- </FormProvider>;
137
+ return (
138
+ <FormProvider {...methods} watch={watch} trigger={trigger} getValues={getValues} setError={setError}>
139
+ <SendFormContext.Provider value={innerOnSend}>
140
+ <LoadingArea loading={methods.formState.isSubmitting} __allowChildren="all">
141
+ {children}
142
+ <FormError error={unhanldedError} />
143
+ </LoadingArea>
144
+ </SendFormContext.Provider>
145
+ </FormProvider>
146
+ );
43
147
  });
@@ -1,4 +1,4 @@
1
- import { Input } from "../Input/Input";
2
- import { withHookController } from "./withHookController";
1
+ import { Input } from '@/Components/FormElements/Input/Input';
2
+ import { withHookController } from '@/Components/FormElements/Controller/withHookController';
3
3
 
4
- export const InputController = withHookController(Input, "onChangeText");
4
+ export const InputController = withHookController(Input, 'onChangeText');
@@ -1,5 +1,4 @@
1
- import { MultipleFileInput } from "../Input/FileInput/MultipleFileInput";
2
- import { withHookController } from "./withHookController";
1
+ import { MultipleFileInput } from '@/Components/FormElements/Input/FileInput/MultipleFileInput';
2
+ import { withHookController } from '@/Components/FormElements/Controller/withHookController';
3
3
 
4
- // TODO Error handling(?)
5
4
  export const MultipleFileInputController = withHookController(MultipleFileInput, 'onChangeFiles');
@@ -1,4 +1,4 @@
1
- import { withHookController } from "./withHookController";
2
- import { PasswordInput } from "../Input/PasswordInput/PasswordInput";
1
+ import { PasswordInput } from '@/Components/FormElements/Input/PasswordInput/PasswordInput';
2
+ import { withHookController } from '@/Components/FormElements/Controller/withHookController';
3
3
 
4
- export const PasswordInputController = withHookController(PasswordInput, "onChangeText");
4
+ export const PasswordInputController = withHookController(PasswordInput, 'onChangeText');
@@ -1,4 +1,4 @@
1
- import { withHookController } from "./withHookController";
2
- import { Select } from "../Select/Select";
1
+ import { Select } from '@/Components/FormElements/Select/Select';
2
+ import { withHookController } from '@/Components/FormElements/Controller/withHookController';
3
3
 
4
- export const SelectController = withHookController(Select, "onChangeValue");
4
+ export const SelectController = withHookController(Select, 'onChangeValue');
@@ -1,7 +1,7 @@
1
- import { createContext, useContext } from "react";
1
+ import { createContext, useContext } from 'react';
2
2
 
3
- export const SendFormContext = createContext<(() => void)|undefined>(undefined);
3
+ export const SendFormContext = createContext<(() => void) | undefined>(undefined);
4
4
 
5
- export function useSendFormContext(){
5
+ export function useSendFormContext() {
6
6
  return useContext(SendFormContext);
7
7
  }
@@ -0,0 +1,4 @@
1
+ import { Slider } from '@/Components/FormElements/Slider/Slider';
2
+ import { withHookController } from '@/Components/FormElements/Controller/withHookController';
3
+
4
+ export const SliderController = withHookController(Slider, 'onChangeValue');
@@ -1,4 +1,4 @@
1
- import { Switch } from "../Switch/Switch";
2
- import { withHookController } from "./withHookController";
1
+ import { Switch } from '@/Components/FormElements/Switch/Switch';
2
+ import { withHookController } from '@/Components/FormElements/Controller/withHookController';
3
3
 
4
- export const SwitchController = withHookController(Switch, "onChangeChecked");
4
+ export const SwitchController = withHookController(Switch, 'onChangeChecked');
@@ -1,4 +1,4 @@
1
- import { withHookController } from "./withHookController";
2
- import { Textarea } from "../Textarea/Textarea";
1
+ import { Textarea } from '@/Components/FormElements/Textarea/Textarea';
2
+ import { withHookController } from '@/Components/FormElements/Controller/withHookController';
3
3
 
4
4
  export const TextareaController = withHookController(Textarea, 'onChangeText');
@@ -1,9 +1,11 @@
1
1
  import { useCallback } from 'react';
2
- import { AnyObject, InferType, Maybe, ObjectSchema, ValidationError } from 'yup';
2
+ import type { AnyObject, InferType, Maybe, ObjectSchema, ValidationError } from 'yup';
3
3
 
4
4
  // TODO set translate function from somewhere else
5
- export function useYupResolver<ObjectType extends Maybe<AnyObject>>(validationSchema: ObjectSchema<ObjectType>, translate: (key: string, args?: Record<string, string | number>) => string) {
6
-
5
+ export function useYupResolver<ObjectType extends Maybe<AnyObject>>(
6
+ validationSchema: ObjectSchema<ObjectType>,
7
+ translate: (key: string, args?: Record<string, string | number>) => string,
8
+ ) {
7
9
  return useCallback(
8
10
  async (data: InferType<ObjectSchema<ObjectType>>) => {
9
11
  try {
@@ -15,8 +17,8 @@ export function useYupResolver<ObjectType extends Maybe<AnyObject>>(validationSc
15
17
  values,
16
18
  errors: {},
17
19
  };
18
- } catch (errors) {
19
- const reducedErrors = (errors.inner as ValidationError[]).reduce(
20
+ } catch (error) {
21
+ const reducedErrors = (error as { inner: ValidationError[] }).inner.reduce(
20
22
  (allErrors, currentError) => {
21
23
  if (currentError.path === undefined) {
22
24
  return allErrors;
@@ -25,9 +27,9 @@ export function useYupResolver<ObjectType extends Maybe<AnyObject>>(validationSc
25
27
  let message = currentError.message as
26
28
  | string
27
29
  | {
28
- key: string;
29
- args?: Record<string, string | number>;
30
- };
30
+ key: string;
31
+ args?: Record<string, string | number>;
32
+ };
31
33
  if (typeof message === 'object') {
32
34
  message = translate(message.key, message.args);
33
35
  } else {
@@ -1,14 +1,15 @@
1
- import React, {
2
- ComponentProps,
3
- ComponentRef,
4
- ComponentType, ForwardedRef,
5
- useCallback
6
- } from "react";
7
- import { FieldPath, FieldValues, useController, useFormContext } from "react-hook-form";
8
- import { useComposedRef } from "../../Hooks/useComposedRef";
9
- import { withMemo } from "../../../helper/withMemo";
1
+ import { useComposedRef } from '@/Components/Hooks/useComposedRef';
2
+ import { useController, useFormContext } from 'react-hook-form';
3
+ import { withMemo } from '@/helper/withMemo';
4
+ import React, { useCallback } from 'react';
5
+ import type { ComponentProps, ComponentRef, ComponentType, ForwardedRef } from 'react';
6
+ import type { FieldPath, FieldValues } from 'react-hook-form';
10
7
 
11
- export function withHookController<C extends ComponentType<any>, OnChangeProp extends keyof ComponentProps<C>>(Comp: C, onChangeProp: OnChangeProp, emptyValue: any = null) {
8
+ export function withHookController<C extends ComponentType<any>, OnChangeProp extends keyof ComponentProps<C>>(
9
+ Comp: C,
10
+ onChangeProp: OnChangeProp,
11
+ emptyValue: any = null,
12
+ ) {
12
13
  type RefType = ComponentRef<C>;
13
14
  type OldProps = ComponentProps<C>;
14
15
 
@@ -17,13 +18,15 @@ export function withHookController<C extends ComponentType<any>, OnChangeProp ex
17
18
  'name' | 'onBlur' | OnChangeProp | 'value'
18
19
  > & { name: Name };
19
20
 
20
- function WithHookComponent<Values extends FieldValues, Name extends FieldPath<Values> = FieldPath<Values>>(
21
- {name, ref, ...otherProps}: Props<Values, Name> & {ref?: ForwardedRef<RefType>},
22
- ) {
23
- const children = "children" in otherProps ? otherProps.children : undefined;
21
+ function WithHookComponent<Values extends FieldValues, Name extends FieldPath<Values> = FieldPath<Values>>({
22
+ name,
23
+ ref,
24
+ ...otherProps
25
+ }: Props<Values, Name> & { ref?: ForwardedRef<RefType> }) {
26
+ const children = 'children' in otherProps ? otherProps.children : undefined;
24
27
 
25
- const {field, fieldState} = useController({name});
26
- const {clearErrors} = useFormContext();
28
+ const { field, fieldState } = useController({ name });
29
+ const { clearErrors } = useFormContext();
27
30
  const composedRef = useComposedRef(ref, field.ref);
28
31
  const errorMessage = fieldState.error?.message;
29
32
 
@@ -32,10 +35,10 @@ export function withHookController<C extends ComponentType<any>, OnChangeProp ex
32
35
  clearErrors(name);
33
36
  field.onChange(arg);
34
37
  },
35
- [clearErrors, field, name]
38
+ [clearErrors, field, name],
36
39
  );
37
40
  const onChangeProps = {
38
- [onChangeProp]: internalOnChange
41
+ [onChangeProp]: internalOnChange,
39
42
  };
40
43
 
41
44
  return (
@@ -0,0 +1,16 @@
1
+ import { FormError } from '@/Components/FormElements/Error/FormError';
2
+ import type { Meta, StoryObj } from '@storybook/react-vite';
3
+
4
+ const meta = {
5
+ component: FormError,
6
+ } satisfies Meta<typeof FormError>;
7
+
8
+ export default meta;
9
+
10
+ type Story = StoryObj<typeof meta>;
11
+
12
+ export const Default: Story = {
13
+ args: {
14
+ error: 'Wrong Value',
15
+ },
16
+ };
@@ -0,0 +1,42 @@
1
+ import { Block } from '@/Components/Layout/Block';
2
+ import { InlineBlock } from '@/Components/Layout/InlineBlock';
3
+ import { TEXT_SIZE, Text } from '@/Components/Text/Text';
4
+ import { withMemo } from '@/helper/withMemo';
5
+ import React from 'react';
6
+ import styles from '@/Components/FormElements/Error/formError.module.scss';
7
+
8
+ export type FormErrorProps = { error?: string; inline?: boolean };
9
+
10
+ export const FormError = withMemo(function FormError({ error, inline }: FormErrorProps) {
11
+ // Refs
12
+
13
+ // States/Variables/Selectors
14
+
15
+ // Dispatch
16
+
17
+ // Callbacks
18
+
19
+ // Effects
20
+
21
+ // Other
22
+
23
+ // RenderFunctions
24
+
25
+ if (!error) {
26
+ return null;
27
+ }
28
+
29
+ if (inline) {
30
+ return (
31
+ <InlineBlock className={styles.error}>
32
+ <Text size={TEXT_SIZE.small}>{error}</Text>
33
+ </InlineBlock>
34
+ );
35
+ }
36
+
37
+ return (
38
+ <Block className={styles.error}>
39
+ <Text size={TEXT_SIZE.small}>{error}</Text>
40
+ </Block>
41
+ );
42
+ });
@@ -0,0 +1,9 @@
1
+ @use "../../../scss/vars" as *;
2
+
3
+ @include vars {
4
+ --error-text-color: var(--flavor-destructive)
5
+ }
6
+
7
+ .error {
8
+ --text-primary-default-color: var(--error-text-color)
9
+ }
@@ -0,0 +1,16 @@
1
+ import { FormError } from '@/Components/FormElements/Error/FormError';
2
+ import type { Meta, StoryObj } from '@storybook/react-vite';
3
+
4
+ const meta = {
5
+ component: FormError,
6
+ } satisfies Meta<typeof FormError>;
7
+
8
+ export default meta;
9
+
10
+ type Story = StoryObj<typeof meta>;
11
+
12
+ export const Default: Story = {
13
+ args: {
14
+ error: 'Wrong Value',
15
+ },
16
+ };
@@ -1,55 +1,75 @@
1
1
  import * as React from 'react';
2
- import { RbmComponentProps } from '../../../RbmComponentProps';
3
- import { Override } from '../../../../TypeHelpers';
2
+ import { MultipleFileInput } from '@/Components/FormElements/Input/FileInput/MultipleFileInput';
4
3
  import { useCallback, useMemo } from 'react';
5
- import { Listener, useListenerWithExtractedProps } from '../../../Hooks/useListener';
6
- import styles from './fileInput.scss';
7
- import { withMemo } from '../../../../helper/withMemo';
8
- import { FileType } from "./FileType";
9
- import { MultipleFileInput, MultipleFileInputProps } from "./MultipleFileInput";
10
-
4
+ import { useListenerWithExtractedProps } from '@/Components/Hooks/useListener';
5
+ import { withMemo } from '@/helper/withMemo';
6
+ import type { FileType } from '@/Components/FormElements/Input/FileInput/FileType';
7
+ import type { Listener } from '@/Components/Hooks/useListener';
8
+ import type { MultipleFileInputProps } from '@/Components/FormElements/Input/FileInput/MultipleFileInput';
9
+ import type { Override } from '@/TypeHelpers';
10
+ import type { RbmComponentProps } from '@/Components/RbmComponentProps';
11
11
 
12
12
  export type FileInputProps<OnChangeFileData> = RbmComponentProps<
13
13
  Override<
14
- Omit<MultipleFileInputProps<unknown>, "onChangeFiles" | "maxFiles" | "onChangeFilesData" | "mimeTypes" | "showDeleteButton">, {
15
- value?: FileType,
16
- mimeType?: string | string[],
17
- required?: boolean,
18
- "data-test-id"?: string;
19
- } & Listener<'onChangeFile', OnChangeFileData, FileType | undefined>>
14
+ Omit<
15
+ MultipleFileInputProps<unknown>,
16
+ 'onChangeFiles' | 'maxFiles' | 'onChangeFilesData' | 'mimeTypes' | 'showDeleteButton'
17
+ >,
18
+ {
19
+ value?: FileType;
20
+ mimeType?: string | string[];
21
+ required?: boolean;
22
+ 'data-test-id'?: string;
23
+ } & Listener<'onChangeFile', OnChangeFileData, FileType | undefined>
24
+ >
20
25
  >;
21
26
 
22
27
  export const FileInput = withMemo(function FileInput<OnChangeData>({
23
- value,
24
- mimeType,
25
- required = false,
26
- ...otherProps
27
- }: FileInputProps<OnChangeData>) {
28
+ value,
29
+ mimeType,
30
+ required = false,
31
+ ...otherProps
32
+ }: FileInputProps<OnChangeData>) {
28
33
  // Variables
29
34
 
30
35
  // Refs
31
36
 
32
37
  // States
33
- const mimeTypes = useMemo(() => (mimeType ? (Array.isArray(mimeType) ? mimeType : [mimeType]) : undefined), [mimeType]);
34
- const innerValue = useMemo(() => value ? [value] : [], [value]);
38
+ const mimeTypes = useMemo(
39
+ () => (mimeType ? (Array.isArray(mimeType) ? mimeType : [mimeType]) : undefined),
40
+ [mimeType],
41
+ );
42
+ const innerValue = useMemo(() => (value ? [value] : []), [value]);
35
43
 
36
44
  // Selectors
37
45
 
38
46
  // Callbacks
39
- const [onChangeFile, multipleFileInputProps] = useListenerWithExtractedProps<"onChangeFile", OnChangeData>("onChangeFile", otherProps);
40
- const onChangeFiles = useCallback((files: FileType[]) => {
41
- if (!required || files[0]) {
42
- console.log("LOG-d onChangeFile", files[0]);
43
- onChangeFile(files[0]);
44
- }
45
- }, [onChangeFile, required]);
47
+ const [onChangeFile, multipleFileInputProps] = useListenerWithExtractedProps<'onChangeFile', OnChangeData>(
48
+ 'onChangeFile',
49
+ otherProps,
50
+ );
51
+ const onChangeFiles = useCallback(
52
+ (files: FileType[]) => {
53
+ if (!required || files[0]) {
54
+ onChangeFile(files[0]);
55
+ }
56
+ },
57
+ [onChangeFile, required],
58
+ );
46
59
 
47
60
  // Effects
48
61
 
49
62
  // Other
50
63
 
51
64
  // Render Functions
52
- return <MultipleFileInput maxFiles={1} value={innerValue} onChangeFiles={onChangeFiles}
53
- mimeTypes={mimeTypes} showDeleteButton={!required} {...multipleFileInputProps}/>;
54
-
55
- }, styles);
65
+ return (
66
+ <MultipleFileInput
67
+ maxFiles={1}
68
+ value={innerValue}
69
+ onChangeFiles={onChangeFiles}
70
+ mimeTypes={mimeTypes}
71
+ showDeleteButton={!required}
72
+ {...multipleFileInputProps}
73
+ />
74
+ );
75
+ });