@udixio/ui-react 0.0.1 → 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (347) hide show
  1. package/.eslintrc.mjs +22 -0
  2. package/.storybook/main.ts +20 -0
  3. package/.storybook/preview.ts +1 -0
  4. package/CHANGELOG.md +141 -0
  5. package/dist/index.cjs +5 -0
  6. package/dist/index.d.ts.map +1 -0
  7. package/dist/index.js +2820 -0
  8. package/dist/lib/components/Button.d.ts.map +1 -0
  9. package/dist/lib/components/Card.d.ts.map +1 -0
  10. package/dist/lib/components/Carousel.d.ts.map +1 -0
  11. package/dist/lib/components/CarouselItem.d.ts.map +1 -0
  12. package/{lib → dist/lib}/components/Divided.d.ts +1 -1
  13. package/dist/lib/components/Divided.d.ts.map +1 -0
  14. package/dist/lib/components/Fab.d.ts.map +1 -0
  15. package/dist/lib/components/IconButton.d.ts.map +1 -0
  16. package/dist/lib/components/NavigationRail.d.ts.map +1 -0
  17. package/dist/lib/components/NavigationRailItem.d.ts.map +1 -0
  18. package/dist/lib/components/ProgressIndicator.d.ts.map +1 -0
  19. package/dist/lib/components/Slider.d.ts.map +1 -0
  20. package/dist/lib/components/Snackbar.d.ts.map +1 -0
  21. package/dist/lib/components/Switch.d.ts.map +1 -0
  22. package/dist/lib/components/Tab.d.ts.map +1 -0
  23. package/dist/lib/components/Tabs.d.ts.map +1 -0
  24. package/dist/lib/components/TextField.d.ts.map +1 -0
  25. package/dist/lib/components/ToolTip.d.ts.map +1 -0
  26. package/dist/lib/components/index.d.ts.map +1 -0
  27. package/dist/lib/effects/SyncedFixedWrapper.d.ts.map +1 -0
  28. package/dist/lib/effects/custom-scroll/custom-scroll.effect.d.ts.map +1 -0
  29. package/dist/lib/effects/custom-scroll/custom-scroll.interface.d.ts.map +1 -0
  30. package/dist/lib/effects/custom-scroll/custom-scroll.style.d.ts.map +1 -0
  31. package/dist/lib/effects/custom-scroll/index.d.ts.map +1 -0
  32. package/dist/lib/effects/index.d.ts.map +1 -0
  33. package/dist/lib/effects/ripple/RippleEffect.d.ts.map +1 -0
  34. package/dist/lib/effects/ripple/index.d.ts.map +1 -0
  35. package/dist/lib/effects/smooth-scroll.effect.d.ts.map +1 -0
  36. package/dist/lib/icon/icon.d.ts.map +1 -0
  37. package/dist/lib/icon/index.d.ts.map +1 -0
  38. package/dist/lib/index.d.ts.map +1 -0
  39. package/dist/lib/interfaces/button.interface.d.ts.map +1 -0
  40. package/dist/lib/interfaces/card.interface.d.ts.map +1 -0
  41. package/dist/lib/interfaces/carousel-item.interface.d.ts.map +1 -0
  42. package/dist/lib/interfaces/carousel.interface.d.ts.map +1 -0
  43. package/dist/lib/interfaces/divider.interface.d.ts.map +1 -0
  44. package/dist/lib/interfaces/fab.interface.d.ts.map +1 -0
  45. package/dist/lib/interfaces/icon-button.interface.d.ts.map +1 -0
  46. package/dist/lib/interfaces/index.d.ts.map +1 -0
  47. package/dist/lib/interfaces/navigation-rail-item.interface.d.ts.map +1 -0
  48. package/dist/lib/interfaces/navigation-rail.interface.d.ts.map +1 -0
  49. package/dist/lib/interfaces/progress-indicator.interface.d.ts.map +1 -0
  50. package/dist/lib/interfaces/slider.interface.d.ts.map +1 -0
  51. package/dist/lib/interfaces/snackbar.interface.d.ts.map +1 -0
  52. package/dist/lib/interfaces/switch.interface.d.ts.map +1 -0
  53. package/dist/lib/interfaces/tab.interface.d.ts.map +1 -0
  54. package/{lib → dist/lib}/interfaces/tabs.interface.d.ts +1 -1
  55. package/dist/lib/interfaces/tabs.interface.d.ts.map +1 -0
  56. package/dist/lib/interfaces/text-field.interface.d.ts.map +1 -0
  57. package/dist/lib/interfaces/tooltip.interface.d.ts.map +1 -0
  58. package/dist/lib/styles/button.style.d.ts.map +1 -0
  59. package/dist/lib/styles/card.style.d.ts.map +1 -0
  60. package/dist/lib/styles/carousel-item.style.d.ts.map +1 -0
  61. package/dist/lib/styles/carousel.style.d.ts.map +1 -0
  62. package/dist/lib/styles/divider.style.d.ts.map +1 -0
  63. package/dist/lib/styles/fab.style.d.ts.map +1 -0
  64. package/dist/lib/styles/icon-button.style.d.ts.map +1 -0
  65. package/dist/lib/styles/index.d.ts.map +1 -0
  66. package/dist/lib/styles/navigation-rail-item.style.d.ts.map +1 -0
  67. package/dist/lib/styles/navigation-rail.style.d.ts.map +1 -0
  68. package/dist/lib/styles/progress-indicator.style.d.ts.map +1 -0
  69. package/dist/lib/styles/slider.style.d.ts.map +1 -0
  70. package/dist/lib/styles/snackbar.style.d.ts.map +1 -0
  71. package/dist/lib/styles/switch.style.d.ts.map +1 -0
  72. package/dist/lib/styles/tab.style.d.ts.map +1 -0
  73. package/{lib → dist/lib}/styles/tabs.style.d.ts +1 -1
  74. package/dist/lib/styles/tabs.style.d.ts.map +1 -0
  75. package/dist/lib/styles/text-field.style.d.ts.map +1 -0
  76. package/dist/lib/styles/tooltip.style.d.ts.map +1 -0
  77. package/dist/lib/utils/component-helper.d.ts.map +1 -0
  78. package/dist/lib/utils/component.d.ts.map +1 -0
  79. package/dist/lib/utils/index.d.ts.map +1 -0
  80. package/dist/lib/utils/string.d.ts.map +1 -0
  81. package/dist/lib/utils/styles/classnames.d.ts.map +1 -0
  82. package/dist/lib/utils/styles/get-classname.d.ts.map +1 -0
  83. package/dist/lib/utils/styles/index.d.ts.map +1 -0
  84. package/package.json +12 -7
  85. package/postcss.config.mjs +5 -0
  86. package/src/index.css +4 -0
  87. package/src/index.ts +1 -0
  88. package/src/lib/components/Button.tsx +140 -0
  89. package/src/lib/components/Card.tsx +31 -0
  90. package/src/lib/components/Carousel.tsx +190 -0
  91. package/src/lib/components/CarouselItem.tsx +53 -0
  92. package/src/lib/components/Divided.tsx +13 -0
  93. package/src/lib/components/Fab.tsx +109 -0
  94. package/src/lib/components/IconButton.tsx +141 -0
  95. package/src/lib/components/NavigationRail.tsx +178 -0
  96. package/src/lib/components/NavigationRailItem.tsx +199 -0
  97. package/src/lib/components/ProgressIndicator.tsx +157 -0
  98. package/src/lib/components/Slider.tsx +361 -0
  99. package/src/lib/components/Snackbar.tsx +66 -0
  100. package/src/lib/components/Switch.tsx +94 -0
  101. package/src/lib/components/Tab.tsx +110 -0
  102. package/src/lib/components/Tabs.tsx +85 -0
  103. package/src/lib/components/TextField.tsx +269 -0
  104. package/src/lib/components/ToolTip.tsx +232 -0
  105. package/src/lib/components/index.ts +19 -0
  106. package/src/lib/effects/SyncedFixedWrapper.tsx +64 -0
  107. package/src/lib/effects/custom-scroll/custom-scroll.effect.tsx +287 -0
  108. package/src/lib/effects/custom-scroll/custom-scroll.interface.ts +25 -0
  109. package/src/lib/effects/custom-scroll/custom-scroll.style.ts +32 -0
  110. package/src/lib/effects/custom-scroll/index.ts +3 -0
  111. package/src/lib/effects/index.ts +4 -0
  112. package/src/lib/effects/ripple/RippleEffect.tsx +103 -0
  113. package/src/lib/effects/ripple/index.tsx +1 -0
  114. package/src/lib/effects/smooth-scroll.effect.tsx +91 -0
  115. package/src/lib/icon/icon.tsx +47 -0
  116. package/src/lib/icon/index.ts +1 -0
  117. package/src/lib/index.ts +6 -0
  118. package/src/lib/interfaces/button.interface.ts +46 -0
  119. package/src/lib/interfaces/card.interface.ts +8 -0
  120. package/src/lib/interfaces/carousel-item.interface.ts +11 -0
  121. package/src/lib/interfaces/carousel.interface.ts +21 -0
  122. package/src/lib/interfaces/divider.interface.ts +7 -0
  123. package/src/lib/interfaces/fab.interface.ts +19 -0
  124. package/src/lib/interfaces/icon-button.interface.ts +35 -0
  125. package/src/lib/interfaces/index.ts +16 -0
  126. package/src/lib/interfaces/navigation-rail-item.interface.ts +38 -0
  127. package/src/lib/interfaces/navigation-rail.interface.ts +39 -0
  128. package/src/lib/interfaces/progress-indicator.interface.ts +35 -0
  129. package/src/lib/interfaces/slider.interface.ts +29 -0
  130. package/src/lib/interfaces/snackbar.interface.ts +13 -0
  131. package/src/lib/interfaces/switch.interface.ts +14 -0
  132. package/src/lib/interfaces/tab.interface.ts +30 -0
  133. package/src/lib/interfaces/tabs.interface.ts +22 -0
  134. package/src/lib/interfaces/text-field.interface.ts +48 -0
  135. package/src/lib/interfaces/tooltip.interface.ts +35 -0
  136. package/src/lib/styles/button.style.ts +155 -0
  137. package/src/lib/styles/card.style.ts +22 -0
  138. package/src/lib/styles/carousel-item.style.ts +11 -0
  139. package/src/lib/styles/carousel.style.ts +12 -0
  140. package/src/lib/styles/divider.style.ts +17 -0
  141. package/src/lib/styles/fab.style.ts +55 -0
  142. package/src/lib/styles/icon-button.style.ts +140 -0
  143. package/src/lib/styles/index.ts +15 -0
  144. package/src/lib/styles/navigation-rail-item.style.ts +44 -0
  145. package/src/lib/styles/navigation-rail.style.ts +20 -0
  146. package/src/lib/styles/progress-indicator.style.ts +30 -0
  147. package/src/lib/styles/slider.style.ts +27 -0
  148. package/src/lib/styles/snackbar.style.ts +14 -0
  149. package/src/lib/styles/switch.style.ts +51 -0
  150. package/src/lib/styles/tab.style.ts +68 -0
  151. package/src/lib/styles/tabs.style.ts +13 -0
  152. package/src/lib/styles/text-field.style.ts +104 -0
  153. package/src/lib/styles/tooltip.style.ts +37 -0
  154. package/src/lib/utils/component-helper.ts +134 -0
  155. package/src/lib/utils/component.ts +34 -0
  156. package/src/lib/utils/index.ts +7 -0
  157. package/src/lib/utils/string.ts +9 -0
  158. package/src/lib/utils/styles/classnames.ts +49 -0
  159. package/src/lib/utils/styles/get-classname.ts +73 -0
  160. package/src/lib/utils/styles/index.ts +3 -0
  161. package/src/stories/action/button.stories.tsx +86 -0
  162. package/src/stories/action/fab.stories.tsx +54 -0
  163. package/src/stories/action/icon-button.stories.tsx +134 -0
  164. package/src/stories/assets/accessibility.png +0 -0
  165. package/src/stories/assets/accessibility.svg +5 -0
  166. package/src/stories/assets/addon-library.png +0 -0
  167. package/src/stories/assets/assets.png +0 -0
  168. package/src/stories/assets/context.png +0 -0
  169. package/src/stories/assets/discord.svg +15 -0
  170. package/src/stories/assets/docs.png +0 -0
  171. package/src/stories/assets/figma-plugin.png +0 -0
  172. package/src/stories/assets/github.svg +3 -0
  173. package/src/stories/assets/share.png +0 -0
  174. package/src/stories/assets/styling.png +0 -0
  175. package/src/stories/assets/testing.png +0 -0
  176. package/src/stories/assets/theming.png +0 -0
  177. package/src/stories/assets/tutorials.svg +12 -0
  178. package/src/stories/assets/youtube.svg +4 -0
  179. package/src/stories/communication/ProgressIndicator.stories.tsx +57 -0
  180. package/src/stories/communication/SnackBar.stories.tsx +32 -0
  181. package/src/stories/communication/tool-tip.stories.tsx +133 -0
  182. package/src/stories/containment/card.stories.tsx +42 -0
  183. package/src/stories/containment/carousel.stories.tsx +65 -0
  184. package/src/stories/containment/divider.stories.tsx +35 -0
  185. package/src/stories/effect/smooth-scroll.stories.tsx +45 -0
  186. package/src/stories/navigation/navigation-rail/navigation-rail-item.stories.tsx +65 -0
  187. package/src/stories/navigation/navigation-rail/navigation-rail.stories.tsx +122 -0
  188. package/src/stories/navigation/tabs/tab.stories.tsx +57 -0
  189. package/src/stories/navigation/tabs/tabs.stories.tsx +102 -0
  190. package/src/stories/selection/slider.stories.tsx +85 -0
  191. package/src/stories/selection/switch.stories.tsx +46 -0
  192. package/src/stories/text-inputs/text-field.stories.tsx +135 -0
  193. package/src/tests/Button.spec.tsx +67 -0
  194. package/src/udixio.css +120 -0
  195. package/theme.config.ts +7 -0
  196. package/tsconfig.json +22 -0
  197. package/tsconfig.lib.json +51 -0
  198. package/tsconfig.spec.json +37 -0
  199. package/tsconfig.storybook.json +38 -0
  200. package/vite.config.ts +75 -0
  201. package/index.d.ts.map +0 -1
  202. package/index.js +0 -10841
  203. package/lib/components/Button.d.ts.map +0 -1
  204. package/lib/components/Card.d.ts.map +0 -1
  205. package/lib/components/Carousel.d.ts.map +0 -1
  206. package/lib/components/CarouselItem.d.ts.map +0 -1
  207. package/lib/components/Divided.d.ts.map +0 -1
  208. package/lib/components/Fab.d.ts.map +0 -1
  209. package/lib/components/IconButton.d.ts.map +0 -1
  210. package/lib/components/NavigationRail.d.ts.map +0 -1
  211. package/lib/components/NavigationRailItem.d.ts.map +0 -1
  212. package/lib/components/ProgressIndicator.d.ts.map +0 -1
  213. package/lib/components/Slider.d.ts.map +0 -1
  214. package/lib/components/Snackbar.d.ts.map +0 -1
  215. package/lib/components/Switch.d.ts.map +0 -1
  216. package/lib/components/Tab.d.ts.map +0 -1
  217. package/lib/components/Tabs.d.ts.map +0 -1
  218. package/lib/components/TextField.d.ts.map +0 -1
  219. package/lib/components/ToolTip.d.ts.map +0 -1
  220. package/lib/components/index.d.ts.map +0 -1
  221. package/lib/effects/SyncedFixedWrapper.d.ts.map +0 -1
  222. package/lib/effects/custom-scroll/custom-scroll.effect.d.ts.map +0 -1
  223. package/lib/effects/custom-scroll/custom-scroll.interface.d.ts.map +0 -1
  224. package/lib/effects/custom-scroll/custom-scroll.style.d.ts.map +0 -1
  225. package/lib/effects/custom-scroll/index.d.ts.map +0 -1
  226. package/lib/effects/index.d.ts.map +0 -1
  227. package/lib/effects/ripple/RippleEffect.d.ts.map +0 -1
  228. package/lib/effects/ripple/index.d.ts.map +0 -1
  229. package/lib/effects/smooth-scroll.effect.d.ts.map +0 -1
  230. package/lib/icon/icon.d.ts.map +0 -1
  231. package/lib/icon/index.d.ts.map +0 -1
  232. package/lib/index.d.ts.map +0 -1
  233. package/lib/interfaces/button.interface.d.ts.map +0 -1
  234. package/lib/interfaces/card.interface.d.ts.map +0 -1
  235. package/lib/interfaces/carousel-item.interface.d.ts.map +0 -1
  236. package/lib/interfaces/carousel.interface.d.ts.map +0 -1
  237. package/lib/interfaces/divider.interface.d.ts.map +0 -1
  238. package/lib/interfaces/fab.interface.d.ts.map +0 -1
  239. package/lib/interfaces/icon-button.interface.d.ts.map +0 -1
  240. package/lib/interfaces/index.d.ts.map +0 -1
  241. package/lib/interfaces/navigation-rail-item.interface.d.ts.map +0 -1
  242. package/lib/interfaces/navigation-rail.interface.d.ts.map +0 -1
  243. package/lib/interfaces/progress-indicator.interface.d.ts.map +0 -1
  244. package/lib/interfaces/slider.interface.d.ts.map +0 -1
  245. package/lib/interfaces/snackbar.interface.d.ts.map +0 -1
  246. package/lib/interfaces/switch.interface.d.ts.map +0 -1
  247. package/lib/interfaces/tab.interface.d.ts.map +0 -1
  248. package/lib/interfaces/tabs.interface.d.ts.map +0 -1
  249. package/lib/interfaces/text-field.interface.d.ts.map +0 -1
  250. package/lib/interfaces/tooltip.interface.d.ts.map +0 -1
  251. package/lib/styles/button.style.d.ts.map +0 -1
  252. package/lib/styles/card.style.d.ts.map +0 -1
  253. package/lib/styles/carousel-item.style.d.ts.map +0 -1
  254. package/lib/styles/carousel.style.d.ts.map +0 -1
  255. package/lib/styles/divider.style.d.ts.map +0 -1
  256. package/lib/styles/fab.style.d.ts.map +0 -1
  257. package/lib/styles/icon-button.style.d.ts.map +0 -1
  258. package/lib/styles/index.d.ts.map +0 -1
  259. package/lib/styles/navigation-rail-item.style.d.ts.map +0 -1
  260. package/lib/styles/navigation-rail.style.d.ts.map +0 -1
  261. package/lib/styles/progress-indicator.style.d.ts.map +0 -1
  262. package/lib/styles/slider.style.d.ts.map +0 -1
  263. package/lib/styles/snackbar.style.d.ts.map +0 -1
  264. package/lib/styles/switch.style.d.ts.map +0 -1
  265. package/lib/styles/tab.style.d.ts.map +0 -1
  266. package/lib/styles/tabs.style.d.ts.map +0 -1
  267. package/lib/styles/text-field.style.d.ts.map +0 -1
  268. package/lib/styles/tooltip.style.d.ts.map +0 -1
  269. package/lib/utils/component-helper.d.ts.map +0 -1
  270. package/lib/utils/component.d.ts.map +0 -1
  271. package/lib/utils/index.d.ts.map +0 -1
  272. package/lib/utils/string.d.ts.map +0 -1
  273. package/lib/utils/styles/classnames.d.ts.map +0 -1
  274. package/lib/utils/styles/get-classname.d.ts.map +0 -1
  275. package/lib/utils/styles/index.d.ts.map +0 -1
  276. /package/{LICENSE → dist/LICENSE} +0 -0
  277. /package/{index.d.ts → dist/index.d.ts} +0 -0
  278. /package/{lib → dist/lib}/components/Button.d.ts +0 -0
  279. /package/{lib → dist/lib}/components/Card.d.ts +0 -0
  280. /package/{lib → dist/lib}/components/Carousel.d.ts +0 -0
  281. /package/{lib → dist/lib}/components/CarouselItem.d.ts +0 -0
  282. /package/{lib → dist/lib}/components/Fab.d.ts +0 -0
  283. /package/{lib → dist/lib}/components/IconButton.d.ts +0 -0
  284. /package/{lib → dist/lib}/components/NavigationRail.d.ts +0 -0
  285. /package/{lib → dist/lib}/components/NavigationRailItem.d.ts +0 -0
  286. /package/{lib → dist/lib}/components/ProgressIndicator.d.ts +0 -0
  287. /package/{lib → dist/lib}/components/Slider.d.ts +0 -0
  288. /package/{lib → dist/lib}/components/Snackbar.d.ts +0 -0
  289. /package/{lib → dist/lib}/components/Switch.d.ts +0 -0
  290. /package/{lib → dist/lib}/components/Tab.d.ts +0 -0
  291. /package/{lib → dist/lib}/components/Tabs.d.ts +0 -0
  292. /package/{lib → dist/lib}/components/TextField.d.ts +0 -0
  293. /package/{lib → dist/lib}/components/ToolTip.d.ts +0 -0
  294. /package/{lib → dist/lib}/components/index.d.ts +0 -0
  295. /package/{lib → dist/lib}/effects/SyncedFixedWrapper.d.ts +0 -0
  296. /package/{lib → dist/lib}/effects/custom-scroll/custom-scroll.effect.d.ts +0 -0
  297. /package/{lib → dist/lib}/effects/custom-scroll/custom-scroll.interface.d.ts +0 -0
  298. /package/{lib → dist/lib}/effects/custom-scroll/custom-scroll.style.d.ts +0 -0
  299. /package/{lib → dist/lib}/effects/custom-scroll/index.d.ts +0 -0
  300. /package/{lib → dist/lib}/effects/index.d.ts +0 -0
  301. /package/{lib → dist/lib}/effects/ripple/RippleEffect.d.ts +0 -0
  302. /package/{lib → dist/lib}/effects/ripple/index.d.ts +0 -0
  303. /package/{lib → dist/lib}/effects/smooth-scroll.effect.d.ts +0 -0
  304. /package/{lib → dist/lib}/icon/icon.d.ts +0 -0
  305. /package/{lib → dist/lib}/icon/index.d.ts +0 -0
  306. /package/{lib → dist/lib}/index.d.ts +0 -0
  307. /package/{lib → dist/lib}/interfaces/button.interface.d.ts +0 -0
  308. /package/{lib → dist/lib}/interfaces/card.interface.d.ts +0 -0
  309. /package/{lib → dist/lib}/interfaces/carousel-item.interface.d.ts +0 -0
  310. /package/{lib → dist/lib}/interfaces/carousel.interface.d.ts +0 -0
  311. /package/{lib → dist/lib}/interfaces/divider.interface.d.ts +0 -0
  312. /package/{lib → dist/lib}/interfaces/fab.interface.d.ts +0 -0
  313. /package/{lib → dist/lib}/interfaces/icon-button.interface.d.ts +0 -0
  314. /package/{lib → dist/lib}/interfaces/index.d.ts +0 -0
  315. /package/{lib → dist/lib}/interfaces/navigation-rail-item.interface.d.ts +0 -0
  316. /package/{lib → dist/lib}/interfaces/navigation-rail.interface.d.ts +0 -0
  317. /package/{lib → dist/lib}/interfaces/progress-indicator.interface.d.ts +0 -0
  318. /package/{lib → dist/lib}/interfaces/slider.interface.d.ts +0 -0
  319. /package/{lib → dist/lib}/interfaces/snackbar.interface.d.ts +0 -0
  320. /package/{lib → dist/lib}/interfaces/switch.interface.d.ts +0 -0
  321. /package/{lib → dist/lib}/interfaces/tab.interface.d.ts +0 -0
  322. /package/{lib → dist/lib}/interfaces/text-field.interface.d.ts +0 -0
  323. /package/{lib → dist/lib}/interfaces/tooltip.interface.d.ts +0 -0
  324. /package/{lib → dist/lib}/styles/button.style.d.ts +0 -0
  325. /package/{lib → dist/lib}/styles/card.style.d.ts +0 -0
  326. /package/{lib → dist/lib}/styles/carousel-item.style.d.ts +0 -0
  327. /package/{lib → dist/lib}/styles/carousel.style.d.ts +0 -0
  328. /package/{lib → dist/lib}/styles/divider.style.d.ts +0 -0
  329. /package/{lib → dist/lib}/styles/fab.style.d.ts +0 -0
  330. /package/{lib → dist/lib}/styles/icon-button.style.d.ts +0 -0
  331. /package/{lib → dist/lib}/styles/index.d.ts +0 -0
  332. /package/{lib → dist/lib}/styles/navigation-rail-item.style.d.ts +0 -0
  333. /package/{lib → dist/lib}/styles/navigation-rail.style.d.ts +0 -0
  334. /package/{lib → dist/lib}/styles/progress-indicator.style.d.ts +0 -0
  335. /package/{lib → dist/lib}/styles/slider.style.d.ts +0 -0
  336. /package/{lib → dist/lib}/styles/snackbar.style.d.ts +0 -0
  337. /package/{lib → dist/lib}/styles/switch.style.d.ts +0 -0
  338. /package/{lib → dist/lib}/styles/tab.style.d.ts +0 -0
  339. /package/{lib → dist/lib}/styles/text-field.style.d.ts +0 -0
  340. /package/{lib → dist/lib}/styles/tooltip.style.d.ts +0 -0
  341. /package/{lib → dist/lib}/utils/component-helper.d.ts +0 -0
  342. /package/{lib → dist/lib}/utils/component.d.ts +0 -0
  343. /package/{lib → dist/lib}/utils/index.d.ts +0 -0
  344. /package/{lib → dist/lib}/utils/string.d.ts +0 -0
  345. /package/{lib → dist/lib}/utils/styles/classnames.d.ts +0 -0
  346. /package/{lib → dist/lib}/utils/styles/get-classname.d.ts +0 -0
  347. /package/{lib → dist/lib}/utils/styles/index.d.ts +0 -0
@@ -0,0 +1,66 @@
1
+ import React, { useEffect, useState } from 'react';
2
+ import { AnimatePresence, motion } from 'motion/react';
3
+ import { faXmark } from '@fortawesome/free-solid-svg-icons';
4
+ import { SnackbarInterface } from '../interfaces/snackbar.interface';
5
+ import { snackbarStyle } from '../styles/snackbar.style';
6
+
7
+ import { MotionProps } from '../utils/component';
8
+ import { IconButton } from './IconButton';
9
+
10
+ export const Snackbar = ({
11
+ supportingText,
12
+ className,
13
+ duration,
14
+ closeIcon = faXmark,
15
+ onClose,
16
+ ...restProps
17
+ }: MotionProps<SnackbarInterface>) => {
18
+ const [isVisible, setIsVisible] = useState(true);
19
+
20
+ const styles = snackbarStyle({
21
+ className,
22
+ closeIcon,
23
+ duration,
24
+ isVisible,
25
+ onClose,
26
+ supportingText,
27
+ });
28
+
29
+ useEffect(() => {
30
+ if (duration) {
31
+ setTimeout(() => {
32
+ handleClose();
33
+ }, duration);
34
+ }
35
+ }, [duration]);
36
+
37
+ const handleClose = () => {
38
+ setIsVisible(false);
39
+ onClose?.();
40
+ };
41
+
42
+ return (
43
+ <AnimatePresence>
44
+ {isVisible && (
45
+ <motion.div
46
+ initial={{ height: 0 }}
47
+ animate={{ height: 'auto' }}
48
+ exit={{ height: 0 }}
49
+ transition={{ duration: 0.1 }}
50
+ className={styles.snackbar}
51
+ {...restProps}
52
+ >
53
+ <div className={styles.container}>
54
+ <p className={styles.supportingText}>{supportingText}</p>
55
+ <IconButton
56
+ onClick={() => handleClose()}
57
+ className={styles.icon}
58
+ icon={closeIcon}
59
+ arialLabel={'close the snackbar'}
60
+ ></IconButton>
61
+ </div>
62
+ </motion.div>
63
+ )}
64
+ </AnimatePresence>
65
+ );
66
+ };
@@ -0,0 +1,94 @@
1
+ import React, { useRef, useState } from 'react';
2
+
3
+ import { Icon } from '../icon';
4
+ import { motion } from 'motion/react';
5
+ import { SwitchInterface } from '../interfaces/switch.interface';
6
+ import { switchStyle } from '../styles/switch.style';
7
+ import { MotionProps } from '../utils/component';
8
+
9
+ export const Switch = ({
10
+ selected = false,
11
+ className,
12
+ activeIcon,
13
+ disabled = false,
14
+ inactiveIcon,
15
+ onChange,
16
+ onClick,
17
+ onKeyDown,
18
+ ref,
19
+ ...restProps
20
+ }: MotionProps<SwitchInterface>) => {
21
+ const [isSelected, setIsSelected] = useState(selected);
22
+
23
+ const handleClick = (event: React.MouseEvent<HTMLDivElement>) => {
24
+ if (disabled) return;
25
+ toggleSwitchState();
26
+ if (onClick) {
27
+ onClick(event);
28
+ }
29
+ };
30
+
31
+ const handleKeyDown = (event: React.KeyboardEvent<HTMLDivElement>) => {
32
+ if (disabled) return;
33
+ if (event.key === ' ' || event.key === 'Enter') {
34
+ event.preventDefault();
35
+ toggleSwitchState();
36
+ }
37
+ if (onKeyDown) {
38
+ onKeyDown(event);
39
+ }
40
+ };
41
+
42
+ const toggleSwitchState = () => {
43
+ setIsSelected(!isSelected);
44
+ onChange?.(!isSelected);
45
+ };
46
+ const styles = switchStyle({
47
+ className,
48
+ isSelected,
49
+ activeIcon,
50
+ inactiveIcon,
51
+ disabled,
52
+ selected: isSelected,
53
+ onChange,
54
+ });
55
+
56
+ const defaultRef = useRef<HTMLDivElement>(null);
57
+ const resolvedRef: React.RefObject<any> | React.ForwardedRef<any> =
58
+ ref || defaultRef;
59
+
60
+ return (
61
+ <motion.div
62
+ role="switch"
63
+ aria-checked={isSelected}
64
+ tabIndex={disabled ? -1 : 0}
65
+ onKeyDown={handleKeyDown}
66
+ onClick={handleClick}
67
+ ref={resolvedRef}
68
+ className={styles.switch}
69
+ {...restProps}
70
+ >
71
+ <input type="hidden" value={isSelected ? '1' : '0'} />
72
+ <motion.div
73
+ layout
74
+ style={{ translate: isSelected ? '50%' : '-50%' }}
75
+ transition={{
76
+ type: 'spring',
77
+ stiffness: 700,
78
+ damping: 30,
79
+ }}
80
+ className={styles.handleContainer}
81
+ >
82
+ <div className={styles.handle}>
83
+ {(isSelected ? activeIcon : inactiveIcon) && (
84
+ <Icon
85
+ className={styles.icon}
86
+ icon={isSelected ? activeIcon! : inactiveIcon!}
87
+ ></Icon>
88
+ )}
89
+ </div>
90
+ <div className={styles.handleStateLayer} />
91
+ </motion.div>
92
+ </motion.div>
93
+ );
94
+ };
@@ -0,0 +1,110 @@
1
+ import { motion } from 'motion/react';
2
+ import React, { useEffect, useRef, useState } from 'react';
3
+
4
+ import { Icon } from '../icon';
5
+ import { RippleEffect } from '../effects/ripple';
6
+ import { tabStyle } from '../styles/tab.style';
7
+ import { TabInterface } from '../interfaces/tab.interface';
8
+ import { ReactProps } from '../utils/component';
9
+
10
+ export const Tab = ({
11
+ className,
12
+ onClick,
13
+ label,
14
+ variant = 'primary',
15
+ href,
16
+ icon,
17
+ selectedTab,
18
+ setSelectedTab,
19
+ tabsId,
20
+ index,
21
+ onTabSelected,
22
+ scrollable = false,
23
+ selected = false,
24
+ ref,
25
+ ...restProps
26
+ }: ReactProps<TabInterface>) => {
27
+ const defaultRef = useRef(null);
28
+ const resolvedRef = ref || defaultRef;
29
+
30
+ const [isSelected, setIsSelected] = useState<boolean>(selected);
31
+
32
+ useEffect(() => {
33
+ if (selected && selectedTab == null) {
34
+ setIsSelected(true);
35
+ } else {
36
+ setIsSelected(selectedTab == index && index != null);
37
+ }
38
+ }, [selectedTab]);
39
+
40
+ useEffect(() => {
41
+ if (selectedTab == index && onTabSelected) {
42
+ onTabSelected({
43
+ ref: resolvedRef as any,
44
+ index: index || 0,
45
+ label,
46
+ icon,
47
+ });
48
+ }
49
+ }, [selectedTab]);
50
+
51
+ const ElementType = href ? 'a' : 'button';
52
+
53
+ const handleClick = (e: React.MouseEvent<any>) => {
54
+ if (setSelectedTab) {
55
+ setSelectedTab(index ?? null);
56
+ }
57
+ if (onClick) {
58
+ onClick(e);
59
+ }
60
+ };
61
+
62
+ const styles = tabStyle({
63
+ className,
64
+ onTabSelected,
65
+ scrollable,
66
+ selectedTab,
67
+ index,
68
+ tabsId,
69
+ selected: isSelected,
70
+ variant,
71
+ icon,
72
+ label,
73
+ isSelected,
74
+ setSelectedTab,
75
+ href: href as any,
76
+ });
77
+
78
+ return (
79
+ <ElementType
80
+ {...restProps}
81
+ role="tab"
82
+ aria-selected={isSelected}
83
+ ref={resolvedRef}
84
+ href={href}
85
+ className={styles.tab}
86
+ onClick={handleClick}
87
+ {...(restProps as any)}
88
+ >
89
+ <span className={styles.stateLayer}>
90
+ <RippleEffect
91
+ colorName={
92
+ variant === 'primary' && isSelected ? 'primary' : 'on-surface'
93
+ }
94
+ triggerRef={resolvedRef}
95
+ />
96
+ </span>
97
+ <span className={styles.content}>
98
+ {icon && <Icon icon={icon} className={styles.icon} />}
99
+ <span className={styles.label}>{label}</span>
100
+ {isSelected && (
101
+ <motion.span
102
+ layoutId={`underline-${tabsId}`}
103
+ className={styles.underline}
104
+ transition={{ duration: 0.3 }}
105
+ />
106
+ )}
107
+ </span>
108
+ </ElementType>
109
+ );
110
+ };
@@ -0,0 +1,85 @@
1
+ import React, { useMemo, useState } from 'react';
2
+ import { v4 as uuidv4 } from 'uuid';
3
+ import { TabsInterface } from '../interfaces/tabs.interface';
4
+
5
+ import { tabsStyle } from '../styles/tabs.style';
6
+ import { ReactProps } from '../utils/component';
7
+ import { TabProps } from '../interfaces/tab.interface';
8
+ import { Tab } from './Tab';
9
+
10
+ export const Tabs = ({
11
+ variant = 'primary',
12
+ onTabSelected,
13
+ children,
14
+ className,
15
+ selectedTab: externalSelectedTab,
16
+ setSelectedTab: externalSetSelectedTab,
17
+ scrollable = false,
18
+ }: ReactProps<TabsInterface>) => {
19
+ const [internalSelectedTab, internalSetSelectedTab] = useState<number | null>(
20
+ null
21
+ );
22
+
23
+ let selectedTab: number | null;
24
+ if (externalSelectedTab == 0 || externalSelectedTab != undefined) {
25
+ selectedTab = externalSelectedTab;
26
+ } else {
27
+ selectedTab = internalSelectedTab;
28
+ }
29
+
30
+ const setSelectedTab = externalSetSelectedTab || internalSetSelectedTab;
31
+
32
+ const tabChildren = React.Children.toArray(children).filter(
33
+ (child) => React.isValidElement(child) && child.type === Tab
34
+ );
35
+
36
+ const ref = React.useRef<HTMLDivElement | null>(null);
37
+
38
+ const handleOnTabSelected = (
39
+ args: { index: number } & Pick<TabProps, 'label' | 'icon'> & {
40
+ ref: React.RefObject<any>;
41
+ }
42
+ ) => {
43
+ onTabSelected?.(args);
44
+
45
+ if (scrollable) {
46
+ const tabs: HTMLElement = ref.current!;
47
+ const tabSelected: HTMLElement = args.ref.current;
48
+ if (tabs && tabSelected) {
49
+ const scrollLeft =
50
+ tabSelected.offsetLeft +
51
+ tabSelected.offsetWidth / 2 -
52
+ tabs.offsetWidth / 2;
53
+ tabs.scrollTo({ left: scrollLeft, behavior: 'smooth' });
54
+ }
55
+ }
56
+ };
57
+
58
+ const tabsId = useMemo(() => uuidv4(), []);
59
+
60
+ const styles = tabsStyle({
61
+ children,
62
+ onTabSelected,
63
+ scrollable,
64
+ selectedTab,
65
+ setSelectedTab,
66
+ className,
67
+ variant,
68
+ });
69
+ return (
70
+ <div ref={ref} role="tablist" className={styles.tabs}>
71
+ {tabChildren.map((child, index) => {
72
+ return React.cloneElement(child as React.ReactElement<TabProps>, {
73
+ key: index,
74
+ index,
75
+ variant: variant,
76
+ selectedTab,
77
+ setSelectedTab: setSelectedTab,
78
+ tabsId: tabsId,
79
+ onTabSelected: handleOnTabSelected,
80
+ scrollable,
81
+ });
82
+ })}
83
+ </div>
84
+ );
85
+ };
@@ -0,0 +1,269 @@
1
+ import React, { useEffect, useState } from 'react';
2
+ import { Icon } from '../icon';
3
+ import { faCircleExclamation } from '@fortawesome/free-solid-svg-icons';
4
+ import { motion } from 'motion/react';
5
+ import { v4 as uuidv4 } from 'uuid';
6
+
7
+ import TextareaAutosize from 'react-textarea-autosize';
8
+ import { textFieldStyle } from '../styles/text-field.style';
9
+ import { classNames } from '../utils';
10
+ import { ReactProps } from '../utils/component';
11
+ import { TextFieldInterface } from '../interfaces/text-field.interface';
12
+
13
+ export const TextField = ({
14
+ variant = 'filled',
15
+ disabled = false,
16
+ errorText,
17
+ placeholder,
18
+ suffix,
19
+ name,
20
+ label,
21
+ className,
22
+ supportingText,
23
+ trailingIcon,
24
+ leadingIcon,
25
+ type = 'text',
26
+ textLine = 'singleLine',
27
+ autoComplete = 'on',
28
+ onChange,
29
+ value: defaultValue,
30
+ showSupportingText: defaultShowSupportingText = false,
31
+ ...restProps
32
+ }: ReactProps<TextFieldInterface>) => {
33
+ const [value, setValue] = useState(defaultValue ?? '');
34
+ const [isFocused, setIsFocused] = useState(false);
35
+ const [showErrorIcon, setShowErrorIcon] = useState(false);
36
+ const [showSupportingText, setShowSupportingText] = useState(
37
+ defaultShowSupportingText
38
+ );
39
+
40
+ useEffect(() => {
41
+ setValue(defaultValue ?? '');
42
+ }, [defaultValue]);
43
+
44
+ useEffect(() => {
45
+ if (errorText?.length) {
46
+ setShowErrorIcon(true);
47
+ } else {
48
+ setShowErrorIcon(false);
49
+ }
50
+ }, [errorText]);
51
+
52
+ useEffect(() => {
53
+ if (defaultShowSupportingText) {
54
+ setShowSupportingText(defaultShowSupportingText);
55
+ } else {
56
+ if (supportingText?.length) {
57
+ setShowSupportingText(true);
58
+ } else {
59
+ setShowSupportingText(false);
60
+ }
61
+ }
62
+ }, [showSupportingText, supportingText]);
63
+
64
+ useEffect(() => {
65
+ if (isFocused) {
66
+ setShowErrorIcon(false);
67
+ }
68
+ }, [isFocused]);
69
+
70
+ const inputRef = React.useRef<HTMLInputElement & HTMLTextAreaElement>(null);
71
+
72
+ const focusInput = () => {
73
+ if (inputRef.current && !isFocused) {
74
+ inputRef.current.focus();
75
+ }
76
+ };
77
+
78
+ const handleOnFocus = () => {
79
+ setIsFocused(true);
80
+ };
81
+
82
+ const handleChange = (
83
+ event: React.ChangeEvent<HTMLInputElement & HTMLTextAreaElement>
84
+ ) => {
85
+ const newValue = event.target.value;
86
+ setValue(newValue); // Update local state
87
+
88
+ setShowErrorIcon(false);
89
+
90
+ // If external onChange prop is provided, call it with the new value
91
+ if (typeof onChange === 'function') {
92
+ onChange(newValue);
93
+ }
94
+ };
95
+
96
+ const handleBlur = () => {
97
+ setIsFocused(false);
98
+ };
99
+
100
+ const styles = textFieldStyle({
101
+ showSupportingText,
102
+ isFocused,
103
+ showErrorIcon,
104
+ disabled,
105
+ name,
106
+ label,
107
+ autoComplete,
108
+ className,
109
+ onChange,
110
+ placeholder,
111
+ supportingText,
112
+ type,
113
+ leadingIcon,
114
+ trailingIcon,
115
+ variant,
116
+ errorText,
117
+ value,
118
+ suffix,
119
+ textLine,
120
+ });
121
+
122
+ const [uuid] = useState(uuidv4());
123
+
124
+ let textComponentProps: object;
125
+ let TextComponent;
126
+ switch (textLine) {
127
+ case 'multiLine':
128
+ TextComponent = TextareaAutosize;
129
+ textComponentProps = {};
130
+ break;
131
+ case 'textAreas':
132
+ TextComponent = 'textarea';
133
+ textComponentProps = {};
134
+ break;
135
+ case 'singleLine':
136
+ default:
137
+ TextComponent = 'input';
138
+ textComponentProps = { type: type };
139
+ break;
140
+ }
141
+
142
+ return (
143
+ <div className={styles.textField} {...restProps}>
144
+ <fieldset onClick={focusInput} className={styles.content}>
145
+ <div className={styles.stateLayer}></div>
146
+ {leadingIcon && (
147
+ <div className={styles.leadingIcon}>
148
+ {React.isValidElement(leadingIcon) ? (
149
+ leadingIcon
150
+ ) : (
151
+ <Icon className={'w-5 h-5'} icon={leadingIcon}></Icon>
152
+ )}
153
+ </div>
154
+ )}
155
+
156
+ {!((!isFocused && !value.length) || variant == 'filled') && (
157
+ <motion.legend
158
+ variants={{
159
+ hidden: { width: 0, padding: 0 },
160
+ visible: { width: 'auto', padding: '0 8px' },
161
+ }}
162
+ initial={'hidden'}
163
+ animate={!(!isFocused && !value.length) ? 'visible' : 'hidden'}
164
+ className={'max-w-full ml-2 px-2 text-body-small h-0'}
165
+ transition={{ duration: 0.2 }}
166
+ >
167
+ <span className={'transform inline-flex -translate-y-1/2'}>
168
+ <motion.span
169
+ className={styles.label}
170
+ transition={{ duration: 0.3 }}
171
+ layoutId={uuid}
172
+ >
173
+ {label}
174
+ </motion.span>
175
+ </span>
176
+ </motion.legend>
177
+ )}
178
+ <div className={'flex-1 relative'}>
179
+ {((!isFocused && !value.length) || variant == 'filled') && (
180
+ <motion.label
181
+ htmlFor={name}
182
+ className={classNames(
183
+ 'absolute left-4 transition-all duration-300',
184
+ {
185
+ 'text-body-small top-2':
186
+ variant == 'filled' && !(!isFocused && !value.length),
187
+ 'text-body-large top-1/2 transform -translate-y-1/2': !(
188
+ variant == 'filled' && !(!isFocused && !value.length)
189
+ ),
190
+ }
191
+ )}
192
+ transition={{ duration: 0.3 }}
193
+ >
194
+ <motion.span
195
+ className={styles.label}
196
+ transition={{ duration: 0.3 }}
197
+ layoutId={variant == 'outlined' ? uuid : undefined}
198
+ >
199
+ {label}
200
+ </motion.span>
201
+ </motion.label>
202
+ )}
203
+ <TextComponent
204
+ ref={inputRef}
205
+ value={value}
206
+ onChange={handleChange}
207
+ className={styles.input}
208
+ id={name}
209
+ name={name}
210
+ placeholder={isFocused ? (placeholder ?? undefined) : ''}
211
+ onFocus={handleOnFocus}
212
+ onBlur={handleBlur}
213
+ disabled={disabled}
214
+ autoComplete={autoComplete}
215
+ aria-invalid={!!errorText?.length}
216
+ aria-label={label}
217
+ {...textComponentProps}
218
+ />
219
+ </div>
220
+
221
+ <div className={styles.activeIndicator}></div>
222
+
223
+ {!showErrorIcon && (
224
+ <>
225
+ {trailingIcon && (
226
+ <div
227
+ onClick={(event) => {
228
+ event.stopPropagation();
229
+ }}
230
+ className={styles.trailingIcon}
231
+ >
232
+ {React.isValidElement(trailingIcon) ? (
233
+ trailingIcon
234
+ ) : (
235
+ <Icon className={'h-5'} icon={trailingIcon}></Icon>
236
+ )}
237
+ </div>
238
+ )}
239
+ {!trailingIcon && suffix && (
240
+ <span className={styles.suffix}>{suffix}</span>
241
+ )}
242
+ </>
243
+ )}
244
+
245
+ {showErrorIcon && (
246
+ <div
247
+ className={classNames(styles.trailingIcon, {
248
+ ' absolute right-0': !trailingIcon,
249
+ })}
250
+ >
251
+ <Icon
252
+ className={'h-5 text-error'}
253
+ icon={faCircleExclamation}
254
+ ></Icon>
255
+ </div>
256
+ )}
257
+ </fieldset>
258
+ {showSupportingText && (
259
+ <p className={styles.supportingText}>
260
+ {errorText?.length
261
+ ? errorText
262
+ : supportingText?.length
263
+ ? supportingText
264
+ : '\u00A0'}
265
+ </p>
266
+ )}
267
+ </div>
268
+ );
269
+ };