trepur_components 2.3.6 → 2.3.8

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 (470) hide show
  1. package/.eslintrc.cjs +33 -4
  2. package/.prettierignore +10 -0
  3. package/README.md +1 -1
  4. package/archive/theme.ts +1 -1
  5. package/lib/_virtual/react.js +4 -0
  6. package/lib/components/Accordion/Accordion.stories.d.ts +3 -2
  7. package/lib/components/Accordion/index.d.ts +2 -4
  8. package/lib/components/Accordion/index.js +4 -13
  9. package/lib/components/AlertBar/AlertBar.stories.d.ts +3 -2
  10. package/lib/components/AlertBar/index.d.ts +1 -1
  11. package/lib/components/Avatar/index.d.ts +1 -2
  12. package/lib/components/Breadcrumbs/Breadcrumbs.stories.d.ts +62 -0
  13. package/lib/components/Breadcrumbs/index.d.ts +9 -0
  14. package/lib/components/Breadcrumbs/index.js +12 -0
  15. package/lib/components/BreadcrumbsBordered/BreadcrumbsBordered.stories.d.ts +67 -0
  16. package/lib/components/BreadcrumbsBordered/index.d.ts +6 -0
  17. package/lib/components/BreadcrumbsBordered/index.js +28 -0
  18. package/lib/components/BreadcrumbsItem/BreadcrumbsItem.stories.d.ts +74 -0
  19. package/lib/components/BreadcrumbsItem/index.d.ts +10 -0
  20. package/lib/components/BreadcrumbsItem/index.js +117 -0
  21. package/lib/components/Button/Button.stories.d.ts +192 -0
  22. package/lib/components/Button/index.d.ts +19 -0
  23. package/lib/components/Button/index.js +66 -0
  24. package/lib/components/Calendar/Calendar.stories.d.ts +136 -0
  25. package/lib/components/Calendar/index.d.ts +15 -0
  26. package/lib/components/Calendar/index.js +46 -0
  27. package/lib/components/Calendar/style.css.js +1 -0
  28. package/lib/components/Card/Card.stories.d.ts +108 -0
  29. package/lib/components/Card/index.d.ts +17 -0
  30. package/lib/components/Card/index.js +51 -0
  31. package/lib/components/CardWithTopImage/CardWithTopImage.stories.d.ts +83 -0
  32. package/lib/components/CardWithTopImage/index.d.ts +9 -0
  33. package/lib/components/CardWithTopImage/index.js +28 -0
  34. package/lib/components/Carousel/Carousel.stories.d.ts +562 -0
  35. package/lib/components/Carousel/index.d.ts +77 -0
  36. package/lib/components/Carousel/index.js +248 -0
  37. package/lib/components/CarouselThumbnail/CarouselThumbnail.stories.d.ts +546 -0
  38. package/lib/components/CarouselThumbnail/index.d.ts +50 -0
  39. package/lib/components/CarouselThumbnail/index.js +205 -0
  40. package/lib/components/Checkbox/Checkbox.stories.d.ts +52 -0
  41. package/lib/components/Checkbox/index.d.ts +7 -0
  42. package/lib/components/Checkbox/index.js +31 -0
  43. package/lib/components/Collapsible/Collapsible.stories.d.ts +82 -0
  44. package/lib/components/Collapsible/index.d.ts +12 -0
  45. package/lib/components/Collapsible/index.js +88 -0
  46. package/lib/components/Column/Column.stories.d.ts +116 -0
  47. package/lib/components/Column/index.d.ts +10 -0
  48. package/lib/components/Column/index.js +8 -0
  49. package/lib/components/ComponentWrapper/ComponentWrapper.stories.d.ts +77 -0
  50. package/lib/components/ComponentWrapper/index.d.ts +14 -0
  51. package/lib/components/ComponentWrapper/index.js +27 -0
  52. package/lib/components/Container/Container.stories.d.ts +75 -0
  53. package/lib/components/Container/index.d.ts +7 -0
  54. package/lib/components/Container/index.js +12 -0
  55. package/lib/components/Counter/Counter.stories.d.ts +45 -0
  56. package/lib/components/Counter/index.d.ts +6 -0
  57. package/lib/components/Counter/index.js +31 -0
  58. package/lib/components/DetailUpdater/DetailUpdater.stories.d.ts +104 -0
  59. package/lib/components/DetailUpdater/index.d.ts +18 -0
  60. package/lib/components/DetailUpdater/index.js +63 -0
  61. package/lib/components/Dialog/Dialog.stories.d.ts +145 -0
  62. package/lib/components/Dialog/index.d.ts +12 -0
  63. package/lib/components/Dialog/index.js +78 -0
  64. package/lib/components/DropdownMenu/DropdownMenu.stories.d.ts +76 -0
  65. package/lib/components/DropdownMenu/index.d.ts +14 -0
  66. package/lib/components/DropdownMenu/index.js +27 -0
  67. package/lib/components/DynamicTextSection/DynamicTextSection.stories.d.ts +100 -0
  68. package/lib/components/DynamicTextSection/index.d.ts +11 -0
  69. package/lib/components/DynamicTextSection/index.js +18 -0
  70. package/lib/components/FileUploader/FilePreview.d.ts +8 -0
  71. package/lib/components/FileUploader/FileUploader.stories.d.ts +50 -0
  72. package/lib/components/FileUploader/index.d.ts +9 -0
  73. package/lib/components/FilterItem/FilterItem.stories.d.ts +57 -0
  74. package/lib/components/FilterItem/index.d.ts +8 -0
  75. package/lib/components/FilterItem/index.js +60 -0
  76. package/lib/components/Footer/Footer.stories.d.ts +105 -0
  77. package/lib/components/Footer/index.d.ts +10 -0
  78. package/lib/components/Footer/index.js +36 -0
  79. package/lib/components/FooterNav/FooterNav.stories.d.ts +135 -0
  80. package/lib/components/FooterNav/index.d.ts +13 -0
  81. package/lib/components/FooterNav/index.js +28 -0
  82. package/lib/components/FooterNavItem/FooterNavItem.stories.d.ts +93 -0
  83. package/lib/components/FooterNavItem/index.d.ts +16 -0
  84. package/lib/components/FooterNavItem/index.js +27 -0
  85. package/lib/components/Form/Form.stories.d.ts +117 -0
  86. package/lib/components/Form/index.d.ts +13 -0
  87. package/lib/components/Form/index.js +28 -0
  88. package/lib/components/FyreCard/FyreCard.stories.d.ts +58 -0
  89. package/lib/components/FyreCard/index.d.ts +12 -0
  90. package/lib/components/FyreCard/index.js +27 -0
  91. package/lib/components/Greeting/Greeting.stories.d.ts +83 -0
  92. package/lib/components/Greeting/index.d.ts +8 -0
  93. package/lib/components/Greeting/index.js +13 -0
  94. package/lib/components/HamburgerIcon/HamburgerIcon.stories.d.ts +64 -0
  95. package/lib/components/HamburgerIcon/index.d.ts +7 -0
  96. package/lib/components/HamburgerIcon/index.js +93 -0
  97. package/lib/components/HorizontalLine/HorizontalLine.stories.d.ts +96 -0
  98. package/lib/components/HorizontalLine/index.d.ts +11 -0
  99. package/lib/components/HorizontalLine/index.js +24 -0
  100. package/lib/components/Icon/Icon.stories.d.ts +47 -0
  101. package/lib/components/Icon/index.d.ts +10 -0
  102. package/lib/components/Icon/index.js +15 -0
  103. package/lib/components/IconCard/IconCard.stories.d.ts +51 -0
  104. package/lib/components/IconCard/index.d.ts +13 -0
  105. package/lib/components/IconCard/index.js +27 -0
  106. package/lib/components/Image/Image.stories.d.ts +158 -0
  107. package/lib/components/Image/index.d.ts +15 -0
  108. package/lib/components/Image/index.js +99 -0
  109. package/lib/components/ImageInfo/ImageInfo.stories.d.ts +69 -0
  110. package/lib/components/ImageInfo/index.d.ts +14 -0
  111. package/lib/components/ImageLink/ImageLink.stories.d.ts +63 -0
  112. package/lib/components/ImageLink/index.d.ts +14 -0
  113. package/lib/components/ImageLink/index.js +39 -0
  114. package/lib/components/ImageLinkList/ImageLinkList.stories.d.ts +48 -0
  115. package/lib/components/ImageLinkList/index.d.ts +8 -0
  116. package/lib/components/ImageLinkList/index.js +18 -0
  117. package/lib/components/InformationIcon/InformationIcon.stories.d.ts +54 -0
  118. package/lib/components/InformationIcon/index.d.ts +12 -0
  119. package/lib/components/InformationIcon/index.js +65 -0
  120. package/lib/components/InformationIconBlock/InformationIconBlock.stories.d.ts +55 -0
  121. package/lib/components/InformationIconBlock/index.d.ts +12 -0
  122. package/lib/components/Input/Input.stories.d.ts +114 -0
  123. package/lib/components/Input/index.d.ts +29 -0
  124. package/lib/components/Input/index.js +89 -0
  125. package/lib/components/Jumbotron/Jumbotron.stories.d.ts +48 -0
  126. package/lib/components/Jumbotron/index.d.ts +8 -0
  127. package/lib/components/Jumbotron/index.js +9 -0
  128. package/lib/components/MenuButton/MenuButton.stories.d.ts +76 -0
  129. package/lib/components/MenuButton/index.d.ts +14 -0
  130. package/lib/components/MenuButton/index.js +56 -0
  131. package/lib/components/Modal/Modal.stories.d.ts +67 -0
  132. package/lib/components/Modal/index.d.ts +10 -0
  133. package/lib/components/Modal/index.js +45 -0
  134. package/lib/components/NavItem/NavItem.stories.d.ts +154 -0
  135. package/lib/components/NavItem/index.d.ts +16 -0
  136. package/lib/components/NavItem/index.js +25 -0
  137. package/lib/components/NavOld/NavOld.stories.d.ts +290 -0
  138. package/lib/components/NavOld/StickyNav.d.ts +22 -0
  139. package/lib/components/NavOld/StickyNav.js +135 -0
  140. package/lib/components/NavOld/index.d.ts +26 -0
  141. package/lib/components/NavOld/index.js +187 -0
  142. package/lib/components/NavTwo/Dropdown.d.ts +7 -0
  143. package/lib/components/NavTwo/Dropdown.js +21 -0
  144. package/lib/components/NavTwo/Nav.stories.d.ts +62 -0
  145. package/lib/components/NavTwo/Sidebar.d.ts +7 -0
  146. package/lib/components/NavTwo/Sidebar.js +21 -0
  147. package/lib/components/NavTwo/StickyNav.d.ts +7 -0
  148. package/lib/components/NavTwo/StickyNav.js +20 -0
  149. package/lib/components/NavTwo/index.d.ts +13 -0
  150. package/lib/components/NavTwo/index.js +28 -0
  151. package/lib/components/NewsCard/NewsCard.stories.d.ts +102 -0
  152. package/lib/components/NewsCard/index.d.ts +13 -0
  153. package/lib/components/NewsCard/index.js +26 -0
  154. package/lib/components/Pill/Pill.stories.d.ts +84 -0
  155. package/lib/components/Pill/index.d.ts +8 -0
  156. package/lib/components/Pill/index.js +31 -0
  157. package/lib/components/ProductCard/ProductCard.stories.d.ts +86 -0
  158. package/lib/components/ProductCard/index.d.ts +18 -0
  159. package/lib/components/ProductCard/index.js +69 -0
  160. package/lib/components/ProductCardV2/ProductCardV2.stories.d.ts +75 -0
  161. package/lib/components/ProductCardV2/index.d.ts +21 -0
  162. package/lib/components/ProductCardV2/index.js +67 -0
  163. package/lib/components/Proficiencies/Proficiencies.stories.d.ts +51 -0
  164. package/lib/components/Proficiencies/index.d.ts +12 -0
  165. package/lib/components/Profile/Profile.stories.d.ts +80 -0
  166. package/lib/components/Profile/index.d.ts +17 -0
  167. package/lib/components/Profile/index.js +78 -0
  168. package/lib/components/Row/Row.stories.d.ts +62 -0
  169. package/lib/components/Row/index.d.ts +6 -0
  170. package/lib/components/Row/index.js +9 -0
  171. package/lib/components/Search/Search.stories.d.ts +86 -0
  172. package/lib/components/Search/index.d.ts +12 -0
  173. package/lib/components/Search/index.js +42 -0
  174. package/lib/components/Select/Select.stories.d.ts +56 -0
  175. package/lib/components/Select/index.d.ts +11 -0
  176. package/lib/components/Select/index.js +68 -0
  177. package/lib/components/Showcase/Showcase.stories.d.ts +55 -0
  178. package/lib/components/Showcase/index.d.ts +15 -0
  179. package/lib/components/SideNav/SideNav.stories.d.ts +80 -0
  180. package/lib/components/SideNav/index.d.ts +12 -0
  181. package/lib/components/SocialBlock/SocialBlock.stories.d.ts +101 -0
  182. package/lib/components/SocialBlock/index.d.ts +14 -0
  183. package/lib/components/SocialBlock/index.js +37 -0
  184. package/lib/components/SocialButton/SocialButton.stories.d.ts +130 -0
  185. package/lib/components/SocialButton/index.d.ts +12 -0
  186. package/lib/components/SocialButton/index.js +37 -0
  187. package/lib/components/StarRating/StarRating.stories.d.ts +49 -0
  188. package/lib/components/StarRating/index.d.ts +9 -0
  189. package/lib/components/StarRating/index.js +47 -0
  190. package/lib/components/Testimonial/Testimonial.stories.d.ts +172 -0
  191. package/lib/components/Testimonial/index.d.ts +16 -0
  192. package/lib/components/Testimonial/index.js +42 -0
  193. package/lib/components/TextAndTitle/TextAndTitle.stories.d.ts +97 -0
  194. package/lib/components/TextAndTitle/index.d.ts +25 -0
  195. package/lib/components/TextAndTitle/index.js +70 -0
  196. package/lib/components/TextArea/TextArea.stories.d.ts +85 -0
  197. package/lib/components/TextArea/index.d.ts +26 -0
  198. package/lib/components/TextArea/index.js +86 -0
  199. package/lib/components/Timeline/Timeline.stories.d.ts +81 -0
  200. package/lib/components/Timeline/index.d.ts +17 -0
  201. package/lib/components/Timeline/index.js +172 -0
  202. package/lib/components/TimelineV2/TimelineV2.stories.d.ts +87 -0
  203. package/lib/components/TimelineV2/index.d.ts +20 -0
  204. package/lib/components/Tubestops/Tubestops.stories.d.ts +54 -0
  205. package/lib/components/Tubestops/index.d.ts +8 -0
  206. package/lib/components/Tubestops/index.js +44 -0
  207. package/lib/components/UserIcon/UserIcon.stories.d.ts +81 -0
  208. package/lib/components/UserIcon/index.d.ts +10 -0
  209. package/lib/components/UserIcon/index.js +34 -0
  210. package/lib/components/Video/Video.stories.d.ts +49 -0
  211. package/lib/components/Video/index.d.ts +15 -0
  212. package/lib/components/Video/index.js +34 -0
  213. package/lib/components/index.d.ts +57 -1
  214. package/lib/components/typography/Fonts/Fonts.d.ts +2 -0
  215. package/lib/components/typography/Fonts/Fonts.stories.d.ts +10 -0
  216. package/lib/index.js +114 -2
  217. package/lib/node_modules/keen-slider/keen-slider.min.css.js +1 -0
  218. package/lib/node_modules/keen-slider/react.js +591 -0
  219. package/lib/style.css +1 -0
  220. package/lib/styles/global.css +1 -0
  221. package/lib/styles/themes/local.css +39 -39
  222. package/lib/styles/themes/palette.css +131 -0
  223. package/lib/tailwind/boxShadow.ts +9 -0
  224. package/lib/tailwind/colors.ts +410 -0
  225. package/lib/tailwind/container.ts +11 -0
  226. package/lib/tailwind/preset.ts +88 -0
  227. package/lib/tailwind/spacing.ts +14 -0
  228. package/lib/utils/matchMedia.js +9 -0
  229. package/package.json +7 -4
  230. package/src/components/Accordion/Accordion.stories.tsx +8 -8
  231. package/src/components/Accordion/index.tsx +8 -15
  232. package/src/components/AlertBar/AlertBar.stories.tsx +9 -9
  233. package/src/components/AlertBar/index.tsx +11 -11
  234. package/src/components/Avatar/Avatar.stories.tsx +3 -3
  235. package/src/components/Avatar/index.tsx +35 -38
  236. package/{archive → src/components}/Breadcrumbs/Breadcrumbs.stories.tsx +8 -8
  237. package/{archive → src/components}/Breadcrumbs/index.tsx +11 -13
  238. package/{archive → src/components}/BreadcrumbsBordered/BreadcrumbsBordered.stories.tsx +8 -8
  239. package/{archive → src/components}/BreadcrumbsBordered/index.tsx +8 -11
  240. package/{archive → src/components}/BreadcrumbsItem/BreadcrumbsItem.stories.tsx +8 -8
  241. package/{archive → src/components}/BreadcrumbsItem/index.tsx +20 -22
  242. package/{archive → src/components}/Button/Button.stories.tsx +18 -18
  243. package/{archive → src/components}/Button/index.tsx +27 -34
  244. package/{archive → src/components}/Calendar/Calendar.stories.tsx +9 -9
  245. package/{archive → src/components}/Calendar/index.tsx +6 -10
  246. package/{archive → src/components}/Card/Card.stories.tsx +7 -7
  247. package/{archive → src/components}/Card/index.tsx +20 -26
  248. package/{archive → src/components}/CardWithTopImage/CardWithTopImage.stories.tsx +8 -8
  249. package/{archive → src/components}/CardWithTopImage/index.tsx +9 -13
  250. package/{archive → src/components}/Carousel/Carousel.stories.tsx +37 -37
  251. package/{archive → src/components}/Carousel/index.tsx +35 -41
  252. package/{archive → src/components}/CarouselThumbnail/CarouselThumbnail.stories.tsx +36 -36
  253. package/{archive → src/components}/CarouselThumbnail/index.tsx +24 -33
  254. package/{archive → src/components}/Checkbox/Checkbox.stories.tsx +9 -9
  255. package/{archive → src/components}/Checkbox/index.tsx +8 -18
  256. package/{archive → src/components}/Collapsible/Collapsible.stories.tsx +10 -10
  257. package/{archive → src/components}/Collapsible/index.tsx +42 -30
  258. package/{archive → src/components}/Column/Column.stories.tsx +12 -12
  259. package/src/components/Column/index.tsx +18 -0
  260. package/{archive → src/components}/ComponentWrapper/ComponentWrapper.stories.tsx +7 -7
  261. package/{archive → src/components}/ComponentWrapper/index.tsx +13 -20
  262. package/{archive → src/components}/Container/Container.stories.tsx +7 -7
  263. package/{archive → src/components}/Container/index.tsx +6 -9
  264. package/{archive → src/components}/Counter/Counter.stories.tsx +4 -4
  265. package/src/components/Counter/index.tsx +42 -0
  266. package/{archive → src/components}/DetailUpdater/DetailUpdater.stories.tsx +17 -18
  267. package/{archive → src/components}/DetailUpdater/index.tsx +21 -25
  268. package/{archive → src/components}/Dialog/Dialog.stories.tsx +14 -15
  269. package/{archive → src/components}/Dialog/index.tsx +26 -24
  270. package/{archive → src/components}/DropdownMenu/DropdownMenu.stories.tsx +8 -8
  271. package/{archive → src/components}/DropdownMenu/index.tsx +6 -12
  272. package/{archive → src/components}/DynamicTextSection/DynamicTextSection.stories.tsx +13 -11
  273. package/{archive → src/components}/DynamicTextSection/index.tsx +5 -9
  274. package/{archive → src/components}/FileUploader/FilePreview.tsx +13 -16
  275. package/{archive → src/components}/FileUploader/FileUploader.stories.tsx +6 -8
  276. package/{archive → src/components}/FileUploader/index.tsx +22 -25
  277. package/{archive → src/components}/FilterItem/FilterItem.stories.tsx +7 -7
  278. package/{archive → src/components}/FilterItem/index.tsx +23 -27
  279. package/{archive → src/components}/Footer/Footer.stories.tsx +7 -7
  280. package/{archive → src/components}/Footer/index.tsx +14 -16
  281. package/{archive → src/components}/FooterNav/FooterNav.stories.tsx +22 -25
  282. package/{archive → src/components}/FooterNav/index.tsx +8 -16
  283. package/{archive → src/components}/FooterNavItem/FooterNavItem.stories.tsx +8 -8
  284. package/{archive → src/components}/FooterNavItem/index.tsx +10 -32
  285. package/{archive → src/components}/Form/Form.stories.tsx +11 -11
  286. package/{archive → src/components}/Form/index.tsx +6 -21
  287. package/{archive → src/components}/FyreCard/FyreCard.stories.tsx +7 -7
  288. package/{archive → src/components}/FyreCard/index.tsx +10 -18
  289. package/{archive → src/components}/Greeting/Greeting.stories.tsx +9 -9
  290. package/{archive → src/components}/Greeting/index.tsx +4 -6
  291. package/{archive → src/components}/HamburgerIcon/HamburgerIcon.stories.tsx +6 -6
  292. package/{archive → src/components}/HamburgerIcon/index.tsx +26 -32
  293. package/{archive → src/components}/HorizontalLine/HorizontalLine.stories.tsx +5 -5
  294. package/{archive → src/components}/HorizontalLine/index.tsx +8 -16
  295. package/src/components/Icon/Icon.stories.tsx +22 -0
  296. package/src/components/Icon/index.tsx +25 -0
  297. package/{archive → src/components}/IconCard/IconCard.stories.tsx +7 -27
  298. package/{archive → src/components}/IconCard/index.tsx +13 -16
  299. package/{archive → src/components}/Image/Image.stories.tsx +15 -15
  300. package/{archive → src/components}/Image/index.tsx +43 -48
  301. package/{archive → src/components}/ImageInfo/ImageInfo.stories.tsx +8 -9
  302. package/{archive → src/components}/ImageInfo/index.tsx +18 -29
  303. package/{archive → src/components}/ImageLink/ImageLink.stories.tsx +8 -9
  304. package/src/components/ImageLink/index.tsx +58 -0
  305. package/{archive → src/components}/ImageLinkList/ImageLinkList.stories.tsx +8 -8
  306. package/{archive → src/components}/ImageLinkList/index.tsx +4 -9
  307. package/src/components/InformationIcon/InformationIcon.stories.tsx +29 -0
  308. package/{archive → src/components}/InformationIcon/index.tsx +21 -44
  309. package/src/components/InformationIconBlock/InformationIconBlock.stories.tsx +38 -0
  310. package/{archive → src/components}/InformationIconBlock/index.tsx +15 -22
  311. package/{archive → src/components}/Input/Input.stories.tsx +13 -13
  312. package/{archive → src/components}/Input/index.tsx +22 -23
  313. package/{archive → src/components}/Jumbotron/Jumbotron.stories.tsx +5 -5
  314. package/{archive → src/components}/Jumbotron/index.tsx +4 -16
  315. package/{archive → src/components}/MenuButton/MenuButton.stories.tsx +7 -7
  316. package/src/components/MenuButton/index.tsx +66 -0
  317. package/{archive → src/components}/Modal/Modal.stories.tsx +11 -15
  318. package/{archive → src/components}/Modal/index.tsx +13 -16
  319. package/{archive → src/components}/NavItem/NavItem.stories.tsx +9 -9
  320. package/src/components/NavItem/index.tsx +43 -0
  321. package/{archive → src/components}/NavOld/NavOld.stories.tsx +21 -21
  322. package/{archive → src/components}/NavOld/StickyNav.tsx +47 -51
  323. package/{archive → src/components}/NavOld/index.tsx +50 -58
  324. package/{archive → src/components}/NavTwo/Dropdown.tsx +7 -12
  325. package/{archive → src/components}/NavTwo/Nav.stories.tsx +6 -12
  326. package/{archive → src/components}/NavTwo/Sidebar.tsx +6 -10
  327. package/{archive → src/components}/NavTwo/StickyNav.tsx +5 -10
  328. package/{archive → src/components}/NavTwo/index.tsx +6 -14
  329. package/{archive → src/components}/NewsCard/NewsCard.stories.tsx +11 -11
  330. package/{archive → src/components}/NewsCard/index.tsx +8 -21
  331. package/{archive → src/components}/Pill/Pill.stories.tsx +9 -9
  332. package/{archive → src/components}/Pill/index.tsx +17 -27
  333. package/{archive → src/components}/ProductCard/ProductCard.stories.tsx +6 -6
  334. package/{archive → src/components}/ProductCard/index.tsx +21 -22
  335. package/{archive → src/components}/ProductCardV2/ProductCardV2.stories.tsx +6 -6
  336. package/src/components/ProductCardV2/index.tsx +98 -0
  337. package/{archive → src/components}/Proficiencies/Proficiencies.stories.tsx +5 -5
  338. package/{archive → src/components}/Proficiencies/index.tsx +10 -22
  339. package/{archive → src/components}/Profile/Profile.stories.tsx +9 -9
  340. package/{archive → src/components}/Profile/index.tsx +26 -26
  341. package/{archive → src/components}/Row/Row.stories.tsx +8 -8
  342. package/{archive → src/components}/Row/index.tsx +3 -9
  343. package/{archive → src/components}/Search/Search.stories.tsx +10 -10
  344. package/{archive → src/components}/Search/index.tsx +14 -18
  345. package/{archive → src/components}/Select/Select.stories.tsx +7 -8
  346. package/{archive → src/components}/Select/index.tsx +28 -36
  347. package/{archive → src/components}/Showcase/Showcase.stories.tsx +7 -6
  348. package/src/components/Showcase/index.tsx +69 -0
  349. package/{archive → src/components}/SideNav/SideNav.stories.tsx +9 -9
  350. package/{archive → src/components}/SideNav/index.tsx +10 -17
  351. package/{archive → src/components}/SocialBlock/SocialBlock.stories.tsx +8 -8
  352. package/{archive → src/components}/SocialBlock/index.tsx +15 -19
  353. package/{archive → src/components}/SocialButton/SocialButton.stories.tsx +13 -13
  354. package/{archive → src/components}/SocialButton/index.tsx +19 -26
  355. package/{archive → src/components}/StarRating/StarRating.stories.tsx +5 -5
  356. package/{archive → src/components}/StarRating/index.tsx +22 -28
  357. package/{archive → src/components}/Testimonial/Testimonial.stories.tsx +7 -8
  358. package/{archive → src/components}/Testimonial/index.tsx +12 -18
  359. package/{archive → src/components}/TextAndTitle/TextAndTitle.stories.tsx +9 -8
  360. package/{archive → src/components}/TextAndTitle/index.tsx +25 -29
  361. package/{archive → src/components}/TextArea/TextArea.stories.tsx +9 -9
  362. package/{archive → src/components}/TextArea/index.tsx +22 -23
  363. package/{archive → src/components}/Timeline/Timeline.stories.tsx +14 -14
  364. package/{archive → src/components}/Timeline/index.tsx +58 -56
  365. package/{archive → src/components}/TimelineV2/TimelineV2.stories.tsx +10 -10
  366. package/{archive → src/components}/TimelineV2/index.tsx +15 -15
  367. package/{archive → src/components}/Tubestops/Tubestops.stories.tsx +6 -6
  368. package/src/components/Tubestops/index.tsx +54 -0
  369. package/{archive → src/components}/UserIcon/UserIcon.stories.tsx +8 -8
  370. package/{archive → src/components}/UserIcon/index.tsx +15 -18
  371. package/{archive → src/components}/Video/Video.stories.tsx +5 -5
  372. package/{archive → src/components}/Video/index.tsx +3 -5
  373. package/src/components/index.ts +112 -112
  374. package/src/components/typography/Fonts/Fonts.stories.tsx +14 -0
  375. package/src/components/typography/Fonts/Fonts.tsx +74 -0
  376. package/src/documentation/Colours.mdx +1 -1
  377. package/src/styles/global.css +1 -0
  378. package/src/styles/themes/local.css +39 -39
  379. package/src/styles/themes/palette.css +131 -0
  380. package/tailwind/boxShadow.ts +9 -0
  381. package/tailwind/colors.ts +410 -0
  382. package/tailwind/container.ts +11 -0
  383. package/tailwind/preset.ts +88 -0
  384. package/tailwind/spacing.ts +14 -0
  385. package/tsconfig.json +8 -2
  386. package/archive/Button/style.module.css +0 -76
  387. package/archive/Card/style.module.css +0 -75
  388. package/archive/CardWithTopImage/style.module.css +0 -11
  389. package/archive/Carousel/style.module.css +0 -99
  390. package/archive/CarouselThumbnail/style.module.css +0 -67
  391. package/archive/Checkbox/style.module.css +0 -15
  392. package/archive/Collapsible/style.module.css +0 -47
  393. package/archive/Column/index.tsx +0 -119
  394. package/archive/Column/style.module.css +0 -151
  395. package/archive/ComponentWrapper/style.module.css +0 -40
  396. package/archive/Container/style.module.css +0 -4
  397. package/archive/Counter/index.tsx +0 -66
  398. package/archive/Counter/style.module.css +0 -19
  399. package/archive/DetailUpdater/style.module.css +0 -31
  400. package/archive/Dialog/style.module.css +0 -44
  401. package/archive/DropdownMenu/style.module.css +0 -38
  402. package/archive/FileUploader/style.module.css +0 -54
  403. package/archive/FilterItem/style.module.css +0 -27
  404. package/archive/Footer/style.module.css +0 -19
  405. package/archive/FooterNav/style.module.css +0 -32
  406. package/archive/FooterNavItem/style.module.css +0 -139
  407. package/archive/Form/style.module.css +0 -0
  408. package/archive/FyreCard/style.module.css +0 -19
  409. package/archive/HamburgerIcon/style.module.css +0 -85
  410. package/archive/HorizontalLine/style.module.css +0 -55
  411. package/archive/Icon/Icon.stories.tsx +0 -164
  412. package/archive/Icon/index.tsx +0 -115
  413. package/archive/Icon/style.module.css +0 -253
  414. package/archive/IconCard/style.module.css +0 -18
  415. package/archive/Image/style.module.css +0 -109
  416. package/archive/ImageInfo/style.module.css +0 -47
  417. package/archive/ImageLink/index.tsx +0 -49
  418. package/archive/ImageLink/style.module.css +0 -23
  419. package/archive/ImageLinkList/style.module.css +0 -3
  420. package/archive/InformationIcon/InformationIcon.stories.tsx +0 -83
  421. package/archive/InformationIcon/style.module.css +0 -71
  422. package/archive/InformationIconBlock/InformationIconBlock.stories.tsx +0 -32
  423. package/archive/InformationIconBlock/style.module.css +0 -7
  424. package/archive/Input/style.module.css +0 -60
  425. package/archive/Jumbotron/style.module.css +0 -8
  426. package/archive/MenuButton/index.tsx +0 -82
  427. package/archive/MenuButton/style.module.css +0 -45
  428. package/archive/Modal/style.module.css +0 -35
  429. package/archive/NavItem/index.tsx +0 -65
  430. package/archive/NavItem/style.module.css +0 -71
  431. package/archive/NavOld/style.module.css +0 -156
  432. package/archive/NavTwo/style.module.css +0 -35
  433. package/archive/NewsCard/style.module.css +0 -15
  434. package/archive/Pill/style.module.css +0 -32
  435. package/archive/ProductCard/style.module.css +0 -53
  436. package/archive/ProductCardV2/index.tsx +0 -119
  437. package/archive/ProductCardV2/style.module.css +0 -59
  438. package/archive/Proficiencies/style.module.css +0 -31
  439. package/archive/Profile/style.module.css +0 -47
  440. package/archive/Row/style.module.css +0 -3
  441. package/archive/Search/style.module.css +0 -23
  442. package/archive/Select/style.module.css +0 -52
  443. package/archive/Showcase/index.tsx +0 -75
  444. package/archive/Showcase/style.module.css +0 -47
  445. package/archive/SideNav/style.module.css +0 -43
  446. package/archive/SocialButton/style.module.css +0 -77
  447. package/archive/Testimonial/style.module.css +0 -27
  448. package/archive/TextAndTitle/style.module.css +0 -75
  449. package/archive/TextArea/style.module.css +0 -60
  450. package/archive/Timeline/style.module.css +0 -134
  451. package/archive/TimelineV2/style.module.css +0 -28
  452. package/archive/Tubestops/index.tsx +0 -58
  453. package/archive/Tubestops/style.module.css +0 -54
  454. package/archive/UserIcon/style.module.css +0 -19
  455. package/archive/typography/Fonts/Fonts.stories.tsx +0 -14
  456. package/archive/typography/Fonts/Fonts.tsx +0 -181
  457. /package/{archive → src/components}/Calendar/style.css +0 -0
  458. /package/{archive → src/components}/Checkbox/Checkbox.mdx +0 -0
  459. /package/{archive/DynamicTextSection → src/components/Form}/style.module.css +0 -0
  460. /package/{archive → src/components}/fonts/Sora/OFL.txt +0 -0
  461. /package/{archive → src/components}/fonts/Sora/README.txt +0 -0
  462. /package/{archive → src/components}/fonts/Sora/Sora-VariableFont_wght.ttf +0 -0
  463. /package/{archive → src/components}/fonts/Sora/static/Sora-Bold.ttf +0 -0
  464. /package/{archive → src/components}/fonts/Sora/static/Sora-ExtraBold.ttf +0 -0
  465. /package/{archive → src/components}/fonts/Sora/static/Sora-ExtraLight.ttf +0 -0
  466. /package/{archive → src/components}/fonts/Sora/static/Sora-Light.ttf +0 -0
  467. /package/{archive → src/components}/fonts/Sora/static/Sora-Medium.ttf +0 -0
  468. /package/{archive → src/components}/fonts/Sora/static/Sora-Regular.ttf +0 -0
  469. /package/{archive → src/components}/fonts/Sora/static/Sora-SemiBold.ttf +0 -0
  470. /package/{archive → src/components}/fonts/Sora/static/Sora-Thin.ttf +0 -0
@@ -1,13 +1,8 @@
1
- import React from 'react';
2
-
3
- import ComponentWrapper from '@components/ComponentWrapper';
4
- import Container from '@components/Container';
5
- import { type Props as iconProps } from '@components/Icon';
6
- import InformationIcon from '@components/InformationIcon';
1
+ import { ComponentWrapper } from '@components/ComponentWrapper';
2
+ import { Container } from '@components/Container';
3
+ import { type IconProps } from '@components/Icon';
4
+ import { InformationIcon } from '@components/InformationIcon';
7
5
  import { type Colours } from '@utils/controls';
8
- import classNames from 'classnames';
9
-
10
-
11
6
 
12
7
  export interface Props {
13
8
  id?: string;
@@ -15,18 +10,18 @@ export interface Props {
15
10
  title?: string;
16
11
  description?: string;
17
12
  bgColour?: Colours;
18
- icons?: iconProps[];
13
+ icons?: IconProps[];
19
14
  }
20
15
 
21
- const InformationIconBlock = ({
16
+ export const InformationIconBlock = ({
22
17
  id,
23
18
  className,
24
19
  title,
25
20
  description,
26
21
  bgColour,
27
22
  icons,
28
- }: Props): JSX.Element => {
29
- const classList = classNames(className, 'theme-local');
23
+ }: Props) => {
24
+ const classList = className;
30
25
  return (
31
26
  <ComponentWrapper
32
27
  id={id}
@@ -35,18 +30,18 @@ const InformationIconBlock = ({
35
30
  description={description}
36
31
  bgColour={bgColour}
37
32
  >
38
- <Container className={style.iconWrapper} withPadding={false}>
33
+ <Container
34
+ className="grid grid-cols-2 gap-4 xl:grid-cols-4"
35
+ withPadding={false}
36
+ >
39
37
  {icons?.map((icon: any, i: number) => {
40
38
  return (
41
39
  <InformationIcon
42
40
  key={i}
43
41
  iconProps={{
44
- size: 2,
45
- type: icon.type,
42
+ size: '2x',
43
+ icon: icon.icon,
46
44
  colour: 'primary',
47
- bgColour: 'white',
48
- hoverColour: 'primary',
49
- hoverBgColour: 'white',
50
45
  }}
51
46
  id={icon.name.replace(/\s+/g, '')}
52
47
  title={icon.name}
@@ -58,6 +53,4 @@ const InformationIconBlock = ({
58
53
  </Container>
59
54
  </ComponentWrapper>
60
55
  );
61
- };
62
-
63
- export default InformationIconBlock;
56
+ }
@@ -1,7 +1,7 @@
1
- import { Meta, StoryObj } from '@storybook/react';
1
+ import { Meta, type StoryObj } from '@storybook/react';
2
2
  import { idAndClassName } from '@utils/controls';
3
3
 
4
- import Input from '.';
4
+ import { Input } from '.';
5
5
 
6
6
  const meta = {
7
7
  title: 'Components/Input',
@@ -15,49 +15,49 @@ const meta = {
15
15
  control: 'text',
16
16
  table: {
17
17
  category: '',
18
- },
18
+ }
19
19
  },
20
20
  placeholder: {
21
21
  description: '',
22
22
  control: 'text',
23
23
  table: {
24
24
  category: '',
25
- },
25
+ }
26
26
  },
27
27
  bold: {
28
28
  description: '',
29
29
  control: 'boolean',
30
30
  table: {
31
31
  category: '',
32
- },
32
+ }
33
33
  },
34
34
  required: {
35
35
  description: '',
36
36
  control: 'boolean',
37
37
  table: {
38
38
  category: '',
39
- },
39
+ }
40
40
  },
41
41
  withValidation: {
42
42
  description: '',
43
43
  control: 'boolean',
44
44
  table: {
45
45
  category: '',
46
- },
46
+ }
47
47
  },
48
48
  errors: {
49
49
  description: 'An array of errors to display',
50
50
  control: 'array',
51
51
  table: {
52
52
  category: '',
53
- },
53
+ }
54
54
  },
55
55
  value: {
56
56
  description: 'The default value of the input',
57
57
  control: 'text',
58
58
  table: {
59
59
  category: '',
60
- },
60
+ }
61
61
  },
62
62
  bgColour: {
63
63
  type: { name: 'string', required: false },
@@ -68,17 +68,17 @@ const meta = {
68
68
  },
69
69
  defaultValue: 'primary',
70
70
  control: 'select',
71
- },
71
+ }
72
72
  },
73
73
  args: {
74
74
  label: 'This is a label',
75
75
  placeholder: 'This is a placeholder',
76
76
  errors: [],
77
- },
78
- };
77
+ }
78
+ }
79
79
 
80
80
  export default meta;
81
81
 
82
- type Story = StoryObj<typeof meta>;
82
+ type Story = StoryObj<typeof Input>;
83
83
 
84
84
  export const Default: Story = {};
@@ -1,10 +1,8 @@
1
- import React, { useRef } from 'react';
1
+ import { useRef } from 'react';
2
2
 
3
3
  import { type Colours } from '@utils/controls';
4
4
  import classNames from 'classnames';
5
5
 
6
-
7
-
8
6
  export interface Props {
9
7
  id?: string;
10
8
  className?: string;
@@ -32,7 +30,7 @@ export interface Props {
32
30
  bgColour?: Colours;
33
31
  }
34
32
 
35
- const Input = ({
33
+ export const Input = ({
36
34
  id,
37
35
  className,
38
36
  autoComplete,
@@ -56,37 +54,37 @@ const Input = ({
56
54
  errors,
57
55
  errorState = false,
58
56
  value,
59
- }: Props): JSX.Element => {
57
+ }: Props) => {
60
58
  const newId = id !== undefined ? `-${id}` : '';
61
59
 
62
60
  const valueClassList = classNames(
63
61
  {
64
- [style.errorState]: errors != null || errorState,
62
+ 'border-2 border-error': errors != null || errorState,
65
63
  },
66
- style.value,
67
- );
64
+ 'w-full rounded-md bg-white py-2 pl-4 text-ink cursor-pointer border border-black text-md',
65
+ )
68
66
 
69
- const labelClassList = classNames(
70
- {
71
- [style.labelError]: errors != null || errorState,
72
- },
73
- style.label,
74
- );
67
+ const labelClassList = classNames({
68
+ 'text-error': errors != null || errorState,
69
+ })
75
70
 
76
- const headerClassList = classNames(style.classList, className, 'theme-local');
71
+ const headerClassList = classNames(
72
+ className,
73
+ 'mt-4 w-full bg-white cursor-pointer',
74
+ )
77
75
 
78
76
  const btnRef = useRef<any>(null);
79
77
 
80
78
  const handleClick = (): void => {
81
79
  btnRef.current?.focus();
82
- };
80
+ }
83
81
 
84
82
  return (
85
83
  <>
86
84
  <div id={id} className={headerClassList} onClick={handleClick}>
87
- <div className={style.labelWrapper}>
85
+ <div className="absolute -mt-3 ml-3 flex rounded-2xl bg-white px-1 text-sm font-regular">
88
86
  <p className={labelClassList}>{label}</p>
89
- {required && <p className={style.required}>&nbsp;*</p>}
87
+ {required && <p className="font-semiBold text-error">&nbsp;*</p>}
90
88
  </div>
91
89
  <input
92
90
  ref={btnRef}
@@ -114,10 +112,13 @@ const Input = ({
114
112
  />
115
113
  </div>
116
114
  {withValidation && (
117
- <div id={`errors${newId}`} className={classNames(style.errors)}>
115
+ <div id={`errors${newId}`} className="text-sm font-regular text-error">
118
116
  {errors?.map((error, i) => {
119
117
  return (
120
- <p key={`error-msg-${i + 0}`} className={style.errorText}>
118
+ <p
119
+ key={`error-msg-${i + 0}`}
120
+ className="mt-1 border-l-4 border-error pl-3"
121
+ >
121
122
  {error}
122
123
  </p>
123
124
  );
@@ -126,6 +127,4 @@ const Input = ({
126
127
  )}
127
128
  </>
128
129
  );
129
- };
130
-
131
- export default Input;
130
+ }
@@ -1,7 +1,7 @@
1
- import { Meta, StoryObj } from '@storybook/react';
1
+ import { Meta, type StoryObj } from '@storybook/react';
2
2
  import { idAndClassName } from '@utils/controls';
3
3
 
4
- import Jumbotron from '.';
4
+ import { Jumbotron } from '.';
5
5
 
6
6
  const meta = {
7
7
  title: 'Components/Jumbotron',
@@ -12,10 +12,10 @@ const meta = {
12
12
  },
13
13
  args: {
14
14
  image: 'https://picsum.photos/1000/1000',
15
- },
16
- };
15
+ }
16
+ }
17
17
  export default meta;
18
18
 
19
- type Story = StoryObj<typeof meta>;
19
+ type Story = StoryObj<typeof Jumbotron>;
20
20
 
21
21
  export const Default: Story = {};
@@ -1,9 +1,5 @@
1
- import React from 'react';
2
-
3
1
  import classNames from 'classnames';
4
2
 
5
-
6
-
7
3
  export interface Props {
8
4
  id?: string;
9
5
  className?: string;
@@ -12,20 +8,12 @@ export interface Props {
12
8
  title?: string;
13
9
  }
14
10
 
15
- const Jumbotron = ({
16
- id,
17
- className,
18
- image,
19
- altText,
20
- title,
21
- }: Props): JSX.Element => {
22
- const classList = classNames(style.classes, className, 'theme-local');
23
- const imageClassList = classNames(style.imageClasses);
11
+ export const Jumbotron = ({ id, className, image, altText, title }: Props) => {
12
+ const classList = classNames(className, 'h-96 overflow-hidden w-full');
13
+ const imageClassList = 'h-full w-full object-cover';
24
14
  return (
25
15
  <div id={id} className={classList}>
26
16
  <img className={imageClassList} src={image} alt={altText} title={title} />
27
17
  </div>
28
18
  );
29
- };
30
-
31
- export default Jumbotron;
19
+ }
@@ -1,8 +1,8 @@
1
1
  import { action } from '@storybook/addon-actions';
2
- import { Meta, StoryObj } from '@storybook/react';
2
+ import { Meta, type StoryObj } from '@storybook/react';
3
3
  import { idAndClassName } from '@utils/controls';
4
4
 
5
- import MenuButton from '.';
5
+ import { MenuButton } from '.';
6
6
 
7
7
  const meta = {
8
8
  title: 'Components/Menu Button',
@@ -25,8 +25,8 @@ const meta = {
25
25
  control: 'array',
26
26
  table: {
27
27
  type: { summary: 'array' },
28
- },
29
- },
28
+ }
29
+ }
30
30
  },
31
31
  args: {
32
32
  backgroundColour: 'white',
@@ -36,11 +36,11 @@ const meta = {
36
36
  { name: 'Menu Item 2', href: '#' },
37
37
  { name: 'Menu Item 3', href: '#' },
38
38
  { name: 'Menu Item 4', href: '#' },
39
- ],
40
- },
39
+ ]
40
+ }
41
41
  };
42
42
  export default meta;
43
43
 
44
- type Story = StoryObj<typeof meta>;
44
+ type Story = StoryObj<typeof MenuButton>;
45
45
 
46
46
  export const Default: Story = {};
@@ -0,0 +1,66 @@
1
+ import React, { useState } from 'react';
2
+
3
+ import { DropdownMenu } from '@components/DropdownMenu';
4
+ import { Image } from '@components/Image';
5
+ import { type Colours } from '@utils/controls';
6
+ import classNames from 'classnames';
7
+
8
+ export interface Props {
9
+ id?: string;
10
+ className?: string;
11
+ backgroundColour?: Colours;
12
+
13
+ menuItems: Array<{ name: string; href: string }>;
14
+ onClick?: React.MouseEventHandler;
15
+ }
16
+
17
+ export const MenuButton = ({
18
+ id,
19
+ className,
20
+ backgroundColour = 'white',
21
+
22
+ menuItems,
23
+ onClick,
24
+ }: Props) => {
25
+ const [showMenu, setShowMenu] = useState(false);
26
+ const classList = classNames(
27
+ className,
28
+ 'h-[45px] w-[80px] overflow-hidden rounded-full border-2 border-lightest-grey my-auto flex cursor-pointer justify-between pl-2 text-center hover:shadow-md',
29
+ )
30
+
31
+ if (!menuItems) return <></>;
32
+
33
+ return (
34
+ <div>
35
+ <div
36
+ id={id}
37
+ className={classList}
38
+ onClick={() => {
39
+ setShowMenu(!showMenu);
40
+ }}
41
+ >
42
+ <div className="mx-auto my-auto" onClick={(e) => onClick?.(e)}>
43
+ <svg
44
+ width="18"
45
+ height="24"
46
+ viewBox="0 0 24 15"
47
+ xmlns="http://www.w3.org/2000/svg"
48
+ >
49
+ <path d="M0 1.5C0 0.947715 0.447715 0.5 1 0.5H21C21.5523 0.5 22 0.947715 22 1.5C22 2.05228 21.5523 2.5 21 2.5H1C0.447716 2.5 0 2.05228 0 1.5Z" />
50
+ <path d="M0 7.5C0 6.94772 0.447715 6.5 1 6.5H21C21.5523 6.5 22 6.94772 22 7.5C22 8.05228 21.5523 8.5 21 8.5H1C0.447716 8.5 0 8.05228 0 7.5Z" />
51
+ <path d="M0 13.5C0 12.9477 0.447715 12.5 1 12.5H21C21.5523 12.5 22 12.9477 22 13.5C22 14.0523 21.5523 14.5 21 14.5H1C0.447716 14.5 0 14.0523 0 13.5Z" />
52
+ </svg>
53
+ </div>
54
+ <Image
55
+ src="https://picsum.photos/300/300"
56
+ className="mx-auto my-auto h-8 w-8 rounded-full object-contain"
57
+ />
58
+ </div>
59
+ {showMenu && (
60
+ <div>
61
+ <DropdownMenu menuItems={menuItems} />
62
+ </div>
63
+ )}
64
+ </div>
65
+ );
66
+ }
@@ -1,19 +1,18 @@
1
1
  import React, { useState } from 'react';
2
2
 
3
- import { type Meta } from '@storybook/react';
4
3
  import classNames from 'classnames';
5
4
 
6
- import Modal from '.';
5
+ import { Modal } from '.';
7
6
 
8
7
  const meta = {
9
- title: 'Trepur Components/molecules/Modal',
8
+ title: 'Components/Modal',
10
9
  component: Modal,
11
10
  parameters: {
12
11
  docs: {
13
12
  description: {
14
13
  component: 'A Modal component',
15
- },
16
- },
14
+ }
15
+ }
17
16
  },
18
17
  argTypes: {
19
18
  id: {
@@ -34,20 +33,17 @@ const meta = {
34
33
  summary: 'Array',
35
34
  },
36
35
  defaultValue: { summary: 'undefined' },
37
- },
36
+ }
38
37
  },
39
38
  onOverlayClick: {
40
39
  type: { name: 'function', required: false },
41
40
  description: 'Specifies the action to take when the overlay is clicked',
42
- },
41
+ }
43
42
  },
44
43
  args: {
45
44
  visible: true,
46
45
  children: (
47
- <div
48
- style={{ maxWidth: '609px' }}
49
- className={classNames('theme-local rounded-2xl bg-white p-4')}
50
- >
46
+ <div style={{ maxWidth: '609px' }} className="rounded-2xl bg-white p-4">
51
47
  <p className="py-4">
52
48
  This is a child of the modal component, add any child to this
53
49
  component to show in this location.
@@ -61,10 +57,10 @@ const meta = {
61
57
  </p>
62
58
  </div>
63
59
  ),
64
- },
65
- };
60
+ }
61
+ }
66
62
 
67
- const Template = (args): React.ReactElement => {
63
+ const Template = (args: any): React.ReactElement => {
68
64
  const [visible, setVisible] = useState<boolean>(false);
69
65
 
70
66
  return (
@@ -79,7 +75,7 @@ const Template = (args): React.ReactElement => {
79
75
  />
80
76
  </div>
81
77
  );
82
- };
78
+ }
83
79
 
84
80
  export const _Modal = Template.bind({});
85
81
 
@@ -2,8 +2,6 @@ import React, { useState, useEffect } from 'react';
2
2
 
3
3
  import classNames from 'classnames';
4
4
 
5
-
6
-
7
5
  export interface Props extends Partial<Pick<HTMLElement, 'className' | 'id'>> {
8
6
  children?: React.ReactNode;
9
7
  visible?: boolean;
@@ -12,7 +10,7 @@ export interface Props extends Partial<Pick<HTMLElement, 'className' | 'id'>> {
12
10
  animationStyle?: 'fade' | 'slideBottom';
13
11
  }
14
12
 
15
- const Modal = ({
13
+ export const Modal = ({
16
14
  id,
17
15
  className,
18
16
  children,
@@ -20,7 +18,7 @@ const Modal = ({
20
18
  onOverlayClick,
21
19
  mobileGutter,
22
20
  animationStyle = 'fade',
23
- }: Props): JSX.Element => {
21
+ }: Props) => {
24
22
  const [hidden, setHidden] = useState(!visible);
25
23
  const [showModal, setShowModal] = useState(visible);
26
24
 
@@ -41,25 +39,26 @@ const Modal = ({
41
39
 
42
40
  return () => {
43
41
  clearTimeout(timeoutId);
44
- };
42
+ }
45
43
  }, [visible]);
46
44
 
47
45
  const classList = classNames(
48
46
  {
49
- [style.visible]: !hidden && showModal,
47
+ 'opacity-100': !hidden && showModal,
50
48
  },
51
- style.overlay,
49
+ 'block h-screen w-screen fixed right-0 top-0 z-50 opacity-0 transition-opacity duration-300 ease-linear ease-out',
52
50
  className,
53
- );
51
+ )
54
52
 
55
53
  const childrenClassList = classNames(
56
54
  {
57
- [style.visible]: showModal,
58
- [style.mobileGutter]: mobileGutter,
59
- [style.slideBottom]: animationStyle === 'slideBottom',
55
+ 'opacity-100': showModal,
56
+ 'px-4 md:px-0': mobileGutter,
57
+ 'transition-transform duration-300 ease-linear ease-out opacity-100 translate-y-full':
58
+ animationStyle === 'slideBottom',
60
59
  },
61
- style.children,
62
- );
60
+ ' mx-auto flex w-full md:w-auto fixed left-1/2 top-1/2 z-50 block -translate-x-1/2 -translate-y-1/2 transform opacity-0 transition-opacity duration-300 ease-linear ease-out',
61
+ )
63
62
 
64
63
  if (hidden) return <></>;
65
64
 
@@ -69,6 +68,4 @@ const Modal = ({
69
68
  {children && <div className={childrenClassList}>{children}</div>}
70
69
  </>
71
70
  );
72
- };
73
-
74
- export default Modal;
71
+ }
@@ -1,8 +1,8 @@
1
1
  import { action } from '@storybook/addon-actions';
2
- import { Meta, StoryObj } from '@storybook/react';
2
+ import { Meta, type StoryObj } from '@storybook/react';
3
3
  import { idAndClassName } from '@utils/controls';
4
4
 
5
- import NavItem from '.';
5
+ import { NavItem } from '.';
6
6
 
7
7
  const meta = {
8
8
  title: 'Components/Nav Item',
@@ -15,14 +15,14 @@ const meta = {
15
15
  description: 'A title for the component',
16
16
  table: {
17
17
  type: { summary: 'string' },
18
- },
18
+ }
19
19
  },
20
20
  href: {
21
21
  type: { name: 'string', required: false },
22
22
  description: 'A href for the component',
23
23
  table: {
24
24
  type: { summary: 'string' },
25
- },
25
+ }
26
26
  },
27
27
  onClick: {
28
28
  type: { name: 'function', required: false },
@@ -30,7 +30,7 @@ const meta = {
30
30
  'An on click handle to execute when clicking on the component',
31
31
  table: {
32
32
  type: { summary: 'function' },
33
- },
33
+ }
34
34
  },
35
35
  bordered: {
36
36
  type: { name: 'boolean', required: false },
@@ -73,18 +73,18 @@ const meta = {
73
73
  },
74
74
  defaultValue: 'primary',
75
75
  control: 'radio',
76
- },
76
+ }
77
77
  },
78
78
  args: {
79
79
  title: 'Home',
80
80
  href: '/',
81
81
  underlineOnHover: true,
82
82
  onClick: action('button-click'),
83
- },
84
- };
83
+ }
84
+ }
85
85
 
86
86
  export default meta;
87
87
 
88
- type Story = StoryObj<typeof meta>;
88
+ type Story = StoryObj<typeof NavItem>;
89
89
 
90
90
  export const Default: Story = {};
@@ -0,0 +1,43 @@
1
+ import React from 'react';
2
+
3
+ import classNames from 'classnames';
4
+
5
+ export interface Props {
6
+ id?: string;
7
+ className?: string;
8
+ title: string;
9
+ href?: string;
10
+ onClick?: React.MouseEventHandler;
11
+ bordered?: boolean;
12
+ rounded?: boolean;
13
+ underlineOnHover?: boolean;
14
+ isActive?: boolean;
15
+ variant?: 'primary' | 'secondary' | 'tertiary';
16
+ tabindex?: number;
17
+ }
18
+
19
+ export const NavItem = ({
20
+ id,
21
+ className,
22
+ title,
23
+ href = '/',
24
+ onClick,
25
+ tabindex,
26
+ }: Props) => {
27
+ const classList = classNames(className, 'w-auto list-none');
28
+
29
+ const anchorClassList = 'rounded-xl border-2 border-transparent p-2';
30
+
31
+ return (
32
+ <div id={id} className={classList}>
33
+ <a
34
+ href={href}
35
+ onClick={onClick}
36
+ className={anchorClassList}
37
+ {...(tabindex !== undefined && { tabIndex: tabindex })}
38
+ >
39
+ <span className="whitespace-nowrap text-center">{title}</span>
40
+ </a>
41
+ </div>
42
+ );
43
+ }