@spaced-out/ui-design-system 0.3.38-beta.0 → 0.3.39-beta.0

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 +16 -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 +5 -5
@@ -0,0 +1,131 @@
1
+ import {$ReadOnly, $Values} from 'utility-types';
2
+ import * as React from 'react';
3
+ import {
4
+ borderRadiusCircle,
5
+ borderRadiusMedium,
6
+ borderRadiusNone,
7
+ borderRadiusXSmall,
8
+ } from '../../styles/variables/_border';
9
+ import {size40, sizeFluid} from '../../styles/variables/_size';
10
+ import classify from '../../utils/classify';
11
+ import {appendPx} from '../../utils/string';
12
+ import css from './Shimmer.module.css';
13
+ type ClassNames = $ReadOnly<{
14
+ wrapper?: string;
15
+ }>;
16
+ export const SHIMMER_TYPES = Object.freeze({
17
+ text: 'text',
18
+ rounded: 'rounded',
19
+ circular: 'circular',
20
+ rectangular: 'rectangular',
21
+ });
22
+ export const SHIMMER_TYPE_TO_BORDER_RADIUS_MAP = Object.freeze({
23
+ text: borderRadiusXSmall,
24
+ rounded: borderRadiusMedium,
25
+ circular: borderRadiusCircle,
26
+ rectangular: borderRadiusNone,
27
+ });
28
+ export type ShimmerType = $Values<typeof SHIMMER_TYPES>;
29
+ export type ShimmerProps = {
30
+ classNames?: ClassNames;
31
+ show?: boolean;
32
+ type?: ShimmerType;
33
+ width?: number | string;
34
+ height?: number | string;
35
+ borderRadius?: number | string;
36
+ children?: React.ReactNode;
37
+ };
38
+ export type ShimmerWrapperProps = {
39
+ children?: React.ReactNode;
40
+ };
41
+
42
+ /**
43
+ * Note(Nishant): ShimmerWrapper is a wrapper component for Shimmer component. This should only be used for Text based Shimmers
44
+ * This solves a very annoying problem with out text components where the display prop is set to flex.
45
+ * Genesis assumes that every element is flexible for simplicity and for text text shimmers to work in use cases
46
+ * where text wraps across multiple lines, we need to wrap the shimmer in a span element.
47
+ * to avoid the misuse where consumers use there own / other block level components, we have this wrapper.
48
+ * This would ensure the layout remains same even when you toggle the shimmer to show your actual content
49
+ * @param {React.Node} children - The children to be rendered
50
+ */
51
+ export const ShimmerWrapper = ({
52
+ children,
53
+ }: ShimmerWrapperProps): React.ReactElement<
54
+ React.ComponentProps<'span'>,
55
+ 'span'
56
+ > => <span>{children}</span>;
57
+ export const Shimmer: React$AbstractComponent<ShimmerProps, HTMLSpanElement> =
58
+ React.forwardRef<ShimmerProps, HTMLSpanElement>(
59
+ (
60
+ {
61
+ classNames,
62
+ show = true,
63
+ type = SHIMMER_TYPES.text,
64
+ children,
65
+ width = size40,
66
+ height = sizeFluid,
67
+ borderRadius,
68
+ }: ShimmerProps,
69
+ ref,
70
+ ) => {
71
+ if (!show) {
72
+ return <>{children}</>;
73
+ }
74
+
75
+ const borderRadiusValue =
76
+ borderRadius ?? SHIMMER_TYPE_TO_BORDER_RADIUS_MAP[type];
77
+ return (
78
+ <span
79
+ ref={ref}
80
+ data-testid="Shimmer"
81
+ className={classify(css.wrapper, css[type], classNames?.wrapper)}
82
+ style={{
83
+ '--width': appendPx(width),
84
+ '--height': appendPx(height),
85
+ '--border-radius': appendPx(borderRadiusValue),
86
+ }}
87
+ ></span>
88
+ );
89
+ },
90
+ );
91
+ type KPIShimmerClassNames = $ReadOnly<{
92
+ wrapper?: string;
93
+ icon?: string;
94
+ text?: string;
95
+ }>;
96
+ export type KPIShimmerProps = {
97
+ textWidth?: number | string;
98
+ hasTopContent?: boolean;
99
+ hasMiddleContent?: boolean;
100
+ hasBottomContent?: boolean;
101
+ hasIcon?: boolean;
102
+ classNames?: KPIShimmerClassNames;
103
+ };
104
+ export const KPIShimmer = ({
105
+ textWidth = 150,
106
+ hasBottomContent = true,
107
+ hasIcon = true,
108
+ hasTopContent = true,
109
+ hasMiddleContent = true,
110
+ classNames,
111
+ }: KPIShimmerProps): React.ReactNode => (
112
+ <div className={classify(css.kpiBox, classNames?.wrapper)}>
113
+ {hasIcon && (
114
+ <div className={classify(css.section, css.iconSection, classNames?.icon)}>
115
+ <Shimmer type="rounded" width={60} height={60}></Shimmer>
116
+ </div>
117
+ )}
118
+
119
+ <div className={classify(css.section, classNames?.text)}>
120
+ {hasTopContent && (
121
+ <Shimmer type="text" width={textWidth} height={15}></Shimmer>
122
+ )}
123
+ {hasMiddleContent && (
124
+ <Shimmer type="text" width={textWidth} height={25}></Shimmer>
125
+ )}
126
+ {hasBottomContent && (
127
+ <Shimmer type="text" width={textWidth} height={15}></Shimmer>
128
+ )}
129
+ </div>
130
+ </div>
131
+ );
@@ -0,0 +1 @@
1
+ export * from './Shimmer';
@@ -0,0 +1,336 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ import classify from '../../utils/classify';
4
+ import {UnstyledButton} from '../Button';
5
+ import {ConditionalWrapper} from '../ConditionalWrapper';
6
+ import {Icon} from '../Icon';
7
+ import type {BaseLinkProps} from '../Link';
8
+ import {Link} from '../Link';
9
+ import type {StatusSemanticType} from '../StatusIndicator';
10
+ import {StatusIndicator} from '../StatusIndicator';
11
+ import {BodyMedium, SubTitleSmall, TEXT_COLORS} from '../Text';
12
+ import type {BaseTooltipProps} from '../Tooltip';
13
+ import {Tooltip} from '../Tooltip';
14
+ import css from './SideMenuLink.module.css';
15
+ export const MENU_NAME_LIST = Object.freeze({
16
+ dashboard: {
17
+ title: 'Dashboard',
18
+ iconName: 'house',
19
+ iconType: 'duotone',
20
+ },
21
+ engage: {
22
+ title: 'Engage',
23
+ iconName: 'bullseye-pointer',
24
+ iconType: 'duotone',
25
+ },
26
+ journeys: {
27
+ title: 'Journeys',
28
+ iconName: 'bullseye-pointer',
29
+ iconType: 'duotone',
30
+ },
31
+ automation: {
32
+ title: 'Automation',
33
+ iconName: 'bullseye-pointer',
34
+ iconType: 'duotone',
35
+ },
36
+ trm: {
37
+ title: 'TRM',
38
+ iconName: 'screen-users',
39
+ iconType: 'duotone',
40
+ },
41
+ analytics: {
42
+ title: 'Analytics & Data',
43
+ iconName: 'chart-column',
44
+ iconType: 'duotone',
45
+ },
46
+ messaging: {
47
+ title: 'Messaging',
48
+ iconName: 'messages',
49
+ iconType: 'duotone',
50
+ },
51
+ messages: {
52
+ title: 'Messaging',
53
+ iconName: 'messages',
54
+ iconType: 'duotone',
55
+ },
56
+ chatbot: {
57
+ title: 'Chatbot',
58
+ iconName: 'message-bot',
59
+ iconType: 'duotone',
60
+ },
61
+ referral: {
62
+ title: 'Referrals',
63
+ iconName: 'user-check',
64
+ iconType: 'duotone',
65
+ },
66
+ referrals: {
67
+ title: 'Referrals',
68
+ iconName: 'user-check',
69
+ iconType: 'duotone',
70
+ },
71
+ records: {
72
+ title: 'Records',
73
+ iconName: 'folder-open',
74
+ iconType: 'duotone',
75
+ },
76
+ 'database-cleanup': {
77
+ title: 'Bulk Cleanup',
78
+ iconName: 'retweet',
79
+ iconType: 'duotone',
80
+ },
81
+ support: {
82
+ title: 'Support',
83
+ iconName: 'headset',
84
+ iconType: 'duotone',
85
+ },
86
+ audit: {
87
+ title: 'Audit',
88
+ iconName: 'print-magnifying-glass',
89
+ iconType: 'duotone',
90
+ },
91
+ schedule: {
92
+ title: 'Timeline',
93
+ iconName: 'timeline',
94
+ iconType: 'duotone',
95
+ },
96
+ people: {
97
+ title: 'People',
98
+ iconName: 'people-group',
99
+ iconType: 'duotone',
100
+ },
101
+ contacts: {
102
+ title: 'Contacts',
103
+ iconName: 'address-card',
104
+ iconType: 'duotone',
105
+ },
106
+ meetings: {
107
+ title: 'Meetings',
108
+ iconName: 'calendars',
109
+ iconType: 'duotone',
110
+ },
111
+ contacts3: {
112
+ title: 'Contacts',
113
+ iconName: 'browser',
114
+ iconType: 'duotone',
115
+ },
116
+ senseai: {
117
+ title: 'AI Copilot',
118
+ iconName: 'sparkles',
119
+ iconType: 'duotone',
120
+ },
121
+ 'sense-jd-ai': {
122
+ title: 'Jd generator',
123
+ iconName: 'sparkles',
124
+ iconType: 'duotone',
125
+ },
126
+ tracking: {
127
+ title: 'Tracking',
128
+ iconName: 'user-check',
129
+ iconType: 'duotone',
130
+ },
131
+ jobs: {
132
+ title: 'Jobs',
133
+ iconName: 'briefcase',
134
+ iconType: 'duotone',
135
+ },
136
+ drive: {
137
+ title: 'Events',
138
+ iconName: 'briefcase',
139
+ iconType: 'duotone',
140
+ },
141
+ conversations: {
142
+ title: 'Conversations',
143
+ iconName: 'message-smile',
144
+ iconType: 'duotone',
145
+ },
146
+ pages: {
147
+ title: 'Pages',
148
+ iconName: 'pager',
149
+ iconType: 'duotone',
150
+ },
151
+ sourcing: {
152
+ title: 'Sourcing',
153
+ iconName: 'browser',
154
+ iconType: 'duotone',
155
+ },
156
+ earnings: {
157
+ title: 'Earnings',
158
+ iconName: 'wallet',
159
+ iconType: 'duotone',
160
+ },
161
+ settings: {
162
+ title: 'Settings',
163
+ iconName: 'gear',
164
+ iconType: 'duotone',
165
+ },
166
+ configuration: {
167
+ title: 'Configuration',
168
+ iconName: 'gear',
169
+ iconType: 'duotone',
170
+ },
171
+ supportLinks: {
172
+ title: 'Support Links',
173
+ iconName: 'circle-question',
174
+ iconType: 'duotone',
175
+ },
176
+ voiceflow: {
177
+ title: 'Voiceflow',
178
+ iconName: 'phone-volume',
179
+ iconType: 'duotone',
180
+ },
181
+ broadcast: {
182
+ title: 'Broadcast',
183
+ iconName: 'bullhorn',
184
+ iconType: 'duotone',
185
+ },
186
+ liveAgentTransfer: {
187
+ title: 'Live Agent Transfer',
188
+ iconName: 'user-headset',
189
+ iconType: 'duotone',
190
+ },
191
+ });
192
+ type ClassNames = $ReadOnly<{
193
+ wrapper?: string;
194
+ }>;
195
+ export type SideMenuLinkProps = {
196
+ classNames?: ClassNames;
197
+ children?: React.ReactNode;
198
+ customTitle?: string;
199
+ pageNameKey: string;
200
+ disabled?: boolean;
201
+ hovered?: boolean;
202
+ selectedValue?: string;
203
+ opened?: boolean;
204
+ onChange?: (
205
+ e: React.SyntheticEvent<HTMLElement>,
206
+ newValue: string,
207
+ ) => unknown;
208
+ tabIndex?: number;
209
+ tooltip?: BaseTooltipProps;
210
+ isGroupMenuLink?: boolean;
211
+ to?: string;
212
+ rightSlot?: React.ReactNode;
213
+ linkComponent?: React.AbstractComponent<
214
+ BaseLinkProps,
215
+ HTMLAnchorElement | null | undefined
216
+ >;
217
+ status?: StatusSemanticType;
218
+ };
219
+ export const SideMenuLink: React$AbstractComponent<
220
+ SideMenuLinkProps,
221
+ HTMLButtonElement
222
+ > = React.forwardRef<SideMenuLinkProps, HTMLButtonElement>(
223
+ (
224
+ {
225
+ classNames,
226
+ pageNameKey,
227
+ disabled,
228
+ opened,
229
+ selectedValue,
230
+ onChange,
231
+ tabIndex = 0,
232
+ tooltip,
233
+ isGroupMenuLink = false,
234
+ linkComponent: LinkComponent,
235
+ rightSlot,
236
+ to,
237
+ customTitle,
238
+ status,
239
+ ...restButtonProps
240
+ }: SideMenuLinkProps,
241
+ ref,
242
+ ): React.ReactNode => {
243
+ const selected = selectedValue === pageNameKey;
244
+ const inActive = !onChange;
245
+
246
+ const onChangeHandler = (e: React.SyntheticEvent<HTMLElement>) => {
247
+ onChange && onChange(e, pageNameKey);
248
+ };
249
+
250
+ const linkTitle = customTitle || MENU_NAME_LIST[pageNameKey].title;
251
+ return (
252
+ <ConditionalWrapper
253
+ condition={to !== undefined}
254
+ wrapper={(children) => (
255
+ <Link
256
+ to={to}
257
+ tabIndex={-1}
258
+ linkComponent={LinkComponent}
259
+ className={classify(css.linkComponent, {
260
+ [css.closed]: !opened,
261
+ })}
262
+ onClick={onChangeHandler}
263
+ >
264
+ {children}
265
+ </Link>
266
+ )}
267
+ >
268
+ <ConditionalWrapper
269
+ condition={Boolean(!opened && !inActive)}
270
+ wrapper={(children) => (
271
+ <Tooltip body={linkTitle} {...tooltip}>
272
+ {children}
273
+ </Tooltip>
274
+ )}
275
+ >
276
+ <UnstyledButton
277
+ {...restButtonProps}
278
+ className={classify(
279
+ css.linkWrapper,
280
+ {
281
+ [css.selected]: selected,
282
+ [css.disabled]: disabled,
283
+ [css.inActive]: inActive,
284
+ [css.closed]: !opened,
285
+ },
286
+ classNames?.wrapper,
287
+ )}
288
+ onClick={onChangeHandler}
289
+ ref={ref}
290
+ tabIndex={disabled ? -1 : tabIndex}
291
+ disabled={disabled}
292
+ key={pageNameKey}
293
+ >
294
+ {pageNameKey && MENU_NAME_LIST[pageNameKey] ? (
295
+ <div className={css.iconContainer}>
296
+ {status && (
297
+ <StatusIndicator
298
+ status={status}
299
+ classNames={{
300
+ wrapper: css.statusIndicatorBlock,
301
+ }}
302
+ />
303
+ )}
304
+ <Icon
305
+ type={MENU_NAME_LIST[pageNameKey].iconType}
306
+ name={MENU_NAME_LIST[pageNameKey].iconName}
307
+ size="medium"
308
+ color={TEXT_COLORS.inverseSecondary}
309
+ className={css.menuIcon}
310
+ />
311
+ </div>
312
+ ) : null}
313
+ {opened ? (
314
+ <div className={css.menuLabelContainer}>
315
+ {pageNameKey && MENU_NAME_LIST[pageNameKey] ? (
316
+ isGroupMenuLink ? (
317
+ <SubTitleSmall className={css.groupMenuLinkText}>
318
+ {linkTitle}
319
+ </SubTitleSmall>
320
+ ) : (
321
+ <BodyMedium className={css.menuLinkText}>
322
+ {linkTitle}
323
+ </BodyMedium>
324
+ )
325
+ ) : null}
326
+
327
+ {rightSlot ? rightSlot : null}
328
+ </div>
329
+ ) : null}
330
+ </UnstyledButton>
331
+ </ConditionalWrapper>
332
+ </ConditionalWrapper>
333
+ );
334
+ },
335
+ );
336
+ SideMenuLink.displayName = 'SideMenuLink';
@@ -0,0 +1 @@
1
+ export * from './SideMenuLink';
@@ -0,0 +1,60 @@
1
+ import {$ReadOnly, $Values, $Keys} from 'utility-types';
2
+ import * as React from 'react';
3
+ import * as COLORS from '../../styles/variables/_color';
4
+ import classify from '../../utils/classify';
5
+ import css from './StatusIndicator.module.css';
6
+ type ClassNames = $ReadOnly<{
7
+ wrapper?: string;
8
+ }>;
9
+ export const STATUS_SEMANTIC = Object.freeze({
10
+ primary: 'primary',
11
+ information: 'information',
12
+ success: 'success',
13
+ warning: 'warning',
14
+ danger: 'danger',
15
+ neutral: 'neutral',
16
+ secondary: 'secondary',
17
+ });
18
+ export type StatusSemanticType = $Values<typeof STATUS_SEMANTIC>;
19
+ export type StatusIndicatorProps = {
20
+ classNames?: ClassNames;
21
+ status?: StatusSemanticType;
22
+ withBorder?: boolean;
23
+ borderColorToken?: $Keys<typeof COLORS>;
24
+ disabled?: boolean;
25
+ };
26
+ export const StatusIndicator: React$AbstractComponent<
27
+ StatusIndicatorProps,
28
+ HTMLDivElement
29
+ > = React.forwardRef<StatusIndicatorProps, HTMLDivElement>(
30
+ (
31
+ {
32
+ classNames,
33
+ status = 'information',
34
+ withBorder,
35
+ borderColorToken = 'colorBackgroundTertiary',
36
+ disabled,
37
+ ...props
38
+ }: StatusIndicatorProps,
39
+ ref,
40
+ ): React.ReactNode => (
41
+ <div
42
+ {...props}
43
+ data-testid="StatusIndicator"
44
+ className={classify(
45
+ css.statusWrapper,
46
+ css[status],
47
+ {
48
+ [css.withBorder]: withBorder,
49
+ [css.disabled]: disabled,
50
+ },
51
+ classNames?.wrapper,
52
+ )}
53
+ ref={ref}
54
+ style={{
55
+ '--border-color':
56
+ COLORS[borderColorToken] || COLORS['colorBackgroundTertiary'],
57
+ }}
58
+ ></div>
59
+ ),
60
+ );
@@ -0,0 +1 @@
1
+ export * from './StatusIndicator';
@@ -0,0 +1,119 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ import classify from '../../../utils/classify';
4
+ import type {IconType} from '../../Icon';
5
+ import {Icon, ICON_SIZE, ICON_TYPE} from '../../Icon';
6
+ import css from '../Stepper.module.css';
7
+ type ClassNames = $ReadOnly<{
8
+ wrapper?: string;
9
+ stepCounter?: string;
10
+ content?: string;
11
+ }>;
12
+ export type StepProps = {
13
+ active?: boolean;
14
+ children: React.ReactNode;
15
+ completed?: boolean;
16
+ disabled?: boolean;
17
+ expanded?: boolean;
18
+ index: number;
19
+ last?: boolean;
20
+ classNames?: ClassNames;
21
+ allowClick?: boolean;
22
+ onClick?: (
23
+ idx: number,
24
+ e?: React.SyntheticEvent<HTMLElement> | null | undefined,
25
+ ) => unknown;
26
+ iconName?: string;
27
+ iconType?: IconType;
28
+ };
29
+ export const Step: React$AbstractComponent<StepProps, HTMLDivElement> =
30
+ React.forwardRef<StepProps, HTMLDivElement>(
31
+ (
32
+ {
33
+ active,
34
+ children,
35
+ completed = false,
36
+ disabled = false,
37
+ expanded = false,
38
+ index = 0,
39
+ last,
40
+ classNames,
41
+ onClick,
42
+ allowClick,
43
+ iconName,
44
+ iconType,
45
+ }: StepProps,
46
+ ref,
47
+ ): React.ReactNode => {
48
+ const childrenArray = React.Children.toArray(children).filter(Boolean);
49
+ const stepContent = childrenArray.map((stepContent) =>
50
+ React.cloneElement(stepContent, {
51
+ ...stepContent.props,
52
+ active,
53
+ completed,
54
+ disabled,
55
+ }),
56
+ );
57
+
58
+ const handleClick = (e) => allowClick && onClick?.(index, e);
59
+
60
+ return (
61
+ <div
62
+ ref={ref}
63
+ className={classify(
64
+ css.stepWrapper,
65
+ {
66
+ [css.active]: active,
67
+ [css.completed]: completed,
68
+ [css.expanded]: expanded,
69
+ [css.last]: last,
70
+ [css.disabled]: disabled,
71
+ [css.clickable]: allowClick,
72
+ },
73
+ classNames?.wrapper,
74
+ )}
75
+ onClick={handleClick}
76
+ >
77
+ <div
78
+ className={classify(
79
+ css.stepWrapperCounter,
80
+ {
81
+ [css.selected]: active,
82
+ [css.completed]: completed,
83
+ [css.expanded]: expanded,
84
+ [css.last]: last,
85
+ [css.disabled]: disabled,
86
+ [css.withIcon]: !!iconName,
87
+ },
88
+ classNames?.stepCounter,
89
+ )}
90
+ >
91
+ {completed && !active ? (
92
+ <Icon
93
+ name="check"
94
+ type={ICON_TYPE.solid}
95
+ size={ICON_SIZE.small}
96
+ className={css.stepIcon}
97
+ />
98
+ ) : (
99
+ <React.Fragment>
100
+ {iconName ? (
101
+ <Icon
102
+ name={iconName}
103
+ className={css.stepIcon}
104
+ size={ICON_SIZE.small}
105
+ type={iconType}
106
+ />
107
+ ) : (
108
+ (index + 1).toString()
109
+ )}
110
+ </React.Fragment>
111
+ )}
112
+ </div>
113
+ <div className={classify(css.stepContent, classNames?.content)}>
114
+ {stepContent}
115
+ </div>
116
+ </div>
117
+ );
118
+ },
119
+ );
@@ -0,0 +1,35 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ import {classify} from '../../../utils/classify';
4
+ import css from '../Stepper.module.css';
5
+ type ClassNames = $ReadOnly<{
6
+ wrapper?: string;
7
+ }>;
8
+ export type StepContentProps = {
9
+ children: React.ReactNode;
10
+ active?: boolean;
11
+ completed?: boolean;
12
+ disabled?: boolean;
13
+ classNames?: ClassNames;
14
+ };
15
+ export const StepContent = ({
16
+ children,
17
+ classNames,
18
+ active,
19
+ completed = false,
20
+ disabled = false,
21
+ }: StepContentProps): React.ReactNode => (
22
+ <div
23
+ className={classify(
24
+ css.stepContentWrapper,
25
+ {
26
+ [css.active]: active,
27
+ [css.completed]: completed,
28
+ [css.disabled]: disabled,
29
+ },
30
+ classNames?.wrapper,
31
+ )}
32
+ >
33
+ {children}
34
+ </div>
35
+ );