@ilo-org/react 0.14.0 → 0.14.1

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 (377) hide show
  1. package/package.json +13 -10
  2. package/.eslintrc.cjs +0 -39
  3. package/.storybook/main.ts +0 -41
  4. package/.storybook/manager-head.html +0 -92
  5. package/.storybook/manager.ts +0 -6
  6. package/.storybook/preview-head.html +0 -5
  7. package/.storybook/preview.tsx +0 -81
  8. package/.storybook/styles.scss +0 -25
  9. package/.storybook/theme.ts +0 -46
  10. package/.turbo/turbo-build:lib.log +0 -15
  11. package/CHANGELOG.md +0 -884
  12. package/public/fao-logo.svg +0 -195
  13. package/public/favicon.ico +0 -0
  14. package/public/hero.jpg +0 -0
  15. package/public/ilo-dg.jpg +0 -0
  16. package/public/ilo-headquarters.jpg +0 -0
  17. package/public/large.jpg +0 -0
  18. package/public/media-file-poster.jpg +0 -0
  19. package/public/medium.jpg +0 -0
  20. package/public/react.svg +0 -8
  21. package/public/small.jpg +0 -0
  22. package/public/unhcr-logo.svg +0 -1
  23. package/public/unicef-logo.png +0 -0
  24. package/public/video-example.mp4 +0 -0
  25. package/public/wfp-logo.svg +0 -1
  26. package/public/who-logo.svg +0 -1
  27. package/public/youtube-video-poster.avif +0 -0
  28. package/rollup.config.mjs +0 -72
  29. package/src/__tests__/Accordion.test.tsx +0 -16
  30. package/src/__tests__/Button.test.tsx +0 -60
  31. package/src/__tests__/Callout.test.tsx +0 -43
  32. package/src/__tests__/ContextMenu.test.tsx +0 -19
  33. package/src/__tests__/Dropdown.test.tsx +0 -38
  34. package/src/__tests__/Heading.test.tsx +0 -51
  35. package/src/__tests__/Image.test.tsx +0 -21
  36. package/src/__tests__/LinkList.test.tsx +0 -17
  37. package/src/__tests__/List.test.tsx +0 -25
  38. package/src/__tests__/Loading.test.tsx +0 -33
  39. package/src/__tests__/Notification.test.tsx +0 -39
  40. package/src/__tests__/Pagination.test.tsx +0 -58
  41. package/src/__tests__/Profile.test.tsx +0 -48
  42. package/src/__tests__/ReadMore.test.tsx +0 -43
  43. package/src/__tests__/RichText.test.tsx +0 -16
  44. package/src/__tests__/SearchField.test.tsx +0 -35
  45. package/src/__tests__/TableOfContents.test.tsx +0 -12
  46. package/src/__tests__/Tag.test.tsx +0 -10
  47. package/src/components/Accordion/Accordion.args.ts +0 -16
  48. package/src/components/Accordion/Accordion.props.ts +0 -41
  49. package/src/components/Accordion/Accordion.tsx +0 -62
  50. package/src/components/Accordion/AccordionButton.props.ts +0 -13
  51. package/src/components/Accordion/AccordionButton.tsx +0 -58
  52. package/src/components/Accordion/AccordionCtx.ts +0 -9
  53. package/src/components/Accordion/AccordionItem.props.ts +0 -25
  54. package/src/components/Accordion/AccordionItem.tsx +0 -27
  55. package/src/components/Accordion/AccordionPanel.props.ts +0 -25
  56. package/src/components/Accordion/AccordionPanel.tsx +0 -46
  57. package/src/components/Accordion/index.ts +0 -4
  58. package/src/components/Breadcrumb/Breadcrumb.args.ts +0 -61
  59. package/src/components/Breadcrumb/Breadcrumb.props.ts +0 -13
  60. package/src/components/Breadcrumb/Breadcrumb.tsx +0 -82
  61. package/src/components/Breadcrumb/index.ts +0 -1
  62. package/src/components/Button/Button.args.ts +0 -35
  63. package/src/components/Button/Button.props.ts +0 -89
  64. package/src/components/Button/Button.tsx +0 -77
  65. package/src/components/Button/index.ts +0 -2
  66. package/src/components/Callout/Callout.args.ts +0 -38
  67. package/src/components/Callout/Callout.props.ts +0 -60
  68. package/src/components/Callout/Callout.tsx +0 -80
  69. package/src/components/Callout/index.ts +0 -2
  70. package/src/components/Cards/CardGroup/CardGroup.args.ts +0 -807
  71. package/src/components/Cards/CardGroup/CardGroup.props.ts +0 -78
  72. package/src/components/Cards/CardGroup/CardGroup.tsx +0 -54
  73. package/src/components/Cards/CardGroup/index.tsx +0 -3
  74. package/src/components/Cards/DataCard/DataCard.args.ts +0 -69
  75. package/src/components/Cards/DataCard/DataCard.props.ts +0 -60
  76. package/src/components/Cards/DataCard/DataCard.tsx +0 -107
  77. package/src/components/Cards/DataCard/index.tsx +0 -3
  78. package/src/components/Cards/DetailCard/DetailCard.args.ts +0 -17
  79. package/src/components/Cards/DetailCard/DetailCard.props.ts +0 -43
  80. package/src/components/Cards/DetailCard/DetailCard.tsx +0 -62
  81. package/src/components/Cards/DetailCard/index.tsx +0 -3
  82. package/src/components/Cards/FactlistCard/FactListCard.args.ts +0 -14
  83. package/src/components/Cards/FactlistCard/FactListCard.props.ts +0 -19
  84. package/src/components/Cards/FactlistCard/FactListCard.tsx +0 -42
  85. package/src/components/Cards/FactlistCard/index.tsx +0 -3
  86. package/src/components/Cards/FeatureCard/FeatureCard.args.ts +0 -30
  87. package/src/components/Cards/FeatureCard/FeatureCard.props.ts +0 -38
  88. package/src/components/Cards/FeatureCard/FeatureCard.tsx +0 -69
  89. package/src/components/Cards/FeatureCard/index.tsx +0 -3
  90. package/src/components/Cards/MultilinkCard/MultiLinkCard.tsx +0 -76
  91. package/src/components/Cards/MultilinkCard/MultilinkCard.args.ts +0 -33
  92. package/src/components/Cards/MultilinkCard/MultilinkCard.props.ts +0 -30
  93. package/src/components/Cards/MultilinkCard/index.tsx +0 -3
  94. package/src/components/Cards/PromoCard/PromoCard.args.ts +0 -19
  95. package/src/components/Cards/PromoCard/PromoCard.props.ts +0 -36
  96. package/src/components/Cards/PromoCard/PromoCard.tsx +0 -60
  97. package/src/components/Cards/PromoCard/index.tsx +0 -3
  98. package/src/components/Cards/StatCard/StatCard.args.ts +0 -14
  99. package/src/components/Cards/StatCard/StatCard.props.ts +0 -21
  100. package/src/components/Cards/StatCard/StatCard.tsx +0 -36
  101. package/src/components/Cards/StatCard/index.tsx +0 -3
  102. package/src/components/Cards/TextCard/TextCard.args.ts +0 -21
  103. package/src/components/Cards/TextCard/TextCard.props.ts +0 -32
  104. package/src/components/Cards/TextCard/TextCard.tsx +0 -62
  105. package/src/components/Cards/TextCard/index.tsx +0 -3
  106. package/src/components/Checkbox/Checkbox.args.ts +0 -42
  107. package/src/components/Checkbox/Checkbox.props.ts +0 -5
  108. package/src/components/Checkbox/Checkbox.tsx +0 -94
  109. package/src/components/Checkbox/index.ts +0 -2
  110. package/src/components/Collapse/Collapse.props.ts +0 -92
  111. package/src/components/Collapse/Collapse.tsx +0 -130
  112. package/src/components/Collapse/index.ts +0 -1
  113. package/src/components/ContextMenu/ContextMenu.args.ts +0 -62
  114. package/src/components/ContextMenu/ContextMenu.props.ts +0 -28
  115. package/src/components/ContextMenu/ContextMenu.tsx +0 -32
  116. package/src/components/ContextMenu/index.ts +0 -1
  117. package/src/components/Credit/Credit.args.ts +0 -14
  118. package/src/components/Credit/Credit.props.ts +0 -11
  119. package/src/components/Credit/Credit.tsx +0 -41
  120. package/src/components/Credit/index.ts +0 -1
  121. package/src/components/DatePicker/DatePicker.args.ts +0 -56
  122. package/src/components/DatePicker/DatePicker.props.ts +0 -26
  123. package/src/components/DatePicker/DatePicker.tsx +0 -80
  124. package/src/components/DatePicker/index.ts +0 -1
  125. package/src/components/Dropdown/Dropdown.args.ts +0 -70
  126. package/src/components/Dropdown/Dropdown.props.ts +0 -53
  127. package/src/components/Dropdown/Dropdown.tsx +0 -95
  128. package/src/components/Dropdown/index.ts +0 -1
  129. package/src/components/Empty/Empty.props.ts +0 -13
  130. package/src/components/Empty/Empty.tsx +0 -16
  131. package/src/components/Empty/index.ts +0 -1
  132. package/src/components/Fieldset/Fieldset.props.ts +0 -33
  133. package/src/components/Fieldset/Fieldset.tsx +0 -96
  134. package/src/components/Fieldset/index.ts +0 -1
  135. package/src/components/FileUpload/FileUpload.args.ts +0 -60
  136. package/src/components/FileUpload/FileUpload.props.ts +0 -21
  137. package/src/components/FileUpload/FileUpload.tsx +0 -116
  138. package/src/components/FileUpload/index.ts +0 -1
  139. package/src/components/Footer/Footer.args.ts +0 -74
  140. package/src/components/Footer/Footer.props.ts +0 -60
  141. package/src/components/Footer/Footer.tsx +0 -99
  142. package/src/components/Footer/index.ts +0 -1
  143. package/src/components/Form/Form.args.ts +0 -5
  144. package/src/components/Form/Form.props.ts +0 -8
  145. package/src/components/Form/Form.tsx +0 -23
  146. package/src/components/Form/index.ts +0 -2
  147. package/src/components/FormControl/FormControl.props.ts +0 -72
  148. package/src/components/FormControl/FormControl.tsx +0 -169
  149. package/src/components/FormControl/index.ts +0 -2
  150. package/src/components/FormElement/FormElement.props.ts +0 -60
  151. package/src/components/FormElement/FormElement.tsx +0 -19
  152. package/src/components/FormElement/index.ts +0 -1
  153. package/src/components/GlobalProvider/GlobalCtx.ts +0 -6
  154. package/src/components/GlobalProvider/GlobalProvider.props.ts +0 -15
  155. package/src/components/GlobalProvider/GlobalProvider.tsx +0 -21
  156. package/src/components/GlobalProvider/index.ts +0 -2
  157. package/src/components/Heading/Heading.args.ts +0 -49
  158. package/src/components/Heading/Heading.props.ts +0 -24
  159. package/src/components/Heading/Heading.tsx +0 -28
  160. package/src/components/Heading/index.ts +0 -1
  161. package/src/components/Hero/Hero.args.ts +0 -136
  162. package/src/components/Hero/Hero.props.ts +0 -62
  163. package/src/components/Hero/Hero.tsx +0 -94
  164. package/src/components/Hero/HeroCard.props.ts +0 -54
  165. package/src/components/Hero/HeroCard.tsx +0 -65
  166. package/src/components/Hero/index.ts +0 -2
  167. package/src/components/Icon/Icon.args.ts +0 -15
  168. package/src/components/Icon/Icon.props.ts +0 -16
  169. package/src/components/Icon/Icon.tsx +0 -25
  170. package/src/components/Icon/index.ts +0 -1
  171. package/src/components/Image/Image.args.ts +0 -29
  172. package/src/components/Image/Image.props.ts +0 -43
  173. package/src/components/Image/Image.tsx +0 -51
  174. package/src/components/Image/index.ts +0 -1
  175. package/src/components/Input/Input.args.ts +0 -139
  176. package/src/components/Input/Input.props.ts +0 -65
  177. package/src/components/Input/Input.tsx +0 -65
  178. package/src/components/Input/index.ts +0 -1
  179. package/src/components/Link/Link.props.ts +0 -39
  180. package/src/components/Link/Link.tsx +0 -42
  181. package/src/components/Link/index.ts +0 -1
  182. package/src/components/LinkList/LinkList.args.ts +0 -193
  183. package/src/components/LinkList/LinkList.props.ts +0 -52
  184. package/src/components/LinkList/LinkList.tsx +0 -59
  185. package/src/components/LinkList/index.ts +0 -1
  186. package/src/components/List/List.args.ts +0 -34
  187. package/src/components/List/List.props.ts +0 -29
  188. package/src/components/List/List.tsx +0 -36
  189. package/src/components/List/ListItem.props.ts +0 -18
  190. package/src/components/List/ListItem.tsx +0 -17
  191. package/src/components/List/index.ts +0 -2
  192. package/src/components/Loading/Loading.args.ts +0 -55
  193. package/src/components/Loading/Loading.props.ts +0 -23
  194. package/src/components/Loading/Loading.tsx +0 -24
  195. package/src/components/Loading/index.ts +0 -1
  196. package/src/components/LocalNav/LocalNav.args.ts +0 -64
  197. package/src/components/LocalNav/LocalNav.props.ts +0 -56
  198. package/src/components/LocalNav/LocalNav.tsx +0 -181
  199. package/src/components/LocalNav/index.ts +0 -1
  200. package/src/components/Logo/Logo.args.ts +0 -45
  201. package/src/components/Logo/Logo.props.ts +0 -67
  202. package/src/components/Logo/Logo.tsx +0 -247
  203. package/src/components/Logo/index.ts +0 -1
  204. package/src/components/LogoGrid/LogoGrid.args.ts +0 -50
  205. package/src/components/LogoGrid/LogoGrid.props.ts +0 -28
  206. package/src/components/LogoGrid/LogoGrid.tsx +0 -53
  207. package/src/components/LogoGrid/index.ts +0 -1
  208. package/src/components/Navigation/Navigation.args.ts +0 -113
  209. package/src/components/Navigation/Navigation.props.ts +0 -120
  210. package/src/components/Navigation/Navigation.tsx +0 -246
  211. package/src/components/Navigation/index.ts +0 -1
  212. package/src/components/Notification/Notification.args.ts +0 -157
  213. package/src/components/Notification/Notification.props.ts +0 -67
  214. package/src/components/Notification/Notification.tsx +0 -78
  215. package/src/components/Notification/index.ts +0 -1
  216. package/src/components/NumberPicker/NumberPicker.args.ts +0 -50
  217. package/src/components/NumberPicker/NumberPicker.props.ts +0 -26
  218. package/src/components/NumberPicker/NumberPicker.tsx +0 -88
  219. package/src/components/NumberPicker/index.ts +0 -1
  220. package/src/components/Pagination/Pagination.args.ts +0 -43
  221. package/src/components/Pagination/Pagination.props.ts +0 -66
  222. package/src/components/Pagination/Pagination.tsx +0 -115
  223. package/src/components/Pagination/index.ts +0 -1
  224. package/src/components/Profile/Profile.args.ts +0 -58
  225. package/src/components/Profile/Profile.props.ts +0 -55
  226. package/src/components/Profile/Profile.tsx +0 -51
  227. package/src/components/Profile/index.ts +0 -1
  228. package/src/components/Radio/Radio.args.ts +0 -15
  229. package/src/components/Radio/Radio.props.ts +0 -6
  230. package/src/components/Radio/Radio.tsx +0 -102
  231. package/src/components/Radio/index.ts +0 -2
  232. package/src/components/ReadMore/ReadMore.args.ts +0 -23
  233. package/src/components/ReadMore/ReadMore.props.ts +0 -38
  234. package/src/components/ReadMore/ReadMore.tsx +0 -55
  235. package/src/components/ReadMore/index.ts +0 -1
  236. package/src/components/RichText/RichText.props.ts +0 -11
  237. package/src/components/RichText/RichText.tsx +0 -22
  238. package/src/components/RichText/index.ts +0 -1
  239. package/src/components/RichText/richText.args.ts +0 -38
  240. package/src/components/SearchField/SearchField.args.ts +0 -73
  241. package/src/components/SearchField/SearchField.props.ts +0 -35
  242. package/src/components/SearchField/SearchField.tsx +0 -83
  243. package/src/components/SearchField/index.ts +0 -1
  244. package/src/components/SocialMedia/SocialMedia.args.ts +0 -54
  245. package/src/components/SocialMedia/SocialMedia.props.ts +0 -45
  246. package/src/components/SocialMedia/SocialMedia.tsx +0 -46
  247. package/src/components/SocialMedia/index.ts +0 -3
  248. package/src/components/TableOfContents/TableOfContents.args.ts +0 -35
  249. package/src/components/TableOfContents/TableOfContents.props.ts +0 -23
  250. package/src/components/TableOfContents/TableOfContents.tsx +0 -32
  251. package/src/components/TableOfContents/index.ts +0 -1
  252. package/src/components/Tabs/Tabs.args.tsx +0 -201
  253. package/src/components/Tabs/Tabs.props.ts +0 -13
  254. package/src/components/Tabs/Tabs.tsx +0 -60
  255. package/src/components/Tabs/index.ts +0 -1
  256. package/src/components/Tag/Tag.args.ts +0 -15
  257. package/src/components/Tag/Tag.props.ts +0 -34
  258. package/src/components/Tag/Tag.tsx +0 -104
  259. package/src/components/Tag/TagCtx.ts +0 -4
  260. package/src/components/Tag/TagSet.args.ts +0 -37
  261. package/src/components/Tag/TagSet.props.ts +0 -37
  262. package/src/components/Tag/TagSet.tsx +0 -61
  263. package/src/components/Tag/index.ts +0 -2
  264. package/src/components/TextInput/TextInput.args.ts +0 -75
  265. package/src/components/TextInput/TextInput.props.ts +0 -20
  266. package/src/components/TextInput/TextInput.tsx +0 -71
  267. package/src/components/TextInput/index.ts +0 -2
  268. package/src/components/Textarea/Textarea.args.ts +0 -34
  269. package/src/components/Textarea/Textarea.props.ts +0 -45
  270. package/src/components/Textarea/Textarea.tsx +0 -52
  271. package/src/components/Textarea/index.ts +0 -3
  272. package/src/components/Toggle/Toggle.args.ts +0 -62
  273. package/src/components/Toggle/Toggle.props.ts +0 -27
  274. package/src/components/Toggle/Toggle.tsx +0 -85
  275. package/src/components/Toggle/index.ts +0 -3
  276. package/src/components/Tooltip/Tooltip.args.ts +0 -39
  277. package/src/components/Tooltip/Tooltip.props.ts +0 -38
  278. package/src/components/Tooltip/Tooltip.tsx +0 -119
  279. package/src/components/Tooltip/index.ts +0 -1
  280. package/src/components/Video/Video.args.ts +0 -47
  281. package/src/components/Video/Video.props.ts +0 -35
  282. package/src/components/Video/Video.tsx +0 -34
  283. package/src/components/Video/VideoPlayer.props.ts +0 -51
  284. package/src/components/Video/VideoPlayer.tsx +0 -71
  285. package/src/components/Video/index.ts +0 -1
  286. package/src/components/Video/media-file-poster.jpg +0 -0
  287. package/src/components/index.ts +0 -46
  288. package/src/declarations.d.ts +0 -36
  289. package/src/hooks/index.ts +0 -2
  290. package/src/hooks/useGlobalSettings.ts +0 -13
  291. package/src/hooks/usePrevious.ts +0 -15
  292. package/src/hooks/useVideoPlayer.ts +0 -85
  293. package/src/index.ts +0 -1
  294. package/src/setup.ts +0 -6
  295. package/src/stories/Accordion/Accordion.stories.tsx +0 -145
  296. package/src/stories/Breadcrumb/Breadcrumb.mdx +0 -17
  297. package/src/stories/Breadcrumb/Breadcrumb.stories.tsx +0 -20
  298. package/src/stories/Button/Button.mdx +0 -94
  299. package/src/stories/Button/Button.stories.tsx +0 -68
  300. package/src/stories/Callout/Callout.mdx +0 -35
  301. package/src/stories/Callout/Callout.stories.tsx +0 -43
  302. package/src/stories/Card/DataCard.stories.tsx +0 -45
  303. package/src/stories/Card/DetailCard.stories.tsx +0 -41
  304. package/src/stories/Card/FactlistCard.stories.tsx +0 -48
  305. package/src/stories/Card/FeatureCard.stories.tsx +0 -56
  306. package/src/stories/Card/MultilinkCard.stories.tsx +0 -48
  307. package/src/stories/Card/PromoCard.stories.tsx +0 -48
  308. package/src/stories/Card/StatCard.stories.tsx +0 -45
  309. package/src/stories/Card/TextCard.stories.tsx +0 -45
  310. package/src/stories/CardGroup/CardGroup.mdx +0 -17
  311. package/src/stories/CardGroup/CardGroup.stories.tsx +0 -50
  312. package/src/stories/Checkbox/Checkbox.stories.tsx +0 -118
  313. package/src/stories/ContextMenu/ContextMenu.stories.tsx +0 -83
  314. package/src/stories/DatePicker/DatePicker.stories.tsx +0 -110
  315. package/src/stories/Dropdown/Dropdown.stories.tsx +0 -145
  316. package/src/stories/Empty/Empty.stories.tsx +0 -53
  317. package/src/stories/Fieldset/Fieldset.stories.tsx +0 -167
  318. package/src/stories/FileUpload/FileUpload.stories.tsx +0 -103
  319. package/src/stories/Footer/Footer.mdx +0 -17
  320. package/src/stories/Footer/Footer.stories.tsx +0 -15
  321. package/src/stories/Form/Form.mdx +0 -58
  322. package/src/stories/Form/Form.stories.tsx +0 -162
  323. package/src/stories/GetStarted.mdx +0 -57
  324. package/src/stories/Heading/Heading.stories.tsx +0 -193
  325. package/src/stories/Hero/Hero.stories.tsx +0 -68
  326. package/src/stories/Image/Image.stories.tsx +0 -50
  327. package/src/stories/Link/Link.stories.tsx +0 -81
  328. package/src/stories/LinkList/LinkList.args.ts +0 -190
  329. package/src/stories/LinkList/LinkList.stories.tsx +0 -60
  330. package/src/stories/List/List.stories.tsx +0 -167
  331. package/src/stories/Loading/Loading.stories.tsx +0 -97
  332. package/src/stories/LocalNav/LocalNav.mdx +0 -17
  333. package/src/stories/LocalNav/LocalNav.stories.tsx +0 -15
  334. package/src/stories/Logo/Logo.stories.tsx +0 -172
  335. package/src/stories/LogoGrid/LogoGrid.stories.tsx +0 -59
  336. package/src/stories/Navigation/Navigation.mdx +0 -17
  337. package/src/stories/Navigation/Navigation.stories.tsx +0 -15
  338. package/src/stories/Notification/Notification.stories.tsx +0 -187
  339. package/src/stories/NumberPicker/NumberPicker.stories.tsx +0 -69
  340. package/src/stories/Pagination/Pagination.stories.tsx +0 -86
  341. package/src/stories/Profile/Profile.stories.tsx +0 -64
  342. package/src/stories/Radio/Radio.stories.tsx +0 -232
  343. package/src/stories/ReadMore/ReadMore.stories.tsx +0 -59
  344. package/src/stories/RichText/RichText.stories.tsx +0 -63
  345. package/src/stories/SearchField/SearchField.stories.tsx +0 -91
  346. package/src/stories/SocialMedia/SocialMedia.stories.tsx +0 -60
  347. package/src/stories/TableOfContents/TableOfContents.stories.tsx +0 -55
  348. package/src/stories/Tabs/Tabs.mdx +0 -17
  349. package/src/stories/Tabs/Tabs.stories.tsx +0 -25
  350. package/src/stories/Tag/Tag.stories.tsx +0 -130
  351. package/src/stories/TextInput/TextInput.stories.tsx +0 -100
  352. package/src/stories/Textarea/Textarea.stories.tsx +0 -147
  353. package/src/stories/Toggle/Toggle.stories.tsx +0 -99
  354. package/src/stories/Tooltip/Tooltip.stories.tsx +0 -82
  355. package/src/stories/Video/Video.stories.tsx +0 -71
  356. package/src/stories/Welcome.stories.mdx +0 -37
  357. package/src/stories/assets/code-brackets.svg +0 -1
  358. package/src/stories/assets/colors.svg +0 -1
  359. package/src/stories/assets/comments.svg +0 -1
  360. package/src/stories/assets/direction.svg +0 -1
  361. package/src/stories/assets/flow.svg +0 -1
  362. package/src/stories/assets/plugin.svg +0 -1
  363. package/src/stories/assets/repo.svg +0 -1
  364. package/src/stories/assets/stackalt.svg +0 -1
  365. package/src/stories/welcome.scss +0 -133
  366. package/src/types/forms.args.ts +0 -288
  367. package/src/types/index.ts +0 -137
  368. package/src/types/temp.d.ts +0 -9
  369. package/src/utils/checkArrayDuplicates.ts +0 -3
  370. package/src/utils/createChainedFunction.ts +0 -31
  371. package/src/utils/getDefaultDimensionValue.ts +0 -28
  372. package/src/utils/hoursMinutesSeconds.ts +0 -8
  373. package/src/utils/index.ts +0 -6
  374. package/src/utils/transitionEndListener.ts +0 -29
  375. package/src/utils/triggerBrowserReflow.ts +0 -4
  376. package/tsconfig.build.json +0 -19
  377. package/tsconfig.json +0 -8
@@ -1,247 +0,0 @@
1
- import React, { useEffect, useLayoutEffect, useRef, useState } from "react";
2
- import { useGlobalSettings } from "../../hooks";
3
- import { InnerLogoProps, LogoProps } from "./Logo.props";
4
- import classnames from "classnames";
5
-
6
- const isOverflown = ({
7
- clientHeight,
8
- clientWidth,
9
- scrollHeight,
10
- scrollWidth,
11
- }: HTMLElement) => scrollHeight > clientHeight || scrollWidth > clientWidth;
12
-
13
- const getFullFontSize = (
14
- container: HTMLElement,
15
- { maxSize = 600, startingHeight = 9, step = 0.5 }
16
- ) => {
17
- let i = startingHeight;
18
- let overflow = false;
19
-
20
- while (!overflow && i < maxSize) {
21
- container.style.fontSize = `${i}px`;
22
- container.style.lineHeight = `${i}px`;
23
-
24
- overflow = isOverflown(container);
25
- if (!overflow) {
26
- i = i + step;
27
- }
28
- }
29
-
30
- // Reset styles to the way they were
31
- container.style.fontSize = "";
32
- container.style.lineHeight = "";
33
-
34
- // Return the ideal font size
35
- return i - step;
36
- };
37
-
38
- const BaseLogo: React.FC<InnerLogoProps> = ({
39
- baseClass,
40
- className,
41
- subbrand,
42
- alt,
43
- src,
44
- style: userStyles,
45
- size = "fluid",
46
- theme = "light",
47
- ...props
48
- }) => {
49
- // The logo image element
50
- const imageRef = useRef<HTMLImageElement>(null);
51
-
52
- // The lockup container
53
- const lockupRef = useRef<HTMLDivElement>(null);
54
-
55
- // The lockup text
56
- const lockupTextRef = useRef<HTMLSpanElement>(null);
57
-
58
- // Initial height of the image when it's loaded
59
- const initialImageHeight = useRef<null | number>(null);
60
-
61
- // Has the image loaded or not
62
- const [imageLoaded, setImageLoaded] = useState(false);
63
-
64
- // Dynamic height of the image
65
- const [imageHeight, setImageHeight] = useState(0);
66
-
67
- // Ratio of the font size to the height of the logo image
68
- const [fontSizeRatio, setfontSizeRatio] = useState<number>(0);
69
-
70
- // Is the logo visible? Default to true if not a subbrand
71
- const [isLogoVisible, setIsLogoVisible] = useState(!subbrand);
72
-
73
- // Resize observer gets the initial height of the image when
74
- // it loads and updates the height when it changes in state
75
- const observer = useRef(
76
- new ResizeObserver((entries) => {
77
- const { height } = entries[0].contentRect;
78
- if (!initialImageHeight.current) {
79
- initialImageHeight.current = height;
80
- }
81
- setImageHeight(height);
82
- })
83
- );
84
-
85
- // Make the logo visible for subrand when everything is ready
86
- useEffect(() => {
87
- if (subbrand && imageLoaded && fontSizeRatio) {
88
- setIsLogoVisible(true);
89
- }
90
- }, [imageLoaded, fontSizeRatio, subbrand]);
91
-
92
- // Set up the Resize observer to watch the image
93
- useLayoutEffect(() => {
94
- if (imageLoaded && lockupRef.current && imageRef.current) {
95
- const imageEl = imageRef.current;
96
- observer.current.observe(imageEl);
97
- return () => observer.current.unobserve(imageEl);
98
- }
99
- }, [imageLoaded]);
100
-
101
- // Gets the font size necessary for the lockup text to fill the
102
- // the lockup container as much as possible without overflowing.
103
- // Then gets the ratio of full font size to image height which will
104
- // be used to calculate the font size if the image gets resized
105
- useLayoutEffect(() => {
106
- setFontSize();
107
- }, [imageLoaded, initialImageHeight.current]);
108
-
109
- // Adjust the font size if for some weird reason the subbrand changes
110
- // This is mostly just to illustrate how the component works on Storybook
111
- useLayoutEffect(() => {
112
- setFontSize();
113
- }, [subbrand]);
114
-
115
- function setFontSize() {
116
- if (
117
- lockupRef.current &&
118
- lockupTextRef.current &&
119
- initialImageHeight.current
120
- ) {
121
- const fullFontSize = getFullFontSize(lockupRef.current, {
122
- maxSize: initialImageHeight.current,
123
- });
124
- const ratio = fullFontSize / initialImageHeight.current;
125
- setfontSizeRatio(ratio);
126
- }
127
- }
128
-
129
- // Has the image loaded or not
130
- function handleImageLoaded() {
131
- setImageLoaded(true);
132
- }
133
-
134
- // Conditions for different CSS classes
135
- const hasSubbrand = !!subbrand;
136
- const hasFluidWidth = size === "fluid";
137
- const hasFixedWidth = !hasFluidWidth && typeof size === "number";
138
-
139
- // Classes for the outer figure container
140
- const subBrandClass = `${baseClass}--sub-brand`;
141
- const fluidWidthClass = `${baseClass}--size--fluid`;
142
- const visibilityHidden = `${baseClass}--visibility--hidden`;
143
-
144
- // Outer figure classes
145
- const classNames = classnames(
146
- baseClass,
147
- className,
148
- `${baseClass}--theme--${theme}`,
149
- {
150
- [visibilityHidden]: !isLogoVisible,
151
- [fluidWidthClass]: hasFluidWidth,
152
- [subBrandClass]: hasSubbrand,
153
- }
154
- );
155
-
156
- // Classes for the image element
157
- const noSubBrandImageClass = `${baseClass}--image`;
158
- const subBrandImageClass = `${subBrandClass}--image`;
159
-
160
- // Set inline CSS including variables on the outer figure element
161
- const getStyle = (): React.CSSProperties => {
162
- const conditionalStyles: any = {};
163
- // Add CSS vars if this is a sub-brand
164
- if (hasSubbrand) {
165
- conditionalStyles["--logo-image-height"] = `${imageHeight}px`;
166
- conditionalStyles["--logo-font-size"] = `${
167
- fontSizeRatio * imageHeight
168
- }px`;
169
- }
170
- // Add fixed width if it has fixed width
171
- if (hasFixedWidth) {
172
- conditionalStyles.width = `${size}px`;
173
- }
174
- // User styles may be overriden
175
- return { userStyles, ...conditionalStyles };
176
- };
177
-
178
- const getImageSrc = () => {
179
- if (typeof src === "string") {
180
- return src;
181
- }
182
- return src[theme];
183
- };
184
-
185
- return (
186
- <figure className={classNames} style={getStyle()}>
187
- <img
188
- ref={imageRef}
189
- alt={alt}
190
- src={getImageSrc()}
191
- className={classnames({
192
- [subBrandImageClass]: hasSubbrand,
193
- [noSubBrandImageClass]: !hasSubbrand,
194
- })}
195
- onLoad={handleImageLoaded}
196
- {...props}
197
- />
198
- {hasSubbrand && (
199
- <div ref={lockupRef} className={`${subBrandClass}--lock-up`}>
200
- <span className={`${subBrandClass}--lock-up--separator`} />
201
- <span ref={lockupTextRef}>{subbrand}</span>
202
- </div>
203
- )}
204
- </figure>
205
- );
206
- };
207
-
208
- const Logo: React.FC<LogoProps> = ({
209
- className,
210
- url,
211
- target,
212
- style,
213
- size,
214
- ...props
215
- }) => {
216
- const { prefix } = useGlobalSettings();
217
- const baseClass = `${prefix}--logo`;
218
- const linkClass = `${baseClass}--link`;
219
- const fluidClass = `${baseClass}--size--fluid`;
220
-
221
- if (url) {
222
- return (
223
- <a
224
- href={url}
225
- target={target}
226
- className={classnames(linkClass, className, {
227
- [fluidClass]: size === "fluid",
228
- })}
229
- style={style}
230
- >
231
- <BaseLogo {...props} baseClass={baseClass} size={size} />
232
- </a>
233
- );
234
- }
235
-
236
- return (
237
- <BaseLogo
238
- baseClass={baseClass}
239
- className={className}
240
- style={style}
241
- size={size}
242
- {...props}
243
- />
244
- );
245
- };
246
-
247
- export default Logo;
@@ -1 +0,0 @@
1
- export { default as Logo } from "./Logo";
@@ -1,50 +0,0 @@
1
- import { LogoGridProps } from "./LogoGrid.props";
2
- import { logo_en_horizontal_blue_svg } from "@ilo-org/brand-assets";
3
-
4
- export const defaultLogoGrid: LogoGridProps = {
5
- logos: [
6
- {
7
- label: "International Labour Organization",
8
- src: logo_en_horizontal_blue_svg,
9
- url: "https://www.ilo.org/",
10
- },
11
- {
12
- label: "Food and Agriculture Organization",
13
- src: "/fao-logo.svg",
14
- url: "https://www.fao.org",
15
- },
16
- {
17
- label: "World Health Organization",
18
- src: "/who-logo.svg",
19
- url: "https://www.who.int/",
20
- },
21
- {
22
- label: "World Food Programme",
23
- src: "/wfp-logo.svg",
24
- url: "https://www.wfp.org/",
25
- },
26
-
27
- {
28
- label: "UNICEF",
29
- src: "/unicef-logo.png",
30
- url: "https://www.unicef.org/",
31
- },
32
- {
33
- label: "UN Refugees",
34
- src: "/unhcr-logo.svg",
35
- url: "https://www.unhcr.org/",
36
- },
37
- ],
38
- };
39
-
40
- export const darkLogoGrid: LogoGridProps = {
41
- ...defaultLogoGrid,
42
- theme: "dark",
43
- };
44
-
45
- export const noLinksGrid: LogoGridProps = {
46
- logos: defaultLogoGrid.logos.map(({ label, src }) => ({
47
- label,
48
- src,
49
- })),
50
- };
@@ -1,28 +0,0 @@
1
- export interface LogoGridItemProps {
2
- /**
3
- * The label of the logo
4
- */
5
- label: string;
6
-
7
- /**
8
- * The image src of the logo
9
- */
10
- src: string | URL;
11
-
12
- /**
13
- * The link of the logo
14
- */
15
- url?: string;
16
- }
17
-
18
- export interface LogoGridProps {
19
- /**
20
- * The logos to display
21
- */
22
- logos: LogoGridItemProps[];
23
-
24
- /**
25
- * The theme of the logo grid
26
- */
27
- theme?: "dark" | "light";
28
- }
@@ -1,53 +0,0 @@
1
- import React from "react";
2
- import classnames from "classnames";
3
- import { useGlobalSettings } from "../../hooks";
4
- import { LogoGridProps, LogoGridItemProps } from "./LogoGrid.props";
5
-
6
- const LogoGridItem: React.FC<LogoGridItemProps> = ({ url, label, src }) => {
7
- const { prefix } = useGlobalSettings();
8
-
9
- const itemClass = `${prefix}--logo-grid--item`;
10
- const itemLinkClass = `${prefix}--logo-grid--link`;
11
-
12
- const gridItemClass = classnames(itemClass, {
13
- [itemLinkClass]: !!url,
14
- });
15
-
16
- if (!url) {
17
- return (
18
- <div className={gridItemClass}>
19
- <img alt={label} src={src as string} />
20
- </div>
21
- );
22
- }
23
- return (
24
- <a
25
- className={gridItemClass}
26
- href={url}
27
- target="_blank"
28
- rel="noopener noreferrer"
29
- >
30
- <img alt={label} src={src as string} />
31
- </a>
32
- );
33
- };
34
-
35
- const LogoGrid: React.FC<LogoGridProps> = ({ logos, theme = "light" }) => {
36
- const { prefix } = useGlobalSettings();
37
-
38
- const baseClass = `${prefix}--logo-grid`;
39
- const themeClass = `${baseClass}__theme__${theme}`;
40
- const logoGridClass = classnames(baseClass, themeClass);
41
-
42
- return (
43
- <div className={logoGridClass}>
44
- <div className={`${baseClass}--logos`}>
45
- {logos.map((logo) => (
46
- <LogoGridItem {...logo} />
47
- ))}
48
- </div>
49
- </div>
50
- );
51
- };
52
-
53
- export default LogoGrid;
@@ -1 +0,0 @@
1
- export { default as LogoGrid } from "./LogoGrid";
@@ -1,113 +0,0 @@
1
- import { NavigationProps } from "./Navigation.props";
2
- import ilo_logo_white from "@ilo-org/brand-assets/logo_en_horizontal_white.svg";
3
- import ilo_logo_blue from "@ilo-org/brand-assets/logo_en_horizontal_blue.svg";
4
-
5
- const basic: NavigationProps = {
6
- logo: ilo_logo_white,
7
- mobilelogo: ilo_logo_blue,
8
- siteurl: "https://www.ilo.org/",
9
- tagline: {
10
- tag: "Advancing social justice, promoting decent work",
11
- small: "ILO is a specialized agency of the United Nations",
12
- },
13
- primarynav: {
14
- navlabel: "Primary Navigation",
15
- mobilecloselabel: "Close",
16
- items: [
17
- {
18
- label: "Topics",
19
- url: "https://www.ilo.org",
20
- },
21
- {
22
- label: "Countries",
23
- url: "https://www.ilo.org",
24
- },
25
- {
26
- label: "Standards",
27
- url: "https://www.ilo.org",
28
- },
29
- {
30
- label: "Statistics",
31
- url: "https://www.ilo.org",
32
- },
33
- {
34
- label: "About",
35
- url: "https://www.ilo.org",
36
- },
37
- ],
38
- },
39
- subnav: {
40
- navlabel: "Secondary Navigation",
41
- buttonlabel: "More",
42
- mobilecloselabel: "Close",
43
- mobilebacklabel: "Menu Home",
44
- items: [
45
- {
46
- label: "News",
47
- url: "https://www.ilo.org",
48
- },
49
- {
50
- label: "Meeting & Events",
51
- url: "https://www.ilo.org",
52
- },
53
- {
54
- label: "Publications",
55
- url: "https://www.ilo.org",
56
- },
57
- {
58
- label: "Projects",
59
- url: "https://www.ilo.org",
60
- },
61
- {
62
- label: "Partners",
63
- url: "https://www.ilo.org",
64
- },
65
- {
66
- label: "Industries & Sectors",
67
- url: "https://www.ilo.org",
68
- },
69
- {
70
- label: "About the ILO",
71
- url: "https://www.ilo.org",
72
- },
73
- ],
74
- },
75
- languagelabel: "English",
76
- menulabel: "Menu",
77
- menucloselabel: "Close",
78
- languagecontextmenu: {
79
- links: [
80
- {
81
- label: "Français",
82
- url: "https://www.ilo.org",
83
- },
84
- {
85
- label: "Español",
86
- url: "https://www.ilo.org",
87
- },
88
- {
89
- label: "中文",
90
- url: "https://www.ilo.org",
91
- },
92
- {
93
- label: "Русский",
94
- url: "https://www.ilo.org",
95
- },
96
- ],
97
- },
98
- searchlabel: "Search",
99
- searchfield: {
100
- action: "https://www.ilo.org",
101
- input: {
102
- label: "",
103
- helper: "",
104
- name: "text",
105
- placeholder: "Search Field",
106
- type: "text",
107
- },
108
- },
109
- };
110
-
111
- const NavigationArgs = { basic };
112
-
113
- export default NavigationArgs;
@@ -1,120 +0,0 @@
1
- import { LinkProps, ContextMenuProps } from "../ContextMenu/ContextMenu.props";
2
- import { SearchFieldProps } from "../SearchField/SearchField.props";
3
-
4
- export interface NavigationProps {
5
- /**
6
- * Props for the logo of the Navigation
7
- */
8
- logo?: Required<string>;
9
-
10
- /**
11
- * Props for the mobile logo of the Navigation
12
- */
13
- mobilelogo?: Required<string>;
14
-
15
- /**
16
- * Props for the home url of the Navigation
17
- */
18
- siteurl?: Required<string>;
19
-
20
- /**
21
- * Specify the tagline for the Navigation
22
- */
23
- tagline?: Required<TaglineProps>;
24
-
25
- /**
26
- * Specify the primary items for the Navigation
27
- */
28
- primarynav?: Required<PrimaryNavProps>;
29
-
30
- /**
31
- * Specify the secondary items for the Navigation
32
- */
33
- subnav?: Required<SubNavProps>;
34
-
35
- /**
36
- * Specify the tagline for the Navigation
37
- */
38
- searchlabel?: string;
39
-
40
- /**
41
- * Specify the searchfield props for the Navigation
42
- */
43
- searchfield?: SearchFieldProps;
44
-
45
- /**
46
- * Specify the menu label for the Navigation
47
- */
48
- menulabel?: string;
49
-
50
- /**
51
- * Specify the menu close label for the Navigation
52
- */
53
- menucloselabel?: string;
54
-
55
- /**
56
- * Specify the language label for the Navigation
57
- */
58
- languagelabel?: string;
59
-
60
- /**
61
- * Specify the language context menu for the Navigation
62
- */
63
- languagecontextmenu?: ContextMenuProps;
64
- }
65
-
66
- interface PrimaryNavProps {
67
- /**
68
- * Specify the label for Navigation
69
- */
70
- navlabel?: Required<string>;
71
-
72
- /**
73
- * Specify the close label for mobile Navigation
74
- */
75
- mobilecloselabel?: Required<string>;
76
-
77
- /**
78
- * Specify the links
79
- */
80
- items?: Required<Array<LinkProps>>;
81
- }
82
-
83
- interface SubNavProps {
84
- /**
85
- * Specify the label for sub Navigation
86
- */
87
- navlabel?: Required<string>;
88
-
89
- /**
90
- * Specify the button label for sub Navigation
91
- */
92
- buttonlabel?: Required<string>;
93
-
94
- /**
95
- * Specify the close label for mobile sub Navigation
96
- */
97
- mobilecloselabel?: Required<string>;
98
-
99
- /**
100
- * Specify the back label for mobile sub Navigation
101
- */
102
- mobilebacklabel?: Required<string>;
103
-
104
- /**
105
- * Specify the subnav links
106
- */
107
- items?: Required<Array<LinkProps>>;
108
- }
109
-
110
- interface TaglineProps {
111
- /**
112
- * Specify the main tagline text
113
- */
114
- tag?: Required<string>;
115
-
116
- /**
117
- * Specify the small tagline text
118
- */
119
- small?: Required<string>;
120
- }