@chartts/core 0.1.2 → 0.1.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 (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-FEQKBVCZ.cjs → chunk-2EZ2TVYT.cjs} +14 -14
  57. package/dist/chunk-2EZ2TVYT.cjs.map +1 -0
  58. package/dist/{chunk-GI7PBJSK.js → chunk-2ITF366P.js} +4 -4
  59. package/dist/chunk-2ITF366P.js.map +1 -0
  60. package/dist/{chunk-YMJQUKKX.js → chunk-2MWA7H6J.js} +68 -42
  61. package/dist/chunk-2MWA7H6J.js.map +1 -0
  62. package/dist/{chunk-CJEMSKW3.js → chunk-3SOKHPAO.js} +217 -57
  63. package/dist/chunk-3SOKHPAO.js.map +1 -0
  64. package/dist/{chunk-3N447NTJ.cjs → chunk-3V64BDKG.cjs} +14 -14
  65. package/dist/chunk-3V64BDKG.cjs.map +1 -0
  66. package/dist/{chunk-DZW35WR2.js → chunk-46ZZTP5B.js} +5 -5
  67. package/dist/chunk-46ZZTP5B.js.map +1 -0
  68. package/dist/{chunk-PCTMS2PX.cjs → chunk-47EP245Y.cjs} +19 -9
  69. package/dist/chunk-47EP245Y.cjs.map +1 -0
  70. package/dist/{chunk-DZHP4UUE.cjs → chunk-4H2LGLGI.cjs} +16 -12
  71. package/dist/chunk-4H2LGLGI.cjs.map +1 -0
  72. package/dist/{chunk-7HOU6XMW.js → chunk-4L62MAZA.js} +25 -28
  73. package/dist/chunk-4L62MAZA.js.map +1 -0
  74. package/dist/{chunk-GQR7IHER.js → chunk-4ORSJM2I.js} +6 -6
  75. package/dist/chunk-4ORSJM2I.js.map +1 -0
  76. package/dist/{chunk-FQG4DRJS.cjs → chunk-4WQUX2B4.cjs} +71 -45
  77. package/dist/chunk-4WQUX2B4.cjs.map +1 -0
  78. package/dist/{chunk-3QXN7JBV.js → chunk-4XVJYNOT.js} +7 -5
  79. package/dist/chunk-4XVJYNOT.js.map +1 -0
  80. package/dist/{chunk-6WJJ26J5.js → chunk-5J26EN5I.js} +6 -6
  81. package/dist/chunk-5J26EN5I.js.map +1 -0
  82. package/dist/{chunk-K2EZ4SS4.js → chunk-5YNIOIKK.js} +5 -5
  83. package/dist/chunk-5YNIOIKK.js.map +1 -0
  84. package/dist/{chunk-5LQ26P4J.cjs → chunk-66BHM3UN.cjs} +11 -11
  85. package/dist/chunk-66BHM3UN.cjs.map +1 -0
  86. package/dist/{chunk-DAH76GIX.cjs → chunk-6E6ZDWZD.cjs} +11 -11
  87. package/dist/chunk-6E6ZDWZD.cjs.map +1 -0
  88. package/dist/{chunk-COPERSVL.cjs → chunk-6EGHZDZI.cjs} +15 -15
  89. package/dist/{chunk-COPERSVL.cjs.map → chunk-6EGHZDZI.cjs.map} +1 -1
  90. package/dist/{chunk-KHQRHTTN.js → chunk-6JNW43SE.js} +40 -30
  91. package/dist/chunk-6JNW43SE.js.map +1 -0
  92. package/dist/{chunk-3YFDZGHO.cjs → chunk-6UWYKNFN.cjs} +13 -13
  93. package/dist/{chunk-3YFDZGHO.cjs.map → chunk-6UWYKNFN.cjs.map} +1 -1
  94. package/dist/{chunk-CHERQT4B.js → chunk-7PNCJ4OQ.js} +4 -4
  95. package/dist/chunk-7PNCJ4OQ.js.map +1 -0
  96. package/dist/{chunk-2KMMVJEE.cjs → chunk-7ZPHLIFP.cjs} +7 -7
  97. package/dist/chunk-7ZPHLIFP.cjs.map +1 -0
  98. package/dist/{chunk-FIAKZSRR.cjs → chunk-AG7VY6MJ.cjs} +19 -12
  99. package/dist/chunk-AG7VY6MJ.cjs.map +1 -0
  100. package/dist/{chunk-7MXBXWVD.js → chunk-ASNAQ35U.js} +5 -5
  101. package/dist/chunk-ASNAQ35U.js.map +1 -0
  102. package/dist/{chunk-DKVRRL3F.js → chunk-BT5H3WMI.js} +6 -6
  103. package/dist/chunk-BT5H3WMI.js.map +1 -0
  104. package/dist/{chunk-S64PTNT7.cjs → chunk-BYB3LQAT.cjs} +27 -30
  105. package/dist/chunk-BYB3LQAT.cjs.map +1 -0
  106. package/dist/{chunk-NZWFBAFQ.js → chunk-CCMLOCTH.js} +30 -4
  107. package/dist/chunk-CCMLOCTH.js.map +1 -0
  108. package/dist/{chunk-HOPFELRP.cjs → chunk-CDS2NXGT.cjs} +4 -4
  109. package/dist/{chunk-HOPFELRP.cjs.map → chunk-CDS2NXGT.cjs.map} +1 -1
  110. package/dist/{chunk-7JN6GXML.cjs → chunk-DKXW2FQC.cjs} +13 -11
  111. package/dist/chunk-DKXW2FQC.cjs.map +1 -0
  112. package/dist/{chunk-QCR6L55R.js → chunk-DR5MQC3W.js} +8 -5
  113. package/dist/chunk-DR5MQC3W.js.map +1 -0
  114. package/dist/{chunk-GUVPVNPD.cjs → chunk-DRIJNFWP.cjs} +11 -11
  115. package/dist/chunk-DRIJNFWP.cjs.map +1 -0
  116. package/dist/{chunk-BMTVFAX2.js → chunk-DX4FBN3I.js} +230 -99
  117. package/dist/chunk-DX4FBN3I.js.map +1 -0
  118. package/dist/{chunk-IKUA7O73.cjs → chunk-E43H3A3G.cjs} +7 -7
  119. package/dist/{chunk-IKUA7O73.cjs.map → chunk-E43H3A3G.cjs.map} +1 -1
  120. package/dist/{chunk-K7UR7GYC.cjs → chunk-ECB3UPTC.cjs} +13 -13
  121. package/dist/chunk-ECB3UPTC.cjs.map +1 -0
  122. package/dist/{chunk-TVPS2NJH.cjs → chunk-EHKHXQ46.cjs} +11 -11
  123. package/dist/chunk-EHKHXQ46.cjs.map +1 -0
  124. package/dist/{chunk-SLJNRP7O.cjs → chunk-EHNX3MG3.cjs} +14 -24
  125. package/dist/chunk-EHNX3MG3.cjs.map +1 -0
  126. package/dist/{chunk-MQBKLKYF.js → chunk-F5AOBHQY.js} +4 -4
  127. package/dist/{chunk-MQBKLKYF.js.map → chunk-F5AOBHQY.js.map} +1 -1
  128. package/dist/{chunk-KUFDELQM.cjs → chunk-FDNJNVKA.cjs} +10 -10
  129. package/dist/chunk-FDNJNVKA.cjs.map +1 -0
  130. package/dist/{chunk-NML7F34A.js → chunk-FSDI3NJV.js} +4 -4
  131. package/dist/chunk-FSDI3NJV.js.map +1 -0
  132. package/dist/{chunk-CCHMQZIB.js → chunk-FV7R2LLD.js} +5 -5
  133. package/dist/chunk-FV7R2LLD.js.map +1 -0
  134. package/dist/{chunk-ID7GYRYL.cjs → chunk-FZIBM3G5.cjs} +11 -11
  135. package/dist/chunk-FZIBM3G5.cjs.map +1 -0
  136. package/dist/{chunk-43WDYYVH.cjs → chunk-G6R6MSRF.cjs} +10 -10
  137. package/dist/chunk-G6R6MSRF.cjs.map +1 -0
  138. package/dist/{chunk-VK72MICB.cjs → chunk-GAWIUMAK.cjs} +8 -8
  139. package/dist/{chunk-VK72MICB.cjs.map → chunk-GAWIUMAK.cjs.map} +1 -1
  140. package/dist/{chunk-3NWZJCWL.js → chunk-GPSNBZPX.js} +5 -5
  141. package/dist/chunk-GPSNBZPX.js.map +1 -0
  142. package/dist/{chunk-MGYBMQAX.cjs → chunk-HFWO37RY.cjs} +9 -9
  143. package/dist/chunk-HFWO37RY.cjs.map +1 -0
  144. package/dist/{chunk-U7GBOQXX.js → chunk-HMB2RIEE.js} +5 -5
  145. package/dist/chunk-HMB2RIEE.js.map +1 -0
  146. package/dist/{chunk-RLH3PS3Y.js → chunk-ILCWDAKD.js} +3 -3
  147. package/dist/{chunk-RLH3PS3Y.js.map → chunk-ILCWDAKD.js.map} +1 -1
  148. package/dist/{chunk-L37ZPX6D.js → chunk-IRUIWMH6.js} +5 -5
  149. package/dist/chunk-IRUIWMH6.js.map +1 -0
  150. package/dist/{chunk-B7IV2PB3.cjs → chunk-JNQ4NL3R.cjs} +9 -9
  151. package/dist/chunk-JNQ4NL3R.cjs.map +1 -0
  152. package/dist/{chunk-FSKUEB7P.js → chunk-K5TPJVOK.js} +3 -3
  153. package/dist/{chunk-FSKUEB7P.js.map → chunk-K5TPJVOK.js.map} +1 -1
  154. package/dist/{chunk-5M624BRW.js → chunk-KTCP23W6.js} +4 -4
  155. package/dist/chunk-KTCP23W6.js.map +1 -0
  156. package/dist/{chunk-2L46SAT7.js → chunk-LIY7MYRG.js} +30 -5
  157. package/dist/chunk-LIY7MYRG.js.map +1 -0
  158. package/dist/{chunk-AA45U5KV.js → chunk-LK2A3HBT.js} +5 -5
  159. package/dist/chunk-LK2A3HBT.js.map +1 -0
  160. package/dist/{chunk-GMLJDDHZ.js → chunk-MPQECPE3.js} +3 -3
  161. package/dist/{chunk-GMLJDDHZ.js.map → chunk-MPQECPE3.js.map} +1 -1
  162. package/dist/{chunk-T6LXFMBR.cjs → chunk-MY4KMVJ5.cjs} +9 -9
  163. package/dist/{chunk-T6LXFMBR.cjs.map → chunk-MY4KMVJ5.cjs.map} +1 -1
  164. package/dist/chunk-MYXLKVJE.js +889 -0
  165. package/dist/chunk-MYXLKVJE.js.map +1 -0
  166. package/dist/{chunk-N7NZQVIV.cjs → chunk-NG7DRWWT.cjs} +7 -7
  167. package/dist/chunk-NG7DRWWT.cjs.map +1 -0
  168. package/dist/{chunk-MZQY2FTP.cjs → chunk-NGKUI7XE.cjs} +13 -13
  169. package/dist/chunk-NGKUI7XE.cjs.map +1 -0
  170. package/dist/{chunk-D2IP3MWJ.cjs → chunk-OAIMES5S.cjs} +219 -59
  171. package/dist/chunk-OAIMES5S.cjs.map +1 -0
  172. package/dist/{chunk-XKDBNAHH.cjs → chunk-OAL5RS2X.cjs} +11 -11
  173. package/dist/chunk-OAL5RS2X.cjs.map +1 -0
  174. package/dist/{chunk-FTKL3UAN.cjs → chunk-OFEROCC5.cjs} +6 -6
  175. package/dist/{chunk-FTKL3UAN.cjs.map → chunk-OFEROCC5.cjs.map} +1 -1
  176. package/dist/{chunk-IAE4VRB7.cjs → chunk-OUN3MWRQ.cjs} +35 -10
  177. package/dist/chunk-OUN3MWRQ.cjs.map +1 -0
  178. package/dist/{chunk-TIHVTKXS.cjs → chunk-PQCHNZHM.cjs} +11 -11
  179. package/dist/chunk-PQCHNZHM.cjs.map +1 -0
  180. package/dist/{chunk-BMEMMYVF.js → chunk-PVPTFMJJ.js} +5 -5
  181. package/dist/{chunk-BMEMMYVF.js.map → chunk-PVPTFMJJ.js.map} +1 -1
  182. package/dist/{chunk-LCEMO7NI.js → chunk-QERWC7U6.js} +3 -3
  183. package/dist/{chunk-LCEMO7NI.js.map → chunk-QERWC7U6.js.map} +1 -1
  184. package/dist/{chunk-2PRCN5OJ.cjs → chunk-QKJUAMRK.cjs} +6 -6
  185. package/dist/{chunk-2PRCN5OJ.cjs.map → chunk-QKJUAMRK.cjs.map} +1 -1
  186. package/dist/{chunk-WS2AL7GY.cjs → chunk-R6ZDSXN7.cjs} +34 -8
  187. package/dist/chunk-R6ZDSXN7.cjs.map +1 -0
  188. package/dist/{chunk-FKVYS4RB.js → chunk-RFEKSP62.js} +15 -8
  189. package/dist/chunk-RFEKSP62.js.map +1 -0
  190. package/dist/{chunk-FKAA5FNG.cjs → chunk-RHTVKBRC.cjs} +10 -10
  191. package/dist/chunk-RHTVKBRC.cjs.map +1 -0
  192. package/dist/{chunk-QRTYX5KO.js → chunk-RJIPFWW7.js} +5 -5
  193. package/dist/chunk-RJIPFWW7.js.map +1 -0
  194. package/dist/{chunk-GL3M7MAM.js → chunk-RN7NNB6I.js} +4 -4
  195. package/dist/chunk-RN7NNB6I.js.map +1 -0
  196. package/dist/{chunk-VGGKMTO6.js → chunk-RQJRVKAH.js} +4 -4
  197. package/dist/chunk-RQJRVKAH.js.map +1 -0
  198. package/dist/{chunk-AAKS22M3.cjs → chunk-RWQH5EO5.cjs} +12 -12
  199. package/dist/{chunk-AAKS22M3.cjs.map → chunk-RWQH5EO5.cjs.map} +1 -1
  200. package/dist/{chunk-SKREYNRK.cjs → chunk-SXVMEC6N.cjs} +45 -35
  201. package/dist/chunk-SXVMEC6N.cjs.map +1 -0
  202. package/dist/{chunk-4ABM7UYD.js → chunk-TVDQNLGJ.js} +4 -4
  203. package/dist/chunk-TVDQNLGJ.js.map +1 -0
  204. package/dist/{chunk-QXQSJ3FZ.js → chunk-TWSWD4PU.js} +5 -5
  205. package/dist/chunk-TWSWD4PU.js.map +1 -0
  206. package/dist/chunk-UFMPALRH.js +126 -0
  207. package/dist/chunk-UFMPALRH.js.map +1 -0
  208. package/dist/{chunk-3TLJCGGQ.cjs → chunk-UMIJYYF3.cjs} +230 -99
  209. package/dist/chunk-UMIJYYF3.cjs.map +1 -0
  210. package/dist/{chunk-DZKYVTV3.js → chunk-UZH6PVHD.js} +5 -5
  211. package/dist/{chunk-DZKYVTV3.js.map → chunk-UZH6PVHD.js.map} +1 -1
  212. package/dist/{chunk-ARQLGTTV.js → chunk-V45C74EB.js} +5 -5
  213. package/dist/{chunk-ARQLGTTV.js.map → chunk-V45C74EB.js.map} +1 -1
  214. package/dist/{chunk-EAKXLFOR.cjs → chunk-VBEZS3Q4.cjs} +11 -11
  215. package/dist/chunk-VBEZS3Q4.cjs.map +1 -0
  216. package/dist/{chunk-IXFSJBJS.js → chunk-WJP6CRML.js} +4 -14
  217. package/dist/chunk-WJP6CRML.js.map +1 -0
  218. package/dist/{chunk-KEMT7F5H.cjs → chunk-WVQVGQJO.cjs} +9 -9
  219. package/dist/chunk-WVQVGQJO.cjs.map +1 -0
  220. package/dist/chunk-WYIIWTIR.cjs +128 -0
  221. package/dist/chunk-WYIIWTIR.cjs.map +1 -0
  222. package/dist/{chunk-EYN74SQ5.js → chunk-XE5ZYFGM.js} +5 -5
  223. package/dist/chunk-XE5ZYFGM.js.map +1 -0
  224. package/dist/{chunk-S6NGWPXC.js → chunk-XKERO5K2.js} +4 -4
  225. package/dist/chunk-XKERO5K2.js.map +1 -0
  226. package/dist/chunk-XN6YS55F.cjs +891 -0
  227. package/dist/chunk-XN6YS55F.cjs.map +1 -0
  228. package/dist/{chunk-JT6H7G52.js → chunk-XWCY67K5.js} +5 -5
  229. package/dist/chunk-XWCY67K5.js.map +1 -0
  230. package/dist/{chunk-SC5BGA2N.cjs → chunk-XWN43PZF.cjs} +8 -8
  231. package/dist/chunk-XWN43PZF.cjs.map +1 -0
  232. package/dist/{chunk-Y4HJCMB4.cjs → chunk-YDQDZWZ7.cjs} +7 -7
  233. package/dist/chunk-YDQDZWZ7.cjs.map +1 -0
  234. package/dist/{chunk-VJQCHBS6.js → chunk-YJHB2GHQ.js} +15 -5
  235. package/dist/chunk-YJHB2GHQ.js.map +1 -0
  236. package/dist/{chunk-IUYPKYOU.js → chunk-YOLF5DYU.js} +9 -5
  237. package/dist/chunk-YOLF5DYU.js.map +1 -0
  238. package/dist/{chunk-ALRCYQQX.cjs → chunk-YX6RW6ZW.cjs} +10 -7
  239. package/dist/chunk-YX6RW6ZW.cjs.map +1 -0
  240. package/dist/{chunk-27E6G2GT.js → chunk-YZQROIJY.js} +4 -4
  241. package/dist/chunk-YZQROIJY.js.map +1 -0
  242. package/dist/{chunk-M6JYSINX.cjs → chunk-ZFSFOD5W.cjs} +8 -8
  243. package/dist/chunk-ZFSFOD5W.cjs.map +1 -0
  244. package/dist/{chunk-EFRBTSUO.cjs → chunk-ZTUKOCJN.cjs} +4 -4
  245. package/dist/{chunk-EFRBTSUO.cjs.map → chunk-ZTUKOCJN.cjs.map} +1 -1
  246. package/dist/{chunk-MVJKRPX7.js → chunk-ZY7ETQD6.js} +3 -3
  247. package/dist/{chunk-MVJKRPX7.js.map → chunk-ZY7ETQD6.js.map} +1 -1
  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 +47 -47
  321. package/dist/index.d.ts +47 -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 chunkWYIIWTIR_cjs = require('./chunk-WYIIWTIR.cjs');
4
+ var chunkCDS2NXGT_cjs = require('./chunk-CDS2NXGT.cjs');
5
+ var chunkUMIJYYF3_cjs = require('./chunk-UMIJYYF3.cjs');
5
6
 
6
7
  // src/charts/pie/pie-type.ts
7
8
  var pieChartType = {
@@ -10,7 +11,7 @@ var pieChartType = {
10
11
  return { x: "categorical", y: "linear" };
11
12
  },
12
13
  prepareData(data, options) {
13
- return chunkHOPFELRP_cjs.prepareNoAxes(data, options);
14
+ return chunkCDS2NXGT_cjs.prepareNoAxes(data, options);
14
15
  },
15
16
  render(ctx) {
16
17
  const { data, area, theme } = ctx;
@@ -23,52 +24,42 @@ var pieChartType = {
23
24
  const cx = area.x + area.width / 2;
24
25
  const cy = area.y + area.height / 2;
25
26
  const outerR = Math.min(area.width, area.height) / 2 - 2;
26
- const innerRatio = ctx.options.innerRadius ?? 0;
27
+ const opts = ctx.options;
28
+ const innerRatio = opts.innerRadius ?? 0.08;
27
29
  const innerR = outerR * Math.max(0, Math.min(0.9, innerRatio));
28
- const padAngleDeg = ctx.options.padAngle ?? 2;
29
- const padAngle = padAngleDeg * Math.PI / 180;
30
- const showLabels = ctx.options.showLabels ?? true;
30
+ const gapPx = opts.gap ?? 4;
31
+ const halfGap = gapPx / 2;
32
+ const cornerRadius = opts.cornerRadius ?? 6;
33
+ const showLabels = opts.showLabels ?? true;
34
+ const outerPadAngle = halfGap / outerR;
35
+ const rawInnerPad = innerR > 0 ? halfGap / innerR : 0;
36
+ const innerPadAngle = Math.min(rawInnerPad, outerPadAngle * 3);
31
37
  let startAngle = -Math.PI / 2;
32
38
  for (let i = 0; i < values.length; i++) {
33
39
  const value = Math.abs(values[i]);
34
40
  const sliceAngle = value / total * Math.PI * 2;
35
41
  const endAngle = startAngle + sliceAngle;
36
- const actualStart = startAngle + padAngle / 2;
37
- const actualEnd = endAngle - padAngle / 2;
38
- if (actualEnd <= actualStart) {
42
+ if (sliceAngle < outerPadAngle * 2 + 0.01) {
39
43
  startAngle = endAngle;
40
44
  continue;
41
45
  }
42
- const pb = new chunk3TLJCGGQ_cjs.PathBuilder();
43
- const x1o = cx + outerR * Math.cos(actualStart);
44
- const y1o = cy + outerR * Math.sin(actualStart);
45
- const x2o = cx + outerR * Math.cos(actualEnd);
46
- const y2o = cy + outerR * Math.sin(actualEnd);
47
- const largeArc = sliceAngle > Math.PI;
48
- if (innerR > 0) {
49
- const x1i = cx + innerR * Math.cos(actualEnd);
50
- const y1i = cy + innerR * Math.sin(actualEnd);
51
- const x2i = cx + innerR * Math.cos(actualStart);
52
- const y2i = cy + innerR * Math.sin(actualStart);
53
- pb.moveTo(x1o, y1o);
54
- pb.arc(outerR, outerR, 0, largeArc, true, x2o, y2o);
55
- pb.lineTo(x1i, y1i);
56
- pb.arc(innerR, innerR, 0, largeArc, false, x2i, y2i);
57
- pb.close();
58
- } else {
59
- pb.moveTo(cx, cy);
60
- pb.lineTo(x1o, y1o);
61
- pb.arc(outerR, outerR, 0, largeArc, true, x2o, y2o);
62
- pb.close();
63
- }
46
+ const sliceInnerPad = Math.min(innerPadAngle, sliceAngle * 0.15);
47
+ const d = chunkWYIIWTIR_cjs.roundedSlicePath(
48
+ cx,
49
+ cy,
50
+ outerR,
51
+ innerR,
52
+ startAngle + outerPadAngle,
53
+ endAngle - outerPadAngle,
54
+ startAngle + sliceInnerPad,
55
+ endAngle - sliceInnerPad,
56
+ cornerRadius
57
+ );
64
58
  const colorIndex = i % ctx.options.colors.length;
65
59
  const sliceNodes = [
66
- chunk3TLJCGGQ_cjs.path(pb.build(), {
60
+ chunkUMIJYYF3_cjs.path(d, {
67
61
  class: "chartts-slice",
68
62
  fill: `url(#chartts-pie-${colorIndex})`,
69
- stroke: theme.background,
70
- strokeWidth: 3,
71
- style: "stroke-linejoin:round;stroke-linecap:round;",
72
63
  "data-series": 0,
73
64
  "data-index": i,
74
65
  tabindex: 0,
@@ -77,12 +68,12 @@ var pieChartType = {
77
68
  })
78
69
  ];
79
70
  if (showLabels && sliceAngle > 0.3) {
80
- const midAngle = (actualStart + actualEnd) / 2;
81
- const labelR = innerR > 0 ? (outerR + innerR) / 2 : outerR * 0.65;
71
+ const midAngle = (startAngle + endAngle) / 2;
72
+ const labelR = (outerR + innerR) / 2;
82
73
  const lx = cx + labelR * Math.cos(midAngle);
83
74
  const ly = cy + labelR * Math.sin(midAngle);
84
75
  const pct = Math.round(value / total * 100);
85
- sliceNodes.push(chunk3TLJCGGQ_cjs.text(lx, ly, `${pct}%`, {
76
+ sliceNodes.push(chunkUMIJYYF3_cjs.text(lx, ly, `${pct}%`, {
86
77
  class: "chartts-slice-label",
87
78
  fill: "#fff",
88
79
  textAnchor: "middle",
@@ -92,7 +83,7 @@ var pieChartType = {
92
83
  fontWeight: 600
93
84
  }));
94
85
  }
95
- nodes.push(chunk3TLJCGGQ_cjs.group(sliceNodes, {
86
+ nodes.push(chunkUMIJYYF3_cjs.group(sliceNodes, {
96
87
  class: `chartts-series chartts-series-${i}`,
97
88
  "data-series-name": String(data.labels[i] ?? `Slice ${i + 1}`)
98
89
  }));
@@ -100,6 +91,39 @@ var pieChartType = {
100
91
  }
101
92
  return nodes;
102
93
  },
94
+ getHighlightNodes(ctx, hit) {
95
+ const { data, area } = ctx;
96
+ const series = data.series[0];
97
+ if (!series || series.values.length === 0) return [];
98
+ const values = series.values;
99
+ const total = values.reduce((sum, v) => sum + Math.abs(v), 0);
100
+ if (total === 0) return [];
101
+ const cx = area.x + area.width / 2;
102
+ const cy = area.y + area.height / 2;
103
+ const outerR = Math.min(area.width, area.height) / 2 - 2;
104
+ const opts = ctx.options;
105
+ const innerRatio = opts.innerRadius ?? 0.08;
106
+ const innerR = outerR * Math.max(0, Math.min(0.9, innerRatio));
107
+ let startAngle = -Math.PI / 2;
108
+ for (let i = 0; i < values.length; i++) {
109
+ const sliceAngle = Math.abs(values[i]) / total * Math.PI * 2;
110
+ const endAngle = startAngle + sliceAngle;
111
+ if (i === hit.pointIndex) {
112
+ const d = chunkWYIIWTIR_cjs.roundedSlicePath(cx, cy, outerR + 3, innerR - 2, startAngle, endAngle, startAngle, endAngle, 0);
113
+ return [
114
+ chunkUMIJYYF3_cjs.path(d, {
115
+ class: "chartts-highlight-slice",
116
+ fill: "none",
117
+ stroke: series.color,
118
+ strokeWidth: 2,
119
+ strokeOpacity: 0.8
120
+ })
121
+ ];
122
+ }
123
+ startAngle = endAngle;
124
+ }
125
+ return [];
126
+ },
103
127
  hitTest(ctx, mx, my) {
104
128
  const { data, area } = ctx;
105
129
  const series = data.series[0];
@@ -107,7 +131,7 @@ var pieChartType = {
107
131
  const cx = area.x + area.width / 2;
108
132
  const cy = area.y + area.height / 2;
109
133
  const outerR = Math.min(area.width, area.height) / 2 - 2;
110
- const innerRatio = ctx.options.innerRadius ?? 0;
134
+ const innerRatio = ctx.options.innerRadius ?? 0.08;
111
135
  const innerR = outerR * Math.max(0, Math.min(0.9, innerRatio));
112
136
  const dx = mx - cx;
113
137
  const dy = my - cy;
@@ -123,7 +147,9 @@ var pieChartType = {
123
147
  const sliceAngle = Math.abs(values[i]) / total * Math.PI * 2;
124
148
  const endAngle = startAngle + sliceAngle;
125
149
  if (angle >= startAngle && angle < endAngle) {
126
- return { seriesIndex: 0, pointIndex: i, distance: 0 };
150
+ const midAngle = (startAngle + endAngle) / 2;
151
+ const midR = (innerR + outerR) / 2;
152
+ return { seriesIndex: 0, pointIndex: i, distance: 0, x: cx + midR * Math.cos(midAngle), y: cy + midR * Math.sin(midAngle) };
127
153
  }
128
154
  startAngle = endAngle;
129
155
  }
@@ -135,7 +161,7 @@ var donutChartType = {
135
161
  type: "donut",
136
162
  render(ctx) {
137
163
  const opts = ctx.options;
138
- if (!opts.innerRadius) {
164
+ if (!opts.innerRadius || opts.innerRadius < 0.3) {
139
165
  opts.innerRadius = 0.55;
140
166
  }
141
167
  return pieChartType.render(ctx);
@@ -144,5 +170,5 @@ var donutChartType = {
144
170
 
145
171
  exports.donutChartType = donutChartType;
146
172
  exports.pieChartType = pieChartType;
147
- //# sourceMappingURL=chunk-FQG4DRJS.cjs.map
148
- //# sourceMappingURL=chunk-FQG4DRJS.cjs.map
173
+ //# sourceMappingURL=chunk-4WQUX2B4.cjs.map
174
+ //# sourceMappingURL=chunk-4WQUX2B4.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/pie/pie-type.ts"],"names":["prepareNoAxes","roundedSlicePath","path","text","group"],"mappings":"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","file":"chunk-4WQUX2B4.cjs","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 } from './chunk-BMTVFAX2.js';
1
+ import { prepareNoAxes } from './chunk-MPQECPE3.js';
2
+ import { PathBuilder, path, text } from './chunk-DX4FBN3I.js';
3
3
 
4
4
  // src/charts/chord/chord-type.ts
5
5
  var chordChartType = {
@@ -113,7 +113,9 @@ var chordChartType = {
113
113
  if (angle < -Math.PI / 2) angle += Math.PI * 2;
114
114
  for (const arc of arcs) {
115
115
  if (angle >= arc.startAngle && angle <= arc.endAngle) {
116
- return { seriesIndex: arc.index, pointIndex: 0, distance: 0 };
116
+ const midAngle = (arc.startAngle + arc.endAngle) / 2;
117
+ const midR = (innerR + outerR) / 2;
118
+ return { seriesIndex: arc.index, pointIndex: 0, distance: 0, x: cx + midR * Math.cos(midAngle), y: cy + midR * Math.sin(midAngle) };
117
119
  }
118
120
  }
119
121
  }
@@ -214,5 +216,5 @@ function buildChordLayout(data, _options) {
214
216
  }
215
217
 
216
218
  export { chordChartType };
217
- //# sourceMappingURL=chunk-3QXN7JBV.js.map
218
- //# sourceMappingURL=chunk-3QXN7JBV.js.map
219
+ //# sourceMappingURL=chunk-4XVJYNOT.js.map
220
+ //# sourceMappingURL=chunk-4XVJYNOT.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/chord/chord-type.ts"],"names":[],"mappings":"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","file":"chunk-4XVJYNOT.js","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 { PathBuilder } from '../../render/tree'\n\n/**\n * Chord diagram — shows relationships between entities via ribbons\n * connecting arcs on a circle.\n *\n * Data convention:\n * - labels: entity names (placed around the circle as arcs)\n * - series[i].values[j]: flow from entity i to entity j (adjacency matrix)\n * series.length should equal labels.length for a square matrix.\n *\n * Alternative: arrow notation like Sankey\n * - series names contain \"→\" or \"->\" (e.g., \"A → B\")\n */\n\ninterface ChordArc {\n index: number\n name: string\n total: number\n startAngle: number\n endAngle: number\n}\n\ninterface ChordRibbon {\n source: number\n target: number\n value: number\n sourceStart: number\n sourceEnd: number\n targetStart: number\n targetEnd: number\n}\n\nexport const chordChartType: ChartTypePlugin = {\n type: 'chord',\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 { arcs, ribbons } = buildChordLayout(data, options)\n if (arcs.length === 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 - 20\n const innerR = outerR - 14\n\n // Render arcs\n for (const arc of arcs) {\n if (arc.endAngle - arc.startAngle < 0.01) continue\n\n const color = options.colors[arc.index % options.colors.length]!\n const pb = new PathBuilder()\n\n const x1o = cx + outerR * Math.cos(arc.startAngle)\n const y1o = cy + outerR * Math.sin(arc.startAngle)\n const x2o = cx + outerR * Math.cos(arc.endAngle)\n const y2o = cy + outerR * Math.sin(arc.endAngle)\n const x1i = cx + innerR * Math.cos(arc.endAngle)\n const y1i = cy + innerR * Math.sin(arc.endAngle)\n const x2i = cx + innerR * Math.cos(arc.startAngle)\n const y2i = cy + innerR * Math.sin(arc.startAngle)\n const largeArc = (arc.endAngle - arc.startAngle) > Math.PI\n\n pb.moveTo(x1o, y1o)\n pb.arc(outerR, outerR, 0, largeArc, true, x2o, y2o)\n pb.lineTo(x1i, y1i)\n pb.arc(innerR, innerR, 0, largeArc, false, x2i, y2i)\n pb.close()\n\n nodes.push(path(pb.build(), {\n class: 'chartts-chord-arc',\n fill: color,\n stroke: color,\n strokeWidth: 0.5,\n 'data-series': arc.index,\n 'data-index': 0,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${arc.name}: ${arc.total}`,\n }))\n\n // Label\n const midAngle = (arc.startAngle + arc.endAngle) / 2\n const labelR = outerR + 12\n const lx = cx + labelR * Math.cos(midAngle)\n const ly = cy + labelR * Math.sin(midAngle)\n const anchor = Math.abs(Math.cos(midAngle)) < 0.01 ? 'middle' as const\n : Math.cos(midAngle) > 0 ? 'start' as const : 'end' as const\n\n nodes.push(text(lx, ly, arc.name, {\n class: 'chartts-chord-label',\n fill: theme.textColor,\n textAnchor: anchor,\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Render ribbons\n for (let ri = 0; ri < ribbons.length; ri++) {\n const ribbon = ribbons[ri]!\n const color = options.colors[ribbon.source % options.colors.length]!\n\n const pb = new PathBuilder()\n // Source arc on inner ring\n const sx1 = cx + innerR * Math.cos(ribbon.sourceStart)\n const sy1 = cy + innerR * Math.sin(ribbon.sourceStart)\n const sx2 = cx + innerR * Math.cos(ribbon.sourceEnd)\n const sy2 = cy + innerR * Math.sin(ribbon.sourceEnd)\n // Target arc on inner ring\n const tx1 = cx + innerR * Math.cos(ribbon.targetStart)\n const ty1 = cy + innerR * Math.sin(ribbon.targetStart)\n const tx2 = cx + innerR * Math.cos(ribbon.targetEnd)\n const ty2 = cy + innerR * Math.sin(ribbon.targetEnd)\n\n const srcLarge = (ribbon.sourceEnd - ribbon.sourceStart) > Math.PI\n const tgtLarge = (ribbon.targetEnd - ribbon.targetStart) > Math.PI\n\n pb.moveTo(sx1, sy1)\n pb.arc(innerR, innerR, 0, srcLarge, true, sx2, sy2)\n // Bezier to target\n pb.quadTo(cx, cy, tx1, ty1)\n pb.arc(innerR, innerR, 0, tgtLarge, true, tx2, ty2)\n // Bezier back to source\n pb.quadTo(cx, cy, sx1, sy1)\n pb.close()\n\n nodes.push(path(pb.build(), {\n class: 'chartts-chord-ribbon',\n fill: color,\n fillOpacity: 0.35,\n stroke: color,\n strokeWidth: 0.3,\n 'data-series': ribbon.source,\n 'data-index': ri,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${arcs[ribbon.source]!.name} → ${arcs[ribbon.target]!.name}: ${ribbon.value}`,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area, options } = ctx\n const { arcs } = buildChordLayout(data, options)\n if (arcs.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 - 20\n const innerR = outerR - 14\n\n const dx = mx - cx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n // Check arc hits\n if (dist >= innerR && dist <= outerR) {\n let angle = Math.atan2(dy, dx)\n if (angle < -Math.PI / 2) angle += Math.PI * 2\n\n for (const arc of arcs) {\n if (angle >= arc.startAngle && angle <= arc.endAngle) {\n const midAngle = (arc.startAngle + arc.endAngle) / 2\n const midR = (innerR + outerR) / 2\n return { seriesIndex: arc.index, pointIndex: 0, distance: 0, x: cx + midR * Math.cos(midAngle), y: cy + midR * Math.sin(midAngle) }\n }\n }\n }\n\n return null\n },\n}\n\n// ---------------------------------------------------------------------------\n// Layout computation\n// ---------------------------------------------------------------------------\n\nfunction buildChordLayout(\n data: PreparedData,\n _options: ResolvedOptions,\n): { arcs: ChordArc[]; ribbons: ChordRibbon[]; matrix: number[][] } {\n const arcs: ChordArc[] = []\n const ribbons: ChordRibbon[] = []\n\n // Check for arrow notation\n const hasArrows = data.series.some(s => s.name.includes('→') || s.name.includes('->'))\n\n // Build adjacency matrix\n const nodeNames: string[] = []\n const nodeMap = new Map<string, number>()\n\n function getOrCreate(name: string): number {\n if (nodeMap.has(name)) return nodeMap.get(name)!\n const idx = nodeNames.length\n nodeMap.set(name, idx)\n nodeNames.push(name)\n return idx\n }\n\n if (hasArrows) {\n // Parse arrow notation\n for (const series of data.series) {\n const parts = series.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length < 2) continue\n getOrCreate(parts[0]!.trim())\n getOrCreate(parts[1]!.trim())\n }\n } else {\n for (let i = 0; i < data.labels.length; i++) {\n getOrCreate(String(data.labels[i]))\n }\n }\n\n const n = nodeNames.length\n if (n === 0) return { arcs, ribbons, matrix: [] }\n\n const matrix: number[][] = Array.from({ length: n }, () => new Array(n).fill(0))\n\n if (hasArrows) {\n for (const series of data.series) {\n const parts = series.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length < 2) continue\n const src = getOrCreate(parts[0]!.trim())\n const tgt = getOrCreate(parts[1]!.trim())\n const val = series.values[0] ?? 0\n if (val > 0) matrix[src]![tgt]! += val\n }\n } else {\n for (let si = 0; si < data.series.length && si < n; si++) {\n for (let j = 0; j < data.series[si]!.values.length && j < n; j++) {\n const val = data.series[si]!.values[j]!\n if (val > 0) matrix[si]![j]! = val\n }\n }\n }\n\n // Compute totals per node\n const totals = nodeNames.map((_, i) => {\n let total = 0\n for (let j = 0; j < n; j++) {\n total += matrix[i]![j]!\n total += matrix[j]![i]!\n }\n return total\n })\n\n const grandTotal = totals.reduce((s, t) => s + t, 0)\n if (grandTotal === 0) return { arcs, ribbons, matrix }\n\n // Layout arcs\n const padAngle = 0.04\n const totalPad = padAngle * n\n const available = Math.PI * 2 - totalPad\n\n let angle = -Math.PI / 2\n for (let i = 0; i < n; i++) {\n const span = (totals[i]! / grandTotal) * available\n arcs.push({\n index: i,\n name: nodeNames[i]!,\n total: totals[i]!,\n startAngle: angle,\n endAngle: angle + span,\n })\n angle += span + padAngle\n }\n\n // Layout ribbons — track offsets within each arc\n const arcOffsets = arcs.map(a => a.startAngle)\n\n for (let i = 0; i < n; i++) {\n for (let j = i; j < n; j++) {\n const val = matrix[i]![j]! + matrix[j]![i]!\n if (val <= 0) continue\n\n const srcSpan = (matrix[i]![j]! / Math.max(totals[i]!, 1)) * (arcs[i]!.endAngle - arcs[i]!.startAngle)\n const tgtSpan = (matrix[j]![i]! / Math.max(totals[j]!, 1)) * (arcs[j]!.endAngle - arcs[j]!.startAngle)\n\n ribbons.push({\n source: i,\n target: j,\n value: val,\n sourceStart: arcOffsets[i]!,\n sourceEnd: arcOffsets[i]! + srcSpan,\n targetStart: arcOffsets[j]!,\n targetEnd: arcOffsets[j]! + tgtSpan,\n })\n\n arcOffsets[i]! += srcSpan\n arcOffsets[j]! += tgtSpan\n }\n }\n\n return { arcs, ribbons, matrix }\n}\n"]}
@@ -1,10 +1,10 @@
1
- import { prepareNoAxes } from './chunk-GMLJDDHZ.js';
2
- import { path, text, group } from './chunk-BMTVFAX2.js';
1
+ import { prepareNoAxes } from './chunk-MPQECPE3.js';
2
+ import { path, text, group } from './chunk-DX4FBN3I.js';
3
3
 
4
4
  // src/charts/pictorialbar/pictorialbar-type.ts
5
5
  var SYMBOL_PATHS = {
6
6
  circle: "M0.5,0A0.5,0.5,0,1,1,-0.5,0A0.5,0.5,0,1,1,0.5,0Z",
7
- diamond: "M0,-0.5L0.5,0L0,-0.5L-0.5,0Z",
7
+ diamond: "M0,-0.5L0.5,0L0,0.5L-0.5,0Z",
8
8
  square: "M-0.4,-0.4L0.4,-0.4L0.4,0.4L-0.4,0.4Z",
9
9
  triangle: "M0,-0.5L0.5,0.4L-0.5,0.4Z",
10
10
  star: "M0,-0.5L0.15,-0.15L0.5,-0.15L0.22,0.07L0.31,0.45L0,0.22L-0.31,0.45L-0.22,0.07L-0.5,-0.15L-0.15,-0.15Z"
@@ -118,7 +118,7 @@ var pictorialBarChartType = {
118
118
  for (let i = 0; i < barCount; i++) {
119
119
  const cx = startX + i * (barWidth + barGap) + barWidth / 2;
120
120
  if (Math.abs(mx - cx) < barWidth / 2 + 5) {
121
- return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx) };
121
+ return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx), x: cx, y: area.y + area.height / 2 };
122
122
  }
123
123
  }
124
124
  return null;
@@ -126,5 +126,5 @@ var pictorialBarChartType = {
126
126
  };
127
127
 
128
128
  export { pictorialBarChartType };
129
- //# sourceMappingURL=chunk-6WJJ26J5.js.map
130
- //# sourceMappingURL=chunk-6WJJ26J5.js.map
129
+ //# sourceMappingURL=chunk-5J26EN5I.js.map
130
+ //# sourceMappingURL=chunk-5J26EN5I.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/pictorialbar/pictorialbar-type.ts"],"names":[],"mappings":"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","file":"chunk-5J26EN5I.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'\n\n/**\n * PictorialBar chart — bar chart where bars are filled with repeated symbols.\n *\n * Data convention:\n * - labels: category names\n * - series[0].values: bar values\n *\n * The bars are made of stacked symbols (circles, diamonds, or custom shapes)\n * creating a pictograph/isotype visualization.\n */\n\nexport interface PictorialBarOptions {\n /** Symbol shape. Default 'circle'. */\n symbol?: 'circle' | 'diamond' | 'square' | 'triangle' | 'star'\n /** Symbol size in px. Default 12. */\n symbolSize?: number\n /** Gap between symbols. Default 2. */\n symbolGap?: number\n /** Show value labels. Default true. */\n showValues?: boolean\n}\n\n// SVG path data for symbols (centered at 0,0, size 1x1)\nconst SYMBOL_PATHS: Record<string, string> = {\n circle: 'M0.5,0A0.5,0.5,0,1,1,-0.5,0A0.5,0.5,0,1,1,0.5,0Z',\n diamond: 'M0,-0.5L0.5,0L0,0.5L-0.5,0Z',\n square: 'M-0.4,-0.4L0.4,-0.4L0.4,0.4L-0.4,0.4Z',\n triangle: 'M0,-0.5L0.5,0.4L-0.5,0.4Z',\n star: 'M0,-0.5L0.15,-0.15L0.5,-0.15L0.22,0.07L0.31,0.45L0,0.22L-0.31,0.45L-0.22,0.07L-0.5,-0.15L-0.15,-0.15Z',\n}\n\nexport const pictorialBarChartType: ChartTypePlugin = {\n type: 'pictorialbar',\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 const pOpts = options as unknown as PictorialBarOptions\n const symbolShape = pOpts.symbol ?? 'circle'\n const symbolSize = pOpts.symbolSize ?? 14\n const symbolGap = pOpts.symbolGap ?? 2\n const showValues = pOpts.showValues ?? true\n\n const values = series.values\n const maxVal = Math.max(...values.map(Math.abs))\n if (maxVal === 0) return nodes\n\n const barCount = values.length\n const barGap = 16\n const barWidth = Math.min(\n (area.width - barGap * (barCount + 1)) / barCount,\n symbolSize * 3,\n )\n const totalWidth = barCount * barWidth + (barCount - 1) * barGap\n const startX = area.x + (area.width - totalWidth) / 2\n\n const symbolStep = symbolSize + symbolGap\n const maxSymbols = Math.floor((area.height - 30) / symbolStep)\n\n for (let i = 0; i < barCount; i++) {\n const val = Math.abs(values[i]!)\n const symbolCount = Math.max(1, Math.round((val / maxVal) * maxSymbols))\n const color = options.colors[i % options.colors.length]!\n const cx = startX + i * (barWidth + barGap) + barWidth / 2\n const barNodes: RenderNode[] = []\n\n for (let s = 0; s < symbolCount; s++) {\n const sy = area.y + area.height - 20 - s * symbolStep - symbolSize / 2\n\n if (symbolShape === 'circle') {\n barNodes.push({\n type: 'circle',\n cx,\n cy: sy,\n r: symbolSize / 2,\n attrs: {\n class: 'chartts-pictorialbar-symbol',\n fill: color,\n fillOpacity: 0.85,\n 'data-series': 0,\n 'data-index': i,\n },\n })\n } else {\n // Use path-based symbols\n const symbolPath = SYMBOL_PATHS[symbolShape] ?? SYMBOL_PATHS.circle!\n barNodes.push(path(symbolPath, {\n class: 'chartts-pictorialbar-symbol',\n fill: color,\n fillOpacity: 0.85,\n transform: `translate(${cx},${sy}) scale(${symbolSize})`,\n 'data-series': 0,\n 'data-index': i,\n }))\n }\n }\n\n // Value label above bar\n if (showValues) {\n const topY = area.y + area.height - 20 - (symbolCount - 1) * symbolStep - symbolSize\n barNodes.push(text(cx, topY - 8, String(values[i]!), {\n class: 'chartts-pictorialbar-value',\n fill: theme.textColor,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n }\n\n // Category label below\n barNodes.push(text(cx, area.y + area.height - 4, String(data.labels[i] ?? `Cat ${i + 1}`), {\n class: 'chartts-pictorialbar-label',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n nodes.push(group(barNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': String(data.labels[i] ?? `Cat ${i + 1}`),\n }))\n }\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 pOpts = ctx.options as unknown as PictorialBarOptions\n const symbolSize = pOpts.symbolSize ?? 14\n\n const barCount = series.values.length\n const barGap = 16\n const barWidth = Math.min(\n (area.width - barGap * (barCount + 1)) / barCount,\n symbolSize * 3,\n )\n const totalWidth = barCount * barWidth + (barCount - 1) * barGap\n const startX = area.x + (area.width - totalWidth) / 2\n\n for (let i = 0; i < barCount; i++) {\n const cx = startX + i * (barWidth + barGap) + barWidth / 2\n if (Math.abs(mx - cx) < barWidth / 2 + 5) {\n return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx), x: cx, y: area.y + area.height / 2 }\n }\n }\n\n return null\n },\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import { getBandwidth } from './chunk-E6PR75X7.js';
2
2
  import { formatNum } from './chunk-OGSZO22B.js';
3
- import { path, rect, group, PathBuilder, circle, prepareData } from './chunk-BMTVFAX2.js';
3
+ import { path, rect, group, PathBuilder, circle, prepareData } from './chunk-DX4FBN3I.js';
4
4
 
5
5
  // src/charts/combo/combo-type.ts
6
6
  var comboChartType = {
@@ -132,7 +132,7 @@ var comboChartType = {
132
132
  const y = barSeries.values[i] >= 0 ? vy : baseline;
133
133
  const h = Math.abs(vy - baseline);
134
134
  if (mx >= barX - 2 && mx <= barX + barWidth + 2 && my >= y - 2 && my <= y + h + 2) {
135
- best = { seriesIndex: barSeries.index, pointIndex: i, distance: 0 };
135
+ best = { seriesIndex: barSeries.index, pointIndex: i, distance: 0, x: cx, y: vy };
136
136
  return best;
137
137
  }
138
138
  }
@@ -147,7 +147,7 @@ var comboChartType = {
147
147
  const dist = Math.sqrt(dx * dx + dy * dy);
148
148
  if (dist < bestDist && dist < 20) {
149
149
  bestDist = dist;
150
- best = { seriesIndex: series.index, pointIndex: i, distance: dist };
150
+ best = { seriesIndex: series.index, pointIndex: i, distance: dist, x: px, y: py };
151
151
  }
152
152
  }
153
153
  }
@@ -156,5 +156,5 @@ var comboChartType = {
156
156
  };
157
157
 
158
158
  export { comboChartType };
159
- //# sourceMappingURL=chunk-K2EZ4SS4.js.map
160
- //# sourceMappingURL=chunk-K2EZ4SS4.js.map
159
+ //# sourceMappingURL=chunk-5YNIOIKK.js.map
160
+ //# sourceMappingURL=chunk-5YNIOIKK.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/combo/combo-type.ts"],"names":[],"mappings":"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","file":"chunk-5YNIOIKK.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect, path, circle } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\nimport { formatNum } from '../../utils/format'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Combo / Mixed chart — overlays bar + line on the same axes.\n *\n * Convention: series with `fill: true` or series at index 0 render as bars.\n * Remaining series render as lines with points.\n * Use the series `fill` flag to control: fill=false (or omitted after first) → line.\n *\n * Simple heuristic:\n * - series[0] → bars\n * - series[1..N] → lines\n */\nexport const comboChartType: ChartTypePlugin = {\n type: 'combo',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, options)\n if (options.yMin === undefined && prepared.bounds.yMin > 0) {\n prepared.bounds.yMin = 0\n }\n if (options.yMax === undefined && prepared.bounds.yMax < 0) {\n prepared.bounds.yMax = 0\n }\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n if (data.series.length === 0) return nodes\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n // Bars for series[0]\n const barSeries = data.series[0]!\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - options.barGap)\n const baseline = yScale.map(Math.max(0, yScale.getDomain()[0] as number))\n\n const barNodes: RenderNode[] = []\n for (let i = 0; i < barSeries.values.length; i++) {\n if (isNaN(barSeries.values[i]!)) continue // skip missing data\n const cx = xScale.map(i)\n const barX = cx - barWidth / 2\n const vy = yScale.map(barSeries.values[i]!)\n const isPositive = barSeries.values[i]! >= 0\n const y = isPositive ? vy : baseline\n const h = Math.abs(vy - baseline)\n\n const barFill = `url(#chartts-bar-${barSeries.index})`\n const r = Math.min(options.barRadius, barWidth / 2, h / 2)\n\n if (r > 0 && h > r * 2) {\n const d = isPositive\n ? `M${formatNum(barX)},${formatNum(y + h)}V${formatNum(y + r)}Q${formatNum(barX)},${formatNum(y)},${formatNum(barX + r)},${formatNum(y)}H${formatNum(barX + barWidth - r)}Q${formatNum(barX + barWidth)},${formatNum(y)},${formatNum(barX + barWidth)},${formatNum(y + r)}V${formatNum(y + h)}Z`\n : `M${formatNum(barX)},${formatNum(y)}V${formatNum(y + h - r)}Q${formatNum(barX)},${formatNum(y + h)},${formatNum(barX + r)},${formatNum(y + h)}H${formatNum(barX + barWidth - r)}Q${formatNum(barX + barWidth)},${formatNum(y + h)},${formatNum(barX + barWidth)},${formatNum(y + h - r)}V${formatNum(y)}Z`\n barNodes.push(path(d, {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': barSeries.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${barSeries.name}: ${barSeries.values[i]}`,\n }))\n } else {\n barNodes.push(rect(barX, y, barWidth, h, {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': barSeries.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${barSeries.name}: ${barSeries.values[i]}`,\n }))\n }\n }\n nodes.push(group(barNodes, {\n class: `chartts-series chartts-series-${barSeries.index}`,\n 'data-series-name': barSeries.name,\n }))\n\n // Lines for series[1..N]\n for (let si = 1; si < data.series.length; si++) {\n const series = data.series[si]!\n const color = options.colors[series.index % options.colors.length]!\n const lineNodes: RenderNode[] = []\n\n // Build line path\n const pb = new PathBuilder()\n let started = false\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) { started = false; continue } // break line at NaN\n const px = xScale.map(i)\n const py = yScale.map(series.values[i]!)\n if (!started) {\n pb.moveTo(px, py)\n started = true\n } else {\n pb.lineTo(px, py)\n }\n }\n\n lineNodes.push(path(pb.build(), {\n class: 'chartts-line chartts-combo-line',\n stroke: color,\n strokeWidth: 2,\n fill: 'none',\n }))\n\n // Points\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue // skip missing data\n const px = xScale.map(i)\n const py = yScale.map(series.values[i]!)\n lineNodes.push(circle(px, py, 4, {\n class: 'chartts-point chartts-combo-point',\n fill: color,\n stroke: '#fff',\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]}`,\n }))\n }\n\n nodes.push(group(lineNodes, {\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, options } = ctx\n if (data.series.length === 0) return null\n\n let best: HitResult | null = null\n let bestDist = Infinity\n\n // Check bar hits first (series[0])\n const barSeries = data.series[0]!\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - options.barGap)\n const baseline = yScale.map(Math.max(0, yScale.getDomain()[0] as number))\n\n for (let i = 0; i < barSeries.values.length; i++) {\n if (isNaN(barSeries.values[i]!)) continue\n const cx = xScale.map(i)\n const barX = cx - barWidth / 2\n const vy = yScale.map(barSeries.values[i]!)\n const y = barSeries.values[i]! >= 0 ? vy : baseline\n const h = Math.abs(vy - baseline)\n\n if (mx >= barX - 2 && mx <= barX + barWidth + 2 && my >= y - 2 && my <= y + h + 2) {\n best = { seriesIndex: barSeries.index, pointIndex: i, distance: 0, x: cx, y: vy }\n return best\n }\n }\n\n // Check line point hits (series[1..N])\n for (let si = 1; si < data.series.length; si++) {\n const series = data.series[si]!\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue\n const px = xScale.map(i)\n const py = yScale.map(series.values[i]!)\n const dx = mx - px\n const dy = my - py\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist < bestDist && dist < 20) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist, x: px, y: py }\n }\n }\n }\n\n return best\n },\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
3
  var chunkNHGKZMD7_cjs = require('./chunk-NHGKZMD7.cjs');
4
- var chunk3TLJCGGQ_cjs = require('./chunk-3TLJCGGQ.cjs');
4
+ var chunkUMIJYYF3_cjs = require('./chunk-UMIJYYF3.cjs');
5
5
 
6
6
  // src/charts/boxplot/boxplot-type.ts
7
7
  var boxplotChartType = {
@@ -18,7 +18,7 @@ var boxplotChartType = {
18
18
  while (padded.length < valLen) padded.push("");
19
19
  syntheticData.labels = padded;
20
20
  }
21
- const prepared = chunk3TLJCGGQ_cjs.prepareData(syntheticData, options);
21
+ const prepared = chunkUMIJYYF3_cjs.prepareData(syntheticData, options);
22
22
  if (data.labels && data.labels.length < valLen) {
23
23
  prepared.labels = [...data.labels];
24
24
  }
@@ -54,24 +54,24 @@ var boxplotChartType = {
54
54
  const color = options.colors[i % options.colors.length];
55
55
  const seriesIdx = Math.min(i, data.series.length - 1);
56
56
  const boxNodes = [];
57
- boxNodes.push(chunk3TLJCGGQ_cjs.line(cx, yMin, cx, yMax, {
57
+ boxNodes.push(chunkUMIJYYF3_cjs.line(cx, yMin, cx, yMax, {
58
58
  class: "chartts-boxplot-whisker",
59
59
  stroke: color,
60
60
  strokeWidth: 1.5
61
61
  }));
62
- boxNodes.push(chunk3TLJCGGQ_cjs.line(cx - boxWidth * 0.3, yMin, cx + boxWidth * 0.3, yMin, {
62
+ boxNodes.push(chunkUMIJYYF3_cjs.line(cx - boxWidth * 0.3, yMin, cx + boxWidth * 0.3, yMin, {
63
63
  class: "chartts-boxplot-cap",
64
64
  stroke: color,
65
65
  strokeWidth: 1.5
66
66
  }));
67
- boxNodes.push(chunk3TLJCGGQ_cjs.line(cx - boxWidth * 0.3, yMax, cx + boxWidth * 0.3, yMax, {
67
+ boxNodes.push(chunkUMIJYYF3_cjs.line(cx - boxWidth * 0.3, yMax, cx + boxWidth * 0.3, yMax, {
68
68
  class: "chartts-boxplot-cap",
69
69
  stroke: color,
70
70
  strokeWidth: 1.5
71
71
  }));
72
72
  const boxTop = Math.min(yQ1, yQ3);
73
73
  const boxH = Math.abs(yQ3 - yQ1);
74
- boxNodes.push(chunk3TLJCGGQ_cjs.rect(boxX, boxTop, boxWidth, boxH, {
74
+ boxNodes.push(chunkUMIJYYF3_cjs.rect(boxX, boxTop, boxWidth, boxH, {
75
75
  class: "chartts-boxplot-box",
76
76
  fill: color,
77
77
  fillOpacity: 0.25,
@@ -85,12 +85,12 @@ var boxplotChartType = {
85
85
  role: "img",
86
86
  ariaLabel: `${data.labels[i]}: min=${vMin}, Q1=${q1}, median=${median}, Q3=${q3}, max=${vMax}`
87
87
  }));
88
- boxNodes.push(chunk3TLJCGGQ_cjs.line(boxX, yMed, boxX + boxWidth, yMed, {
88
+ boxNodes.push(chunkUMIJYYF3_cjs.line(boxX, yMed, boxX + boxWidth, yMed, {
89
89
  class: "chartts-boxplot-median",
90
90
  stroke: color,
91
91
  strokeWidth: 2.5
92
92
  }));
93
- nodes.push(chunk3TLJCGGQ_cjs.group(boxNodes, {
93
+ nodes.push(chunkUMIJYYF3_cjs.group(boxNodes, {
94
94
  class: `chartts-series chartts-series-${i}`,
95
95
  "data-series-name": String(data.labels[i])
96
96
  }));
@@ -120,7 +120,7 @@ var boxplotChartType = {
120
120
  const bottom = Math.max(yMin, yMax);
121
121
  if (mx >= cx - boxWidth / 2 - 4 && mx <= cx + boxWidth / 2 + 4 && my >= top - 4 && my <= bottom + 4) {
122
122
  const seriesIdx = Math.min(i, data.series.length - 1);
123
- return { seriesIndex: seriesIdx, pointIndex: i, distance: 0 };
123
+ return { seriesIndex: seriesIdx, pointIndex: i, distance: 0, x: cx, y: yScale.map(vals[2]) };
124
124
  }
125
125
  }
126
126
  return null;
@@ -128,5 +128,5 @@ var boxplotChartType = {
128
128
  };
129
129
 
130
130
  exports.boxplotChartType = boxplotChartType;
131
- //# sourceMappingURL=chunk-5LQ26P4J.cjs.map
132
- //# sourceMappingURL=chunk-5LQ26P4J.cjs.map
131
+ //# sourceMappingURL=chunk-66BHM3UN.cjs.map
132
+ //# sourceMappingURL=chunk-66BHM3UN.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/boxplot/boxplot-type.ts"],"names":["prepareData","getBandwidth","line","rect","group"],"mappings":"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","file":"chunk-66BHM3UN.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect, line } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Boxplot / Whisker chart — displays statistical distribution for each category.\n *\n * Data format: each series has exactly 5 values per label:\n * [min, Q1, median, Q3, max]\n *\n * For simplicity, if there are N labels, series[0] has N*5 values:\n * [min1, q1_1, med1, q3_1, max1, min2, q1_2, med2, q3_2, max2, ...]\n *\n * Or use multiple series where each series has 5 values for its category.\n */\nexport interface BoxplotOptions {\n /** Width ratio of boxes. Default 0.6. */\n boxWidth?: number\n}\n\nexport const boxplotChartType: ChartTypePlugin = {\n type: 'boxplot',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n // Boxplot: single series with N*5 values. Create synthetic labels if needed.\n // We need to trick the validator: expand labels to match values length.\n const labelCount = data.labels?.length ?? 0\n const valLen = data.series[0]?.values.length ?? 0\n const syntheticData = { ...data }\n if (labelCount > 0 && valLen > labelCount) {\n // Pad labels to match values length (validator needs them equal)\n const padded: string[] = (data.labels ?? []).map(String)\n while (padded.length < valLen) padded.push('')\n syntheticData.labels = padded\n }\n\n const prepared = prepareData(syntheticData, options)\n\n // Restore original labels for rendering\n if (data.labels && data.labels.length < valLen) {\n prepared.labels = [...data.labels]\n }\n\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n // Each series represents one boxplot: 5 values = [min, Q1, median, Q3, max]\n const seriesCount = data.series.length\n if (seriesCount === 0) return nodes\n\n const bOpts = options as unknown as BoxplotOptions\n const boxWidthRatio = bOpts.boxWidth ?? 0.6\n\n const bw = getBandwidth(xScale)\n const boxWidth = bw * boxWidthRatio\n\n for (let i = 0; i < data.labels.length; i++) {\n // Collect the 5 values for this label from all series,\n // or if single series with N*5 values, extract 5 at offset i*5\n let vals: number[]\n if (data.series.length === 1) {\n const s = data.series[0]!\n if (s.values.length >= (i + 1) * 5) {\n vals = s.values.slice(i * 5, i * 5 + 5)\n } else continue\n } else if (data.series.length > i && data.series[i]!.values.length >= 5) {\n vals = data.series[i]!.values.slice(0, 5)\n } else continue\n\n const [vMin, q1, median, q3, vMax] = vals as [number, number, number, number, number]\n const cx = xScale.map(i)\n const boxX = cx - boxWidth / 2\n\n const yMin = yScale.map(vMin)\n const yQ1 = yScale.map(q1)\n const yMed = yScale.map(median)\n const yQ3 = yScale.map(q3)\n const yMax = yScale.map(vMax)\n\n const color = options.colors[i % options.colors.length]!\n const seriesIdx = Math.min(i, data.series.length - 1)\n const boxNodes: RenderNode[] = []\n\n // Whisker line (min to max)\n boxNodes.push(line(cx, yMin, cx, yMax, {\n class: 'chartts-boxplot-whisker',\n stroke: color,\n strokeWidth: 1.5,\n }))\n\n // Min whisker cap\n boxNodes.push(line(cx - boxWidth * 0.3, yMin, cx + boxWidth * 0.3, yMin, {\n class: 'chartts-boxplot-cap',\n stroke: color,\n strokeWidth: 1.5,\n }))\n\n // Max whisker cap\n boxNodes.push(line(cx - boxWidth * 0.3, yMax, cx + boxWidth * 0.3, yMax, {\n class: 'chartts-boxplot-cap',\n stroke: color,\n strokeWidth: 1.5,\n }))\n\n // IQR box (Q1 to Q3)\n const boxTop = Math.min(yQ1, yQ3)\n const boxH = Math.abs(yQ3 - yQ1)\n boxNodes.push(rect(boxX, boxTop, boxWidth, boxH, {\n class: 'chartts-boxplot-box',\n fill: color,\n fillOpacity: 0.25,\n stroke: color,\n strokeWidth: 1.5,\n rx: 4,\n ry: 4,\n 'data-series': seriesIdx,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i]}: min=${vMin}, Q1=${q1}, median=${median}, Q3=${q3}, max=${vMax}`,\n }))\n\n // Median line\n boxNodes.push(line(boxX, yMed, boxX + boxWidth, yMed, {\n class: 'chartts-boxplot-median',\n stroke: color,\n strokeWidth: 2.5,\n }))\n\n nodes.push(group(boxNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': String(data.labels[i]),\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale, options } = ctx\n if (data.labels.length === 0) return null\n\n const bOpts = options as unknown as BoxplotOptions\n const boxWidthRatio = bOpts.boxWidth ?? 0.6\n const bw = getBandwidth(xScale)\n const boxWidth = bw * boxWidthRatio\n\n for (let i = 0; i < data.labels.length; i++) {\n let vals: number[]\n if (data.series.length === 1) {\n const s = data.series[0]!\n if (s.values.length >= (i + 1) * 5) vals = s.values.slice(i * 5, i * 5 + 5)\n else continue\n } else if (data.series.length > i && data.series[i]!.values.length >= 5) {\n vals = data.series[i]!.values.slice(0, 5)\n } else continue\n\n const cx = xScale.map(i)\n const yMin = yScale.map(vals[0]!)\n const yMax = yScale.map(vals[4]!)\n\n const top = Math.min(yMin, yMax)\n const bottom = Math.max(yMin, yMax)\n\n if (mx >= cx - boxWidth / 2 - 4 && mx <= cx + boxWidth / 2 + 4 &&\n my >= top - 4 && my <= bottom + 4) {\n const seriesIdx = Math.min(i, data.series.length - 1)\n return { seriesIndex: seriesIdx, pointIndex: i, distance: 0, x: cx, y: yScale.map(vals[2]!) }\n }\n }\n\n return null\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 chunkCDS2NXGT_cjs = require('./chunk-CDS2NXGT.cjs');
4
+ var chunkUMIJYYF3_cjs = require('./chunk-UMIJYYF3.cjs');
5
5
 
6
6
  // src/charts/matrix/matrix-type.ts
7
7
  var matrixChartType = {
@@ -10,7 +10,7 @@ var matrixChartType = {
10
10
  return { x: "categorical", y: "categorical" };
11
11
  },
12
12
  prepareData(data, options) {
13
- return chunkHOPFELRP_cjs.prepareNoAxes(data, options);
13
+ return chunkCDS2NXGT_cjs.prepareNoAxes(data, options);
14
14
  },
15
15
  render(ctx) {
16
16
  const { data, area, theme, options } = ctx;
@@ -43,7 +43,7 @@ var matrixChartType = {
43
43
  const gridY = area.y + labelPadTop;
44
44
  for (let c = 0; c < cols; c++) {
45
45
  const cx = gridX + c * (cellW + gap) + cellW / 2;
46
- nodes.push(chunk3TLJCGGQ_cjs.text(cx, gridY - 8, String(data.labels[c] ?? ""), {
46
+ nodes.push(chunkUMIJYYF3_cjs.text(cx, gridY - 8, String(data.labels[c] ?? ""), {
47
47
  class: "chartts-matrix-col-label",
48
48
  fill: theme.textMuted,
49
49
  textAnchor: "middle",
@@ -55,7 +55,7 @@ var matrixChartType = {
55
55
  for (let r = 0; r < rows; r++) {
56
56
  const series = data.series[r];
57
57
  const ry = gridY + r * (cellH + gap);
58
- nodes.push(chunk3TLJCGGQ_cjs.text(gridX - 6, ry + cellH / 2, series.name, {
58
+ nodes.push(chunkUMIJYYF3_cjs.text(gridX - 6, ry + cellH / 2, series.name, {
59
59
  class: "chartts-matrix-row-label",
60
60
  fill: theme.textMuted,
61
61
  textAnchor: "end",
@@ -69,7 +69,7 @@ var matrixChartType = {
69
69
  const cx = gridX + c * (cellW + gap);
70
70
  const color = getCellColor(val, allMin, allMax, valRange, colorScale, options.colors);
71
71
  const textColor = getContrastColor(val, allMin, allMax, valRange, colorScale);
72
- rowNodes.push(chunk3TLJCGGQ_cjs.rect(cx, ry, cellW, cellH, {
72
+ rowNodes.push(chunkUMIJYYF3_cjs.rect(cx, ry, cellW, cellH, {
73
73
  class: "chartts-matrix-cell",
74
74
  fill: color,
75
75
  rx: cellRadius,
@@ -82,7 +82,7 @@ var matrixChartType = {
82
82
  }));
83
83
  if (showValues && cellW > 18 && cellH > 14) {
84
84
  const displayVal = Number.isInteger(val) ? String(val) : Math.abs(val) < 10 ? val.toFixed(2) : val.toFixed(1);
85
- rowNodes.push(chunk3TLJCGGQ_cjs.text(cx + cellW / 2, ry + cellH / 2, displayVal, {
85
+ rowNodes.push(chunkUMIJYYF3_cjs.text(cx + cellW / 2, ry + cellH / 2, displayVal, {
86
86
  class: "chartts-matrix-value",
87
87
  fill: textColor,
88
88
  textAnchor: "middle",
@@ -94,7 +94,7 @@ var matrixChartType = {
94
94
  }));
95
95
  }
96
96
  }
97
- nodes.push(chunk3TLJCGGQ_cjs.group(rowNodes, {
97
+ nodes.push(chunkUMIJYYF3_cjs.group(rowNodes, {
98
98
  class: `chartts-series chartts-series-${r}`,
99
99
  "data-series-name": series.name
100
100
  }));
@@ -118,7 +118,7 @@ var matrixChartType = {
118
118
  const col = Math.floor((mx - gridX) / (cellW + gap));
119
119
  const row = Math.floor((my - gridY) / (cellH + gap));
120
120
  if (row >= 0 && row < rows && col >= 0 && col < cols) {
121
- return { seriesIndex: row, pointIndex: col, distance: 0 };
121
+ return { seriesIndex: row, pointIndex: col, distance: 0, x: gridX + col * (cellW + gap) + cellW / 2, y: gridY + row * (cellH + gap) + cellH / 2 };
122
122
  }
123
123
  return null;
124
124
  }
@@ -155,5 +155,5 @@ function interpolateOpacity(baseColor, opacity) {
155
155
  }
156
156
 
157
157
  exports.matrixChartType = matrixChartType;
158
- //# sourceMappingURL=chunk-DAH76GIX.cjs.map
159
- //# sourceMappingURL=chunk-DAH76GIX.cjs.map
158
+ //# sourceMappingURL=chunk-6E6ZDWZD.cjs.map
159
+ //# sourceMappingURL=chunk-6E6ZDWZD.cjs.map