@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,66 +1,73 @@
1
1
  import * as React from 'react';
2
- import { RbmComponentProps } from '../RbmComponentProps';
3
- import { Container } from '../Layout/Container';
4
-
5
- import styles from './toast.scss';
2
+ import { Container } from '@/Components/Layout/Container';
3
+ import { ObjectHelper } from '@ainias42/js-helper';
4
+ import { Toast } from '@/Components/Toast/Toast';
5
+ import { ToastContext } from '@/Components/Toast/ToastContext';
6
+ import { useCallback, useRef, useState } from 'react';
7
+ import { withMemo } from '@/helper/withMemo';
6
8
  import classNames from 'classnames';
7
- import { withMemo } from '../../helper/withMemo';
8
- import { EmptyProps } from '../../helper/EmptyProps';
9
- import { useCallback, useRef, useState } from "react";
10
- import { ObjectHelper, URecord } from "@ainias42/js-helper";
11
- import { Toast } from "./Toast";
12
- import { Text } from "../Text/Text";
13
- import { ToastContext } from "./ToastContext";
9
+ import styles from '@/Components/Toast/toast.module.scss';
10
+ import type { EmptyProps } from '@/helper/EmptyProps';
11
+ import type { RbmComponentProps } from '@/Components/RbmComponentProps';
12
+ import type { URecord } from '@ainias42/js-helper';
14
13
 
15
14
  export type ToastContainerProps = RbmComponentProps<EmptyProps>;
16
15
 
17
- function ToastContainer({className, children, style}: ToastContainerProps) {
16
+ function ToastContainer({ className, children, style }: ToastContainerProps) {
18
17
  // Variables
19
18
 
20
19
  // States
21
20
  const lastId = useRef(0);
22
- const [toasts, setToasts] = useState<URecord<number, {
23
- id: number,
24
- text: string,
25
- duration: number,
26
- action?: { name: string, onClick: (data?: any) => void, onClickData?: any }
27
- }>>({});
21
+ const [toasts, setToasts] = useState<
22
+ URecord<
23
+ number,
24
+ {
25
+ id: number;
26
+ text: string;
27
+ duration: number;
28
+ action?: { name: string; onClick: (data?: any) => void; onClickData?: any };
29
+ }
30
+ >
31
+ >({});
28
32
 
29
33
  // Refs
30
34
 
31
35
  // Callbacks
32
36
  const removeToast = useCallback((id: number) => {
33
37
  setToasts((oldToasts) => {
34
- const newToasts = {...oldToasts};
38
+ const newToasts = { ...oldToasts };
35
39
  delete newToasts[id];
36
40
  return newToasts;
37
41
  });
38
42
  }, []);
39
43
 
40
- const addToast = useCallback((
41
- text: string,
42
- action?: {
43
- name: string,
44
- onClick: (data?: any) => void,
45
- onClickData?: any
46
- },
47
- duration = 2500
48
- ) => {
49
- lastId.current++;
50
- const id = lastId.current;
44
+ const addToast = useCallback(
45
+ (
46
+ text: string,
47
+ action?: {
48
+ name: string;
49
+ onClick: (data?: any) => void;
50
+ onClickData?: any;
51
+ },
52
+ duration = 2500,
53
+ ) => {
54
+ lastId.current++;
55
+ const id = lastId.current;
51
56
 
52
- setToasts((oldToasts) => {
53
- return {
54
- ...oldToasts,
55
- [id]: {
56
- id,
57
- text,
58
- duration,
59
- action
60
- }
61
- };
62
- });
63
- }, []);
57
+ setToasts((oldToasts) => {
58
+ return {
59
+ ...oldToasts,
60
+ [id]: {
61
+ id,
62
+ text,
63
+ duration,
64
+ action,
65
+ },
66
+ };
67
+ });
68
+ },
69
+ [],
70
+ );
64
71
 
65
72
  // Effects
66
73
 
@@ -71,21 +78,32 @@ function ToastContainer({className, children, style}: ToastContainerProps) {
71
78
  return (
72
79
  <ToastContext.Provider value={addToast}>
73
80
  {children}
74
- <Container className={classNames(styles.toastContainer, className)} fluid __allowChildren="all"
75
- style={style}>
76
- {ObjectHelper.values(toasts).map((toast) => <Toast key={toast.id}
77
- timeToShow={toast.duration}
78
- onDismissed={removeToast}
79
- onDismissedData={toast.id} {...(toast.action ? {
80
- ...toast.action,
81
- actionName: toast.action.name
82
- } : {})}>
83
- <Text>{toast.text}</Text>
84
- </Toast>)}
81
+ <Container
82
+ className={classNames(styles.toastContainer, className)}
83
+ fluid
84
+ __allowChildren="all"
85
+ style={style}
86
+ >
87
+ {ObjectHelper.values(toasts).map((toast) => (
88
+ <Toast
89
+ key={toast.id}
90
+ timeToShow={toast.duration}
91
+ onDismissed={removeToast}
92
+ onDismissedData={toast.id}
93
+ {...(toast.action
94
+ ? {
95
+ ...toast.action,
96
+ actionName: toast.action.name,
97
+ }
98
+ : {})}
99
+ >
100
+ {toast.text}
101
+ </Toast>
102
+ ))}
85
103
  </Container>
86
104
  </ToastContext.Provider>
87
105
  );
88
106
  }
89
107
 
90
- const ToastContainerMemo = withMemo(ToastContainer, styles);
108
+ const ToastContainerMemo = withMemo(ToastContainer);
91
109
  export { ToastContainerMemo as ToastContainer };
@@ -1,7 +1,13 @@
1
- import { createContext, useContext } from "react";
1
+ import { createContext, useContext } from 'react';
2
2
 
3
- export const ToastContext = createContext<<Data>(text: string, action?: {name: string, onClick: (data?: Data) => void, onClickData?: Data }, duration?: number) => void>(() => {
4
- console.error("ToastContext not initialized");
3
+ export const ToastContext = createContext<
4
+ <Data>(
5
+ text: string,
6
+ action?: { name: string; onClick: (data?: Data) => void; onClickData?: Data },
7
+ duration?: number,
8
+ ) => void
9
+ >(() => {
10
+ console.error('ToastContext not initialized');
5
11
  });
6
12
 
7
13
  export function useToast() {
@@ -0,0 +1,65 @@
1
+ @use "sass:map";
2
+ @use "../../scss/variables" as variables;
3
+ @use "../../scss/designMixin" as mixin;
4
+ @use "../../scss/vars" as *;
5
+
6
+ @include vars {
7
+ --toast-z-index: 1001;
8
+ --toast-background-color: var(--curtain-strong);
9
+ --toast-text-color: var(--text-inverse);
10
+ }
11
+
12
+ @include mixin.design(variables.$material) {
13
+ --toast-action-text-color: var(--text-inverse);
14
+ }
15
+
16
+ @include mixin.design(variables.$flat) {
17
+ --toast-action-text-color: var(--text-inverse);
18
+ }
19
+
20
+ .toastContainer {
21
+ pointer-events: none;
22
+ position: fixed;
23
+ left: 0;
24
+ right: 0;
25
+ bottom: 3rem;
26
+ margin: auto;
27
+ max-width: map.get(variables.$grid-breakpoints, "sm");
28
+ z-index: var(--toast-z-index);
29
+ display: flex;
30
+ align-items: center;
31
+ flex-direction: column;
32
+ }
33
+
34
+ .toast {
35
+ --text-primary-default-color: var(--toast-text-color);
36
+
37
+ pointer-events: auto;
38
+ background-color: var(--toast-background-color);
39
+ min-height: 48px;
40
+ line-height: 1.5;
41
+ color: var(--toast-text-color);
42
+ font-size: 0.77rem;
43
+ letter-spacing: normal;
44
+ transition-duration: 0.25s;
45
+ margin: 8px;
46
+
47
+ &.hiding {
48
+ opacity: 0;
49
+ }
50
+
51
+ @include mixin.design(variables.$material) {
52
+ padding: 16px 24px;
53
+ }
54
+
55
+ @include mixin.design(variables.$flat) {
56
+ border-radius: 0.5rem;
57
+ padding: 16px;
58
+ }
59
+
60
+ .action {
61
+ text-transform: uppercase;
62
+ margin-left: 24px;
63
+ color: var(--toast-action-text-color)
64
+ }
65
+ }
@@ -1,17 +1,18 @@
1
1
  import * as React from 'react';
2
- import { RbmComponentProps } from '../RbmComponentProps';
3
- import { TopBarButton } from './TopBarButton';
4
- import { Icon } from '../Icon/Icon';
2
+ import { Icon } from '@/Components/Icon/Icon';
3
+ import { TopBarButton } from '@/Components/TopBar/TopBarButton';
5
4
  import { faEllipsisH, faEllipsisV } from '@fortawesome/free-solid-svg-icons';
5
+ import { withMemo } from '@/helper/withMemo';
6
+ import type { RbmComponentProps } from '@/Components/RbmComponentProps';
6
7
 
7
- import { withMemo } from '../../helper/withMemo';
8
+ import baseStyles from '@/scss/baseClasses.module.scss';
8
9
 
9
10
  export type MoreButtonProps = RbmComponentProps<{
10
11
  disabled?: boolean;
11
12
  onClick?: () => void;
12
13
  }>;
13
14
 
14
- function MoreButton({ onClick, disabled, className, style }: MoreButtonProps) {
15
+ export const MoreButton = withMemo(function MoreButton({ onClick, disabled, className, style }: MoreButtonProps) {
15
16
  // Variables
16
17
 
17
18
  // States
@@ -28,11 +29,8 @@ function MoreButton({ onClick, disabled, className, style }: MoreButtonProps) {
28
29
 
29
30
  return (
30
31
  <TopBarButton onClick={onClick} disabled={disabled} className={className} style={style}>
31
- <Icon icon={faEllipsisH} className="material-hidden" />
32
- <Icon icon={faEllipsisV} className="flat-hidden" />
32
+ <Icon icon={faEllipsisH} className={baseStyles.materialHidden} />
33
+ <Icon icon={faEllipsisV} className={baseStyles.flatHidden} />
33
34
  </TopBarButton>
34
35
  );
35
- }
36
-
37
- const MoreButtonMemo = withMemo(MoreButton);
38
- export { MoreButtonMemo as MoreButton };
36
+ });
@@ -0,0 +1,63 @@
1
+ import type { Meta, StoryObj } from '@storybook/react-vite';
2
+
3
+ import { TopBar } from '@/Components/TopBar/TopBar';
4
+ import { faCog, faHome, faSearch, faUser } from '@fortawesome/free-solid-svg-icons';
5
+ import { fn } from 'storybook/test';
6
+
7
+ const meta = {
8
+ component: TopBar,
9
+ } satisfies Meta<typeof TopBar>;
10
+
11
+ export default meta;
12
+
13
+ type Story = StoryObj<typeof meta>;
14
+
15
+ export const Default: Story = {
16
+ args: {
17
+ title: 'Title',
18
+ rightButtons: [
19
+ {
20
+ title: 'Button 1',
21
+ action: fn(),
22
+ icon: faHome,
23
+ },
24
+ {
25
+ title: 'Button 1',
26
+ action: fn(),
27
+ icon: faSearch,
28
+ },
29
+ {
30
+ title: 'Button 1',
31
+ action: fn(),
32
+ icon: faUser,
33
+ disabled: true,
34
+ },
35
+ ],
36
+ leftButtons: [
37
+ {
38
+ title: 'Button 1',
39
+ action: fn(),
40
+ icon: faCog,
41
+ },
42
+ ],
43
+ hiddenButtons: [
44
+ {
45
+ title: 'Button 1',
46
+ action: fn(),
47
+ icon: faHome,
48
+ },
49
+ {
50
+ title: 'Button 2',
51
+ action: fn(),
52
+ icon: faSearch,
53
+ },
54
+ {
55
+ title: 'Button 3',
56
+ action: fn(),
57
+ icon: faCog,
58
+ },
59
+ ],
60
+ transparent: false,
61
+ drawBehind: true,
62
+ },
63
+ };
@@ -1,21 +1,24 @@
1
1
  import * as React from 'react';
2
- import { ComponentType, ReactElement, useCallback, useMemo, useRef, useState } from 'react';
3
- import { Container } from '../Layout/Container';
4
- import { TopBarButton } from './TopBarButton';
5
- import { RbmComponentProps } from '../RbmComponentProps';
6
- import { ActionSheet, ActionSheetAction } from '../ActionSheet/ActionSheet';
7
- import { Icon, IconSource } from '../Icon/Icon';
8
- import { MoreButton } from './MoreButton';
9
-
10
- import styles from './topBar.scss';
11
-
12
- import { withMemo } from '../../helper/withMemo';
2
+ import { ActionSheet } from '@/Components/ActionSheet/ActionSheet';
3
+ import { Container } from '@/Components/Layout/Container';
4
+ import { Icon } from '@/Components/Icon/Icon';
5
+ import { MoreButton } from '@/Components/TopBar/MoreButton';
6
+ import { TopBarButton } from '@/Components/TopBar/TopBarButton';
7
+ import { useCallback, useMemo, useRef, useState } from 'react';
8
+ import type { ComponentType, ReactElement } from 'react';
9
+ import type { RbmComponentProps } from '@/Components/RbmComponentProps';
10
+
11
+ import styles from '@/Components/TopBar/topBar.module.scss';
12
+
13
+ import { Block } from '@/Components/Layout/Block';
14
+ import { Flex } from '@/Components/Layout/Flex';
15
+ import { Inline } from '@/Components/Layout/Inline';
16
+ import { Text } from '@/Components/Text/Text';
17
+ import { View } from '@/Components/Layout/View';
18
+ import { withMemo } from '@/helper/withMemo';
13
19
  import classNames from 'classnames';
14
- import { Block } from '../Layout/Block';
15
- import { Text } from '../Text/Text';
16
- import { Flex } from '../Layout/Flex';
17
- import { Inline } from '../Layout/Inline';
18
- import { View } from '../Layout/View';
20
+ import type { ActionSheetAction } from '@/Components/ActionSheet/ActionSheet';
21
+ import type { IconSource } from '@/Components/Icon/Icon';
19
22
 
20
23
  export type TopBarActionButtonType = {
21
24
  order?: number;
@@ -46,11 +49,11 @@ function getButtonComponents(buttons: TopBarButtonType[]) {
46
49
  const key = button.key ?? String(index);
47
50
  if ('component' in button) {
48
51
  const Component = button.component;
49
- return <Component {...button} key={key} onClick={button.action}/>;
52
+ return <Component {...button} key={key} onClick={button.action} />;
50
53
  }
51
54
  let child: string | ReactElement | undefined = button.title;
52
55
  if (button.icon) {
53
- child = <Icon icon={button.icon}/>;
56
+ child = <Icon icon={button.icon} />;
54
57
  }
55
58
  return (
56
59
  <TopBarButton key={key} onClick={button.action} disabled={button.disabled} __allowChildren="all">
@@ -60,16 +63,16 @@ function getButtonComponents(buttons: TopBarButtonType[]) {
60
63
  });
61
64
  }
62
65
 
63
- function TopBar({
64
- title = '',
65
- rightButtons: unsortedRightButtons = [],
66
- leftButtons: unsortedLeftButtons = [],
67
- hiddenButtons: unsortedHiddenButtons = [],
68
- className,
69
- transparent = false,
70
- drawBehind = false,
71
- ...rbmProps
72
- }: TopBarProps) {
66
+ export const TopBar = withMemo(function TopBar({
67
+ title = '',
68
+ rightButtons: unsortedRightButtons = [],
69
+ leftButtons: unsortedLeftButtons = [],
70
+ hiddenButtons: unsortedHiddenButtons = [],
71
+ className,
72
+ transparent = false,
73
+ drawBehind = false,
74
+ ...rbmProps
75
+ }: TopBarProps) {
73
76
  const [isHiddenMenuOpen, setIsHiddenMenuOpen] = useState(false);
74
77
 
75
78
  if (isHiddenMenuOpen) {
@@ -77,9 +80,18 @@ function TopBar({
77
80
  }
78
81
 
79
82
  const actionSheetRef = useRef<React.ElementRef<typeof ActionSheet>>(null);
80
- let rightButtons = useMemo(() => unsortedRightButtons.sort((a, b) => (a.order ?? 0) - (b.order ?? 0)), [unsortedRightButtons]);
81
- const leftButtons = useMemo(() => unsortedLeftButtons.sort((a, b) => (a.order ?? 0) - (b.order ?? 0)), [unsortedLeftButtons]);
82
- let hiddenButtons = useMemo(() => unsortedHiddenButtons.sort((a, b) => (a.order ?? 0) - (b.order ?? 0)), [unsortedHiddenButtons]);
83
+ let rightButtons = useMemo(
84
+ () => unsortedRightButtons.sort((a, b) => (a.order ?? 0) - (b.order ?? 0)),
85
+ [unsortedRightButtons],
86
+ );
87
+ const leftButtons = useMemo(
88
+ () => unsortedLeftButtons.sort((a, b) => (a.order ?? 0) - (b.order ?? 0)),
89
+ [unsortedLeftButtons],
90
+ );
91
+ let hiddenButtons = useMemo(
92
+ () => unsortedHiddenButtons.sort((a, b) => (a.order ?? 0) - (b.order ?? 0)),
93
+ [unsortedHiddenButtons],
94
+ );
83
95
 
84
96
  const toggleHiddenMenu = useCallback(() => {
85
97
  setIsHiddenMenuOpen((isOpen) => {
@@ -120,12 +132,12 @@ function TopBar({
120
132
  }
121
133
  },
122
134
  })),
123
- [hiddenButtons]
135
+ [hiddenButtons],
124
136
  );
125
137
 
126
138
  const rightButtonComponents = getButtonComponents(rightButtons);
127
139
  const leftButtonComponents = getButtonComponents(leftButtons);
128
- const hiddenButtonComponents = getButtonComponents(hiddenButtons.map(({icon: _, ...button}) => button));
140
+ const hiddenButtonComponents = getButtonComponents(hiddenButtons.map(({ icon: _, ...button }) => button));
129
141
 
130
142
  const actions: ActionSheetAction<any>[] = useMemo(
131
143
  () =>
@@ -134,7 +146,7 @@ function TopBar({
134
146
  name: button.title!,
135
147
  icon: button.icon,
136
148
  })),
137
- [hiddenButtons]
149
+ [hiddenButtons],
138
150
  );
139
151
 
140
152
  return (
@@ -146,7 +158,7 @@ function TopBar({
146
158
  [styles.transparent]: transparent,
147
159
  [styles.drawBehind]: drawBehind,
148
160
  },
149
- className
161
+ className,
150
162
  )}
151
163
  >
152
164
  <Container fluid="xxl" className={styles.container}>
@@ -161,7 +173,7 @@ function TopBar({
161
173
  </Flex>
162
174
  {hiddenButtons.length > 0 && isHiddenMenuOpen ? (
163
175
  <Inline className={styles.hiddenContainer}>
164
- <View aria-hidden={true} className={styles.hiddenCloseCurtain} onClick={toggleHiddenMenu}/>
176
+ <View aria-hidden={true} className={styles.hiddenCloseCurtain} onClick={toggleHiddenMenu} />
165
177
  <View className={styles.hiddenMenu}>{hiddenButtonComponents}</View>
166
178
  </Inline>
167
179
  ) : null}
@@ -174,7 +186,4 @@ function TopBar({
174
186
  </Container>
175
187
  </nav>
176
188
  );
177
- }
178
-
179
- const TopBarMemo = withMemo(TopBar, styles);
180
- export { TopBarMemo as TopBar };
189
+ });
@@ -1,27 +1,37 @@
1
1
  import * as React from 'react';
2
- import { RbmComponentProps } from '../RbmComponentProps';
3
-
4
- import styles from './topBar.scss';
2
+ import { withMemo } from '@/helper/withMemo';
5
3
  import classNames from 'classnames';
6
- import { withMemo } from '../../helper/withMemo';
4
+ import styles from '@/Components/TopBar/topBar.module.scss';
5
+ import type { RbmComponentProps } from '@/Components/RbmComponentProps';
7
6
 
8
7
  export type TopBarButtonProps = RbmComponentProps<{
9
8
  disabled?: boolean;
10
9
  onClick?: () => void;
11
10
  }>;
12
11
 
13
- function TopBarButton({ disabled = false, onClick, className, children, ...rbmProps }: TopBarButtonProps) {
12
+ export const TopBarButton = withMemo(function TopBarButton({
13
+ disabled = false,
14
+ onClick,
15
+ className,
16
+ children,
17
+ ...rbmProps
18
+ }: TopBarButtonProps) {
14
19
  return (
15
20
  <a
16
21
  role="button"
22
+ tabIndex={0}
17
23
  {...rbmProps}
18
24
  onClick={onClick}
19
- className={classNames(styles.button, { [styles.disabled]: disabled, [styles.active]: !disabled && onClick }, className)}
25
+ className={classNames(
26
+ styles.button,
27
+ {
28
+ [styles.disabled]: disabled,
29
+ [styles.active]: !disabled && onClick,
30
+ },
31
+ className,
32
+ )}
20
33
  >
21
34
  {children}
22
35
  </a>
23
36
  );
24
- }
25
-
26
- const TopBarButtonMemo = withMemo(TopBarButton, styles);
27
- export { TopBarButtonMemo as TopBarButton };
37
+ });