@chartts/core 0.1.2 → 0.1.4

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 (563) hide show
  1. package/LICENSE +21 -0
  2. package/dist/{area-type-B3CtuIIP.d.cts → area-type-BanqpQvK.d.cts} +1 -1
  3. package/dist/{area-type-DmB6fTVf.d.ts → area-type-Bzn6ur_t.d.ts} +1 -1
  4. package/dist/area.cjs +10 -10
  5. package/dist/area.d.cts +4 -4
  6. package/dist/area.d.ts +4 -4
  7. package/dist/area.js +5 -5
  8. package/dist/{bar-type-CkI-kkrC.d.cts → bar-type-BjYOtm2e.d.cts} +1 -1
  9. package/dist/{bar-type-Bne_khsO.d.ts → bar-type-D1gkUeQ2.d.ts} +1 -1
  10. package/dist/bar.cjs +9 -9
  11. package/dist/bar.d.cts +4 -4
  12. package/dist/bar.d.ts +4 -4
  13. package/dist/bar.js +4 -4
  14. package/dist/{baseline-type-B1O4XHT3.d.ts → baseline-type-DnAv8oax.d.ts} +1 -1
  15. package/dist/{baseline-type-BAPrZJ5W.d.cts → baseline-type-DskNy6iR.d.cts} +1 -1
  16. package/dist/baseline.cjs +9 -9
  17. package/dist/baseline.d.cts +4 -4
  18. package/dist/baseline.d.ts +4 -4
  19. package/dist/baseline.js +4 -4
  20. package/dist/{boxplot-type-CEWf7p5X.d.ts → boxplot-type-Bi46NGr5.d.ts} +1 -1
  21. package/dist/{boxplot-type-Da8_smoe.d.cts → boxplot-type-Df2L92GY.d.cts} +1 -1
  22. package/dist/boxplot.cjs +9 -9
  23. package/dist/boxplot.d.cts +4 -4
  24. package/dist/boxplot.d.ts +4 -4
  25. package/dist/boxplot.js +4 -4
  26. package/dist/{bubble-type-Dxb2JCKv.d.cts → bubble-type-D2_dA-tK.d.cts} +1 -1
  27. package/dist/{bubble-type-pru5MgB7.d.ts → bubble-type-XCkdPCxY.d.ts} +1 -1
  28. package/dist/bubble.cjs +9 -9
  29. package/dist/bubble.d.cts +4 -4
  30. package/dist/bubble.d.ts +4 -4
  31. package/dist/bubble.js +4 -4
  32. package/dist/{bullet-type-CPEYkEvt.d.ts → bullet-type-CluDVdqG.d.ts} +1 -1
  33. package/dist/{bullet-type-khCmwFqH.d.cts → bullet-type-yyHFEoBR.d.cts} +1 -1
  34. package/dist/bullet.cjs +10 -10
  35. package/dist/bullet.d.cts +4 -4
  36. package/dist/bullet.d.ts +4 -4
  37. package/dist/bullet.js +5 -5
  38. package/dist/{calendar-type-yJWPY6qT.d.ts → calendar-type-BXl4jP0I.d.ts} +1 -1
  39. package/dist/{calendar-type-Br5mpdea.d.cts → calendar-type-_hW3OLW-.d.cts} +1 -1
  40. package/dist/calendar.cjs +10 -10
  41. package/dist/calendar.d.cts +4 -4
  42. package/dist/calendar.d.ts +4 -4
  43. package/dist/calendar.js +5 -5
  44. package/dist/{candlestick-type-CtLZy_uC.d.ts → candlestick-type-CAfkfMPN.d.ts} +1 -1
  45. package/dist/{candlestick-type-CazXUb77.d.cts → candlestick-type-D-fhJzmV.d.cts} +1 -1
  46. package/dist/candlestick.cjs +9 -9
  47. package/dist/candlestick.d.cts +4 -4
  48. package/dist/candlestick.d.ts +4 -4
  49. package/dist/candlestick.js +4 -4
  50. package/dist/{chord-type-ruvHboZl.d.ts → chord-type-BLjyRxsx.d.ts} +1 -1
  51. package/dist/{chord-type-ChIZaOZd.d.cts → chord-type-Dvuvx5rp.d.cts} +1 -1
  52. package/dist/chord.cjs +10 -10
  53. package/dist/chord.d.cts +4 -4
  54. package/dist/chord.d.ts +4 -4
  55. package/dist/chord.js +5 -5
  56. package/dist/{chunk-S6NGWPXC.js → chunk-24557PYN.js} +4 -4
  57. package/dist/chunk-24557PYN.js.map +1 -0
  58. package/dist/{chunk-K2EZ4SS4.js → chunk-2BUIZDOB.js} +5 -5
  59. package/dist/chunk-2BUIZDOB.js.map +1 -0
  60. package/dist/{chunk-TVPS2NJH.cjs → chunk-2IMUTDTD.cjs} +11 -11
  61. package/dist/chunk-2IMUTDTD.cjs.map +1 -0
  62. package/dist/{chunk-2KMMVJEE.cjs → chunk-2IWLOBSF.cjs} +7 -7
  63. package/dist/chunk-2IWLOBSF.cjs.map +1 -0
  64. package/dist/{chunk-MQBKLKYF.js → chunk-2JYK52HV.js} +4 -4
  65. package/dist/{chunk-MQBKLKYF.js.map → chunk-2JYK52HV.js.map} +1 -1
  66. package/dist/{chunk-KEMT7F5H.cjs → chunk-2QRCHYTZ.cjs} +9 -9
  67. package/dist/chunk-2QRCHYTZ.cjs.map +1 -0
  68. package/dist/{chunk-JT6H7G52.js → chunk-34DQGCPP.js} +5 -5
  69. package/dist/chunk-34DQGCPP.js.map +1 -0
  70. package/dist/{chunk-6WJJ26J5.js → chunk-3JB4JBBK.js} +6 -6
  71. package/dist/chunk-3JB4JBBK.js.map +1 -0
  72. package/dist/{chunk-SLJNRP7O.cjs → chunk-3NHH6C4K.cjs} +14 -24
  73. package/dist/chunk-3NHH6C4K.cjs.map +1 -0
  74. package/dist/{chunk-K7UR7GYC.cjs → chunk-3SVNEKXE.cjs} +13 -13
  75. package/dist/chunk-3SVNEKXE.cjs.map +1 -0
  76. package/dist/{chunk-S64PTNT7.cjs → chunk-4D6PVH2C.cjs} +27 -30
  77. package/dist/chunk-4D6PVH2C.cjs.map +1 -0
  78. package/dist/{chunk-N7NZQVIV.cjs → chunk-4MNVJVK3.cjs} +7 -7
  79. package/dist/chunk-4MNVJVK3.cjs.map +1 -0
  80. package/dist/{chunk-VGGKMTO6.js → chunk-4QRND2V5.js} +4 -4
  81. package/dist/chunk-4QRND2V5.js.map +1 -0
  82. package/dist/{chunk-MZQY2FTP.cjs → chunk-55ZTXQQQ.cjs} +13 -13
  83. package/dist/chunk-55ZTXQQQ.cjs.map +1 -0
  84. package/dist/{chunk-YMJQUKKX.js → chunk-56BN43J4.js} +68 -42
  85. package/dist/chunk-56BN43J4.js.map +1 -0
  86. package/dist/{chunk-QRTYX5KO.js → chunk-5E7FXDBM.js} +5 -5
  87. package/dist/chunk-5E7FXDBM.js.map +1 -0
  88. package/dist/{chunk-RLH3PS3Y.js → chunk-5HZEDCJG.js} +3 -3
  89. package/dist/{chunk-RLH3PS3Y.js.map → chunk-5HZEDCJG.js.map} +1 -1
  90. package/dist/{chunk-7JN6GXML.cjs → chunk-5QT67VYJ.cjs} +13 -11
  91. package/dist/chunk-5QT67VYJ.cjs.map +1 -0
  92. package/dist/{chunk-EYN74SQ5.js → chunk-5QVUBGM7.js} +5 -5
  93. package/dist/chunk-5QVUBGM7.js.map +1 -0
  94. package/dist/{chunk-QCR6L55R.js → chunk-62DBXI4N.js} +8 -5
  95. package/dist/chunk-62DBXI4N.js.map +1 -0
  96. package/dist/{chunk-U7GBOQXX.js → chunk-6QMV75NT.js} +5 -5
  97. package/dist/chunk-6QMV75NT.js.map +1 -0
  98. package/dist/{chunk-IAE4VRB7.cjs → chunk-754Z4OR6.cjs} +35 -10
  99. package/dist/chunk-754Z4OR6.cjs.map +1 -0
  100. package/dist/{chunk-CJEMSKW3.js → chunk-7GLCJPV5.js} +217 -57
  101. package/dist/chunk-7GLCJPV5.js.map +1 -0
  102. package/dist/{chunk-TIHVTKXS.cjs → chunk-7PHOSSLJ.cjs} +11 -11
  103. package/dist/chunk-7PHOSSLJ.cjs.map +1 -0
  104. package/dist/{chunk-EAKXLFOR.cjs → chunk-A5G32G2R.cjs} +11 -11
  105. package/dist/chunk-A5G32G2R.cjs.map +1 -0
  106. package/dist/{chunk-BMTVFAX2.js → chunk-AEQXFDL7.js} +240 -104
  107. package/dist/chunk-AEQXFDL7.js.map +1 -0
  108. package/dist/{chunk-FKAA5FNG.cjs → chunk-ATMSGQCW.cjs} +10 -10
  109. package/dist/chunk-ATMSGQCW.cjs.map +1 -0
  110. package/dist/{chunk-GI7PBJSK.js → chunk-BFBVJ6MU.js} +4 -4
  111. package/dist/chunk-BFBVJ6MU.js.map +1 -0
  112. package/dist/{chunk-IKUA7O73.cjs → chunk-BGGESAAG.cjs} +7 -7
  113. package/dist/{chunk-IKUA7O73.cjs.map → chunk-BGGESAAG.cjs.map} +1 -1
  114. package/dist/{chunk-WS2AL7GY.cjs → chunk-CA42BCSM.cjs} +34 -8
  115. package/dist/chunk-CA42BCSM.cjs.map +1 -0
  116. package/dist/{chunk-CCHMQZIB.js → chunk-CU5ZXVZQ.js} +5 -5
  117. package/dist/chunk-CU5ZXVZQ.js.map +1 -0
  118. package/dist/{chunk-B7IV2PB3.cjs → chunk-CUIPBYMG.cjs} +9 -9
  119. package/dist/chunk-CUIPBYMG.cjs.map +1 -0
  120. package/dist/{chunk-NZWFBAFQ.js → chunk-CWZADOJ6.js} +30 -4
  121. package/dist/chunk-CWZADOJ6.js.map +1 -0
  122. package/dist/{chunk-ID7GYRYL.cjs → chunk-D5QUAWF3.cjs} +11 -11
  123. package/dist/chunk-D5QUAWF3.cjs.map +1 -0
  124. package/dist/{chunk-27E6G2GT.js → chunk-DAAU5H24.js} +4 -4
  125. package/dist/chunk-DAAU5H24.js.map +1 -0
  126. package/dist/{chunk-VK72MICB.cjs → chunk-DT4GG5BF.cjs} +8 -8
  127. package/dist/{chunk-VK72MICB.cjs.map → chunk-DT4GG5BF.cjs.map} +1 -1
  128. package/dist/{chunk-7HOU6XMW.js → chunk-DX77WSIB.js} +25 -28
  129. package/dist/chunk-DX77WSIB.js.map +1 -0
  130. package/dist/{chunk-GQR7IHER.js → chunk-EPUWA3ZW.js} +6 -6
  131. package/dist/chunk-EPUWA3ZW.js.map +1 -0
  132. package/dist/{chunk-EFRBTSUO.cjs → chunk-ESJMEDLY.cjs} +4 -4
  133. package/dist/{chunk-EFRBTSUO.cjs.map → chunk-ESJMEDLY.cjs.map} +1 -1
  134. package/dist/{chunk-KHQRHTTN.js → chunk-EWVXMQRW.js} +40 -30
  135. package/dist/chunk-EWVXMQRW.js.map +1 -0
  136. package/dist/{chunk-2L46SAT7.js → chunk-FGBIJ6PL.js} +30 -5
  137. package/dist/chunk-FGBIJ6PL.js.map +1 -0
  138. package/dist/{chunk-FTKL3UAN.cjs → chunk-FGHSUT6X.cjs} +6 -6
  139. package/dist/{chunk-FTKL3UAN.cjs.map → chunk-FGHSUT6X.cjs.map} +1 -1
  140. package/dist/{chunk-2PRCN5OJ.cjs → chunk-FVLVTY5D.cjs} +6 -6
  141. package/dist/{chunk-2PRCN5OJ.cjs.map → chunk-FVLVTY5D.cjs.map} +1 -1
  142. package/dist/{chunk-ALRCYQQX.cjs → chunk-GBL4R3GH.cjs} +10 -7
  143. package/dist/chunk-GBL4R3GH.cjs.map +1 -0
  144. package/dist/{chunk-SKREYNRK.cjs → chunk-GRXHW5S3.cjs} +45 -35
  145. package/dist/chunk-GRXHW5S3.cjs.map +1 -0
  146. package/dist/{chunk-FSKUEB7P.js → chunk-HCIBBUV5.js} +3 -3
  147. package/dist/{chunk-FSKUEB7P.js.map → chunk-HCIBBUV5.js.map} +1 -1
  148. package/dist/{chunk-MGYBMQAX.cjs → chunk-HCK2VUWD.cjs} +9 -9
  149. package/dist/chunk-HCK2VUWD.cjs.map +1 -0
  150. package/dist/{chunk-NML7F34A.js → chunk-IDZTDJLH.js} +4 -4
  151. package/dist/chunk-IDZTDJLH.js.map +1 -0
  152. package/dist/{chunk-KUFDELQM.cjs → chunk-IF6RQ53Q.cjs} +10 -10
  153. package/dist/chunk-IF6RQ53Q.cjs.map +1 -0
  154. package/dist/{chunk-BMEMMYVF.js → chunk-IOV77VHP.js} +5 -5
  155. package/dist/{chunk-BMEMMYVF.js.map → chunk-IOV77VHP.js.map} +1 -1
  156. package/dist/{chunk-3TLJCGGQ.cjs → chunk-JVVGQLJQ.cjs} +240 -104
  157. package/dist/chunk-JVVGQLJQ.cjs.map +1 -0
  158. package/dist/{chunk-T6LXFMBR.cjs → chunk-JYVRX3BX.cjs} +9 -9
  159. package/dist/{chunk-T6LXFMBR.cjs.map → chunk-JYVRX3BX.cjs.map} +1 -1
  160. package/dist/{chunk-MVJKRPX7.js → chunk-KHG3G2ZX.js} +3 -3
  161. package/dist/{chunk-MVJKRPX7.js.map → chunk-KHG3G2ZX.js.map} +1 -1
  162. package/dist/{chunk-7MXBXWVD.js → chunk-KNMEXOKJ.js} +5 -5
  163. package/dist/chunk-KNMEXOKJ.js.map +1 -0
  164. package/dist/chunk-KWSVJRXX.cjs +128 -0
  165. package/dist/chunk-KWSVJRXX.cjs.map +1 -0
  166. package/dist/{chunk-XKDBNAHH.cjs → chunk-LARNENXE.cjs} +11 -11
  167. package/dist/chunk-LARNENXE.cjs.map +1 -0
  168. package/dist/chunk-LRHMLNPW.js +897 -0
  169. package/dist/chunk-LRHMLNPW.js.map +1 -0
  170. package/dist/{chunk-5LQ26P4J.cjs → chunk-LXYNL7BI.cjs} +11 -11
  171. package/dist/chunk-LXYNL7BI.cjs.map +1 -0
  172. package/dist/{chunk-ARQLGTTV.js → chunk-MEERXUZS.js} +5 -5
  173. package/dist/{chunk-ARQLGTTV.js.map → chunk-MEERXUZS.js.map} +1 -1
  174. package/dist/{chunk-VJQCHBS6.js → chunk-MJY25P44.js} +15 -5
  175. package/dist/chunk-MJY25P44.js.map +1 -0
  176. package/dist/{chunk-3YFDZGHO.cjs → chunk-MSCRIA2U.cjs} +13 -13
  177. package/dist/{chunk-3YFDZGHO.cjs.map → chunk-MSCRIA2U.cjs.map} +1 -1
  178. package/dist/{chunk-DZKYVTV3.js → chunk-N35UAFEU.js} +5 -5
  179. package/dist/{chunk-DZKYVTV3.js.map → chunk-N35UAFEU.js.map} +1 -1
  180. package/dist/{chunk-DAH76GIX.cjs → chunk-NE2W2MF3.cjs} +11 -11
  181. package/dist/chunk-NE2W2MF3.cjs.map +1 -0
  182. package/dist/{chunk-CHERQT4B.js → chunk-NQ7Y6ZKH.js} +4 -4
  183. package/dist/chunk-NQ7Y6ZKH.js.map +1 -0
  184. package/dist/{chunk-AA45U5KV.js → chunk-NRULNA5F.js} +5 -5
  185. package/dist/chunk-NRULNA5F.js.map +1 -0
  186. package/dist/{chunk-PCTMS2PX.cjs → chunk-OEGSDOJ2.cjs} +19 -9
  187. package/dist/chunk-OEGSDOJ2.cjs.map +1 -0
  188. package/dist/{chunk-M6JYSINX.cjs → chunk-OMAW52LY.cjs} +8 -8
  189. package/dist/chunk-OMAW52LY.cjs.map +1 -0
  190. package/dist/{chunk-IUYPKYOU.js → chunk-OMSHGBV3.js} +9 -5
  191. package/dist/chunk-OMSHGBV3.js.map +1 -0
  192. package/dist/{chunk-DZHP4UUE.cjs → chunk-OTXHJHXU.cjs} +16 -12
  193. package/dist/chunk-OTXHJHXU.cjs.map +1 -0
  194. package/dist/{chunk-GUVPVNPD.cjs → chunk-PCAYYCLY.cjs} +11 -11
  195. package/dist/chunk-PCAYYCLY.cjs.map +1 -0
  196. package/dist/{chunk-LCEMO7NI.js → chunk-PKXW45G4.js} +3 -3
  197. package/dist/{chunk-LCEMO7NI.js.map → chunk-PKXW45G4.js.map} +1 -1
  198. package/dist/{chunk-Y4HJCMB4.cjs → chunk-QEPMEEZC.cjs} +7 -7
  199. package/dist/chunk-QEPMEEZC.cjs.map +1 -0
  200. package/dist/{chunk-43WDYYVH.cjs → chunk-QPHUAF3R.cjs} +10 -10
  201. package/dist/chunk-QPHUAF3R.cjs.map +1 -0
  202. package/dist/{chunk-FKVYS4RB.js → chunk-QPHWRD25.js} +15 -8
  203. package/dist/chunk-QPHWRD25.js.map +1 -0
  204. package/dist/chunk-QYI7ZV3B.cjs +899 -0
  205. package/dist/chunk-QYI7ZV3B.cjs.map +1 -0
  206. package/dist/{chunk-3N447NTJ.cjs → chunk-R2W3RJFW.cjs} +14 -14
  207. package/dist/chunk-R2W3RJFW.cjs.map +1 -0
  208. package/dist/{chunk-DZW35WR2.js → chunk-SGZUUUXU.js} +5 -5
  209. package/dist/chunk-SGZUUUXU.js.map +1 -0
  210. package/dist/{chunk-GMLJDDHZ.js → chunk-T7SCCACB.js} +3 -3
  211. package/dist/{chunk-GMLJDDHZ.js.map → chunk-T7SCCACB.js.map} +1 -1
  212. package/dist/{chunk-3NWZJCWL.js → chunk-TC3H6ZED.js} +5 -5
  213. package/dist/chunk-TC3H6ZED.js.map +1 -0
  214. package/dist/{chunk-FIAKZSRR.cjs → chunk-TEZNWW3R.cjs} +19 -12
  215. package/dist/chunk-TEZNWW3R.cjs.map +1 -0
  216. package/dist/{chunk-5M624BRW.js → chunk-THHZMRFU.js} +4 -4
  217. package/dist/chunk-THHZMRFU.js.map +1 -0
  218. package/dist/{chunk-AAKS22M3.cjs → chunk-TLHQ6JCK.cjs} +12 -12
  219. package/dist/{chunk-AAKS22M3.cjs.map → chunk-TLHQ6JCK.cjs.map} +1 -1
  220. package/dist/{chunk-HOPFELRP.cjs → chunk-V5Q6UNUK.cjs} +4 -4
  221. package/dist/{chunk-HOPFELRP.cjs.map → chunk-V5Q6UNUK.cjs.map} +1 -1
  222. package/dist/{chunk-DKVRRL3F.js → chunk-VBMLJUBE.js} +6 -6
  223. package/dist/chunk-VBMLJUBE.js.map +1 -0
  224. package/dist/chunk-VGJD4F4H.js +126 -0
  225. package/dist/chunk-VGJD4F4H.js.map +1 -0
  226. package/dist/{chunk-GL3M7MAM.js → chunk-VJXUBN7J.js} +4 -4
  227. package/dist/chunk-VJXUBN7J.js.map +1 -0
  228. package/dist/{chunk-4ABM7UYD.js → chunk-VUHNBLFA.js} +4 -4
  229. package/dist/chunk-VUHNBLFA.js.map +1 -0
  230. package/dist/{chunk-D2IP3MWJ.cjs → chunk-W476ER4X.cjs} +219 -59
  231. package/dist/chunk-W476ER4X.cjs.map +1 -0
  232. package/dist/{chunk-3QXN7JBV.js → chunk-WZCES5M6.js} +7 -5
  233. package/dist/chunk-WZCES5M6.js.map +1 -0
  234. package/dist/{chunk-FEQKBVCZ.cjs → chunk-Y6CVUI6A.cjs} +14 -14
  235. package/dist/chunk-Y6CVUI6A.cjs.map +1 -0
  236. package/dist/{chunk-FQG4DRJS.cjs → chunk-YCL43UQM.cjs} +71 -45
  237. package/dist/chunk-YCL43UQM.cjs.map +1 -0
  238. package/dist/{chunk-SC5BGA2N.cjs → chunk-YZXRD6K6.cjs} +8 -8
  239. package/dist/chunk-YZXRD6K6.cjs.map +1 -0
  240. package/dist/{chunk-L37ZPX6D.js → chunk-ZFGLBJYC.js} +5 -5
  241. package/dist/chunk-ZFGLBJYC.js.map +1 -0
  242. package/dist/{chunk-COPERSVL.cjs → chunk-ZNKVOTPB.cjs} +15 -15
  243. package/dist/{chunk-COPERSVL.cjs.map → chunk-ZNKVOTPB.cjs.map} +1 -1
  244. package/dist/{chunk-IXFSJBJS.js → chunk-ZOEN3ARN.js} +4 -14
  245. package/dist/chunk-ZOEN3ARN.js.map +1 -0
  246. package/dist/{chunk-QXQSJ3FZ.js → chunk-ZYXRRVR6.js} +5 -5
  247. package/dist/chunk-ZYXRRVR6.js.map +1 -0
  248. package/dist/{combo-type-wodyLq1f.d.cts → combo-type-CCrfKcTc.d.cts} +1 -1
  249. package/dist/{combo-type-BdSohVyy.d.ts → combo-type-Drb7xHSH.d.ts} +1 -1
  250. package/dist/combo.cjs +9 -9
  251. package/dist/combo.d.cts +4 -4
  252. package/dist/combo.d.ts +4 -4
  253. package/dist/combo.js +4 -4
  254. package/dist/{custom-type-B6w1n5Ua.d.cts → custom-type-CUdaJtsU.d.cts} +1 -1
  255. package/dist/{custom-type-XFjuPwCr.d.ts → custom-type-DeCdYBIK.d.ts} +1 -1
  256. package/dist/custom.cjs +10 -10
  257. package/dist/custom.d.cts +4 -4
  258. package/dist/custom.d.ts +4 -4
  259. package/dist/custom.js +5 -5
  260. package/dist/donut.cjs +11 -10
  261. package/dist/donut.cjs.map +1 -1
  262. package/dist/donut.d.cts +4 -4
  263. package/dist/donut.d.ts +4 -4
  264. package/dist/donut.js +6 -5
  265. package/dist/donut.js.map +1 -1
  266. package/dist/{dumbbell-type-w424KzI2.d.cts → dumbbell-type--8jqwUbP.d.cts} +1 -1
  267. package/dist/{dumbbell-type-DPSE0OTg.d.ts → dumbbell-type-FrAcyybz.d.ts} +1 -1
  268. package/dist/dumbbell.cjs +10 -10
  269. package/dist/dumbbell.d.cts +4 -4
  270. package/dist/dumbbell.d.ts +4 -4
  271. package/dist/dumbbell.js +5 -5
  272. package/dist/{engine-CNukbv7k.d.ts → engine-7vdmtmTm.d.cts} +20 -0
  273. package/dist/{engine-CNukbv7k.d.cts → engine-7vdmtmTm.d.ts} +20 -0
  274. package/dist/{factory-dbngWV4d.d.cts → factory-DVmPQ-5P.d.cts} +1 -1
  275. package/dist/{factory-jRzNNxwj.d.ts → factory-DXvw-FCZ.d.ts} +1 -1
  276. package/dist/{funnel-type-CMXGQq4T.d.ts → funnel-type-BhtkYPBR.d.ts} +1 -1
  277. package/dist/{funnel-type-BeVl3ohX.d.cts → funnel-type-BqLhbGkI.d.cts} +1 -1
  278. package/dist/funnel.cjs +10 -10
  279. package/dist/funnel.d.cts +4 -4
  280. package/dist/funnel.d.ts +4 -4
  281. package/dist/funnel.js +5 -5
  282. package/dist/{gauge-type-DmjDdfsY.d.cts → gauge-type-NeAO1otO.d.cts} +1 -1
  283. package/dist/{gauge-type-BpDBwCeD.d.ts → gauge-type-h6z_4lnL.d.ts} +1 -1
  284. package/dist/gauge.cjs +10 -10
  285. package/dist/gauge.d.cts +4 -4
  286. package/dist/gauge.d.ts +4 -4
  287. package/dist/gauge.js +5 -5
  288. package/dist/geo.cjs +12 -12
  289. package/dist/geo.d.cts +4 -4
  290. package/dist/geo.d.ts +4 -4
  291. package/dist/geo.js +5 -5
  292. package/dist/graph-type-Bg04GFeS.d.ts +15 -0
  293. package/dist/graph-type-DF-vww8T.d.cts +15 -0
  294. package/dist/graph.cjs +63 -10
  295. package/dist/graph.cjs.map +1 -1
  296. package/dist/graph.d.cts +65 -5
  297. package/dist/graph.d.ts +65 -5
  298. package/dist/graph.js +58 -6
  299. package/dist/graph.js.map +1 -1
  300. package/dist/{heatmap-type-q6nNhVTr.d.ts → heatmap-type-BAxcLZ1S.d.ts} +1 -1
  301. package/dist/{heatmap-type-D0shkxK7.d.cts → heatmap-type-CkmoO1Vi.d.cts} +1 -1
  302. package/dist/heatmap.cjs +10 -10
  303. package/dist/heatmap.d.cts +4 -4
  304. package/dist/heatmap.d.ts +4 -4
  305. package/dist/heatmap.js +5 -5
  306. package/dist/{histogram-type-BWil-Rb7.d.cts → histogram-type-BMxwKNZD.d.cts} +1 -1
  307. package/dist/{histogram-type-CF593WSp.d.ts → histogram-type-Bz1r_8dr.d.ts} +1 -1
  308. package/dist/histogram.cjs +9 -9
  309. package/dist/histogram.d.cts +4 -4
  310. package/dist/histogram.d.ts +4 -4
  311. package/dist/histogram.js +4 -4
  312. package/dist/{horizontal-bar-type-0mqnyMUR.d.cts → horizontal-bar-type-CPMqObyF.d.cts} +1 -1
  313. package/dist/{horizontal-bar-type-DAlrxY0h.d.ts → horizontal-bar-type-oNPstB_X.d.ts} +1 -1
  314. package/dist/horizontal-bar.cjs +9 -9
  315. package/dist/horizontal-bar.d.cts +4 -4
  316. package/dist/horizontal-bar.d.ts +4 -4
  317. package/dist/horizontal-bar.js +4 -4
  318. package/dist/index.cjs +180 -179
  319. package/dist/index.cjs.map +1 -1
  320. package/dist/index.d.cts +51 -47
  321. package/dist/index.d.ts +51 -47
  322. package/dist/index.js +92 -91
  323. package/dist/index.js.map +1 -1
  324. package/dist/{kagi-type-Y5XUVm3h.d.ts → kagi-type-DLvdmNEs.d.ts} +1 -1
  325. package/dist/{kagi-type-aG-Q1bWk.d.cts → kagi-type-DolumABK.d.cts} +1 -1
  326. package/dist/kagi.cjs +10 -10
  327. package/dist/kagi.d.cts +4 -4
  328. package/dist/kagi.d.ts +4 -4
  329. package/dist/kagi.js +5 -5
  330. package/dist/{line-type-Diw0nXj7.d.ts → line-type-CQ_Sbwde.d.ts} +1 -1
  331. package/dist/{line-type-B8lgTFjb.d.cts → line-type-DU-iLYyU.d.cts} +1 -1
  332. package/dist/line.cjs +9 -9
  333. package/dist/line.d.cts +4 -4
  334. package/dist/line.d.ts +4 -4
  335. package/dist/line.js +4 -4
  336. package/dist/{lines-type-CGrg_mDi.d.cts → lines-type-BZF5YnFG.d.cts} +1 -1
  337. package/dist/{lines-type-V-seVNZ4.d.ts → lines-type-CkKW7kQN.d.ts} +1 -1
  338. package/dist/lines.cjs +10 -10
  339. package/dist/lines.d.cts +4 -4
  340. package/dist/lines.d.ts +4 -4
  341. package/dist/lines.js +5 -5
  342. package/dist/{lollipop-type-CoTzKLSu.d.cts → lollipop-type-BUeY0pGU.d.cts} +1 -1
  343. package/dist/{lollipop-type-Ygc4rRql.d.ts → lollipop-type-DY7z1meu.d.ts} +1 -1
  344. package/dist/lollipop.cjs +9 -9
  345. package/dist/lollipop.d.cts +4 -4
  346. package/dist/lollipop.d.ts +4 -4
  347. package/dist/lollipop.js +4 -4
  348. package/dist/{matrix-type-Crb_NwUJ.d.cts → matrix-type-DZBt3yku.d.cts} +1 -1
  349. package/dist/{matrix-type-Dag1VLCY.d.ts → matrix-type-DkaWmxKb.d.ts} +1 -1
  350. package/dist/matrix.cjs +10 -10
  351. package/dist/matrix.d.cts +4 -4
  352. package/dist/matrix.d.ts +4 -4
  353. package/dist/matrix.js +5 -5
  354. package/dist/{ohlc-type-BQBHvVJO.d.cts → ohlc-type-C6NE-Bb3.d.cts} +1 -1
  355. package/dist/{ohlc-type-CGR-vRGL.d.ts → ohlc-type-eQd0E8lm.d.ts} +1 -1
  356. package/dist/ohlc.cjs +9 -9
  357. package/dist/ohlc.d.cts +4 -4
  358. package/dist/ohlc.d.ts +4 -4
  359. package/dist/ohlc.js +4 -4
  360. package/dist/{parallel-type-D-S-EqeC.d.cts → parallel-type-Cn2B_2-r.d.cts} +1 -1
  361. package/dist/{parallel-type-6t6xyHMg.d.ts → parallel-type-D4B96-R-.d.ts} +1 -1
  362. package/dist/parallel.cjs +10 -10
  363. package/dist/parallel.d.cts +4 -4
  364. package/dist/parallel.d.ts +4 -4
  365. package/dist/parallel.js +5 -5
  366. package/dist/{pictorialbar-type-A-8mTX1N.d.ts → pictorialbar-type-CoClaroO.d.ts} +1 -1
  367. package/dist/{pictorialbar-type-CnJEH9GZ.d.cts → pictorialbar-type-jiWGSHOU.d.cts} +1 -1
  368. package/dist/pictorialbar.cjs +10 -10
  369. package/dist/pictorialbar.d.cts +4 -4
  370. package/dist/pictorialbar.d.ts +4 -4
  371. package/dist/pictorialbar.js +5 -5
  372. package/dist/{pie-type-S7kUKGRS.d.ts → pie-type-0inQl-lu.d.ts} +1 -1
  373. package/dist/{pie-type-duX5xkfQ.d.cts → pie-type-9iaid0XE.d.cts} +1 -1
  374. package/dist/pie.cjs +11 -10
  375. package/dist/pie.cjs.map +1 -1
  376. package/dist/pie.d.cts +4 -4
  377. package/dist/pie.d.ts +4 -4
  378. package/dist/pie.js +6 -5
  379. package/dist/pie.js.map +1 -1
  380. package/dist/{polar-type-CI6-I8Yg.d.cts → polar-type-BraqKI4A.d.ts} +2 -1
  381. package/dist/{polar-type-Dj21GIc9.d.ts → polar-type-DsB9FOAO.d.cts} +2 -1
  382. package/dist/polar.cjs +11 -10
  383. package/dist/polar.cjs.map +1 -1
  384. package/dist/polar.d.cts +4 -4
  385. package/dist/polar.d.ts +4 -4
  386. package/dist/polar.js +6 -5
  387. package/dist/polar.js.map +1 -1
  388. package/dist/{radar-type-CYjZHuKm.d.ts → radar-type-C0JiXn53.d.ts} +1 -1
  389. package/dist/{radar-type-Dgyr13Zd.d.cts → radar-type-DaLjHpgO.d.cts} +1 -1
  390. package/dist/radar.cjs +10 -10
  391. package/dist/radar.d.cts +4 -4
  392. package/dist/radar.d.ts +4 -4
  393. package/dist/radar.js +5 -5
  394. package/dist/{radialbar-type-CLZ8XgST.d.ts → radialbar-type-DMzib3wW.d.ts} +1 -1
  395. package/dist/{radialbar-type-C_SBXoaa.d.cts → radialbar-type-YtZDe2x4.d.cts} +1 -1
  396. package/dist/radialbar.cjs +10 -10
  397. package/dist/radialbar.d.cts +4 -4
  398. package/dist/radialbar.d.ts +4 -4
  399. package/dist/radialbar.js +5 -5
  400. package/dist/{range-type-_LbMV4tl.d.ts → range-type-RlwPvBxs.d.ts} +1 -1
  401. package/dist/{range-type-CkriEnLm.d.cts → range-type-imi4626F.d.cts} +1 -1
  402. package/dist/range.cjs +9 -9
  403. package/dist/range.d.cts +4 -4
  404. package/dist/range.d.ts +4 -4
  405. package/dist/range.js +4 -4
  406. package/dist/{renko-type-ejoXt2ro.d.ts → renko-type-Bv23hPuk.d.ts} +1 -1
  407. package/dist/{renko-type-43OXCtZ3.d.cts → renko-type-DEe4vBKT.d.cts} +1 -1
  408. package/dist/renko.cjs +10 -10
  409. package/dist/renko.d.cts +4 -4
  410. package/dist/renko.d.ts +4 -4
  411. package/dist/renko.js +5 -5
  412. package/dist/{sankey-type-DfkTUnXB.d.cts → sankey-type-B0LCLees.d.cts} +1 -1
  413. package/dist/{sankey-type-CN7PL5MQ.d.ts → sankey-type-Gr2owHtQ.d.ts} +1 -1
  414. package/dist/sankey.cjs +10 -10
  415. package/dist/sankey.d.cts +4 -4
  416. package/dist/sankey.d.ts +4 -4
  417. package/dist/sankey.js +5 -5
  418. package/dist/{scatter-type-CD7X1pZb.d.cts → scatter-type-C0vMtH11.d.cts} +1 -1
  419. package/dist/{scatter-type-D3HdPkZ6.d.ts → scatter-type-DPCIXt3X.d.ts} +1 -1
  420. package/dist/scatter.cjs +9 -9
  421. package/dist/scatter.d.cts +4 -4
  422. package/dist/scatter.d.ts +4 -4
  423. package/dist/scatter.js +4 -4
  424. package/dist/{sparkline-type-qt3yoLs7.d.cts → sparkline-type-BDDpw4DS.d.cts} +1 -1
  425. package/dist/{sparkline-type-COW3izgF.d.ts → sparkline-type-BtSsuoh4.d.ts} +1 -1
  426. package/dist/sparkline.cjs +9 -9
  427. package/dist/sparkline.d.cts +4 -4
  428. package/dist/sparkline.d.ts +4 -4
  429. package/dist/sparkline.js +4 -4
  430. package/dist/{stacked-bar-type-C-5pmb-D.d.ts → stacked-bar-type-5_GXIxLN.d.ts} +1 -1
  431. package/dist/{stacked-bar-type-Ct6HK2A0.d.cts → stacked-bar-type-BF4R1zEK.d.cts} +1 -1
  432. package/dist/stacked-bar.cjs +9 -9
  433. package/dist/stacked-bar.d.cts +4 -4
  434. package/dist/stacked-bar.d.ts +4 -4
  435. package/dist/stacked-bar.js +4 -4
  436. package/dist/{step-type-BSL-CUny.d.cts → step-type-CZJO5PE4.d.cts} +1 -1
  437. package/dist/{step-type-Cleoshov.d.ts → step-type-CoBGeRRR.d.ts} +1 -1
  438. package/dist/step.cjs +10 -10
  439. package/dist/step.d.cts +4 -4
  440. package/dist/step.d.ts +4 -4
  441. package/dist/step.js +5 -5
  442. package/dist/{sunburst-type-ZFw2w6m8.d.ts → sunburst-type-CAcFLV8s.d.ts} +1 -1
  443. package/dist/{sunburst-type-BOztb_Px.d.cts → sunburst-type-DgP1x1nn.d.cts} +1 -1
  444. package/dist/sunburst.cjs +11 -10
  445. package/dist/sunburst.cjs.map +1 -1
  446. package/dist/sunburst.d.cts +4 -4
  447. package/dist/sunburst.d.ts +4 -4
  448. package/dist/sunburst.js +6 -5
  449. package/dist/sunburst.js.map +1 -1
  450. package/dist/{themeriver-type-B5PYChcC.d.ts → themeriver-type-BxLJux1v.d.ts} +1 -1
  451. package/dist/{themeriver-type-BnRSsyal.d.cts → themeriver-type-CGn5zE2F.d.cts} +1 -1
  452. package/dist/themeriver.cjs +10 -10
  453. package/dist/themeriver.d.cts +4 -4
  454. package/dist/themeriver.d.ts +4 -4
  455. package/dist/themeriver.js +5 -5
  456. package/dist/{tree-type-B-bOSg0l.d.ts → tree-type-Dyw9F7oq.d.ts} +1 -1
  457. package/dist/{tree-type-Cz84wHnR.d.cts → tree-type-xf-pj4pG.d.cts} +1 -1
  458. package/dist/tree.cjs +10 -10
  459. package/dist/tree.d.cts +4 -4
  460. package/dist/tree.d.ts +4 -4
  461. package/dist/tree.js +5 -5
  462. package/dist/{treemap-type-DYDj-rWv.d.ts → treemap-type-B4ty-Vge.d.ts} +1 -1
  463. package/dist/{treemap-type-OBCGexiK.d.cts → treemap-type-CeLgbJFQ.d.cts} +1 -1
  464. package/dist/treemap.cjs +10 -10
  465. package/dist/treemap.d.cts +4 -4
  466. package/dist/treemap.d.ts +4 -4
  467. package/dist/treemap.js +5 -5
  468. package/dist/{volume-type-C9wRmKR6.d.ts → volume-type-2ZgLIkPV.d.ts} +1 -1
  469. package/dist/{volume-type-CfERBN5g.d.cts → volume-type-Dvnr4sC9.d.cts} +1 -1
  470. package/dist/volume.cjs +9 -9
  471. package/dist/volume.d.cts +4 -4
  472. package/dist/volume.d.ts +4 -4
  473. package/dist/volume.js +4 -4
  474. package/dist/{waterfall-type-hm5ylGgW.d.cts → waterfall-type-D_6Db7Zy.d.cts} +1 -1
  475. package/dist/{waterfall-type-CpdVtBi_.d.ts → waterfall-type-DsC5vlAP.d.ts} +1 -1
  476. package/dist/waterfall.cjs +9 -9
  477. package/dist/waterfall.d.cts +4 -4
  478. package/dist/waterfall.d.ts +4 -4
  479. package/dist/waterfall.js +4 -4
  480. package/dist/world-regions-C0JUJCGT.d.ts +25 -0
  481. package/dist/world-regions-gUFRPji8.d.cts +25 -0
  482. package/package.json +11 -7
  483. package/dist/chunk-27E6G2GT.js.map +0 -1
  484. package/dist/chunk-2KMMVJEE.cjs.map +0 -1
  485. package/dist/chunk-2L46SAT7.js.map +0 -1
  486. package/dist/chunk-3N447NTJ.cjs.map +0 -1
  487. package/dist/chunk-3NWZJCWL.js.map +0 -1
  488. package/dist/chunk-3QXN7JBV.js.map +0 -1
  489. package/dist/chunk-3TLJCGGQ.cjs.map +0 -1
  490. package/dist/chunk-43WDYYVH.cjs.map +0 -1
  491. package/dist/chunk-4ABM7UYD.js.map +0 -1
  492. package/dist/chunk-5LQ26P4J.cjs.map +0 -1
  493. package/dist/chunk-5M624BRW.js.map +0 -1
  494. package/dist/chunk-6WJJ26J5.js.map +0 -1
  495. package/dist/chunk-7HOU6XMW.js.map +0 -1
  496. package/dist/chunk-7JN6GXML.cjs.map +0 -1
  497. package/dist/chunk-7MXBXWVD.js.map +0 -1
  498. package/dist/chunk-AA45U5KV.js.map +0 -1
  499. package/dist/chunk-ALRCYQQX.cjs.map +0 -1
  500. package/dist/chunk-B7IV2PB3.cjs.map +0 -1
  501. package/dist/chunk-BMTVFAX2.js.map +0 -1
  502. package/dist/chunk-CCHMQZIB.js.map +0 -1
  503. package/dist/chunk-CHERQT4B.js.map +0 -1
  504. package/dist/chunk-CJEMSKW3.js.map +0 -1
  505. package/dist/chunk-D2IP3MWJ.cjs.map +0 -1
  506. package/dist/chunk-DAH76GIX.cjs.map +0 -1
  507. package/dist/chunk-DKVRRL3F.js.map +0 -1
  508. package/dist/chunk-DZHP4UUE.cjs.map +0 -1
  509. package/dist/chunk-DZW35WR2.js.map +0 -1
  510. package/dist/chunk-EAKXLFOR.cjs.map +0 -1
  511. package/dist/chunk-EYN74SQ5.js.map +0 -1
  512. package/dist/chunk-FEQKBVCZ.cjs.map +0 -1
  513. package/dist/chunk-FIAKZSRR.cjs.map +0 -1
  514. package/dist/chunk-FKAA5FNG.cjs.map +0 -1
  515. package/dist/chunk-FKVYS4RB.js.map +0 -1
  516. package/dist/chunk-FQG4DRJS.cjs.map +0 -1
  517. package/dist/chunk-GI7PBJSK.js.map +0 -1
  518. package/dist/chunk-GL3M7MAM.js.map +0 -1
  519. package/dist/chunk-GQR7IHER.js.map +0 -1
  520. package/dist/chunk-GUVPVNPD.cjs.map +0 -1
  521. package/dist/chunk-IAE4VRB7.cjs.map +0 -1
  522. package/dist/chunk-ID7GYRYL.cjs.map +0 -1
  523. package/dist/chunk-IUYPKYOU.js.map +0 -1
  524. package/dist/chunk-IXFSJBJS.js.map +0 -1
  525. package/dist/chunk-JT6H7G52.js.map +0 -1
  526. package/dist/chunk-K2EZ4SS4.js.map +0 -1
  527. package/dist/chunk-K7UR7GYC.cjs.map +0 -1
  528. package/dist/chunk-KEMT7F5H.cjs.map +0 -1
  529. package/dist/chunk-KHQRHTTN.js.map +0 -1
  530. package/dist/chunk-KUFDELQM.cjs.map +0 -1
  531. package/dist/chunk-L37ZPX6D.js.map +0 -1
  532. package/dist/chunk-M6JYSINX.cjs.map +0 -1
  533. package/dist/chunk-MGYBMQAX.cjs.map +0 -1
  534. package/dist/chunk-MZCKMTQE.cjs +0 -210
  535. package/dist/chunk-MZCKMTQE.cjs.map +0 -1
  536. package/dist/chunk-MZQY2FTP.cjs.map +0 -1
  537. package/dist/chunk-N7NZQVIV.cjs.map +0 -1
  538. package/dist/chunk-NML7F34A.js.map +0 -1
  539. package/dist/chunk-NQGZMWNT.js +0 -208
  540. package/dist/chunk-NQGZMWNT.js.map +0 -1
  541. package/dist/chunk-NZWFBAFQ.js.map +0 -1
  542. package/dist/chunk-PCTMS2PX.cjs.map +0 -1
  543. package/dist/chunk-QCR6L55R.js.map +0 -1
  544. package/dist/chunk-QRTYX5KO.js.map +0 -1
  545. package/dist/chunk-QXQSJ3FZ.js.map +0 -1
  546. package/dist/chunk-S64PTNT7.cjs.map +0 -1
  547. package/dist/chunk-S6NGWPXC.js.map +0 -1
  548. package/dist/chunk-SC5BGA2N.cjs.map +0 -1
  549. package/dist/chunk-SKREYNRK.cjs.map +0 -1
  550. package/dist/chunk-SLJNRP7O.cjs.map +0 -1
  551. package/dist/chunk-TIHVTKXS.cjs.map +0 -1
  552. package/dist/chunk-TVPS2NJH.cjs.map +0 -1
  553. package/dist/chunk-U7GBOQXX.js.map +0 -1
  554. package/dist/chunk-VGGKMTO6.js.map +0 -1
  555. package/dist/chunk-VJQCHBS6.js.map +0 -1
  556. package/dist/chunk-WS2AL7GY.cjs.map +0 -1
  557. package/dist/chunk-XKDBNAHH.cjs.map +0 -1
  558. package/dist/chunk-Y4HJCMB4.cjs.map +0 -1
  559. package/dist/chunk-YMJQUKKX.js.map +0 -1
  560. package/dist/graph-type-DkdAB6Vc.d.cts +0 -5
  561. package/dist/graph-type-ul9xwdf5.d.ts +0 -5
  562. package/dist/world-regions-D-TCHPZP.d.cts +0 -38
  563. package/dist/world-regions-DjMvYgFu.d.ts +0 -38
@@ -1,7 +1,8 @@
1
1
  'use strict';
2
2
 
3
- var chunkHOPFELRP_cjs = require('./chunk-HOPFELRP.cjs');
4
- var chunk3TLJCGGQ_cjs = require('./chunk-3TLJCGGQ.cjs');
3
+ var chunkKWSVJRXX_cjs = require('./chunk-KWSVJRXX.cjs');
4
+ var chunkV5Q6UNUK_cjs = require('./chunk-V5Q6UNUK.cjs');
5
+ var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
5
6
 
6
7
  // src/charts/sunburst/sunburst-type.ts
7
8
  var sunburstChartType = {
@@ -10,7 +11,7 @@ var sunburstChartType = {
10
11
  return { x: "categorical", y: "linear" };
11
12
  },
12
13
  prepareData(data, options) {
13
- return chunkHOPFELRP_cjs.prepareNoAxes(data, options);
14
+ return chunkV5Q6UNUK_cjs.prepareNoAxes(data, options);
14
15
  },
15
16
  render(ctx) {
16
17
  const { data, area, theme, options } = ctx;
@@ -40,32 +41,28 @@ var sunburstChartType = {
40
41
  const r1 = r0 + ringWidth - 1;
41
42
  const sliceAngle = node.endAngle - node.startAngle;
42
43
  if (sliceAngle < 5e-3) return;
43
- const padAngle = 0.01;
44
- const actualStart = node.startAngle + padAngle / 2;
45
- const actualEnd = node.endAngle - padAngle / 2;
46
- if (actualEnd <= actualStart) return;
47
- const pb = new chunk3TLJCGGQ_cjs.PathBuilder();
48
- const largeArc = sliceAngle > Math.PI;
49
- const x1o = cx + r1 * Math.cos(actualStart);
50
- const y1o = cy + r1 * Math.sin(actualStart);
51
- const x2o = cx + r1 * Math.cos(actualEnd);
52
- const y2o = cy + r1 * Math.sin(actualEnd);
53
- const x1i = cx + r0 * Math.cos(actualEnd);
54
- const y1i = cy + r0 * Math.sin(actualEnd);
55
- const x2i = cx + r0 * Math.cos(actualStart);
56
- const y2i = cy + r0 * Math.sin(actualStart);
57
- pb.moveTo(x1o, y1o);
58
- pb.arc(r1, r1, 0, largeArc, true, x2o, y2o);
59
- pb.lineTo(x1i, y1i);
60
- pb.arc(r0, r0, 0, largeArc, false, x2i, y2i);
61
- pb.close();
44
+ const gapPx = 3;
45
+ const halfGap = gapPx / 2;
46
+ const outerPadAngle = halfGap / r1;
47
+ const innerPadAngle = r0 > 0 ? halfGap / r0 : 0;
48
+ if (sliceAngle < outerPadAngle * 2 + 5e-3) return;
49
+ const cr = Math.min(4, ringWidth * 0.2);
50
+ const d = chunkKWSVJRXX_cjs.roundedSlicePath(
51
+ cx,
52
+ cy,
53
+ r1,
54
+ r0,
55
+ node.startAngle + outerPadAngle,
56
+ node.endAngle - outerPadAngle,
57
+ node.startAngle + innerPadAngle,
58
+ node.endAngle - innerPadAngle,
59
+ cr
60
+ );
62
61
  const opacity = 1 - (node.depth - 1) * 0.15;
63
- nodes.push(chunk3TLJCGGQ_cjs.path(pb.build(), {
62
+ nodes.push(chunkJVVGQLJQ_cjs.path(d, {
64
63
  class: "chartts-sunburst-sector",
65
64
  fill: color,
66
65
  fillOpacity: Math.max(0.4, opacity),
67
- stroke: theme.background === "transparent" ? "#fff" : theme.background,
68
- strokeWidth: 0.5,
69
66
  "data-series": 0,
70
67
  "data-index": colorIdx,
71
68
  tabindex: 0,
@@ -73,12 +70,12 @@ var sunburstChartType = {
73
70
  ariaLabel: `${node.name}: ${node.totalValue}`
74
71
  }));
75
72
  if (sliceAngle > 0.3 && ringWidth > 20) {
76
- const midAngle = (actualStart + actualEnd) / 2;
73
+ const midAngle = (node.startAngle + node.endAngle) / 2;
77
74
  const labelR = (r0 + r1) / 2;
78
75
  const lx = cx + labelR * Math.cos(midAngle);
79
76
  const ly = cy + labelR * Math.sin(midAngle);
80
77
  const fontSize = Math.min(theme.fontSizeSmall, ringWidth * 0.35);
81
- nodes.push(chunk3TLJCGGQ_cjs.text(lx, ly, node.name, {
78
+ nodes.push(chunkJVVGQLJQ_cjs.text(lx, ly, node.name, {
82
79
  class: "chartts-sunburst-label",
83
80
  fill: "#fff",
84
81
  textAnchor: "middle",
@@ -118,7 +115,7 @@ var sunburstChartType = {
118
115
  const depth = Math.floor(depthFloat) + 1;
119
116
  const hit = findSector(root, depth, angle);
120
117
  if (hit) {
121
- return { seriesIndex: 0, pointIndex: hit, distance: 0 };
118
+ return { seriesIndex: 0, pointIndex: hit, distance: 0, x: mx, y: my };
122
119
  }
123
120
  return null;
124
121
  }
@@ -214,5 +211,5 @@ function findSector(node, targetDepth, angle) {
214
211
  }
215
212
 
216
213
  exports.sunburstChartType = sunburstChartType;
217
- //# sourceMappingURL=chunk-S64PTNT7.cjs.map
218
- //# sourceMappingURL=chunk-S64PTNT7.cjs.map
214
+ //# sourceMappingURL=chunk-4D6PVH2C.cjs.map
215
+ //# sourceMappingURL=chunk-4D6PVH2C.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/sunburst/sunburst-type.ts"],"names":["prepareNoAxes","roundedSlicePath","path","text"],"mappings":"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","file":"chunk-4D6PVH2C.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { path, text } from '../../render/tree'\nimport { roundedSlicePath } from '../../utils/slice-path'\n\n/**\n * Sunburst chart — hierarchical radial visualization.\n *\n * Data convention:\n * - labels: leaf node names\n * - series[0].values: leaf values (sizes)\n * - Hierarchy is encoded via label separators: \"A/B/C\" means root→A→B→C\n * If no separators, falls back to flat ring layout (single ring).\n *\n * The chart draws concentric rings from center outward, one ring per depth level.\n */\n\ninterface SunburstNode {\n name: string\n fullPath: string\n value: number\n children: SunburstNode[]\n depth: number\n startAngle: number\n endAngle: number\n // Computed during layout\n totalValue: number\n}\n\nexport const sunburstChartType: ChartTypePlugin = {\n type: 'sunburst',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n // Build tree from labels\n const root = buildTree(data.labels, series.values)\n if (root.totalValue === 0) return nodes\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const maxRadius = Math.min(area.width, area.height) / 2 - 4\n const innerRadius = maxRadius * 0.15\n\n // Compute max depth for ring sizing\n const maxDepth = getMaxDepth(root)\n const ringWidth = (maxRadius - innerRadius) / Math.max(maxDepth, 1)\n\n // Layout angles recursively\n layoutAngles(root, -Math.PI / 2, -Math.PI / 2 + Math.PI * 2)\n\n // Render all non-root nodes\n let colorIdx = 0\n const renderNode = (node: SunburstNode, parentColorIdx: number) => {\n if (node.depth === 0) {\n // Root — render children with cycling colors\n for (let i = 0; i < node.children.length; i++) {\n renderNode(node.children[i]!, i)\n }\n return\n }\n\n const ci = node.depth === 1 ? parentColorIdx : parentColorIdx\n const color = options.colors[ci % options.colors.length]!\n const r0 = innerRadius + (node.depth - 1) * ringWidth\n const r1 = r0 + ringWidth - 1 // 1px gap between rings\n\n const sliceAngle = node.endAngle - node.startAngle\n if (sliceAngle < 0.005) return // Skip tiny slices\n\n // Uniform pixel gap: different angular offsets at different radii\n const gapPx = 3\n const halfGap = gapPx / 2\n const outerPadAngle = halfGap / r1\n const innerPadAngle = r0 > 0 ? halfGap / r0 : 0\n\n if (sliceAngle < outerPadAngle * 2 + 0.005) return\n\n const cr = Math.min(4, ringWidth * 0.2)\n\n const d = roundedSlicePath(\n cx, cy, r1, r0,\n node.startAngle + outerPadAngle, node.endAngle - outerPadAngle,\n node.startAngle + innerPadAngle, node.endAngle - innerPadAngle,\n cr,\n )\n\n const opacity = 1 - (node.depth - 1) * 0.15\n\n nodes.push(path(d, {\n class: 'chartts-sunburst-sector',\n fill: color,\n fillOpacity: Math.max(0.4, opacity),\n 'data-series': 0,\n 'data-index': colorIdx,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${node.name}: ${node.totalValue}`,\n }))\n\n // Label for larger sectors\n if (sliceAngle > 0.3 && ringWidth > 20) {\n const midAngle = (node.startAngle + node.endAngle) / 2\n const labelR = (r0 + r1) / 2\n const lx = cx + labelR * Math.cos(midAngle)\n const ly = cy + labelR * Math.sin(midAngle)\n\n const fontSize = Math.min(theme.fontSizeSmall, ringWidth * 0.35)\n nodes.push(text(lx, ly, node.name, {\n class: 'chartts-sunburst-label',\n fill: '#fff',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n }\n\n colorIdx++\n\n // Render children\n for (let i = 0; i < node.children.length; i++) {\n renderNode(node.children[i]!, parentColorIdx)\n }\n }\n\n renderNode(root, 0)\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const maxRadius = Math.min(area.width, area.height) / 2 - 4\n const innerRadius = maxRadius * 0.15\n\n const dx = mx - cx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist > maxRadius || dist < innerRadius) return null\n\n const root = buildTree(data.labels, series.values)\n const maxDepth = getMaxDepth(root)\n const ringWidth = (maxRadius - innerRadius) / Math.max(maxDepth, 1)\n\n layoutAngles(root, -Math.PI / 2, -Math.PI / 2 + Math.PI * 2)\n\n let angle = Math.atan2(dy, dx)\n if (angle < -Math.PI / 2) angle += Math.PI * 2\n\n // Find which ring (depth) the point is in\n const depthFloat = (dist - innerRadius) / ringWidth\n const depth = Math.floor(depthFloat) + 1\n\n // Find sector at this depth and angle\n const hit = findSector(root, depth, angle)\n if (hit) {\n return { seriesIndex: 0, pointIndex: hit, distance: 0, x: mx, y: my }\n }\n\n return null\n },\n}\n\n// ---------------------------------------------------------------------------\n// Tree building\n// ---------------------------------------------------------------------------\n\nfunction buildTree(labels: (string | number | Date)[], values: number[]): SunburstNode {\n const root: SunburstNode = {\n name: 'root', fullPath: '', value: 0,\n children: [], depth: 0, startAngle: 0, endAngle: 0, totalValue: 0,\n }\n\n for (let i = 0; i < labels.length; i++) {\n const label = String(labels[i] ?? `Item ${i}`)\n const value = Math.abs(values[i] ?? 0)\n if (value <= 0) continue\n\n const parts = label.includes('/') ? label.split('/') : [label]\n let current = root\n\n for (let p = 0; p < parts.length; p++) {\n const part = parts[p]!.trim()\n let child = current.children.find(c => c.name === part)\n\n if (!child) {\n child = {\n name: part,\n fullPath: parts.slice(0, p + 1).join('/'),\n value: 0,\n children: [],\n depth: p + 1,\n startAngle: 0,\n endAngle: 0,\n totalValue: 0,\n }\n current.children.push(child)\n }\n\n if (p === parts.length - 1) {\n child.value = value\n }\n current = child\n }\n }\n\n // Compute totals bottom-up\n computeTotals(root)\n\n return root\n}\n\nfunction computeTotals(node: SunburstNode): number {\n if (node.children.length === 0) {\n node.totalValue = node.value\n return node.totalValue\n }\n let sum = 0\n for (const child of node.children) {\n sum += computeTotals(child)\n }\n node.totalValue = Math.max(sum, node.value)\n return node.totalValue\n}\n\nfunction layoutAngles(node: SunburstNode, start: number, end: number): void {\n node.startAngle = start\n node.endAngle = end\n\n if (node.children.length === 0 || node.totalValue === 0) return\n\n let current = start\n for (const child of node.children) {\n const fraction = child.totalValue / node.totalValue\n const childEnd = current + fraction * (end - start)\n layoutAngles(child, current, childEnd)\n current = childEnd\n }\n}\n\nfunction getMaxDepth(node: SunburstNode): number {\n if (node.children.length === 0) return node.depth\n let max = node.depth\n for (const child of node.children) {\n max = Math.max(max, getMaxDepth(child))\n }\n return max\n}\n\nfunction findSector(node: SunburstNode, targetDepth: number, angle: number): number | null {\n if (node.depth === targetDepth) {\n if (angle >= node.startAngle && angle < node.endAngle) {\n return node.depth // Return something non-null to indicate a hit\n }\n return null\n }\n\n for (const child of node.children) {\n if (angle >= child.startAngle && angle < child.endAngle) {\n const result = findSector(child, targetDepth, angle)\n if (result !== null) return result\n }\n }\n\n return null\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- var chunk3TLJCGGQ_cjs = require('./chunk-3TLJCGGQ.cjs');
3
+ var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
4
4
 
5
5
  // src/charts/bubble/bubble-type.ts
6
6
  var bubbleChartType = {
@@ -9,7 +9,7 @@ var bubbleChartType = {
9
9
  return { x: "categorical", y: "linear" };
10
10
  },
11
11
  prepareData(data, options) {
12
- return chunk3TLJCGGQ_cjs.prepareData(data, options);
12
+ return chunkJVVGQLJQ_cjs.prepareData(data, options);
13
13
  },
14
14
  render(ctx) {
15
15
  const { data, xScale, yScale } = ctx;
@@ -40,7 +40,7 @@ var bubbleChartType = {
40
40
  const rawSize = sizes[i] ?? 1;
41
41
  const normalized = (rawSize - sizeMin) / sizeRange;
42
42
  const r = minR + normalized * (maxR - minR);
43
- dots.push(chunk3TLJCGGQ_cjs.circle(x, y, r, {
43
+ dots.push(chunkJVVGQLJQ_cjs.circle(x, y, r, {
44
44
  class: "chartts-bubble",
45
45
  fill: series.color,
46
46
  fillOpacity: 0.5,
@@ -53,7 +53,7 @@ var bubbleChartType = {
53
53
  ariaLabel: `${series.name}: ${series.values[i]} (size: ${rawSize})`
54
54
  }));
55
55
  }
56
- nodes.push(chunk3TLJCGGQ_cjs.group(dots, {
56
+ nodes.push(chunkJVVGQLJQ_cjs.group(dots, {
57
57
  class: `chartts-series chartts-series-${series.index}`,
58
58
  "data-series-name": series.name
59
59
  }));
@@ -92,7 +92,7 @@ var bubbleChartType = {
92
92
  const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2);
93
93
  if (dist < r + 4 && dist < bestDist) {
94
94
  bestDist = dist;
95
- best = { seriesIndex: series.index, pointIndex: i, distance: dist };
95
+ best = { seriesIndex: series.index, pointIndex: i, distance: dist, x, y };
96
96
  }
97
97
  }
98
98
  }
@@ -101,5 +101,5 @@ var bubbleChartType = {
101
101
  };
102
102
 
103
103
  exports.bubbleChartType = bubbleChartType;
104
- //# sourceMappingURL=chunk-N7NZQVIV.cjs.map
105
- //# sourceMappingURL=chunk-N7NZQVIV.cjs.map
104
+ //# sourceMappingURL=chunk-4MNVJVK3.cjs.map
105
+ //# sourceMappingURL=chunk-4MNVJVK3.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/bubble/bubble-type.ts"],"names":["prepareData","circle","group"],"mappings":"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","file":"chunk-4MNVJVK3.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, circle } from '../../render/tree'\n\nexport interface BubbleOptions {\n /** Sizes array per series. Each entry maps 1:1 to values. */\n sizes?: number[][]\n /** Min bubble radius in px. Default 4. */\n minRadius?: number\n /** Max bubble radius in px. Default 30. */\n maxRadius?: number\n}\n\n/**\n * Bubble chart — scatter with variable-radius circles.\n * Pass sizes via options: `{ sizes: [[10, 20, 5, ...], ...] }`\n */\nexport const bubbleChartType: ChartTypePlugin = {\n type: 'bubble',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareData(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n const bOpts = ctx.options as unknown as BubbleOptions\n const allSizes = bOpts.sizes ?? []\n const minR = bOpts.minRadius ?? 4\n const maxR = bOpts.maxRadius ?? 30\n\n // Find global size range for normalization\n let sizeMin = Infinity\n let sizeMax = -Infinity\n for (const sizes of allSizes) {\n for (const s of sizes) {\n if (s < sizeMin) sizeMin = s\n if (s > sizeMax) sizeMax = s\n }\n }\n if (!isFinite(sizeMin)) { sizeMin = 1; sizeMax = 1 }\n const sizeRange = sizeMax - sizeMin || 1\n\n for (const series of data.series) {\n const sizes = allSizes[series.index] ?? []\n const dots: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n const rawSize = sizes[i] ?? 1\n const normalized = (rawSize - sizeMin) / sizeRange\n const r = minR + normalized * (maxR - minR)\n\n dots.push(circle(x, y, r, {\n class: 'chartts-bubble',\n fill: series.color,\n fillOpacity: 0.5,\n stroke: series.color,\n strokeWidth: 1.5,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]} (size: ${rawSize})`,\n }))\n }\n\n nodes.push(group(dots, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale } = ctx\n const bOpts = ctx.options as unknown as BubbleOptions\n const allSizes = bOpts.sizes ?? []\n const minR = bOpts.minRadius ?? 4\n const maxR = bOpts.maxRadius ?? 30\n\n let sizeMin = Infinity\n let sizeMax = -Infinity\n for (const sizes of allSizes) {\n for (const s of sizes) {\n if (s < sizeMin) sizeMin = s\n if (s > sizeMax) sizeMax = s\n }\n }\n if (!isFinite(sizeMin)) { sizeMin = 1; sizeMax = 1 }\n const sizeRange = sizeMax - sizeMin || 1\n\n let best: HitResult | null = null\n let bestDist = Infinity\n\n for (const series of data.series) {\n const sizes = allSizes[series.index] ?? []\n for (let i = 0; i < series.values.length; i++) {\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n const rawSize = sizes[i] ?? 1\n const normalized = (rawSize - sizeMin) / sizeRange\n const r = minR + normalized * (maxR - minR)\n\n const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2)\n if (dist < r + 4 && dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist, x, y }\n }\n }\n }\n\n return best\n },\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { circle, group, prepareData } from './chunk-BMTVFAX2.js';
1
+ import { circle, group, prepareData } from './chunk-AEQXFDL7.js';
2
2
 
3
3
  // src/charts/bubble/bubble-type.ts
4
4
  var bubbleChartType = {
@@ -90,7 +90,7 @@ var bubbleChartType = {
90
90
  const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2);
91
91
  if (dist < r + 4 && dist < bestDist) {
92
92
  bestDist = dist;
93
- best = { seriesIndex: series.index, pointIndex: i, distance: dist };
93
+ best = { seriesIndex: series.index, pointIndex: i, distance: dist, x, y };
94
94
  }
95
95
  }
96
96
  }
@@ -99,5 +99,5 @@ var bubbleChartType = {
99
99
  };
100
100
 
101
101
  export { bubbleChartType };
102
- //# sourceMappingURL=chunk-VGGKMTO6.js.map
103
- //# sourceMappingURL=chunk-VGGKMTO6.js.map
102
+ //# sourceMappingURL=chunk-4QRND2V5.js.map
103
+ //# sourceMappingURL=chunk-4QRND2V5.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/bubble/bubble-type.ts"],"names":[],"mappings":"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","file":"chunk-4QRND2V5.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, circle } from '../../render/tree'\n\nexport interface BubbleOptions {\n /** Sizes array per series. Each entry maps 1:1 to values. */\n sizes?: number[][]\n /** Min bubble radius in px. Default 4. */\n minRadius?: number\n /** Max bubble radius in px. Default 30. */\n maxRadius?: number\n}\n\n/**\n * Bubble chart — scatter with variable-radius circles.\n * Pass sizes via options: `{ sizes: [[10, 20, 5, ...], ...] }`\n */\nexport const bubbleChartType: ChartTypePlugin = {\n type: 'bubble',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareData(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n const bOpts = ctx.options as unknown as BubbleOptions\n const allSizes = bOpts.sizes ?? []\n const minR = bOpts.minRadius ?? 4\n const maxR = bOpts.maxRadius ?? 30\n\n // Find global size range for normalization\n let sizeMin = Infinity\n let sizeMax = -Infinity\n for (const sizes of allSizes) {\n for (const s of sizes) {\n if (s < sizeMin) sizeMin = s\n if (s > sizeMax) sizeMax = s\n }\n }\n if (!isFinite(sizeMin)) { sizeMin = 1; sizeMax = 1 }\n const sizeRange = sizeMax - sizeMin || 1\n\n for (const series of data.series) {\n const sizes = allSizes[series.index] ?? []\n const dots: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n const rawSize = sizes[i] ?? 1\n const normalized = (rawSize - sizeMin) / sizeRange\n const r = minR + normalized * (maxR - minR)\n\n dots.push(circle(x, y, r, {\n class: 'chartts-bubble',\n fill: series.color,\n fillOpacity: 0.5,\n stroke: series.color,\n strokeWidth: 1.5,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]} (size: ${rawSize})`,\n }))\n }\n\n nodes.push(group(dots, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale } = ctx\n const bOpts = ctx.options as unknown as BubbleOptions\n const allSizes = bOpts.sizes ?? []\n const minR = bOpts.minRadius ?? 4\n const maxR = bOpts.maxRadius ?? 30\n\n let sizeMin = Infinity\n let sizeMax = -Infinity\n for (const sizes of allSizes) {\n for (const s of sizes) {\n if (s < sizeMin) sizeMin = s\n if (s > sizeMax) sizeMax = s\n }\n }\n if (!isFinite(sizeMin)) { sizeMin = 1; sizeMax = 1 }\n const sizeRange = sizeMax - sizeMin || 1\n\n let best: HitResult | null = null\n let bestDist = Infinity\n\n for (const series of data.series) {\n const sizes = allSizes[series.index] ?? []\n for (let i = 0; i < series.values.length; i++) {\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n const rawSize = sizes[i] ?? 1\n const normalized = (rawSize - sizeMin) / sizeRange\n const r = minR + normalized * (maxR - minR)\n\n const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2)\n if (dist < r + 4 && dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist, x, y }\n }\n }\n }\n\n return best\n },\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
- var chunkHOPFELRP_cjs = require('./chunk-HOPFELRP.cjs');
4
- var chunk3TLJCGGQ_cjs = require('./chunk-3TLJCGGQ.cjs');
3
+ var chunkV5Q6UNUK_cjs = require('./chunk-V5Q6UNUK.cjs');
4
+ var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
5
5
 
6
6
  // src/charts/lines/lines-type.ts
7
7
  var linesChartType = {
@@ -10,7 +10,7 @@ var linesChartType = {
10
10
  return { x: "categorical", y: "linear" };
11
11
  },
12
12
  prepareData(data, options) {
13
- return chunkHOPFELRP_cjs.prepareNoAxes(data, options);
13
+ return chunkV5Q6UNUK_cjs.prepareNoAxes(data, options);
14
14
  },
15
15
  render(ctx) {
16
16
  const { data, area, theme, options } = ctx;
@@ -76,10 +76,10 @@ var linesChartType = {
76
76
  const my = (src.y + tgt.y) / 2;
77
77
  const cpx = mx - dy * curvature;
78
78
  const cpy = my + dx * curvature;
79
- const pb = new chunk3TLJCGGQ_cjs.PathBuilder();
79
+ const pb = new chunkJVVGQLJQ_cjs.PathBuilder();
80
80
  pb.moveTo(src.x, src.y);
81
81
  pb.quadTo(cpx, cpy, tgt.x, tgt.y);
82
- nodes.push(chunk3TLJCGGQ_cjs.path(pb.build(), {
82
+ nodes.push(chunkJVVGQLJQ_cjs.path(pb.build(), {
83
83
  class: "chartts-lines-flow",
84
84
  fill: "none",
85
85
  stroke: color,
@@ -98,7 +98,7 @@ var linesChartType = {
98
98
  const ay = (1 - t) * (1 - t) * src.y + 2 * (1 - t) * t * cpy + t * t * tgt.y;
99
99
  const angle = Math.atan2(tgt.y - ay, tgt.x - ax);
100
100
  const arrowSize = 6 + lineWidth;
101
- const apb = new chunk3TLJCGGQ_cjs.PathBuilder();
101
+ const apb = new chunkJVVGQLJQ_cjs.PathBuilder();
102
102
  apb.moveTo(tgt.x, tgt.y);
103
103
  apb.lineTo(
104
104
  tgt.x - arrowSize * Math.cos(angle - 0.4),
@@ -109,7 +109,7 @@ var linesChartType = {
109
109
  tgt.y - arrowSize * Math.sin(angle + 0.4)
110
110
  );
111
111
  apb.close();
112
- nodes.push(chunk3TLJCGGQ_cjs.path(apb.build(), {
112
+ nodes.push(chunkJVVGQLJQ_cjs.path(apb.build(), {
113
113
  class: "chartts-lines-arrow",
114
114
  fill: color,
115
115
  fillOpacity: 0.8
@@ -121,7 +121,7 @@ var linesChartType = {
121
121
  let idx = 0;
122
122
  for (const [name, pos] of pointMap) {
123
123
  const color = options.colors[idx % options.colors.length];
124
- nodeNodes.push(chunk3TLJCGGQ_cjs.circle(pos.x, pos.y, 6, {
124
+ nodeNodes.push(chunkJVVGQLJQ_cjs.circle(pos.x, pos.y, 6, {
125
125
  class: "chartts-lines-node",
126
126
  fill: color,
127
127
  stroke: theme.background === "transparent" ? "#fff" : theme.background,
@@ -130,7 +130,7 @@ var linesChartType = {
130
130
  "data-index": 0
131
131
  }));
132
132
  if (showLabels) {
133
- nodeNodes.push(chunk3TLJCGGQ_cjs.text(pos.x, pos.y - 14, name, {
133
+ nodeNodes.push(chunkJVVGQLJQ_cjs.text(pos.x, pos.y - 14, name, {
134
134
  class: "chartts-lines-label",
135
135
  fill: theme.textColor,
136
136
  textAnchor: "middle",
@@ -142,7 +142,7 @@ var linesChartType = {
142
142
  }
143
143
  idx++;
144
144
  }
145
- nodes.push(chunk3TLJCGGQ_cjs.group(nodeNodes, { class: "chartts-lines-nodes" }));
145
+ nodes.push(chunkJVVGQLJQ_cjs.group(nodeNodes, { class: "chartts-lines-nodes" }));
146
146
  }
147
147
  return nodes;
148
148
  },
@@ -165,7 +165,7 @@ var linesChartType = {
165
165
  const dy = my - pos.y;
166
166
  const dist = Math.sqrt(dx * dx + dy * dy);
167
167
  if (dist < 12) {
168
- return { seriesIndex: idx, pointIndex: 0, distance: dist };
168
+ return { seriesIndex: idx, pointIndex: 0, distance: dist, x: pos.x, y: pos.y };
169
169
  }
170
170
  idx++;
171
171
  }
@@ -174,5 +174,5 @@ var linesChartType = {
174
174
  };
175
175
 
176
176
  exports.linesChartType = linesChartType;
177
- //# sourceMappingURL=chunk-MZQY2FTP.cjs.map
178
- //# sourceMappingURL=chunk-MZQY2FTP.cjs.map
177
+ //# sourceMappingURL=chunk-55ZTXQQQ.cjs.map
178
+ //# sourceMappingURL=chunk-55ZTXQQQ.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/lines/lines-type.ts"],"names":["prepareNoAxes","PathBuilder","path","circle","text","group"],"mappings":"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","file":"chunk-55ZTXQQQ.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { circle, text, group } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\nimport { path } from '../../render/tree'\n\n/**\n * Lines (flow lines) chart — curved connection lines between named points.\n *\n * Data convention:\n * - labels: point/city names\n * - series use arrow notation: \"A → B\" with values[0] = flow magnitude\n *\n * Options:\n * - points: array of {name, x, y} defining positions in 0..1 normalized space\n * - showNodes: show circles at point positions (default true)\n * - showArrows: show arrowheads (default true)\n * - showLabels: show point name labels (default true)\n * - curvature: bezier curve amount 0..1 (default 0.3)\n */\n\nexport interface LinesPoint {\n name: string\n x: number // 0..1 normalized\n y: number // 0..1 normalized\n}\n\nexport interface LinesOptions {\n points?: LinesPoint[]\n showNodes?: boolean\n showArrows?: boolean\n showLabels?: boolean\n curvature?: number\n}\n\ninterface ParsedFlow {\n source: string\n target: string\n value: number\n}\n\nexport const linesChartType: ChartTypePlugin = {\n type: 'lines',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const lOpts = options as unknown as LinesOptions\n const showNodes = lOpts.showNodes !== false\n const showArrows = lOpts.showArrows !== false\n const showLabels = lOpts.showLabels !== false\n const curvature = lOpts.curvature ?? 0.3\n\n // Build point positions\n const pointMap = new Map<string, { x: number; y: number }>()\n\n if (lOpts.points) {\n for (const p of lOpts.points) {\n pointMap.set(p.name, {\n x: area.x + p.x * area.width,\n y: area.y + p.y * area.height,\n })\n }\n } else {\n // Auto-layout: arrange points in a circle\n const names = new Set<string>()\n for (const s of data.series) {\n const parts = s.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length >= 2) {\n names.add(parts[0]!.trim())\n names.add(parts[1]!.trim())\n }\n }\n // Also add labels\n for (const l of data.labels) names.add(String(l))\n\n const nameArr = [...names]\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const r = Math.min(area.width, area.height) / 2 - 40\n\n nameArr.forEach((name, i) => {\n const angle = (i / nameArr.length) * Math.PI * 2 - Math.PI / 2\n pointMap.set(name, {\n x: cx + r * Math.cos(angle),\n y: cy + r * Math.sin(angle),\n })\n })\n }\n\n // Parse flows from series\n const flows: ParsedFlow[] = []\n for (const s of data.series) {\n const parts = s.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length >= 2) {\n flows.push({\n source: parts[0]!.trim(),\n target: parts[1]!.trim(),\n value: s.values[0] ?? 1,\n })\n }\n }\n\n if (flows.length === 0 && pointMap.size === 0) return nodes\n\n // Max flow for line width scaling\n const maxFlow = Math.max(...flows.map(f => Math.abs(f.value)), 1)\n\n // Render flow lines\n for (let fi = 0; fi < flows.length; fi++) {\n const flow = flows[fi]!\n const src = pointMap.get(flow.source)\n const tgt = pointMap.get(flow.target)\n if (!src || !tgt) continue\n\n const color = options.colors[fi % options.colors.length]!\n const lineWidth = 1 + (Math.abs(flow.value) / maxFlow) * 4\n\n // Curved bezier\n const dx = tgt.x - src.x\n const dy = tgt.y - src.y\n const mx = (src.x + tgt.x) / 2\n const my = (src.y + tgt.y) / 2\n const cpx = mx - dy * curvature\n const cpy = my + dx * curvature\n\n const pb = new PathBuilder()\n pb.moveTo(src.x, src.y)\n pb.quadTo(cpx, cpy, tgt.x, tgt.y)\n\n nodes.push(path(pb.build(), {\n class: 'chartts-lines-flow',\n fill: 'none',\n stroke: color,\n strokeWidth: lineWidth,\n strokeOpacity: 0.6,\n strokeLinecap: 'round',\n 'data-series': fi,\n 'data-index': 0,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${flow.source} → ${flow.target}: ${flow.value}`,\n }))\n\n // Arrowhead at target\n if (showArrows) {\n const t = 0.95 // position along curve for arrow direction\n const ax = (1 - t) * (1 - t) * src.x + 2 * (1 - t) * t * cpx + t * t * tgt.x\n const ay = (1 - t) * (1 - t) * src.y + 2 * (1 - t) * t * cpy + t * t * tgt.y\n const angle = Math.atan2(tgt.y - ay, tgt.x - ax)\n const arrowSize = 6 + lineWidth\n\n const apb = new PathBuilder()\n apb.moveTo(tgt.x, tgt.y)\n apb.lineTo(\n tgt.x - arrowSize * Math.cos(angle - 0.4),\n tgt.y - arrowSize * Math.sin(angle - 0.4),\n )\n apb.lineTo(\n tgt.x - arrowSize * Math.cos(angle + 0.4),\n tgt.y - arrowSize * Math.sin(angle + 0.4),\n )\n apb.close()\n\n nodes.push(path(apb.build(), {\n class: 'chartts-lines-arrow',\n fill: color,\n fillOpacity: 0.8,\n }))\n }\n }\n\n // Render nodes\n if (showNodes) {\n const nodeNodes: RenderNode[] = []\n let idx = 0\n for (const [name, pos] of pointMap) {\n const color = options.colors[idx % options.colors.length]!\n\n nodeNodes.push(circle(pos.x, pos.y, 6, {\n class: 'chartts-lines-node',\n fill: color,\n stroke: theme.background === 'transparent' ? '#fff' : theme.background,\n strokeWidth: 2,\n 'data-series': idx,\n 'data-index': 0,\n }))\n\n if (showLabels) {\n nodeNodes.push(text(pos.x, pos.y - 14, name, {\n class: 'chartts-lines-label',\n fill: theme.textColor,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n }\n idx++\n }\n nodes.push(group(nodeNodes, { class: 'chartts-lines-nodes' }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { options } = ctx\n const lOpts = options as unknown as LinesOptions\n const pointMap = new Map<string, { x: number; y: number }>()\n\n if (lOpts.points) {\n const { area } = ctx\n for (const p of lOpts.points) {\n pointMap.set(p.name, {\n x: area.x + p.x * area.width,\n y: area.y + p.y * area.height,\n })\n }\n }\n\n let idx = 0\n for (const [, pos] of pointMap) {\n const dx = mx - pos.x\n const dy = my - pos.y\n const dist = Math.sqrt(dx * dx + dy * dy)\n if (dist < 12) {\n return { seriesIndex: idx, pointIndex: 0, distance: dist, x: pos.x, y: pos.y }\n }\n idx++\n }\n return null\n },\n}\n"]}
@@ -1,5 +1,6 @@
1
- import { prepareNoAxes } from './chunk-GMLJDDHZ.js';
2
- import { PathBuilder, path, text, group } from './chunk-BMTVFAX2.js';
1
+ import { roundedSlicePath } from './chunk-VGJD4F4H.js';
2
+ import { prepareNoAxes } from './chunk-T7SCCACB.js';
3
+ import { path, text, group } from './chunk-AEQXFDL7.js';
3
4
 
4
5
  // src/charts/pie/pie-type.ts
5
6
  var pieChartType = {
@@ -21,52 +22,42 @@ var pieChartType = {
21
22
  const cx = area.x + area.width / 2;
22
23
  const cy = area.y + area.height / 2;
23
24
  const outerR = Math.min(area.width, area.height) / 2 - 2;
24
- const innerRatio = ctx.options.innerRadius ?? 0;
25
+ const opts = ctx.options;
26
+ const innerRatio = opts.innerRadius ?? 0.08;
25
27
  const innerR = outerR * Math.max(0, Math.min(0.9, innerRatio));
26
- const padAngleDeg = ctx.options.padAngle ?? 2;
27
- const padAngle = padAngleDeg * Math.PI / 180;
28
- const showLabels = ctx.options.showLabels ?? true;
28
+ const gapPx = opts.gap ?? 4;
29
+ const halfGap = gapPx / 2;
30
+ const cornerRadius = opts.cornerRadius ?? 6;
31
+ const showLabels = opts.showLabels ?? true;
32
+ const outerPadAngle = halfGap / outerR;
33
+ const rawInnerPad = innerR > 0 ? halfGap / innerR : 0;
34
+ const innerPadAngle = Math.min(rawInnerPad, outerPadAngle * 3);
29
35
  let startAngle = -Math.PI / 2;
30
36
  for (let i = 0; i < values.length; i++) {
31
37
  const value = Math.abs(values[i]);
32
38
  const sliceAngle = value / total * Math.PI * 2;
33
39
  const endAngle = startAngle + sliceAngle;
34
- const actualStart = startAngle + padAngle / 2;
35
- const actualEnd = endAngle - padAngle / 2;
36
- if (actualEnd <= actualStart) {
40
+ if (sliceAngle < outerPadAngle * 2 + 0.01) {
37
41
  startAngle = endAngle;
38
42
  continue;
39
43
  }
40
- const pb = new PathBuilder();
41
- const x1o = cx + outerR * Math.cos(actualStart);
42
- const y1o = cy + outerR * Math.sin(actualStart);
43
- const x2o = cx + outerR * Math.cos(actualEnd);
44
- const y2o = cy + outerR * Math.sin(actualEnd);
45
- const largeArc = sliceAngle > Math.PI;
46
- if (innerR > 0) {
47
- const x1i = cx + innerR * Math.cos(actualEnd);
48
- const y1i = cy + innerR * Math.sin(actualEnd);
49
- const x2i = cx + innerR * Math.cos(actualStart);
50
- const y2i = cy + innerR * Math.sin(actualStart);
51
- pb.moveTo(x1o, y1o);
52
- pb.arc(outerR, outerR, 0, largeArc, true, x2o, y2o);
53
- pb.lineTo(x1i, y1i);
54
- pb.arc(innerR, innerR, 0, largeArc, false, x2i, y2i);
55
- pb.close();
56
- } else {
57
- pb.moveTo(cx, cy);
58
- pb.lineTo(x1o, y1o);
59
- pb.arc(outerR, outerR, 0, largeArc, true, x2o, y2o);
60
- pb.close();
61
- }
44
+ const sliceInnerPad = Math.min(innerPadAngle, sliceAngle * 0.15);
45
+ const d = roundedSlicePath(
46
+ cx,
47
+ cy,
48
+ outerR,
49
+ innerR,
50
+ startAngle + outerPadAngle,
51
+ endAngle - outerPadAngle,
52
+ startAngle + sliceInnerPad,
53
+ endAngle - sliceInnerPad,
54
+ cornerRadius
55
+ );
62
56
  const colorIndex = i % ctx.options.colors.length;
63
57
  const sliceNodes = [
64
- path(pb.build(), {
58
+ path(d, {
65
59
  class: "chartts-slice",
66
60
  fill: `url(#chartts-pie-${colorIndex})`,
67
- stroke: theme.background,
68
- strokeWidth: 3,
69
- style: "stroke-linejoin:round;stroke-linecap:round;",
70
61
  "data-series": 0,
71
62
  "data-index": i,
72
63
  tabindex: 0,
@@ -75,8 +66,8 @@ var pieChartType = {
75
66
  })
76
67
  ];
77
68
  if (showLabels && sliceAngle > 0.3) {
78
- const midAngle = (actualStart + actualEnd) / 2;
79
- const labelR = innerR > 0 ? (outerR + innerR) / 2 : outerR * 0.65;
69
+ const midAngle = (startAngle + endAngle) / 2;
70
+ const labelR = (outerR + innerR) / 2;
80
71
  const lx = cx + labelR * Math.cos(midAngle);
81
72
  const ly = cy + labelR * Math.sin(midAngle);
82
73
  const pct = Math.round(value / total * 100);
@@ -98,6 +89,39 @@ var pieChartType = {
98
89
  }
99
90
  return nodes;
100
91
  },
92
+ getHighlightNodes(ctx, hit) {
93
+ const { data, area } = ctx;
94
+ const series = data.series[0];
95
+ if (!series || series.values.length === 0) return [];
96
+ const values = series.values;
97
+ const total = values.reduce((sum, v) => sum + Math.abs(v), 0);
98
+ if (total === 0) return [];
99
+ const cx = area.x + area.width / 2;
100
+ const cy = area.y + area.height / 2;
101
+ const outerR = Math.min(area.width, area.height) / 2 - 2;
102
+ const opts = ctx.options;
103
+ const innerRatio = opts.innerRadius ?? 0.08;
104
+ const innerR = outerR * Math.max(0, Math.min(0.9, innerRatio));
105
+ let startAngle = -Math.PI / 2;
106
+ for (let i = 0; i < values.length; i++) {
107
+ const sliceAngle = Math.abs(values[i]) / total * Math.PI * 2;
108
+ const endAngle = startAngle + sliceAngle;
109
+ if (i === hit.pointIndex) {
110
+ const d = roundedSlicePath(cx, cy, outerR + 3, innerR - 2, startAngle, endAngle, startAngle, endAngle, 0);
111
+ return [
112
+ path(d, {
113
+ class: "chartts-highlight-slice",
114
+ fill: "none",
115
+ stroke: series.color,
116
+ strokeWidth: 2,
117
+ strokeOpacity: 0.8
118
+ })
119
+ ];
120
+ }
121
+ startAngle = endAngle;
122
+ }
123
+ return [];
124
+ },
101
125
  hitTest(ctx, mx, my) {
102
126
  const { data, area } = ctx;
103
127
  const series = data.series[0];
@@ -105,7 +129,7 @@ var pieChartType = {
105
129
  const cx = area.x + area.width / 2;
106
130
  const cy = area.y + area.height / 2;
107
131
  const outerR = Math.min(area.width, area.height) / 2 - 2;
108
- const innerRatio = ctx.options.innerRadius ?? 0;
132
+ const innerRatio = ctx.options.innerRadius ?? 0.08;
109
133
  const innerR = outerR * Math.max(0, Math.min(0.9, innerRatio));
110
134
  const dx = mx - cx;
111
135
  const dy = my - cy;
@@ -121,7 +145,9 @@ var pieChartType = {
121
145
  const sliceAngle = Math.abs(values[i]) / total * Math.PI * 2;
122
146
  const endAngle = startAngle + sliceAngle;
123
147
  if (angle >= startAngle && angle < endAngle) {
124
- return { seriesIndex: 0, pointIndex: i, distance: 0 };
148
+ const midAngle = (startAngle + endAngle) / 2;
149
+ const midR = (innerR + outerR) / 2;
150
+ return { seriesIndex: 0, pointIndex: i, distance: 0, x: cx + midR * Math.cos(midAngle), y: cy + midR * Math.sin(midAngle) };
125
151
  }
126
152
  startAngle = endAngle;
127
153
  }
@@ -133,7 +159,7 @@ var donutChartType = {
133
159
  type: "donut",
134
160
  render(ctx) {
135
161
  const opts = ctx.options;
136
- if (!opts.innerRadius) {
162
+ if (!opts.innerRadius || opts.innerRadius < 0.3) {
137
163
  opts.innerRadius = 0.55;
138
164
  }
139
165
  return pieChartType.render(ctx);
@@ -141,5 +167,5 @@ var donutChartType = {
141
167
  };
142
168
 
143
169
  export { donutChartType, pieChartType };
144
- //# sourceMappingURL=chunk-YMJQUKKX.js.map
145
- //# sourceMappingURL=chunk-YMJQUKKX.js.map
170
+ //# sourceMappingURL=chunk-56BN43J4.js.map
171
+ //# sourceMappingURL=chunk-56BN43J4.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/pie/pie-type.ts"],"names":[],"mappings":"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","file":"chunk-56BN43J4.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, path, text } from '../../render/tree'\nimport { roundedSlicePath } from '../../utils/slice-path'\n\nexport interface PieOptions {\n /** Inner radius ratio (0 = pie, 0.5+ = donut). Default 0.08 (small center gap). */\n innerRadius?: number\n /** Uniform pixel gap between slices. Default 4. */\n gap?: number\n /** Corner radius in px for rounded slice edges. Default 6. */\n cornerRadius?: number\n /** Show value labels on slices. Default true. */\n showLabels?: boolean\n}\n\n// ---------------------------------------------------------------------------\n// Pie chart type\n// ---------------------------------------------------------------------------\n\nexport const pieChartType: ChartTypePlugin = {\n type: 'pie',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme } = ctx\n const nodes: RenderNode[] = []\n\n const series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n const values = series.values\n const total = values.reduce((sum, v) => sum + Math.abs(v), 0)\n if (total === 0) return nodes\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 2\n const opts = ctx.options as unknown as PieOptions\n const innerRatio = opts.innerRadius ?? 0.08\n const innerR = outerR * Math.max(0, Math.min(0.9, innerRatio))\n const gapPx = opts.gap ?? 4\n const halfGap = gapPx / 2\n const cornerRadius = opts.cornerRadius ?? 6\n const showLabels = opts.showLabels ?? true\n\n // Angular gap offsets per radius.\n // At the outer edge, uniform pixel gap is straightforward.\n // At the inner edge, clamp the pad angle so it never eats more than 15%\n // of the smallest slice — otherwise the inner path self-intersects.\n // When innerR is tiny, use the same angle as outer (gap tapers to center).\n const outerPadAngle = halfGap / outerR\n const rawInnerPad = innerR > 0 ? halfGap / innerR : 0\n const innerPadAngle = Math.min(rawInnerPad, outerPadAngle * 3)\n\n let startAngle = -Math.PI / 2\n\n for (let i = 0; i < values.length; i++) {\n const value = Math.abs(values[i]!)\n const sliceAngle = (value / total) * Math.PI * 2\n const endAngle = startAngle + sliceAngle\n\n // Check if slice is too small to render with gap\n if (sliceAngle < outerPadAngle * 2 + 0.01) {\n startAngle = endAngle\n continue\n }\n\n // Per-slice clamp: inner pad must not exceed 15% of the slice angle\n const sliceInnerPad = Math.min(innerPadAngle, sliceAngle * 0.15)\n\n const d = roundedSlicePath(\n cx, cy, outerR, innerR,\n startAngle + outerPadAngle, endAngle - outerPadAngle,\n startAngle + sliceInnerPad, endAngle - sliceInnerPad,\n cornerRadius,\n )\n\n const colorIndex = i % ctx.options.colors.length\n const sliceNodes: RenderNode[] = [\n path(d, {\n class: 'chartts-slice',\n fill: `url(#chartts-pie-${colorIndex})`,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i] ?? `Slice ${i + 1}`}: ${values[i]}`,\n }),\n ]\n\n // Label\n if (showLabels && sliceAngle > 0.3) {\n const midAngle = (startAngle + endAngle) / 2\n const labelR = (outerR + innerR) / 2\n const lx = cx + labelR * Math.cos(midAngle)\n const ly = cy + labelR * Math.sin(midAngle)\n const pct = Math.round((value / total) * 100)\n\n sliceNodes.push(text(lx, ly, `${pct}%`, {\n class: 'chartts-slice-label',\n fill: '#fff',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n }\n\n nodes.push(group(sliceNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': String(data.labels[i] ?? `Slice ${i + 1}`),\n }))\n\n startAngle = endAngle\n }\n\n return nodes\n },\n\n getHighlightNodes(ctx: RenderContext, hit: HitResult): RenderNode[] {\n const { data, area } = ctx\n const series = data.series[0]\n if (!series || series.values.length === 0) return []\n\n const values = series.values\n const total = values.reduce((sum, v) => sum + Math.abs(v), 0)\n if (total === 0) return []\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 2\n const opts = ctx.options as unknown as PieOptions\n const innerRatio = opts.innerRadius ?? 0.08\n const innerR = outerR * Math.max(0, Math.min(0.9, innerRatio))\n\n // Find the hit slice angles\n let startAngle = -Math.PI / 2\n for (let i = 0; i < values.length; i++) {\n const sliceAngle = (Math.abs(values[i]!) / total) * Math.PI * 2\n const endAngle = startAngle + sliceAngle\n if (i === hit.pointIndex) {\n // Draw a bright outline around this slice\n const d = roundedSlicePath(cx, cy, outerR + 3, innerR - 2, startAngle, endAngle, startAngle, endAngle, 0)\n return [\n path(d, {\n class: 'chartts-highlight-slice',\n fill: 'none',\n stroke: series.color,\n strokeWidth: 2,\n strokeOpacity: 0.8,\n }),\n ]\n }\n startAngle = endAngle\n }\n return []\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 2\n const innerRatio = (ctx.options as unknown as PieOptions).innerRadius ?? 0.08\n const innerR = outerR * Math.max(0, Math.min(0.9, innerRatio))\n\n const dx = mx - cx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist > outerR || dist < innerR) return null\n\n let angle = Math.atan2(dy, dx)\n if (angle < -Math.PI / 2) angle += Math.PI * 2\n\n const values = series.values\n const total = values.reduce((sum, v) => sum + Math.abs(v), 0)\n if (total === 0) return null\n\n let startAngle = -Math.PI / 2\n for (let i = 0; i < values.length; i++) {\n const sliceAngle = (Math.abs(values[i]!) / total) * Math.PI * 2\n const endAngle = startAngle + sliceAngle\n\n if (angle >= startAngle && angle < endAngle) {\n const midAngle = (startAngle + endAngle) / 2\n const midR = (innerR + outerR) / 2\n return { seriesIndex: 0, pointIndex: i, distance: 0, x: cx + midR * Math.cos(midAngle), y: cy + midR * Math.sin(midAngle) }\n }\n\n startAngle = endAngle\n }\n\n return null\n },\n}\n\n/** Donut chart = pie with innerRadius */\nexport const donutChartType: ChartTypePlugin = {\n ...pieChartType,\n type: 'donut',\n render(ctx: RenderContext): RenderNode[] {\n const opts = ctx.options as unknown as PieOptions\n if (!opts.innerRadius || opts.innerRadius < 0.3) {\n (opts as PieOptions).innerRadius = 0.55\n }\n return pieChartType.render(ctx)\n },\n}\n"]}
@@ -1,5 +1,5 @@
1
- import { prepareNoAxes } from './chunk-GMLJDDHZ.js';
2
- import { PathBuilder, path, text, group } from './chunk-BMTVFAX2.js';
1
+ import { prepareNoAxes } from './chunk-T7SCCACB.js';
2
+ import { PathBuilder, path, text, group } from './chunk-AEQXFDL7.js';
3
3
 
4
4
  // src/charts/funnel/funnel-type.ts
5
5
  var funnelChartType = {
@@ -86,7 +86,7 @@ var funnelChartType = {
86
86
  for (let i = 0; i < stepCount; i++) {
87
87
  const y = area.y + i * (stepHeight + stepGap);
88
88
  if (my >= y && my <= y + stepHeight) {
89
- return { seriesIndex: 0, pointIndex: i, distance: 0 };
89
+ return { seriesIndex: 0, pointIndex: i, distance: 0, x: area.x + area.width / 2, y: y + stepHeight / 2 };
90
90
  }
91
91
  }
92
92
  return null;
@@ -94,5 +94,5 @@ var funnelChartType = {
94
94
  };
95
95
 
96
96
  export { funnelChartType };
97
- //# sourceMappingURL=chunk-QRTYX5KO.js.map
98
- //# sourceMappingURL=chunk-QRTYX5KO.js.map
97
+ //# sourceMappingURL=chunk-5E7FXDBM.js.map
98
+ //# sourceMappingURL=chunk-5E7FXDBM.js.map