@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 @@
1
+ export * from './KPIBox';
@@ -0,0 +1,44 @@
1
+ import * as React from 'react';
2
+ import {classify} from '../../utils/classify';
3
+ import css from './LinearLoader.module.css';
4
+ export type LinearLoaderProps = {
5
+ value: number;
6
+ size?: 'large' | 'medium' | 'small';
7
+ className?: string;
8
+ indeterminate?: boolean;
9
+ };
10
+ export const LinearLoader: React$AbstractComponent<
11
+ LinearLoaderProps,
12
+ HTMLDivElement
13
+ > = React.forwardRef<LinearLoaderProps, HTMLDivElement>(
14
+ (
15
+ {value, size = 'medium', className, indeterminate}: LinearLoaderProps,
16
+ ref,
17
+ ): React.ReactNode => (
18
+ <div
19
+ className={classify(
20
+ css.lineContainer,
21
+ {
22
+ [css.large]: size === 'large',
23
+ [css.medium]: size === 'medium',
24
+ [css.small]: size === 'small',
25
+ },
26
+ className,
27
+ )}
28
+ ref={ref}
29
+ >
30
+ <div
31
+ className={classify(css.progressBar, {
32
+ [css.indeterminate]: indeterminate,
33
+ })}
34
+ style={{
35
+ width: `${value + '%'}`,
36
+ }}
37
+ role="progressbar"
38
+ aria-valuenow={indeterminate ? undefined : value}
39
+ aria-valuemin="0"
40
+ aria-valuemax="100"
41
+ ></div>
42
+ </div>
43
+ ),
44
+ );
@@ -0,0 +1 @@
1
+ export {LinearLoader} from './LinearLoader';
@@ -0,0 +1,225 @@
1
+ import {$Values} 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 {ConditionalWrapper} from '../ConditionalWrapper';
7
+ import type {IconSize, IconType} from '../Icon';
8
+ import {Icon, ICON_SIZE} from '../Icon';
9
+ import css from '../../styles/typography.module.css';
10
+ export const LINK_AS = Object.freeze({
11
+ bodyLarge: 'bodyLarge',
12
+ bodyMedium: 'bodyMedium',
13
+ bodySmall: 'bodySmall',
14
+ buttonTextExtraSmall: 'buttonTextExtraSmall',
15
+ buttonTextMedium: 'buttonTextMedium',
16
+ buttonTextSmall: 'buttonTextSmall',
17
+ formInputMedium: 'formInputMedium',
18
+ formInputSmall: 'formInputSmall',
19
+ formLabelMedium: 'formLabelMedium',
20
+ formLabelSmall: 'formLabelSmall',
21
+ jumboMedium: 'jumboMedium',
22
+ subTitleExtraSmall: 'subTitleExtraSmall',
23
+ subTitleLarge: 'subTitleLarge',
24
+ subTitleMedium: 'subTitleMedium',
25
+ subTitleSmall: 'subTitleSmall',
26
+ titleMedium: 'titleMedium',
27
+ });
28
+ export type LinkAs = $Values<typeof LINK_AS>;
29
+ export const ANCHOR_REL = Object.freeze({
30
+ alternate: 'alternate',
31
+ author: 'author',
32
+ bookmark: 'bookmark',
33
+ external: 'external',
34
+ help: 'help',
35
+ license: 'license',
36
+ next: 'next',
37
+ nofollow: 'nofollow',
38
+ noopener: 'noopener',
39
+ noreferrer: 'noreferrer',
40
+ search: 'search',
41
+ tag: 'tag',
42
+ });
43
+ export type AnchorRel = $Values<typeof ANCHOR_REL>;
44
+ export const ANCHOR_TARGET = Object.freeze({
45
+ _blank: '_blank',
46
+ _self: '_self',
47
+ _parent: '_parent',
48
+ _top: '_top',
49
+ framename: 'framename',
50
+ });
51
+ export type AnchorTarget = $Values<typeof ANCHOR_TARGET>;
52
+ export type BaseLinkProps = {
53
+ children: React.ReactNode;
54
+ onClick?:
55
+ | ((arg0: React.SyntheticEvent<HTMLElement>) => unknown)
56
+ | null
57
+ | undefined;
58
+ tabIndex?: number;
59
+ disabled?: boolean;
60
+ className?: string;
61
+ as?: LinkAs;
62
+ rel?: AnchorRel;
63
+ target?: AnchorTarget;
64
+ iconLeftName?: string;
65
+ iconLeftSize?: IconSize;
66
+ iconLeftType?: IconType;
67
+ iconRightName?: string;
68
+ iconRightSize?: IconSize;
69
+ iconRightType?: IconType;
70
+
71
+ /**
72
+ * IMPORTANT: If you are using `to` make sure to provide link component from your router
73
+ * if you want to prevent full page reloads in a Single Page Application (SPA).
74
+ *
75
+ * Using `href` in anchor tags causes the browser to navigate to a new URL,
76
+ * resulting in a full page reload. However, in a Single Page Application (SPA), we aim to provide a seamless
77
+ * user experience without such reloads.
78
+ *
79
+ * To achieve client-side navigation and prevent page reloads, use client-side routing libraries
80
+ * (e.g., React Router) and their navigation components (e.g., <Link> or <a> with an onClick handler)
81
+ * to handle navigation within your SPA. These components work without triggering full page reloads
82
+ * and maintain the SPA's performance and user experience.
83
+ *
84
+ */
85
+ to?: string;
86
+ href?: string;
87
+ };
88
+ export type LinkProps = BaseLinkProps & {
89
+ color?: ColorTypes;
90
+ underline?: boolean;
91
+
92
+ /**
93
+ * Provide your router's link component
94
+ *
95
+ * import {Link} from 'src/rerouter';
96
+ * import {Link as GenesisLink} from '@spaced-out/ui-design-system/lib/components/Link';
97
+ *
98
+ * <GenesisLink linkComponent={Link} to="/pages" />
99
+ */
100
+ linkComponent?: React.AbstractComponent<
101
+ BaseLinkProps,
102
+ HTMLAnchorElement | null | undefined
103
+ >;
104
+ };
105
+ export const Link: React$AbstractComponent<
106
+ LinkProps,
107
+ HTMLAnchorElement | null | undefined
108
+ > = React.forwardRef<LinkProps, HTMLAnchorElement | null | undefined>(
109
+ (
110
+ {
111
+ color = TEXT_COLORS.clickable,
112
+ children,
113
+ className,
114
+ as = 'buttonTextExtraSmall',
115
+ underline = true,
116
+ tabIndex = 0,
117
+ disabled,
118
+ onClick,
119
+ linkComponent: LinkComponent = DefaultLink,
120
+ iconLeftName,
121
+ iconLeftSize = ICON_SIZE.small,
122
+ iconLeftType,
123
+ iconRightName,
124
+ iconRightSize = ICON_SIZE.small,
125
+ iconRightType,
126
+ ...props
127
+ }: LinkProps,
128
+ ref,
129
+ ) => {
130
+ const linkRef = React.useRef(null);
131
+ React.useImperativeHandle(ref, () => linkRef.current);
132
+ React.useEffect(() => {
133
+ if (disabled) {
134
+ linkRef.current?.blur();
135
+ }
136
+ }, [disabled]);
137
+
138
+ const handleClick = (event: React.SyntheticEvent<HTMLElement>) => {
139
+ if (disabled) {
140
+ event.preventDefault();
141
+ return;
142
+ }
143
+
144
+ onClick?.(event);
145
+ };
146
+
147
+ /**
148
+ * By spec anchor tag wont call onClick on enter key press when the element is focussed
149
+ * as a workaround we would need to listen to key press event and call onClick
150
+ * manually, one workaround to avoid this is to have empty href along with onClick
151
+ * but that would break accessibility
152
+ */
153
+ const handleKeyPress = (event) => {
154
+ if (event.key === 'Enter' && onClick) {
155
+ handleClick(event);
156
+ }
157
+ };
158
+
159
+ return (
160
+ <LinkComponent
161
+ {...props}
162
+ tabIndex={disabled ? -1 : tabIndex}
163
+ ref={linkRef}
164
+ data-testid="Link"
165
+ className={classify(
166
+ css.link,
167
+ css[as],
168
+ css[color],
169
+ {
170
+ [css.underline]: underline && !(iconLeftName || iconRightName),
171
+ [css.disabled]: disabled,
172
+ },
173
+ className,
174
+ )}
175
+ onClick={handleClick}
176
+ onKeyPress={handleKeyPress}
177
+ >
178
+ {!!iconLeftName && (
179
+ <Icon
180
+ name={iconLeftName}
181
+ size={iconLeftSize}
182
+ type={iconLeftType}
183
+ className={classify(css[color], {
184
+ [css.disabled]: disabled,
185
+ })}
186
+ />
187
+ )}
188
+
189
+ <ConditionalWrapper
190
+ condition={Boolean(iconLeftName || iconRightName)}
191
+ wrapper={(children) => (
192
+ <span
193
+ className={classify({
194
+ [css.underline]: underline,
195
+ })}
196
+ >
197
+ {children}
198
+ </span>
199
+ )}
200
+ >
201
+ {children}
202
+ </ConditionalWrapper>
203
+
204
+ {!!iconRightName && (
205
+ <Icon
206
+ name={iconRightName}
207
+ size={iconRightSize}
208
+ type={iconRightType}
209
+ className={css[color]}
210
+ />
211
+ )}
212
+ </LinkComponent>
213
+ );
214
+ },
215
+ );
216
+ const DefaultLink = React.forwardRef<BaseLinkProps, HTMLAnchorElement>(
217
+ ({children, href, to, ...props}, ref) => {
218
+ const resolvedHref = to ?? href;
219
+ return (
220
+ <a {...props} href={resolvedHref} ref={ref}>
221
+ {children}
222
+ </a>
223
+ );
224
+ },
225
+ );
@@ -0,0 +1 @@
1
+ export * from './Link';
@@ -0,0 +1,379 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ import {FixedSizeList} from 'react-window';
4
+ import type {MenuClassNames, MenuLabelTooltip} from '../../types/menu';
5
+ import {classify} from '../../utils/classify';
6
+ import {
7
+ getFilteredComposeOptionsFromSearchText,
8
+ getFilteredComposeOptionsResultText,
9
+ getFilteredGroupTitleOptionsFromSearchText,
10
+ getFilteredGroupTitleOptionsResultText,
11
+ getFilteredOptionsFromSearchText,
12
+ getFilteredOptionsResultText,
13
+ } from '../../utils/menu';
14
+ import type {IconType} from '../Icon/Icon';
15
+ import {SearchInput} from '../SearchInput';
16
+ import {FormLabelSmall} from '../Text';
17
+ import {MenuOptionButton} from './MenuOptionButton';
18
+ import css from './Menu.module.css';
19
+ type ClassNames = MenuClassNames;
20
+ type OptionClassNames = $ReadOnly<{
21
+ wrapper?: string;
22
+ }>;
23
+ export type Virtualization = $ReadOnly<{
24
+ enable: boolean;
25
+ itemHeight?: number;
26
+ menuHeight?: number;
27
+ }>;
28
+ export type MenuOption = {
29
+ key: string;
30
+ classNames?: OptionClassNames;
31
+ label?: string;
32
+ secondaryLabel?: string;
33
+ customComponent?: React.ReactNode;
34
+ iconLeft?: string;
35
+ iconLeftType?: IconType;
36
+ iconRight?: string;
37
+ iconRightType?: IconType;
38
+ disabled?: boolean;
39
+ optionSize?: MenuSizeTypes;
40
+ optionVariant?: MenuOptionsVariant;
41
+ keepMenuOpenOnOptionSelect?: boolean;
42
+ indeterminate?: boolean;
43
+ };
44
+ // Render first available option set
45
+ export type BaseMenuProps = {
46
+ onSelect?: (
47
+ option: MenuOption,
48
+ arg1: React.SyntheticEvent<HTMLElement> | null | undefined,
49
+ ) => unknown;
50
+ selectedOption?: MenuOption | null | undefined;
51
+ optionsVariant?: MenuOptionsVariant;
52
+ selectedKeys?: Array<string>;
53
+ classNames?: ClassNames;
54
+ size?: MenuSizeTypes;
55
+ width?: string;
56
+ menuDisabled?: boolean;
57
+ isFluid?: boolean;
58
+ // onTabOut is a callback function that is called when
59
+ // the user navigates outside of the menu using the tab key.
60
+ onTabOut?: () => unknown;
61
+ allowSearch?: boolean;
62
+ // A function that resolves the label for a MenuOption.
63
+ // It takes a MenuOption as a parameter and returns either a string or a React Node.
64
+ resolveLabel?: (option: MenuOption) => string | React.ReactNode;
65
+ // A function that resolves the secondaryLabel for a MenuOption.
66
+ // It takes a MenuOption as a parameter and returns either a string or a React Node.
67
+ resolveSecondaryLabel?: (option: MenuOption) => string | React.ReactNode;
68
+ // When virtualization is enabled, the MenuOptionButtons will be rendered only when they are present in the Menu's viewport
69
+ virtualization?: Virtualization;
70
+ header?: React.ReactNode;
71
+ footer?: React.ReactNode;
72
+ showResultText?: boolean;
73
+ staticLabels?: {
74
+ RESULT?: string;
75
+ RESULTS?: string;
76
+ SEARCH_PLACEHOLDER?: string;
77
+ };
78
+ showLabelTooltip?: MenuLabelTooltip;
79
+ allowWrap?: boolean;
80
+ };
81
+ export type MenuOptionTypes = {
82
+ options?: Array<MenuOption>;
83
+ composeOptions?: Array<Array<MenuOption>>;
84
+ groupTitleOptions?: Array<MenuGroupTitleOption>;
85
+ };
86
+ export type MenuSizeTypes = 'medium' | 'small';
87
+ export type MenuOptionsVariant = 'checkbox' | 'radio' | 'normal';
88
+ export type MenuGroupTitleOption = {
89
+ groupTitle?: React.ReactNode;
90
+ options?: Array<MenuOption>;
91
+ showLineDivider?: boolean;
92
+ };
93
+ export type MenuProps = BaseMenuProps & MenuOptionTypes;
94
+ export type RenderOptionProps = MenuProps & {
95
+ searchText?: string;
96
+ };
97
+ const menuSizeMedium = 276,
98
+ menuSizeSmall = 228;
99
+ const buttonSizeMedium = 40,
100
+ buttonSizeSmall = 32;
101
+
102
+ const RenderOption = ({
103
+ options,
104
+ composeOptions,
105
+ groupTitleOptions,
106
+ classNames,
107
+ searchText = '',
108
+ showResultText = true,
109
+ staticLabels = {
110
+ RESULT: 'result',
111
+ RESULTS: 'results',
112
+ SEARCH_PLACEHOLDER: 'Search...',
113
+ },
114
+ ...restProps
115
+ }: RenderOptionProps): React.ReactNode => {
116
+ const {
117
+ allowSearch,
118
+ size,
119
+ virtualization = {
120
+ enable: false,
121
+ menuHeight: null,
122
+ itemHeight: null,
123
+ },
124
+ } = restProps;
125
+
126
+ if (options && Array.isArray(options) && options.length) {
127
+ const optionsFiltered = !allowSearch
128
+ ? options
129
+ : getFilteredOptionsFromSearchText(options, searchText);
130
+ const finalResultText = !allowSearch
131
+ ? ''
132
+ : getFilteredOptionsResultText(optionsFiltered, staticLabels);
133
+ const {
134
+ enable: isVirtualizationEnabled,
135
+ menuHeight,
136
+ itemHeight,
137
+ } = virtualization;
138
+ return (
139
+ <>
140
+ {allowSearch && showResultText && (
141
+ <FormLabelSmall
142
+ className={css.filterOptionsResultText}
143
+ color="tertiary"
144
+ >
145
+ {finalResultText}
146
+ </FormLabelSmall>
147
+ )}
148
+ {virtualization && isVirtualizationEnabled ? (
149
+ <FixedSizeList
150
+ height={
151
+ menuHeight || (size === 'medium' ? menuSizeMedium : menuSizeSmall)
152
+ }
153
+ itemSize={
154
+ itemHeight ||
155
+ (size === 'medium' ? buttonSizeMedium : buttonSizeSmall)
156
+ }
157
+ itemCount={optionsFiltered.length}
158
+ >
159
+ {({index: idx, style}) => {
160
+ const buttonOption = optionsFiltered[idx];
161
+ return (
162
+ <React.Fragment key={buttonOption.key}>
163
+ <MenuOptionButton
164
+ option={buttonOption}
165
+ classNames={classNames}
166
+ style={style}
167
+ {...restProps}
168
+ isLastItem={idx === optionsFiltered.length - 1}
169
+ />
170
+ </React.Fragment>
171
+ );
172
+ }}
173
+ </FixedSizeList>
174
+ ) : (
175
+ optionsFiltered.map((option, idx) => (
176
+ <React.Fragment key={option.key}>
177
+ <MenuOptionButton
178
+ option={option}
179
+ classNames={classNames}
180
+ {...restProps}
181
+ isLastItem={idx === optionsFiltered.length - 1}
182
+ />
183
+ </React.Fragment>
184
+ ))
185
+ )}
186
+ </>
187
+ );
188
+ }
189
+
190
+ if (
191
+ composeOptions &&
192
+ Array.isArray(composeOptions) &&
193
+ composeOptions.length
194
+ ) {
195
+ const optionsFiltered = !allowSearch
196
+ ? composeOptions
197
+ : getFilteredComposeOptionsFromSearchText(composeOptions, searchText);
198
+ const finalResultText = !allowSearch
199
+ ? ''
200
+ : getFilteredComposeOptionsResultText(optionsFiltered, staticLabels);
201
+ return (
202
+ <>
203
+ {allowSearch && showResultText && (
204
+ <FormLabelSmall
205
+ className={css.filterOptionsResultText}
206
+ color="tertiary"
207
+ >
208
+ {finalResultText}
209
+ </FormLabelSmall>
210
+ )}
211
+ {optionsFiltered.map(
212
+ (
213
+ composeMenuOptions,
214
+ index, // eslint-disable-next-line react/no-array-index-key
215
+ ) => (
216
+ <span key={index} className={css.menuDivider}>
217
+ {composeMenuOptions.map((option, idx) => (
218
+ <React.Fragment key={option.key}>
219
+ <MenuOptionButton
220
+ option={option}
221
+ classNames={classNames}
222
+ {...restProps}
223
+ isLastItem={
224
+ index === optionsFiltered.length - 1 &&
225
+ idx === composeMenuOptions.length - 1
226
+ }
227
+ />
228
+ </React.Fragment>
229
+ ))}
230
+ </span>
231
+ ),
232
+ )}
233
+ </>
234
+ );
235
+ }
236
+
237
+ if (
238
+ groupTitleOptions &&
239
+ Array.isArray(groupTitleOptions) &&
240
+ groupTitleOptions.length
241
+ ) {
242
+ const optionsFiltered = !allowSearch
243
+ ? groupTitleOptions
244
+ : getFilteredGroupTitleOptionsFromSearchText(
245
+ groupTitleOptions,
246
+ searchText,
247
+ );
248
+ const finalResultText = !allowSearch
249
+ ? ''
250
+ : getFilteredGroupTitleOptionsResultText(optionsFiltered, staticLabels);
251
+ return (
252
+ <>
253
+ {allowSearch && showResultText && (
254
+ <FormLabelSmall
255
+ className={css.filterOptionsResultText}
256
+ color="tertiary"
257
+ >
258
+ {finalResultText}
259
+ </FormLabelSmall>
260
+ )}
261
+ {optionsFiltered.map(
262
+ (
263
+ optionsGroup,
264
+ index, // eslint-disable-next-line react/no-array-index-key
265
+ ) => (
266
+ <React.Fragment key={index}>
267
+ {!!optionsGroup.groupTitle && (
268
+ <div
269
+ className={classify(
270
+ css.groupTitleWrapper,
271
+ classNames?.groupTitle,
272
+ )}
273
+ >
274
+ {optionsGroup.groupTitle}
275
+ </div>
276
+ )}
277
+
278
+ {optionsGroup.options?.map((option, idx) => (
279
+ <React.Fragment key={option.key}>
280
+ <MenuOptionButton
281
+ option={option}
282
+ classNames={classNames}
283
+ {...restProps}
284
+ isLastItem={
285
+ index === optionsFiltered.length - 1 &&
286
+ idx ===
287
+ (optionsGroup.options &&
288
+ optionsGroup.options.length - 1)
289
+ }
290
+ />
291
+ </React.Fragment>
292
+ ))}
293
+ </React.Fragment>
294
+ ),
295
+ )}
296
+ </>
297
+ );
298
+ }
299
+
300
+ return <></>;
301
+ };
302
+
303
+ export const Menu: React$AbstractComponent<MenuProps, HTMLDivElement> =
304
+ React.forwardRef<MenuProps, HTMLDivElement>(
305
+ (props: MenuProps, ref): React.ReactNode => {
306
+ const {
307
+ classNames,
308
+ size = 'medium',
309
+ width,
310
+ isFluid = true,
311
+ allowSearch,
312
+ virtualization = {
313
+ enable: false,
314
+ menuHeight: null,
315
+ itemHeight: null,
316
+ },
317
+ header,
318
+ footer,
319
+ staticLabels,
320
+ } = props;
321
+ const [searchText, setSearchText] = React.useState('');
322
+ const {menuHeight} = virtualization;
323
+ const hasHeader = header ? true : false;
324
+ const hasFooter = footer ? true : false;
325
+ return (
326
+ <div
327
+ className={classify(
328
+ css.menuCard,
329
+ {
330
+ [css.fluid]: isFluid,
331
+ [css.medium]: size === 'medium',
332
+ [css.mediumWithHeader]:
333
+ size === 'medium' && hasHeader && !hasFooter,
334
+ [css.mediumWithFooter]:
335
+ size === 'medium' && !hasHeader && hasFooter,
336
+ [css.mediumWithHeaderAndFooter]:
337
+ size === 'medium' && hasFooter && hasHeader,
338
+ [css.small]: size === 'small',
339
+ [css.smallWithHeader]:
340
+ size === 'small' && hasHeader && !hasFooter,
341
+ [css.smallWithFooter]:
342
+ size === 'small' && !hasHeader && hasFooter,
343
+ [css.smallWithHeaderAndFooter]:
344
+ size === 'small' && hasFooter && hasHeader,
345
+ [css.menuCardTopPaddingZero]: header,
346
+ [css.menuCardBottomPaddingZero]: footer,
347
+ },
348
+ classNames?.wrapper,
349
+ )}
350
+ style={{
351
+ width,
352
+ maxHeight: menuHeight ? menuHeight + 'px' : '',
353
+ }}
354
+ ref={ref}
355
+ >
356
+ {hasHeader && (
357
+ <div className={classify(css.menuHeader, classNames?.header)}>
358
+ {header}
359
+ </div>
360
+ )}
361
+ {allowSearch && (
362
+ <SearchInput
363
+ value={searchText}
364
+ onChange={(e) => setSearchText(e.target.value)}
365
+ onClear={() => setSearchText('')}
366
+ size={size}
367
+ placeholder={staticLabels?.SEARCH_PLACEHOLDER ?? 'Search...'}
368
+ />
369
+ )}
370
+ <RenderOption {...props} searchText={searchText} />
371
+ {hasFooter && (
372
+ <div className={classify(css.menuFooter, classNames?.footer)}>
373
+ {footer}
374
+ </div>
375
+ )}
376
+ </div>
377
+ );
378
+ },
379
+ );