@ultraviolet/ui 1.51.1 → 1.51.3

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 (435) hide show
  1. package/dist/components/ActionBar/index.d.ts +20 -0
  2. package/dist/components/ActionBar/index.js +30 -0
  3. package/dist/components/Alert/index.d.ts +27 -0
  4. package/dist/components/Alert/index.js +115 -0
  5. package/dist/components/Avatar/index.d.ts +43 -0
  6. package/dist/components/Avatar/index.js +57 -0
  7. package/dist/components/Badge/index.d.ts +31 -0
  8. package/dist/components/Badge/index.js +99 -0
  9. package/dist/components/Banner/assets/default-image-small.svg.js +4 -0
  10. package/dist/components/Banner/assets/default-image.svg.js +4 -0
  11. package/dist/components/Banner/index.d.ts +24 -0
  12. package/dist/components/Banner/index.js +116 -0
  13. package/dist/components/BarChart/Tooltip.d.ts +9 -0
  14. package/dist/components/BarChart/Tooltip.js +41 -0
  15. package/dist/components/BarChart/index.d.ts +27 -0
  16. package/dist/components/BarChart/index.js +69 -0
  17. package/dist/components/BarStack/index.d.ts +36 -0
  18. package/dist/components/BarStack/index.js +114 -0
  19. package/dist/components/Breadcrumbs/index.d.ts +30 -0
  20. package/dist/components/Breadcrumbs/index.js +73 -0
  21. package/dist/components/Bullet/index.d.ts +39 -0
  22. package/dist/components/Bullet/index.js +84 -0
  23. package/dist/components/Button/index.d.ts +120 -0
  24. package/dist/components/Button/index.js +249 -0
  25. package/dist/components/Card/index.d.ts +20 -0
  26. package/dist/components/Card/index.js +52 -0
  27. package/dist/components/Carousel/index.d.ts +19 -0
  28. package/dist/components/Carousel/index.js +123 -0
  29. package/dist/components/Checkbox/index.d.ts +36 -0
  30. package/dist/components/Checkbox/index.js +262 -0
  31. package/dist/components/CheckboxGroup/index.d.ts +24 -0
  32. package/dist/components/CheckboxGroup/index.js +116 -0
  33. package/dist/components/CopyButton/index.d.ts +19 -0
  34. package/dist/components/CopyButton/index.js +23 -0
  35. package/dist/components/DateInput/datepicker.css.js +4 -0
  36. package/dist/components/DateInput/index.d.ts +38 -0
  37. package/dist/components/DateInput/index.js +182 -0
  38. package/dist/components/Dialog/Context.d.ts +7 -0
  39. package/dist/components/Dialog/Context.js +13 -0
  40. package/dist/components/Dialog/constants.d.ts +2 -0
  41. package/dist/components/Dialog/index.d.ts +87 -0
  42. package/dist/components/Dialog/index.js +66 -0
  43. package/dist/components/Dialog/subComponents/Button.d.ts +7 -0
  44. package/dist/components/Dialog/subComponents/Button.js +15 -0
  45. package/dist/components/Dialog/subComponents/Buttons.d.ts +7 -0
  46. package/dist/components/Dialog/subComponents/Buttons.js +12 -0
  47. package/dist/components/Dialog/subComponents/CancelButton.d.ts +8 -0
  48. package/dist/components/Dialog/subComponents/CancelButton.js +9 -0
  49. package/dist/components/Dialog/subComponents/Stack.d.ts +6 -0
  50. package/dist/components/Dialog/subComponents/Stack.js +8 -0
  51. package/dist/components/Dialog/subComponents/Text.d.ts +6 -0
  52. package/dist/components/Dialog/subComponents/Text.js +8 -0
  53. package/dist/components/EmptyState/index.d.ts +38 -0
  54. package/dist/components/EmptyState/index.js +90 -0
  55. package/dist/components/Expandable/index.d.ts +33 -0
  56. package/dist/components/Expandable/index.js +75 -0
  57. package/dist/components/GlobalAlert/GlobalAlertLink.d.ts +3 -0
  58. package/dist/components/GlobalAlert/GlobalAlertLink.js +23 -0
  59. package/dist/components/GlobalAlert/index.d.ts +40 -0
  60. package/dist/components/GlobalAlert/index.js +59 -0
  61. package/dist/components/LineChart/CustomLegend.d.ts +13 -0
  62. package/dist/components/LineChart/CustomLegend.js +113 -0
  63. package/dist/components/LineChart/Tooltip.d.ts +6 -0
  64. package/dist/components/LineChart/Tooltip.js +35 -0
  65. package/dist/components/LineChart/helpers.d.ts +8 -0
  66. package/dist/{src/components → components}/LineChart/helpers.js +22 -10
  67. package/dist/components/LineChart/index.d.ts +25 -0
  68. package/dist/components/LineChart/index.js +101 -0
  69. package/dist/components/Link/index.d.ts +33 -0
  70. package/dist/components/Link/index.js +128 -0
  71. package/dist/components/List/Body.d.ts +6 -0
  72. package/dist/components/List/Body.js +16 -0
  73. package/dist/components/List/Cell.d.ts +12 -0
  74. package/dist/components/List/Cell.js +41 -0
  75. package/dist/components/List/HeaderCell.d.ts +11 -0
  76. package/dist/components/List/HeaderCell.js +82 -0
  77. package/dist/components/List/HeaderRow.d.ts +7 -0
  78. package/dist/components/List/HeaderRow.js +36 -0
  79. package/dist/components/List/ListContext.d.ts +34 -0
  80. package/dist/{src/components → components}/List/ListContext.js +27 -29
  81. package/dist/components/List/Row.d.ts +23 -0
  82. package/dist/components/List/Row.js +161 -0
  83. package/dist/components/List/SelectBar.d.ts +15 -0
  84. package/dist/components/List/SelectBar.js +52 -0
  85. package/dist/components/List/SkeletonRows.d.ts +7 -0
  86. package/dist/components/List/SkeletonRows.js +55 -0
  87. package/dist/components/List/constants.d.ts +2 -0
  88. package/dist/{src/components → components}/List/constants.js +4 -2
  89. package/dist/components/List/index.d.ts +68 -0
  90. package/dist/components/List/index.js +60 -0
  91. package/dist/components/Loader/index.d.ts +22 -0
  92. package/dist/components/Loader/index.js +77 -0
  93. package/dist/components/Menu/Item.d.ts +15 -0
  94. package/dist/components/Menu/Item.js +91 -0
  95. package/dist/components/Menu/index.d.ts +49 -0
  96. package/dist/components/Menu/index.js +116 -0
  97. package/dist/components/MenuV2/Group.d.ts +7 -0
  98. package/dist/components/MenuV2/Group.js +21 -0
  99. package/dist/components/MenuV2/Item.d.ts +16 -0
  100. package/dist/components/MenuV2/Item.js +113 -0
  101. package/dist/components/MenuV2/index.d.ts +90 -0
  102. package/dist/components/MenuV2/index.js +90 -0
  103. package/dist/components/Meter/index.d.ts +26 -0
  104. package/dist/components/Meter/index.js +63 -0
  105. package/dist/components/Modal/Dialog.d.ts +3 -0
  106. package/dist/components/Modal/Dialog.js +141 -0
  107. package/dist/components/Modal/Disclosure.d.ts +3 -0
  108. package/dist/{src/components → components}/Modal/Disclosure.js +12 -12
  109. package/dist/components/Modal/constants.d.ts +3 -0
  110. package/dist/{src/components → components}/Modal/constants.js +8 -6
  111. package/dist/components/Modal/index.d.ts +42 -0
  112. package/dist/components/Modal/index.js +79 -0
  113. package/dist/components/Modal/types.d.ts +48 -0
  114. package/dist/components/Notice/index.d.ts +11 -0
  115. package/dist/components/Notice/index.js +23 -0
  116. package/dist/components/Notification/index.d.ts +36 -0
  117. package/dist/components/Notification/index.js +49 -0
  118. package/dist/components/Notification/react-toastify.css.js +4 -0
  119. package/dist/components/NumberInput/helpers.d.ts +4 -0
  120. package/dist/{src/components → components}/NumberInput/helpers.js +6 -2
  121. package/dist/components/NumberInput/index.d.ts +41 -0
  122. package/dist/components/NumberInput/index.js +262 -0
  123. package/dist/components/NumberInputV2/index.d.ts +27 -0
  124. package/dist/components/NumberInputV2/index.js +221 -0
  125. package/dist/components/Pagination/getPageNumbers.d.ts +8 -0
  126. package/dist/{src/components → components}/Pagination/getPageNumbers.js +3 -9
  127. package/dist/components/Pagination/index.d.ts +30 -0
  128. package/dist/components/Pagination/index.js +88 -0
  129. package/dist/components/PasswordCheck/index.d.ts +20 -0
  130. package/dist/components/PasswordCheck/index.js +24 -0
  131. package/dist/components/PasswordStrengthMeter/index.d.ts +39 -0
  132. package/dist/components/PasswordStrengthMeter/index.js +96 -0
  133. package/dist/components/PieChart/Legends.d.ts +9 -0
  134. package/dist/components/PieChart/Legends.js +142 -0
  135. package/dist/components/PieChart/Tooltip.d.ts +12 -0
  136. package/dist/components/PieChart/Tooltip.js +49 -0
  137. package/dist/components/PieChart/index.d.ts +20 -0
  138. package/dist/components/PieChart/index.js +101 -0
  139. package/dist/components/PieChart/types.d.ts +7 -0
  140. package/dist/components/Popover/index.d.ts +55 -0
  141. package/dist/components/Popover/index.js +100 -0
  142. package/dist/components/Popup/animations.d.ts +11 -0
  143. package/dist/{src/components → components}/Popup/animations.js +7 -6
  144. package/dist/components/Popup/helpers.d.ts +31 -0
  145. package/dist/components/Popup/helpers.js +216 -0
  146. package/dist/components/Popup/index.d.ts +72 -0
  147. package/dist/components/Popup/index.js +297 -0
  148. package/dist/components/ProgressBar/index.d.ts +14 -0
  149. package/dist/components/ProgressBar/index.js +53 -0
  150. package/dist/components/Radio/index.d.ts +21 -0
  151. package/dist/components/Radio/index.js +133 -0
  152. package/dist/components/RadioGroup/index.d.ts +25 -0
  153. package/dist/components/RadioGroup/index.js +99 -0
  154. package/dist/components/Row/index.d.ts +22 -0
  155. package/dist/components/Row/index.js +34 -0
  156. package/dist/components/SelectInput/index.d.ts +75 -0
  157. package/dist/components/SelectInput/index.js +516 -0
  158. package/dist/components/SelectInputV2/Dropdown.d.ts +23 -0
  159. package/dist/components/SelectInputV2/Dropdown.js +429 -0
  160. package/dist/components/SelectInputV2/DropdownOption.d.ts +8 -0
  161. package/dist/components/SelectInputV2/DropdownOption.js +62 -0
  162. package/dist/components/SelectInputV2/SearchBarDropdown.d.ts +9 -0
  163. package/dist/components/SelectInputV2/SearchBarDropdown.js +107 -0
  164. package/dist/components/SelectInputV2/SelectBar.d.ts +14 -0
  165. package/dist/components/SelectInputV2/SelectBar.js +224 -0
  166. package/dist/components/SelectInputV2/SelectInputProvider.d.ts +41 -0
  167. package/dist/{src/components → components}/SelectInputV2/SelectInputProvider.js +38 -36
  168. package/dist/components/SelectInputV2/findOptionInOptions.d.ts +2 -0
  169. package/dist/components/SelectInputV2/findOptionInOptions.js +12 -0
  170. package/dist/components/SelectInputV2/index.d.ts +115 -0
  171. package/dist/components/SelectInputV2/index.js +87 -0
  172. package/dist/components/SelectInputV2/types.d.ts +38 -0
  173. package/dist/{src/components → components}/SelectInputV2/types.js +4 -2
  174. package/dist/components/SelectableCard/index.d.ts +25 -0
  175. package/dist/components/SelectableCard/index.js +137 -0
  176. package/dist/components/SelectableCardGroup/index.d.ts +23 -0
  177. package/dist/components/SelectableCardGroup/index.js +107 -0
  178. package/dist/components/Separator/index.d.ts +17 -0
  179. package/dist/components/Separator/index.js +56 -0
  180. package/dist/components/Skeleton/Block.d.ts +3 -0
  181. package/dist/components/Skeleton/Block.js +38 -0
  182. package/dist/components/Skeleton/Blocks.d.ts +4 -0
  183. package/dist/components/Skeleton/Blocks.js +38 -0
  184. package/dist/components/Skeleton/BoxWithIcon.d.ts +4 -0
  185. package/dist/components/Skeleton/BoxWithIcon.js +36 -0
  186. package/dist/components/Skeleton/Donut.d.ts +1 -0
  187. package/dist/components/Skeleton/Donut.js +61 -0
  188. package/dist/components/Skeleton/IconSkeleton.d.ts +5 -0
  189. package/dist/components/Skeleton/IconSkeleton.js +22 -0
  190. package/dist/components/Skeleton/Line.d.ts +5 -0
  191. package/dist/components/Skeleton/Line.js +16 -0
  192. package/dist/components/Skeleton/List.d.ts +4 -0
  193. package/dist/components/Skeleton/List.js +56 -0
  194. package/dist/components/Skeleton/Slider.d.ts +3 -0
  195. package/dist/components/Skeleton/Slider.js +40 -0
  196. package/dist/components/Skeleton/Square.d.ts +5 -0
  197. package/dist/components/Skeleton/Square.js +12 -0
  198. package/dist/components/Skeleton/index.d.ts +47 -0
  199. package/dist/components/Skeleton/index.js +79 -0
  200. package/dist/components/Snippet/index.d.ts +23 -0
  201. package/dist/components/Snippet/index.js +182 -0
  202. package/dist/components/Stack/index.d.ts +23 -0
  203. package/dist/components/Stack/index.js +29 -0
  204. package/dist/components/Status/index.d.ts +32 -0
  205. package/dist/components/Status/index.js +72 -0
  206. package/dist/components/StepList/index.d.ts +33 -0
  207. package/dist/components/StepList/index.js +58 -0
  208. package/dist/components/Stepper/index.d.ts +15 -0
  209. package/dist/components/Stepper/index.js +145 -0
  210. package/dist/components/SwitchButton/FocusOverlay.d.ts +8 -0
  211. package/dist/components/SwitchButton/FocusOverlay.js +38 -0
  212. package/dist/components/SwitchButton/index.d.ts +26 -0
  213. package/dist/components/SwitchButton/index.js +76 -0
  214. package/dist/components/Table/Body.d.ts +6 -0
  215. package/dist/components/Table/Body.js +7 -0
  216. package/dist/components/Table/Cell.d.ts +9 -0
  217. package/dist/components/Table/Cell.js +19 -0
  218. package/dist/components/Table/Header.d.ts +6 -0
  219. package/dist/components/Table/Header.js +16 -0
  220. package/dist/components/Table/HeaderCell.d.ts +14 -0
  221. package/dist/components/Table/HeaderCell.js +80 -0
  222. package/dist/components/Table/HeaderRow.d.ts +7 -0
  223. package/dist/components/Table/HeaderRow.js +23 -0
  224. package/dist/components/Table/Row.d.ts +14 -0
  225. package/dist/components/Table/Row.js +80 -0
  226. package/dist/components/Table/SelectBar.d.ts +15 -0
  227. package/dist/components/Table/SelectBar.js +52 -0
  228. package/dist/components/Table/SkeletonRows.d.ts +7 -0
  229. package/dist/components/Table/SkeletonRows.js +54 -0
  230. package/dist/components/Table/TableContext.d.ts +27 -0
  231. package/dist/{src/components → components}/Table/TableContext.js +19 -21
  232. package/dist/components/Table/index.d.ts +60 -0
  233. package/dist/components/Table/index.js +67 -0
  234. package/dist/components/Tabs/Tab.d.ts +20 -0
  235. package/dist/components/Tabs/Tab.js +120 -0
  236. package/dist/components/Tabs/TabMenu.d.ts +8 -0
  237. package/dist/components/Tabs/TabMenu.js +62 -0
  238. package/dist/components/Tabs/TabMenuItem.d.ts +20 -0
  239. package/dist/components/Tabs/TabMenuItem.js +34 -0
  240. package/dist/components/Tabs/TabsContext.d.ts +8 -0
  241. package/dist/components/Tabs/TabsContext.js +7 -0
  242. package/dist/components/Tabs/index.d.ts +50 -0
  243. package/dist/components/Tabs/index.js +102 -0
  244. package/dist/components/Tag/index.d.ts +26 -0
  245. package/dist/components/Tag/index.js +144 -0
  246. package/dist/components/TagInput/index.d.ts +55 -0
  247. package/dist/components/TagInput/index.js +253 -0
  248. package/dist/components/TagList/index.d.ts +37 -0
  249. package/dist/components/TagList/index.js +98 -0
  250. package/dist/components/Text/index.d.ts +40 -0
  251. package/dist/components/Text/index.js +82 -0
  252. package/dist/components/TextArea/index.d.ts +50 -0
  253. package/dist/components/TextArea/index.js +158 -0
  254. package/dist/components/TextInput/index.d.ts +75 -0
  255. package/dist/components/TextInput/index.js +387 -0
  256. package/dist/components/TextInputV2/index.d.ts +30 -0
  257. package/dist/components/TextInputV2/index.js +190 -0
  258. package/dist/components/TimeInput/index.d.ts +25 -0
  259. package/dist/components/TimeInput/index.js +28 -0
  260. package/dist/components/Toaster/index.d.ts +46 -0
  261. package/dist/components/Toaster/index.js +83 -0
  262. package/dist/components/Toaster/react-toastify.css.js +4 -0
  263. package/dist/components/Toggle/index.d.ts +34 -0
  264. package/dist/components/Toggle/index.js +136 -0
  265. package/dist/components/ToggleGroup/index.d.ts +24 -0
  266. package/dist/components/ToggleGroup/index.js +96 -0
  267. package/dist/components/Tooltip/index.d.ts +9 -0
  268. package/dist/components/Tooltip/index.js +40 -0
  269. package/dist/components/VerificationCode/index.d.ts +36 -0
  270. package/dist/components/VerificationCode/index.js +217 -0
  271. package/dist/components/index.d.ts +75 -0
  272. package/dist/helpers/isJSON.d.ts +2 -0
  273. package/dist/{src/helpers → helpers}/isJSON.js +4 -3
  274. package/dist/helpers/jestMockMatchMedia.d.ts +6 -0
  275. package/dist/helpers/keycode.d.ts +3 -0
  276. package/dist/helpers/legend.d.ts +2 -0
  277. package/dist/helpers/legend.js +14 -0
  278. package/dist/helpers/numbers.d.ts +2 -0
  279. package/dist/helpers/recursivelyGetChildrenString.d.ts +3 -0
  280. package/dist/helpers/recursivelyGetChildrenString.js +15 -0
  281. package/dist/hooks/useIsOverflowing.d.ts +5 -0
  282. package/dist/hooks/useIsOverflowing.js +23 -0
  283. package/dist/index.d.ts +4 -3723
  284. package/dist/index.js +187 -0
  285. package/dist/mocks/list.d.ts +12 -0
  286. package/dist/theme/index.d.ts +1573 -0
  287. package/dist/theme/index.js +27 -0
  288. package/dist/types.d.ts +6 -0
  289. package/dist/utils/animations.d.ts +27 -0
  290. package/dist/{src/utils → utils}/animations.js +30 -4
  291. package/dist/utils/capitalize.d.ts +2 -0
  292. package/dist/utils/capitalize.js +4 -0
  293. package/dist/utils/ids.d.ts +1 -0
  294. package/dist/{src/utils → utils}/ids.js +5 -4
  295. package/dist/utils/index.d.ts +6 -0
  296. package/dist/utils/normalize.d.ts +2 -0
  297. package/dist/{src/utils → utils}/normalize.js +4 -3
  298. package/dist/utils/orderBy.d.ts +2 -0
  299. package/dist/utils/responsive/Breakpoint.d.ts +9 -0
  300. package/dist/utils/responsive/Breakpoint.js +15 -0
  301. package/dist/utils/responsive/index.d.ts +2 -0
  302. package/dist/utils/responsive/utilities.d.ts +3 -0
  303. package/dist/{src/utils → utils}/responsive/utilities.js +9 -6
  304. package/package.json +18 -8
  305. package/dist/react-datepicker/dist/react-datepicker.min.css.js +0 -3
  306. package/dist/react-toastify/dist/ReactToastify.min.css.js +0 -3
  307. package/dist/src/components/ActionBar/index.js +0 -40
  308. package/dist/src/components/Alert/index.js +0 -133
  309. package/dist/src/components/Avatar/index.js +0 -74
  310. package/dist/src/components/Badge/index.js +0 -116
  311. package/dist/src/components/Banner/assets/default-image-small.svg.js +0 -5
  312. package/dist/src/components/Banner/assets/default-image.svg.js +0 -5
  313. package/dist/src/components/Banner/index.js +0 -159
  314. package/dist/src/components/BarChart/Tooltip.js +0 -48
  315. package/dist/src/components/BarChart/index.js +0 -95
  316. package/dist/src/components/BarStack/index.js +0 -136
  317. package/dist/src/components/Breadcrumbs/index.js +0 -82
  318. package/dist/src/components/Bullet/index.js +0 -98
  319. package/dist/src/components/Button/index.js +0 -311
  320. package/dist/src/components/Card/index.js +0 -67
  321. package/dist/src/components/Carousel/index.js +0 -128
  322. package/dist/src/components/Checkbox/index.js +0 -316
  323. package/dist/src/components/CheckboxGroup/index.js +0 -143
  324. package/dist/src/components/CopyButton/index.js +0 -37
  325. package/dist/src/components/DateInput/index.js +0 -242
  326. package/dist/src/components/Dialog/Context.js +0 -12
  327. package/dist/src/components/Dialog/index.js +0 -88
  328. package/dist/src/components/Dialog/subComponents/Button.js +0 -21
  329. package/dist/src/components/Dialog/subComponents/Buttons.js +0 -14
  330. package/dist/src/components/Dialog/subComponents/CancelButton.js +0 -14
  331. package/dist/src/components/Dialog/subComponents/Stack.js +0 -11
  332. package/dist/src/components/Dialog/subComponents/Text.js +0 -12
  333. package/dist/src/components/EmptyState/index.js +0 -112
  334. package/dist/src/components/Expandable/index.js +0 -96
  335. package/dist/src/components/GlobalAlert/GlobalAlertLink.js +0 -38
  336. package/dist/src/components/GlobalAlert/index.js +0 -82
  337. package/dist/src/components/LineChart/CustomLegend.js +0 -138
  338. package/dist/src/components/LineChart/Tooltip.js +0 -43
  339. package/dist/src/components/LineChart/index.js +0 -131
  340. package/dist/src/components/Link/index.js +0 -147
  341. package/dist/src/components/List/Body.js +0 -16
  342. package/dist/src/components/List/Cell.js +0 -43
  343. package/dist/src/components/List/HeaderCell.js +0 -90
  344. package/dist/src/components/List/HeaderRow.js +0 -43
  345. package/dist/src/components/List/Row.js +0 -185
  346. package/dist/src/components/List/SelectBar.js +0 -48
  347. package/dist/src/components/List/SkeletonRows.js +0 -53
  348. package/dist/src/components/List/index.js +0 -75
  349. package/dist/src/components/Loader/index.js +0 -100
  350. package/dist/src/components/Menu/Item.js +0 -112
  351. package/dist/src/components/Menu/index.js +0 -129
  352. package/dist/src/components/MenuV2/Group.js +0 -25
  353. package/dist/src/components/MenuV2/Item.js +0 -139
  354. package/dist/src/components/MenuV2/index.js +0 -118
  355. package/dist/src/components/Meter/index.js +0 -76
  356. package/dist/src/components/Modal/Dialog.js +0 -182
  357. package/dist/src/components/Modal/index.js +0 -113
  358. package/dist/src/components/Notice/index.js +0 -34
  359. package/dist/src/components/Notification/index.js +0 -77
  360. package/dist/src/components/NumberInput/index.js +0 -299
  361. package/dist/src/components/NumberInputV2/index.js +0 -284
  362. package/dist/src/components/Pagination/index.js +0 -117
  363. package/dist/src/components/PasswordCheck/index.js +0 -41
  364. package/dist/src/components/PasswordStrengthMeter/index.js +0 -102
  365. package/dist/src/components/PieChart/Legends.js +0 -138
  366. package/dist/src/components/PieChart/Tooltip.js +0 -61
  367. package/dist/src/components/PieChart/index.js +0 -125
  368. package/dist/src/components/Popover/index.js +0 -146
  369. package/dist/src/components/Popup/helpers.js +0 -252
  370. package/dist/src/components/Popup/index.js +0 -383
  371. package/dist/src/components/ProgressBar/index.js +0 -57
  372. package/dist/src/components/Radio/index.js +0 -157
  373. package/dist/src/components/RadioGroup/index.js +0 -131
  374. package/dist/src/components/Row/index.js +0 -41
  375. package/dist/src/components/SelectInput/index.js +0 -610
  376. package/dist/src/components/SelectInputV2/Dropdown.js +0 -594
  377. package/dist/src/components/SelectInputV2/DropdownOption.js +0 -130
  378. package/dist/src/components/SelectInputV2/SearchBarDropdown.js +0 -122
  379. package/dist/src/components/SelectInputV2/SelectBar.js +0 -282
  380. package/dist/src/components/SelectInputV2/findOptionInOptions.js +0 -11
  381. package/dist/src/components/SelectInputV2/index.js +0 -137
  382. package/dist/src/components/SelectableCard/index.js +0 -175
  383. package/dist/src/components/SelectableCardGroup/index.js +0 -141
  384. package/dist/src/components/Separator/index.js +0 -73
  385. package/dist/src/components/Skeleton/Block.js +0 -35
  386. package/dist/src/components/Skeleton/Blocks.js +0 -34
  387. package/dist/src/components/Skeleton/BoxWithIcon.js +0 -32
  388. package/dist/src/components/Skeleton/Donut.js +0 -55
  389. package/dist/src/components/Skeleton/IconSkeleton.js +0 -19
  390. package/dist/src/components/Skeleton/Line.js +0 -13
  391. package/dist/src/components/Skeleton/List.js +0 -51
  392. package/dist/src/components/Skeleton/Slider.js +0 -36
  393. package/dist/src/components/Skeleton/Square.js +0 -9
  394. package/dist/src/components/Skeleton/index.js +0 -82
  395. package/dist/src/components/Snippet/index.js +0 -200
  396. package/dist/src/components/Stack/index.js +0 -29
  397. package/dist/src/components/Status/index.js +0 -74
  398. package/dist/src/components/StepList/index.js +0 -69
  399. package/dist/src/components/Stepper/index.js +0 -150
  400. package/dist/src/components/SwitchButton/FocusOverlay.js +0 -37
  401. package/dist/src/components/SwitchButton/index.js +0 -108
  402. package/dist/src/components/Table/Body.js +0 -9
  403. package/dist/src/components/Table/Cell.js +0 -21
  404. package/dist/src/components/Table/Header.js +0 -15
  405. package/dist/src/components/Table/HeaderCell.js +0 -103
  406. package/dist/src/components/Table/HeaderRow.js +0 -32
  407. package/dist/src/components/Table/Row.js +0 -89
  408. package/dist/src/components/Table/SelectBar.js +0 -48
  409. package/dist/src/components/Table/SkeletonRows.js +0 -51
  410. package/dist/src/components/Table/index.js +0 -82
  411. package/dist/src/components/Tabs/Tab.js +0 -138
  412. package/dist/src/components/Tabs/TabMenu.js +0 -59
  413. package/dist/src/components/Tabs/TabMenuItem.js +0 -36
  414. package/dist/src/components/Tabs/TabsContext.js +0 -6
  415. package/dist/src/components/Tabs/index.js +0 -117
  416. package/dist/src/components/Tag/index.js +0 -169
  417. package/dist/src/components/TagInput/index.js +0 -309
  418. package/dist/src/components/TagList/index.js +0 -106
  419. package/dist/src/components/Text/index.js +0 -107
  420. package/dist/src/components/TextArea/index.js +0 -210
  421. package/dist/src/components/TextInput/index.js +0 -451
  422. package/dist/src/components/TextInputV2/index.js +0 -289
  423. package/dist/src/components/TimeInput/index.js +0 -37
  424. package/dist/src/components/Toaster/index.js +0 -131
  425. package/dist/src/components/Toggle/index.js +0 -160
  426. package/dist/src/components/ToggleGroup/index.js +0 -122
  427. package/dist/src/components/Tooltip/index.js +0 -55
  428. package/dist/src/components/VerificationCode/index.js +0 -222
  429. package/dist/src/helpers/legend.js +0 -13
  430. package/dist/src/helpers/recursivelyGetChildrenString.js +0 -11
  431. package/dist/src/hooks/useIsOverflowing.js +0 -34
  432. package/dist/src/index.js +0 -77
  433. package/dist/src/theme/index.js +0 -29
  434. package/dist/src/utils/capitalize.js +0 -3
  435. package/dist/src/utils/responsive/Breakpoint.js +0 -12
@@ -0,0 +1,101 @@
1
+ import { jsx, jsxs } from "@emotion/react/jsx-runtime";
2
+ import _styled from "@emotion/styled/base";
3
+ import { useTheme } from "@emotion/react";
4
+ import { Pie } from "@nivo/pie";
5
+ import { useState, useCallback } from "react";
6
+ import { getLegendColor } from "../../helpers/legend.js";
7
+ import { Text } from "../Text/index.js";
8
+ import Legends from "./Legends.js";
9
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
10
+ return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
11
+ }
12
+ const Container = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
13
+ target: "epjfe5p2"
14
+ } : {
15
+ target: "epjfe5p2",
16
+ label: "Container"
17
+ })("display:flex;align-items:center;height:", ({
18
+ height
19
+ }) => `${height}px`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXZ0QiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUGllQ2hhcnQvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlVGhlbWUgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBCb3ggfSBmcm9tICdAbml2by9jb3JlJ1xuaW1wb3J0IHsgUGllIH0gZnJvbSAnQG5pdm8vcGllJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZUNhbGxiYWNrLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgZ2V0TGVnZW5kQ29sb3IgfSBmcm9tICcuLi8uLi9oZWxwZXJzL2xlZ2VuZCdcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IExlZ2VuZHMgZnJvbSAnLi9MZWdlbmRzJ1xuaW1wb3J0IHR5cGUgeyBEYXRhIH0gZnJvbSAnLi90eXBlcydcblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkLmRpdjx7IGhlaWdodDogbnVtYmVyIH0+YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBoZWlnaHQ6ICR7KHsgaGVpZ2h0IH0pID0+IGAke2hlaWdodH1weGB9O1xuYFxuXG5jb25zdCBFbXB0eUxlZ2VuZCA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1hcmdpbi1sZWZ0OiAyMHB4O1xuYFxuXG5jb25zdCBTdHlsZWRDb250ZW50ID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIGJvdHRvbTogMDtcbiAgbGVmdDogMDtcbiAgcmlnaHQ6IDA7XG4gIHRvcDogMDtcblxuICBmb250LXNpemU6IDI1cHg7XG4gIGxpbmUtaGVpZ2h0OiAxMDBweDtcbiAgaGVpZ2h0OiAxMDBweDtcbiAgd2lkdGg6IDEwMHB4O1xuICBtYXJnaW46IGF1dG87XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbiAgdmVydGljYWwtYWxpZ246IG1pZGRsZTtcbmBcblxudHlwZSBQaWVDaGFydFByb3BzID0ge1xuICBjaGFydFByb3BzPzogUmVjb3JkPHN0cmluZywgdW5rbm93bj5cbiAgZGF0YT86IERhdGFbXVxuICBoZWlnaHQ/OiBudW1iZXJcbiAgd2lkdGg/OiBudW1iZXJcbiAgZW1wdHlMZWdlbmQ/OiBzdHJpbmdcbiAgY29udGVudD86IFJlYWN0Tm9kZVxuICB3aXRoTGVnZW5kPzogYm9vbGVhblxuICBtYXJnaW4/OiBCb3hcbn1cblxuY29uc3QgREVGQVVMVF9DSEFSVFBST1BTID0ge31cbmNvbnN0IERFRkFVTFRfTUFSR0lOID0geyBib3R0b206IDEwLCBsZWZ0OiAxMCwgcmlnaHQ6IDEwLCB0b3A6IDEwIH1cblxuLyoqXG4gKiBQaWVDaGFydCBjb21wb25lbnQgaXMgYSB3cmFwcGVyIGFyb3VuZCB0aGUgTml2byBQaWUgY29tcG9uZW50IHRvIGRpc3BsYXkgYSBwaWUgY2hhcnQuXG4gKiBTZWUgaHR0cHM6Ly9uaXZvLnJvY2tzL3BpZS8gZm9yIG1vcmUgaW5mb3JtYXRpb24uXG4gKiBAZXhwZXJpbWVudGFsIFRoaXMgY29tcG9uZW50IGlzIGV4cGVyaW1lbnRhbCBhbmQgbWF5IGJlIHN1YmplY3QgdG8gYnJlYWtpbmcgY2hhbmdlcyBpbiB0aGUgZnV0dXJlLlxuICovXG5leHBvcnQgY29uc3QgUGllQ2hhcnQgPSAoe1xuICBoZWlnaHQgPSAyMDYsXG4gIHdpZHRoID0gMjA2LFxuICBkYXRhID0gdW5kZWZpbmVkLFxuICBlbXB0eUxlZ2VuZCxcbiAgY29udGVudCxcbiAgd2l0aExlZ2VuZCA9IGZhbHNlLFxuICBtYXJnaW4gPSBERUZBVUxUX01BUkdJTixcbiAgY2hhcnRQcm9wcyA9IERFRkFVTFRfQ0hBUlRQUk9QUyxcbn06IFBpZUNoYXJ0UHJvcHMpID0+IHtcbiAgY29uc3QgdGhlbWUgPSB1c2VUaGVtZSgpXG4gIGNvbnN0IFtjdXJyZW50Rm9jdXNJbmRleCwgc2V0Q3VycmVudEZvY3VzSW5kZXhdID0gdXNlU3RhdGU8c3RyaW5nPigpXG4gIGNvbnN0IGVtcHR5VG9vbHRpcCA9IHVzZUNhbGxiYWNrKCgpID0+IDxzcGFuIC8+LCBbXSlcbiAgY29uc3QgaXNFbXB0eSA9ICFkYXRhIHx8IGRhdGEubGVuZ3RoID09PSAwXG5cbiAgY29uc3QgRW1wdHlMZWdlbmREaXNwbGF5ZWQgPSB1c2VDYWxsYmFjayhcbiAgICAoKSA9PlxuICAgICAgZW1wdHlMZWdlbmQgPyAoXG4gICAgICAgIDxFbXB0eUxlZ2VuZD5cbiAgICAgICAgICA8VGV4dCB2YXJpYW50PVwiYm9keVwiIGFzPVwicFwiPlxuICAgICAgICAgICAge2VtcHR5TGVnZW5kfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgPC9FbXB0eUxlZ2VuZD5cbiAgICAgICkgOiBudWxsLFxuICAgIFtlbXB0eUxlZ2VuZF0sXG4gIClcblxuICBjb25zdCBsb2NhbENvbG9ycyA9IGdldExlZ2VuZENvbG9yKHRoZW1lKVxuXG4gIGNvbnN0IExlZ2VuZERpc3BsYXllciA9IHVzZUNhbGxiYWNrKFxuICAgICgpID0+XG4gICAgICBpc0VtcHR5ID8gKFxuICAgICAgICA8RW1wdHlMZWdlbmREaXNwbGF5ZWQgLz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxMZWdlbmRzXG4gICAgICAgICAgZm9jdXNlZD17Y3VycmVudEZvY3VzSW5kZXh9XG4gICAgICAgICAgZGF0YT17ZGF0YX1cbiAgICAgICAgICBvbkZvY3VzQ2hhbmdlPXtzZXRDdXJyZW50Rm9jdXNJbmRleH1cbiAgICAgICAgICBjb2xvcnM9e2xvY2FsQ29sb3JzfVxuICAgICAgICAvPlxuICAgICAgKSxcbiAgICBbaXNFbXB0eSwgY3VycmVudEZvY3VzSW5kZXgsIGRhdGEsIEVtcHR5TGVnZW5kRGlzcGxheWVkLCBsb2NhbENvbG9yc10sXG4gIClcblxuICByZXR1cm4gKFxuICAgIDxDb250YWluZXIgaGVpZ2h0PXtoZWlnaHR9PlxuICAgICAgPGRpdiBzdHlsZT17eyBwb3NpdGlvbjogJ3JlbGF0aXZlJyB9fT5cbiAgICAgICAgPFBpZVxuICAgICAgICAgIGNvbG9ycz17bG9jYWxDb2xvcnN9XG4gICAgICAgICAgaGVpZ2h0PXtoZWlnaHR9XG4gICAgICAgICAgd2lkdGg9e3dpZHRofVxuICAgICAgICAgIHZhbHVlPVwicGVyY2VudFwiXG4gICAgICAgICAgZW5hYmxlQXJjTGFiZWxzPXtmYWxzZX1cbiAgICAgICAgICBlbmFibGVBcmNMaW5rTGFiZWxzPXtmYWxzZX1cbiAgICAgICAgICBkYXRhPXtcbiAgICAgICAgICAgICFpc0VtcHR5XG4gICAgICAgICAgICAgID8gZGF0YVxuICAgICAgICAgICAgICA6IFtcbiAgICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgaWQ6ICdlbXB0eScsXG4gICAgICAgICAgICAgICAgICAgIHBlcmNlbnQ6IDEwMCxcbiAgICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgXVxuICAgICAgICAgIH1cbiAgICAgICAgICBkZWZzPXtbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIGJhY2tncm91bmQ6ICdpbmhlcml0JyxcbiAgICAgICAgICAgICAgY29sb3I6IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRTdHJvbmcsXG4gICAgICAgICAgICAgIGlkOiAnbGluZXMnLFxuICAgICAgICAgICAgICBsaW5lV2lkdGg6IDIsXG4gICAgICAgICAgICAgIHJvdGF0aW9uOiAwLFxuICAgICAgICAgICAgICBzcGFjaW5nOiA1LFxuICAgICAgICAgICAgICB0eXBlOiAncGF0dGVybkxpbmVzJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgXX1cbiAgICAgICAgICBtYXJnaW49e21hcmdpbn1cbiAgICAgICAgICBpbm5lclJhZGl1cz17MC44fVxuICAgICAgICAgIGNvcm5lclJhZGl1cz17MH1cbiAgICAgICAgICBwYWRBbmdsZT17MX1cbiAgICAgICAgICBhY3RpdmVPdXRlclJhZGl1c09mZnNldD17IWlzRW1wdHkgPyA0IDogMH1cbiAgICAgICAgICB0b29sdGlwPXtlbXB0eVRvb2x0aXB9XG4gICAgICAgICAgb25Nb3VzZUVudGVyPXsoZGF0dW0sIGV2ZW50KSA9PiB7XG4gICAgICAgICAgICBpZiAoIWlzRW1wdHkpIHtcbiAgICAgICAgICAgICAgY29uc3QgcGllID0gZXZlbnQuY3VycmVudFRhcmdldFxuICAgICAgICAgICAgICBwaWUuc3R5bGUuY3Vyc29yID0gJ3BvaW50ZXInXG4gICAgICAgICAgICAgIHNldEN1cnJlbnRGb2N1c0luZGV4KGRhdHVtLmlkLnRvU3RyaW5nKCkpXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfX1cbiAgICAgICAgICBvbk1vdXNlTGVhdmU9eygpID0+IHNldEN1cnJlbnRGb2N1c0luZGV4KHVuZGVmaW5lZCl9XG4gICAgICAgICAgey4uLmNoYXJ0UHJvcHN9XG4gICAgICAgIC8+XG4gICAgICAgIHtjb250ZW50ID8gPFN0eWxlZENvbnRlbnQ+e2NvbnRlbnR9PC9TdHlsZWRDb250ZW50PiA6IG51bGx9XG4gICAgICA8L2Rpdj5cbiAgICAgIHt3aXRoTGVnZW5kID8gPExlZ2VuZERpc3BsYXllciAvPiA6IG51bGx9XG4gICAgPC9Db250YWluZXI+XG4gIClcbn1cbiJdfQ== */"));
20
+ const EmptyLegend = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
21
+ target: "epjfe5p1"
22
+ } : {
23
+ target: "epjfe5p1",
24
+ label: "EmptyLegend"
25
+ })(process.env.NODE_ENV === "production" ? {
26
+ name: "dwqz7h",
27
+ styles: "display:flex;align-items:center;margin-left:20px"
28
+ } : {
29
+ name: "dwqz7h",
30
+ styles: "display:flex;align-items:center;margin-left:20px",
31
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQjhCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZVRoZW1lIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgQm94IH0gZnJvbSAnQG5pdm8vY29yZSdcbmltcG9ydCB7IFBpZSB9IGZyb20gJ0BuaXZvL3BpZSdcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VDYWxsYmFjaywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGdldExlZ2VuZENvbG9yIH0gZnJvbSAnLi4vLi4vaGVscGVycy9sZWdlbmQnXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBMZWdlbmRzIGZyb20gJy4vTGVnZW5kcydcbmltcG9ydCB0eXBlIHsgRGF0YSB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyBoZWlnaHQ6IG51bWJlciB9PmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgaGVpZ2h0OiAkeyh7IGhlaWdodCB9KSA9PiBgJHtoZWlnaHR9cHhgfTtcbmBcblxuY29uc3QgRW1wdHlMZWdlbmQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtYXJnaW4tbGVmdDogMjBweDtcbmBcblxuY29uc3QgU3R5bGVkQ29udGVudCA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBib3R0b206IDA7XG4gIGxlZnQ6IDA7XG4gIHJpZ2h0OiAwO1xuICB0b3A6IDA7XG5cbiAgZm9udC1zaXplOiAyNXB4O1xuICBsaW5lLWhlaWdodDogMTAwcHg7XG4gIGhlaWdodDogMTAwcHg7XG4gIHdpZHRoOiAxMDBweDtcbiAgbWFyZ2luOiBhdXRvO1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG5gXG5cbnR5cGUgUGllQ2hhcnRQcm9wcyA9IHtcbiAgY2hhcnRQcm9wcz86IFJlY29yZDxzdHJpbmcsIHVua25vd24+XG4gIGRhdGE/OiBEYXRhW11cbiAgaGVpZ2h0PzogbnVtYmVyXG4gIHdpZHRoPzogbnVtYmVyXG4gIGVtcHR5TGVnZW5kPzogc3RyaW5nXG4gIGNvbnRlbnQ/OiBSZWFjdE5vZGVcbiAgd2l0aExlZ2VuZD86IGJvb2xlYW5cbiAgbWFyZ2luPzogQm94XG59XG5cbmNvbnN0IERFRkFVTFRfQ0hBUlRQUk9QUyA9IHt9XG5jb25zdCBERUZBVUxUX01BUkdJTiA9IHsgYm90dG9tOiAxMCwgbGVmdDogMTAsIHJpZ2h0OiAxMCwgdG9wOiAxMCB9XG5cbi8qKlxuICogUGllQ2hhcnQgY29tcG9uZW50IGlzIGEgd3JhcHBlciBhcm91bmQgdGhlIE5pdm8gUGllIGNvbXBvbmVudCB0byBkaXNwbGF5IGEgcGllIGNoYXJ0LlxuICogU2VlIGh0dHBzOi8vbml2by5yb2Nrcy9waWUvIGZvciBtb3JlIGluZm9ybWF0aW9uLlxuICogQGV4cGVyaW1lbnRhbCBUaGlzIGNvbXBvbmVudCBpcyBleHBlcmltZW50YWwgYW5kIG1heSBiZSBzdWJqZWN0IHRvIGJyZWFraW5nIGNoYW5nZXMgaW4gdGhlIGZ1dHVyZS5cbiAqL1xuZXhwb3J0IGNvbnN0IFBpZUNoYXJ0ID0gKHtcbiAgaGVpZ2h0ID0gMjA2LFxuICB3aWR0aCA9IDIwNixcbiAgZGF0YSA9IHVuZGVmaW5lZCxcbiAgZW1wdHlMZWdlbmQsXG4gIGNvbnRlbnQsXG4gIHdpdGhMZWdlbmQgPSBmYWxzZSxcbiAgbWFyZ2luID0gREVGQVVMVF9NQVJHSU4sXG4gIGNoYXJ0UHJvcHMgPSBERUZBVUxUX0NIQVJUUFJPUFMsXG59OiBQaWVDaGFydFByb3BzKSA9PiB7XG4gIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKVxuICBjb25zdCBbY3VycmVudEZvY3VzSW5kZXgsIHNldEN1cnJlbnRGb2N1c0luZGV4XSA9IHVzZVN0YXRlPHN0cmluZz4oKVxuICBjb25zdCBlbXB0eVRvb2x0aXAgPSB1c2VDYWxsYmFjaygoKSA9PiA8c3BhbiAvPiwgW10pXG4gIGNvbnN0IGlzRW1wdHkgPSAhZGF0YSB8fCBkYXRhLmxlbmd0aCA9PT0gMFxuXG4gIGNvbnN0IEVtcHR5TGVnZW5kRGlzcGxheWVkID0gdXNlQ2FsbGJhY2soXG4gICAgKCkgPT5cbiAgICAgIGVtcHR5TGVnZW5kID8gKFxuICAgICAgICA8RW1wdHlMZWdlbmQ+XG4gICAgICAgICAgPFRleHQgdmFyaWFudD1cImJvZHlcIiBhcz1cInBcIj5cbiAgICAgICAgICAgIHtlbXB0eUxlZ2VuZH1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgIDwvRW1wdHlMZWdlbmQ+XG4gICAgICApIDogbnVsbCxcbiAgICBbZW1wdHlMZWdlbmRdLFxuICApXG5cbiAgY29uc3QgbG9jYWxDb2xvcnMgPSBnZXRMZWdlbmRDb2xvcih0aGVtZSlcblxuICBjb25zdCBMZWdlbmREaXNwbGF5ZXIgPSB1c2VDYWxsYmFjayhcbiAgICAoKSA9PlxuICAgICAgaXNFbXB0eSA/IChcbiAgICAgICAgPEVtcHR5TGVnZW5kRGlzcGxheWVkIC8+XG4gICAgICApIDogKFxuICAgICAgICA8TGVnZW5kc1xuICAgICAgICAgIGZvY3VzZWQ9e2N1cnJlbnRGb2N1c0luZGV4fVxuICAgICAgICAgIGRhdGE9e2RhdGF9XG4gICAgICAgICAgb25Gb2N1c0NoYW5nZT17c2V0Q3VycmVudEZvY3VzSW5kZXh9XG4gICAgICAgICAgY29sb3JzPXtsb2NhbENvbG9yc31cbiAgICAgICAgLz5cbiAgICAgICksXG4gICAgW2lzRW1wdHksIGN1cnJlbnRGb2N1c0luZGV4LCBkYXRhLCBFbXB0eUxlZ2VuZERpc3BsYXllZCwgbG9jYWxDb2xvcnNdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8Q29udGFpbmVyIGhlaWdodD17aGVpZ2h0fT5cbiAgICAgIDxkaXYgc3R5bGU9e3sgcG9zaXRpb246ICdyZWxhdGl2ZScgfX0+XG4gICAgICAgIDxQaWVcbiAgICAgICAgICBjb2xvcnM9e2xvY2FsQ29sb3JzfVxuICAgICAgICAgIGhlaWdodD17aGVpZ2h0fVxuICAgICAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgICAgICB2YWx1ZT1cInBlcmNlbnRcIlxuICAgICAgICAgIGVuYWJsZUFyY0xhYmVscz17ZmFsc2V9XG4gICAgICAgICAgZW5hYmxlQXJjTGlua0xhYmVscz17ZmFsc2V9XG4gICAgICAgICAgZGF0YT17XG4gICAgICAgICAgICAhaXNFbXB0eVxuICAgICAgICAgICAgICA/IGRhdGFcbiAgICAgICAgICAgICAgOiBbXG4gICAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgIGlkOiAnZW1wdHknLFxuICAgICAgICAgICAgICAgICAgICBwZXJjZW50OiAxMDAsXG4gICAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIF1cbiAgICAgICAgICB9XG4gICAgICAgICAgZGVmcz17W1xuICAgICAgICAgICAge1xuICAgICAgICAgICAgICBiYWNrZ3JvdW5kOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICAgIGNvbG9yOiB0aGVtZS5jb2xvcnMubmV1dHJhbC50ZXh0U3Ryb25nLFxuICAgICAgICAgICAgICBpZDogJ2xpbmVzJyxcbiAgICAgICAgICAgICAgbGluZVdpZHRoOiAyLFxuICAgICAgICAgICAgICByb3RhdGlvbjogMCxcbiAgICAgICAgICAgICAgc3BhY2luZzogNSxcbiAgICAgICAgICAgICAgdHlwZTogJ3BhdHRlcm5MaW5lcycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgIF19XG4gICAgICAgICAgbWFyZ2luPXttYXJnaW59XG4gICAgICAgICAgaW5uZXJSYWRpdXM9ezAuOH1cbiAgICAgICAgICBjb3JuZXJSYWRpdXM9ezB9XG4gICAgICAgICAgcGFkQW5nbGU9ezF9XG4gICAgICAgICAgYWN0aXZlT3V0ZXJSYWRpdXNPZmZzZXQ9eyFpc0VtcHR5ID8gNCA6IDB9XG4gICAgICAgICAgdG9vbHRpcD17ZW1wdHlUb29sdGlwfVxuICAgICAgICAgIG9uTW91c2VFbnRlcj17KGRhdHVtLCBldmVudCkgPT4ge1xuICAgICAgICAgICAgaWYgKCFpc0VtcHR5KSB7XG4gICAgICAgICAgICAgIGNvbnN0IHBpZSA9IGV2ZW50LmN1cnJlbnRUYXJnZXRcbiAgICAgICAgICAgICAgcGllLnN0eWxlLmN1cnNvciA9ICdwb2ludGVyJ1xuICAgICAgICAgICAgICBzZXRDdXJyZW50Rm9jdXNJbmRleChkYXR1bS5pZC50b1N0cmluZygpKVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH19XG4gICAgICAgICAgb25Nb3VzZUxlYXZlPXsoKSA9PiBzZXRDdXJyZW50Rm9jdXNJbmRleCh1bmRlZmluZWQpfVxuICAgICAgICAgIHsuLi5jaGFydFByb3BzfVxuICAgICAgICAvPlxuICAgICAgICB7Y29udGVudCA/IDxTdHlsZWRDb250ZW50Pntjb250ZW50fTwvU3R5bGVkQ29udGVudD4gOiBudWxsfVxuICAgICAgPC9kaXY+XG4gICAgICB7d2l0aExlZ2VuZCA/IDxMZWdlbmREaXNwbGF5ZXIgLz4gOiBudWxsfVxuICAgIDwvQ29udGFpbmVyPlxuICApXG59XG4iXX0= */",
32
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
33
+ });
34
+ const StyledContent = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
35
+ target: "epjfe5p0"
36
+ } : {
37
+ target: "epjfe5p0",
38
+ label: "StyledContent"
39
+ })(process.env.NODE_ENV === "production" ? {
40
+ name: "qcd8cv",
41
+ styles: "display:inline-block;position:absolute;bottom:0;left:0;right:0;top:0;font-size:25px;line-height:100px;height:100px;width:100px;margin:auto;text-align:center;vertical-align:middle"
42
+ } : {
43
+ name: "qcd8cv",
44
+ styles: "display:inline-block;position:absolute;bottom:0;left:0;right:0;top:0;font-size:25px;line-height:100px;height:100px;width:100px;margin:auto;text-align:center;vertical-align:middle",
45
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QmdDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZVRoZW1lIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgQm94IH0gZnJvbSAnQG5pdm8vY29yZSdcbmltcG9ydCB7IFBpZSB9IGZyb20gJ0BuaXZvL3BpZSdcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VDYWxsYmFjaywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGdldExlZ2VuZENvbG9yIH0gZnJvbSAnLi4vLi4vaGVscGVycy9sZWdlbmQnXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBMZWdlbmRzIGZyb20gJy4vTGVnZW5kcydcbmltcG9ydCB0eXBlIHsgRGF0YSB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyBoZWlnaHQ6IG51bWJlciB9PmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgaGVpZ2h0OiAkeyh7IGhlaWdodCB9KSA9PiBgJHtoZWlnaHR9cHhgfTtcbmBcblxuY29uc3QgRW1wdHlMZWdlbmQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtYXJnaW4tbGVmdDogMjBweDtcbmBcblxuY29uc3QgU3R5bGVkQ29udGVudCA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBib3R0b206IDA7XG4gIGxlZnQ6IDA7XG4gIHJpZ2h0OiAwO1xuICB0b3A6IDA7XG5cbiAgZm9udC1zaXplOiAyNXB4O1xuICBsaW5lLWhlaWdodDogMTAwcHg7XG4gIGhlaWdodDogMTAwcHg7XG4gIHdpZHRoOiAxMDBweDtcbiAgbWFyZ2luOiBhdXRvO1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG5gXG5cbnR5cGUgUGllQ2hhcnRQcm9wcyA9IHtcbiAgY2hhcnRQcm9wcz86IFJlY29yZDxzdHJpbmcsIHVua25vd24+XG4gIGRhdGE/OiBEYXRhW11cbiAgaGVpZ2h0PzogbnVtYmVyXG4gIHdpZHRoPzogbnVtYmVyXG4gIGVtcHR5TGVnZW5kPzogc3RyaW5nXG4gIGNvbnRlbnQ/OiBSZWFjdE5vZGVcbiAgd2l0aExlZ2VuZD86IGJvb2xlYW5cbiAgbWFyZ2luPzogQm94XG59XG5cbmNvbnN0IERFRkFVTFRfQ0hBUlRQUk9QUyA9IHt9XG5jb25zdCBERUZBVUxUX01BUkdJTiA9IHsgYm90dG9tOiAxMCwgbGVmdDogMTAsIHJpZ2h0OiAxMCwgdG9wOiAxMCB9XG5cbi8qKlxuICogUGllQ2hhcnQgY29tcG9uZW50IGlzIGEgd3JhcHBlciBhcm91bmQgdGhlIE5pdm8gUGllIGNvbXBvbmVudCB0byBkaXNwbGF5IGEgcGllIGNoYXJ0LlxuICogU2VlIGh0dHBzOi8vbml2by5yb2Nrcy9waWUvIGZvciBtb3JlIGluZm9ybWF0aW9uLlxuICogQGV4cGVyaW1lbnRhbCBUaGlzIGNvbXBvbmVudCBpcyBleHBlcmltZW50YWwgYW5kIG1heSBiZSBzdWJqZWN0IHRvIGJyZWFraW5nIGNoYW5nZXMgaW4gdGhlIGZ1dHVyZS5cbiAqL1xuZXhwb3J0IGNvbnN0IFBpZUNoYXJ0ID0gKHtcbiAgaGVpZ2h0ID0gMjA2LFxuICB3aWR0aCA9IDIwNixcbiAgZGF0YSA9IHVuZGVmaW5lZCxcbiAgZW1wdHlMZWdlbmQsXG4gIGNvbnRlbnQsXG4gIHdpdGhMZWdlbmQgPSBmYWxzZSxcbiAgbWFyZ2luID0gREVGQVVMVF9NQVJHSU4sXG4gIGNoYXJ0UHJvcHMgPSBERUZBVUxUX0NIQVJUUFJPUFMsXG59OiBQaWVDaGFydFByb3BzKSA9PiB7XG4gIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKVxuICBjb25zdCBbY3VycmVudEZvY3VzSW5kZXgsIHNldEN1cnJlbnRGb2N1c0luZGV4XSA9IHVzZVN0YXRlPHN0cmluZz4oKVxuICBjb25zdCBlbXB0eVRvb2x0aXAgPSB1c2VDYWxsYmFjaygoKSA9PiA8c3BhbiAvPiwgW10pXG4gIGNvbnN0IGlzRW1wdHkgPSAhZGF0YSB8fCBkYXRhLmxlbmd0aCA9PT0gMFxuXG4gIGNvbnN0IEVtcHR5TGVnZW5kRGlzcGxheWVkID0gdXNlQ2FsbGJhY2soXG4gICAgKCkgPT5cbiAgICAgIGVtcHR5TGVnZW5kID8gKFxuICAgICAgICA8RW1wdHlMZWdlbmQ+XG4gICAgICAgICAgPFRleHQgdmFyaWFudD1cImJvZHlcIiBhcz1cInBcIj5cbiAgICAgICAgICAgIHtlbXB0eUxlZ2VuZH1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgIDwvRW1wdHlMZWdlbmQ+XG4gICAgICApIDogbnVsbCxcbiAgICBbZW1wdHlMZWdlbmRdLFxuICApXG5cbiAgY29uc3QgbG9jYWxDb2xvcnMgPSBnZXRMZWdlbmRDb2xvcih0aGVtZSlcblxuICBjb25zdCBMZWdlbmREaXNwbGF5ZXIgPSB1c2VDYWxsYmFjayhcbiAgICAoKSA9PlxuICAgICAgaXNFbXB0eSA/IChcbiAgICAgICAgPEVtcHR5TGVnZW5kRGlzcGxheWVkIC8+XG4gICAgICApIDogKFxuICAgICAgICA8TGVnZW5kc1xuICAgICAgICAgIGZvY3VzZWQ9e2N1cnJlbnRGb2N1c0luZGV4fVxuICAgICAgICAgIGRhdGE9e2RhdGF9XG4gICAgICAgICAgb25Gb2N1c0NoYW5nZT17c2V0Q3VycmVudEZvY3VzSW5kZXh9XG4gICAgICAgICAgY29sb3JzPXtsb2NhbENvbG9yc31cbiAgICAgICAgLz5cbiAgICAgICksXG4gICAgW2lzRW1wdHksIGN1cnJlbnRGb2N1c0luZGV4LCBkYXRhLCBFbXB0eUxlZ2VuZERpc3BsYXllZCwgbG9jYWxDb2xvcnNdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8Q29udGFpbmVyIGhlaWdodD17aGVpZ2h0fT5cbiAgICAgIDxkaXYgc3R5bGU9e3sgcG9zaXRpb246ICdyZWxhdGl2ZScgfX0+XG4gICAgICAgIDxQaWVcbiAgICAgICAgICBjb2xvcnM9e2xvY2FsQ29sb3JzfVxuICAgICAgICAgIGhlaWdodD17aGVpZ2h0fVxuICAgICAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgICAgICB2YWx1ZT1cInBlcmNlbnRcIlxuICAgICAgICAgIGVuYWJsZUFyY0xhYmVscz17ZmFsc2V9XG4gICAgICAgICAgZW5hYmxlQXJjTGlua0xhYmVscz17ZmFsc2V9XG4gICAgICAgICAgZGF0YT17XG4gICAgICAgICAgICAhaXNFbXB0eVxuICAgICAgICAgICAgICA/IGRhdGFcbiAgICAgICAgICAgICAgOiBbXG4gICAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgIGlkOiAnZW1wdHknLFxuICAgICAgICAgICAgICAgICAgICBwZXJjZW50OiAxMDAsXG4gICAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIF1cbiAgICAgICAgICB9XG4gICAgICAgICAgZGVmcz17W1xuICAgICAgICAgICAge1xuICAgICAgICAgICAgICBiYWNrZ3JvdW5kOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICAgIGNvbG9yOiB0aGVtZS5jb2xvcnMubmV1dHJhbC50ZXh0U3Ryb25nLFxuICAgICAgICAgICAgICBpZDogJ2xpbmVzJyxcbiAgICAgICAgICAgICAgbGluZVdpZHRoOiAyLFxuICAgICAgICAgICAgICByb3RhdGlvbjogMCxcbiAgICAgICAgICAgICAgc3BhY2luZzogNSxcbiAgICAgICAgICAgICAgdHlwZTogJ3BhdHRlcm5MaW5lcycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgIF19XG4gICAgICAgICAgbWFyZ2luPXttYXJnaW59XG4gICAgICAgICAgaW5uZXJSYWRpdXM9ezAuOH1cbiAgICAgICAgICBjb3JuZXJSYWRpdXM9ezB9XG4gICAgICAgICAgcGFkQW5nbGU9ezF9XG4gICAgICAgICAgYWN0aXZlT3V0ZXJSYWRpdXNPZmZzZXQ9eyFpc0VtcHR5ID8gNCA6IDB9XG4gICAgICAgICAgdG9vbHRpcD17ZW1wdHlUb29sdGlwfVxuICAgICAgICAgIG9uTW91c2VFbnRlcj17KGRhdHVtLCBldmVudCkgPT4ge1xuICAgICAgICAgICAgaWYgKCFpc0VtcHR5KSB7XG4gICAgICAgICAgICAgIGNvbnN0IHBpZSA9IGV2ZW50LmN1cnJlbnRUYXJnZXRcbiAgICAgICAgICAgICAgcGllLnN0eWxlLmN1cnNvciA9ICdwb2ludGVyJ1xuICAgICAgICAgICAgICBzZXRDdXJyZW50Rm9jdXNJbmRleChkYXR1bS5pZC50b1N0cmluZygpKVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH19XG4gICAgICAgICAgb25Nb3VzZUxlYXZlPXsoKSA9PiBzZXRDdXJyZW50Rm9jdXNJbmRleCh1bmRlZmluZWQpfVxuICAgICAgICAgIHsuLi5jaGFydFByb3BzfVxuICAgICAgICAvPlxuICAgICAgICB7Y29udGVudCA/IDxTdHlsZWRDb250ZW50Pntjb250ZW50fTwvU3R5bGVkQ29udGVudD4gOiBudWxsfVxuICAgICAgPC9kaXY+XG4gICAgICB7d2l0aExlZ2VuZCA/IDxMZWdlbmREaXNwbGF5ZXIgLz4gOiBudWxsfVxuICAgIDwvQ29udGFpbmVyPlxuICApXG59XG4iXX0= */",
46
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
47
+ });
48
+ const DEFAULT_CHARTPROPS = {};
49
+ const DEFAULT_MARGIN = {
50
+ bottom: 10,
51
+ left: 10,
52
+ right: 10,
53
+ top: 10
54
+ };
55
+ const PieChart = ({
56
+ height = 206,
57
+ width = 206,
58
+ data = void 0,
59
+ emptyLegend,
60
+ content,
61
+ withLegend = false,
62
+ margin = DEFAULT_MARGIN,
63
+ chartProps = DEFAULT_CHARTPROPS
64
+ }) => {
65
+ const theme = useTheme();
66
+ const [currentFocusIndex, setCurrentFocusIndex] = useState();
67
+ const emptyTooltip = useCallback(() => /* @__PURE__ */ jsx("span", {}), []);
68
+ const isEmpty = !data || data.length === 0;
69
+ const EmptyLegendDisplayed = useCallback(() => emptyLegend ? /* @__PURE__ */ jsx(EmptyLegend, { children: /* @__PURE__ */ jsx(Text, { variant: "body", as: "p", children: emptyLegend }) }) : null, [emptyLegend]);
70
+ const localColors = getLegendColor(theme);
71
+ const LegendDisplayer = useCallback(() => isEmpty ? /* @__PURE__ */ jsx(EmptyLegendDisplayed, {}) : /* @__PURE__ */ jsx(Legends, { focused: currentFocusIndex, data, onFocusChange: setCurrentFocusIndex, colors: localColors }), [isEmpty, currentFocusIndex, data, EmptyLegendDisplayed, localColors]);
72
+ return /* @__PURE__ */ jsxs(Container, { height, children: [
73
+ /* @__PURE__ */ jsxs("div", { style: {
74
+ position: "relative"
75
+ }, children: [
76
+ /* @__PURE__ */ jsx(Pie, { colors: localColors, height, width, value: "percent", enableArcLabels: false, enableArcLinkLabels: false, data: !isEmpty ? data : [{
77
+ id: "empty",
78
+ percent: 100
79
+ }], defs: [{
80
+ background: "inherit",
81
+ color: theme.colors.neutral.textStrong,
82
+ id: "lines",
83
+ lineWidth: 2,
84
+ rotation: 0,
85
+ spacing: 5,
86
+ type: "patternLines"
87
+ }], margin, innerRadius: 0.8, cornerRadius: 0, padAngle: 1, activeOuterRadiusOffset: !isEmpty ? 4 : 0, tooltip: emptyTooltip, onMouseEnter: (datum, event) => {
88
+ if (!isEmpty) {
89
+ const pie = event.currentTarget;
90
+ pie.style.cursor = "pointer";
91
+ setCurrentFocusIndex(datum.id.toString());
92
+ }
93
+ }, onMouseLeave: () => setCurrentFocusIndex(void 0), ...chartProps }),
94
+ content ? /* @__PURE__ */ jsx(StyledContent, { children: content }) : null
95
+ ] }),
96
+ withLegend ? /* @__PURE__ */ jsx(LegendDisplayer, {}) : null
97
+ ] });
98
+ };
99
+ export {
100
+ PieChart
101
+ };
@@ -0,0 +1,7 @@
1
+ export type Data = {
2
+ name?: string | null;
3
+ needPattern?: boolean | null;
4
+ percent: number;
5
+ id: string;
6
+ value?: string | null;
7
+ };
@@ -0,0 +1,55 @@
1
+ import type { ReactNode, Ref } from 'react';
2
+ type SentimentType = 'neutral' | 'primary';
3
+ /**
4
+ * Popover component is used to display additional information or actions on top of the main content of the page.
5
+ * It is usually triggered by clicking on a button. It includes a title, a close button and a content area.
6
+ */
7
+ export declare const Popover: import("react").ForwardRefExoticComponent<{
8
+ children: ReactNode;
9
+ content: ReactNode;
10
+ title: string;
11
+ sentiment?: SentimentType | undefined;
12
+ visible?: boolean | undefined;
13
+ size?: "large" | "small" | "medium" | undefined;
14
+ onClose?: (() => void) | undefined;
15
+ className?: string | undefined;
16
+ 'data-testid'?: string | undefined;
17
+ maxWidth?: string | undefined;
18
+ maxHeight?: string | undefined;
19
+ /**
20
+ * By default, the portal target is children container or document.body if children is a function. You can override this
21
+ * behavior by setting a portalTarget prop.
22
+ */
23
+ portalTarget?: HTMLElement | undefined;
24
+ } & Pick<{
25
+ id?: string | undefined;
26
+ children: ReactNode | ((renderProps: {
27
+ className?: string | undefined;
28
+ onBlur: () => void;
29
+ onFocus: () => void;
30
+ onPointerEnter: () => void;
31
+ onPointerLeave: () => void;
32
+ ref: import("react").RefObject<HTMLDivElement>;
33
+ }) => ReactNode);
34
+ maxWidth?: string | number | undefined;
35
+ placement?: import("../Popup/helpers").PopupPlacement | undefined;
36
+ text?: ReactNode;
37
+ className?: string | undefined;
38
+ containerFullWidth?: boolean | undefined;
39
+ visible?: boolean | undefined;
40
+ innerRef?: Ref<HTMLDivElement | null> | undefined;
41
+ role?: string | undefined;
42
+ 'data-testid'?: string | undefined;
43
+ hasArrow?: boolean | undefined;
44
+ onClose?: (() => void) | undefined;
45
+ tabIndex?: number | undefined;
46
+ onKeyDown?: import("react").KeyboardEventHandler | undefined;
47
+ 'aria-haspopup'?: boolean | "menu" | "dialog" | "grid" | "listbox" | "tree" | "false" | "true" | undefined;
48
+ hideOnClickOutside?: boolean | undefined;
49
+ debounceDelay?: number | undefined;
50
+ maxHeight?: string | number | undefined;
51
+ disableAnimation?: boolean | undefined;
52
+ portalTarget?: HTMLElement | undefined;
53
+ dynamicDomRendering?: boolean | undefined;
54
+ } & import("react").RefAttributes<HTMLDivElement>, "placement" | "dynamicDomRendering"> & import("react").RefAttributes<HTMLDivElement>>;
55
+ export {};
@@ -0,0 +1,100 @@
1
+ import { jsx, jsxs } from "@emotion/react/jsx-runtime";
2
+ import _styled from "@emotion/styled/base";
3
+ import { forwardRef, useRef, useState, useEffect, useCallback } from "react";
4
+ import { Button } from "../Button/index.js";
5
+ import { Popup } from "../Popup/index.js";
6
+ import { Stack } from "../Stack/index.js";
7
+ import { Text } from "../Text/index.js";
8
+ const SIZES_WIDTH = {
9
+ small: 320,
10
+ medium: 420,
11
+ large: 520
12
+ };
13
+ const StyledPopup = /* @__PURE__ */ _styled(Popup, process.env.NODE_ENV === "production" ? {
14
+ shouldForwardProp: (prop) => !["sentiment", "size"].includes(prop),
15
+ target: "ejpxv5a1"
16
+ } : {
17
+ shouldForwardProp: (prop) => !["sentiment", "size"].includes(prop),
18
+ target: "ejpxv5a1",
19
+ label: "StyledPopup"
20
+ })("padding:", ({
21
+ theme
22
+ }) => theme.space["2"], ";width:", ({
23
+ size
24
+ }) => SIZES_WIDTH[size], "px;max-width:", ({
25
+ size
26
+ }) => SIZES_WIDTH[size], "px;text-align:initial;", ({
27
+ theme,
28
+ sentiment
29
+ }) => {
30
+ if (sentiment === "neutral") {
31
+ return `
32
+ background: ${theme.colors.neutral.background};
33
+ box-shadow: ${theme.shadows.popover};
34
+ &[data-has-arrow='true'] {
35
+ &::after {
36
+ border-color: ${theme.colors.neutral.background} transparent transparent transparent;
37
+ }
38
+ }
39
+ `;
40
+ }
41
+ return `
42
+ background: ${theme.colors.primary.backgroundStrong};
43
+ box-shadow: ${theme.shadows.popover};
44
+ &[data-has-arrow='true'] {
45
+ &::after {
46
+ border-color: ${theme.colors.primary.backgroundStrong} transparent transparent transparent;
47
+ }
48
+ }
49
+ `;
50
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BvcG92ZXIvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCRSIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9Qb3BvdmVyL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcywgUmVhY3ROb2RlLCBSZWYgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGZvcndhcmRSZWYsIHVzZUNhbGxiYWNrLCB1c2VFZmZlY3QsIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IEJ1dHRvbiB9IGZyb20gJy4uL0J1dHRvbidcbmltcG9ydCB7IFBvcHVwIH0gZnJvbSAnLi4vUG9wdXAnXG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJy4uL1N0YWNrJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5cbnR5cGUgU2VudGltZW50VHlwZSA9ICduZXV0cmFsJyB8ICdwcmltYXJ5J1xuXG5jb25zdCBTSVpFU19XSURUSCA9IHtcbiAgc21hbGw6IDMyMCxcbiAgbWVkaXVtOiA0MjAsXG4gIGxhcmdlOiA1MjAsXG59XG5cbmNvbnN0IFN0eWxlZFBvcHVwID0gc3R5bGVkKFBvcHVwLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NlbnRpbWVudCcsICdzaXplJ10uaW5jbHVkZXMocHJvcCksXG59KTx7XG4gIHNlbnRpbWVudDogU2VudGltZW50VHlwZVxuICBzaXplOiBrZXlvZiB0eXBlb2YgU0laRVNfV0lEVEhcbn0+YFxuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycyJ119O1xuICB3aWR0aDogJHsoeyBzaXplIH0pID0+IFNJWkVTX1dJRFRIW3NpemVdfXB4O1xuICBtYXgtd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiBTSVpFU19XSURUSFtzaXplXX1weDtcbiAgdGV4dC1hbGlnbjogaW5pdGlhbDtcblxuICAkeyh7IHRoZW1lLCBzZW50aW1lbnQgfSkgPT4ge1xuICAgIGlmIChzZW50aW1lbnQgPT09ICduZXV0cmFsJykge1xuICAgICAgcmV0dXJuIGBcbiAgICAgIGJhY2tncm91bmQ6ICR7dGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZH07XG4gICAgICBib3gtc2hhZG93OiAke3RoZW1lLnNoYWRvd3MucG9wb3Zlcn07XG4gICAgICAmW2RhdGEtaGFzLWFycm93PSd0cnVlJ10ge1xuICAgICAgICAmOjphZnRlciB7XG4gICAgICAgICAgYm9yZGVyLWNvbG9yOiAke3RoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmR9IHRyYW5zcGFyZW50IHRyYW5zcGFyZW50IHRyYW5zcGFyZW50O1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICBgXG4gICAgfVxuXG4gICAgcmV0dXJuIGBcbiAgICAgIGJhY2tncm91bmQ6ICR7dGhlbWUuY29sb3JzLnByaW1hcnkuYmFja2dyb3VuZFN0cm9uZ307XG4gICAgICBib3gtc2hhZG93OiAke3RoZW1lLnNoYWRvd3MucG9wb3Zlcn07XG4gICAgICAmW2RhdGEtaGFzLWFycm93PSd0cnVlJ10ge1xuICAgICAgICAmOjphZnRlciB7XG4gICAgICAgICAgYm9yZGVyLWNvbG9yOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmRTdHJvbmd9IHRyYW5zcGFyZW50IHRyYW5zcGFyZW50IHRyYW5zcGFyZW50O1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICBgXG4gIH19XG5gXG5cbi8vIFRoaXMgaXMgdG8gYXZvaWQgaGF2aW5nIHRleHQgaW5oZXJpdCBjb2xvciBmcm9tIHBvcHVwICh3aGljaCBpcyB3aGl0ZSBvbiB3aGl0ZSBiYWNrZ3JvdW5kKVxuY29uc3QgU3R5bGVkU3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC50ZXh0fTtcbmBcblxudHlwZSBDb250ZW50V3JhcHBlclByb3BzID0gUGljazxcbiAgUG9wb3ZlclByb3BzLFxuICAndGl0bGUnIHwgJ29uQ2xvc2UnIHwgJ3NlbnRpbWVudCcgfCAnY2hpbGRyZW4nXG4+XG5cbmNvbnN0IENvbnRlbnRXcmFwcGVyID0gKHtcbiAgdGl0bGUsXG4gIG9uQ2xvc2UsXG4gIGNoaWxkcmVuLFxuICBzZW50aW1lbnQsXG59OiBDb250ZW50V3JhcHBlclByb3BzKSA9PiAoXG4gIDxTdHlsZWRTdGFjayBnYXA9ezF9PlxuICAgIDxTdGFjayBkaXJlY3Rpb249XCJyb3dcIiBqdXN0aWZ5Q29udGVudD1cInNwYWNlLWJldHdlZW5cIj5cbiAgICAgIDxUZXh0XG4gICAgICAgIHZhcmlhbnQ9XCJib2R5U3Ryb25nXCJcbiAgICAgICAgYXM9XCJoM1wiXG4gICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICBwcm9taW5lbmNlPXtzZW50aW1lbnQgPT09ICduZXV0cmFsJyA/ICdzdHJvbmcnIDogJ3N0cm9uZ2VyJ31cbiAgICAgID5cbiAgICAgICAge3RpdGxlfVxuICAgICAgPC9UZXh0PlxuICAgICAgPEJ1dHRvblxuICAgICAgICB2YXJpYW50PXtzZW50aW1lbnQgPT09ICduZXV0cmFsJyA/ICdnaG9zdCcgOiAnZmlsbGVkJ31cbiAgICAgICAgc2VudGltZW50PXtzZW50aW1lbnQgPT09ICduZXV0cmFsJyA/ICduZXV0cmFsJyA6ICdwcmltYXJ5J31cbiAgICAgICAgb25DbGljaz17b25DbG9zZX1cbiAgICAgICAgc2l6ZT1cInNtYWxsXCJcbiAgICAgICAgaWNvbj1cImNsb3NlXCJcbiAgICAgICAgYXJpYS1sYWJlbD1cImNsb3NlXCJcbiAgICAgIC8+XG4gICAgPC9TdGFjaz5cbiAgICB7dHlwZW9mIGNoaWxkcmVuID09PSAnc3RyaW5nJyA/IChcbiAgICAgIDxUZXh0XG4gICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxcIlxuICAgICAgICBhcz1cInBcIlxuICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgcHJvbWluZW5jZT17c2VudGltZW50ID09PSAnbmV1dHJhbCcgPyAnc3Ryb25nJyA6ICdzdHJvbmdlcid9XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvVGV4dD5cbiAgICApIDogKFxuICAgICAgY2hpbGRyZW5cbiAgICApfVxuICA8L1N0eWxlZFN0YWNrPlxuKVxuXG50eXBlIFBvcG92ZXJQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZVxuICBjb250ZW50OiBSZWFjdE5vZGVcbiAgdGl0bGU6IHN0cmluZ1xuICBzZW50aW1lbnQ/OiBTZW50aW1lbnRUeXBlXG4gIHZpc2libGU/OiBib29sZWFuXG4gIHNpemU/OiBrZXlvZiB0eXBlb2YgU0laRVNfV0lEVEhcbiAgb25DbG9zZT86ICgpID0+IHZvaWRcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbiAgbWF4V2lkdGg/OiBzdHJpbmdcbiAgbWF4SGVpZ2h0Pzogc3RyaW5nXG4gIC8qKlxuICAgKiBCeSBkZWZhdWx0LCB0aGUgcG9ydGFsIHRhcmdldCBpcyBjaGlsZHJlbiBjb250YWluZXIgb3IgZG9jdW1lbnQuYm9keSBpZiBjaGlsZHJlbiBpcyBhIGZ1bmN0aW9uLiBZb3UgY2FuIG92ZXJyaWRlIHRoaXNcbiAgICogYmVoYXZpb3IgYnkgc2V0dGluZyBhIHBvcnRhbFRhcmdldCBwcm9wLlxuICAgKi9cbiAgcG9ydGFsVGFyZ2V0PzogSFRNTEVsZW1lbnRcbn0gJiBQaWNrPENvbXBvbmVudFByb3BzPHR5cGVvZiBQb3B1cD4sICdwbGFjZW1lbnQnIHwgJ2R5bmFtaWNEb21SZW5kZXJpbmcnPlxuXG4vKipcbiAqIFBvcG92ZXIgY29tcG9uZW50IGlzIHVzZWQgdG8gZGlzcGxheSBhZGRpdGlvbmFsIGluZm9ybWF0aW9uIG9yIGFjdGlvbnMgb24gdG9wIG9mIHRoZSBtYWluIGNvbnRlbnQgb2YgdGhlIHBhZ2UuXG4gKiBJdCBpcyB1c3VhbGx5IHRyaWdnZXJlZCBieSBjbGlja2luZyBvbiBhIGJ1dHRvbi4gSXQgaW5jbHVkZXMgYSB0aXRsZSwgYSBjbG9zZSBidXR0b24gYW5kIGEgY29udGVudCBhcmVhLlxuICovXG5leHBvcnQgY29uc3QgUG9wb3ZlciA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICB2aXNpYmxlID0gZmFsc2UsXG4gICAgICBjaGlsZHJlbixcbiAgICAgIHBsYWNlbWVudCxcbiAgICAgIGNvbnRlbnQsXG4gICAgICB0aXRsZSxcbiAgICAgIHNlbnRpbWVudCA9ICduZXV0cmFsJyxcbiAgICAgIHNpemUgPSAnbWVkaXVtJyxcbiAgICAgIG9uQ2xvc2UsXG4gICAgICBjbGFzc05hbWUsXG4gICAgICBtYXhXaWR0aCxcbiAgICAgIG1heEhlaWdodCxcbiAgICAgICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG4gICAgICBwb3J0YWxUYXJnZXQsXG4gICAgICBkeW5hbWljRG9tUmVuZGVyaW5nLFxuICAgIH06IFBvcG92ZXJQcm9wcyxcbiAgICByZWY6IFJlZjxIVE1MRGl2RWxlbWVudD4sXG4gICkgPT4ge1xuICAgIGNvbnN0IGlubmVyUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKVxuICAgIGNvbnN0IFtsb2NhbFZpc2libGUsIHNldExvY2FsVmlzaWJsZV0gPSB1c2VTdGF0ZSh2aXNpYmxlKVxuXG4gICAgLy8gV2UgY2hhbmdlIGxvY2FsIHZhbHVlIGlmIHZpc2libGUgcHJvcCBjaGFuZ2VzXG4gICAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICAgIHNldExvY2FsVmlzaWJsZSh2aXNpYmxlKVxuICAgIH0sIFt2aXNpYmxlXSlcblxuICAgIGNvbnN0IGxvY2FsT25DbG9zZSA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICAgIHNldExvY2FsVmlzaWJsZShmYWxzZSlcbiAgICAgIG9uQ2xvc2U/LigpXG4gICAgfSwgW29uQ2xvc2VdKVxuXG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRQb3B1cFxuICAgICAgICBoaWRlT25DbGlja091dHNpZGVcbiAgICAgICAgZGVib3VuY2VEZWxheT17MH1cbiAgICAgICAgdmlzaWJsZT17bG9jYWxWaXNpYmxlfVxuICAgICAgICBwbGFjZW1lbnQ9e3BsYWNlbWVudH1cbiAgICAgICAgdGV4dD17XG4gICAgICAgICAgPENvbnRlbnRXcmFwcGVyXG4gICAgICAgICAgICB0aXRsZT17dGl0bGV9XG4gICAgICAgICAgICBvbkNsb3NlPXtsb2NhbE9uQ2xvc2V9XG4gICAgICAgICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7Y29udGVudH1cbiAgICAgICAgICA8L0NvbnRlbnRXcmFwcGVyPlxuICAgICAgICB9XG4gICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgIHJvbGU9XCJkaWFsb2dcIlxuICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgdGFiSW5kZXg9ey0xfVxuICAgICAgICBpbm5lclJlZj17aW5uZXJSZWZ9XG4gICAgICAgIG9uQ2xvc2U9e2xvY2FsT25DbG9zZX1cbiAgICAgICAgbWF4V2lkdGg9e21heFdpZHRofVxuICAgICAgICBtYXhIZWlnaHQ9e21heEhlaWdodH1cbiAgICAgICAgcG9ydGFsVGFyZ2V0PXtwb3J0YWxUYXJnZXR9XG4gICAgICAgIGR5bmFtaWNEb21SZW5kZXJpbmc9e2R5bmFtaWNEb21SZW5kZXJpbmd9XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvU3R5bGVkUG9wdXA+XG4gICAgKVxuICB9LFxuKVxuIl19 */"));
51
+ const StyledStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
52
+ target: "ejpxv5a0"
53
+ } : {
54
+ target: "ejpxv5a0",
55
+ label: "StyledStack"
56
+ })("color:", ({
57
+ theme
58
+ }) => theme.colors.neutral.text, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BvcG92ZXIvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFEaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUG9wb3Zlci9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgQ29tcG9uZW50UHJvcHMsIFJlYWN0Tm9kZSwgUmVmIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBmb3J3YXJkUmVmLCB1c2VDYWxsYmFjaywgdXNlRWZmZWN0LCB1c2VSZWYsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi9CdXR0b24nXG5pbXBvcnQgeyBQb3B1cCB9IGZyb20gJy4uL1BvcHVwJ1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuXG50eXBlIFNlbnRpbWVudFR5cGUgPSAnbmV1dHJhbCcgfCAncHJpbWFyeSdcblxuY29uc3QgU0laRVNfV0lEVEggPSB7XG4gIHNtYWxsOiAzMjAsXG4gIG1lZGl1bTogNDIwLFxuICBsYXJnZTogNTIwLFxufVxuXG5jb25zdCBTdHlsZWRQb3B1cCA9IHN0eWxlZChQb3B1cCwge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydzZW50aW1lbnQnLCAnc2l6ZSddLmluY2x1ZGVzKHByb3ApLFxufSk8e1xuICBzZW50aW1lbnQ6IFNlbnRpbWVudFR5cGVcbiAgc2l6ZToga2V5b2YgdHlwZW9mIFNJWkVTX1dJRFRIXG59PmBcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiBTSVpFU19XSURUSFtzaXplXX1weDtcbiAgbWF4LXdpZHRoOiAkeyh7IHNpemUgfSkgPT4gU0laRVNfV0lEVEhbc2l6ZV19cHg7XG4gIHRleHQtYWxpZ246IGluaXRpYWw7XG5cbiAgJHsoeyB0aGVtZSwgc2VudGltZW50IH0pID0+IHtcbiAgICBpZiAoc2VudGltZW50ID09PSAnbmV1dHJhbCcpIHtcbiAgICAgIHJldHVybiBgXG4gICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmR9O1xuICAgICAgYm94LXNoYWRvdzogJHt0aGVtZS5zaGFkb3dzLnBvcG92ZXJ9O1xuICAgICAgJltkYXRhLWhhcy1hcnJvdz0ndHJ1ZSddIHtcbiAgICAgICAgJjo6YWZ0ZXIge1xuICAgICAgICAgIGJvcmRlci1jb2xvcjogJHt0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kfSB0cmFuc3BhcmVudCB0cmFuc3BhcmVudCB0cmFuc3BhcmVudDtcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgYFxuICAgIH1cblxuICAgIHJldHVybiBgXG4gICAgICBiYWNrZ3JvdW5kOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmRTdHJvbmd9O1xuICAgICAgYm94LXNoYWRvdzogJHt0aGVtZS5zaGFkb3dzLnBvcG92ZXJ9O1xuICAgICAgJltkYXRhLWhhcy1hcnJvdz0ndHJ1ZSddIHtcbiAgICAgICAgJjo6YWZ0ZXIge1xuICAgICAgICAgIGJvcmRlci1jb2xvcjogJHt0aGVtZS5jb2xvcnMucHJpbWFyeS5iYWNrZ3JvdW5kU3Ryb25nfSB0cmFuc3BhcmVudCB0cmFuc3BhcmVudCB0cmFuc3BhcmVudDtcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgYFxuICB9fVxuYFxuXG4vLyBUaGlzIGlzIHRvIGF2b2lkIGhhdmluZyB0ZXh0IGluaGVyaXQgY29sb3IgZnJvbSBwb3B1cCAod2hpY2ggaXMgd2hpdGUgb24gd2hpdGUgYmFja2dyb3VuZClcbmNvbnN0IFN0eWxlZFN0YWNrID0gc3R5bGVkKFN0YWNrKWBcbiAgY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dH07XG5gXG5cbnR5cGUgQ29udGVudFdyYXBwZXJQcm9wcyA9IFBpY2s8XG4gIFBvcG92ZXJQcm9wcyxcbiAgJ3RpdGxlJyB8ICdvbkNsb3NlJyB8ICdzZW50aW1lbnQnIHwgJ2NoaWxkcmVuJ1xuPlxuXG5jb25zdCBDb250ZW50V3JhcHBlciA9ICh7XG4gIHRpdGxlLFxuICBvbkNsb3NlLFxuICBjaGlsZHJlbixcbiAgc2VudGltZW50LFxufTogQ29udGVudFdyYXBwZXJQcm9wcykgPT4gKFxuICA8U3R5bGVkU3RhY2sgZ2FwPXsxfT5cbiAgICA8U3RhY2sgZGlyZWN0aW9uPVwicm93XCIganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCI+XG4gICAgICA8VGV4dFxuICAgICAgICB2YXJpYW50PVwiYm9keVN0cm9uZ1wiXG4gICAgICAgIGFzPVwiaDNcIlxuICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgcHJvbWluZW5jZT17c2VudGltZW50ID09PSAnbmV1dHJhbCcgPyAnc3Ryb25nJyA6ICdzdHJvbmdlcid9XG4gICAgICA+XG4gICAgICAgIHt0aXRsZX1cbiAgICAgIDwvVGV4dD5cbiAgICAgIDxCdXR0b25cbiAgICAgICAgdmFyaWFudD17c2VudGltZW50ID09PSAnbmV1dHJhbCcgPyAnZ2hvc3QnIDogJ2ZpbGxlZCd9XG4gICAgICAgIHNlbnRpbWVudD17c2VudGltZW50ID09PSAnbmV1dHJhbCcgPyAnbmV1dHJhbCcgOiAncHJpbWFyeSd9XG4gICAgICAgIG9uQ2xpY2s9e29uQ2xvc2V9XG4gICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgIGljb249XCJjbG9zZVwiXG4gICAgICAgIGFyaWEtbGFiZWw9XCJjbG9zZVwiXG4gICAgICAvPlxuICAgIDwvU3RhY2s+XG4gICAge3R5cGVvZiBjaGlsZHJlbiA9PT0gJ3N0cmluZycgPyAoXG4gICAgICA8VGV4dFxuICAgICAgICB2YXJpYW50PVwiYm9keVNtYWxsXCJcbiAgICAgICAgYXM9XCJwXCJcbiAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgIHByb21pbmVuY2U9e3NlbnRpbWVudCA9PT0gJ25ldXRyYWwnID8gJ3N0cm9uZycgOiAnc3Ryb25nZXInfVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L1RleHQ+XG4gICAgKSA6IChcbiAgICAgIGNoaWxkcmVuXG4gICAgKX1cbiAgPC9TdHlsZWRTdGFjaz5cbilcblxudHlwZSBQb3BvdmVyUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgY29udGVudDogUmVhY3ROb2RlXG4gIHRpdGxlOiBzdHJpbmdcbiAgc2VudGltZW50PzogU2VudGltZW50VHlwZVxuICB2aXNpYmxlPzogYm9vbGVhblxuICBzaXplPzoga2V5b2YgdHlwZW9mIFNJWkVTX1dJRFRIXG4gIG9uQ2xvc2U/OiAoKSA9PiB2b2lkXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAnZGF0YS10ZXN0aWQnPzogc3RyaW5nXG4gIG1heFdpZHRoPzogc3RyaW5nXG4gIG1heEhlaWdodD86IHN0cmluZ1xuICAvKipcbiAgICogQnkgZGVmYXVsdCwgdGhlIHBvcnRhbCB0YXJnZXQgaXMgY2hpbGRyZW4gY29udGFpbmVyIG9yIGRvY3VtZW50LmJvZHkgaWYgY2hpbGRyZW4gaXMgYSBmdW5jdGlvbi4gWW91IGNhbiBvdmVycmlkZSB0aGlzXG4gICAqIGJlaGF2aW9yIGJ5IHNldHRpbmcgYSBwb3J0YWxUYXJnZXQgcHJvcC5cbiAgICovXG4gIHBvcnRhbFRhcmdldD86IEhUTUxFbGVtZW50XG59ICYgUGljazxDb21wb25lbnRQcm9wczx0eXBlb2YgUG9wdXA+LCAncGxhY2VtZW50JyB8ICdkeW5hbWljRG9tUmVuZGVyaW5nJz5cblxuLyoqXG4gKiBQb3BvdmVyIGNvbXBvbmVudCBpcyB1c2VkIHRvIGRpc3BsYXkgYWRkaXRpb25hbCBpbmZvcm1hdGlvbiBvciBhY3Rpb25zIG9uIHRvcCBvZiB0aGUgbWFpbiBjb250ZW50IG9mIHRoZSBwYWdlLlxuICogSXQgaXMgdXN1YWxseSB0cmlnZ2VyZWQgYnkgY2xpY2tpbmcgb24gYSBidXR0b24uIEl0IGluY2x1ZGVzIGEgdGl0bGUsIGEgY2xvc2UgYnV0dG9uIGFuZCBhIGNvbnRlbnQgYXJlYS5cbiAqL1xuZXhwb3J0IGNvbnN0IFBvcG92ZXIgPSBmb3J3YXJkUmVmKFxuICAoXG4gICAge1xuICAgICAgdmlzaWJsZSA9IGZhbHNlLFxuICAgICAgY2hpbGRyZW4sXG4gICAgICBwbGFjZW1lbnQsXG4gICAgICBjb250ZW50LFxuICAgICAgdGl0bGUsXG4gICAgICBzZW50aW1lbnQgPSAnbmV1dHJhbCcsXG4gICAgICBzaXplID0gJ21lZGl1bScsXG4gICAgICBvbkNsb3NlLFxuICAgICAgY2xhc3NOYW1lLFxuICAgICAgbWF4V2lkdGgsXG4gICAgICBtYXhIZWlnaHQsXG4gICAgICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxuICAgICAgcG9ydGFsVGFyZ2V0LFxuICAgICAgZHluYW1pY0RvbVJlbmRlcmluZyxcbiAgICB9OiBQb3BvdmVyUHJvcHMsXG4gICAgcmVmOiBSZWY8SFRNTERpdkVsZW1lbnQ+LFxuICApID0+IHtcbiAgICBjb25zdCBpbm5lclJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbClcbiAgICBjb25zdCBbbG9jYWxWaXNpYmxlLCBzZXRMb2NhbFZpc2libGVdID0gdXNlU3RhdGUodmlzaWJsZSlcblxuICAgIC8vIFdlIGNoYW5nZSBsb2NhbCB2YWx1ZSBpZiB2aXNpYmxlIHByb3AgY2hhbmdlc1xuICAgIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgICBzZXRMb2NhbFZpc2libGUodmlzaWJsZSlcbiAgICB9LCBbdmlzaWJsZV0pXG5cbiAgICBjb25zdCBsb2NhbE9uQ2xvc2UgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgICBzZXRMb2NhbFZpc2libGUoZmFsc2UpXG4gICAgICBvbkNsb3NlPy4oKVxuICAgIH0sIFtvbkNsb3NlXSlcblxuICAgIHJldHVybiAoXG4gICAgICA8U3R5bGVkUG9wdXBcbiAgICAgICAgaGlkZU9uQ2xpY2tPdXRzaWRlXG4gICAgICAgIGRlYm91bmNlRGVsYXk9ezB9XG4gICAgICAgIHZpc2libGU9e2xvY2FsVmlzaWJsZX1cbiAgICAgICAgcGxhY2VtZW50PXtwbGFjZW1lbnR9XG4gICAgICAgIHRleHQ9e1xuICAgICAgICAgIDxDb250ZW50V3JhcHBlclxuICAgICAgICAgICAgdGl0bGU9e3RpdGxlfVxuICAgICAgICAgICAgb25DbG9zZT17bG9jYWxPbkNsb3NlfVxuICAgICAgICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICAgICAgPlxuICAgICAgICAgICAge2NvbnRlbnR9XG4gICAgICAgICAgPC9Db250ZW50V3JhcHBlcj5cbiAgICAgICAgfVxuICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICByb2xlPVwiZGlhbG9nXCJcbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIHRhYkluZGV4PXstMX1cbiAgICAgICAgaW5uZXJSZWY9e2lubmVyUmVmfVxuICAgICAgICBvbkNsb3NlPXtsb2NhbE9uQ2xvc2V9XG4gICAgICAgIG1heFdpZHRoPXttYXhXaWR0aH1cbiAgICAgICAgbWF4SGVpZ2h0PXttYXhIZWlnaHR9XG4gICAgICAgIHBvcnRhbFRhcmdldD17cG9ydGFsVGFyZ2V0fVxuICAgICAgICBkeW5hbWljRG9tUmVuZGVyaW5nPXtkeW5hbWljRG9tUmVuZGVyaW5nfVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L1N0eWxlZFBvcHVwPlxuICAgIClcbiAgfSxcbilcbiJdfQ== */"));
59
+ const ContentWrapper = ({
60
+ title,
61
+ onClose,
62
+ children,
63
+ sentiment
64
+ }) => /* @__PURE__ */ jsxs(StyledStack, { gap: 1, children: [
65
+ /* @__PURE__ */ jsxs(Stack, { direction: "row", justifyContent: "space-between", children: [
66
+ /* @__PURE__ */ jsx(Text, { variant: "bodyStrong", as: "h3", sentiment: "neutral", prominence: sentiment === "neutral" ? "strong" : "stronger", children: title }),
67
+ /* @__PURE__ */ jsx(Button, { variant: sentiment === "neutral" ? "ghost" : "filled", sentiment: sentiment === "neutral" ? "neutral" : "primary", onClick: onClose, size: "small", icon: "close", "aria-label": "close" })
68
+ ] }),
69
+ typeof children === "string" ? /* @__PURE__ */ jsx(Text, { variant: "bodySmall", as: "p", sentiment: "neutral", prominence: sentiment === "neutral" ? "strong" : "stronger", children }) : children
70
+ ] });
71
+ const Popover = forwardRef(({
72
+ visible = false,
73
+ children,
74
+ placement,
75
+ content,
76
+ title,
77
+ sentiment = "neutral",
78
+ size = "medium",
79
+ onClose,
80
+ className,
81
+ maxWidth,
82
+ maxHeight,
83
+ "data-testid": dataTestId,
84
+ portalTarget,
85
+ dynamicDomRendering
86
+ }, ref) => {
87
+ const innerRef = useRef(null);
88
+ const [localVisible, setLocalVisible] = useState(visible);
89
+ useEffect(() => {
90
+ setLocalVisible(visible);
91
+ }, [visible]);
92
+ const localOnClose = useCallback(() => {
93
+ setLocalVisible(false);
94
+ onClose?.();
95
+ }, [onClose]);
96
+ return /* @__PURE__ */ jsx(StyledPopup, { hideOnClickOutside: true, debounceDelay: 0, visible: localVisible, placement, text: /* @__PURE__ */ jsx(ContentWrapper, { title, onClose: localOnClose, sentiment, children: content }), className, sentiment, "data-testid": dataTestId, size, role: "dialog", ref, tabIndex: -1, innerRef, onClose: localOnClose, maxWidth, maxHeight, portalTarget, dynamicDomRendering, children });
97
+ });
98
+ export {
99
+ Popover
100
+ };
@@ -0,0 +1,11 @@
1
+ export type PositionsType = {
2
+ arrowLeft: number;
3
+ arrowTop: number;
4
+ arrowTransform: string;
5
+ placement: string;
6
+ rotate: number;
7
+ popupInitialPosition: string;
8
+ popupPosition: string;
9
+ };
10
+ export declare const animation: (positions: PositionsType) => import("@emotion/react").Keyframes;
11
+ export declare const exitAnimation: (positions: PositionsType) => import("@emotion/react").Keyframes;
@@ -1,6 +1,5 @@
1
- import { keyframes } from '@emotion/react';
2
-
3
- const animation = positions => keyframes`
1
+ import { keyframes } from "@emotion/react";
2
+ const animation = (positions) => keyframes`
4
3
  0% {
5
4
  opacity: 0;
6
5
  transform: ${positions.popupInitialPosition};
@@ -10,7 +9,7 @@ const animation = positions => keyframes`
10
9
  transform: ${positions.popupPosition};
11
10
  }
12
11
  `;
13
- const exitAnimation = positions => keyframes`
12
+ const exitAnimation = (positions) => keyframes`
14
13
  0% {
15
14
  opacity: 1;
16
15
  transform: ${positions.popupPosition};
@@ -20,5 +19,7 @@ const exitAnimation = positions => keyframes`
20
19
  transform: ${positions.popupInitialPosition};
21
20
  }
22
21
  `;
23
-
24
- export { animation, exitAnimation };
22
+ export {
23
+ animation,
24
+ exitAnimation
25
+ };
@@ -0,0 +1,31 @@
1
+ import type { RefObject } from 'react';
2
+ export type PopupPlacement = 'top' | 'right' | 'bottom' | 'left' | 'auto';
3
+ export declare const ARROW_WIDTH = 8;
4
+ export declare const DEFAULT_POSITIONS: {
5
+ arrowLeft: number;
6
+ arrowTop: number;
7
+ arrowTransform: string;
8
+ placement: string;
9
+ rotate: number;
10
+ popupInitialPosition: string;
11
+ popupPosition: string;
12
+ };
13
+ type ComputePositionsTypes = {
14
+ placement: PopupPlacement;
15
+ childrenRef: RefObject<HTMLDivElement>;
16
+ popupRef: RefObject<HTMLDivElement>;
17
+ popupPortalTarget: HTMLElement;
18
+ };
19
+ /**
20
+ * This function will compute the positions of popup and arrow based on children position and popup size
21
+ */
22
+ export declare const computePositions: ({ placement, childrenRef, popupRef, popupPortalTarget, }: ComputePositionsTypes) => {
23
+ arrowLeft: number;
24
+ arrowTop: number;
25
+ arrowTransform: string;
26
+ placement: string;
27
+ rotate: number;
28
+ popupInitialPosition: string;
29
+ popupPosition: string;
30
+ };
31
+ export {};
@@ -0,0 +1,216 @@
1
+ const ARROW_WIDTH = 8;
2
+ const SPACE = 4;
3
+ const TOTAL_USED_SPACE = 0;
4
+ const DEFAULT_POSITIONS = {
5
+ arrowLeft: 0,
6
+ arrowTop: 0,
7
+ arrowTransform: "translate(-50%, -50)",
8
+ placement: "top",
9
+ rotate: 135,
10
+ popupInitialPosition: "translate3d(0px, 0px, 0)",
11
+ popupPosition: "translate3d(0px, 0px, 0)"
12
+ };
13
+ const computePlacement = ({
14
+ childrenStructuredRef,
15
+ popupStructuredRef,
16
+ offsetParentRect,
17
+ offsetParent,
18
+ popupPortalTarget
19
+ }) => {
20
+ const {
21
+ top: childrenTop,
22
+ left: childrenLeft,
23
+ right: childrenRight,
24
+ width: childrenWidth
25
+ } = childrenStructuredRef;
26
+ const {
27
+ top: parentTop,
28
+ left: parentLeft
29
+ } = offsetParentRect;
30
+ const isPopupPortalTargetBody = popupPortalTarget === document.body || offsetParent === document.body;
31
+ const overloadedChildrenLeft = isPopupPortalTargetBody ? childrenLeft : childrenLeft - parentLeft;
32
+ const overloadedChildrenTop = isPopupPortalTargetBody ? childrenTop : childrenTop - parentTop;
33
+ const overloadedChildrenRight = isPopupPortalTargetBody ? childrenRight : childrenLeft - parentLeft + childrenWidth;
34
+ const {
35
+ width: popupWidth,
36
+ height: popupHeight
37
+ } = popupStructuredRef;
38
+ if (overloadedChildrenTop - popupHeight - TOTAL_USED_SPACE < 0) {
39
+ return "bottom";
40
+ }
41
+ if (overloadedChildrenLeft - popupWidth - TOTAL_USED_SPACE < 0) {
42
+ return "right";
43
+ }
44
+ if (overloadedChildrenRight + popupWidth + TOTAL_USED_SPACE > window.innerWidth) {
45
+ return "left";
46
+ }
47
+ return "top";
48
+ };
49
+ const findOffsetParent = (element) => {
50
+ const offsetParent = element?.current?.offsetParent;
51
+ if (offsetParent && !["TH", "TD", "TABLE"].includes(offsetParent.tagName)) {
52
+ return offsetParent;
53
+ }
54
+ let currentElement = element?.current;
55
+ while (currentElement && currentElement.tagName !== "BODY") {
56
+ const {
57
+ position
58
+ } = window.getComputedStyle(currentElement);
59
+ if (position !== "static") {
60
+ return currentElement;
61
+ }
62
+ currentElement = currentElement.parentElement;
63
+ }
64
+ return document.body;
65
+ };
66
+ const getPopupOverflowFromParent = (position, offsetParentRect, childrenRect, popupStructuredRef) => {
67
+ const {
68
+ top: parentTop,
69
+ left: parentLeft,
70
+ right: parentRight
71
+ } = offsetParentRect;
72
+ const {
73
+ top: childrenTop,
74
+ bottom: childrenBottom,
75
+ left: childrenLeft,
76
+ right: childrenRight,
77
+ width: childrenWidth
78
+ } = childrenRect;
79
+ const {
80
+ width: popupWidth,
81
+ height: popupHeight
82
+ } = popupStructuredRef;
83
+ const popupHalfWidthWithArrow = popupWidth / 2 - ARROW_WIDTH;
84
+ const popupHalfHeightWithArrow = popupHeight / 2 - ARROW_WIDTH;
85
+ if (position === "top" || position === "bottom") {
86
+ const popupOverflowRight = childrenRight - childrenWidth / 2 + popupWidth / 2;
87
+ const popupOverflowLeft = childrenLeft + childrenWidth / 2 - parentLeft - popupWidth / 2;
88
+ if (popupOverflowRight > parentRight) {
89
+ if (Math.abs(popupOverflowRight - parentRight) > popupHalfWidthWithArrow) {
90
+ return -popupHalfWidthWithArrow;
91
+ }
92
+ return parentRight - popupOverflowRight;
93
+ }
94
+ if (popupOverflowLeft < 0) {
95
+ if (Math.abs(popupOverflowLeft) > popupHalfWidthWithArrow) {
96
+ return popupHalfWidthWithArrow;
97
+ }
98
+ return Math.abs(popupOverflowLeft);
99
+ }
100
+ }
101
+ if (position === "left" || position === "right") {
102
+ const popupOverflowTop = childrenTop - parentTop - popupHeight / 2;
103
+ if (popupOverflowTop < 0) {
104
+ if (Math.abs(childrenTop - parentTop - popupHalfHeightWithArrow) > popupHalfHeightWithArrow) {
105
+ return popupHalfHeightWithArrow;
106
+ }
107
+ return Math.abs(popupOverflowTop);
108
+ }
109
+ if (childrenBottom + popupHeight > window.innerHeight) {
110
+ return -popupHalfHeightWithArrow;
111
+ }
112
+ }
113
+ return 0;
114
+ };
115
+ const computePositions = ({
116
+ placement,
117
+ childrenRef,
118
+ popupRef,
119
+ popupPortalTarget
120
+ }) => {
121
+ const childrenRect = childrenRef.current.getBoundingClientRect();
122
+ const offsetParent = findOffsetParent(childrenRef);
123
+ const offsetParentRect = offsetParent?.getBoundingClientRect() ?? {
124
+ top: 0,
125
+ left: 0,
126
+ right: 0
127
+ };
128
+ const popupStructuredRef = popupRef.current.getBoundingClientRect();
129
+ const placementBasedOnWindowSize = placement === "auto" ? computePlacement({
130
+ childrenStructuredRef: childrenRect,
131
+ popupStructuredRef,
132
+ offsetParentRect,
133
+ popupPortalTarget,
134
+ offsetParent
135
+ }) : placement;
136
+ const {
137
+ top: childrenTop,
138
+ left: childrenLeft,
139
+ right: childrenRight,
140
+ width: childrenWidth,
141
+ height: childrenHeight
142
+ } = childrenRect;
143
+ const {
144
+ top: parentTop,
145
+ left: parentLeft
146
+ } = offsetParentRect;
147
+ const {
148
+ width: popupWidth,
149
+ height: popupHeight
150
+ } = popupStructuredRef;
151
+ const isPopupPortalTargetBody = popupPortalTarget === document.body || offsetParent === document.body;
152
+ const scrollTopValue = isPopupPortalTargetBody ? document.documentElement.scrollTop : offsetParent.scrollTop;
153
+ const overloadedChildrenLeft = isPopupPortalTargetBody ? childrenLeft : childrenLeft - parentLeft;
154
+ const overloadedChildrenTop = isPopupPortalTargetBody ? childrenTop : childrenTop - parentTop;
155
+ const overloadedChildrenRight = isPopupPortalTargetBody ? childrenRight : childrenLeft - parentLeft + childrenWidth;
156
+ const popupOverflow = getPopupOverflowFromParent(placementBasedOnWindowSize, offsetParentRect, childrenRect, popupStructuredRef);
157
+ switch (placementBasedOnWindowSize) {
158
+ case "bottom": {
159
+ const positionX = overloadedChildrenLeft + childrenWidth / 2 - popupWidth / 2;
160
+ const positionY = overloadedChildrenTop + scrollTopValue + childrenHeight + ARROW_WIDTH + SPACE;
161
+ return {
162
+ arrowLeft: popupWidth / 2 + popupOverflow * -1,
163
+ arrowTop: -ARROW_WIDTH - 5,
164
+ arrowTransform: "",
165
+ placement: "bottom",
166
+ rotate: 180,
167
+ popupInitialPosition: `translate3d(${positionX + popupOverflow}px, ${positionY - TOTAL_USED_SPACE}px, 0)`,
168
+ popupPosition: `translate3d(${positionX + popupOverflow}px, ${positionY}px, 0)`
169
+ };
170
+ }
171
+ case "left": {
172
+ const positionX = overloadedChildrenLeft - popupWidth - ARROW_WIDTH - SPACE * 2;
173
+ const positionY = overloadedChildrenTop + scrollTopValue - popupHeight / 2 + childrenHeight / 2;
174
+ return {
175
+ arrowLeft: popupWidth + ARROW_WIDTH + 5,
176
+ arrowTop: popupHeight / 2 + popupOverflow * -1,
177
+ arrowTransform: "translate(-50%, -50%)",
178
+ placement: "left",
179
+ rotate: -90,
180
+ popupInitialPosition: `translate3d(${positionX + TOTAL_USED_SPACE}px, ${positionY + popupOverflow}px, 0)`,
181
+ popupPosition: `translate3d(${positionX}px, ${positionY + popupOverflow}px, 0)`
182
+ };
183
+ }
184
+ case "right": {
185
+ const positionX = overloadedChildrenRight + ARROW_WIDTH + SPACE * 2;
186
+ const positionY = overloadedChildrenTop + scrollTopValue - popupHeight / 2 + childrenHeight / 2;
187
+ return {
188
+ arrowLeft: -ARROW_WIDTH - 5,
189
+ arrowTop: popupHeight / 2 + popupOverflow * -1,
190
+ arrowTransform: "translate(50%, -50%)",
191
+ placement: "right",
192
+ rotate: 90,
193
+ popupInitialPosition: `translate3d(${positionX - TOTAL_USED_SPACE}px, ${positionY + popupOverflow}px, 0)`,
194
+ popupPosition: `translate3d(${positionX}px, ${positionY + popupOverflow}px, 0)`
195
+ };
196
+ }
197
+ default: {
198
+ const positionX = overloadedChildrenLeft + childrenWidth / 2 - popupWidth / 2;
199
+ const positionY = overloadedChildrenTop + scrollTopValue - popupHeight - ARROW_WIDTH - SPACE;
200
+ return {
201
+ arrowLeft: popupWidth / 2 + popupOverflow * -1,
202
+ arrowTop: popupHeight - 1,
203
+ arrowTransform: "",
204
+ placement: "top",
205
+ rotate: 0,
206
+ popupInitialPosition: `translate3d(${positionX + popupOverflow}px, ${positionY + TOTAL_USED_SPACE}px, 0)`,
207
+ popupPosition: `translate3d(${positionX + popupOverflow}px, ${positionY}px, 0)`
208
+ };
209
+ }
210
+ }
211
+ };
212
+ export {
213
+ ARROW_WIDTH,
214
+ DEFAULT_POSITIONS,
215
+ computePositions
216
+ };