uikit-react-public 0.14.21 → 0.21.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 (392) hide show
  1. package/README.md +2 -2
  2. package/dist/components/Accordion/Accordion.Heading.d.ts +5 -4
  3. package/dist/components/Accordion/Accordion.Panel.d.ts +2 -2
  4. package/dist/components/Accordion/Accordion.d.ts +1 -1
  5. package/dist/components/Accordion/Accordion.stories.d.ts +57 -0
  6. package/dist/components/Accordion/index.d.ts +2 -0
  7. package/dist/components/AppHeader/AppHeader.d.ts +1 -1
  8. package/dist/components/AppHeader/AppHeaderBottom.d.ts +1 -1
  9. package/dist/components/AppHeader/AppHeaderNav.d.ts +1 -1
  10. package/dist/components/AppHeader/AppHeaderTop.d.ts +1 -1
  11. package/dist/components/Avatar/Avatar.stories.d.ts +107 -1
  12. package/dist/components/Breadcrumbs/Breadcrumb.d.ts +3 -4
  13. package/dist/components/Breadcrumbs/Breadcrumbs.d.ts +1 -1
  14. package/dist/components/Breadcrumbs/Breadcrumbs.stories.d.ts +1 -1
  15. package/dist/components/Button/Button.d.ts +8 -3
  16. package/dist/components/Button/Button.stories.d.ts +17 -7
  17. package/dist/components/Button/style/buttonAccentStyle.d.ts +4 -0
  18. package/dist/components/Button/style/buttonPrimaryDestructiveStyle.d.ts +4 -0
  19. package/dist/components/Button/style/buttonPrimaryStyle.d.ts +4 -0
  20. package/dist/components/Button/style/buttonPrimarySubtleStyle.d.ts +4 -0
  21. package/dist/components/Button/style/buttonPrimaryWarningStyle.d.ts +4 -0
  22. package/dist/components/Button/style/buttonSecondaryDestructiveStyle.d.ts +4 -0
  23. package/dist/components/Button/style/buttonSecondaryStyle.d.ts +4 -0
  24. package/dist/components/Button/style/buttonSecondarySubtleStyle.d.ts +4 -0
  25. package/dist/components/Button/style/buttonTertiaryDestructiveStyle.d.ts +4 -0
  26. package/dist/components/Button/style/buttonTertiaryNoPaddingStyle.d.ts +4 -0
  27. package/dist/components/Button/style/buttonTertiaryStyle.d.ts +4 -0
  28. package/dist/components/Calendar/index.d.ts +1 -1
  29. package/dist/components/Checkbox/Checkbox.d.ts +1 -0
  30. package/dist/components/Datepicker/Datepicker.d.ts +1 -1
  31. package/dist/components/Datepicker/Datepicker.stories.d.ts +4 -3
  32. package/dist/components/Datepicker/Datepicker.types.d.ts +4 -5
  33. package/dist/components/Datepicker/subcomponents/CustomDatepicker.d.ts +4 -1
  34. package/dist/components/Datepicker/subcomponents/DatepickerInput.d.ts +15 -2
  35. package/dist/components/Datepicker/subcomponents/Panel.d.ts +1 -1
  36. package/dist/components/Datepicker/subcomponents/VisibleField.d.ts +6 -1
  37. package/dist/components/Datepicker/subcomponents/index.d.ts +0 -1
  38. package/dist/components/Datepicker/utils/index.d.ts +0 -1
  39. package/dist/components/Dialog/BaseDialog.d.ts +2 -1
  40. package/dist/components/Dialog/Dialog.d.ts +2 -0
  41. package/dist/components/FooterNew/BackToTop.d.ts +8 -0
  42. package/dist/components/FooterNew/Footer.d.ts +23 -0
  43. package/dist/components/FooterNew/FooterColumn.d.ts +8 -0
  44. package/dist/components/FooterNew/FooterLinks.d.ts +7 -0
  45. package/dist/components/FooterNew/FooterNavLink.d.ts +8 -0
  46. package/dist/components/FooterNew/LegalAndCopyright.d.ts +14 -0
  47. package/dist/components/FooterNew/LogoAddressAndSocial.d.ts +10 -0
  48. package/dist/components/FooterNew/SocialLink.d.ts +8 -0
  49. package/dist/components/FooterNew/index.d.ts +2 -0
  50. package/dist/components/Header/Header.d.ts +4 -1
  51. package/dist/components/Header/Header.stories.d.ts +40 -0
  52. package/dist/components/HeaderNew/Header.d.ts +18 -0
  53. package/dist/components/HeaderNew/HeaderBorder.d.ts +7 -0
  54. package/dist/components/HeaderNew/HeaderLogo.d.ts +9 -0
  55. package/dist/components/HeaderNew/HeaderMenuContainer.d.ts +7 -0
  56. package/dist/components/HeaderNew/HeaderTitle.d.ts +9 -0
  57. package/dist/components/HeaderNew/__tests__/Header.test.d.ts +1 -0
  58. package/dist/components/HeaderNew/constants.d.ts +3 -0
  59. package/dist/components/HeaderNew/index.d.ts +3 -0
  60. package/dist/components/HeadingNew/Heading.d.ts +13 -0
  61. package/dist/components/HeadingNew/index.d.ts +2 -0
  62. package/dist/components/Icon/svgImports.d.ts +7 -881
  63. package/dist/components/Link/BaseLink.d.ts +14 -5
  64. package/dist/components/Link/Link.d.ts +8 -3
  65. package/dist/components/Link/Link.stories.d.ts +3 -1
  66. package/dist/components/Main/Main.d.ts +21 -0
  67. package/dist/components/Main/Main.stories.d.ts +15 -0
  68. package/dist/components/Main/__tests__/Main.test.d.ts +1 -0
  69. package/dist/components/Main/index.d.ts +2 -0
  70. package/dist/components/MenuNew/Menu.context.d.ts +14 -0
  71. package/dist/components/MenuNew/Menu.d.ts +20 -0
  72. package/dist/components/MenuNew/MenuContent.d.ts +9 -0
  73. package/dist/components/MenuNew/MenuItem.d.ts +10 -0
  74. package/dist/components/MenuNew/MenuSection.d.ts +7 -0
  75. package/dist/components/MenuNew/index.d.ts +6 -0
  76. package/dist/components/MenuNew/trigger/ButtonMenuTrigger.d.ts +8 -0
  77. package/dist/components/MenuNew/trigger/IconMenuTrigger.d.ts +8 -0
  78. package/dist/components/NativeDatepicker/NativeDatepicker.d.ts +3 -0
  79. package/dist/components/NativeDatepicker/NativeDatepicker.stories.d.ts +36 -0
  80. package/dist/components/NativeDatepicker/NativeDatepicker.types.d.ts +10 -0
  81. package/dist/components/NativeDatepicker/index.d.ts +2 -0
  82. package/dist/components/{Datepicker → NativeDatepicker}/utils/dateToLocaleISOString/dateToLocaleISOString.d.ts +1 -1
  83. package/dist/components/NativeDatepicker/utils/dateToLocaleISOString/dateToLocaleISOString.test.d.ts +1 -0
  84. package/dist/components/NativeDatepicker/utils/index.d.ts +1 -0
  85. package/dist/components/Overlay/Overlay.stories.d.ts +12 -12
  86. package/dist/components/ParagraphNew/Paragraph.d.ts +13 -0
  87. package/dist/components/ParagraphNew/index.d.ts +4 -0
  88. package/dist/components/Select/Select.d.ts +2 -1
  89. package/dist/components/Select/Select.stories.d.ts +167 -3
  90. package/dist/components/Select/Select.types.d.ts +75 -19
  91. package/dist/components/Select/subcomponents/CustomOption.d.ts +1 -1
  92. package/dist/components/Select/subcomponents/CustomSelect.d.ts +3 -2
  93. package/dist/components/Select/subcomponents/FilterInput.d.ts +16 -0
  94. package/dist/components/Select/subcomponents/NativeSelect.d.ts +5 -1
  95. package/dist/components/Select/subcomponents/VisibleField.d.ts +6 -1
  96. package/dist/components/Select/subcomponents/index.d.ts +1 -0
  97. package/dist/components/Spinner/Spinner.d.ts +2 -0
  98. package/dist/components/StandaloneLink/StandaloneLink.d.ts +8 -5
  99. package/dist/components/StandaloneLink/StandaloneLink.stories.d.ts +3 -1
  100. package/dist/components/Table/Table.d.ts +3 -3
  101. package/dist/components/Table/Table.stories.d.ts +3 -3
  102. package/dist/components/Table/Table.types.d.ts +1 -0
  103. package/dist/components/Table/subcomponents/Cell/Cell.d.ts +5 -1
  104. package/dist/components/Table/subcomponents/Cell/Cell.stories.d.ts +15 -13
  105. package/dist/components/Table/subcomponents/Cell/CellContent.d.ts +5 -1
  106. package/dist/components/Table/subcomponents/HeadCell/HeadCell.d.ts +2 -1
  107. package/dist/components/Table/subcomponents/HeadCell/HeadCell.stories.d.ts +14 -13
  108. package/dist/components/Table/subcomponents/HeadCell/HeadCellContent.d.ts +2 -1
  109. package/dist/components/Table/subcomponents/__tests__/Row.test.d.ts +1 -0
  110. package/dist/components/UclLogoNew/UclLogo.d.ts +8 -0
  111. package/dist/components/UclLogoNew/index.d.ts +2 -0
  112. package/dist/components/WeekPicker/WeekPicker.d.ts +2 -2
  113. package/dist/components/WeekPicker/WeekPicker.stories.d.ts +41 -0
  114. package/dist/components/WeekPicker/WeekPicker.types.d.ts +16 -0
  115. package/dist/components/WeekPicker/index.d.ts +1 -0
  116. package/dist/components/WeekPicker/subcomponents/CustomDatepicker.d.ts +1 -1
  117. package/dist/components/index.d.ts +20 -0
  118. package/dist/hooks/useFocusTrap.d.ts +2 -1
  119. package/dist/index.d.ts +1 -0
  120. package/dist/index.js +22204 -16719
  121. package/dist/theme/__tests__/fonts.test.d.ts +1 -0
  122. package/dist/theme/common/themeCommon.d.ts +904 -0
  123. package/dist/theme/fonts.d.ts +18 -0
  124. package/dist/theme/index.d.ts +6 -3
  125. package/dist/theme/light/lightColour.d.ts +126 -0
  126. package/dist/theme/light/lightTheme.d.ts +3 -0
  127. package/dist/theme/original/color.d.ts +166 -0
  128. package/dist/theme/original/defaultTheme.d.ts +1340 -0
  129. package/dist/theme/original/originalColourNewStructure.d.ts +126 -0
  130. package/dist/theme/useTheme.d.ts +2174 -0
  131. package/dist/utils/__tests__/announce.test.d.ts +1 -0
  132. package/dist/utils/addAlphaToHex.d.ts +5 -0
  133. package/dist/utils/announce.d.ts +6 -0
  134. package/dist/utils/index.d.ts +1 -0
  135. package/dist/utils/scrollToTop.d.ts +2 -0
  136. package/lib/components/Accordion/Accordion.Heading.tsx +65 -34
  137. package/lib/components/Accordion/Accordion.Panel.tsx +11 -7
  138. package/lib/components/Accordion/Accordion.stories.tsx +139 -0
  139. package/lib/components/Accordion/Accordion.tsx +39 -31
  140. package/lib/components/Accordion/__tests__/__snapshots__/Accordion.test.tsx.snap +15 -13
  141. package/lib/components/Accordion/index.ts +2 -0
  142. package/lib/components/Alert/Alert.stories.tsx +1 -1
  143. package/lib/components/Alert/Alert.tsx +12 -12
  144. package/lib/components/Alert/__tests__/__snapshots__/Alert.test.tsx.snap +13 -39
  145. package/lib/components/AppHeader/AppHeader.tsx +6 -11
  146. package/lib/components/AppHeader/AppHeaderBottom.tsx +2 -3
  147. package/lib/components/AppHeader/AppHeaderNav.tsx +2 -3
  148. package/lib/components/AppHeader/AppHeaderTop.tsx +1 -1
  149. package/lib/components/AppHeader/__tests__/__snapshots__/AppHeader.test.tsx.snap +2 -2
  150. package/lib/components/AppMenu/__tests__/__snapshots__/AppMenu.test.tsx.snap +6 -19
  151. package/lib/components/Avatar/Avatar.mdx +117 -0
  152. package/lib/components/Avatar/Avatar.stories.tsx +110 -2
  153. package/lib/components/Badge/Badge.stories.tsx +1 -1
  154. package/lib/components/Blanket/Blanket.stories.tsx +1 -1
  155. package/lib/components/Breadcrumbs/Breadcrumb.tsx +26 -12
  156. package/lib/components/Breadcrumbs/Breadcrumbs.tsx +1 -1
  157. package/lib/components/Breadcrumbs/__tests__/Breadcrumbs.test.tsx +9 -27
  158. package/lib/components/Breadcrumbs/__tests__/__snapshots__/Breadcrumbs.test.tsx.snap +24 -20
  159. package/lib/components/Button/Button.mdx +32 -279
  160. package/lib/components/Button/Button.stories.tsx +44 -51
  161. package/lib/components/Button/Button.tsx +166 -25
  162. package/lib/components/Button/__tests__/Button.test.tsx +49 -15
  163. package/lib/components/Button/__tests__/__snapshots__/Button.test.tsx.snap +80 -73
  164. package/lib/components/Button/style/buttonAccentStyle.ts +53 -0
  165. package/lib/components/Button/style/buttonPrimaryDestructiveStyle.ts +55 -0
  166. package/lib/components/Button/style/buttonPrimaryStyle.ts +53 -0
  167. package/lib/components/Button/style/buttonPrimarySubtleStyle.ts +64 -0
  168. package/lib/components/Button/style/buttonPrimaryWarningStyle.ts +56 -0
  169. package/lib/components/Button/style/buttonSecondaryDestructiveStyle.ts +63 -0
  170. package/lib/components/Button/style/buttonSecondaryStyle.ts +62 -0
  171. package/lib/components/Button/style/buttonSecondarySubtleStyle.ts +72 -0
  172. package/lib/components/Button/style/buttonTertiaryDestructiveStyle.ts +65 -0
  173. package/lib/components/Button/style/buttonTertiaryNoPaddingStyle.ts +52 -0
  174. package/lib/components/Button/style/buttonTertiaryStyle.ts +62 -0
  175. package/lib/components/Calendar/Calendar.stories.tsx +1 -1
  176. package/lib/components/Calendar/Calendar.tsx +2 -2
  177. package/lib/components/Calendar/__tests__/Calendar.test.tsx +23 -15
  178. package/lib/components/Calendar/__tests__/__snapshots__/Calendar.test.tsx.snap +99 -95
  179. package/lib/components/Calendar/index.ts +1 -5
  180. package/lib/components/Calendar/subcomponents/AcademicWeek.tsx +2 -1
  181. package/lib/components/Calendar/subcomponents/AcademicWeeks.tsx +1 -1
  182. package/lib/components/Calendar/subcomponents/ColumnHeading.tsx +2 -2
  183. package/lib/components/Calendar/subcomponents/Controls.tsx +1 -1
  184. package/lib/components/Calendar/subcomponents/Day.stories.tsx +1 -1
  185. package/lib/components/Calendar/subcomponents/Day.tsx +7 -9
  186. package/lib/components/Calendar/subcomponents/EventDot.tsx +3 -6
  187. package/lib/components/Calendar/subcomponents/index.ts +1 -1
  188. package/lib/components/Calendar/utils/getDatesForCalendarGrid/getDatesForCalendarGrid.ts +43 -11
  189. package/lib/components/Calendar/utils/normaliseMonth/normaliseMonth.test.ts +5 -5
  190. package/lib/components/Checkbox/Checkbox.stories.tsx +1 -1
  191. package/lib/components/Checkbox/Checkbox.tsx +12 -10
  192. package/lib/components/Checkbox/__tests__/Checkbox.test.tsx +29 -0
  193. package/lib/components/Checkbox/__tests__/__snapshots__/Checkbox.test.tsx.snap +4 -4
  194. package/lib/components/Datepicker/Datepicker.lld.md +108 -0
  195. package/lib/components/Datepicker/Datepicker.stories.tsx +44 -5
  196. package/lib/components/Datepicker/Datepicker.tsx +14 -36
  197. package/lib/components/Datepicker/Datepicker.types.ts +5 -14
  198. package/lib/components/Datepicker/__tests__/Datepicker.test.tsx +267 -8
  199. package/lib/components/Datepicker/__tests__/__snapshots__/Datepicker.test.tsx.snap +20 -42
  200. package/lib/components/Datepicker/subcomponents/CustomDatepicker.tsx +48 -5
  201. package/lib/components/Datepicker/subcomponents/DatepickerInput.tsx +30 -17
  202. package/lib/components/Datepicker/subcomponents/Panel.tsx +6 -2
  203. package/lib/components/Datepicker/subcomponents/VisibleField.tsx +46 -8
  204. package/lib/components/Datepicker/subcomponents/index.ts +0 -1
  205. package/lib/components/Datepicker/utils/index.ts +0 -1
  206. package/lib/components/Dialog/BaseDialog.tsx +13 -2
  207. package/lib/components/Dialog/Dialog.stories.tsx +1 -1
  208. package/lib/components/Dialog/Dialog.tsx +8 -1
  209. package/lib/components/Dialog/DialogBody.tsx +5 -1
  210. package/lib/components/Dialog/DialogHeader.tsx +2 -1
  211. package/lib/components/Divider/Divider.stories.tsx +1 -1
  212. package/lib/components/Divider/__tests__/__snapshots__/Breadcrumbs.test.tsx.snap +12 -12
  213. package/lib/components/FeedbackDialog/FeedbackDialog.stories.tsx +1 -1
  214. package/lib/components/FeedbackDialog/FeedbackDialog.tsx +4 -6
  215. package/lib/components/Field/CharacterCount.tsx +2 -2
  216. package/lib/components/Field/ErrorText.tsx +2 -1
  217. package/lib/components/Field/Field.stories.tsx +1 -1
  218. package/lib/components/Field/Field.tsx +1 -1
  219. package/lib/components/Field/HelperText.tsx +3 -1
  220. package/lib/components/Field/__tests__/Field.test.tsx +13 -0
  221. package/lib/components/FileInput/FileInput.stories.tsx +1 -1
  222. package/lib/components/FileInput/__tests__/__snapshots__/FileInput.test.tsx.snap +4 -20
  223. package/lib/components/Footer/Footer.stories.tsx +1 -1
  224. package/lib/components/Footer/__tests__/__snapshots__/Footer.test.tsx.snap +73 -82
  225. package/lib/components/FooterNew/BackToTop.tsx +83 -0
  226. package/lib/components/FooterNew/Footer.tsx +110 -0
  227. package/lib/components/FooterNew/FooterColumn.tsx +79 -0
  228. package/lib/components/FooterNew/FooterLinks.tsx +44 -0
  229. package/lib/components/FooterNew/FooterNavLink.tsx +63 -0
  230. package/lib/components/FooterNew/LegalAndCopyright.tsx +150 -0
  231. package/lib/components/FooterNew/LogoAddressAndSocial.tsx +154 -0
  232. package/lib/components/FooterNew/SocialLink.tsx +108 -0
  233. package/lib/components/FooterNew/__tests__/Footer.test.tsx +51 -0
  234. package/lib/components/FooterNew/__tests__/__snapshots__/Footer.test.tsx.snap +1107 -0
  235. package/lib/components/FooterNew/index.ts +2 -0
  236. package/lib/components/Header/Header.mdx +52 -0
  237. package/lib/components/Header/Header.stories.tsx +98 -0
  238. package/lib/components/Header/Header.tsx +51 -6
  239. package/lib/components/Header/__tests__/Header.test.tsx +17 -1
  240. package/lib/components/HeaderDraft/__tests__/__snapshots__/Header.test.tsx.snap +3 -2
  241. package/lib/components/HeaderNew/Header.tsx +93 -0
  242. package/lib/components/HeaderNew/HeaderBorder.tsx +55 -0
  243. package/lib/components/HeaderNew/HeaderLogo.tsx +70 -0
  244. package/lib/components/HeaderNew/HeaderMenuContainer.tsx +35 -0
  245. package/lib/components/HeaderNew/HeaderTitle.tsx +53 -0
  246. package/lib/components/HeaderNew/__tests__/Header.test.tsx +42 -0
  247. package/lib/components/HeaderNew/__tests__/__snapshots__/Header.test.tsx.snap +79 -0
  248. package/lib/components/HeaderNew/constants.ts +3 -0
  249. package/lib/components/HeaderNew/index.ts +7 -0
  250. package/lib/components/Heading/Heading.stories.tsx +1 -1
  251. package/lib/components/HeadingNew/Heading.tsx +208 -0
  252. package/lib/components/HeadingNew/index.ts +2 -0
  253. package/lib/components/Icon/Icon.stories.tsx +1 -1
  254. package/lib/components/Icon/__tests__/__snapshots__/Icon.test.tsx.snap +16 -12
  255. package/lib/components/Icon/svgImports.ts +318 -296
  256. package/lib/components/IconButton/IconButton.stories.tsx +1 -1
  257. package/lib/components/IconButton/IconButton.tsx +3 -4
  258. package/lib/components/IconButton/__tests__/__snapshots__/IconButton.test.tsx.snap +12 -9
  259. package/lib/components/Input/Input.stories.tsx +1 -1
  260. package/lib/components/Label/Label.stories.tsx +1 -1
  261. package/lib/components/Link/BaseLink.tsx +114 -71
  262. package/lib/components/Link/Link.stories.tsx +1 -1
  263. package/lib/components/Link/Link.tsx +120 -109
  264. package/lib/components/Link/__tests__/__snapshots__/link.test.tsx.snap +2 -2
  265. package/lib/components/Main/Main.stories.tsx +36 -0
  266. package/lib/components/Main/Main.tsx +46 -0
  267. package/lib/components/Main/__tests__/Main.test.tsx +80 -0
  268. package/lib/components/Main/__tests__/__snapshots__/Main.test.tsx.snap +33 -0
  269. package/lib/components/Main/index.ts +2 -0
  270. package/lib/components/MenuNew/Menu.context.tsx +149 -0
  271. package/lib/components/MenuNew/Menu.tsx +75 -0
  272. package/lib/components/MenuNew/MenuContent.tsx +140 -0
  273. package/lib/components/MenuNew/MenuItem.tsx +101 -0
  274. package/lib/components/MenuNew/MenuSection.tsx +47 -0
  275. package/lib/components/MenuNew/index.ts +8 -0
  276. package/lib/components/MenuNew/trigger/ButtonMenuTrigger.tsx +42 -0
  277. package/lib/components/MenuNew/trigger/IconMenuTrigger.tsx +40 -0
  278. package/lib/components/NativeDatepicker/NativeDatepicker.stories.tsx +100 -0
  279. package/lib/components/{Datepicker/subcomponents → NativeDatepicker}/NativeDatepicker.tsx +14 -15
  280. package/lib/components/NativeDatepicker/NativeDatepicker.types.ts +19 -0
  281. package/lib/components/NativeDatepicker/index.ts +2 -0
  282. package/lib/components/{Datepicker → NativeDatepicker}/utils/dateToLocaleISOString/dateToLocaleISOString.ts +1 -1
  283. package/lib/components/NativeDatepicker/utils/index.ts +1 -0
  284. package/lib/components/Pagination/Pagination.stories.tsx +1 -1
  285. package/lib/components/Pagination/PaginationControls.tsx +59 -17
  286. package/lib/components/Pagination/PaginationInfo.tsx +7 -4
  287. package/lib/components/Paragraph/Paragraph.stories.tsx +1 -1
  288. package/lib/components/ParagraphNew/Paragraph.tsx +200 -0
  289. package/lib/components/ParagraphNew/index.ts +6 -0
  290. package/lib/components/Radio/Radio.stories.tsx +1 -1
  291. package/lib/components/Radio/Radio.tsx +8 -8
  292. package/lib/components/Radio/__tests__/__snapshots__/Radio.test.tsx.snap +4 -4
  293. package/lib/components/Search/Search.stories.tsx +1 -1
  294. package/lib/components/Search/Search.tsx +4 -1
  295. package/lib/components/Search/__tests__/Search.test.tsx +19 -1
  296. package/lib/components/Search/__tests__/__snapshots__/Search.test.tsx.snap +12 -32
  297. package/lib/components/Select/Select.mdx +192 -0
  298. package/lib/components/Select/Select.stories.tsx +229 -48
  299. package/lib/components/Select/Select.tsx +50 -15
  300. package/lib/components/Select/Select.types.ts +99 -44
  301. package/lib/components/Select/__tests__/Select.test.tsx +698 -8
  302. package/lib/components/Select/__tests__/__snapshots__/Select.test.tsx.snap +5 -4
  303. package/lib/components/Select/subcomponents/CustomOption.tsx +12 -4
  304. package/lib/components/Select/subcomponents/CustomSelect.tsx +411 -41
  305. package/lib/components/Select/subcomponents/FilterInput.tsx +90 -0
  306. package/lib/components/Select/subcomponents/NativeSelect.tsx +21 -17
  307. package/lib/components/Select/subcomponents/Panel.tsx +2 -2
  308. package/lib/components/Select/subcomponents/VisibleField.tsx +59 -6
  309. package/lib/components/Select/subcomponents/index.tsx +1 -0
  310. package/lib/components/Snackbar/Snackbar.stories.tsx +1 -1
  311. package/lib/components/Snackbar/__tests__/__snapshots__/Snackbar.test.tsx.snap +9 -15
  312. package/lib/components/Spinner/Spinner.stories.tsx +1 -1
  313. package/lib/components/Spinner/Spinner.tsx +24 -5
  314. package/lib/components/Spinner/__tests__/Spinner.test.tsx +35 -5
  315. package/lib/components/Spinner/__tests__/__snapshots__/Spinner.test.tsx.snap +40 -16
  316. package/lib/components/StandaloneLink/StandaloneLink.stories.tsx +1 -1
  317. package/lib/components/StandaloneLink/StandaloneLink.tsx +180 -163
  318. package/lib/components/StandaloneLink/__tests__/__snapshots__/StandaloneLink.test.tsx.snap +2 -2
  319. package/lib/components/Table/Table.stories.tsx +1 -1
  320. package/lib/components/Table/Table.tsx +2 -0
  321. package/lib/components/Table/Table.types.ts +1 -0
  322. package/lib/components/Table/__tests__/Table.test.tsx +19 -0
  323. package/lib/components/Table/__tests__/__snapshots__/Table.test.tsx.snap +7 -3
  324. package/lib/components/Table/subcomponents/Cell/Cell.stories.tsx +1 -1
  325. package/lib/components/Table/subcomponents/Cell/Cell.tsx +23 -2
  326. package/lib/components/Table/subcomponents/Cell/CellContent.tsx +12 -1
  327. package/lib/components/Table/subcomponents/Cell/__tests__/Cell.test.tsx +106 -0
  328. package/lib/components/Table/subcomponents/Cell/__tests__/__snapshots__/Cell.test.tsx.snap +4 -3
  329. package/lib/components/Table/subcomponents/HeadCell/HeadCell.stories.tsx +1 -1
  330. package/lib/components/Table/subcomponents/HeadCell/HeadCell.tsx +28 -6
  331. package/lib/components/Table/subcomponents/HeadCell/HeadCellContent.tsx +3 -0
  332. package/lib/components/Table/subcomponents/HeadCell/__tests__/HeadCell.test.tsx +221 -2
  333. package/lib/components/Table/subcomponents/HeadCell/__tests__/__snapshots__/HeadCell.test.tsx.snap +6 -4
  334. package/lib/components/Table/subcomponents/Row.tsx +2 -2
  335. package/lib/components/Table/subcomponents/SortIcon.tsx +1 -0
  336. package/lib/components/Table/subcomponents/__tests__/Row.test.tsx +59 -0
  337. package/lib/components/Tabs/Tab.tsx +3 -3
  338. package/lib/components/Tabs/Tabs.stories.tsx +1 -1
  339. package/lib/components/Tabs/Tabs.tsx +5 -3
  340. package/lib/components/Tabs/__tests__/__snapshots__/Tabs.test.tsx.snap +4 -4
  341. package/lib/components/Textarea/Textarea.stories.tsx +1 -1
  342. package/lib/components/Timepicker/Timepicker.stories.tsx +1 -1
  343. package/lib/components/Timepicker/Timepicker.tsx +4 -0
  344. package/lib/components/Timepicker/__tests__/__snapshots__/Timepicker.test.tsx.snap +2 -2
  345. package/lib/components/Toggle/Toggle.stories.tsx +1 -1
  346. package/lib/components/Toggle/Toggle.tsx +5 -5
  347. package/lib/components/Toggle/ToggleHandle.tsx +2 -3
  348. package/lib/components/Tooltip/Tooltip.stories.tsx +1 -1
  349. package/lib/components/Tooltip/Tooltip.tsx +2 -2
  350. package/lib/components/Tooltip/__tests__/__snapshots__/tooltip.test.tsx.snap +2 -2
  351. package/lib/components/UclLogoNew/UclLogo.tsx +42 -0
  352. package/lib/components/UclLogoNew/index.ts +2 -0
  353. package/lib/components/WeekPicker/WeekPicker.stories.tsx +145 -0
  354. package/lib/components/WeekPicker/WeekPicker.tsx +2 -2
  355. package/lib/components/WeekPicker/WeekPicker.types.ts +21 -0
  356. package/lib/components/WeekPicker/index.ts +1 -0
  357. package/lib/components/WeekPicker/subcomponents/CustomDatepicker.tsx +1 -1
  358. package/lib/components/common/Common.mdx +1 -2
  359. package/lib/components/index.ts +30 -3
  360. package/lib/hooks/useFocusTrap.ts +40 -4
  361. package/lib/index.ts +1 -0
  362. package/lib/theme/Colours.mdx +1 -1
  363. package/lib/theme/Theme.mdx +1 -1
  364. package/lib/theme/Typography.mdx +1 -1
  365. package/lib/theme/__tests__/fonts.test.ts +37 -0
  366. package/lib/theme/common/themeCommon.ts +515 -0
  367. package/lib/theme/fonts.ts +110 -0
  368. package/lib/theme/index.ts +6 -6
  369. package/lib/theme/light/lightColour.ts +232 -0
  370. package/lib/theme/light/lightTheme.ts +37 -0
  371. package/lib/theme/{defaultTheme.ts → original/color.ts} +17 -199
  372. package/lib/theme/original/defaultTheme.ts +207 -0
  373. package/lib/theme/original/originalColourNewStructure.ts +185 -0
  374. package/lib/theme/useTheme.tsx +72 -15
  375. package/lib/types/assets.d.ts +10 -0
  376. package/lib/utils/__tests__/announce.test.ts +121 -0
  377. package/lib/utils/addAlphaToHex.ts +29 -0
  378. package/lib/utils/announce.ts +134 -0
  379. package/lib/utils/index.ts +1 -0
  380. package/lib/utils/scrollToTop.ts +5 -0
  381. package/package.json +11 -9
  382. package/dist/components/Button/buttonPrimaryStyle.d.ts +0 -4
  383. package/dist/components/Button/buttonSecondaryStyle.d.ts +0 -4
  384. package/dist/components/Button/buttonTertiaryStyle.d.ts +0 -4
  385. package/dist/components/Datepicker/subcomponents/NativeDatepicker.d.ts +0 -6
  386. package/dist/theme/defaultTheme.d.ts +0 -274
  387. package/lib/components/Accordion/Accordion.stories.tsx.NOT_READY +0 -93
  388. package/lib/components/Button/buttonPrimaryStyle.ts +0 -62
  389. package/lib/components/Button/buttonSecondaryStyle.ts +0 -65
  390. package/lib/components/Button/buttonTertiaryStyle.ts +0 -54
  391. /package/dist/components/{Datepicker/utils/dateToLocaleISOString/dateToLocaleISOString.test.d.ts → FooterNew/__tests__/Footer.test.d.ts} +0 -0
  392. /package/lib/components/{Datepicker → NativeDatepicker}/utils/dateToLocaleISOString/dateToLocaleISOString.test.ts +0 -0
@@ -0,0 +1,232 @@
1
+ import { tokens } from 'design-system-foundations-public';
2
+ import tokenToHex from '../../utils/addAlphaToHex';
3
+
4
+ const { light: lightThemeTokens } = tokens;
5
+
6
+ // UCL Light Theme Colours
7
+
8
+ const bg = {
9
+ default: tokenToHex(lightThemeTokens.colour.bg.default.$value),
10
+ brand: tokenToHex(lightThemeTokens.colour.bg.brand.$value),
11
+ inverse: tokenToHex(lightThemeTokens.colour.bg.inverse.$value),
12
+ inversePrimary: tokenToHex(
13
+ lightThemeTokens.colour.bg['inverse-primary'].$value
14
+ ),
15
+ };
16
+
17
+ const border = {
18
+ default: tokenToHex(lightThemeTokens.colour.border.default.$value),
19
+ brand: tokenToHex(lightThemeTokens.colour.border.brand.$value),
20
+ brandHover: tokenToHex(lightThemeTokens.colour.border['brand-hover'].$value),
21
+ brandSubtle: tokenToHex(
22
+ lightThemeTokens.colour.border['brand-subtle'].$value
23
+ ),
24
+ primary: tokenToHex(lightThemeTokens.colour.border.primary.$value),
25
+ secondary: tokenToHex(lightThemeTokens.colour.border.secondary.$value),
26
+ tertiary: tokenToHex(lightThemeTokens.colour.border.tertiary.$value),
27
+ subtle: tokenToHex(lightThemeTokens.colour.border.subtle.$value),
28
+ disabled: tokenToHex(lightThemeTokens.colour.border.disabled.$value),
29
+ inverse: tokenToHex(lightThemeTokens.colour.border.inverse.$value),
30
+ brandInverse: tokenToHex(
31
+ lightThemeTokens.colour.border['brand-inverse'].$value
32
+ ),
33
+ brandInverseSecondary: tokenToHex(
34
+ lightThemeTokens.colour.border['brand-inverse-secondary'].$value
35
+ ),
36
+ focus: tokenToHex(lightThemeTokens.colour.border.focus.$value),
37
+ success: tokenToHex(lightThemeTokens.colour.border.success.$value),
38
+ critical: tokenToHex(lightThemeTokens.colour.border.critical.$value),
39
+ warning: tokenToHex(lightThemeTokens.colour.border.warning.$value),
40
+ };
41
+
42
+ const fill = {
43
+ default: tokenToHex(lightThemeTokens.colour.fill.default.$value),
44
+ hover: tokenToHex(lightThemeTokens.colour.fill.hover.$value),
45
+ brand: tokenToHex(lightThemeTokens.colour.fill.brand.$value),
46
+ brandHover: tokenToHex(lightThemeTokens.colour.fill['brand-hover'].$value),
47
+ brandPressed: tokenToHex(
48
+ lightThemeTokens.colour.fill['brand-pressed'].$value
49
+ ),
50
+ brandSubtleSelected: tokenToHex(
51
+ lightThemeTokens.colour.fill['brand-subtle-selected'].$value
52
+ ),
53
+ brandSubtleHover: tokenToHex(
54
+ lightThemeTokens.colour.fill['brand-subtle-hover'].$value
55
+ ),
56
+ brandPrimary: tokenToHex(
57
+ lightThemeTokens.colour.fill['brand-primary'].$value
58
+ ),
59
+ disabled: tokenToHex(lightThemeTokens.colour.fill.disabled.$value),
60
+ inverse: tokenToHex(lightThemeTokens.colour.fill.inverse.$value),
61
+ brandInverseSecondary: tokenToHex(
62
+ lightThemeTokens.colour.fill['brand-inverse-secondary'].$value
63
+ ),
64
+ inverseHover: tokenToHex(
65
+ lightThemeTokens.colour.fill['inverse-hover'].$value
66
+ ),
67
+ critical: tokenToHex(lightThemeTokens.colour.fill.critical.$value),
68
+ criticalHover: tokenToHex(
69
+ lightThemeTokens.colour.fill['critical-hover'].$value
70
+ ),
71
+ criticalSelected: tokenToHex(
72
+ lightThemeTokens.colour.fill['critical-selected'].$value
73
+ ),
74
+ criticalPressed: tokenToHex(
75
+ lightThemeTokens.colour.fill['critical-pressed'].$value
76
+ ),
77
+ warning: tokenToHex(lightThemeTokens.colour.fill.warning.$value),
78
+ warningHover: tokenToHex(
79
+ lightThemeTokens.colour.fill['warning-hover'].$value
80
+ ),
81
+ warningSelected: tokenToHex(
82
+ lightThemeTokens.colour.fill['warning-selected'].$value
83
+ ),
84
+ warningPressed: tokenToHex(
85
+ lightThemeTokens.colour.fill['warning-pressed'].$value
86
+ ),
87
+ success: tokenToHex(lightThemeTokens.colour.fill.success.$value),
88
+ };
89
+
90
+ const icon = {
91
+ default: tokenToHex(lightThemeTokens.colour.icon.default.$value),
92
+ hover: tokenToHex(lightThemeTokens.colour.icon.hover.$value),
93
+ secondary: tokenToHex(lightThemeTokens.colour.icon.secondary.$value),
94
+ tertiary: tokenToHex(lightThemeTokens.colour.icon.tertiary.$value),
95
+ disabled: tokenToHex(lightThemeTokens.colour.icon.disabled.$value),
96
+ disabledOnBgFill: tokenToHex(
97
+ lightThemeTokens.colour.icon['disabled-on-bg-fill'].$value
98
+ ),
99
+ brand: tokenToHex(lightThemeTokens.colour.icon.brand.$value),
100
+ brandHover: tokenToHex(lightThemeTokens.colour.icon['brand-hover'].$value),
101
+ brandSelectedOnBgFill: tokenToHex(
102
+ lightThemeTokens.colour.icon['brand-selected-on-bg-fill'].$value
103
+ ),
104
+ visited: tokenToHex(lightThemeTokens.colour.icon.visited.$value),
105
+ brandPrimary: tokenToHex(
106
+ lightThemeTokens.colour.icon['brand-primary'].$value
107
+ ),
108
+ brandInverted: tokenToHex(
109
+ lightThemeTokens.colour.icon['brand-inverted'].$value
110
+ ),
111
+ inverse: tokenToHex(lightThemeTokens.colour.icon.inverse.$value),
112
+ inverseHover: tokenToHex(
113
+ lightThemeTokens.colour.icon['inverse-hover'].$value
114
+ ),
115
+ brandInverseSecondary: tokenToHex(
116
+ lightThemeTokens.colour.icon['brand-inverse-secondary'].$value
117
+ ),
118
+ inverseTertiary: tokenToHex(
119
+ lightThemeTokens.colour.icon['inverse-tertiary'].$value
120
+ ),
121
+ inverseDisabled: tokenToHex(
122
+ lightThemeTokens.colour.icon['inverse-disabled'].$value
123
+ ),
124
+ critical: tokenToHex(lightThemeTokens.colour.icon.critical.$value),
125
+ criticalOnBgFill: tokenToHex(
126
+ lightThemeTokens.colour.icon['critical-on-bg-fill'].$value
127
+ ),
128
+ success: tokenToHex(lightThemeTokens.colour.icon.success.$value),
129
+ successOnBgFill: tokenToHex(
130
+ lightThemeTokens.colour.icon['success-on-bg-fill'].$value
131
+ ),
132
+ warning: tokenToHex(lightThemeTokens.colour.icon.warning.$value),
133
+ warningOnBgFill: tokenToHex(
134
+ lightThemeTokens.colour.icon['warning-on-bg-fill'].$value
135
+ ),
136
+ };
137
+
138
+ const surface = {
139
+ default: tokenToHex(lightThemeTokens.colour.surface.default.$value),
140
+ primary: tokenToHex(lightThemeTokens.colour.surface.primary.$value),
141
+ secondary: tokenToHex(lightThemeTokens.colour.surface.secondary.$value),
142
+ brand: tokenToHex(lightThemeTokens.colour.surface.brand.$value),
143
+ brandHover: tokenToHex(lightThemeTokens.colour.surface['brand-hover'].$value),
144
+ brandSelected: tokenToHex(
145
+ lightThemeTokens.colour.surface['brand-selected'].$value
146
+ ),
147
+ warning: tokenToHex(lightThemeTokens.colour.surface.warning.$value),
148
+ success: tokenToHex(lightThemeTokens.colour.surface.success.$value),
149
+ critical: tokenToHex(lightThemeTokens.colour.surface.critical.$value),
150
+ hover: tokenToHex(lightThemeTokens.colour.surface.hover.$value),
151
+ selected: tokenToHex(lightThemeTokens.colour.surface.selected.$value),
152
+ disabled: tokenToHex(lightThemeTokens.colour.surface.disabled.$value),
153
+ tertiary: tokenToHex(lightThemeTokens.colour.surface.tertiary.$value),
154
+ inverseBrand: tokenToHex(
155
+ lightThemeTokens.colour.surface['inverse-brand'].$value
156
+ ),
157
+ inverseBrandPrimary: tokenToHex(
158
+ lightThemeTokens.colour.surface['inverse-brand-primary'].$value
159
+ ),
160
+ backdrop: tokenToHex(lightThemeTokens.colour.surface.backdrop.$value),
161
+ };
162
+
163
+ const text = {
164
+ default: tokenToHex(lightThemeTokens.colour.text.default.$value),
165
+ secondary: tokenToHex(lightThemeTokens.colour.text.secondary.$value),
166
+ tertiary: tokenToHex(lightThemeTokens.colour.text.tertiary.$value),
167
+ disabled: tokenToHex(lightThemeTokens.colour.text.disabled.$value),
168
+ inverse: tokenToHex(lightThemeTokens.colour.text.inverse.$value),
169
+ onBgFillDisabled: tokenToHex(
170
+ lightThemeTokens.colour.text['on-bg-fill-disabled'].$value
171
+ ),
172
+ brand: tokenToHex(lightThemeTokens.colour.text.brand.$value),
173
+ brandAccent: tokenToHex(lightThemeTokens.colour.text['brand-accent'].$value),
174
+ brandHover: tokenToHex(lightThemeTokens.colour.text['brand-hover'].$value),
175
+ brandInverse: tokenToHex(
176
+ lightThemeTokens.colour.text['brand-inverse'].$value
177
+ ),
178
+ brandInverseSecondary: tokenToHex(
179
+ lightThemeTokens.colour.text['brand-inverse-secondary'].$value
180
+ ),
181
+ brandPrimary: tokenToHex(
182
+ lightThemeTokens.colour.text['brand-primary'].$value
183
+ ),
184
+ critical: tokenToHex(lightThemeTokens.colour.text.critical.$value),
185
+ warningOnBgFill: tokenToHex(
186
+ lightThemeTokens.colour.text['warning-on-bg-fill'].$value
187
+ ),
188
+ };
189
+
190
+ const link = {
191
+ default: tokenToHex(lightThemeTokens.colour.link.default.$value),
192
+ brand: tokenToHex(lightThemeTokens.colour.link.brand.$value),
193
+ brandHover: tokenToHex(lightThemeTokens.colour.link['brand-hover'].$value),
194
+ visited: tokenToHex(lightThemeTokens.colour.link.visited.$value),
195
+ primary: tokenToHex(lightThemeTokens.colour.link.primary.$value),
196
+ primaryHover: tokenToHex(
197
+ lightThemeTokens.colour.link['primary-hover'].$value
198
+ ),
199
+ disabled: tokenToHex(lightThemeTokens.colour.link.disabled.$value),
200
+ inverse: tokenToHex(lightThemeTokens.colour.link.inverse.$value),
201
+ inverseVisited: tokenToHex(
202
+ lightThemeTokens.colour.link['inverse-visited'].$value
203
+ ),
204
+ inverseDisabled: tokenToHex(
205
+ lightThemeTokens.colour.link['inverse-disabled'].$value
206
+ ),
207
+ inverseSecondary: tokenToHex(
208
+ lightThemeTokens.colour.link['inverse-secondary'].$value
209
+ ),
210
+ inverseTertiary: tokenToHex(
211
+ lightThemeTokens.colour.link['inverse-tertiary'].$value
212
+ ),
213
+ };
214
+
215
+ const speciality = {
216
+ inputDefault: tokenToHex(
217
+ lightThemeTokens.colour.speciality['input-default'].$value
218
+ ),
219
+ };
220
+
221
+ const colour = {
222
+ bg,
223
+ border,
224
+ fill,
225
+ icon,
226
+ surface,
227
+ text,
228
+ link,
229
+ speciality,
230
+ };
231
+
232
+ export default colour;
@@ -0,0 +1,37 @@
1
+ import defaultTheme, { ThemeType } from '../original/defaultTheme';
2
+ import { typography, primitiveColour } from '../common/themeCommon';
3
+ import colour from './lightColour';
4
+
5
+ // UCL Light Theme
6
+
7
+ const lightTheme: ThemeType = {
8
+ // new
9
+ primitiveColour,
10
+ colour,
11
+ typography,
12
+
13
+ // todo: depcrecate
14
+ color: defaultTheme.color,
15
+ thickness: defaultTheme.thickness,
16
+ width: defaultTheme.width,
17
+ height: defaultTheme.height,
18
+ margin: defaultTheme.margin,
19
+ padding: defaultTheme.padding,
20
+ radius: defaultTheme.radius,
21
+ border: defaultTheme.border,
22
+ outline: defaultTheme.outline,
23
+ font: defaultTheme.font,
24
+ boxShadow: {
25
+ ...defaultTheme.boxShadow,
26
+ focus: `0 0 0 2px ${colour.border.inverse}, 0 0 0 4px ${colour.border.brand}`,
27
+ },
28
+ breakpoints: defaultTheme.breakpoints,
29
+ mq: defaultTheme.mq,
30
+
31
+ // For ease of use, margin and padding are added at the top level
32
+ // Usage: margin-top: ${theme.m16};
33
+ ...defaultTheme.margin,
34
+ ...defaultTheme.padding,
35
+ };
36
+
37
+ export default lightTheme;
@@ -24,6 +24,10 @@ const blue5 = '#F2F8FE';
24
24
  const blue200 = '#002248'; // UCL dark blue
25
25
  const blue50 = '#34C6C6'; // UCL vibrant blue
26
26
  const blue20 = '#B6DCE5'; // UCL muted blue
27
+ // added for interim use
28
+ const blue15 = '#D4E6FC';
29
+ const blue20Alt = '#C3DDFB'; // corrected (was #B6DCE5 — wrong hue, too cyan)
30
+ const blue25 = '#B2D3FA';
27
31
 
28
32
  const yellow200 = '#504D48'; // UCL dark yellow
29
33
  const yellow50 = '#FFCA36'; // UCL vibrant yellow
@@ -39,6 +43,9 @@ const red70 = '#CA0007';
39
43
  const red50 = '#E48083';
40
44
  const red40 = '#E48083';
41
45
  const red10 = '#FAE6E7';
46
+ // added for interim use
47
+ const red80 = '#B1070A';
48
+ const red90 = '#990F0E';
42
49
 
43
50
  const pink200 = '#4B0A32'; // UCL dark pink
44
51
  const pink50 = '#AC145A'; // UCL vibrant pink
@@ -80,6 +87,9 @@ const baseColour = {
80
87
  blue200,
81
88
  blue50,
82
89
  blue20,
90
+ blue15,
91
+ blue20Alt,
92
+ blue25,
83
93
 
84
94
  yellow200,
85
95
  yellow50,
@@ -95,6 +105,8 @@ const baseColour = {
95
105
  red50,
96
106
  red40,
97
107
  red10,
108
+ red80,
109
+ red90,
98
110
 
99
111
  pink200,
100
112
  pink50,
@@ -143,7 +155,7 @@ const interactionColours = {
143
155
  blue5: baseColour.blue5,
144
156
  };
145
157
 
146
- const displayColours = {
158
+ export const displayColours = {
147
159
  purpleDark: baseColour.purple200,
148
160
  purpleVibrant: baseColour.purple50,
149
161
  purpleMuted: baseColour.purple20,
@@ -198,7 +210,7 @@ const linkColours = {
198
210
  disabled: baseColour.black20,
199
211
  };
200
212
 
201
- const blackAndWhite = {
213
+ export const blackAndWhite = {
202
214
  black: baseColour.black100,
203
215
  white: baseColour.white,
204
216
  };
@@ -222,209 +234,15 @@ const overlayColours = {
222
234
  };
223
235
 
224
236
  const color = {
237
+ base: baseColour,
225
238
  text: textColours,
226
239
  interaction: interactionColours,
227
240
  display: displayColours,
228
241
  system: systemColours,
229
242
  link: linkColours,
230
243
  neutral: neutralColours,
244
+ blackAndWhite,
231
245
  overlay: overlayColours,
232
246
  };
233
247
 
234
- // These colour definitions will need to be refactored to match the design system.
235
-
236
- const baseSizes = {
237
- s1: '1px',
238
- s2: '2px',
239
- s4: '4px',
240
- s6: '6px',
241
- s8: '8px',
242
- s12: '12px',
243
- s16: '16px',
244
- s20: '20px',
245
- s24: '24px',
246
- s28: '28px',
247
- s32: '32px',
248
- s36: '36px',
249
- s40: '40px',
250
- s44: '44px',
251
- s48: '48px',
252
- s52: '52px',
253
- s56: '56px',
254
- s60: '60px',
255
- s64: '64px',
256
- s72: '72px',
257
- s80: '80px',
258
- };
259
-
260
- const margin = {
261
- m0: 0,
262
- m2: baseSizes.s2,
263
- m4: baseSizes.s4,
264
- m6: baseSizes.s6,
265
- m8: baseSizes.s8,
266
- m12: baseSizes.s12,
267
- m16: baseSizes.s16,
268
- m20: baseSizes.s20,
269
- m24: baseSizes.s24,
270
- m32: baseSizes.s32,
271
- m40: baseSizes.s40,
272
- m48: baseSizes.s48,
273
- m56: baseSizes.s56,
274
- m64: baseSizes.s64,
275
- m72: baseSizes.s72,
276
- m80: baseSizes.s80,
277
- };
278
-
279
- const padding = {
280
- p0: 0,
281
- p2: baseSizes.s2,
282
- p4: baseSizes.s4,
283
- p6: baseSizes.s6,
284
- p8: baseSizes.s8,
285
- p12: baseSizes.s12,
286
- p16: baseSizes.s16,
287
- p20: baseSizes.s20,
288
- p24: baseSizes.s24,
289
- p32: baseSizes.s32,
290
- p40: baseSizes.s40,
291
- p48: baseSizes.s48,
292
- p56: baseSizes.s56,
293
- p64: baseSizes.s64,
294
- p72: baseSizes.s72,
295
- p80: baseSizes.s80,
296
- };
297
-
298
- const breakpoints = {
299
- mobile: 320,
300
- tablet: 672,
301
- desktop: 1056,
302
- desktopLarge: 1536,
303
- };
304
-
305
- const createMediaQuery = (breakpoint: number) =>
306
- // Breakpoints apply at the specified width and above
307
- `@media (min-width: ${breakpoint}px)`;
308
-
309
- const custom = (breakpoint: number) =>
310
- // Fallback for edge cases
311
- createMediaQuery(breakpoint);
312
-
313
- const mq = {
314
- mobile: createMediaQuery(breakpoints.mobile),
315
- tablet: createMediaQuery(breakpoints.tablet),
316
- desktop: createMediaQuery(breakpoints.desktop),
317
- desktopLarge: createMediaQuery(breakpoints.desktopLarge),
318
- custom,
319
- };
320
-
321
- const theme = {
322
- color,
323
-
324
- thickness: {
325
- t1: baseSizes.s1,
326
- t2: baseSizes.s2,
327
- },
328
-
329
- width: {
330
- h16: baseSizes.s16,
331
- h20: baseSizes.s20,
332
- h24: baseSizes.s24,
333
- },
334
-
335
- height: {
336
- h16: baseSizes.s16,
337
- h20: baseSizes.s20,
338
- h24: baseSizes.s24,
339
- h32: baseSizes.s32,
340
- h36: baseSizes.s36,
341
- h40: baseSizes.s40,
342
- h80: baseSizes.s80,
343
- },
344
-
345
- margin,
346
-
347
- padding,
348
-
349
- radius: {
350
- r2: baseSizes.s2,
351
- r4: baseSizes.s4,
352
- r8: baseSizes.s8,
353
- r12: baseSizes.s12,
354
- r16: baseSizes.s16,
355
- },
356
-
357
- border: {
358
- b1: baseSizes.s1,
359
- b2: baseSizes.s2,
360
- },
361
-
362
- outline: {
363
- o2: baseSizes.s2,
364
- o4: baseSizes.s4,
365
- },
366
-
367
- font: {
368
- family: {
369
- primary: 'Helvetica, "Helvetica Neue", Arial, sans-serif',
370
- secondary:
371
- 'Garamond, Baskerville, "Baskerville Old Face", "Hoefler Text", "Times New Roman", serif',
372
- fixed: 'Courier, fixed',
373
- },
374
- size: {
375
- f12: '12px',
376
- f14: '14px', // Font should be at least 14px in most cases
377
- f16: '16px', // Prefer 16px to 14px in most cases
378
- f18: '18px',
379
- f20: '20px',
380
- f22: '22px',
381
- f24: '24px',
382
- f26: '26px',
383
- f28: '28px',
384
- f30: '30px',
385
- f32: '32px',
386
- f36: '36px',
387
- f40: '40px',
388
- },
389
- weight: {
390
- light: 300,
391
- regular: 400,
392
- medium: 500,
393
- semiBold: 600,
394
- bold: 700,
395
- extraBold: 800,
396
- },
397
- lineHeight: {
398
- h100: '100%',
399
- h110: '110%',
400
- h120: '120%',
401
- h130: '130%',
402
- h140: '140%',
403
- h150: '150%',
404
- },
405
- },
406
-
407
- boxShadow: {
408
- // offset-x | offset-y | blur-radius | spread-radius | color
409
- y1: '0 1px 4px 1px rgba(0, 0, 0, 0.1)',
410
- y2: '0 2px 4px 1px rgba(0, 0, 0, 0.1)',
411
- x2y4: '2px 4px 8px 4px rgba(0, 0, 0, 0.1)',
412
- focus: `0px 0px 0px 2px ${color.neutral.white}, 0px 0px 0px 4px ${color.neutral.black}, 0px 0px 0px 6px ${color.system.orange70}`,
413
- active: `0px 6px 0px 0px ${color.interaction.blue80} inset`,
414
- destructiveActive: `0px 6px 0px 0px ${color.system.red100} inset`,
415
- },
416
-
417
- breakpoints,
418
- mq,
419
-
420
- // For ease of use, margin and padding are added at the top level
421
- // Usage: margin-top: ${theme.m16};
422
- ...margin,
423
- ...padding,
424
- };
425
-
426
- export type ThemeType = typeof theme;
427
- export type DisplayColoursType = typeof displayColours;
428
- export type BlackAndWhiteColoursType = typeof blackAndWhite;
429
-
430
- export default theme;
248
+ export default color;