@spaced-out/ui-design-system 0.3.38 → 0.3.39

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 (307) hide show
  1. package/.cspell/custom-words.txt +4 -0
  2. package/.github/workflows/publish_to_npm.yml +32 -4
  3. package/CHANGELOG.md +21 -0
  4. package/dts-generator/.editorconfig +10 -0
  5. package/dts-generator/.gitattributes +4 -0
  6. package/dts-generator/README.md +63 -0
  7. package/dts-generator/convert.js +101 -0
  8. package/dts-generator/package.json +16 -0
  9. package/gulpfile.js +20 -1
  10. package/lib/components/Avatar/Avatar.d.ts +264 -0
  11. package/lib/components/Avatar/index.d.ts +1 -0
  12. package/lib/components/AvatarGroup/AvatarGroup.d.ts +161 -0
  13. package/lib/components/AvatarGroup/index.d.ts +1 -0
  14. package/lib/components/Badge/Badge.d.ts +138 -0
  15. package/lib/components/Badge/index.d.ts +1 -0
  16. package/lib/components/Banner/Banner.d.ts +52 -0
  17. package/lib/components/Banner/index.d.ts +1 -0
  18. package/lib/components/Breadcrumbs/BreadcrumbLink/BreadcrumbLink.d.ts +50 -0
  19. package/lib/components/Breadcrumbs/BreadcrumbLink/index.d.ts +1 -0
  20. package/lib/components/Breadcrumbs/Breadcrumbs.d.ts +64 -0
  21. package/lib/components/Breadcrumbs/index.d.ts +2 -0
  22. package/lib/components/Button/Button.d.ts +288 -0
  23. package/lib/components/Button/index.d.ts +14 -0
  24. package/lib/components/ButtonDropdown/ButtonDropdown.d.ts +192 -0
  25. package/lib/components/ButtonDropdown/SimpleButtonDropdown.d.ts +148 -0
  26. package/lib/components/ButtonDropdown/index.d.ts +2 -0
  27. package/lib/components/ButtonTabs/ButtonTab/ButtonTab.d.ts +82 -0
  28. package/lib/components/ButtonTabs/ButtonTab/index.d.ts +1 -0
  29. package/lib/components/ButtonTabs/ButtonTabDropdown.d.ts +118 -0
  30. package/lib/components/ButtonTabs/ButtonTabs.d.ts +113 -0
  31. package/lib/components/ButtonTabs/index.d.ts +2 -0
  32. package/lib/components/Card/Card.d.ts +163 -0
  33. package/lib/components/Card/index.d.ts +1 -0
  34. package/lib/components/Charts/ChartTooltip/index.d.ts +10 -0
  35. package/lib/components/Charts/ChartWrapper/ChartWrapper.d.ts +184 -0
  36. package/lib/components/Charts/ChartWrapper/index.d.ts +1 -0
  37. package/lib/components/Charts/ColumnChart/ColumnChart.d.ts +111 -0
  38. package/lib/components/Charts/ColumnChart/index.d.ts +1 -0
  39. package/lib/components/Charts/DonutChart/DonutChart.d.ts +142 -0
  40. package/lib/components/Charts/DonutChart/index.d.ts +1 -0
  41. package/lib/components/Charts/FunnelChart/FunnelChart.d.ts +99 -0
  42. package/lib/components/Charts/FunnelChart/index.d.ts +1 -0
  43. package/lib/components/Charts/LineChart/LineChart.d.ts +97 -0
  44. package/lib/components/Charts/LineChart/index.d.ts +1 -0
  45. package/lib/components/Charts/SpiderChart/SpiderChart.d.ts +95 -0
  46. package/lib/components/Charts/SpiderChart/index.d.ts +1 -0
  47. package/lib/components/Charts/index.d.ts +7 -0
  48. package/lib/components/ChatBubble/ChatBubble.d.ts +203 -0
  49. package/lib/components/ChatBubble/index.d.ts +1 -0
  50. package/lib/components/Checkbox/Checkbox.d.ts +165 -0
  51. package/lib/components/Checkbox/CheckboxGroup.d.ts +113 -0
  52. package/lib/components/Checkbox/index.d.ts +2 -0
  53. package/lib/components/Chip/Chip.d.ts +181 -0
  54. package/lib/components/Chip/index.d.ts +2 -0
  55. package/lib/components/CircularLoader/CircularLoader.d.ts +56 -0
  56. package/lib/components/CircularLoader/index.d.ts +1 -0
  57. package/lib/components/CollapsibleCard/CollapsibleCard.d.ts +134 -0
  58. package/lib/components/CollapsibleCard/index.d.ts +1 -0
  59. package/lib/components/Combobox/Combobox.d.ts +292 -0
  60. package/lib/components/Combobox/helper.d.ts +205 -0
  61. package/lib/components/Combobox/index.d.ts +1 -0
  62. package/lib/components/ConditionalWrapper/ConditionalWrapper.d.ts +12 -0
  63. package/lib/components/ConditionalWrapper/index.d.ts +1 -0
  64. package/lib/components/DateRangePicker/Calendar.d.ts +119 -0
  65. package/lib/components/DateRangePicker/DateRangePicker.d.ts +196 -0
  66. package/lib/components/DateRangePicker/DateRangeWrapper.d.ts +311 -0
  67. package/lib/components/DateRangePicker/Day.d.ts +70 -0
  68. package/lib/components/DateRangePicker/index.d.ts +1 -0
  69. package/lib/components/Dialog/Dialog.d.ts +208 -0
  70. package/lib/components/Dialog/index.d.ts +1 -0
  71. package/lib/components/Disclaimer/Disclaimer.d.ts +32 -0
  72. package/lib/components/Disclaimer/index.d.ts +1 -0
  73. package/lib/components/Dropdown/Dropdown.d.ts +145 -0
  74. package/lib/components/Dropdown/SimpleDropdown.d.ts +142 -0
  75. package/lib/components/Dropdown/index.d.ts +2 -0
  76. package/lib/components/EmptyState/EmptyImages/CalendarEmptyImage.d.ts +108 -0
  77. package/lib/components/EmptyState/EmptyImages/ChartEmptyImage.d.ts +194 -0
  78. package/lib/components/EmptyState/EmptyImages/DataEmptyImage.d.ts +116 -0
  79. package/lib/components/EmptyState/EmptyImages/FileEmptyImage.d.ts +133 -0
  80. package/lib/components/EmptyState/EmptyImages/MessageEmptyImage.d.ts +64 -0
  81. package/lib/components/EmptyState/EmptyImages/UploadEmptyImage.d.ts +67 -0
  82. package/lib/components/EmptyState/EmptyImages/index.d.ts +6 -0
  83. package/lib/components/EmptyState/EmptyState.d.ts +82 -0
  84. package/lib/components/EmptyState/index.d.ts +1 -0
  85. package/lib/components/ErrorMessage/ErrorImages/ForbiddenImage.d.ts +85 -0
  86. package/lib/components/ErrorMessage/ErrorImages/NotFoundImage.d.ts +117 -0
  87. package/lib/components/ErrorMessage/ErrorImages/ServerErrorImage.d.ts +237 -0
  88. package/lib/components/ErrorMessage/ErrorImages/UnauthorizedImage.d.ts +73 -0
  89. package/lib/components/ErrorMessage/ErrorImages/index.d.ts +4 -0
  90. package/lib/components/ErrorMessage/ErrorMessage.d.ts +86 -0
  91. package/lib/components/ErrorMessage/index.d.ts +1 -0
  92. package/lib/components/FileUpload/FileBlock/FileBlock.d.ts +137 -0
  93. package/lib/components/FileUpload/FileBlock/index.d.ts +1 -0
  94. package/lib/components/FileUpload/FileUpload.d.ts +190 -0
  95. package/lib/components/FileUpload/index.d.ts +2 -0
  96. package/lib/components/FocusManager/FocusManager.d.ts +52 -0
  97. package/lib/components/FocusManager/index.d.ts +1 -0
  98. package/lib/components/FocusManagerWithArrowKeyNavigation/FocusManagerWithArrowKeyNavigation.d.ts +137 -0
  99. package/lib/components/FocusManagerWithArrowKeyNavigation/index.d.ts +1 -0
  100. package/lib/components/FormTitleWrapper/FormTitleWrapper.d.ts +62 -0
  101. package/lib/components/FormTitleWrapper/index.d.ts +1 -0
  102. package/lib/components/Grid/Grid.d.ts +104 -0
  103. package/lib/components/Grid/index.d.ts +1 -0
  104. package/lib/components/Icon/ClickableIcon.d.ts +101 -0
  105. package/lib/components/Icon/Icon.d.ts +71 -0
  106. package/lib/components/Icon/Icon.docs.d.ts +138 -0
  107. package/lib/components/Icon/SemanticIcon.d.ts +42 -0
  108. package/lib/components/Icon/index.d.ts +3 -0
  109. package/lib/components/InContextAlert/InContextAlert.d.ts +210 -0
  110. package/lib/components/InContextAlert/index.d.ts +1 -0
  111. package/lib/components/InlineDropdown/InlineDropdown.d.ts +146 -0
  112. package/lib/components/InlineDropdown/SimpleInlineDropdown.d.ts +145 -0
  113. package/lib/components/InlineDropdown/index.d.ts +2 -0
  114. package/lib/components/Input/Input.d.ts +327 -0
  115. package/lib/components/Input/index.d.ts +1 -0
  116. package/lib/components/KPIBox/KPIBox.d.ts +89 -0
  117. package/lib/components/KPIBox/index.d.ts +1 -0
  118. package/lib/components/LinearLoader/LinearLoader.d.ts +44 -0
  119. package/lib/components/LinearLoader/index.d.ts +1 -0
  120. package/lib/components/Link/Link.d.ts +225 -0
  121. package/lib/components/Link/index.d.ts +1 -0
  122. package/lib/components/Menu/Menu.d.ts +379 -0
  123. package/lib/components/Menu/MenuOptionButton.d.ts +199 -0
  124. package/lib/components/Menu/index.d.ts +2 -0
  125. package/lib/components/Modal/Modal.d.ts +354 -0
  126. package/lib/components/Modal/index.d.ts +14 -0
  127. package/lib/components/Notification/Notification.d.ts +147 -0
  128. package/lib/components/Notification/index.d.ts +1 -0
  129. package/lib/components/OptionButton/OptionButton.d.ts +150 -0
  130. package/lib/components/OptionButton/SimpleOptionButton.d.ts +150 -0
  131. package/lib/components/OptionButton/index.d.ts +2 -0
  132. package/lib/components/PageTitle/PageTitle.d.ts +256 -0
  133. package/lib/components/PageTitle/index.d.ts +1 -0
  134. package/lib/components/Pagination/Pagination.d.ts +144 -0
  135. package/lib/components/Pagination/PaginationItem.d.ts +136 -0
  136. package/lib/components/Pagination/index.d.ts +1 -0
  137. package/lib/components/Panel/Panel.d.ts +168 -0
  138. package/lib/components/Panel/index.d.ts +9 -0
  139. package/lib/components/ProgressDonut/ProgressDonut.d.ts +102 -0
  140. package/lib/components/ProgressDonut/index.d.ts +1 -0
  141. package/lib/components/PromptChip/PromptChip.d.ts +167 -0
  142. package/lib/components/PromptChip/index.d.ts +1 -0
  143. package/lib/components/PromptInput/PromptInput.d.ts +189 -0
  144. package/lib/components/PromptInput/index.d.ts +1 -0
  145. package/lib/components/RadioButton/RadioButton.d.ts +132 -0
  146. package/lib/components/RadioButton/RadioGroup.d.ts +88 -0
  147. package/lib/components/RadioButton/index.d.ts +2 -0
  148. package/lib/components/RadioTile/RadioTile.d.ts +109 -0
  149. package/lib/components/RadioTile/index.d.ts +1 -0
  150. package/lib/components/RangeSlider/RangeSlider.d.ts +207 -0
  151. package/lib/components/RangeSlider/index.d.ts +1 -0
  152. package/lib/components/Rating/Rating.d.ts +131 -0
  153. package/lib/components/Rating/index.d.ts +1 -0
  154. package/lib/components/ScoreBar/ScoreBar.d.ts +122 -0
  155. package/lib/components/ScoreBar/index.d.ts +1 -0
  156. package/lib/components/SearchInput/SearchInput.d.ts +79 -0
  157. package/lib/components/SearchInput/index.d.ts +2 -0
  158. package/lib/components/Separator/Separator.d.ts +51 -0
  159. package/lib/components/Separator/index.d.ts +1 -0
  160. package/lib/components/Shimmer/Shimmer.d.ts +131 -0
  161. package/lib/components/Shimmer/index.d.ts +1 -0
  162. package/lib/components/SideMenuLink/SideMenuLink.d.ts +336 -0
  163. package/lib/components/SideMenuLink/index.d.ts +1 -0
  164. package/lib/components/StatusIndicator/StatusIndicator.d.ts +60 -0
  165. package/lib/components/StatusIndicator/index.d.ts +1 -0
  166. package/lib/components/Stepper/Step/Step.d.ts +119 -0
  167. package/lib/components/Stepper/Step/StepContent.d.ts +35 -0
  168. package/lib/components/Stepper/Step/StepLabel.d.ts +35 -0
  169. package/lib/components/Stepper/Step/index.d.ts +3 -0
  170. package/lib/components/Stepper/Stepper.d.ts +60 -0
  171. package/lib/components/Stepper/index.d.ts +2 -0
  172. package/lib/components/StickyBar/StickyBar.d.ts +55 -0
  173. package/lib/components/StickyBar/index.d.ts +1 -0
  174. package/lib/components/SubMenu/SubMenu.d.ts +89 -0
  175. package/lib/components/SubMenu/SubMenuGroup.d.ts +156 -0
  176. package/lib/components/SubMenu/SubMenuItem.d.ts +161 -0
  177. package/lib/components/SubMenu/SubMenuLink.d.ts +81 -0
  178. package/lib/components/SubMenu/index.d.ts +4 -0
  179. package/lib/components/Table/Cell.d.ts +107 -0
  180. package/lib/components/Table/DefaultRow.d.ts +144 -0
  181. package/lib/components/Table/DefaultTableHeader.d.ts +236 -0
  182. package/lib/components/Table/StaticTable.d.ts +198 -0
  183. package/lib/components/Table/Table.d.ts +113 -0
  184. package/lib/components/Table/Table.docs.d.ts +532 -0
  185. package/lib/components/Table/TableActionBar.d.ts +48 -0
  186. package/lib/components/Table/TableBottomBar.d.ts +20 -0
  187. package/lib/components/Table/TableTopBar.d.ts +20 -0
  188. package/lib/components/Table/dummyTableData.d.ts +2189 -0
  189. package/lib/components/Table/hooks.d.ts +98 -0
  190. package/lib/components/Table/index.d.ts +8 -0
  191. package/lib/components/Tabs/Tab/Tab.d.ts +146 -0
  192. package/lib/components/Tabs/Tab/index.d.ts +1 -0
  193. package/lib/components/Tabs/TabList/TabDropdown.d.ts +100 -0
  194. package/lib/components/Tabs/TabList/TabList.d.ts +157 -0
  195. package/lib/components/Tabs/TabList/index.d.ts +1 -0
  196. package/lib/components/Tabs/index.d.ts +2 -0
  197. package/lib/components/Text/Text.d.ts +1021 -0
  198. package/lib/components/Text/index.d.ts +30 -0
  199. package/lib/components/TextTile/TextTile.d.ts +40 -0
  200. package/lib/components/TextTile/index.d.ts +1 -0
  201. package/lib/components/Textarea/Textarea.d.ts +132 -0
  202. package/lib/components/Textarea/index.d.ts +2 -0
  203. package/lib/components/Timeline/Timeline.d.ts +40 -0
  204. package/lib/components/Timeline/TimelineItem/TimelineItem.d.ts +121 -0
  205. package/lib/components/Timeline/TimelineItem/index.d.ts +1 -0
  206. package/lib/components/Timeline/index.d.ts +2 -0
  207. package/lib/components/Toast/Toast.d.ts +248 -0
  208. package/lib/components/Toast/ToastContainer.d.ts +140 -0
  209. package/lib/components/Toast/ToastManager.d.ts +58 -0
  210. package/lib/components/Toast/index.d.ts +10 -0
  211. package/lib/components/Toggle/Toggle.d.ts +111 -0
  212. package/lib/components/Toggle/index.d.ts +1 -0
  213. package/lib/components/TokenListInput/TokenListInput.d.ts +333 -0
  214. package/lib/components/TokenListInput/TokenValueChips.d.ts +64 -0
  215. package/lib/components/TokenListInput/index.d.ts +1 -0
  216. package/lib/components/Tooltip/Tooltip.d.ts +186 -0
  217. package/lib/components/Tooltip/index.d.ts +1 -0
  218. package/lib/components/Truncate/Truncate.d.ts +87 -0
  219. package/lib/components/Truncate/index.d.ts +2 -0
  220. package/lib/components/TruncatedTextWithTooltip/TruncatedTextWithTooltip.d.ts +95 -0
  221. package/lib/components/TruncatedTextWithTooltip/index.d.ts +1 -0
  222. package/lib/components/Typeahead/SimpleTypeahead.d.ts +141 -0
  223. package/lib/components/Typeahead/Typeahead.d.ts +217 -0
  224. package/lib/components/Typeahead/index.d.ts +2 -0
  225. package/lib/components/WeekdayPicker/WeekdayPicker.d.ts +242 -0
  226. package/lib/components/WeekdayPicker/index.d.ts +1 -0
  227. package/lib/components/index.d.ts +71 -0
  228. package/lib/hooks/index.d.ts +12 -0
  229. package/lib/hooks/useArbitraryOptionAddition/index.d.ts +1 -0
  230. package/lib/hooks/useArbitraryOptionAddition/useArbitraryOptionAddition.d.ts +124 -0
  231. package/lib/hooks/useCopyToClipboard/index.d.ts +1 -0
  232. package/lib/hooks/useCopyToClipboard/useCopyToClipboard.d.ts +27 -0
  233. package/lib/hooks/useFileUpload/index.d.ts +1 -0
  234. package/lib/hooks/useFileUpload/useFileUpload.d.ts +342 -0
  235. package/lib/hooks/useFilteredOptions/index.d.ts +1 -0
  236. package/lib/hooks/useFilteredOptions/useFilteredOptions.d.ts +87 -0
  237. package/lib/hooks/useInputState/index.d.ts +1 -0
  238. package/lib/hooks/useInputState/useInputState.d.ts +22 -0
  239. package/lib/hooks/useLockedBody/index.d.ts +1 -0
  240. package/lib/hooks/useLockedBody/useLockedBody.d.ts +46 -0
  241. package/lib/hooks/useModal/index.d.ts +1 -0
  242. package/lib/hooks/useModal/useModal.d.ts +32 -0
  243. package/lib/hooks/useMountTransition/index.d.ts +24 -0
  244. package/lib/hooks/usePagination/index.d.ts +1 -0
  245. package/lib/hooks/usePagination/usePagination.d.ts +140 -0
  246. package/lib/hooks/useToastPortal/index.d.ts +1 -0
  247. package/lib/hooks/useToastPortal/useToastPortal.d.ts +31 -0
  248. package/lib/hooks/useToggle/index.d.ts +1 -0
  249. package/lib/hooks/useToggle/useToggle.d.ts +11 -0
  250. package/lib/hooks/useWindowSize/index.d.ts +1 -0
  251. package/lib/hooks/useWindowSize/useWindowSize.d.ts +28 -0
  252. package/lib/index.d.ts +5 -0
  253. package/lib/styles/index.d.ts +267 -0
  254. package/lib/styles/variables/_border.d.ts +12 -0
  255. package/lib/styles/variables/_color.d.ts +104 -0
  256. package/lib/styles/variables/_elevation.d.ts +7 -0
  257. package/lib/styles/variables/_font.d.ts +30 -0
  258. package/lib/styles/variables/_motion.d.ts +6 -0
  259. package/lib/styles/variables/_opacity.d.ts +15 -0
  260. package/lib/styles/variables/_shadow.d.ts +24 -0
  261. package/lib/styles/variables/_size.d.ts +57 -0
  262. package/lib/styles/variables/_space.d.ts +12 -0
  263. package/lib/types/charts.d.ts +225 -0
  264. package/lib/types/common.d.ts +10 -0
  265. package/lib/types/date-range-picker.d.ts +17 -0
  266. package/lib/types/date-range-picker.js.flow +2 -3
  267. package/lib/types/index.d.ts +6 -0
  268. package/lib/types/menu.d.ts +13 -0
  269. package/lib/types/toast.d.ts +32 -0
  270. package/lib/types/typography.d.ts +17 -0
  271. package/lib/utils/array/are-arrays-equal.d.ts +11 -0
  272. package/lib/utils/array/index.d.ts +1 -0
  273. package/lib/utils/charts/charts.d.ts +102 -0
  274. package/lib/utils/charts/columnChart.d.ts +51 -0
  275. package/lib/utils/charts/donutChart.d.ts +116 -0
  276. package/lib/utils/charts/funnelChart.d.ts +94 -0
  277. package/lib/utils/charts/helpers.d.ts +44 -0
  278. package/lib/utils/charts/index.d.ts +7 -0
  279. package/lib/utils/charts/lineChart.d.ts +44 -0
  280. package/lib/utils/charts/spiderChart.d.ts +46 -0
  281. package/lib/utils/charts/typography.d.ts +42 -0
  282. package/lib/utils/classify/index.d.ts +27 -0
  283. package/lib/utils/click-away/click-away.d.ts +194 -0
  284. package/lib/utils/click-away/index.d.ts +1 -0
  285. package/lib/utils/date-range-picker/date-range-picker.d.ts +391 -0
  286. package/lib/utils/date-range-picker/index.d.ts +2 -0
  287. package/lib/utils/date-range-picker/timezones.d.ts +262 -0
  288. package/lib/utils/dom/dom.d.ts +245 -0
  289. package/lib/utils/dom/index.d.ts +1 -0
  290. package/lib/utils/helpers/helpers.d.ts +48 -0
  291. package/lib/utils/helpers/index.d.ts +1 -0
  292. package/lib/utils/index.d.ts +14 -0
  293. package/lib/utils/makeClassNameComponent/index.d.ts +1 -0
  294. package/lib/utils/makeClassNameComponent/makeClassNameComponent.d.ts +73 -0
  295. package/lib/utils/menu/index.d.ts +1 -0
  296. package/lib/utils/merge-refs/index.d.ts +1 -0
  297. package/lib/utils/merge-refs/merge-refs.d.ts +15 -0
  298. package/lib/utils/rating/index.d.ts +1 -0
  299. package/lib/utils/rating/rating.d.ts +31 -0
  300. package/lib/utils/score-bar/index.d.ts +1 -0
  301. package/lib/utils/score-bar/score-bar.d.ts +54 -0
  302. package/lib/utils/string/index.d.ts +1 -0
  303. package/lib/utils/string/string.d.ts +30 -0
  304. package/lib/utils/token-list-input/token-list-input.d.ts +32 -0
  305. package/lib/utils/tokens/index.d.ts +1 -0
  306. package/lib/utils/tokens/tokens.d.ts +230 -0
  307. package/package.json +1 -1
@@ -0,0 +1,30 @@
1
+ export {TEXT_COLORS} from '../../types/typography';
2
+ export type {TextProps} from './Text';
3
+ export {
4
+ BodyLarge,
5
+ BodyLargeBold,
6
+ BodyMedium,
7
+ BodyMediumBold,
8
+ BodySmall,
9
+ BodySmallBold,
10
+ ButtonTextExtraSmall,
11
+ ButtonTextExtraSmallUnderline,
12
+ ButtonTextMedium,
13
+ ButtonTextMediumUnderline,
14
+ ButtonTextSmall,
15
+ ButtonTextSmallUnderline,
16
+ FormInputMedium,
17
+ FormInputSmall,
18
+ FormLabelMedium,
19
+ FormLabelSmall,
20
+ JumboLarge,
21
+ JumboMedium,
22
+ JumboSmall,
23
+ MenuTextMedium,
24
+ MenuTextSmall,
25
+ SubTitleExtraSmall,
26
+ SubTitleLarge,
27
+ SubTitleMedium,
28
+ SubTitleSmall,
29
+ TitleMedium,
30
+ } from './Text';
@@ -0,0 +1,40 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ import classify from '../../utils/classify';
4
+ import {Icon, ICON_SIZE, ICON_TYPE} from '../Icon';
5
+ import {BodyLarge, JumboMedium} from '../Text';
6
+ import css from './TextTile.module.css';
7
+ type ClassNames = $ReadOnly<{
8
+ wrapper?: string;
9
+ title?: string;
10
+ }>;
11
+ export type TextTileProps = {
12
+ header?: string;
13
+ iconName?: string;
14
+ classNames?: ClassNames;
15
+ description?: string;
16
+ };
17
+ export const TextTile: React$AbstractComponent<TextTileProps, HTMLDivElement> =
18
+ React.forwardRef<TextTileProps, HTMLDivElement>(
19
+ (
20
+ {header, iconName = 'sparkles', classNames, description}: TextTileProps,
21
+ ref,
22
+ ) => (
23
+ <div
24
+ ref={ref}
25
+ data-testid="TextTile"
26
+ className={classify(css.textTileWrapper, classNames?.wrapper)}
27
+ >
28
+ <div className={classify(css.textTileTitle, classNames?.title)}>
29
+ <Icon
30
+ size={ICON_SIZE.large}
31
+ name={iconName}
32
+ type={ICON_TYPE.solid}
33
+ className={css.sparkles}
34
+ />
35
+ <JumboMedium>{header}</JumboMedium>
36
+ </div>
37
+ <BodyLarge>{description}</BodyLarge>
38
+ </div>
39
+ ),
40
+ );
@@ -0,0 +1 @@
1
+ export * from './TextTile';
@@ -0,0 +1,132 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ import {classify} from '../../utils/classify';
4
+ import {BodySmall, FormLabelSmall} from '../Text';
5
+ import css from './Textarea.module.css';
6
+ type ClassNames = $ReadOnly<{
7
+ box?: string;
8
+ textarea?: string;
9
+ }>;
10
+ export type TextareaProps = {
11
+ value?: string;
12
+ onChange?: (
13
+ evt: React.SyntheticEvent<HTMLInputElement>,
14
+ isEnter?: boolean,
15
+ ) => unknown;
16
+ onFocus?: (e: React.SyntheticEvent<HTMLInputElement>) => unknown;
17
+ onBlur?: (e: React.SyntheticEvent<HTMLInputElement>) => unknown;
18
+ onKeyDown?: (e: React.KeyboardEvent<HTMLInputElement>) => unknown;
19
+ name?: string;
20
+ disabled?: boolean;
21
+ placeholder?: string;
22
+ locked?: boolean;
23
+ error?: boolean;
24
+ errorText?: string;
25
+ label?: string | React.ReactNode;
26
+ helperText?: string | React.ReactNode;
27
+ classNames?: ClassNames;
28
+ size?: 'medium' | 'small';
29
+ required?: boolean;
30
+ textCountLimit?: number;
31
+ };
32
+
33
+ const Textarea_ = (props: TextareaProps, ref): React.ReactNode => {
34
+ const {
35
+ value,
36
+ onChange,
37
+ onFocus,
38
+ onBlur,
39
+ name,
40
+ disabled,
41
+ placeholder,
42
+ error,
43
+ locked,
44
+ errorText,
45
+ label,
46
+ helperText,
47
+ classNames,
48
+ size = 'medium',
49
+ required,
50
+ textCountLimit,
51
+ ...textareaProps
52
+ } = props;
53
+ const [textCountError, setTextCountError] = React.useState(false);
54
+ React.useEffect(() => {
55
+ if (textCountLimit) {
56
+ if (value && value.length > textCountLimit) {
57
+ setTextCountError(true);
58
+ } else {
59
+ setTextCountError(false);
60
+ }
61
+ }
62
+ }, [value]);
63
+ const controlledTextareaFilled = value !== '';
64
+ return (
65
+ <div
66
+ className={classify(css.wrapper, {
67
+ [css.filled]: controlledTextareaFilled ?? false,
68
+ [css.withError]: (error || textCountError) ?? false,
69
+ })}
70
+ >
71
+ {Boolean(label) && (
72
+ <div className={css.info}>
73
+ <div className={css.infoContent}>
74
+ <FormLabelSmall color="secondary">{label ?? ''}</FormLabelSmall>
75
+ &nbsp;
76
+ {required && <FormLabelSmall color="danger">{'*'}</FormLabelSmall>}
77
+ </div>
78
+ <FormLabelSmall
79
+ color={error || textCountError ? 'danger' : 'secondary'}
80
+ >
81
+ {!!textCountLimit &&
82
+ ((value && value.length) || 0) + '/' + textCountLimit}
83
+ </FormLabelSmall>
84
+ </div>
85
+ )}
86
+ <div
87
+ className={classify(
88
+ css.box,
89
+ {
90
+ [css.inputDisabled]: disabled ?? false,
91
+ [css.medium]: size === 'medium',
92
+ [css.small]: size === 'small',
93
+ [css.locked]: locked,
94
+ },
95
+ classNames?.box,
96
+ )}
97
+ >
98
+ <textarea
99
+ {...textareaProps}
100
+ disabled={locked || disabled}
101
+ name={name}
102
+ ref={ref}
103
+ placeholder={placeholder}
104
+ value={value}
105
+ onChange={onChange}
106
+ onFocus={onFocus}
107
+ onBlur={onBlur}
108
+ className={classNames?.textarea}
109
+ ></textarea>
110
+ </div>
111
+ {(Boolean(helperText) || error) && (
112
+ <div className={css.info}>
113
+ <BodySmall
114
+ color={
115
+ error && errorText
116
+ ? 'danger'
117
+ : disabled
118
+ ? 'disabled'
119
+ : 'secondary'
120
+ }
121
+ >
122
+ {error && errorText ? errorText : helperText ?? ''}
123
+ </BodySmall>
124
+ </div>
125
+ )}
126
+ </div>
127
+ );
128
+ };
129
+
130
+ export const Textarea = React.forwardRef<TextareaProps, HTMLTextAreaElement>(
131
+ Textarea_,
132
+ ) as React$AbstractComponent<TextareaProps, HTMLTextAreaElement>;
@@ -0,0 +1,2 @@
1
+ export type {TextareaProps} from './Textarea';
2
+ export {Textarea} from './Textarea';
@@ -0,0 +1,40 @@
1
+ import {$ReadOnly, $Values} from 'utility-types';
2
+ import * as React from 'react';
3
+ import {classify} from '../../utils/classify';
4
+ import css from './Timeline.module.css';
5
+ export const ORIENTATION = Object.freeze({
6
+ left: 'left',
7
+ right: 'right',
8
+ });
9
+ type ClassNames = $ReadOnly<{
10
+ wrapper?: string;
11
+ }>;
12
+ export type Orientation = $Values<typeof ORIENTATION>;
13
+ export type TimelineProps = {
14
+ children: React.ReactNode;
15
+ classNames?: ClassNames;
16
+ orientation?: Orientation;
17
+ };
18
+
19
+ const Timeline_ = (
20
+ {classNames, orientation = ORIENTATION.left, children}: TimelineProps,
21
+ ref,
22
+ ): React.ReactNode => {
23
+ const childrenArray = React.Children.toArray(children).filter(Boolean);
24
+ const timelineItems = childrenArray.map((timelineItem) =>
25
+ React.cloneElement(timelineItem, {...timelineItem.props, orientation}),
26
+ );
27
+ return (
28
+ <div
29
+ ref={ref}
30
+ className={classify(css.timelineWrapper, classNames?.wrapper)}
31
+ data-testid="Timeline"
32
+ >
33
+ {timelineItems}
34
+ </div>
35
+ );
36
+ };
37
+
38
+ export const Timeline = React.forwardRef<TimelineProps, HTMLDivElement>(
39
+ Timeline_,
40
+ ) as React$AbstractComponent<TimelineProps, HTMLDivElement>;
@@ -0,0 +1,121 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ import type {ColorTypes} from '../../../types/typography';
4
+ import {TEXT_COLORS} from '../../../types/typography';
5
+ import {classify} from '../../../utils/classify';
6
+ import {Card, PADDING_SIZES} from '../../Card';
7
+ import {ConditionalWrapper} from '../../ConditionalWrapper';
8
+ import type {IconType} from '../../Icon';
9
+ import {Icon, ICON_SIZE, ICON_TYPE} from '../../Icon';
10
+ import type {Orientation} from '../Timeline';
11
+ import {ORIENTATION} from '../Timeline';
12
+ import css from '../Timeline.module.css';
13
+ type ClassNames = $ReadOnly<{
14
+ card?: string;
15
+ icon?: string;
16
+ title?: string;
17
+ wrapper?: string;
18
+ description?: string;
19
+ }>;
20
+ export type TimelineItemProps = {
21
+ id?: string;
22
+ title?: React.ReactNode;
23
+ iconName: string;
24
+ children: React.ReactNode;
25
+ iconType?: IconType;
26
+ iconColor?: ColorTypes;
27
+ classNames?: ClassNames;
28
+ description?: React.ReactNode;
29
+ orientation?: Orientation;
30
+ parentComponent?: React.ReactNode;
31
+ enableCardWrapper?: boolean;
32
+ };
33
+
34
+ const TimelineItem_ = (
35
+ {
36
+ id,
37
+ title,
38
+ iconName,
39
+ iconType = ICON_TYPE.solid,
40
+ children,
41
+ iconColor = TEXT_COLORS.information,
42
+ classNames,
43
+ description,
44
+ orientation = ORIENTATION.left,
45
+ parentComponent,
46
+ enableCardWrapper = true,
47
+ }: TimelineItemProps,
48
+ ref,
49
+ ): React.ReactNode => (
50
+ <div
51
+ id={id}
52
+ key={id}
53
+ data-testid="Timeline-item"
54
+ className={classify(css.timelineItemWrapper, classNames?.wrapper)}
55
+ style={{
56
+ '--align': orientation === 'left' ? 'flex-start' : 'flex-end',
57
+ }}
58
+ ref={ref}
59
+ >
60
+ {parentComponent}
61
+ <div
62
+ style={{
63
+ '--direction': orientation === 'left' ? 'row' : 'row-reverse',
64
+ }}
65
+ className={css.timelineItemContent}
66
+ >
67
+ <div className={css.timelineItemIconWrapper}>
68
+ <Icon
69
+ name={iconName}
70
+ type={iconType}
71
+ size={ICON_SIZE.small}
72
+ color={iconColor}
73
+ className={classify(css.timelineItemIcon, classNames?.icon)}
74
+ />
75
+ <div className={css.timelineItemBorder}>
76
+ <div className={css.border} />
77
+ </div>
78
+ </div>
79
+ <div className={css.timelineItemEventDetails}>
80
+ <div className={css.timelineItemInfo}>
81
+ <div className={classify(css.timelineItemTitle, classNames?.title)}>
82
+ {title}
83
+ </div>
84
+ {description ? (
85
+ <div
86
+ className={classify(
87
+ css.timelineItemDescription,
88
+ classNames?.description,
89
+ )}
90
+ >
91
+ {description}
92
+ </div>
93
+ ) : null}
94
+ </div>
95
+ <ConditionalWrapper
96
+ condition={enableCardWrapper}
97
+ wrapper={(children) => (
98
+ <Card
99
+ paddingTop={PADDING_SIZES.small}
100
+ paddingBottom={PADDING_SIZES.small}
101
+ classNames={{
102
+ wrapper: classify(
103
+ css.timelineItemCardWrapper,
104
+ classNames?.card,
105
+ ),
106
+ }}
107
+ >
108
+ {children}
109
+ </Card>
110
+ )}
111
+ >
112
+ {children}
113
+ </ConditionalWrapper>
114
+ </div>
115
+ </div>
116
+ </div>
117
+ );
118
+
119
+ export const TimelineItem = React.forwardRef<TimelineItemProps, HTMLDivElement>(
120
+ TimelineItem_,
121
+ ) as React$AbstractComponent<TimelineItemProps, HTMLDivElement>;
@@ -0,0 +1 @@
1
+ export * from './TimelineItem';
@@ -0,0 +1,2 @@
1
+ export * from './Timeline';
2
+ export * from './TimelineItem';
@@ -0,0 +1,248 @@
1
+ import {$ReadOnly, $Values} from 'utility-types';
2
+ import * as React from 'react';
3
+ import {
4
+ // $FlowFixMe[untyped-import]
5
+ FloatingFocusManager, // $FlowFixMe[untyped-import]
6
+ useFloating,
7
+ } from '@floating-ui/react';
8
+ import classify from '../../utils/classify';
9
+ import {CloseIcon, Icon} from '../Icon';
10
+ import {SubTitleExtraSmall, TEXT_COLORS} from '../Text';
11
+ import typography from '../../styles/typography.module.css';
12
+ import css from './Toast.module.css';
13
+ type ClassNames = $ReadOnly<{
14
+ wrapper?: string;
15
+ time?: string;
16
+ }>;
17
+ export const TOAST_SEMANTIC = Object.freeze({
18
+ success: 'success',
19
+ information: 'information',
20
+ warning: 'warning',
21
+ danger: 'danger',
22
+ primary: 'primary',
23
+ });
24
+ export type ToastSemanticType = $Values<typeof TOAST_SEMANTIC>;
25
+ export type ToastProps = {
26
+ classNames?: ClassNames;
27
+ children?: React.ReactNode;
28
+ time?: string;
29
+ semantic?: ToastSemanticType;
30
+ onClose?: () => void;
31
+ initialFocus?: number;
32
+ customIcon?: React.ReactNode;
33
+ hideCloseIcon?: boolean;
34
+ };
35
+
36
+ const ToastIcon = ({semantic}: {semantic: ToastSemanticType}) => {
37
+ switch (semantic) {
38
+ case 'success':
39
+ return (
40
+ <Icon
41
+ name="circle-check"
42
+ size="medium"
43
+ color={TEXT_COLORS.success}
44
+ type="solid"
45
+ />
46
+ );
47
+
48
+ case TOAST_SEMANTIC.information:
49
+ return (
50
+ <Icon
51
+ name="circle-info"
52
+ size="medium"
53
+ color={TEXT_COLORS.information}
54
+ type="solid"
55
+ />
56
+ );
57
+
58
+ case TOAST_SEMANTIC.warning:
59
+ return (
60
+ <Icon
61
+ name="circle-exclamation"
62
+ size="medium"
63
+ color={TEXT_COLORS.warning}
64
+ type="solid"
65
+ />
66
+ );
67
+
68
+ case TOAST_SEMANTIC.danger:
69
+ return (
70
+ <Icon
71
+ name="shield-exclamation"
72
+ size="medium"
73
+ color={TEXT_COLORS.danger}
74
+ type="solid"
75
+ />
76
+ );
77
+
78
+ default:
79
+ return (
80
+ <Icon
81
+ color={TEXT_COLORS.neutral}
82
+ name="face-smile"
83
+ size="medium"
84
+ type="solid"
85
+ />
86
+ );
87
+ }
88
+ };
89
+
90
+ export type ToastTitleProps = {
91
+ children?: React.ReactNode;
92
+ className?: string;
93
+ semantic?: ToastSemanticType;
94
+ };
95
+ export const ToastTitle: React$AbstractComponent<
96
+ ToastTitleProps,
97
+ HTMLDivElement
98
+ > = React.forwardRef<ToastTitleProps, HTMLDivElement>(
99
+ (
100
+ {children, semantic = '', className, ...props}: ToastTitleProps,
101
+ ref,
102
+ ): React.ReactNode => (
103
+ <div
104
+ className={classify(css.toastTitle, typography[semantic], className)}
105
+ {...props}
106
+ ref={ref}
107
+ >
108
+ {children}
109
+ </div>
110
+ ),
111
+ );
112
+ ToastTitle.displayName = 'ToastTitle';
113
+ export type ToastBodyProps = {
114
+ children?: React.ReactNode;
115
+ className?: string;
116
+ };
117
+ export const ToastBody: React$AbstractComponent<
118
+ ToastBodyProps,
119
+ HTMLDivElement
120
+ > = React.forwardRef<ToastBodyProps, HTMLDivElement>(
121
+ ({children, className, ...props}: ToastBodyProps, ref): React.ReactNode => (
122
+ <div className={classify(css.toastBody, className)} {...props} ref={ref}>
123
+ {children}
124
+ </div>
125
+ ),
126
+ );
127
+ ToastBody.displayName = 'ToastBody';
128
+ export type ToastFooterProps = {
129
+ children?: React.ReactNode;
130
+ onClose?: () => void;
131
+ };
132
+ export const ToastFooter = ({
133
+ children,
134
+ onClose,
135
+ }: ToastFooterProps): React.ReactNode => {
136
+ const arrayChildren = React.Children.toArray(children);
137
+ const footerActions = React.Children.map(children, (child, index) => {
138
+ const isLast = index === arrayChildren.length - 1;
139
+
140
+ if (React.isValidElement(child)) {
141
+ const {onClick} = child.props;
142
+
143
+ const buttonClickHandler = (e) => {
144
+ onClose && onClose();
145
+ onClick && onClick(e);
146
+ };
147
+
148
+ if (child?.type?.displayName === 'Button' && isLast) {
149
+ return React.cloneElement(child, {
150
+ size: 'small',
151
+ type: 'primary',
152
+ ...child.props,
153
+ onClick: buttonClickHandler,
154
+ });
155
+ } else if (child?.type?.displayName === 'Button') {
156
+ return React.cloneElement(child, {
157
+ size: 'small',
158
+ type: 'tertiary',
159
+ ...child.props,
160
+ onClick: buttonClickHandler,
161
+ });
162
+ }
163
+ }
164
+
165
+ return child;
166
+ });
167
+ return React.Children.count(children) > 0 ? (
168
+ <div className={css.toastFooterActions}>{footerActions}</div>
169
+ ) : null;
170
+ };
171
+ ToastFooter.displayName = 'ToastFooter';
172
+ export const Toast = ({
173
+ classNames,
174
+ children,
175
+ time,
176
+ semantic = TOAST_SEMANTIC.success,
177
+ onClose,
178
+ initialFocus = -1,
179
+ customIcon,
180
+ hideCloseIcon,
181
+ }: ToastProps): React.ReactNode => {
182
+ const {refs, context} = useFloating({
183
+ open: true,
184
+ });
185
+
186
+ const getComp = (comp: string) => {
187
+ const childrenArray = React.Children.toArray(children);
188
+
189
+ if (childrenArray.length) {
190
+ const nodes: React.ReactNode[] = [];
191
+
192
+ for (const child of childrenArray) {
193
+ if (child?.type?.displayName === comp) {
194
+ nodes.push(
195
+ React.cloneElement(child, {
196
+ semantic,
197
+ }),
198
+ );
199
+ }
200
+ }
201
+
202
+ return nodes.length > 1 ? nodes : nodes[0];
203
+ }
204
+
205
+ return null;
206
+ };
207
+
208
+ const footer = getComp('ToastFooter');
209
+ // $FlowFixMe
210
+ const footerWithClose = footer
211
+ ? React.cloneElement(footer, {
212
+ onClose,
213
+ })
214
+ : null;
215
+ return (
216
+ <FloatingFocusManager context={context} initialFocus={initialFocus}>
217
+ <div
218
+ className={classify(css.toastContainer, classNames?.wrapper)}
219
+ ref={refs.setFloating}
220
+ >
221
+ {customIcon || <ToastIcon semantic={semantic} />}
222
+ <div className={css.toastMidSection}>
223
+ <div className={css.contentWrap}>
224
+ <div className={css.titleBodyWrap}>
225
+ {getComp('ToastTitle')}
226
+ {getComp('ToastBody')}
227
+ </div>
228
+ {time && (
229
+ <SubTitleExtraSmall className={classNames?.time}>
230
+ {time}
231
+ </SubTitleExtraSmall>
232
+ )}
233
+ </div>
234
+ {footerWithClose}
235
+ </div>
236
+ {!hideCloseIcon && (
237
+ <CloseIcon
238
+ classNames={{
239
+ button: css.closeIcon,
240
+ }}
241
+ onClick={onClose}
242
+ ariaLabel="Close Button"
243
+ />
244
+ )}
245
+ </div>
246
+ </FloatingFocusManager>
247
+ );
248
+ };