@ainias42/react-bootstrap-mobile 1.0.0 → 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 -14091
  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 -94
  377. /package/dist/{src/Components → Components}/Dialog/useAlertDialog.d.ts +0 -0
  378. /package/dist/{src/Components → Components}/Dialog/useConfirmDialog.d.ts +0 -0
  379. /package/dist/{src/Components → Components}/DragAndDrop/useStrictEnabled.d.ts +0 -0
  380. /package/dist/{src/Components → Components}/Flavor.d.ts +0 -0
  381. /package/dist/{src/Components → Components}/FormElements/Button/ButtonType.d.ts +0 -0
  382. /package/dist/{src/Components → Components}/FormElements/ColorInput/sharedSelectedColor.d.ts +0 -0
  383. /package/dist/{src/Components → Components}/FormElements/Controller/SendFormContext.d.ts +0 -0
  384. /package/dist/{src/Components → Components}/FormElements/Input/FileInput/FileType.d.ts +0 -0
  385. /package/dist/{src/Components → Components}/Hooks/useBreakpoint.d.ts +0 -0
  386. /package/dist/{src/Components → Components}/Hooks/useDebounced.d.ts +0 -0
  387. /package/dist/{src/Components → Components}/Hooks/useDelayed.d.ts +0 -0
  388. /package/dist/{src/Components → Components}/Hooks/useDelayedEffect.d.ts +0 -0
  389. /package/dist/{src/Components → Components}/Hooks/useKeyListener.d.ts +0 -0
  390. /package/dist/{src/Components → Components}/Hooks/useListener.d.ts +0 -0
  391. /package/dist/{src/Components → Components}/Hooks/useMousePosition.d.ts +0 -0
  392. /package/dist/{src/Components → Components}/Hooks/useOnMount.d.ts +0 -0
  393. /package/dist/{src/Components → Components}/Hooks/useOnce.d.ts +0 -0
  394. /package/dist/{src/Components → Components}/Hooks/useRerender.d.ts +0 -0
  395. /package/dist/{src/Components → Components}/Hooks/useWindowDimensions.d.ts +0 -0
  396. /package/dist/{src/Components → Components}/SpoilerList/useSpoilerGroup.d.ts +0 -0
  397. /package/dist/{src/Components → Components}/Toast/ToastContext.d.ts +0 -0
  398. /package/dist/{src/Size.d.ts → Size.d.ts} +0 -0
  399. /package/dist/{src/TypeHelpers.d.ts → TypeHelpers.d.ts} +0 -0
  400. /package/dist/{src/WindowContext → WindowContext}/WindowContext.d.ts +0 -0
  401. /package/dist/{src/WrongChildError.d.ts → WrongChildError.d.ts} +0 -0
  402. /package/dist/{src/helper → helper}/Characters.d.ts +0 -0
  403. /package/dist/{src/helper → helper}/DistributiveOmit.d.ts +0 -0
  404. /package/dist/{src/helper → helper}/EmptyProps.d.ts +0 -0
  405. /package/dist/{src/helper → helper}/memoComparator.d.ts +0 -0
  406. /package/dist/{src/helper → helper}/nonEmptyString.d.ts +0 -0
  407. /package/src/Components/FormElements/Input/PasswordInput/{passwordInput.scss → passwordInput.module.scss} +0 -0
  408. /package/src/Components/Image/{image.scss → image.module.scss} +0 -0
  409. /package/src/Components/InViewport/{inViewport.scss → inViewport.module.scss} +0 -0
  410. /package/src/Components/Layout/{layout.scss → layout.module.scss} +0 -0
  411. /package/src/Components/Text/{heading.scss → heading.module.scss} +0 -0
  412. /package/src/types/{scss-module.d.ts → scss.d.ts} +0 -0
@@ -0,0 +1,49 @@
1
+ import { SearchSelectInput } from '@/Components/FormElements/SearchSelectInput/SearchSelectInput';
2
+ import React, { useState } from 'react';
3
+ import type { Meta, StoryObj } from '@storybook/react-vite';
4
+ import type { SearchSelectInputProps } from '@/Components/FormElements/SearchSelectInput/SearchSelectInput';
5
+
6
+ const meta = {
7
+ component: SearchSelectInput,
8
+ } satisfies Meta<typeof SearchSelectInput>;
9
+
10
+ export default meta;
11
+
12
+ type Story = StoryObj<SearchSelectInputProps<any>>;
13
+
14
+ export const Default: Story = {
15
+ args: {
16
+ label: 'Label',
17
+ options: [
18
+ {
19
+ label: 'Pizza',
20
+ value: 'pizza',
21
+ },
22
+ {
23
+ label: 'Pommes',
24
+ value: 'pommes',
25
+ },
26
+ {
27
+ label: 'Döner',
28
+ value: 'doener',
29
+ },
30
+ {
31
+ label: 'Currywurst',
32
+ value: 'currywurst',
33
+ },
34
+ {
35
+ label: 'Spaghetti',
36
+ value: 'spaghetti',
37
+ },
38
+ ],
39
+ showSelectedOptions: false,
40
+ closeOnSelect: false,
41
+ enableSearch: true,
42
+ allowDeselect: true,
43
+ },
44
+ render: (args: SearchSelectInputProps<any>) => {
45
+ // eslint-disable-next-line react-hooks/rules-of-hooks
46
+ const [value, setValue] = useState<string[]>([]);
47
+ return <SearchSelectInput {...args} values={value} onChangeValue={setValue} />;
48
+ },
49
+ };
@@ -1,20 +1,20 @@
1
1
  import * as React from 'react';
2
- import { OptionalListener } from '../../Hooks/useListener';
3
- import { SelectOption } from '../Select/Select';
4
- import classNames from 'classnames';
5
- import { ChangeEventHandler, KeyboardEvent, ReactNode, useCallback, useMemo, useRef, useState } from 'react';
6
2
  import { ArrayHelper } from '@ainias42/js-helper';
7
- import { RbmComponentProps } from '../../RbmComponentProps';
8
- import { withMemo } from '../../../helper/withMemo';
9
- import { InlineBlock } from '../../Layout/InlineBlock';
10
- import { Text, TEXT_SIZE } from '../../Text/Text';
11
- import { Block } from '../../Layout/Block';
12
-
13
- import styles from './seachSelectInput.scss';
14
- import { Flex } from '../../Layout/Flex';
15
- import { Grow } from '../../Layout/Grow';
16
- import { Clickable } from '../../Clickable/Clickable';
17
- import { useWindow } from '../../../WindowContext/WindowContext';
3
+ import { Block } from '@/Components/Layout/Block';
4
+ import { Clickable } from '@/Components/Clickable/Clickable';
5
+ import { Flex } from '@/Components/Layout/Flex';
6
+ import { Grow } from '@/Components/Layout/Grow';
7
+ import { InlineBlock } from '@/Components/Layout/InlineBlock';
8
+ import { TEXT_SIZE, Text } from '@/Components/Text/Text';
9
+ import { useCallback, useMemo, useRef, useState } from 'react';
10
+ import { useWindow } from '@/WindowContext/WindowContext';
11
+ import { withMemo } from '@/helper/withMemo';
12
+ import classNames from 'classnames';
13
+ import styles from '@/Components/FormElements/SearchSelectInput/seachSelectInput.module.scss';
14
+ import type { ChangeEventHandler, KeyboardEvent, ReactNode } from 'react';
15
+ import type { OptionalListener } from '@/Components/Hooks/useListener';
16
+ import type { RbmComponentProps } from '@/Components/RbmComponentProps';
17
+ import type { SelectOption } from '@/Components/FormElements/Select/Select';
18
18
 
19
19
  export type SearchSelectInputProps<OnChangeData> = RbmComponentProps<
20
20
  {
@@ -22,8 +22,13 @@ export type SearchSelectInputProps<OnChangeData> = RbmComponentProps<
22
22
  options: SelectOption[];
23
23
  onChangeValue?: (newValues: string[]) => void;
24
24
  values: string[];
25
- renderSelectableOptions?: (option: SelectOption, isActive: boolean, index: number, activeIndex: number) => ReactNode,
26
- renderSelectedOption?: (option: SelectOption) => ReactNode,
25
+ renderSelectableOptions?: (
26
+ option: SelectOption,
27
+ isActive: boolean,
28
+ index: number,
29
+ activeIndex: number,
30
+ ) => ReactNode;
31
+ renderSelectedOption?: (option: SelectOption) => ReactNode;
27
32
  showSelectedOptions?: boolean;
28
33
  closeOnSelect?: boolean;
29
34
  enableSearch?: boolean;
@@ -32,169 +37,176 @@ export type SearchSelectInputProps<OnChangeData> = RbmComponentProps<
32
37
  >;
33
38
 
34
39
  export const SearchSelectInput = withMemo(function SearchSelectInput<OnChangeData>({
35
- label,
36
- options,
37
- values,
38
- onChangeValue,
39
- className,
40
- renderSelectableOptions,
41
- renderSelectedOption,
42
- showSelectedOptions = false,
43
- closeOnSelect = false,
44
- enableSearch = true,
40
+ label,
41
+ options,
42
+ values,
43
+ onChangeValue,
44
+ className,
45
+ renderSelectableOptions,
46
+ renderSelectedOption,
47
+ showSelectedOptions = false,
48
+ closeOnSelect = false,
49
+ enableSearch = true,
45
50
  allowDeselect = true,
46
- style,
47
- }: SearchSelectInputProps<OnChangeData>) {
48
- // Variables
49
- const indexedOptions = useMemo(() => ArrayHelper.arrayToObject(options, (opt) => opt.value), [options]);
50
-
51
- // Refs
52
- const containerRef = useRef<HTMLLabelElement>(null);
53
- const inputRef = useRef<HTMLInputElement>(null);
54
- const window = useWindow();
55
-
56
- // States
57
- const [searchText, setSearchText] = useState('');
58
- const [suggestionsPosition, setSuggestionsPosition] = useState<
59
- { top: number; left: number; right: number } | undefined
60
- >(undefined);
61
-
62
- const [selectedIndex, setSelectedIndex] = useState(0);
63
-
64
- const selectableOptions = useMemo(() => {
65
- if (!suggestionsPosition) {
66
- return [];
67
- }
68
- return options.filter(
69
- (option) => (showSelectedOptions || !values.includes(option.value)) && (!enableSearch || option.label.toLowerCase().includes(searchText.toLowerCase()))
70
- );
71
- }, [suggestionsPosition, options, showSelectedOptions, values, enableSearch, searchText]);
72
-
73
- // Selectors
74
-
75
- // Callbacks
76
- const updateSuggestionPosition = useCallback(() => {
77
- if (!containerRef.current) {
78
- return;
79
- }
80
- const {left, right, bottom: top} = containerRef.current.getBoundingClientRect();
81
- setSuggestionsPosition({top, left, right: (window?.innerWidth ?? 0) - right});
82
- }, [window?.innerWidth]);
83
-
84
- const onChange = useCallback<ChangeEventHandler<HTMLInputElement>>((ev) => {
85
- if (!enableSearch){
51
+ style,
52
+ }: SearchSelectInputProps<OnChangeData>) {
53
+ // Variables
54
+ const indexedOptions = useMemo(() => ArrayHelper.arrayToObject(options, (opt) => opt.value), [options]);
55
+
56
+ // Refs
57
+ const containerRef = useRef<HTMLLabelElement>(null);
58
+ const inputRef = useRef<HTMLInputElement>(null);
59
+ const window = useWindow();
60
+
61
+ // States
62
+ const [searchText, setSearchText] = useState('');
63
+ const [suggestionsPosition, setSuggestionsPosition] = useState<
64
+ { top: number; left: number; right: number } | undefined
65
+ >(undefined);
66
+
67
+ const [selectedIndex, setSelectedIndex] = useState(0);
68
+
69
+ const selectableOptions = useMemo(() => {
70
+ if (!suggestionsPosition) {
71
+ return [];
72
+ }
73
+ return options.filter(
74
+ (option) =>
75
+ (showSelectedOptions || !values.includes(option.value)) &&
76
+ (!enableSearch || option.label.toLowerCase().includes(searchText.toLowerCase())),
77
+ );
78
+ }, [suggestionsPosition, options, showSelectedOptions, values, enableSearch, searchText]);
79
+
80
+ // Selectors
81
+
82
+ // Callbacks
83
+ const updateSuggestionPosition = useCallback(() => {
84
+ if (!containerRef.current) {
85
+ return;
86
+ }
87
+ const { left, right, bottom: top } = containerRef.current.getBoundingClientRect();
88
+ setSuggestionsPosition({ top, left, right: (window?.innerWidth ?? 0) - right });
89
+ }, [window?.innerWidth]);
90
+
91
+ const onChange = useCallback<ChangeEventHandler<HTMLInputElement>>(
92
+ (ev) => {
93
+ if (!enableSearch) {
86
94
  return;
87
95
  }
88
96
  setSearchText(ev.target.value);
89
97
  setSelectedIndex(0);
90
- }, [enableSearch]);
91
- const onFocus = useCallback(() => updateSuggestionPosition(), [updateSuggestionPosition]);
92
-
93
- const toggleOption = useCallback(
94
- (_: any, value: string) => {
95
- const newValues = [...values];
96
- const index = values.indexOf(value);
97
- if (index === -1) {
98
- newValues.push(value);
99
- } else {
100
- newValues.splice(index, 1);
98
+ },
99
+ [enableSearch],
100
+ );
101
+ const onFocus = useCallback(() => updateSuggestionPosition(), [updateSuggestionPosition]);
102
+
103
+ const toggleOption = useCallback(
104
+ (_: any, value: string) => {
105
+ const newValues = [...values];
106
+ const index = values.indexOf(value);
107
+ if (index === -1) {
108
+ newValues.push(value);
109
+ } else {
110
+ newValues.splice(index, 1);
111
+ }
112
+ setSearchText('');
113
+ setSelectedIndex(0);
114
+ onChangeValue?.(newValues);
115
+ if (closeOnSelect && containerRef.current?.contains(document.activeElement)) {
116
+ inputRef.current?.focus();
117
+ requestAnimationFrame(() => {
118
+ inputRef.current?.blur();
119
+ });
120
+ }
121
+ },
122
+ [closeOnSelect, onChangeValue, values],
123
+ );
124
+
125
+ const onKeyPress = useCallback(
126
+ (e: KeyboardEvent<HTMLInputElement>) => {
127
+ if (e.key === 'Enter' && !e.defaultPrevented) {
128
+ if (selectedIndex < selectableOptions.length) {
129
+ toggleOption(undefined, selectableOptions[selectedIndex].value);
101
130
  }
102
- setSearchText('');
103
- setSelectedIndex(0);
104
- onChangeValue?.(newValues);
105
- if (closeOnSelect) {
106
- if (containerRef.current?.contains(document.activeElement)) {
107
- inputRef.current?.focus();
108
- requestAnimationFrame(() => {
109
- inputRef.current?.blur();
110
- });
131
+ } else if (e.key === 'ArrowDown') {
132
+ setSelectedIndex((old) => {
133
+ if (old + 1 >= selectableOptions.length) {
134
+ return 0;
111
135
  }
112
- }
113
- },
114
- [closeOnSelect, onChangeValue, values]
115
- );
116
-
117
- const onKeyPress = useCallback(
118
- (e: KeyboardEvent<HTMLInputElement>) => {
119
- if (e.key === 'Enter' && !e.defaultPrevented) {
120
- if (selectedIndex < selectableOptions.length) {
121
- toggleOption(undefined, selectableOptions[selectedIndex].value);
136
+ return old + 1;
137
+ });
138
+ } else if (e.key === 'ArrowUp') {
139
+ setSelectedIndex((old) => {
140
+ if (old - 1 < 0) {
141
+ return Math.max(selectableOptions.length - 1, 0);
122
142
  }
123
- } else if (e.key === 'ArrowDown') {
124
- setSelectedIndex((old) => {
125
- if (old + 1 >= selectableOptions.length) {
126
- return 0;
127
- }
128
- return old + 1;
129
- });
130
- } else if (e.key === 'ArrowUp') {
131
- setSelectedIndex((old) => {
132
- if (old - 1 < 0) {
133
- return Math.max(selectableOptions.length - 1, 0);
134
- }
135
- return old - 1;
136
- });
137
- }
138
- },
139
- [toggleOption, selectableOptions, selectedIndex]
140
- );
143
+ return old - 1;
144
+ });
145
+ }
146
+ },
147
+ [toggleOption, selectableOptions, selectedIndex],
148
+ );
141
149
 
142
- // Effects
150
+ // Effects
143
151
 
144
- // Other
152
+ // Other
145
153
 
146
- // Render Functions
147
- const renderOption = (value: string) => {
148
- const option = indexedOptions[value];
149
- if (!option) {
150
- return null;
151
- }
154
+ // Render Functions
155
+ const renderOption = (value: string) => {
156
+ const option = indexedOptions[value];
157
+ if (!option) {
158
+ return null;
159
+ }
152
160
 
153
- const element = renderSelectedOption?.(option) ?? <InlineBlock className={styles.tag}>
161
+ const element = renderSelectedOption?.(option) ?? (
162
+ <InlineBlock className={styles.tag}>
154
163
  <Text size={TEXT_SIZE.xSmall}>{indexedOptions[value]?.label}</Text>
155
- </InlineBlock>;
156
-
157
- const onClickProps = allowDeselect ? {onClick: toggleOption, onClickData: value} : {};
158
-
159
- return (
160
- <Clickable {...onClickProps} key={option.key} __allowChildren="all">
161
- {element}
162
- </Clickable>
163
- );
164
- };
165
- const renderSelectableOption = (opt: SelectOption, index: number) => {
166
- const isActive = index === selectedIndex;
167
- const element = renderSelectableOptions?.(opt, isActive, index, selectedIndex) ?? (
168
- <Block className={classNames(styles.selectableOption, {[styles.active]: index === selectedIndex})}>
169
- <Text>{opt.label}</Text>
170
- </Block>);
171
-
172
- return <Clickable onClick={toggleOption} onClickData={opt.value} key={opt.key} __allowChildren="all">
164
+ </InlineBlock>
165
+ );
166
+
167
+ const onClickProps = allowDeselect ? { onClick: toggleOption, onClickData: value } : {};
168
+
169
+ return (
170
+ <Clickable {...onClickProps} key={option.key} __allowChildren="all">
173
171
  {element}
174
- </Clickable>;
175
- };
172
+ </Clickable>
173
+ );
174
+ };
175
+ const renderSelectableOption = (opt: SelectOption, index: number) => {
176
+ const isActive = index === selectedIndex;
177
+ const element = renderSelectableOptions?.(opt, isActive, index, selectedIndex) ?? (
178
+ <Block className={classNames(styles.selectableOption, { [styles.active]: index === selectedIndex })}>
179
+ <Text>{opt.label}</Text>
180
+ </Block>
181
+ );
176
182
 
177
183
  return (
178
- // eslint-disable-next-line jsx-a11y/label-has-associated-control
179
- <label className={classNames(styles.input, className)} style={style} ref={containerRef}>
180
- {label ? <span className={styles.label}>{label}</span> : null}
181
- <Flex className={styles.inputContainer} horizontal={true}>
182
- <InlineBlock>{values.map(renderOption)}</InlineBlock>
183
- <Grow __allowChildren="html">
184
- <input
185
- ref={inputRef}
186
- className={classNames(styles.text, {[styles.disabled]: !enableSearch})}
187
- value={searchText}
188
- onChange={onChange}
189
- onKeyDown={onKeyPress}
190
- onFocus={onFocus}
191
- />
192
- </Grow>
193
- </Flex>
194
- <InlineBlock className={styles.selectableOptionContainer} style={suggestionsPosition}>
195
- {selectableOptions.map(renderSelectableOption)}
196
- </InlineBlock>
197
- </label>
184
+ <Clickable onClick={toggleOption} onClickData={opt.value} key={opt.key} __allowChildren="all">
185
+ {element}
186
+ </Clickable>
198
187
  );
199
- },
200
- styles);
188
+ };
189
+
190
+ return (
191
+ // eslint-disable-next-line jsx-a11y/label-has-associated-control
192
+ <label className={classNames(styles.input, className)} style={style} ref={containerRef}>
193
+ {label ? <span className={styles.label}>{label}</span> : null}
194
+ <Flex className={styles.inputContainer} horizontal={true}>
195
+ <InlineBlock>{values.map(renderOption)}</InlineBlock>
196
+ <Grow __allowChildren="html">
197
+ <input
198
+ ref={inputRef}
199
+ className={classNames(styles.text, { [styles.disabled]: !enableSearch })}
200
+ value={searchText}
201
+ onChange={onChange}
202
+ onKeyDown={onKeyPress}
203
+ onFocus={onFocus}
204
+ />
205
+ </Grow>
206
+ </Flex>
207
+ <InlineBlock className={styles.selectableOptionContainer} style={suggestionsPosition}>
208
+ {selectableOptions.map(renderSelectableOption)}
209
+ </InlineBlock>
210
+ </label>
211
+ );
212
+ });
@@ -0,0 +1,112 @@
1
+ @use "../../../scss/variables" as variables;
2
+ @use "../../../scss/designMixin" as mixin;
3
+ @use "../../../scss/vars" as *;
4
+
5
+ @include vars {
6
+ --search-select-input-label-font-weight: bold;
7
+ --search-select-input-text-background-color: transparent;
8
+ --search-select-input-tag-text-color: var(--text-inverse);
9
+ --search-select-input-tag-background-color: var(--flavor-accent);
10
+ --search-select-input-option-list-border-color: var(--border-light);
11
+ --search-select-input-active-option-text-color: var(--text-inverse);
12
+ --search-select-input-active-option-background-color: var(--flavor-accent);
13
+ }
14
+
15
+ @include mixin.design(variables.$material) {
16
+ --search-select-input-background-image: linear-gradient(to top, transparent 1px, var(--border-light) 1px);
17
+ --search-select-input-focused-background-image: linear-gradient(var(--flavor-accent), var(--flavor-accent)), linear-gradient(to top, transparent 1px, var(--border-light) 1px);
18
+ --search-select-input-text-color: var(--text-primary);
19
+ }
20
+
21
+ @include mixin.design(variables.$flat) {
22
+ --search-select-input-border-bottom-color: var(--border-light);
23
+ --search-select-input-text-color: var(--text-primary);
24
+ }
25
+
26
+ .input {
27
+ display: inline-block;
28
+ width: 100%;
29
+ position: relative;
30
+ padding-bottom: 0.1rem;
31
+
32
+ &:focus-within {
33
+ .selectableOptionContainer {
34
+ display: inherit;
35
+ }
36
+ }
37
+
38
+ @include mixin.design(variables.$material) {
39
+ background-image: var(--search-select-input-background-image);
40
+ background-size: 100% 2px;
41
+ background-repeat: no-repeat;
42
+ background-position: center bottom;
43
+ padding-bottom: 2px;
44
+
45
+ &:focus {
46
+ background-image: var(--search-select-input-focused-background-image);
47
+ }
48
+ }
49
+
50
+ @include mixin.design(variables.$flat) {
51
+ &, &:focus {
52
+ border-bottom: 1px solid var(--search-select-input-border-bottom-color);
53
+ }
54
+ }
55
+
56
+ .label {
57
+ display: block;
58
+ font-weight: var(--search-select-input-label-font-weight);
59
+ }
60
+
61
+ .text {
62
+ width: 100%;
63
+ background-color: var(--search-select-input-text-background-color);
64
+ border: 0;
65
+ outline: none;
66
+ padding: 0;
67
+ background-image: none;
68
+ color: var(--search-select-input-text-color);
69
+
70
+ &.disabled {
71
+ caret-color: transparent;
72
+ cursor: pointer;
73
+ }
74
+ }
75
+ }
76
+
77
+ .inputContainer {
78
+ display: flex;
79
+
80
+ }
81
+
82
+ .tag {
83
+ --text-primary-default-color: var(--search-select-input-tag-text-color);
84
+
85
+ color: var(--search-select-input-tag-text-color);
86
+ background-color: var(--search-select-input-tag-background-color);
87
+ padding: 0.1rem 0.2rem;
88
+ margin-right: 0.1rem;
89
+ margin-bottom: 0.1rem;
90
+ border-radius: 4px;
91
+ }
92
+
93
+ .selectableOptionContainer {
94
+ display: none;
95
+ position: fixed;
96
+ background-color: white;
97
+ z-index: 1100;
98
+ border: 1px solid var(--search-select-input-option-list-border-color);
99
+
100
+ .selectableOption {
101
+ padding-left: 0.2rem;
102
+ padding-right: 0.2rem;
103
+ cursor: pointer;
104
+
105
+ &.active {
106
+ --text-primary-default-color: var(--search-select-input-active-option-text-color);
107
+
108
+ color: var(--search-select-input-active-option-text-color);
109
+ background-color: var(--search-select-input-active-option-background-color);
110
+ }
111
+ }
112
+ }
@@ -0,0 +1,49 @@
1
+ import type { Meta, StoryObj } from '@storybook/react-vite';
2
+
3
+ import { Select } from '@/Components/FormElements/Select/Select';
4
+
5
+ const meta = {
6
+ component: Select,
7
+ } satisfies Meta<typeof Select>;
8
+
9
+ export default meta;
10
+
11
+ type Story = StoryObj<typeof meta>;
12
+
13
+ export const Default: Story = {
14
+ args: {
15
+ options: [
16
+ { value: 'option1', label: 'Option 1' },
17
+ { value: 'option2', label: 'Option 2' },
18
+ { value: 'option3', label: 'Option 3' },
19
+ ],
20
+ label: 'Select an option',
21
+ error: '',
22
+ inline: false,
23
+ small: false,
24
+ },
25
+ };
26
+
27
+ export const Error: Story = {
28
+ args: {
29
+ options: [
30
+ {
31
+ value: 'option1',
32
+ label: 'Option 1',
33
+ },
34
+ {
35
+ value: 'option2',
36
+ label: 'Option 2',
37
+ },
38
+ {
39
+ value: 'option3',
40
+ label: 'Option 3',
41
+ },
42
+ ],
43
+
44
+ label: 'Select an option',
45
+ error: 'Wrong Value',
46
+ inline: false,
47
+ small: false,
48
+ },
49
+ };