@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,150 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ import classify from '../../utils/classify';
4
+ import type {ClickAwayRefType} from '../../utils/click-away';
5
+ import type {ButtonProps} from '../Button';
6
+ import {Button} from '../Button';
7
+ import type {AnchorType} from '../ButtonDropdown';
8
+ import {ButtonDropdown} from '../ButtonDropdown';
9
+ import {ConditionalWrapper} from '../ConditionalWrapper';
10
+ import type {MenuOption, MenuProps} from '../Menu';
11
+ import type {BaseTooltipProps} from '../Tooltip';
12
+ import {Tooltip} from '../Tooltip';
13
+ import css from './OptionButton.module.css';
14
+ type ClassNames = $ReadOnly<{
15
+ wrapper?: string;
16
+ baseButtonWrapper?: string;
17
+ baseButtonIcon?: string;
18
+ optionsButtonWrapper?: string;
19
+ optionsButtonIcon?: string;
20
+ dropdownContainer?: string;
21
+ }>;
22
+ export type OptionButtonTooltipProps = {
23
+ baseButton?: BaseTooltipProps;
24
+ optionsButton?: BaseTooltipProps;
25
+ };
26
+ export type OptionButtonProps = ButtonProps & {
27
+ menu?: MenuProps;
28
+ anchorPosition?: AnchorType;
29
+ onOptionSelect?: (
30
+ option: MenuOption,
31
+ arg1: React.SyntheticEvent<HTMLElement> | null | undefined,
32
+ ) => unknown;
33
+ onButtonClick?:
34
+ | ((arg0: React.SyntheticEvent<HTMLElement>) => unknown)
35
+ | null
36
+ | undefined;
37
+ onMenuOpen?: () => unknown;
38
+ onMenuClose?: () => unknown;
39
+ tooltip?: OptionButtonTooltipProps;
40
+ classNames?: ClassNames;
41
+ clickAwayRef?: ClickAwayRefType;
42
+ };
43
+ export const OptionButton: React$AbstractComponent<
44
+ OptionButtonProps,
45
+ HTMLDivElement
46
+ > = React.forwardRef<OptionButtonProps, HTMLDivElement>(
47
+ (
48
+ {
49
+ children,
50
+ iconLeftName,
51
+ iconLeftType,
52
+ type,
53
+ isFluid,
54
+ disabled,
55
+ size,
56
+ isLoading,
57
+ menu,
58
+ anchorPosition,
59
+ onOptionSelect,
60
+ onButtonClick,
61
+ onMenuOpen,
62
+ onMenuClose,
63
+ ariaLabel,
64
+ actionType,
65
+ tooltip,
66
+ classNames,
67
+ clickAwayRef,
68
+ }: OptionButtonProps,
69
+ ref,
70
+ ): React.ReactNode => {
71
+ const [iconName, setIconName] = React.useState('chevron-down');
72
+ const [isMenuOpen, setIsMenuOpen] = React.useState(false);
73
+ return (
74
+ <div
75
+ className={classify(
76
+ css.container,
77
+ {
78
+ [css.isFluid]: isFluid,
79
+ },
80
+ classNames?.wrapper,
81
+ )}
82
+ ref={ref}
83
+ >
84
+ <ConditionalWrapper
85
+ condition={Boolean(tooltip?.baseButton)}
86
+ wrapper={(children) => (
87
+ <Tooltip
88
+ {...tooltip?.baseButton}
89
+ hidden={isMenuOpen ? true : tooltip?.optionsButton?.hidden}
90
+ >
91
+ {children}
92
+ </Tooltip>
93
+ )}
94
+ >
95
+ <Button
96
+ iconLeftName={iconLeftName}
97
+ iconLeftType={iconLeftType}
98
+ onClick={onButtonClick}
99
+ size={size}
100
+ type={type}
101
+ disabled={disabled}
102
+ isFluid={isFluid}
103
+ ariaLabel={ariaLabel}
104
+ actionType={actionType}
105
+ isLoading={isLoading}
106
+ classNames={{
107
+ wrapper: classify(css.leftButton, classNames?.baseButtonWrapper),
108
+ icon: classNames?.baseButtonIcon,
109
+ }}
110
+ >
111
+ {children}
112
+ </Button>
113
+ </ConditionalWrapper>
114
+ <ButtonDropdown
115
+ anchorPosition={anchorPosition}
116
+ ariaLabel={ariaLabel}
117
+ iconLeftName={iconName}
118
+ tooltip={tooltip?.optionsButton}
119
+ classNames={{
120
+ buttonWrapper: classify(
121
+ css.rightButton,
122
+ classNames?.optionsButtonWrapper,
123
+ ),
124
+ dropdownContainer: classify(
125
+ css.dropDownContainer,
126
+ classNames?.dropdownContainer,
127
+ ),
128
+ buttonIcon: classNames?.optionsButtonIcon,
129
+ }}
130
+ type={type}
131
+ disabled={disabled}
132
+ menu={menu}
133
+ onMenuClose={() => {
134
+ setIconName('chevron-down');
135
+ setIsMenuOpen(false);
136
+ onMenuOpen && onMenuOpen();
137
+ }}
138
+ onMenuOpen={() => {
139
+ setIconName('chevron-up');
140
+ setIsMenuOpen(true);
141
+ onMenuClose && onMenuClose();
142
+ }}
143
+ onOptionSelect={onOptionSelect}
144
+ size={size}
145
+ clickAwayRef={clickAwayRef}
146
+ />
147
+ </div>
148
+ );
149
+ },
150
+ );
@@ -0,0 +1,150 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ import type {MenuClassNames, MenuLabelTooltip} from '../../types/menu';
4
+ import type {ClickAwayRefType} from '../../utils/click-away';
5
+ import {getSelectedKeysFromSelectedOption} from '../../utils/menu';
6
+ import type {ButtonProps} from '../Button';
7
+ import type {AnchorType} from '../ButtonDropdown';
8
+ import type {MenuOption, MenuOptionsVariant, Virtualization} from '../Menu';
9
+ import type {OptionButtonTooltipProps} from './OptionButton';
10
+ import {OptionButton} from './OptionButton';
11
+ type ClassNames = $ReadOnly<{
12
+ wrapper?: string;
13
+ baseButtonWrapper?: string;
14
+ baseButtonIcon?: string;
15
+ optionsButtonWrapper?: string;
16
+ optionsButtonIcon?: string;
17
+ dropdownContainer?: string;
18
+ }>;
19
+ export type SimpleOptionButtonRef = {
20
+ selectedKeys?: Array<string>;
21
+ };
22
+ export type SimpleOptionButtonProps = ButtonProps & {
23
+ classNames?: ClassNames;
24
+ tooltip?: OptionButtonTooltipProps;
25
+ anchorPosition?: AnchorType;
26
+ tooltip?: OptionButtonTooltipProps;
27
+ menuSize?: 'small' | 'medium';
28
+ // Menu props
29
+ options?: Array<MenuOption>;
30
+ optionsVariant?: MenuOptionsVariant;
31
+ allowSearch?: boolean;
32
+ selectedKeys?: Array<string>;
33
+ menuVirtualization?: Virtualization;
34
+ header?: React.ReactNode;
35
+ footer?: React.ReactNode;
36
+ menuClassNames?: MenuClassNames;
37
+ showLabelTooltip?: MenuLabelTooltip;
38
+ allowWrap?: boolean;
39
+ // events
40
+ onOptionSelect?: (
41
+ option: MenuOption,
42
+ arg1: React.SyntheticEvent<HTMLElement> | null | undefined,
43
+ ) => unknown;
44
+ onButtonClick?:
45
+ | ((arg0: React.SyntheticEvent<HTMLElement>) => unknown)
46
+ | null
47
+ | undefined;
48
+ onMenuOpen?: () => unknown;
49
+ onMenuClose?: () => unknown;
50
+ // Resolvers
51
+ resolveLabel?: (option: MenuOption) => string | React.ReactNode;
52
+ resolveSecondaryLabel?: (option: MenuOption) => string | React.ReactNode;
53
+ clickAwayRef?: ClickAwayRefType;
54
+ };
55
+
56
+ const SimpleOptionButtonBase = (props: SimpleOptionButtonProps, ref) => {
57
+ const {
58
+ size = 'small',
59
+ classNames,
60
+ tooltip,
61
+ anchorPosition,
62
+ options,
63
+ optionsVariant,
64
+ allowSearch,
65
+ selectedKeys,
66
+ onOptionSelect,
67
+ onButtonClick,
68
+ onMenuOpen,
69
+ onMenuClose,
70
+ resolveLabel,
71
+ resolveSecondaryLabel,
72
+ children,
73
+ menuSize = 'small',
74
+ menuVirtualization,
75
+ header,
76
+ footer,
77
+ menuClassNames,
78
+ showLabelTooltip,
79
+ clickAwayRef,
80
+ allowWrap = false,
81
+ ...buttonProps
82
+ } = props;
83
+ const [optionButtonSelectedKeys, setOptionButtonSelectedKeys] =
84
+ React.useState(selectedKeys);
85
+ React.useEffect(() => {
86
+ setOptionButtonSelectedKeys(selectedKeys);
87
+ }, [selectedKeys]);
88
+
89
+ const handleOptionChange = (selectedOption: MenuOption, e) => {
90
+ e?.stopPropagation();
91
+ let newSelectedKeys = [selectedOption.key];
92
+
93
+ if (optionsVariant === 'checkbox') {
94
+ newSelectedKeys = getSelectedKeysFromSelectedOption(
95
+ selectedOption,
96
+ optionButtonSelectedKeys,
97
+ );
98
+ } else {
99
+ newSelectedKeys = [selectedOption.key];
100
+ }
101
+
102
+ setOptionButtonSelectedKeys(newSelectedKeys);
103
+ setTimeout(() => {
104
+ onOptionSelect?.(selectedOption, e);
105
+ });
106
+ };
107
+
108
+ React.useImperativeHandle(ref, () => ({
109
+ selectedKeys: optionButtonSelectedKeys,
110
+ }));
111
+ return (
112
+ <OptionButton
113
+ {...buttonProps}
114
+ tooltip={tooltip}
115
+ onButtonClick={onButtonClick}
116
+ anchorPosition={anchorPosition}
117
+ classNames={classNames}
118
+ size={size}
119
+ onOptionSelect={handleOptionChange}
120
+ onMenuOpen={onMenuOpen}
121
+ onMenuClose={onMenuClose}
122
+ clickAwayRef={clickAwayRef}
123
+ menu={{
124
+ isFluid: false,
125
+ options,
126
+ selectedKeys: optionButtonSelectedKeys,
127
+ optionsVariant,
128
+ allowSearch,
129
+ resolveLabel,
130
+ resolveSecondaryLabel,
131
+ size: menuSize,
132
+ virtualization: menuVirtualization,
133
+ header,
134
+ footer,
135
+ classNames: menuClassNames,
136
+ showLabelTooltip,
137
+ allowWrap,
138
+ }}
139
+ >
140
+ {children}
141
+ </OptionButton>
142
+ );
143
+ };
144
+
145
+ export const SimpleOptionButton: React.AbstractComponent<
146
+ SimpleOptionButtonProps,
147
+ SimpleOptionButtonRef
148
+ > = React.forwardRef<SimpleOptionButtonProps, SimpleOptionButtonRef>(
149
+ SimpleOptionButtonBase,
150
+ );
@@ -0,0 +1,2 @@
1
+ export * from './OptionButton';
2
+ export * from './SimpleOptionButton';
@@ -0,0 +1,256 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ import {
4
+ colorIconPrimary,
5
+ colorIconSecondary,
6
+ } from '../../styles/variables/_color';
7
+ import classify from '../../utils/classify';
8
+ import {Button} from '../Button';
9
+ import {Icon} from '../Icon';
10
+ import {TEXT_COLORS, TitleMedium} from '../Text';
11
+ import {Tooltip} from '../Tooltip';
12
+ import css from './PageTitle.module.css';
13
+ type ClassNames = $ReadOnly<{
14
+ wrapper?: string;
15
+ leftSlot?: string;
16
+ rightSlot?: string;
17
+ }>;
18
+ export type PageTitleProps = {
19
+ classNames?: ClassNames;
20
+ children?: React.ReactNode;
21
+ pageNameKey?: string;
22
+ showBackButton?: boolean;
23
+ onBack?: () => void;
24
+ };
25
+ export const PAGE_NAME_LIST = Object.freeze({
26
+ dashboard: {
27
+ title: 'Dashboard',
28
+ iconName: 'house',
29
+ iconType: 'duotone',
30
+ },
31
+ engage: {
32
+ title: 'Engage',
33
+ iconName: 'bullseye-pointer',
34
+ iconType: 'duotone',
35
+ },
36
+ journeys: {
37
+ title: 'Journeys',
38
+ iconName: 'bullseye-pointer',
39
+ iconType: 'duotone',
40
+ },
41
+ workflows: {
42
+ title: 'Workflows',
43
+ iconName: 'bullseye-pointer',
44
+ iconType: 'duotone',
45
+ },
46
+ trm: {
47
+ title: 'TRM',
48
+ iconName: 'screen-users',
49
+ iconType: 'duotone',
50
+ },
51
+ analytics: {
52
+ title: 'Analytics',
53
+ iconName: 'chart-column',
54
+ iconType: 'duotone',
55
+ },
56
+ messaging: {
57
+ title: 'Messaging',
58
+ iconName: 'messages',
59
+ iconType: 'duotone',
60
+ },
61
+ chatbot: {
62
+ title: 'Chatbot',
63
+ iconName: 'message-bot',
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
+ bulkCleanup: {
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
+ timeline: {
92
+ title: 'Timeline',
93
+ iconName: 'timeline',
94
+ iconType: 'duotone',
95
+ },
96
+ people: {
97
+ title: 'People',
98
+ iconName: 'people-group',
99
+ iconType: 'duotone',
100
+ },
101
+ jobs: {
102
+ title: 'Jobs',
103
+ iconName: 'briefcase',
104
+ iconType: 'duotone',
105
+ },
106
+ contacts: {
107
+ title: 'Contacts',
108
+ iconName: 'address-card',
109
+ iconType: 'duotone',
110
+ },
111
+ meetings: {
112
+ title: 'Meetings',
113
+ iconName: 'calendars',
114
+ iconType: 'duotone',
115
+ },
116
+ contacts3: {
117
+ title: 'Contacts',
118
+ iconName: 'browser',
119
+ iconType: 'duotone',
120
+ },
121
+ tracking: {
122
+ title: 'Tracking',
123
+ iconName: 'user-check',
124
+ iconType: 'duotone',
125
+ },
126
+ earnings: {
127
+ title: 'Earnings',
128
+ iconName: 'wallet',
129
+ iconType: 'duotone',
130
+ },
131
+ settings: {
132
+ title: 'Settings',
133
+ iconName: 'gear',
134
+ iconType: 'duotone',
135
+ },
136
+ broadcast: {
137
+ title: 'Broadcast',
138
+ iconName: 'bullhorn',
139
+ iconType: 'duotone',
140
+ },
141
+ });
142
+ export type TabSlotProps = {
143
+ children?: React.ReactNode;
144
+ className: string;
145
+ };
146
+ export const TabSlot = ({
147
+ children,
148
+ className,
149
+ ...props
150
+ }: TabSlotProps): React.ReactNode => (
151
+ <div {...props} className={classify(css.tabSlot, className)}>
152
+ {children}
153
+ </div>
154
+ );
155
+ TabSlot.displayName = 'TabSlot';
156
+ export type RightSlotProps = {
157
+ children?: React.ReactNode;
158
+ };
159
+ export const RightSlot = ({
160
+ children,
161
+ ...props
162
+ }: RightSlotProps): React.ReactNode => <div {...props}>{children}</div>;
163
+ RightSlot.displayName = 'RightSlot';
164
+ export type PageNameProps = {
165
+ children?: React.ReactNode;
166
+ };
167
+ export const PageName = ({
168
+ children,
169
+ ...props
170
+ }: PageNameProps): React.ReactNode => (
171
+ <div {...props} className={css.pageTitle}>
172
+ {children}
173
+ </div>
174
+ );
175
+ PageName.displayName = 'PageName';
176
+ export const PageTitle: React$AbstractComponent<
177
+ PageTitleProps,
178
+ HTMLDivElement
179
+ > = React.forwardRef<PageTitleProps, HTMLDivElement>(
180
+ (
181
+ {classNames, children, pageNameKey, showBackButton, onBack}: PageTitleProps,
182
+ ref,
183
+ ): React.ReactNode => {
184
+ const getNamedComp = (comp: string) => {
185
+ const childrenArray = React.Children.toArray(children);
186
+
187
+ if (childrenArray.length) {
188
+ const nodes: React.ReactNode[] = [];
189
+
190
+ for (const child of childrenArray) {
191
+ if (child?.type?.displayName === comp) {
192
+ nodes.push(child);
193
+ }
194
+ }
195
+
196
+ return nodes.length > 1 ? nodes : nodes[0];
197
+ }
198
+
199
+ return null;
200
+ };
201
+
202
+ const handleBack = () => {
203
+ onBack && onBack();
204
+ };
205
+
206
+ return (
207
+ <div
208
+ data-testid="PageTitle"
209
+ className={classify(css.pageTitleWrapper, classNames?.wrapper)}
210
+ ref={ref}
211
+ >
212
+ <div className={classify(css.leftSlot, classNames?.leftSlot)}>
213
+ <div className={css.headerWithBackBtn}>
214
+ {showBackButton && (
215
+ <Tooltip
216
+ title="Navigate Back"
217
+ delayMotionDuration="slow"
218
+ placement="top-start"
219
+ >
220
+ <Button
221
+ onClick={handleBack}
222
+ type="tertiary"
223
+ iconLeftName="chevron-left"
224
+ ariaLabel="Navigate Back Button"
225
+ />
226
+ </Tooltip>
227
+ )}
228
+ {pageNameKey && PAGE_NAME_LIST[pageNameKey] ? (
229
+ <PageName>
230
+ <TitleMedium>{PAGE_NAME_LIST[pageNameKey].title} </TitleMedium>
231
+ <Icon
232
+ type={PAGE_NAME_LIST[pageNameKey].iconType}
233
+ name={PAGE_NAME_LIST[pageNameKey].iconName}
234
+ size="medium"
235
+ color={TEXT_COLORS.primary}
236
+ style={{
237
+ '--fa-primary-color': colorIconPrimary,
238
+ '--fa-secondary-color': colorIconSecondary,
239
+ '--fa-primary-opacity': '1.0',
240
+ '--fa-secondary-opacity': '1.0',
241
+ }}
242
+ />
243
+ </PageName>
244
+ ) : (
245
+ getNamedComp('PageName')
246
+ )}
247
+ </div>
248
+ {getNamedComp('TabSlot')}
249
+ </div>
250
+ <div className={classify(css.rightSlot, classNames?.rightSlot)}>
251
+ {getNamedComp('RightSlot')}
252
+ </div>
253
+ </div>
254
+ );
255
+ },
256
+ );
@@ -0,0 +1 @@
1
+ export * from './PageTitle';
@@ -0,0 +1,144 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ import {usePagination} from '../../hooks/usePagination';
4
+ import {useWindowSize} from '../../hooks/useWindowSize';
5
+ import classify from '../../utils/classify';
6
+ import {range} from '../../utils/helpers';
7
+ import {Dropdown} from '../Dropdown';
8
+ import {SubTitleExtraSmall} from '../Text';
9
+ import {PaginationItem} from './PaginationItem';
10
+ import css from './Pagination.module.css';
11
+ type ClassNames = $ReadOnly<{
12
+ wrapper?: string;
13
+ children?: string;
14
+ paginator?: string;
15
+ }>;
16
+ type MixedEvent = React.SyntheticEvent<EventTarget> | Event;
17
+ type PaginationItemType =
18
+ | 'first'
19
+ | 'previous'
20
+ | 'page'
21
+ | 'start-ellipsis'
22
+ | 'end-ellipsis'
23
+ | 'last'
24
+ | 'next';
25
+ export type PaginationBaseProps = {
26
+ currentPage?: number;
27
+ disabled?: boolean;
28
+ onChange?: (
29
+ value?: number | null | undefined,
30
+ event?: MixedEvent | null | undefined,
31
+ ) => void;
32
+ totalPages?: number;
33
+ showFirstButton?: boolean;
34
+ showLastButton?: boolean;
35
+ hideNextButton?: boolean;
36
+ hidePrevButton?: boolean;
37
+ boundaryCount?: number;
38
+ siblingCount?: number;
39
+ style?: 'primary' | 'secondary';
40
+ };
41
+ export type PaginationProps = PaginationBaseProps & {
42
+ children?: React.ReactNode;
43
+ classNames?: ClassNames;
44
+ };
45
+ export type PaginationItemProps = {
46
+ id: string;
47
+ disabled: boolean;
48
+ onClick: (event: React.SyntheticEvent<HTMLElement>) => void;
49
+ page: number | null | undefined;
50
+ selected: boolean;
51
+ type: PaginationItemType;
52
+ };
53
+ const LARGE_LIST_DROPDOWN_OPTIONS = 50;
54
+ const TABLET_SCREEN_SIZE = 640;
55
+ export const Pagination: React$AbstractComponent<
56
+ PaginationProps,
57
+ HTMLDivElement
58
+ > = React.forwardRef<PaginationProps, HTMLDivElement>(
59
+ (props: PaginationProps, ref) => {
60
+ const {width} = useWindowSize();
61
+ const showExtraSecPaginationButtons = width > TABLET_SCREEN_SIZE;
62
+ const {
63
+ classNames,
64
+ style = 'primary',
65
+ children,
66
+ currentPage = 1,
67
+ totalPages = 1,
68
+ onChange,
69
+ showFirstButton = style !== 'primary' && showExtraSecPaginationButtons,
70
+ showLastButton = style !== 'primary' && showExtraSecPaginationButtons,
71
+ ...restPaginationProps
72
+ } = props;
73
+ const showPageSelectionDropDown =
74
+ style !== 'primary' && showExtraSecPaginationButtons;
75
+ const {items} = usePagination({
76
+ style,
77
+ showFirstButton,
78
+ showLastButton,
79
+ currentPage,
80
+ totalPages,
81
+ onChange,
82
+ ...restPaginationProps,
83
+ });
84
+ const menuVirtualization = {
85
+ enable: totalPages > LARGE_LIST_DROPDOWN_OPTIONS ? true : false,
86
+ };
87
+ const allPages = range(1, totalPages);
88
+ const options =
89
+ style !== 'secondary'
90
+ ? []
91
+ : allPages.map((page) => ({
92
+ key: page.toString(),
93
+ label: page.toString(),
94
+ }));
95
+ return (
96
+ <div
97
+ ref={ref}
98
+ data-testid="Pagination"
99
+ className={classify(css.wrapper, classNames?.wrapper)}
100
+ >
101
+ <div className={classify(css.childrenSlot, classNames?.children)}>
102
+ {children}
103
+ </div>
104
+ <div className={css.paginatorSlots}>
105
+ {style === 'secondary' && showPageSelectionDropDown && (
106
+ <>
107
+ <Dropdown
108
+ size="small"
109
+ classNames={{
110
+ wrapper: css.dropdownWrapper,
111
+ }}
112
+ menu={{
113
+ options,
114
+ isFluid: true,
115
+ classNames: {
116
+ wrapper: css.menuWrapper,
117
+ },
118
+ selectedKeys: currentPage ? [currentPage.toString()] : [],
119
+ virtualization: menuVirtualization,
120
+ }}
121
+ dropdownInputText={currentPage.toString()}
122
+ onChange={(option) => onChange?.(parseInt(option.key))}
123
+ />
124
+ {!!totalPages && !!currentPage && (
125
+ <SubTitleExtraSmall
126
+ color="tertiary"
127
+ className={css.secondaryLabel}
128
+ >
129
+ of {totalPages} {totalPages > 1 ? 'Pages' : 'Page'}
130
+ </SubTitleExtraSmall>
131
+ )}
132
+ </>
133
+ )}
134
+
135
+ <div className={classify(css.paginatorSlot, classNames?.paginator)}>
136
+ {items?.map((item) => (
137
+ <PaginationItem key={item.id} {...item} />
138
+ ))}
139
+ </div>
140
+ </div>
141
+ </div>
142
+ );
143
+ },
144
+ );