@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,111 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ //@ts-expect-error[untyped-import]
4
+ import Highcharts from 'highcharts';
5
+ //@ts-expect-error[untyped-import]
6
+ import HighchartsReact from 'highcharts-react-official';
7
+ import type {
8
+ ChartOptions,
9
+ DataOptionsType,
10
+ Drilldown,
11
+ } from '../../../types/charts';
12
+ import {
13
+ columnPlotWidth,
14
+ getColumnChartOptions,
15
+ getDataVizColor,
16
+ mergeChartUserOptions,
17
+ } from '../../../utils/charts';
18
+ import classify from '../../../utils/classify';
19
+ import type {ChartWrapperClassNames, ExportOptionType} from '../ChartWrapper';
20
+ import {ChartWrapper} from '../ChartWrapper';
21
+ import css from './ColumnChart.module.css';
22
+ export type ClassNames = $ReadOnly<
23
+ ChartWrapperClassNames & {
24
+ highChart?: string;
25
+ }
26
+ >;
27
+ export type ColumnSeries = {
28
+ name: string;
29
+ data: DataOptionsType[];
30
+ };
31
+ export type ColumnChartProps = ChartOptions & {
32
+ isLoading?: boolean;
33
+ classNames?: ClassNames;
34
+ cardTitle?: React.ReactNode;
35
+ customExportOptions?: Array<ExportOptionType> | null;
36
+ series: Array<ColumnSeries>;
37
+ drilldown?: Drilldown;
38
+ headerActions?: React.ReactNode;
39
+ hasEmptyData?: boolean;
40
+ emptyText?: React.ReactNode;
41
+ };
42
+ export const ColumnChart = ({
43
+ isLoading,
44
+ classNames,
45
+ cardTitle,
46
+ customExportOptions,
47
+ series,
48
+ drilldown,
49
+ headerActions,
50
+ hasEmptyData,
51
+ emptyText,
52
+ ...userOptions
53
+ }: ColumnChartProps): React.ReactNode => {
54
+ const chartRef = React.createRef();
55
+ const columnChartSeries = series.map((seriesItem, index) => ({
56
+ ...seriesItem,
57
+ name: seriesItem.name,
58
+ data: seriesItem.data,
59
+ color: getDataVizColor(index),
60
+ pointWidth: columnPlotWidth,
61
+ }));
62
+
63
+ const addColorToDrilldownSeries = (series) =>
64
+ series?.map((seriesItem) => ({
65
+ ...seriesItem,
66
+ data: seriesItem.data.map((dataItem, index) => ({
67
+ ...dataItem,
68
+ color: getDataVizColor(index),
69
+ pointWidth: columnPlotWidth,
70
+ })),
71
+ }));
72
+
73
+ const columnDrilldown = drilldown
74
+ ? {
75
+ ...drilldown,
76
+ series: addColorToDrilldownSeries(drilldown.series),
77
+ breadcrumbs: {
78
+ floating: false,
79
+ },
80
+ }
81
+ : {};
82
+ const defaultColumnChartOptions = getColumnChartOptions();
83
+ //$FlowFixMe[cannot-spread-inexact]
84
+ const chartOptions = mergeChartUserOptions(defaultColumnChartOptions, {
85
+ series: columnChartSeries,
86
+ drilldown: columnDrilldown,
87
+ ...userOptions,
88
+ });
89
+ const {highChart, ...wrapperClassNames} = classNames || {};
90
+ return (
91
+ <ChartWrapper
92
+ isLoading={isLoading}
93
+ title={cardTitle}
94
+ ref={chartRef}
95
+ classNames={wrapperClassNames}
96
+ customExportOptions={customExportOptions}
97
+ headerActions={headerActions}
98
+ hasEmptyData={hasEmptyData}
99
+ emptyText={emptyText}
100
+ >
101
+ <HighchartsReact
102
+ highcharts={Highcharts}
103
+ containerProps={{
104
+ className: classify(css.columnChartContainer, highChart),
105
+ }}
106
+ ref={chartRef}
107
+ options={chartOptions}
108
+ />
109
+ </ChartWrapper>
110
+ );
111
+ };
@@ -0,0 +1 @@
1
+ export * from './ColumnChart';
@@ -0,0 +1,142 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ //@ts-expect-error[untyped-import]
4
+ import Highcharts from 'highcharts';
5
+ //@ts-expect-error[untyped-import]
6
+ import HighchartsReact from 'highcharts-react-official';
7
+ import type {
8
+ ChartOptions,
9
+ Drilldown,
10
+ LegendOptionsType,
11
+ SeriesOptionsType,
12
+ } from '../../../types/charts';
13
+ import {
14
+ getDataVizColor,
15
+ getDonutChartOptions,
16
+ mergeChartUserOptions,
17
+ } from '../../../utils/charts';
18
+ import classify from '../../../utils/classify';
19
+ import type {ChartWrapperClassNames, ExportOptionType} from '../ChartWrapper';
20
+ import {ChartWrapper} from '../ChartWrapper';
21
+ import typographyCss from '../../../styles/typography.module.css';
22
+ import css from './DonutChart.module.css';
23
+ export type ClassNames = $ReadOnly<
24
+ ChartWrapperClassNames & {
25
+ highChart?: string;
26
+ subtitleClassNames?: SubtitleClassNames;
27
+ }
28
+ >;
29
+ export type SubtitleClassNames = {
30
+ wrapper?: string;
31
+ text?: string;
32
+ subtext?: string;
33
+ };
34
+ export type DonutChartProps = ChartOptions & {
35
+ isLoading?: boolean;
36
+ classNames?: ClassNames;
37
+ cardTitle?: React.ReactNode;
38
+ customExportOptions?: Array<ExportOptionType> | null;
39
+ headerActions?: React.ReactNode;
40
+ centerText?: string;
41
+ centerSubtext?: string;
42
+ series: Array<SeriesOptionsType>;
43
+ drilldown?: Drilldown;
44
+ legend?: LegendOptionsType;
45
+ hasEmptyData?: boolean;
46
+ emptyText?: React.ReactNode;
47
+ };
48
+ export const DonutChart = ({
49
+ isLoading,
50
+ classNames,
51
+ cardTitle,
52
+ customExportOptions,
53
+ headerActions,
54
+ series,
55
+ drilldown,
56
+ legend,
57
+ centerText,
58
+ centerSubtext,
59
+ hasEmptyData,
60
+ emptyText,
61
+ ...userOptions
62
+ }: DonutChartProps): React.ReactNode => {
63
+ const chartRef = React.useRef();
64
+ const {highChart, subtitleClassNames, ...wrapperClassNames} =
65
+ classNames || {};
66
+ const defaultCenterHTML = `<span class=${classify(
67
+ css.subtitleWrap,
68
+ subtitleClassNames?.wrapper,
69
+ )}>
70
+ <span class="${classify(
71
+ typographyCss.jumboMedium,
72
+ css.subtitleText,
73
+ subtitleClassNames?.text,
74
+ )}">
75
+ ${centerText ? centerText : ''}
76
+ </span>
77
+ <span class="${classify(
78
+ typographyCss.bodySmall,
79
+ css.subtitleSubtext,
80
+ subtitleClassNames?.subtext,
81
+ )}">
82
+ ${centerSubtext ? centerSubtext : ''}
83
+ </span>
84
+ <span>`;
85
+ const donutChartSeries = series.map((seriesItem) => ({
86
+ ...seriesItem,
87
+ data: seriesItem.data.map((dataItem, index) => ({
88
+ ...dataItem,
89
+ color: getDataVizColor(index),
90
+ })),
91
+ }));
92
+
93
+ const addColorToDrilldownSeries = (series) =>
94
+ series?.map((seriesItem) => ({
95
+ ...seriesItem,
96
+ data: seriesItem.data.map((dataItem, index) => ({
97
+ ...dataItem,
98
+ color: getDataVizColor(index),
99
+ })),
100
+ }));
101
+
102
+ const donutDrilldown = drilldown
103
+ ? {
104
+ ...drilldown,
105
+ series: addColorToDrilldownSeries(drilldown.series),
106
+ breadcrumbs: {
107
+ floating: false,
108
+ },
109
+ }
110
+ : {};
111
+ const defaultLineChartOptions = getDonutChartOptions({
112
+ legend,
113
+ defaultCenterHTML,
114
+ });
115
+ //$FlowFixMe[cannot-spread-inexact]
116
+ const chartOptions = mergeChartUserOptions(defaultLineChartOptions, {
117
+ series: donutChartSeries,
118
+ drilldown: donutDrilldown,
119
+ ...userOptions,
120
+ });
121
+ return (
122
+ <ChartWrapper
123
+ isLoading={isLoading}
124
+ title={cardTitle}
125
+ ref={chartRef}
126
+ customExportOptions={customExportOptions}
127
+ headerActions={headerActions}
128
+ classNames={wrapperClassNames}
129
+ hasEmptyData={hasEmptyData}
130
+ emptyText={emptyText}
131
+ >
132
+ <HighchartsReact
133
+ highcharts={Highcharts}
134
+ containerProps={{
135
+ className: classify(css.donutChartContainer, highChart),
136
+ }}
137
+ ref={chartRef}
138
+ options={chartOptions}
139
+ />
140
+ </ChartWrapper>
141
+ );
142
+ };
@@ -0,0 +1 @@
1
+ export * from './DonutChart';
@@ -0,0 +1,99 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ //@ts-expect-error[untyped-import]
4
+ import Highcharts from 'highcharts';
5
+ //@ts-expect-error[untyped-import]
6
+ import Funnel from 'highcharts/modules/funnel';
7
+ //@ts-expect-error[untyped-import]
8
+ import HighchartsReact from 'highcharts-react-official';
9
+ import type {
10
+ ChartOptions,
11
+ DataOptionsType,
12
+ Drilldown,
13
+ } from '../../../types/charts';
14
+ import {mergeChartUserOptions} from '../../../utils/charts';
15
+ import {
16
+ addColorsToFunnelDrilldownSeries,
17
+ addColorsToFunnelSeries,
18
+ getFunnelChartOptions,
19
+ } from '../../../utils/charts/funnelChart';
20
+ import classify from '../../../utils/classify';
21
+ import type {ChartWrapperClassNames, ExportOptionType} from '../ChartWrapper';
22
+ import {ChartWrapper} from '../ChartWrapper';
23
+ import css from './FunnelChart.module.css';
24
+ export type ClassNames = $ReadOnly<
25
+ ChartWrapperClassNames & {
26
+ highChart?: string;
27
+ }
28
+ >;
29
+ export type FunnelSeriesItem = {
30
+ name?: string;
31
+ showInLegend?: boolean;
32
+ data: Array<DataOptionsType>;
33
+ };
34
+ export type FunnelChartProps = ChartOptions & {
35
+ isLoading?: boolean;
36
+ classNames?: ClassNames;
37
+ cardTitle?: React.ReactNode;
38
+ customExportOptions?: Array<ExportOptionType> | null;
39
+ series: Array<FunnelSeriesItem>;
40
+ headerActions?: React.ReactNode;
41
+ drilldown?: Drilldown;
42
+ showLegend?: boolean;
43
+ hasEmptyData?: boolean;
44
+ emptyText?: React.ReactNode;
45
+ };
46
+ export const FunnelChart = ({
47
+ isLoading,
48
+ classNames,
49
+ cardTitle,
50
+ customExportOptions,
51
+ series,
52
+ headerActions,
53
+ drilldown,
54
+ showLegend = true,
55
+ hasEmptyData,
56
+ emptyText,
57
+ ...userOptions
58
+ }: FunnelChartProps): React.ReactNode => {
59
+ Funnel(Highcharts);
60
+ const chartRef = React.createRef();
61
+ const funnelChartSeries = addColorsToFunnelSeries(series, showLegend);
62
+ const defaultFunnelChartOptions = getFunnelChartOptions();
63
+ const columnDrilldown = drilldown
64
+ ? {
65
+ ...addColorsToFunnelDrilldownSeries(drilldown, showLegend),
66
+ breadcrumbs: {
67
+ floating: false,
68
+ },
69
+ }
70
+ : {};
71
+ //$FlowFixMe[cannot-spread-inexact]
72
+ const chartOptions = mergeChartUserOptions(defaultFunnelChartOptions, {
73
+ series: funnelChartSeries,
74
+ drilldown: columnDrilldown,
75
+ ...userOptions,
76
+ });
77
+ const {highChart, ...wrapperClassNames} = classNames || {};
78
+ return (
79
+ <ChartWrapper
80
+ isLoading={isLoading}
81
+ title={cardTitle}
82
+ ref={chartRef}
83
+ classNames={wrapperClassNames}
84
+ customExportOptions={customExportOptions}
85
+ headerActions={headerActions}
86
+ hasEmptyData={hasEmptyData}
87
+ emptyText={emptyText}
88
+ >
89
+ <HighchartsReact
90
+ highcharts={Highcharts}
91
+ containerProps={{
92
+ className: classify(css.funnelChartContainer, highChart),
93
+ }}
94
+ ref={chartRef}
95
+ options={chartOptions}
96
+ />
97
+ </ChartWrapper>
98
+ );
99
+ };
@@ -0,0 +1 @@
1
+ export * from './FunnelChart';
@@ -0,0 +1,97 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ //@ts-expect-error[untyped-import]
4
+ import Highcharts from 'highcharts';
5
+ //@ts-expect-error[untyped-import]
6
+ import HighchartsReact from 'highcharts-react-official';
7
+ import type {
8
+ ChartOptions,
9
+ DataOptionsType,
10
+ Drilldown,
11
+ } from '../../../types/charts';
12
+ import {
13
+ getDataVizColor,
14
+ getLineChartOptions,
15
+ mergeChartUserOptions,
16
+ } from '../../../utils/charts';
17
+ import classify from '../../../utils/classify';
18
+ import type {ChartWrapperClassNames, ExportOptionType} from '../ChartWrapper';
19
+ import {ChartWrapper} from '../ChartWrapper';
20
+ import css from './LineChart.module.css';
21
+ export type ClassNames = $ReadOnly<
22
+ ChartWrapperClassNames & {
23
+ highChart?: string;
24
+ }
25
+ >;
26
+ export type LineSeriesItem = {
27
+ name: string;
28
+ data: DataOptionsType[];
29
+ };
30
+ export type LineChartProps = ChartOptions & {
31
+ isLoading?: boolean;
32
+ classNames?: ClassNames;
33
+ cardTitle?: React.ReactNode;
34
+ customExportOptions?: Array<ExportOptionType> | null;
35
+ series: Array<LineSeriesItem>;
36
+ headerActions?: React.ReactNode;
37
+ drilldown?: Drilldown;
38
+ hasEmptyData?: boolean;
39
+ emptyText?: React.ReactNode;
40
+ };
41
+ export const LineChart = ({
42
+ isLoading,
43
+ classNames,
44
+ cardTitle,
45
+ customExportOptions,
46
+ series,
47
+ headerActions,
48
+ drilldown,
49
+ hasEmptyData,
50
+ emptyText,
51
+ ...userOptions
52
+ }: LineChartProps): React.ReactNode => {
53
+ const chartRef = React.createRef();
54
+ const lineChartSeries = series.map((seriesItem, index) => ({
55
+ ...seriesItem,
56
+ name: seriesItem.name,
57
+ data: seriesItem.data,
58
+ color: getDataVizColor(index),
59
+ }));
60
+ const defaultLineChartOptions = getLineChartOptions();
61
+ const columnDrilldown = drilldown
62
+ ? {
63
+ ...drilldown,
64
+ breadcrumbs: {
65
+ floating: false,
66
+ },
67
+ }
68
+ : {};
69
+ //$FlowFixMe[cannot-spread-inexact]
70
+ const chartOptions = mergeChartUserOptions(defaultLineChartOptions, {
71
+ series: lineChartSeries,
72
+ drilldown: columnDrilldown,
73
+ ...userOptions,
74
+ });
75
+ const {highChart, ...wrapperClassNames} = classNames || {};
76
+ return (
77
+ <ChartWrapper
78
+ isLoading={isLoading}
79
+ title={cardTitle}
80
+ ref={chartRef}
81
+ classNames={wrapperClassNames}
82
+ customExportOptions={customExportOptions}
83
+ headerActions={headerActions}
84
+ hasEmptyData={hasEmptyData}
85
+ emptyText={emptyText}
86
+ >
87
+ <HighchartsReact
88
+ highcharts={Highcharts}
89
+ containerProps={{
90
+ className: classify(css.lineChartContainer, highChart),
91
+ }}
92
+ ref={chartRef}
93
+ options={chartOptions}
94
+ />
95
+ </ChartWrapper>
96
+ );
97
+ };
@@ -0,0 +1 @@
1
+ export * from './LineChart';
@@ -0,0 +1,95 @@
1
+ import {$ReadOnly} from 'utility-types';
2
+ import * as React from 'react';
3
+ //@ts-expect-error[untyped-import]
4
+ import Highcharts from 'highcharts';
5
+ //@ts-expect-error[untyped-import]
6
+ import highChartsMore from 'highcharts/highcharts-more';
7
+ //@ts-expect-error[untyped-import]
8
+ import HighchartsReact from 'highcharts-react-official';
9
+ import type {ChartOptions, DataOptionsType} from '../../../types/charts';
10
+ import {
11
+ getDataVizColor,
12
+ getSpiderChartOptions,
13
+ mergeChartUserOptions,
14
+ } from '../../../utils/charts';
15
+ import classify from '../../../utils/classify';
16
+ import type {ChartWrapperClassNames, ExportOptionType} from '../ChartWrapper';
17
+ import {ChartWrapper} from '../ChartWrapper';
18
+ import css from './SpiderChart.module.css';
19
+
20
+ if (
21
+ !!highChartsMore &&
22
+ !!Highcharts &&
23
+ typeof highChartsMore === 'function' &&
24
+ typeof Highcharts === 'object'
25
+ ) {
26
+ highChartsMore(Highcharts);
27
+ }
28
+
29
+ export type ClassNames = $ReadOnly<
30
+ ChartWrapperClassNames & {
31
+ highChart?: string;
32
+ }
33
+ >;
34
+ export type SpiderSeriesItem = {
35
+ name: string;
36
+ data: DataOptionsType[];
37
+ };
38
+ export type SpiderChartProps = ChartOptions & {
39
+ isLoading?: boolean;
40
+ classNames?: ClassNames;
41
+ cardTitle?: React.ReactNode;
42
+ customExportOptions?: Array<ExportOptionType> | null;
43
+ headerActions?: React.ReactNode;
44
+ series: Array<SpiderSeriesItem>;
45
+ hasEmptyData?: boolean;
46
+ emptyText?: React.ReactNode;
47
+ };
48
+ export const SpiderChart = ({
49
+ isLoading,
50
+ classNames,
51
+ cardTitle,
52
+ customExportOptions,
53
+ headerActions,
54
+ series,
55
+ hasEmptyData,
56
+ emptyText,
57
+ ...userOptions
58
+ }: SpiderChartProps): React.ReactNode => {
59
+ const chartRef = React.useRef(null);
60
+ const spiderSeries = series.map((seriesItem, index) => ({
61
+ ...seriesItem,
62
+ name: seriesItem.name,
63
+ data: seriesItem.data,
64
+ pointPlacement: 'on',
65
+ color: getDataVizColor(index),
66
+ }));
67
+ const defaultSpiderChartOptions = getSpiderChartOptions();
68
+ //$FlowFixMe[cannot-spread-inexact]
69
+ const chartOptions = mergeChartUserOptions(defaultSpiderChartOptions, {
70
+ series: spiderSeries,
71
+ ...userOptions,
72
+ });
73
+ const {highChart, ...wrapperClassNames} = classNames || {};
74
+ return (
75
+ <ChartWrapper
76
+ isLoading={isLoading}
77
+ title={cardTitle}
78
+ ref={chartRef}
79
+ customExportOptions={customExportOptions}
80
+ classNames={wrapperClassNames}
81
+ headerActions={headerActions}
82
+ hasEmptyData={hasEmptyData}
83
+ emptyText={emptyText}
84
+ >
85
+ <HighchartsReact
86
+ highcharts={Highcharts}
87
+ ref={chartRef}
88
+ containerProps={{
89
+ className: classify(css.spiderChartContainer, highChart),
90
+ }}
91
+ options={chartOptions}
92
+ />
93
+ </ChartWrapper>
94
+ );
95
+ };
@@ -0,0 +1 @@
1
+ export * from './SpiderChart';
@@ -0,0 +1,7 @@
1
+ export * from './ChartTooltip';
2
+ export * from './ChartWrapper';
3
+ export * from './ColumnChart';
4
+ export * from './DonutChart';
5
+ export * from './FunnelChart';
6
+ export * from './LineChart';
7
+ export * from './SpiderChart';