@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,116 @@
1
+ import type {ChartOptions, LegendOptionsType} from '../../types/charts';
2
+ import {commonChartOptions} from './charts';
3
+ import {deepMerge} from './helpers';
4
+ type DonutChartPropsType = {
5
+ legend?: LegendOptionsType;
6
+ defaultCenterHTML?: string;
7
+ };
8
+
9
+ /**
10
+ * Defining these constants here so that internal calculations are self explanatory.
11
+ */
12
+ const INNER_SIZE = 0.5; // set .5 here for 50% inner size w.r.t the pie chart outer circle.
13
+
14
+ const LEGEND_WIDTH = 0.4; // set .4 here for 40% legend width w.r.t the plot width.
15
+
16
+ const CHART_WIDTH = 1 - LEGEND_WIDTH;
17
+ const CHART_CENTER = (1 - LEGEND_WIDTH) / 2;
18
+ const CHART_SIZE = 0.8; // chart size w.r.t area allocated to chart drawing;
19
+
20
+ export const rightLegendColumn = {
21
+ layout: 'vertical',
22
+ align: 'right',
23
+ verticalAlign: 'middle',
24
+ itemMarginBottom: 12,
25
+ symbolPadding: 8,
26
+ symbolWidth: 8,
27
+ // take it as 10% of width as left margin
28
+ width: `${LEGEND_WIDTH * 90}%`,
29
+ };
30
+
31
+ /**
32
+ * This function modifies the the common chart behavior to donut chart default behavior.
33
+ * It will not take userPassed option into account.
34
+ */
35
+ export const getDonutChartOptions = ({
36
+ legend,
37
+ defaultCenterHTML,
38
+ }: DonutChartPropsType): ChartOptions => {
39
+ const legendOption = deepMerge(commonChartOptions.legend, legend);
40
+ const isLegendEnabled = legendOption.enabled;
41
+ return {
42
+ ...commonChartOptions,
43
+ chart: {
44
+ ...commonChartOptions.chart,
45
+ type: 'pie',
46
+ spacing: [0, 0, 0, 0],
47
+ margin: [0, 0, 0, 0],
48
+ events: {
49
+ render() {
50
+ //$FlowFixMe[object-this-reference]
51
+ const chart = this;
52
+ const containerWidth = chart.renderTo.offsetWidth;
53
+ const desiredHeight = CHART_WIDTH * containerWidth;
54
+ // 5px adjustment required due to borderWidth mostly.
55
+ const centerTextX = isLegendEnabled
56
+ ? parseInt(chart.plotWidth) * CHART_CENTER + 5
57
+ : 0;
58
+ chart.update(
59
+ {
60
+ chart: {
61
+ height: desiredHeight, // Set the height dynamically based on the container's width
62
+ },
63
+ subtitle: {
64
+ x: centerTextX,
65
+ },
66
+ },
67
+ false,
68
+ );
69
+ },
70
+ },
71
+ },
72
+ legend: {...legendOption, ...rightLegendColumn},
73
+ plotOptions: {
74
+ pie: {
75
+ innerSize: `${INNER_SIZE * 100}%`,
76
+ allowPointSelect: true,
77
+ cursor: 'pointer',
78
+ dataLabels: {
79
+ // auto disabling the data label when legend is enabled.
80
+ enabled: !isLegendEnabled,
81
+ distance: 20,
82
+ },
83
+ showInLegend: true,
84
+ center: isLegendEnabled
85
+ ? [`${CHART_CENTER * 100}%`, '50%']
86
+ : ['50%', '50%'],
87
+ size: `${CHART_SIZE * 100}%`,
88
+ borderWidth: 5,
89
+ borderRadius: 10,
90
+ minSize: 240,
91
+ clip: false,
92
+ },
93
+ },
94
+ subtitle: {
95
+ useHTML: true,
96
+ text: defaultCenterHTML,
97
+ verticalAlign: 'middle',
98
+ align: isLegendEnabled ? 'left' : 'center',
99
+ style: {
100
+ alignContent: 'center',
101
+ // Note: Width was not working, have given miWidth and maxWidth
102
+ minWidth: isLegendEnabled
103
+ ? `${CHART_WIDTH * CHART_SIZE * INNER_SIZE * 80}%`
104
+ : `${CHART_SIZE * INNER_SIZE * 80}%`,
105
+ maxWidth: isLegendEnabled
106
+ ? `${CHART_WIDTH * CHART_SIZE * INNER_SIZE * 80}%`
107
+ : `${CHART_SIZE * INNER_SIZE * 80}%`,
108
+ ...(isLegendEnabled
109
+ ? {
110
+ transform: 'translate(-50%)',
111
+ }
112
+ : {}),
113
+ },
114
+ },
115
+ };
116
+ };
@@ -0,0 +1,94 @@
1
+ import type {FunnelSeriesItem} from '../../components/Charts/FunnelChart/FunnelChart';
2
+ import {colorBorderPrimary} from '../../styles/variables/_color';
3
+ import type {
4
+ ChartOptions,
5
+ DataOptionsType,
6
+ Drilldown,
7
+ } from '../../types/charts';
8
+ import {commonChartOptions, getDataVizColor} from './charts';
9
+ import {
10
+ bottomLegendRow,
11
+ xAxisTitleStyle,
12
+ yAxisLabelStyle,
13
+ yAxisTitleStyle,
14
+ } from './helpers';
15
+ import {formLabelSmall} from './typography';
16
+
17
+ /**
18
+ * This function modifies the the common chart behavior to funnel chart default behavior.
19
+ * It will not take userPassed option into account.
20
+ */
21
+ export const getFunnelChartOptions = (): ChartOptions => ({
22
+ ...commonChartOptions,
23
+ chart: {
24
+ type: 'funnel',
25
+ },
26
+ legend: {...commonChartOptions.legend, ...bottomLegendRow, symbolWidth: 18},
27
+ xAxis: {
28
+ ...commonChartOptions.xAxis,
29
+ labels: {
30
+ style: formLabelSmall,
31
+ },
32
+ title: {
33
+ margin: 12,
34
+ style: xAxisTitleStyle,
35
+ },
36
+ lineColor: colorBorderPrimary,
37
+ },
38
+ yAxis: {
39
+ labels: {
40
+ align: 'right',
41
+ distance: 12,
42
+ style: yAxisLabelStyle,
43
+ },
44
+ title: {
45
+ margin: 12,
46
+ style: yAxisTitleStyle,
47
+ },
48
+ },
49
+ plotOptions: {
50
+ funnel: {
51
+ neckWidth: '15%',
52
+ neckHeight: '10%',
53
+ minSize: '50%',
54
+ width: '55%',
55
+ dataLabels: {
56
+ enabled: true,
57
+ useHTML: true,
58
+ // Allows custom HTML formatting
59
+ format: `<div style="text-align: center">
60
+ <span>{point.name}</span><br>
61
+ <span>{point.y}</span>
62
+ </div>`,
63
+ style: {
64
+ fontWeight: 'bold',
65
+ },
66
+ },
67
+ },
68
+ },
69
+ });
70
+ export const addColorsToFunnelSeries = (
71
+ series: Array<FunnelSeriesItem>,
72
+ showInLegend: boolean = true,
73
+ ): Array<FunnelSeriesItem> =>
74
+ series.map((item: FunnelSeriesItem) => ({
75
+ ...item,
76
+ data: item.data.map((seriesItem: DataOptionsType, index: number) => ({
77
+ ...seriesItem,
78
+ color: getDataVizColor(index), // Apply color based on index
79
+ })),
80
+ showInLegend, // Ensure legend visibility
81
+ }));
82
+ export const addColorsToFunnelDrilldownSeries = (
83
+ drilldownSeries: Drilldown,
84
+ showInLegend: boolean = true,
85
+ ): Drilldown => ({
86
+ series: drilldownSeries.series?.map((series) => ({
87
+ ...series,
88
+ data: series.data.map((dataPoint, index) => ({
89
+ ...dataPoint,
90
+ color: getDataVizColor(index), // Assign a color dynamically based on index
91
+ })),
92
+ showInLegend, // Ensure legend is displayed
93
+ })),
94
+ });
@@ -0,0 +1,44 @@
1
+ import {$Shape} from 'utility-types';
2
+ import merge from 'lodash/merge';
3
+ import {
4
+ colorTextPrimary,
5
+ colorTextSecondary,
6
+ } from '../../styles/variables/_color';
7
+ import {
8
+ bodySmall,
9
+ buttonTextExtraSmall,
10
+ formLabelSmall,
11
+ underline,
12
+ } from './typography';
13
+ export const deepMerge = <T extends {}>(
14
+ obj1?: $Shape<T>,
15
+ obj2?: $Shape<T>,
16
+ ...args: Array<$Shape<T> | null | undefined>
17
+ ): T => merge({}, obj1, obj2, ...args); // {} is used here to ensure obj1 is not modified
18
+ export const rightLineLegendColumn = {
19
+ layout: 'vertical',
20
+ align: 'right',
21
+ verticalAlign: 'middle',
22
+ itemMarginBottom: 12,
23
+ symbolPadding: 4,
24
+ symbolWidth: 16,
25
+ width: '40%',
26
+ };
27
+ export const bottomLegendRow = {
28
+ layout: 'horizontal',
29
+ align: 'center',
30
+ verticalAlign: 'bottom',
31
+ itemDistance: 20,
32
+ symbolPadding: 4,
33
+ symbolWidth: 16,
34
+ };
35
+ export const yAxisTitleStyle = {...bodySmall, color: colorTextSecondary};
36
+ export const xAxisTitleStyle = {...bodySmall, color: colorTextSecondary};
37
+ export const yAxisLabelStyle = {...formLabelSmall};
38
+ export const xAxisLabelStyle = {...buttonTextExtraSmall};
39
+ export const activeLabelStyle = {
40
+ ...buttonTextExtraSmall,
41
+ ...underline,
42
+ color: colorTextPrimary,
43
+ fill: colorTextPrimary,
44
+ };
@@ -0,0 +1,7 @@
1
+ export * from './charts';
2
+ export * from './columnChart';
3
+ export * from './donutChart';
4
+ export * from './helpers';
5
+ export * from './lineChart';
6
+ export * from './spiderChart';
7
+ export * from './typography';
@@ -0,0 +1,44 @@
1
+ import {colorBorderPrimary} from '../../styles/variables/_color';
2
+ import type {ChartOptions} from '../../types/charts';
3
+ import {commonChartOptions} from './charts';
4
+ import {
5
+ bottomLegendRow,
6
+ xAxisTitleStyle,
7
+ yAxisLabelStyle,
8
+ yAxisTitleStyle,
9
+ } from './helpers';
10
+ import {formLabelSmall} from './typography';
11
+
12
+ /**
13
+ * This function modifies the the common chart behavior to line chart default behavior.
14
+ * It will not take userPassed option into account.
15
+ */
16
+ export const getLineChartOptions = (): ChartOptions => ({
17
+ ...commonChartOptions,
18
+ chart: {
19
+ type: 'line',
20
+ },
21
+ legend: {...commonChartOptions.legend, ...bottomLegendRow, symbolWidth: 18},
22
+ xAxis: {
23
+ ...commonChartOptions.xAxis,
24
+ labels: {
25
+ style: formLabelSmall,
26
+ },
27
+ title: {
28
+ margin: 12,
29
+ style: xAxisTitleStyle,
30
+ },
31
+ lineColor: colorBorderPrimary,
32
+ },
33
+ yAxis: {
34
+ labels: {
35
+ align: 'right',
36
+ distance: 12,
37
+ style: yAxisLabelStyle,
38
+ },
39
+ title: {
40
+ margin: 12,
41
+ style: yAxisTitleStyle,
42
+ },
43
+ },
44
+ });
@@ -0,0 +1,46 @@
1
+ import {colorTextSecondary} from '../../styles/variables/_color';
2
+ import type {ChartOptions} from '../../types/charts';
3
+ import {commonChartOptions} from './charts';
4
+ import {rightLineLegendColumn} from './helpers';
5
+ import {bodySmall} from './typography';
6
+ export const bodySmallSecondary = {...bodySmall, color: colorTextSecondary};
7
+
8
+ /**
9
+ * This function modifies the the common chart behavior to spider chart default behavior.
10
+ * It will not take userPassed option into account.
11
+ */
12
+ export const getSpiderChartOptions = (): ChartOptions => ({
13
+ ...commonChartOptions,
14
+ chart: {
15
+ ...commonChartOptions.chart,
16
+ polar: true,
17
+ type: 'line',
18
+ spacing: [0, 0, 0, 0],
19
+ margin: [0, 0, 0, 0],
20
+ },
21
+ xAxis: {
22
+ ...commonChartOptions.xAxis,
23
+ labels: {
24
+ style: bodySmallSecondary,
25
+ },
26
+ lineWidth: 0,
27
+ tickmarkPlacement: 'on',
28
+ },
29
+ yAxis: {
30
+ labels: {
31
+ style: bodySmallSecondary,
32
+ },
33
+ gridLineInterpolation: 'polygon',
34
+ lineWidth: 0,
35
+ },
36
+ legend: {
37
+ ...commonChartOptions.legend,
38
+ ...rightLineLegendColumn,
39
+ symbolWidth: 18,
40
+ },
41
+ pane: {
42
+ center: ['30%', '50%'],
43
+ size: '70%',
44
+ },
45
+ tooltip: {...commonChartOptions.tooltip, followPointer: false, shared: true},
46
+ });
@@ -0,0 +1,42 @@
1
+ import {colorTextPrimary} from '../../styles/variables/_color';
2
+ import {
3
+ fontLetterSpacing0,
4
+ fontLetterSpacing1,
5
+ fontLetterSpacing4,
6
+ fontSize12,
7
+ fontWeightBook,
8
+ fontWeightMedium,
9
+ } from '../../styles/variables/_font';
10
+ export const baseType = {
11
+ fontFamily: 'Centra No 2',
12
+ fontStyle: 'normal',
13
+ margin: 0,
14
+ color: colorTextPrimary,
15
+ letterSpacing: fontLetterSpacing0,
16
+ fontWeight: fontWeightMedium,
17
+ display: 'flex',
18
+ alignItems: 'center',
19
+ };
20
+ export const bodySmall = {
21
+ ...baseType,
22
+ fontSize: fontSize12,
23
+ fontWeight: fontWeightBook,
24
+ letterSpacing: fontLetterSpacing4,
25
+ };
26
+ export const formLabelSmall = {
27
+ ...baseType,
28
+ fontSize: fontSize12, // Removing the font height as its breaking the chart axis labels
29
+ };
30
+ export const buttonTextExtraSmall = {
31
+ ...baseType,
32
+ fontSize: fontSize12,
33
+ letterSpacing: fontLetterSpacing1, // Removing the font height as its breaking the chart axis labels
34
+ };
35
+ export const underline = {
36
+ textDecoration: 'underline',
37
+ };
38
+ export const subTitleExtraSmall = {
39
+ ...baseType,
40
+ fontSize: fontSize12,
41
+ letterSpacing: fontLetterSpacing0, // Removing the font height as its breaking the chart axis labels
42
+ };
@@ -0,0 +1,27 @@
1
+ import isPlainObject from 'lodash/isPlainObject';
2
+ import map from 'lodash/map';
3
+ export function classify(...args: Array<unknown>): string {
4
+ return args
5
+ .map((arg) => {
6
+ let mappedArg = arg;
7
+
8
+ if (isPlainObject(arg)) {
9
+ // $FlowFixMe[incompatible-call]
10
+ mappedArg = map(arg, (test, name: string) => (test ? name : null));
11
+ }
12
+
13
+ return mappedArg;
14
+ })
15
+ .reduce((array, current) => {
16
+ if (Array.isArray(current)) {
17
+ array.push(...current);
18
+ } else {
19
+ array.push(current);
20
+ }
21
+
22
+ return array;
23
+ }, [])
24
+ .filter((val) => val)
25
+ .join(' ');
26
+ }
27
+ export default classify;
@@ -0,0 +1,194 @@
1
+ import * as React from 'react';
2
+ import invariant from 'invariant';
3
+ import {pageHeight} from '../dom';
4
+ type BoundaryRefType<T> = {
5
+ current: T | null | undefined;
6
+ };
7
+ type TriggerRefType<T> = {
8
+ current: T | null | undefined;
9
+ };
10
+ export type ChildProps = {
11
+ onOpen: () => void;
12
+ isOpen: boolean;
13
+ height: number | null | undefined;
14
+ pageBottom: number | null | undefined;
15
+ clickAway: () => void;
16
+ boundaryRef: BoundaryRefType<HTMLElement | null | undefined>;
17
+ triggerRef: TriggerRefType<HTMLElement | null | undefined>;
18
+ };
19
+ export type ClickAwayRefType =
20
+ | {
21
+ current:
22
+ | {
23
+ forceClose: () => void;
24
+ forceOpen: () => void;
25
+ }
26
+ | null
27
+ | undefined;
28
+ }
29
+ | null
30
+ | undefined;
31
+ export type ClickAwayProps = {
32
+ closeOnEscapeKeypress?: boolean;
33
+ children: (props: ChildProps) => React.ReactNode;
34
+ onChange?: (isOpen: boolean) => unknown;
35
+ clickAwayRef?: ClickAwayRefType;
36
+ };
37
+ type ClickAwayState = {
38
+ isOpen: boolean;
39
+ height: number | null | undefined;
40
+ pageBottom: number | null | undefined;
41
+ };
42
+ // TODO(Nishant): Make this a functional component
43
+ export class ClickAway extends React.Component<ClickAwayProps, ClickAwayState> {
44
+ static defaultProps: {
45
+ closeOnEscapeKeypress?: boolean;
46
+ } = {
47
+ closeOnEscapeKeypress: true,
48
+ };
49
+ state: ClickAwayState = {
50
+ isOpen: false,
51
+ height: null,
52
+ pageBottom: null,
53
+ };
54
+ el: HTMLElement | null | undefined = null;
55
+ boundaryRef: BoundaryRefType<HTMLElement | null | undefined> =
56
+ React.createRef();
57
+ triggerRef: TriggerRefType<HTMLElement | null | undefined> =
58
+ React.createRef();
59
+
60
+ componentDidMount() {
61
+ if (this.el) {
62
+ this.setState({
63
+ height: this.el.offsetHeight,
64
+ pageBottom: this.pageBottom(),
65
+ });
66
+ }
67
+ }
68
+
69
+ componentDidUpdate(prevProps: ClickAwayProps, prevState: ClickAwayState) {
70
+ const {isOpen} = this.state;
71
+
72
+ if (prevState.isOpen !== isOpen) {
73
+ if (this.state.isOpen) {
74
+ window.document.addEventListener('click', this.handleCloseClick, {
75
+ capture: true,
76
+ });
77
+
78
+ if (this.props.closeOnEscapeKeypress) {
79
+ window.document.addEventListener(
80
+ 'keyup',
81
+ this.handleCloseOnEscapeKeypress,
82
+ );
83
+ }
84
+ } else {
85
+ window.document.removeEventListener('click', this.handleCloseClick, {
86
+ capture: true,
87
+ });
88
+ window.document.removeEventListener(
89
+ 'keyup',
90
+ this.handleCloseOnEscapeKeypress,
91
+ );
92
+ }
93
+ }
94
+ }
95
+
96
+ componentWillUnmount() {
97
+ window.document.removeEventListener('click', this.handleCloseClick, {
98
+ capture: true,
99
+ });
100
+ window.document.removeEventListener(
101
+ 'keyup',
102
+ this.handleCloseOnEscapeKeypress,
103
+ );
104
+ }
105
+
106
+ render(): React.ReactNode {
107
+ const {height, isOpen, pageBottom} = this.state;
108
+ const {clickAwayRef} = this.props;
109
+
110
+ if (clickAwayRef) {
111
+ clickAwayRef.current = {
112
+ forceClose: this.forceClose,
113
+ forceOpen: this.handleOpenClick,
114
+ };
115
+ }
116
+
117
+ return this.props.children({
118
+ onOpen: this.handleOpenClick,
119
+ isOpen,
120
+ height,
121
+ pageBottom,
122
+ clickAway: this.forceClose,
123
+ boundaryRef: this.boundaryRef,
124
+ triggerRef: this.triggerRef,
125
+ });
126
+ }
127
+
128
+ handleOpenClick: () => void = () => {
129
+ // NOTE (kyle): we recalculate the position on click because sibling and niece components
130
+ // could have changed.
131
+ let {pageBottom} = this.state;
132
+
133
+ if (this.el) {
134
+ pageBottom = this.pageBottom();
135
+ }
136
+
137
+ this.setState(
138
+ {
139
+ isOpen: !this.state.isOpen,
140
+ pageBottom,
141
+ },
142
+ this.handleOnChange,
143
+ );
144
+ };
145
+ handleCloseClick: (evt: MouseEvent) => void = (evt: MouseEvent) => {
146
+ if (
147
+ evt.target instanceof Node &&
148
+ this.boundaryRef &&
149
+ (this.boundaryRef === evt.target ||
150
+ this.boundaryRef.current?.contains(evt.target))
151
+ ) {
152
+ return;
153
+ }
154
+
155
+ if (
156
+ evt.target instanceof Node &&
157
+ this.triggerRef &&
158
+ (this.triggerRef === evt.target ||
159
+ this.triggerRef.current?.contains(evt.target))
160
+ ) {
161
+ return;
162
+ }
163
+
164
+ this.setState(
165
+ {
166
+ isOpen: false,
167
+ },
168
+ this.handleOnChange,
169
+ );
170
+ };
171
+ handleCloseOnEscapeKeypress: (
172
+ evt?: React.KeyboardEvent<EventTarget>,
173
+ ) => void = (evt?: React.KeyboardEvent<EventTarget>) => {
174
+ if (evt?.key === 'Escape') {
175
+ this.forceClose();
176
+ }
177
+ };
178
+ forceClose: () => void = () => {
179
+ this.setState(
180
+ {
181
+ isOpen: false,
182
+ },
183
+ this.handleOnChange,
184
+ );
185
+ };
186
+ handleOnChange: () => unknown = () =>
187
+ this.props.onChange && this.props.onChange(this.state.isOpen);
188
+
189
+ pageBottom(): any {
190
+ invariant(this.el, 'pageBottom() requires that this.el not be null');
191
+ const bottomBound = this.el ? this.el.getBoundingClientRect().bottom : 0;
192
+ return pageHeight() - bottomBound + window.scrollY;
193
+ }
194
+ }
@@ -0,0 +1 @@
1
+ export * from './click-away';