trepur_components 2.3.7 → 2.3.9

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 (335) hide show
  1. package/.eslintrc.cjs +33 -4
  2. package/.prettierignore +10 -0
  3. package/README.md +1 -1
  4. package/package.json +9 -5
  5. package/src/components/Accordion/Accordion.stories.tsx +21 -98
  6. package/src/components/Accordion/const.tsx +34 -0
  7. package/src/components/Accordion/index.tsx +19 -25
  8. package/src/components/AlertBar/AlertBar.stories.tsx +78 -84
  9. package/src/components/AlertBar/index.tsx +69 -100
  10. package/src/components/Avatar/Avatar.stories.tsx +2 -7
  11. package/src/components/Avatar/index.tsx +4 -7
  12. package/src/components/Breadcrumbs/Breadcrumbs.stories.tsx +29 -0
  13. package/src/components/Breadcrumbs/index.tsx +89 -0
  14. package/src/components/Button/Button.stories.tsx +24 -0
  15. package/src/components/Button/index.tsx +59 -0
  16. package/src/components/Calendar/Calendar.stories.tsx +21 -0
  17. package/src/components/Calendar/index.tsx +92 -0
  18. package/src/components/Card/Card.stories.tsx +14 -0
  19. package/src/components/Card/index.tsx +39 -0
  20. package/src/components/Carousel/Carousel.stories.tsx +44 -0
  21. package/src/components/Carousel/index.tsx +301 -0
  22. package/src/components/Carousel/utils.ts +53 -0
  23. package/src/components/CarouselThumbnail/CarouselThumbnail.stories.tsx +29 -0
  24. package/src/components/CarouselThumbnail/const.ts +17 -0
  25. package/src/components/CarouselThumbnail/index.tsx +169 -0
  26. package/src/components/CarouselThumbnail/utils.ts +87 -0
  27. package/src/components/Checkbox/Checkbox.stories.tsx +27 -0
  28. package/src/components/Checkbox/index.tsx +44 -0
  29. package/src/components/Collapsible/Collapsible.stories.tsx +67 -0
  30. package/src/components/Collapsible/index.tsx +169 -0
  31. package/src/components/Counter/Counter.stories.tsx +20 -0
  32. package/src/components/Counter/index.tsx +98 -0
  33. package/src/components/DetailUpdater/DetailUpdater.stories.tsx +37 -0
  34. package/{archive → src/components}/DetailUpdater/index.tsx +20 -25
  35. package/src/components/Dialog/Dialog.stories.tsx +65 -0
  36. package/src/components/Dialog/index.tsx +29 -0
  37. package/src/components/Dropdown/Dropdown.stories.tsx +22 -0
  38. package/src/components/Dropdown/index.tsx +117 -0
  39. package/src/components/Dropdown/utils.ts +15 -0
  40. package/{archive → src/components}/FileUploader/FilePreview.tsx +11 -14
  41. package/src/components/FileUploader/FileUploader.stories.tsx +28 -0
  42. package/src/components/FileUploader/index.tsx +177 -0
  43. package/src/components/Footer/Footer.stories.tsx +47 -0
  44. package/src/components/Footer/index.tsx +96 -0
  45. package/src/components/FooterNav/FooterNav.stories.tsx +32 -0
  46. package/src/components/FooterNav/index.tsx +75 -0
  47. package/{archive → src/components}/Form/Form.stories.tsx +2 -2
  48. package/src/components/Form/index.tsx +41 -0
  49. package/src/components/Gallery/Gallery.stories.tsx +39 -0
  50. package/src/components/Gallery/index.tsx +31 -0
  51. package/src/components/Greeting/Greeting.stories.tsx +16 -0
  52. package/src/components/Greeting/index.tsx +49 -0
  53. package/src/components/HamburgerIcon/HamburgerIcon.stories.tsx +14 -0
  54. package/src/components/HamburgerIcon/index.tsx +75 -0
  55. package/src/components/Icon/Icon.stories.tsx +41 -0
  56. package/src/components/Icon/index.tsx +33 -0
  57. package/src/components/Image/Image.stories.tsx +17 -0
  58. package/src/components/Image/index.tsx +25 -0
  59. package/src/components/ImageCard/ImageCard.stories.tsx +29 -0
  60. package/src/components/ImageCard/index.tsx +75 -0
  61. package/src/components/Input/Input.stories.tsx +25 -0
  62. package/src/components/Input/index.tsx +139 -0
  63. package/{archive → src/components}/MenuButton/MenuButton.stories.tsx +2 -2
  64. package/src/components/MenuButton/index.tsx +66 -0
  65. package/{archive → src/components}/Modal/Modal.stories.tsx +4 -8
  66. package/{archive → src/components}/Modal/index.tsx +9 -12
  67. package/src/components/Nav/Nav.stories.tsx +80 -0
  68. package/src/components/Nav/index.tsx +171 -0
  69. package/src/components/NavItem/NavItem.stories.tsx +17 -0
  70. package/src/components/NavItem/index.tsx +39 -0
  71. package/src/components/Pill/Pill.stories.tsx +51 -0
  72. package/src/components/Pill/index.tsx +69 -0
  73. package/{archive → src/components}/Search/Search.stories.tsx +2 -2
  74. package/{archive → src/components}/Search/index.tsx +12 -16
  75. package/{archive → src/components}/Select/Select.stories.tsx +2 -3
  76. package/{archive → src/components}/Select/index.tsx +21 -30
  77. package/{archive → src/components}/Showcase/Showcase.stories.tsx +4 -3
  78. package/src/components/Showcase/index.tsx +62 -0
  79. package/{archive → src/components}/SideNav/SideNav.stories.tsx +2 -2
  80. package/{archive → src/components}/SideNav/index.tsx +8 -15
  81. package/{archive → src/components}/SocialButton/SocialButton.stories.tsx +2 -2
  82. package/{archive → src/components}/SocialButton/index.tsx +14 -22
  83. package/src/components/SplitCard/SplitCard.stories.tsx +34 -0
  84. package/src/components/SplitCard/index.tsx +132 -0
  85. package/src/components/Stars/Star.stories.tsx +18 -0
  86. package/src/components/Stars/index.tsx +38 -0
  87. package/src/components/Testimonial/Testimonial.stories.tsx +37 -0
  88. package/src/components/Testimonial/index.tsx +123 -0
  89. package/src/components/TextArea/TextArea.stories.tsx +24 -0
  90. package/src/components/TextArea/index.tsx +133 -0
  91. package/src/components/Timeline/Timeline.stories.tsx +45 -0
  92. package/src/components/Timeline/index.tsx +65 -0
  93. package/src/components/Tubestops/Tubestops.stories.tsx +22 -0
  94. package/src/components/Tubestops/index.tsx +132 -0
  95. package/src/components/Video/Video.stories.tsx +58 -0
  96. package/src/components/Video/assets/example.mp4 +0 -0
  97. package/src/components/Video/assets/example.ogv +0 -0
  98. package/src/components/Video/assets/example.webm +0 -0
  99. package/src/components/Video/index.tsx +92 -0
  100. package/src/components/index.ts +66 -112
  101. package/src/custom.d.ts +14 -0
  102. package/src/documentation/Colours.mdx +34 -34
  103. package/src/documentation/Introduction.mdx +9 -5
  104. package/src/documentation/assets/index.ts +3 -0
  105. package/src/documentation/assets/trepurComponentsLogo.svg +32 -0
  106. package/src/documentation/typography/Fonts/Fonts.stories.tsx +14 -0
  107. package/src/documentation/typography/Fonts/Fonts.tsx +73 -0
  108. package/src/styles/global.css +1 -1
  109. package/src/styles/themes/local.css +91 -39
  110. package/src/styles/themes/test.css +28 -0
  111. package/src/utils/screens.ts +1 -1
  112. package/tailwind/colors.ts +53 -385
  113. package/tailwind/preset.ts +4 -0
  114. package/tailwind.config.ts +12 -80
  115. package/tsconfig.json +8 -2
  116. package/archive/Breadcrumbs/Breadcrumbs.stories.tsx +0 -46
  117. package/archive/Breadcrumbs/index.tsx +0 -42
  118. package/archive/BreadcrumbsBordered/BreadcrumbsBordered.stories.tsx +0 -52
  119. package/archive/BreadcrumbsBordered/index.tsx +0 -44
  120. package/archive/BreadcrumbsItem/BreadcrumbsItem.stories.tsx +0 -40
  121. package/archive/BreadcrumbsItem/index.tsx +0 -149
  122. package/archive/Button/Button.stories.tsx +0 -150
  123. package/archive/Button/index.tsx +0 -111
  124. package/archive/Button/style.module.css +0 -76
  125. package/archive/Calendar/Calendar.stories.tsx +0 -82
  126. package/archive/Calendar/index.tsx +0 -76
  127. package/archive/Card/Card.stories.tsx +0 -75
  128. package/archive/Card/index.tsx +0 -102
  129. package/archive/Card/style.module.css +0 -75
  130. package/archive/CardWithTopImage/CardWithTopImage.stories.tsx +0 -50
  131. package/archive/CardWithTopImage/index.tsx +0 -39
  132. package/archive/CardWithTopImage/style.module.css +0 -11
  133. package/archive/Carousel/Carousel.stories.tsx +0 -451
  134. package/archive/Carousel/index.tsx +0 -388
  135. package/archive/Carousel/style.module.css +0 -99
  136. package/archive/CarouselThumbnail/CarouselThumbnail.stories.tsx +0 -350
  137. package/archive/CarouselThumbnail/index.tsx +0 -302
  138. package/archive/CarouselThumbnail/style.module.css +0 -67
  139. package/archive/Checkbox/Checkbox.stories.tsx +0 -34
  140. package/archive/Checkbox/index.tsx +0 -51
  141. package/archive/Checkbox/style.module.css +0 -15
  142. package/archive/Collapsible/Collapsible.stories.tsx +0 -67
  143. package/archive/Collapsible/index.tsx +0 -116
  144. package/archive/Collapsible/style.module.css +0 -47
  145. package/archive/Column/Column.stories.tsx +0 -89
  146. package/archive/Column/index.tsx +0 -119
  147. package/archive/Column/style.module.css +0 -151
  148. package/archive/ComponentWrapper/ComponentWrapper.stories.tsx +0 -40
  149. package/archive/ComponentWrapper/index.tsx +0 -55
  150. package/archive/ComponentWrapper/style.module.css +0 -40
  151. package/archive/Container/Container.stories.tsx +0 -40
  152. package/archive/Container/index.tsx +0 -24
  153. package/archive/Container/style.module.css +0 -4
  154. package/archive/Counter/Counter.stories.tsx +0 -19
  155. package/archive/Counter/index.tsx +0 -66
  156. package/archive/Counter/style.module.css +0 -19
  157. package/archive/DetailUpdater/DetailUpdater.stories.tsx +0 -96
  158. package/archive/DetailUpdater/style.module.css +0 -31
  159. package/archive/Dialog/Dialog.stories.tsx +0 -131
  160. package/archive/Dialog/index.tsx +0 -91
  161. package/archive/Dialog/style.module.css +0 -44
  162. package/archive/DropdownMenu/DropdownMenu.stories.tsx +0 -59
  163. package/archive/DropdownMenu/index.tsx +0 -51
  164. package/archive/DropdownMenu/style.module.css +0 -38
  165. package/archive/DynamicTextSection/DynamicTextSection.stories.tsx +0 -74
  166. package/archive/DynamicTextSection/index.tsx +0 -36
  167. package/archive/DynamicTextSection/style.module.css +0 -0
  168. package/archive/FileUploader/FileUploader.stories.tsx +0 -28
  169. package/archive/FileUploader/index.tsx +0 -135
  170. package/archive/FileUploader/style.module.css +0 -54
  171. package/archive/FilterItem/FilterItem.stories.tsx +0 -33
  172. package/archive/FilterItem/index.tsx +0 -101
  173. package/archive/FilterItem/style.module.css +0 -27
  174. package/archive/Footer/Footer.stories.tsx +0 -59
  175. package/archive/Footer/index.tsx +0 -50
  176. package/archive/Footer/style.module.css +0 -19
  177. package/archive/FooterNav/FooterNav.stories.tsx +0 -125
  178. package/archive/FooterNav/index.tsx +0 -57
  179. package/archive/FooterNav/style.module.css +0 -32
  180. package/archive/FooterNavItem/FooterNavItem.stories.tsx +0 -53
  181. package/archive/FooterNavItem/index.tsx +0 -80
  182. package/archive/FooterNavItem/style.module.css +0 -139
  183. package/archive/Form/index.tsx +0 -61
  184. package/archive/Form/style.module.css +0 -0
  185. package/archive/FyreCard/FyreCard.stories.tsx +0 -31
  186. package/archive/FyreCard/index.tsx +0 -52
  187. package/archive/FyreCard/style.module.css +0 -19
  188. package/archive/Greeting/Greeting.stories.tsx +0 -41
  189. package/archive/Greeting/index.tsx +0 -32
  190. package/archive/HamburgerIcon/HamburgerIcon.stories.tsx +0 -32
  191. package/archive/HamburgerIcon/index.tsx +0 -103
  192. package/archive/HamburgerIcon/style.module.css +0 -85
  193. package/archive/HorizontalLine/HorizontalLine.stories.tsx +0 -54
  194. package/archive/HorizontalLine/index.tsx +0 -40
  195. package/archive/HorizontalLine/style.module.css +0 -55
  196. package/archive/Icon/Icon.stories.tsx +0 -164
  197. package/archive/Icon/index.tsx +0 -115
  198. package/archive/Icon/style.module.css +0 -253
  199. package/archive/IconCard/IconCard.stories.tsx +0 -46
  200. package/archive/IconCard/index.tsx +0 -57
  201. package/archive/IconCard/style.module.css +0 -18
  202. package/archive/Image/Image.stories.tsx +0 -87
  203. package/archive/Image/index.tsx +0 -132
  204. package/archive/Image/style.module.css +0 -109
  205. package/archive/ImageInfo/ImageInfo.stories.tsx +0 -39
  206. package/archive/ImageInfo/index.tsx +0 -95
  207. package/archive/ImageInfo/style.module.css +0 -47
  208. package/archive/ImageLink/ImageLink.stories.tsx +0 -37
  209. package/archive/ImageLink/index.tsx +0 -49
  210. package/archive/ImageLink/style.module.css +0 -23
  211. package/archive/ImageLinkList/ImageLinkList.stories.tsx +0 -34
  212. package/archive/ImageLinkList/index.tsx +0 -33
  213. package/archive/ImageLinkList/style.module.css +0 -3
  214. package/archive/InformationIcon/InformationIcon.stories.tsx +0 -83
  215. package/archive/InformationIcon/index.tsx +0 -128
  216. package/archive/InformationIcon/style.module.css +0 -71
  217. package/archive/InformationIconBlock/InformationIconBlock.stories.tsx +0 -32
  218. package/archive/InformationIconBlock/index.tsx +0 -63
  219. package/archive/InformationIconBlock/style.module.css +0 -7
  220. package/archive/Input/Input.stories.tsx +0 -84
  221. package/archive/Input/index.tsx +0 -131
  222. package/archive/Input/style.module.css +0 -60
  223. package/archive/Jumbotron/Jumbotron.stories.tsx +0 -21
  224. package/archive/Jumbotron/index.tsx +0 -31
  225. package/archive/Jumbotron/style.module.css +0 -8
  226. package/archive/MenuButton/index.tsx +0 -82
  227. package/archive/MenuButton/style.module.css +0 -45
  228. package/archive/Modal/style.module.css +0 -35
  229. package/archive/NavItem/NavItem.stories.tsx +0 -90
  230. package/archive/NavItem/index.tsx +0 -65
  231. package/archive/NavItem/style.module.css +0 -71
  232. package/archive/NavOld/NavOld.stories.tsx +0 -193
  233. package/archive/NavOld/StickyNav.tsx +0 -191
  234. package/archive/NavOld/index.tsx +0 -273
  235. package/archive/NavOld/style.module.css +0 -156
  236. package/archive/NavTwo/Dropdown.tsx +0 -35
  237. package/archive/NavTwo/Nav.stories.tsx +0 -38
  238. package/archive/NavTwo/Sidebar.tsx +0 -34
  239. package/archive/NavTwo/StickyNav.tsx +0 -34
  240. package/archive/NavTwo/index.tsx +0 -45
  241. package/archive/NavTwo/style.module.css +0 -35
  242. package/archive/NewsCard/NewsCard.stories.tsx +0 -72
  243. package/archive/NewsCard/index.tsx +0 -57
  244. package/archive/NewsCard/style.module.css +0 -15
  245. package/archive/Pill/Pill.stories.tsx +0 -44
  246. package/archive/Pill/index.tsx +0 -64
  247. package/archive/Pill/style.module.css +0 -32
  248. package/archive/ProductCard/ProductCard.stories.tsx +0 -61
  249. package/archive/ProductCard/index.tsx +0 -111
  250. package/archive/ProductCard/style.module.css +0 -53
  251. package/archive/ProductCardV2/ProductCardV2.stories.tsx +0 -50
  252. package/archive/ProductCardV2/index.tsx +0 -119
  253. package/archive/ProductCardV2/style.module.css +0 -59
  254. package/archive/Proficiencies/Proficiencies.stories.tsx +0 -50
  255. package/archive/Proficiencies/index.tsx +0 -63
  256. package/archive/Proficiencies/style.module.css +0 -31
  257. package/archive/Profile/Profile.stories.tsx +0 -49
  258. package/archive/Profile/index.tsx +0 -103
  259. package/archive/Profile/style.module.css +0 -47
  260. package/archive/Row/Row.stories.tsx +0 -53
  261. package/archive/Row/index.tsx +0 -23
  262. package/archive/Row/style.module.css +0 -3
  263. package/archive/Search/style.module.css +0 -23
  264. package/archive/Select/style.module.css +0 -52
  265. package/archive/Showcase/index.tsx +0 -75
  266. package/archive/Showcase/style.module.css +0 -47
  267. package/archive/SideNav/style.module.css +0 -43
  268. package/archive/SocialBlock/SocialBlock.stories.tsx +0 -58
  269. package/archive/SocialBlock/index.tsx +0 -63
  270. package/archive/SocialButton/style.module.css +0 -77
  271. package/archive/StarRating/StarRating.stories.tsx +0 -23
  272. package/archive/StarRating/index.tsx +0 -71
  273. package/archive/Testimonial/Testimonial.stories.tsx +0 -110
  274. package/archive/Testimonial/index.tsx +0 -61
  275. package/archive/Testimonial/style.module.css +0 -27
  276. package/archive/TextAndTitle/TextAndTitle.stories.tsx +0 -70
  277. package/archive/TextAndTitle/index.tsx +0 -123
  278. package/archive/TextAndTitle/style.module.css +0 -75
  279. package/archive/TextArea/TextArea.stories.tsx +0 -55
  280. package/archive/TextArea/index.tsx +0 -125
  281. package/archive/TextArea/style.module.css +0 -60
  282. package/archive/Timeline/Timeline.stories.tsx +0 -92
  283. package/archive/Timeline/index.tsx +0 -254
  284. package/archive/Timeline/style.module.css +0 -134
  285. package/archive/TimelineV2/TimelineV2.stories.tsx +0 -95
  286. package/archive/TimelineV2/index.tsx +0 -70
  287. package/archive/TimelineV2/style.module.css +0 -28
  288. package/archive/Tubestops/Tubestops.stories.tsx +0 -42
  289. package/archive/Tubestops/index.tsx +0 -58
  290. package/archive/Tubestops/style.module.css +0 -54
  291. package/archive/UserIcon/UserIcon.stories.tsx +0 -52
  292. package/archive/UserIcon/index.tsx +0 -46
  293. package/archive/UserIcon/style.module.css +0 -19
  294. package/archive/Video/Video.stories.tsx +0 -23
  295. package/archive/Video/index.tsx +0 -47
  296. package/archive/theme.ts +0 -39
  297. package/archive/typography/Fonts/Fonts.stories.tsx +0 -14
  298. package/archive/typography/Fonts/Fonts.tsx +0 -181
  299. package/lib/components/Accordion/Accordion.stories.d.ts +0 -94
  300. package/lib/components/Accordion/index.d.ts +0 -8
  301. package/lib/components/Accordion/index.js +0 -15
  302. package/lib/components/AlertBar/AlertBar.stories.d.ts +0 -162
  303. package/lib/components/AlertBar/index.d.ts +0 -12
  304. package/lib/components/AlertBar/index.js +0 -49
  305. package/lib/components/Avatar/Avatar.stories.d.ts +0 -44
  306. package/lib/components/Avatar/index.d.ts +0 -4
  307. package/lib/components/index.d.ts +0 -4
  308. package/lib/index.d.ts +0 -1
  309. package/lib/index.js +0 -6
  310. package/lib/styles/global.css +0 -75
  311. package/lib/styles/themes/local.css +0 -40
  312. package/lib/styles/themes/palette.css +0 -131
  313. package/lib/tailwind/boxShadow.ts +0 -9
  314. package/lib/tailwind/colors.ts +0 -410
  315. package/lib/tailwind/container.ts +0 -11
  316. package/lib/tailwind/preset.ts +0 -88
  317. package/lib/tailwind/spacing.ts +0 -14
  318. package/lib/utils/controls.d.ts +0 -36
  319. package/lib/utils/matchMedia.d.ts +0 -2
  320. package/lib/utils/screens.d.ts +0 -7
  321. package/src/styles/themes/palette.css +0 -131
  322. package/svg.d.ts +0 -4
  323. /package/{archive → src/components}/Calendar/style.css +0 -0
  324. /package/{archive → src/components}/Checkbox/Checkbox.mdx +0 -0
  325. /package/{archive → src}/fonts/Sora/OFL.txt +0 -0
  326. /package/{archive → src}/fonts/Sora/README.txt +0 -0
  327. /package/{archive → src}/fonts/Sora/Sora-VariableFont_wght.ttf +0 -0
  328. /package/{archive → src}/fonts/Sora/static/Sora-Bold.ttf +0 -0
  329. /package/{archive → src}/fonts/Sora/static/Sora-ExtraBold.ttf +0 -0
  330. /package/{archive → src}/fonts/Sora/static/Sora-ExtraLight.ttf +0 -0
  331. /package/{archive → src}/fonts/Sora/static/Sora-Light.ttf +0 -0
  332. /package/{archive → src}/fonts/Sora/static/Sora-Medium.ttf +0 -0
  333. /package/{archive → src}/fonts/Sora/static/Sora-Regular.ttf +0 -0
  334. /package/{archive → src}/fonts/Sora/static/Sora-SemiBold.ttf +0 -0
  335. /package/{archive → src}/fonts/Sora/static/Sora-Thin.ttf +0 -0
@@ -1,59 +0,0 @@
1
- import { action } from '@storybook/addon-actions';
2
- import { Meta, StoryObj } from '@storybook/react';
3
- import { idAndClassName } from '@utils/controls';
4
-
5
- import Footer from '.';
6
-
7
- const meta = {
8
- title: 'Components/Footer',
9
- component: Footer,
10
- parameters: {},
11
- argTypes: {
12
- ...idAndClassName,
13
- text: {
14
- type: { name: 'string', required: false },
15
- description: 'The text to show on the component',
16
- table: {
17
- type: { summary: 'default' },
18
- },
19
- defaultValue: { summary: 'undefined' },
20
- },
21
- buttonProps: {
22
- type: { name: 'other', value: 'object' },
23
- description:
24
- 'The props to pass to the button to display on the component',
25
- table: {
26
- type: {
27
- summary: 'object',
28
- },
29
- defaultValue: { summary: 'undefined' },
30
- },
31
- },
32
- variant: {
33
- type: { name: 'string', required: false },
34
- options: ['dark', 'light'],
35
- description: 'The variant of button to render',
36
- table: {
37
- type: { summary: 'light' },
38
- defaultValue: { summary: 'light' },
39
- },
40
- defaultValue: 'light',
41
- control: { type: 'radio' },
42
- },
43
- },
44
- args: {
45
- text: 'Copyright All rights reserved',
46
- variant: 'dark',
47
- buttonProps: {
48
- children: 'Admin Panel',
49
- onClick: action('button clicked'),
50
- href: '/',
51
- target: '_blank',
52
- },
53
- },
54
- };
55
- export default meta;
56
-
57
- type Story = StoryObj<typeof meta>;
58
-
59
- export const Default: Story = {};
@@ -1,50 +0,0 @@
1
- import React from 'react';
2
-
3
- import Button, { type Props as buttonProps } from '@components/Button';
4
- import Container from '@components/Container';
5
- import classNames from 'classnames';
6
-
7
-
8
-
9
- export interface Props {
10
- id?: string;
11
- className?: string;
12
- buttonProps?: buttonProps;
13
- text?: string;
14
- variant?: 'light' | 'dark';
15
- }
16
-
17
- const Footer = ({
18
- id,
19
- className,
20
- text,
21
- buttonProps,
22
- variant,
23
- }: Props): JSX.Element => {
24
- const colours = variant === 'dark' ? [style.dark] : [style.light];
25
- const classList = classNames(className, colours, 'theme-local');
26
-
27
- return (
28
- <div id={id} className={classList}>
29
- <Container withPadding className={style.classList}>
30
- <p className={style.textClassList}>{text}</p>
31
- <div className={style.buttonClassList}>
32
- {buttonProps?.children !== undefined &&
33
- (buttonProps?.href !== undefined ||
34
- buttonProps?.onClick !== undefined) && (
35
- <Button
36
- variant={variant === 'dark' ? 'primary' : 'secondary'}
37
- rounded
38
- href={buttonProps?.href}
39
- onClick={buttonProps?.onClick}
40
- >
41
- {buttonProps?.children}
42
- </Button>
43
- )}
44
- </div>
45
- </Container>
46
- </div>
47
- );
48
- };
49
-
50
- export default Footer;
@@ -1,19 +0,0 @@
1
- .classList {
2
- @apply block h-auto flex-wrap items-center justify-between md:flex;
3
- }
4
-
5
- .textClassList {
6
- @apply pb-4 pt-8 text-center md:my-8 md:pb-0 md:pt-0;
7
- }
8
-
9
- .buttonClassList {
10
- @apply pb-8 pt-4 text-center md:pb-0 md:pt-0;
11
- }
12
-
13
- .dark {
14
- @apply bg-primary text-white;
15
- }
16
-
17
- .light {
18
- @apply bg-white text-primary;
19
- }
@@ -1,125 +0,0 @@
1
- import { action } from '@storybook/addon-actions';
2
- import { Meta, StoryObj } from '@storybook/react';
3
- import { idAndClassName } from '@utils/controls';
4
-
5
- import FooterNav from '.';
6
-
7
- const meta = {
8
- title: 'Components/Footer Nav',
9
- component: FooterNav,
10
- argTypes: {
11
- ...idAndClassName,
12
- title: {
13
- type: { name: 'string', required: true },
14
- description: 'The title to display on the component',
15
- table: {
16
- type: { summary: 'string' },
17
- },
18
- },
19
- subtitle: {
20
- type: { name: 'string', value: 'string | number' },
21
- description: 'The subtitle to display on the component',
22
- table: {
23
- type: {
24
- summary: 'string',
25
- },
26
- defaultValue: { summary: 'undefined' },
27
- },
28
- },
29
- withAnimation: {
30
- type: { name: 'boolean', required: false },
31
- description: 'Enabled the counter animation on the component',
32
- table: {
33
- type: { summary: 'boolean' },
34
- },
35
- defaultValue: 'false',
36
- },
37
- withHoverEffect: {
38
- type: { name: 'boolean', required: false },
39
- description: 'Enabled the hover effect on the component',
40
- table: {
41
- type: { summary: 'boolean' },
42
- },
43
- defaultValue: 'true',
44
- },
45
- iconProps: {
46
- type: { name: 'iconProps', required: false },
47
- description: 'The props to pass to the icon to display on the component',
48
- table: {
49
- type: { summary: 'iconProps' },
50
- },
51
- },
52
-
53
- large: {
54
- description: 'Defines the top and bottom padding size',
55
- control: 'boolean',
56
- table: {
57
- type: { summary: 'boolean' },
58
- defaultValue: { summary: 'true' },
59
- },
60
- defaultValue: 'true',
61
- },
62
- },
63
- args: {
64
- backgroundColour: 'white',
65
- colour: 'grey',
66
- hoverColour: 'primary',
67
- footerItems: [
68
- {
69
- title: 'wishlists',
70
- href: '#',
71
- iconProps: {
72
- type: 'heart',
73
- size: 2,
74
- hollow: true,
75
- },
76
- onClick: action('clicked wishlist'),
77
- },
78
- {
79
- title: 'Profile',
80
- href: '#',
81
- iconProps: {
82
- type: 'star',
83
- size: 2,
84
- hollow: true,
85
- },
86
- onClick: action('clicked profile'),
87
- },
88
- {
89
- title: 'sun',
90
- href: '#',
91
- iconProps: {
92
- type: 'sun',
93
- size: 2,
94
- hollow: true,
95
- },
96
- onClick: action('clicked sun'),
97
- },
98
- {
99
- title: 'moon',
100
- href: '#',
101
- iconProps: {
102
- type: 'moon',
103
- size: 2,
104
- hollow: true,
105
- },
106
- onClick: action('clicked moon'),
107
- },
108
- {
109
- title: 'snowflake',
110
- href: '#',
111
- iconProps: {
112
- type: 'snowflake',
113
- size: 2,
114
- hollow: true,
115
- },
116
- onClick: action('clicked snowflake'),
117
- },
118
- ],
119
- },
120
- };
121
- export default meta;
122
-
123
- type Story = StoryObj<typeof meta>;
124
-
125
- export const Default: Story = {};
@@ -1,57 +0,0 @@
1
- import React from 'react';
2
-
3
- import FooterNavItem, {
4
- type Props as FooterNavItemProps,
5
- } from '@components/FooterNavItem';
6
- import { type Colours } from '@utils/controls';
7
- import classNames from 'classnames';
8
-
9
-
10
-
11
- export interface Props {
12
- id: string;
13
- className?: string;
14
- backgroundColour?: Colours;
15
- colour?: Colours;
16
- hoverColour?: Colours;
17
- hoverBgColour?: Colours;
18
-
19
- footerItems: FooterNavItemProps[];
20
- }
21
-
22
- const FooterNav = ({
23
- id,
24
- className,
25
- backgroundColour = 'white',
26
- colour = 'black',
27
- hoverColour = 'black',
28
- hoverBgColour = 'black',
29
- footerItems,
30
- }: Props): JSX.Element => {
31
- const classList = classNames(
32
- className,
33
- style.classList,
34
- style[backgroundColour],
35
- 'theme-local',
36
- );
37
-
38
- return (
39
- <div id={id} className={classList}>
40
- {footerItems?.map((footerItem: any, i) => {
41
- footerItem.iconProps.colour = colour;
42
- footerItem.iconProps.hoverColour = hoverColour;
43
- footerItem.iconProps.hoverBgColour = hoverBgColour;
44
- footerItem.iconProps.size = 2;
45
- return (
46
- <FooterNavItem
47
- key={i}
48
- {...footerItem}
49
- backgroundColour={backgroundColour}
50
- />
51
- );
52
- })}
53
- </div>
54
- );
55
- };
56
-
57
- export default FooterNav;
@@ -1,32 +0,0 @@
1
- .classList {
2
- @apply fixed bottom-0 flex w-full justify-between px-4;
3
- @apply border-t border-lightest-grey;
4
- }
5
-
6
- .primary {
7
- @apply bg-primary text-white;
8
- }
9
- .secondary {
10
- @apply bg-secondary text-white;
11
- }
12
- .white {
13
- @apply bg-white text-black;
14
- }
15
- .grey {
16
- @apply bg-lightest-grey text-black;
17
- }
18
- .black {
19
- @apply bg-black text-white;
20
- }
21
- .success {
22
- @apply bg-success text-white;
23
- }
24
- .error {
25
- @apply bg-error text-white;
26
- }
27
- .facebook {
28
- @apply bg-facebook text-white;
29
- }
30
- .gold {
31
- @apply bg-gold text-white;
32
- }
@@ -1,53 +0,0 @@
1
- import { action } from '@storybook/addon-actions';
2
- import { Meta, StoryObj } from '@storybook/react';
3
- import { idAndClassName } from '@utils/controls';
4
-
5
- import FooterNavItem from '.';
6
-
7
- const meta = {
8
- title: 'Components/Footer Nav Item',
9
- component: FooterNavItem,
10
- argTypes: {
11
- ...idAndClassName,
12
-
13
- title: {
14
- type: { name: 'string', required: true },
15
- description: 'The title to display on the component',
16
- table: {
17
- type: { summary: 'string' },
18
- },
19
- },
20
- iconProps: {
21
- type: { name: 'iconProps', required: false },
22
- description: 'The props to pass to the icon to display on the component',
23
- table: {
24
- type: { summary: 'iconProps' },
25
- },
26
- },
27
- backgroundColour: {
28
- type: { name: 'string', required: false },
29
- options: ['primary', 'secondary', 'white', 'black', 'gold'],
30
- description: 'The background colour of the component',
31
- table: {
32
- type: { summary: 'string' },
33
- },
34
- defaultValue: 'primary',
35
- control: 'select',
36
- },
37
- },
38
- args: {
39
- title: 'Wishlist',
40
- href: '#',
41
- iconProps: {
42
- type: 'heart',
43
- size: 2,
44
- hollow: true,
45
- },
46
- onClick: action('clicked'),
47
- },
48
- };
49
- export default meta;
50
-
51
- type Story = StoryObj<typeof meta>;
52
-
53
- export const Default: Story = {};
@@ -1,80 +0,0 @@
1
- import React from 'react';
2
-
3
- import Icon, { type Props as iconProps } from '@components/Icon';
4
- import { type Colours } from '@utils/controls';
5
- import classNames from 'classnames';
6
-
7
-
8
-
9
- export interface Props {
10
- id: string;
11
- className?: string;
12
- title?: string;
13
- iconProps?: iconProps;
14
- bgColour?: Colours;
15
- hoverBgColour?: Colours;
16
- colour?: Colours;
17
- hoverColour?: Colours;
18
-
19
- onClick?: () => void;
20
- href: string;
21
- }
22
-
23
- const FooterNavItem = ({
24
- id,
25
- className,
26
- title,
27
- iconProps,
28
- bgColour = 'white',
29
- hoverBgColour = 'secondary',
30
- colour = 'grey',
31
- hoverColour = 'white',
32
- onClick,
33
- href,
34
- }: Props): JSX.Element => {
35
- const formattedText =
36
- typeof colour === 'string' ? `text_${colour}` : 'text_primary';
37
- const formattedBg =
38
- typeof bgColour === 'string' ? `bg_${bgColour}` : 'bg_secondary';
39
- const formattedHoverText =
40
- typeof hoverColour === 'string'
41
- ? `hover_text_${hoverColour}`
42
- : 'hover_text_secondary';
43
- const formattedHoverBg =
44
- typeof hoverBgColour === 'string'
45
- ? `hover_bg_${hoverBgColour}`
46
- : 'hover_bg_primary';
47
-
48
- const classList = classNames(
49
- className,
50
- style.classList,
51
- style[formattedBg],
52
- style[formattedHoverBg],
53
- style[formattedText],
54
- style[formattedHoverText],
55
- 'theme-local',
56
- );
57
-
58
- return (
59
- <div id={id} className={classList}>
60
- <a href={href} onClick={onClick}>
61
- {iconProps !== undefined && (
62
- <Icon
63
- {...iconProps}
64
- className={style.icon}
65
- bgColour={bgColour}
66
- hoverBgColour={hoverBgColour}
67
- colour={colour}
68
- hoverColour={hoverColour}
69
- rounded
70
- />
71
- )}
72
- {title !== undefined && title !== '' && (
73
- <p className={style.title}>{title}</p>
74
- )}
75
- </a>
76
- </div>
77
- );
78
- };
79
-
80
- export default FooterNavItem;
@@ -1,139 +0,0 @@
1
- .classList {
2
- @apply w-full cursor-pointer py-2 text-center transition-all duration-500;
3
- }
4
-
5
- .classList:hover .icon {
6
- @apply bg-secondary text-white;
7
- }
8
-
9
- .icon {
10
- @apply mx-auto;
11
- }
12
-
13
- .title {
14
- @apply pt-0.5 text-xs font-regular;
15
- }
16
-
17
- .text_primary {
18
- @apply text-primary;
19
- }
20
- .text_secondary {
21
- @apply text-secondary;
22
- }
23
- .text_white {
24
- @apply text-white;
25
- }
26
- .text_black {
27
- @apply text-black;
28
- }
29
- .text_gold {
30
- @apply text-gold;
31
- }
32
- .text_grey {
33
- @apply text-light-grey;
34
- }
35
- .text_facebook {
36
- @apply text-facebook;
37
- }
38
- .text_interactive-facebook {
39
- @apply text-interactive-facebook;
40
- }
41
- .text_success {
42
- @apply text-success;
43
- }
44
- .text_error {
45
- @apply text-error;
46
- }
47
-
48
- .bg_primary {
49
- @apply bg-primary;
50
- }
51
- .bg_secondary {
52
- @apply bg-secondary;
53
- }
54
- .bg_white {
55
- @apply bg-white;
56
- }
57
- .bg_black {
58
- @apply bg-black;
59
- }
60
- .bg_gold {
61
- @apply bg-gold;
62
- }
63
- .bg_grey {
64
- @apply bg-light-grey;
65
- }
66
- .bg_facebook {
67
- @apply bg-facebook;
68
- }
69
- .bg_interactive-facebook {
70
- @apply bg-interactive-facebook;
71
- }
72
- .bg_success {
73
- @apply bg-success;
74
- }
75
- .bg_error {
76
- @apply bg-error;
77
- }
78
-
79
- .hover_text_primary {
80
- @apply hover:text-primary;
81
- }
82
- .hover_text_secondary {
83
- @apply hover:text-secondary;
84
- }
85
- .hover_text_white {
86
- @apply hover:text-white;
87
- }
88
- .hover_text_black {
89
- @apply hover:text-black;
90
- }
91
- .hover_text_gold {
92
- @apply hover:text-gold;
93
- }
94
- .hover_text_grey {
95
- @apply hover:text-light-grey;
96
- }
97
- .hover_text_facebook {
98
- @apply hover:text-facebook;
99
- }
100
- .hover_text_interactive-facebook {
101
- @apply hover:text-interactive-facebook;
102
- }
103
- .hover_text_success {
104
- @apply hover:text-success;
105
- }
106
- .hover_text_error {
107
- @apply hover:text-error;
108
- }
109
-
110
- .hover_bg_primary {
111
- @apply hover:bg-primary;
112
- }
113
- .hover_bg_secondary {
114
- @apply hover:bg-secondary;
115
- }
116
- .hover_bg_white {
117
- @apply hover:bg-white;
118
- }
119
- .hover_bg_black {
120
- @apply hover:bg-black;
121
- }
122
- .hover_bg_gold {
123
- @apply hover:bg-gold;
124
- }
125
- .hover_bg_grey {
126
- @apply hover:bg-light-grey;
127
- }
128
- .hover_bg_facebook {
129
- @apply hover:bg-facebook;
130
- }
131
- .hover_bg_interactive-facebook {
132
- @apply hover:bg-interactive-facebook;
133
- }
134
- .hover_bg_success {
135
- @apply hover:bg-success;
136
- }
137
- .hover_bg_error {
138
- @apply hover:bg-error;
139
- }
@@ -1,61 +0,0 @@
1
- import React from 'react';
2
-
3
- import Button, { type Props as buttonProps } from '@components/Button';
4
- import Container from '@components/Container';
5
- import Input, { type Props as inputProps } from '@components/Input';
6
- import classNames from 'classnames';
7
-
8
- export interface Props {
9
- id?: string;
10
- className?: string;
11
- onSubmit?: () => void;
12
- ref?: string;
13
- components?: Array<inputProps & buttonProps & { htmlType: string }>;
14
- }
15
-
16
- const Form = ({
17
- id,
18
- className,
19
- onSubmit,
20
- ref,
21
- components,
22
- }: Props): JSX.Element => {
23
- return (
24
- <Container withPadding>
25
- <form
26
- id={id}
27
- ref={ref}
28
- className={classNames(className, 'theme-local')}
29
- onSubmit={onSubmit}
30
- >
31
- {components?.map((component, i) => {
32
- if (component?.htmlType === 'Input') {
33
- return (
34
- <Input
35
- key={`input_${i + 0}`}
36
- className={classNames(component?.className)}
37
- label={component?.label}
38
- placeholder={component?.placeholder}
39
- type={component?.type}
40
- name={component?.name}
41
- />
42
- );
43
- } else if (component.htmlType === 'Button') {
44
- return (
45
- <Button
46
- key={`button_${i + 0}`}
47
- type={component?.type}
48
- onClick={component?.onClick}
49
- className={classNames(component?.className)}
50
- >
51
- {component?.children}
52
- </Button>
53
- );
54
- } else return <></>;
55
- })}
56
- </form>
57
- </Container>
58
- );
59
- };
60
-
61
- export default Form;
File without changes
@@ -1,31 +0,0 @@
1
- import { Meta, StoryObj } from '@storybook/react';
2
- import { idAndClassName } from '@utils/controls';
3
-
4
- import FyreCard from '.';
5
-
6
- const meta = {
7
- title: 'Components/Fyre Card',
8
- component: FyreCard,
9
- parameters: {},
10
- argTypes: {
11
- ...idAndClassName,
12
- image: {
13
- description: '',
14
- control: 'text',
15
- table: {
16
- category: '',
17
- },
18
- },
19
- },
20
- args: {
21
- image: 'https://picsum.photos/500/300',
22
- buttonProps: {
23
- children: 'Shop Now',
24
- },
25
- },
26
- };
27
- export default meta;
28
-
29
- type Story = StoryObj<typeof meta>;
30
-
31
- export const Default: Story = {};