@chartts/core 0.1.1 → 0.1.2

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 (286) hide show
  1. package/README.md +61 -5
  2. package/dist/area.cjs +10 -10
  3. package/dist/area.js +5 -5
  4. package/dist/bar.cjs +9 -9
  5. package/dist/bar.js +4 -4
  6. package/dist/baseline.cjs +9 -9
  7. package/dist/baseline.js +4 -4
  8. package/dist/boxplot.cjs +9 -9
  9. package/dist/boxplot.js +4 -4
  10. package/dist/bubble.cjs +9 -9
  11. package/dist/bubble.js +4 -4
  12. package/dist/bullet.cjs +10 -10
  13. package/dist/bullet.js +5 -5
  14. package/dist/calendar.cjs +10 -10
  15. package/dist/calendar.js +5 -5
  16. package/dist/candlestick.cjs +9 -9
  17. package/dist/candlestick.js +4 -4
  18. package/dist/chord.cjs +10 -10
  19. package/dist/chord.js +5 -5
  20. package/dist/{chunk-E2S7RAT2.js → chunk-27E6G2GT.js} +3 -3
  21. package/dist/{chunk-E2S7RAT2.js.map → chunk-27E6G2GT.js.map} +1 -1
  22. package/dist/{chunk-ROYZ7W4M.cjs → chunk-2KMMVJEE.cjs} +6 -6
  23. package/dist/{chunk-ROYZ7W4M.cjs.map → chunk-2KMMVJEE.cjs.map} +1 -1
  24. package/dist/{chunk-QZ4ZYTP6.js → chunk-2L46SAT7.js} +4 -4
  25. package/dist/{chunk-QZ4ZYTP6.js.map → chunk-2L46SAT7.js.map} +1 -1
  26. package/dist/{chunk-MVWERW4G.cjs → chunk-2PRCN5OJ.cjs} +6 -6
  27. package/dist/{chunk-MVWERW4G.cjs.map → chunk-2PRCN5OJ.cjs.map} +1 -1
  28. package/dist/{chunk-B54L2CPW.cjs → chunk-3N447NTJ.cjs} +13 -13
  29. package/dist/{chunk-B54L2CPW.cjs.map → chunk-3N447NTJ.cjs.map} +1 -1
  30. package/dist/{chunk-7YV56WPE.js → chunk-3NWZJCWL.js} +4 -4
  31. package/dist/{chunk-7YV56WPE.js.map → chunk-3NWZJCWL.js.map} +1 -1
  32. package/dist/{chunk-O5KGKQSU.js → chunk-3QXN7JBV.js} +4 -4
  33. package/dist/{chunk-O5KGKQSU.js.map → chunk-3QXN7JBV.js.map} +1 -1
  34. package/dist/{chunk-XHQWWR5M.cjs → chunk-3TLJCGGQ.cjs} +71 -37
  35. package/dist/chunk-3TLJCGGQ.cjs.map +1 -0
  36. package/dist/{chunk-BXX2EPFE.cjs → chunk-3YFDZGHO.cjs} +12 -12
  37. package/dist/{chunk-BXX2EPFE.cjs.map → chunk-3YFDZGHO.cjs.map} +1 -1
  38. package/dist/{chunk-LEJGLR2P.cjs → chunk-43WDYYVH.cjs} +8 -8
  39. package/dist/{chunk-LEJGLR2P.cjs.map → chunk-43WDYYVH.cjs.map} +1 -1
  40. package/dist/{chunk-SUNC3CPV.js → chunk-4ABM7UYD.js} +3 -3
  41. package/dist/{chunk-SUNC3CPV.js.map → chunk-4ABM7UYD.js.map} +1 -1
  42. package/dist/{chunk-Z6E3XVP2.cjs → chunk-5LQ26P4J.cjs} +10 -10
  43. package/dist/{chunk-Z6E3XVP2.cjs.map → chunk-5LQ26P4J.cjs.map} +1 -1
  44. package/dist/{chunk-SJS4ISBA.js → chunk-5M624BRW.js} +3 -3
  45. package/dist/{chunk-SJS4ISBA.js.map → chunk-5M624BRW.js.map} +1 -1
  46. package/dist/{chunk-4VG47RLS.js → chunk-6WJJ26J5.js} +4 -4
  47. package/dist/{chunk-4VG47RLS.js.map → chunk-6WJJ26J5.js.map} +1 -1
  48. package/dist/{chunk-HOOOCSU4.js → chunk-7HOU6XMW.js} +4 -4
  49. package/dist/{chunk-HOOOCSU4.js.map → chunk-7HOU6XMW.js.map} +1 -1
  50. package/dist/{chunk-M4AQD6WX.cjs → chunk-7JN6GXML.cjs} +10 -10
  51. package/dist/{chunk-M4AQD6WX.cjs.map → chunk-7JN6GXML.cjs.map} +1 -1
  52. package/dist/{chunk-LUTU4WW3.js → chunk-7MXBXWVD.js} +4 -4
  53. package/dist/{chunk-LUTU4WW3.js.map → chunk-7MXBXWVD.js.map} +1 -1
  54. package/dist/{chunk-22LR6CFM.js → chunk-AA45U5KV.js} +4 -4
  55. package/dist/{chunk-22LR6CFM.js.map → chunk-AA45U5KV.js.map} +1 -1
  56. package/dist/{chunk-GNRRK7TZ.cjs → chunk-AAKS22M3.cjs} +11 -11
  57. package/dist/{chunk-GNRRK7TZ.cjs.map → chunk-AAKS22M3.cjs.map} +1 -1
  58. package/dist/{chunk-J6NPRKT4.cjs → chunk-ALRCYQQX.cjs} +6 -6
  59. package/dist/{chunk-J6NPRKT4.cjs.map → chunk-ALRCYQQX.cjs.map} +1 -1
  60. package/dist/{chunk-KVI6DN3R.js → chunk-ARQLGTTV.js} +4 -4
  61. package/dist/{chunk-KVI6DN3R.js.map → chunk-ARQLGTTV.js.map} +1 -1
  62. package/dist/{chunk-H4RNJ7FK.cjs → chunk-B7IV2PB3.cjs} +8 -8
  63. package/dist/{chunk-H4RNJ7FK.cjs.map → chunk-B7IV2PB3.cjs.map} +1 -1
  64. package/dist/{chunk-CMEXNS5V.js → chunk-BMEMMYVF.js} +4 -4
  65. package/dist/{chunk-CMEXNS5V.js.map → chunk-BMEMMYVF.js.map} +1 -1
  66. package/dist/{chunk-3BRQGYDX.js → chunk-BMTVFAX2.js} +71 -37
  67. package/dist/chunk-BMTVFAX2.js.map +1 -0
  68. package/dist/{chunk-BR3KTAGW.js → chunk-CCHMQZIB.js} +4 -4
  69. package/dist/{chunk-BR3KTAGW.js.map → chunk-CCHMQZIB.js.map} +1 -1
  70. package/dist/{chunk-NQSC7CKN.js → chunk-CHERQT4B.js} +3 -3
  71. package/dist/{chunk-NQSC7CKN.js.map → chunk-CHERQT4B.js.map} +1 -1
  72. package/dist/{chunk-KOHWMGRF.js → chunk-CJEMSKW3.js} +7 -7
  73. package/dist/{chunk-KOHWMGRF.js.map → chunk-CJEMSKW3.js.map} +1 -1
  74. package/dist/{chunk-3TTTELGB.cjs → chunk-COPERSVL.cjs} +15 -15
  75. package/dist/{chunk-3TTTELGB.cjs.map → chunk-COPERSVL.cjs.map} +1 -1
  76. package/dist/{chunk-PLGZ4REQ.cjs → chunk-D2IP3MWJ.cjs} +12 -12
  77. package/dist/{chunk-PLGZ4REQ.cjs.map → chunk-D2IP3MWJ.cjs.map} +1 -1
  78. package/dist/{chunk-M4UST3UU.cjs → chunk-DAH76GIX.cjs} +10 -10
  79. package/dist/{chunk-M4UST3UU.cjs.map → chunk-DAH76GIX.cjs.map} +1 -1
  80. package/dist/{chunk-TOS2RYHQ.js → chunk-DKVRRL3F.js} +4 -4
  81. package/dist/{chunk-TOS2RYHQ.js.map → chunk-DKVRRL3F.js.map} +1 -1
  82. package/dist/{chunk-SKVCPG5R.cjs → chunk-DZHP4UUE.cjs} +11 -11
  83. package/dist/{chunk-SKVCPG5R.cjs.map → chunk-DZHP4UUE.cjs.map} +1 -1
  84. package/dist/{chunk-NMLDPXOL.js → chunk-DZKYVTV3.js} +4 -4
  85. package/dist/{chunk-NMLDPXOL.js.map → chunk-DZKYVTV3.js.map} +1 -1
  86. package/dist/{chunk-66HSJRRH.js → chunk-DZW35WR2.js} +4 -4
  87. package/dist/{chunk-66HSJRRH.js.map → chunk-DZW35WR2.js.map} +1 -1
  88. package/dist/{chunk-FFJ6BVEY.cjs → chunk-EAKXLFOR.cjs} +9 -9
  89. package/dist/{chunk-FFJ6BVEY.cjs.map → chunk-EAKXLFOR.cjs.map} +1 -1
  90. package/dist/{chunk-QHJHYV3H.cjs → chunk-EFRBTSUO.cjs} +4 -4
  91. package/dist/{chunk-QHJHYV3H.cjs.map → chunk-EFRBTSUO.cjs.map} +1 -1
  92. package/dist/{chunk-QIJZZOX7.js → chunk-EYN74SQ5.js} +4 -4
  93. package/dist/{chunk-QIJZZOX7.js.map → chunk-EYN74SQ5.js.map} +1 -1
  94. package/dist/{chunk-Y54XVNXB.cjs → chunk-FEQKBVCZ.cjs} +13 -13
  95. package/dist/{chunk-Y54XVNXB.cjs.map → chunk-FEQKBVCZ.cjs.map} +1 -1
  96. package/dist/{chunk-UQBDGCS6.cjs → chunk-FIAKZSRR.cjs} +7 -7
  97. package/dist/{chunk-UQBDGCS6.cjs.map → chunk-FIAKZSRR.cjs.map} +1 -1
  98. package/dist/{chunk-HB4EGHJ7.cjs → chunk-FKAA5FNG.cjs} +9 -9
  99. package/dist/{chunk-HB4EGHJ7.cjs.map → chunk-FKAA5FNG.cjs.map} +1 -1
  100. package/dist/{chunk-NYVFC2SF.js → chunk-FKVYS4RB.js} +3 -3
  101. package/dist/{chunk-NYVFC2SF.js.map → chunk-FKVYS4RB.js.map} +1 -1
  102. package/dist/{chunk-ZDZQG3GH.cjs → chunk-FQG4DRJS.cjs} +13 -13
  103. package/dist/chunk-FQG4DRJS.cjs.map +1 -0
  104. package/dist/{chunk-GM3ZO5WV.js → chunk-FSKUEB7P.js} +3 -3
  105. package/dist/{chunk-GM3ZO5WV.js.map → chunk-FSKUEB7P.js.map} +1 -1
  106. package/dist/{chunk-NONU7KUN.cjs → chunk-FTKL3UAN.cjs} +6 -6
  107. package/dist/{chunk-NONU7KUN.cjs.map → chunk-FTKL3UAN.cjs.map} +1 -1
  108. package/dist/{chunk-ZL25X5WW.js → chunk-GI7PBJSK.js} +3 -3
  109. package/dist/{chunk-ZL25X5WW.js.map → chunk-GI7PBJSK.js.map} +1 -1
  110. package/dist/{chunk-NFD6VAVM.js → chunk-GL3M7MAM.js} +3 -3
  111. package/dist/{chunk-NFD6VAVM.js.map → chunk-GL3M7MAM.js.map} +1 -1
  112. package/dist/{chunk-3XVGEBR4.js → chunk-GMLJDDHZ.js} +3 -3
  113. package/dist/{chunk-3XVGEBR4.js.map → chunk-GMLJDDHZ.js.map} +1 -1
  114. package/dist/{chunk-N6IVODRJ.js → chunk-GQR7IHER.js} +4 -4
  115. package/dist/{chunk-N6IVODRJ.js.map → chunk-GQR7IHER.js.map} +1 -1
  116. package/dist/{chunk-MYPCA25Y.cjs → chunk-GUVPVNPD.cjs} +10 -10
  117. package/dist/{chunk-MYPCA25Y.cjs.map → chunk-GUVPVNPD.cjs.map} +1 -1
  118. package/dist/{chunk-5QOQR5FE.cjs → chunk-HOPFELRP.cjs} +4 -4
  119. package/dist/{chunk-5QOQR5FE.cjs.map → chunk-HOPFELRP.cjs.map} +1 -1
  120. package/dist/{chunk-FRWC6GUR.cjs → chunk-IAE4VRB7.cjs} +9 -9
  121. package/dist/{chunk-FRWC6GUR.cjs.map → chunk-IAE4VRB7.cjs.map} +1 -1
  122. package/dist/{chunk-BYXRFTEI.cjs → chunk-ID7GYRYL.cjs} +10 -10
  123. package/dist/{chunk-BYXRFTEI.cjs.map → chunk-ID7GYRYL.cjs.map} +1 -1
  124. package/dist/{chunk-QLRK46YY.cjs → chunk-IKUA7O73.cjs} +7 -7
  125. package/dist/{chunk-QLRK46YY.cjs.map → chunk-IKUA7O73.cjs.map} +1 -1
  126. package/dist/{chunk-HDWWUEPD.js → chunk-IUYPKYOU.js} +4 -4
  127. package/dist/{chunk-HDWWUEPD.js.map → chunk-IUYPKYOU.js.map} +1 -1
  128. package/dist/{chunk-BC6KW2OG.js → chunk-IXFSJBJS.js} +3 -3
  129. package/dist/{chunk-BC6KW2OG.js.map → chunk-IXFSJBJS.js.map} +1 -1
  130. package/dist/{chunk-X2JNB5UN.js → chunk-JT6H7G52.js} +4 -4
  131. package/dist/{chunk-X2JNB5UN.js.map → chunk-JT6H7G52.js.map} +1 -1
  132. package/dist/{chunk-TW6KPQIS.js → chunk-K2EZ4SS4.js} +3 -3
  133. package/dist/{chunk-TW6KPQIS.js.map → chunk-K2EZ4SS4.js.map} +1 -1
  134. package/dist/{chunk-KE7ILTM4.cjs → chunk-K7UR7GYC.cjs} +11 -11
  135. package/dist/{chunk-KE7ILTM4.cjs.map → chunk-K7UR7GYC.cjs.map} +1 -1
  136. package/dist/{chunk-TTOX27BZ.cjs → chunk-KEMT7F5H.cjs} +7 -7
  137. package/dist/{chunk-TTOX27BZ.cjs.map → chunk-KEMT7F5H.cjs.map} +1 -1
  138. package/dist/{chunk-FKYNRMPX.js → chunk-KHQRHTTN.js} +4 -4
  139. package/dist/{chunk-FKYNRMPX.js.map → chunk-KHQRHTTN.js.map} +1 -1
  140. package/dist/{chunk-ZDYCIP6N.cjs → chunk-KUFDELQM.cjs} +9 -9
  141. package/dist/{chunk-ZDYCIP6N.cjs.map → chunk-KUFDELQM.cjs.map} +1 -1
  142. package/dist/{chunk-LB4MV5CG.js → chunk-L37ZPX6D.js} +3 -3
  143. package/dist/{chunk-LB4MV5CG.js.map → chunk-L37ZPX6D.js.map} +1 -1
  144. package/dist/{chunk-QAYX6XN3.js → chunk-LCEMO7NI.js} +3 -3
  145. package/dist/{chunk-QAYX6XN3.js.map → chunk-LCEMO7NI.js.map} +1 -1
  146. package/dist/{chunk-L54BZYAI.cjs → chunk-M6JYSINX.cjs} +6 -6
  147. package/dist/{chunk-L54BZYAI.cjs.map → chunk-M6JYSINX.cjs.map} +1 -1
  148. package/dist/{chunk-VPI7UGB3.cjs → chunk-MGYBMQAX.cjs} +8 -8
  149. package/dist/{chunk-VPI7UGB3.cjs.map → chunk-MGYBMQAX.cjs.map} +1 -1
  150. package/dist/{chunk-6KNBJ4CE.js → chunk-MQBKLKYF.js} +4 -4
  151. package/dist/{chunk-6KNBJ4CE.js.map → chunk-MQBKLKYF.js.map} +1 -1
  152. package/dist/{chunk-BRSHEDTZ.js → chunk-MVJKRPX7.js} +3 -3
  153. package/dist/{chunk-BRSHEDTZ.js.map → chunk-MVJKRPX7.js.map} +1 -1
  154. package/dist/{chunk-Q6U5D2ZB.cjs → chunk-MZCKMTQE.cjs} +9 -9
  155. package/dist/{chunk-Q6U5D2ZB.cjs.map → chunk-MZCKMTQE.cjs.map} +1 -1
  156. package/dist/{chunk-BEYG2HQ4.cjs → chunk-MZQY2FTP.cjs} +12 -12
  157. package/dist/{chunk-BEYG2HQ4.cjs.map → chunk-MZQY2FTP.cjs.map} +1 -1
  158. package/dist/{chunk-ETPZGEL7.cjs → chunk-N7NZQVIV.cjs} +6 -6
  159. package/dist/{chunk-ETPZGEL7.cjs.map → chunk-N7NZQVIV.cjs.map} +1 -1
  160. package/dist/{chunk-H2AE7JMU.js → chunk-NML7F34A.js} +3 -3
  161. package/dist/{chunk-H2AE7JMU.js.map → chunk-NML7F34A.js.map} +1 -1
  162. package/dist/{chunk-DNQ6N3VG.js → chunk-NQGZMWNT.js} +4 -4
  163. package/dist/{chunk-DNQ6N3VG.js.map → chunk-NQGZMWNT.js.map} +1 -1
  164. package/dist/{chunk-MLX3EO2C.js → chunk-NZWFBAFQ.js} +3 -3
  165. package/dist/{chunk-MLX3EO2C.js.map → chunk-NZWFBAFQ.js.map} +1 -1
  166. package/dist/{chunk-XBIM73HV.cjs → chunk-PCTMS2PX.cjs} +7 -7
  167. package/dist/{chunk-XBIM73HV.cjs.map → chunk-PCTMS2PX.cjs.map} +1 -1
  168. package/dist/{chunk-D2SV6YT3.js → chunk-QCR6L55R.js} +4 -4
  169. package/dist/{chunk-D2SV6YT3.js.map → chunk-QCR6L55R.js.map} +1 -1
  170. package/dist/{chunk-SZVK6RRQ.js → chunk-QRTYX5KO.js} +4 -4
  171. package/dist/{chunk-SZVK6RRQ.js.map → chunk-QRTYX5KO.js.map} +1 -1
  172. package/dist/{chunk-FUZFNUCJ.js → chunk-QXQSJ3FZ.js} +3 -3
  173. package/dist/{chunk-FUZFNUCJ.js.map → chunk-QXQSJ3FZ.js.map} +1 -1
  174. package/dist/{chunk-7SEHTEMR.js → chunk-RLH3PS3Y.js} +3 -3
  175. package/dist/{chunk-7SEHTEMR.js.map → chunk-RLH3PS3Y.js.map} +1 -1
  176. package/dist/{chunk-Q2BDB5ZA.cjs → chunk-S64PTNT7.cjs} +8 -8
  177. package/dist/{chunk-Q2BDB5ZA.cjs.map → chunk-S64PTNT7.cjs.map} +1 -1
  178. package/dist/{chunk-6LKN3HRX.js → chunk-S6NGWPXC.js} +3 -3
  179. package/dist/{chunk-6LKN3HRX.js.map → chunk-S6NGWPXC.js.map} +1 -1
  180. package/dist/{chunk-4YJPBUX2.cjs → chunk-SC5BGA2N.cjs} +7 -7
  181. package/dist/{chunk-4YJPBUX2.cjs.map → chunk-SC5BGA2N.cjs.map} +1 -1
  182. package/dist/{chunk-KSRROKYC.cjs → chunk-SKREYNRK.cjs} +11 -11
  183. package/dist/{chunk-KSRROKYC.cjs.map → chunk-SKREYNRK.cjs.map} +1 -1
  184. package/dist/{chunk-2TWYS3BT.cjs → chunk-SLJNRP7O.cjs} +14 -14
  185. package/dist/{chunk-2TWYS3BT.cjs.map → chunk-SLJNRP7O.cjs.map} +1 -1
  186. package/dist/{chunk-Y2JZHX3P.cjs → chunk-T6LXFMBR.cjs} +8 -8
  187. package/dist/{chunk-Y2JZHX3P.cjs.map → chunk-T6LXFMBR.cjs.map} +1 -1
  188. package/dist/{chunk-RCVRZCCC.cjs → chunk-TIHVTKXS.cjs} +9 -9
  189. package/dist/{chunk-RCVRZCCC.cjs.map → chunk-TIHVTKXS.cjs.map} +1 -1
  190. package/dist/{chunk-DL7P72FA.cjs → chunk-TVPS2NJH.cjs} +10 -10
  191. package/dist/{chunk-DL7P72FA.cjs.map → chunk-TVPS2NJH.cjs.map} +1 -1
  192. package/dist/{chunk-SQJAKZ4W.js → chunk-U7GBOQXX.js} +4 -4
  193. package/dist/{chunk-SQJAKZ4W.js.map → chunk-U7GBOQXX.js.map} +1 -1
  194. package/dist/{chunk-6N66T7VQ.js → chunk-VGGKMTO6.js} +3 -3
  195. package/dist/{chunk-6N66T7VQ.js.map → chunk-VGGKMTO6.js.map} +1 -1
  196. package/dist/{chunk-7CGXK7KT.js → chunk-VJQCHBS6.js} +3 -3
  197. package/dist/{chunk-7CGXK7KT.js.map → chunk-VJQCHBS6.js.map} +1 -1
  198. package/dist/{chunk-4HK4RM3X.cjs → chunk-VK72MICB.cjs} +7 -7
  199. package/dist/{chunk-4HK4RM3X.cjs.map → chunk-VK72MICB.cjs.map} +1 -1
  200. package/dist/{chunk-EGQ4JCFU.cjs → chunk-WS2AL7GY.cjs} +7 -7
  201. package/dist/{chunk-EGQ4JCFU.cjs.map → chunk-WS2AL7GY.cjs.map} +1 -1
  202. package/dist/{chunk-Y4P4VY7A.cjs → chunk-XKDBNAHH.cjs} +10 -10
  203. package/dist/{chunk-Y4P4VY7A.cjs.map → chunk-XKDBNAHH.cjs.map} +1 -1
  204. package/dist/{chunk-UN7K3YQG.cjs → chunk-Y4HJCMB4.cjs} +6 -6
  205. package/dist/{chunk-UN7K3YQG.cjs.map → chunk-Y4HJCMB4.cjs.map} +1 -1
  206. package/dist/{chunk-SWYCVF46.js → chunk-YMJQUKKX.js} +8 -8
  207. package/dist/chunk-YMJQUKKX.js.map +1 -0
  208. package/dist/combo.cjs +9 -9
  209. package/dist/combo.js +4 -4
  210. package/dist/custom.cjs +10 -10
  211. package/dist/custom.js +5 -5
  212. package/dist/donut.cjs +10 -10
  213. package/dist/donut.js +5 -5
  214. package/dist/dumbbell.cjs +10 -10
  215. package/dist/dumbbell.js +5 -5
  216. package/dist/funnel.cjs +10 -10
  217. package/dist/funnel.js +5 -5
  218. package/dist/gauge.cjs +10 -10
  219. package/dist/gauge.js +5 -5
  220. package/dist/geo.cjs +12 -12
  221. package/dist/geo.js +5 -5
  222. package/dist/graph.cjs +10 -10
  223. package/dist/graph.js +5 -5
  224. package/dist/heatmap.cjs +10 -10
  225. package/dist/heatmap.js +5 -5
  226. package/dist/histogram.cjs +9 -9
  227. package/dist/histogram.js +4 -4
  228. package/dist/horizontal-bar.cjs +9 -9
  229. package/dist/horizontal-bar.js +4 -4
  230. package/dist/index.cjs +179 -179
  231. package/dist/index.js +91 -91
  232. package/dist/kagi.cjs +10 -10
  233. package/dist/kagi.js +5 -5
  234. package/dist/line.cjs +9 -9
  235. package/dist/line.js +4 -4
  236. package/dist/lines.cjs +10 -10
  237. package/dist/lines.js +5 -5
  238. package/dist/lollipop.cjs +9 -9
  239. package/dist/lollipop.js +4 -4
  240. package/dist/matrix.cjs +10 -10
  241. package/dist/matrix.js +5 -5
  242. package/dist/ohlc.cjs +9 -9
  243. package/dist/ohlc.js +4 -4
  244. package/dist/parallel.cjs +10 -10
  245. package/dist/parallel.js +5 -5
  246. package/dist/pictorialbar.cjs +10 -10
  247. package/dist/pictorialbar.js +5 -5
  248. package/dist/pie.cjs +10 -10
  249. package/dist/pie.js +5 -5
  250. package/dist/polar.cjs +10 -10
  251. package/dist/polar.js +5 -5
  252. package/dist/radar.cjs +10 -10
  253. package/dist/radar.js +5 -5
  254. package/dist/radialbar.cjs +10 -10
  255. package/dist/radialbar.js +5 -5
  256. package/dist/range.cjs +9 -9
  257. package/dist/range.js +4 -4
  258. package/dist/renko.cjs +10 -10
  259. package/dist/renko.js +5 -5
  260. package/dist/sankey.cjs +10 -10
  261. package/dist/sankey.js +5 -5
  262. package/dist/scatter.cjs +9 -9
  263. package/dist/scatter.js +4 -4
  264. package/dist/sparkline.cjs +9 -9
  265. package/dist/sparkline.js +4 -4
  266. package/dist/stacked-bar.cjs +9 -9
  267. package/dist/stacked-bar.js +4 -4
  268. package/dist/step.cjs +10 -10
  269. package/dist/step.js +5 -5
  270. package/dist/sunburst.cjs +10 -10
  271. package/dist/sunburst.js +5 -5
  272. package/dist/themeriver.cjs +10 -10
  273. package/dist/themeriver.js +5 -5
  274. package/dist/tree.cjs +10 -10
  275. package/dist/tree.js +5 -5
  276. package/dist/treemap.cjs +10 -10
  277. package/dist/treemap.js +5 -5
  278. package/dist/volume.cjs +9 -9
  279. package/dist/volume.js +4 -4
  280. package/dist/waterfall.cjs +9 -9
  281. package/dist/waterfall.js +4 -4
  282. package/package.json +1 -1
  283. package/dist/chunk-3BRQGYDX.js.map +0 -1
  284. package/dist/chunk-SWYCVF46.js.map +0 -1
  285. package/dist/chunk-XHQWWR5M.cjs.map +0 -1
  286. package/dist/chunk-ZDZQG3GH.cjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/pictorialbar/pictorialbar-type.ts"],"names":["prepareNoAxes","path","text","group"],"mappings":"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","file":"chunk-FFJ6BVEY.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'\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) }\n }\n }\n\n return null\n },\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/pictorialbar/pictorialbar-type.ts"],"names":["prepareNoAxes","path","text","group"],"mappings":"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","file":"chunk-EAKXLFOR.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'\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) }\n }\n }\n\n return null\n },\n}\n"]}
@@ -1,15 +1,15 @@
1
1
  'use strict';
2
2
 
3
- var chunkXHQWWR5M_cjs = require('./chunk-XHQWWR5M.cjs');
3
+ var chunk3TLJCGGQ_cjs = require('./chunk-3TLJCGGQ.cjs');
4
4
 
5
5
  // src/api/factory.ts
6
6
  function createConvenience(chartType) {
7
7
  return function(target, config) {
8
8
  const { data, ...options } = config;
9
- return chunkXHQWWR5M_cjs.createChart(target, chartType, data, options);
9
+ return chunk3TLJCGGQ_cjs.createChart(target, chartType, data, options);
10
10
  };
11
11
  }
12
12
 
13
13
  exports.createConvenience = createConvenience;
14
- //# sourceMappingURL=chunk-QHJHYV3H.cjs.map
15
- //# sourceMappingURL=chunk-QHJHYV3H.cjs.map
14
+ //# sourceMappingURL=chunk-EFRBTSUO.cjs.map
15
+ //# sourceMappingURL=chunk-EFRBTSUO.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/api/factory.ts"],"names":["createChart"],"mappings":";;;;;AAQO,SAAS,kBAAkB,SAAA,EAA4B;AAC5D,EAAA,OAAO,SAAU,QAA8B,MAAA,EAAoC;AACjF,IAAA,MAAM,EAAE,IAAA,EAAM,GAAG,OAAA,EAAQ,GAAI,MAAA;AAC7B,IAAA,OAAOA,6BAAA,CAAY,MAAA,EAAQ,SAAA,EAAW,IAAA,EAAM,OAAO,CAAA;AAAA,EACrD,CAAA;AACF","file":"chunk-QHJHYV3H.cjs","sourcesContent":["import { createChart } from './create'\nimport type { ChartData, ChartOptions, ChartInstance, ChartTypePlugin } from '../types'\n\nexport interface ChartConfig extends ChartOptions {\n data: ChartData\n debug?: boolean\n}\n\nexport function createConvenience(chartType: ChartTypePlugin) {\n return function (target: string | HTMLElement, config: ChartConfig): ChartInstance {\n const { data, ...options } = config\n return createChart(target, chartType, data, options)\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/api/factory.ts"],"names":["createChart"],"mappings":";;;;;AAQO,SAAS,kBAAkB,SAAA,EAA4B;AAC5D,EAAA,OAAO,SAAU,QAA8B,MAAA,EAAoC;AACjF,IAAA,MAAM,EAAE,IAAA,EAAM,GAAG,OAAA,EAAQ,GAAI,MAAA;AAC7B,IAAA,OAAOA,6BAAA,CAAY,MAAA,EAAQ,SAAA,EAAW,IAAA,EAAM,OAAO,CAAA;AAAA,EACrD,CAAA;AACF","file":"chunk-EFRBTSUO.cjs","sourcesContent":["import { createChart } from './create'\nimport type { ChartData, ChartOptions, ChartInstance, ChartTypePlugin } from '../types'\n\nexport interface ChartConfig extends ChartOptions {\n data: ChartData\n debug?: boolean\n}\n\nexport function createConvenience(chartType: ChartTypePlugin) {\n return function (target: string | HTMLElement, config: ChartConfig): ChartInstance {\n const { data, ...options } = config\n return createChart(target, chartType, data, options)\n }\n}\n"]}
@@ -1,5 +1,5 @@
1
- import { prepareNoAxes } from './chunk-3XVGEBR4.js';
2
- import { PathBuilder, path, rect, text, group } from './chunk-3BRQGYDX.js';
1
+ import { prepareNoAxes } from './chunk-GMLJDDHZ.js';
2
+ import { PathBuilder, path, rect, text, group } from './chunk-BMTVFAX2.js';
3
3
 
4
4
  // src/charts/sankey/sankey-type.ts
5
5
  var sankeyChartType = {
@@ -245,5 +245,5 @@ function computeLinkPositions(nodes, links) {
245
245
  }
246
246
 
247
247
  export { sankeyChartType };
248
- //# sourceMappingURL=chunk-QIJZZOX7.js.map
249
- //# sourceMappingURL=chunk-QIJZZOX7.js.map
248
+ //# sourceMappingURL=chunk-EYN74SQ5.js.map
249
+ //# sourceMappingURL=chunk-EYN74SQ5.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/sankey/sankey-type.ts"],"names":[],"mappings":"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","file":"chunk-QIJZZOX7.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, rect, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Sankey / flow diagram.\n *\n * Data convention:\n * - labels: node names (unique). First N are source layer, rest are target layer.\n * - series[i]: a flow. series[i].name = \"Source → Target\", series[i].values = [flowValue]\n *\n * Alternative (simpler): encode flows as a flat list.\n * - labels: all unique node names\n * - series[0].values: flat list of flow values\n * - options.links: array of { source: number, target: number, value: number }\n *\n * This implementation auto-detects the format:\n * If series names contain \"→\" or \"->\", parse as source→target flows.\n * Otherwise treat as adjacency: series[i] = from node i, values[j] = flow to node j.\n */\n\ninterface SankeyNode {\n name: string\n index: number\n column: number\n y: number\n height: number\n totalIn: number\n totalOut: number\n}\n\ninterface SankeyLink {\n source: number\n target: number\n value: number\n sy: number // source y offset\n ty: number // target y offset\n width: number\n}\n\nexport const sankeyChartType: ChartTypePlugin = {\n type: 'sankey',\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 { sankeyNodes, sankeyLinks } = parseSankeyData(data, options)\n if (sankeyNodes.length === 0 || sankeyLinks.length === 0) return nodes\n\n // Layout\n const columns = layoutColumns(sankeyNodes, sankeyLinks, area)\n const nodeWidth = Math.min(20, area.width * 0.04)\n const nodePadding = 8\n\n // Position nodes within columns\n for (const col of columns) {\n const colNodes = sankeyNodes.filter(n => n.column === col)\n const totalHeight = colNodes.reduce((s, n) => s + n.height, 0)\n const gaps = Math.max(0, colNodes.length - 1) * nodePadding\n const scale = (area.height - gaps) / Math.max(totalHeight, 1)\n\n let y = area.y\n for (const node of colNodes) {\n node.height = node.height * scale\n node.y = y\n y += node.height + nodePadding\n }\n }\n\n // Compute link positions\n computeLinkPositions(sankeyNodes, sankeyLinks)\n\n // Render links (curved bands)\n for (let li = 0; li < sankeyLinks.length; li++) {\n const link = sankeyLinks[li]!\n const src = sankeyNodes[link.source]!\n const tgt = sankeyNodes[link.target]!\n const x0 = src.y !== undefined ? getNodeX(src, columns, area, nodeWidth) + nodeWidth : 0\n const x1 = tgt.y !== undefined ? getNodeX(tgt, columns, area, nodeWidth) : 0\n const y0 = src.y + link.sy\n const y1 = tgt.y + link.ty\n const w = link.width\n\n const pb = new PathBuilder()\n const cx = (x0 + x1) / 2\n pb.moveTo(x0, y0)\n pb.curveTo(cx, y0, cx, y1, x1, y1)\n pb.vTo(y1 + w)\n pb.curveTo(cx, y1 + w, cx, y0 + w, x0, y0 + w)\n pb.close()\n\n const color = options.colors[link.source % options.colors.length]!\n\n nodes.push(path(pb.build(), {\n class: 'chartts-sankey-link',\n fill: color,\n fillOpacity: 0.3,\n 'data-series': link.source,\n 'data-index': li,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${src.name} → ${tgt.name}: ${link.value}`,\n }))\n }\n\n // Render nodes (rectangles + labels)\n for (let ni = 0; ni < sankeyNodes.length; ni++) {\n const node = sankeyNodes[ni]!\n const x = getNodeX(node, columns, area, nodeWidth)\n const color = options.colors[ni % options.colors.length]!\n const nodeGroup: RenderNode[] = []\n\n nodeGroup.push(rect(x, node.y, nodeWidth, Math.max(node.height, 2), {\n rx: 3, ry: 3,\n class: 'chartts-sankey-node',\n fill: color,\n 'data-series': ni,\n 'data-index': 0,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${node.name}: ${Math.max(node.totalIn, node.totalOut)}`,\n }))\n\n // Label\n const isLeft = node.column < columns.length / 2\n const labelX = isLeft ? x + nodeWidth + 6 : x - 6\n const anchor = isLeft ? 'start' : 'end'\n\n nodeGroup.push(text(labelX, node.y + node.height / 2, node.name, {\n class: 'chartts-sankey-label',\n fill: theme.textColor,\n textAnchor: anchor as 'start' | 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n nodes.push(group(nodeGroup, {\n class: `chartts-series chartts-series-${ni}`,\n 'data-series-name': node.name,\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 { sankeyNodes, sankeyLinks } = parseSankeyData(data, options)\n if (sankeyNodes.length === 0) return null\n\n const columns = layoutColumns(sankeyNodes, sankeyLinks, area)\n const nodeWidth = Math.min(20, area.width * 0.04)\n const nodePadding = 8\n\n // Re-layout (same as render)\n for (const col of columns) {\n const colNodes = sankeyNodes.filter(n => n.column === col)\n const totalHeight = colNodes.reduce((s, n) => s + n.height, 0)\n const gaps = Math.max(0, colNodes.length - 1) * nodePadding\n const scale = (area.height - gaps) / Math.max(totalHeight, 1)\n let y = area.y\n for (const node of colNodes) {\n node.height = node.height * scale\n node.y = y\n y += node.height + nodePadding\n }\n }\n\n // Check node hits\n for (let ni = 0; ni < sankeyNodes.length; ni++) {\n const node = sankeyNodes[ni]!\n const x = getNodeX(node, columns, area, nodeWidth)\n if (mx >= x && mx <= x + nodeWidth && my >= node.y && my <= node.y + node.height) {\n return { seriesIndex: ni, pointIndex: 0, distance: 0 }\n }\n }\n\n return null\n },\n}\n\n// ---------------------------------------------------------------------------\n// Parsing helpers\n// ---------------------------------------------------------------------------\n\nfunction parseSankeyData(\n data: PreparedData,\n _options: ResolvedOptions,\n): { sankeyNodes: SankeyNode[]; sankeyLinks: SankeyLink[] } {\n const sankeyNodes: SankeyNode[] = []\n const sankeyLinks: SankeyLink[] = []\n const nodeMap = new Map<string, number>()\n\n function getOrCreateNode(name: string): number {\n if (nodeMap.has(name)) return nodeMap.get(name)!\n const idx = sankeyNodes.length\n nodeMap.set(name, idx)\n sankeyNodes.push({\n name,\n index: idx,\n column: -1,\n y: 0,\n height: 0,\n totalIn: 0,\n totalOut: 0,\n })\n return idx\n }\n\n // Check if series names contain arrow notation\n const hasArrows = data.series.some(s => s.name.includes('→') || s.name.includes('->'))\n\n if (hasArrows) {\n // Format: each series is a flow \"Source → Target\"\n for (const series of data.series) {\n const parts = series.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length < 2) continue\n const srcName = parts[0]!.trim()\n const tgtName = parts[1]!.trim()\n const value = series.values[0] ?? 0\n if (value <= 0) continue\n\n const src = getOrCreateNode(srcName)\n const tgt = getOrCreateNode(tgtName)\n sankeyLinks.push({ source: src, target: tgt, value, sy: 0, ty: 0, width: 0 })\n sankeyNodes[src]!.totalOut += value\n sankeyNodes[tgt]!.totalIn += value\n }\n } else {\n // Format: adjacency matrix. labels = node names, series[i].values[j] = flow i→j\n for (let i = 0; i < data.labels.length; i++) {\n getOrCreateNode(String(data.labels[i]))\n }\n for (let si = 0; si < data.series.length; si++) {\n for (let j = 0; j < data.series[si]!.values.length; j++) {\n const value = data.series[si]!.values[j]!\n if (value <= 0 || si === j) continue\n if (si >= sankeyNodes.length || j >= sankeyNodes.length) continue\n sankeyLinks.push({ source: si, target: j, value, sy: 0, ty: 0, width: 0 })\n sankeyNodes[si]!.totalOut += value\n sankeyNodes[j]!.totalIn += value\n }\n }\n }\n\n return { sankeyNodes, sankeyLinks }\n}\n\n// ---------------------------------------------------------------------------\n// Layout\n// ---------------------------------------------------------------------------\n\nfunction layoutColumns(\n nodes: SankeyNode[],\n links: SankeyLink[],\n _area: { width: number; height: number },\n): number[] {\n // Assign columns via topological ordering (longest path from source)\n const adj = new Map<number, number[]>()\n const inDegree = new Map<number, number>()\n\n for (const n of nodes) {\n adj.set(n.index, [])\n inDegree.set(n.index, 0)\n }\n for (const l of links) {\n adj.get(l.source)!.push(l.target)\n inDegree.set(l.target, (inDegree.get(l.target) ?? 0) + 1)\n }\n\n // BFS for column assignment\n const queue: number[] = []\n for (const n of nodes) {\n if ((inDegree.get(n.index) ?? 0) === 0) {\n n.column = 0\n queue.push(n.index)\n }\n }\n\n while (queue.length > 0) {\n const idx = queue.shift()!\n const node = nodes[idx]!\n for (const tgt of adj.get(idx)!) {\n const tgtNode = nodes[tgt]!\n tgtNode.column = Math.max(tgtNode.column, node.column + 1)\n // Only add to queue once all predecessors processed\n const allPredsDone = links\n .filter(l => l.target === tgt)\n .every(l => nodes[l.source]!.column >= 0)\n if (allPredsDone && !queue.includes(tgt)) {\n queue.push(tgt)\n }\n }\n }\n\n // Handle any unassigned nodes (cycles or disconnected)\n for (const n of nodes) {\n if (n.column < 0) n.column = 0\n }\n\n // Set initial heights proportional to flow\n for (const n of nodes) {\n n.height = Math.max(n.totalIn, n.totalOut, 1)\n }\n\n // Get unique columns sorted\n const cols = [...new Set(nodes.map(n => n.column))].sort((a, b) => a - b)\n return cols\n}\n\nfunction getNodeX(\n node: SankeyNode,\n columns: number[],\n area: { x: number; width: number },\n nodeWidth: number,\n): number {\n const maxCol = Math.max(...columns, 1)\n if (maxCol === 0) return area.x\n const usableWidth = area.width - nodeWidth\n return area.x + (node.column / maxCol) * usableWidth\n}\n\nfunction computeLinkPositions(nodes: SankeyNode[], links: SankeyLink[]): void {\n // Total flow for normalization\n const sourceOffsets = new Map<number, number>()\n const targetOffsets = new Map<number, number>()\n\n for (const n of nodes) {\n sourceOffsets.set(n.index, 0)\n targetOffsets.set(n.index, 0)\n }\n\n // Sort links by target position for visual clarity\n links.sort((a, b) => {\n const na = nodes[a.target]!\n const nb = nodes[b.target]!\n return na.y - nb.y || na.column - nb.column\n })\n\n for (const link of links) {\n const src = nodes[link.source]!\n const tgt = nodes[link.target]!\n\n const srcTotal = Math.max(src.totalOut, 1)\n const tgtTotal = Math.max(tgt.totalIn, 1)\n\n link.width = (link.value / srcTotal) * src.height\n const tgtWidth = (link.value / tgtTotal) * tgt.height\n\n link.sy = sourceOffsets.get(link.source)!\n link.ty = targetOffsets.get(link.target)!\n\n sourceOffsets.set(link.source, link.sy + link.width)\n targetOffsets.set(link.target, link.ty + tgtWidth)\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/sankey/sankey-type.ts"],"names":[],"mappings":"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","file":"chunk-EYN74SQ5.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, rect, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Sankey / flow diagram.\n *\n * Data convention:\n * - labels: node names (unique). First N are source layer, rest are target layer.\n * - series[i]: a flow. series[i].name = \"Source → Target\", series[i].values = [flowValue]\n *\n * Alternative (simpler): encode flows as a flat list.\n * - labels: all unique node names\n * - series[0].values: flat list of flow values\n * - options.links: array of { source: number, target: number, value: number }\n *\n * This implementation auto-detects the format:\n * If series names contain \"→\" or \"->\", parse as source→target flows.\n * Otherwise treat as adjacency: series[i] = from node i, values[j] = flow to node j.\n */\n\ninterface SankeyNode {\n name: string\n index: number\n column: number\n y: number\n height: number\n totalIn: number\n totalOut: number\n}\n\ninterface SankeyLink {\n source: number\n target: number\n value: number\n sy: number // source y offset\n ty: number // target y offset\n width: number\n}\n\nexport const sankeyChartType: ChartTypePlugin = {\n type: 'sankey',\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 { sankeyNodes, sankeyLinks } = parseSankeyData(data, options)\n if (sankeyNodes.length === 0 || sankeyLinks.length === 0) return nodes\n\n // Layout\n const columns = layoutColumns(sankeyNodes, sankeyLinks, area)\n const nodeWidth = Math.min(20, area.width * 0.04)\n const nodePadding = 8\n\n // Position nodes within columns\n for (const col of columns) {\n const colNodes = sankeyNodes.filter(n => n.column === col)\n const totalHeight = colNodes.reduce((s, n) => s + n.height, 0)\n const gaps = Math.max(0, colNodes.length - 1) * nodePadding\n const scale = (area.height - gaps) / Math.max(totalHeight, 1)\n\n let y = area.y\n for (const node of colNodes) {\n node.height = node.height * scale\n node.y = y\n y += node.height + nodePadding\n }\n }\n\n // Compute link positions\n computeLinkPositions(sankeyNodes, sankeyLinks)\n\n // Render links (curved bands)\n for (let li = 0; li < sankeyLinks.length; li++) {\n const link = sankeyLinks[li]!\n const src = sankeyNodes[link.source]!\n const tgt = sankeyNodes[link.target]!\n const x0 = src.y !== undefined ? getNodeX(src, columns, area, nodeWidth) + nodeWidth : 0\n const x1 = tgt.y !== undefined ? getNodeX(tgt, columns, area, nodeWidth) : 0\n const y0 = src.y + link.sy\n const y1 = tgt.y + link.ty\n const w = link.width\n\n const pb = new PathBuilder()\n const cx = (x0 + x1) / 2\n pb.moveTo(x0, y0)\n pb.curveTo(cx, y0, cx, y1, x1, y1)\n pb.vTo(y1 + w)\n pb.curveTo(cx, y1 + w, cx, y0 + w, x0, y0 + w)\n pb.close()\n\n const color = options.colors[link.source % options.colors.length]!\n\n nodes.push(path(pb.build(), {\n class: 'chartts-sankey-link',\n fill: color,\n fillOpacity: 0.3,\n 'data-series': link.source,\n 'data-index': li,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${src.name} → ${tgt.name}: ${link.value}`,\n }))\n }\n\n // Render nodes (rectangles + labels)\n for (let ni = 0; ni < sankeyNodes.length; ni++) {\n const node = sankeyNodes[ni]!\n const x = getNodeX(node, columns, area, nodeWidth)\n const color = options.colors[ni % options.colors.length]!\n const nodeGroup: RenderNode[] = []\n\n nodeGroup.push(rect(x, node.y, nodeWidth, Math.max(node.height, 2), {\n rx: 3, ry: 3,\n class: 'chartts-sankey-node',\n fill: color,\n 'data-series': ni,\n 'data-index': 0,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${node.name}: ${Math.max(node.totalIn, node.totalOut)}`,\n }))\n\n // Label\n const isLeft = node.column < columns.length / 2\n const labelX = isLeft ? x + nodeWidth + 6 : x - 6\n const anchor = isLeft ? 'start' : 'end'\n\n nodeGroup.push(text(labelX, node.y + node.height / 2, node.name, {\n class: 'chartts-sankey-label',\n fill: theme.textColor,\n textAnchor: anchor as 'start' | 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n nodes.push(group(nodeGroup, {\n class: `chartts-series chartts-series-${ni}`,\n 'data-series-name': node.name,\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 { sankeyNodes, sankeyLinks } = parseSankeyData(data, options)\n if (sankeyNodes.length === 0) return null\n\n const columns = layoutColumns(sankeyNodes, sankeyLinks, area)\n const nodeWidth = Math.min(20, area.width * 0.04)\n const nodePadding = 8\n\n // Re-layout (same as render)\n for (const col of columns) {\n const colNodes = sankeyNodes.filter(n => n.column === col)\n const totalHeight = colNodes.reduce((s, n) => s + n.height, 0)\n const gaps = Math.max(0, colNodes.length - 1) * nodePadding\n const scale = (area.height - gaps) / Math.max(totalHeight, 1)\n let y = area.y\n for (const node of colNodes) {\n node.height = node.height * scale\n node.y = y\n y += node.height + nodePadding\n }\n }\n\n // Check node hits\n for (let ni = 0; ni < sankeyNodes.length; ni++) {\n const node = sankeyNodes[ni]!\n const x = getNodeX(node, columns, area, nodeWidth)\n if (mx >= x && mx <= x + nodeWidth && my >= node.y && my <= node.y + node.height) {\n return { seriesIndex: ni, pointIndex: 0, distance: 0 }\n }\n }\n\n return null\n },\n}\n\n// ---------------------------------------------------------------------------\n// Parsing helpers\n// ---------------------------------------------------------------------------\n\nfunction parseSankeyData(\n data: PreparedData,\n _options: ResolvedOptions,\n): { sankeyNodes: SankeyNode[]; sankeyLinks: SankeyLink[] } {\n const sankeyNodes: SankeyNode[] = []\n const sankeyLinks: SankeyLink[] = []\n const nodeMap = new Map<string, number>()\n\n function getOrCreateNode(name: string): number {\n if (nodeMap.has(name)) return nodeMap.get(name)!\n const idx = sankeyNodes.length\n nodeMap.set(name, idx)\n sankeyNodes.push({\n name,\n index: idx,\n column: -1,\n y: 0,\n height: 0,\n totalIn: 0,\n totalOut: 0,\n })\n return idx\n }\n\n // Check if series names contain arrow notation\n const hasArrows = data.series.some(s => s.name.includes('→') || s.name.includes('->'))\n\n if (hasArrows) {\n // Format: each series is a flow \"Source → Target\"\n for (const series of data.series) {\n const parts = series.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length < 2) continue\n const srcName = parts[0]!.trim()\n const tgtName = parts[1]!.trim()\n const value = series.values[0] ?? 0\n if (value <= 0) continue\n\n const src = getOrCreateNode(srcName)\n const tgt = getOrCreateNode(tgtName)\n sankeyLinks.push({ source: src, target: tgt, value, sy: 0, ty: 0, width: 0 })\n sankeyNodes[src]!.totalOut += value\n sankeyNodes[tgt]!.totalIn += value\n }\n } else {\n // Format: adjacency matrix. labels = node names, series[i].values[j] = flow i→j\n for (let i = 0; i < data.labels.length; i++) {\n getOrCreateNode(String(data.labels[i]))\n }\n for (let si = 0; si < data.series.length; si++) {\n for (let j = 0; j < data.series[si]!.values.length; j++) {\n const value = data.series[si]!.values[j]!\n if (value <= 0 || si === j) continue\n if (si >= sankeyNodes.length || j >= sankeyNodes.length) continue\n sankeyLinks.push({ source: si, target: j, value, sy: 0, ty: 0, width: 0 })\n sankeyNodes[si]!.totalOut += value\n sankeyNodes[j]!.totalIn += value\n }\n }\n }\n\n return { sankeyNodes, sankeyLinks }\n}\n\n// ---------------------------------------------------------------------------\n// Layout\n// ---------------------------------------------------------------------------\n\nfunction layoutColumns(\n nodes: SankeyNode[],\n links: SankeyLink[],\n _area: { width: number; height: number },\n): number[] {\n // Assign columns via topological ordering (longest path from source)\n const adj = new Map<number, number[]>()\n const inDegree = new Map<number, number>()\n\n for (const n of nodes) {\n adj.set(n.index, [])\n inDegree.set(n.index, 0)\n }\n for (const l of links) {\n adj.get(l.source)!.push(l.target)\n inDegree.set(l.target, (inDegree.get(l.target) ?? 0) + 1)\n }\n\n // BFS for column assignment\n const queue: number[] = []\n for (const n of nodes) {\n if ((inDegree.get(n.index) ?? 0) === 0) {\n n.column = 0\n queue.push(n.index)\n }\n }\n\n while (queue.length > 0) {\n const idx = queue.shift()!\n const node = nodes[idx]!\n for (const tgt of adj.get(idx)!) {\n const tgtNode = nodes[tgt]!\n tgtNode.column = Math.max(tgtNode.column, node.column + 1)\n // Only add to queue once all predecessors processed\n const allPredsDone = links\n .filter(l => l.target === tgt)\n .every(l => nodes[l.source]!.column >= 0)\n if (allPredsDone && !queue.includes(tgt)) {\n queue.push(tgt)\n }\n }\n }\n\n // Handle any unassigned nodes (cycles or disconnected)\n for (const n of nodes) {\n if (n.column < 0) n.column = 0\n }\n\n // Set initial heights proportional to flow\n for (const n of nodes) {\n n.height = Math.max(n.totalIn, n.totalOut, 1)\n }\n\n // Get unique columns sorted\n const cols = [...new Set(nodes.map(n => n.column))].sort((a, b) => a - b)\n return cols\n}\n\nfunction getNodeX(\n node: SankeyNode,\n columns: number[],\n area: { x: number; width: number },\n nodeWidth: number,\n): number {\n const maxCol = Math.max(...columns, 1)\n if (maxCol === 0) return area.x\n const usableWidth = area.width - nodeWidth\n return area.x + (node.column / maxCol) * usableWidth\n}\n\nfunction computeLinkPositions(nodes: SankeyNode[], links: SankeyLink[]): void {\n // Total flow for normalization\n const sourceOffsets = new Map<number, number>()\n const targetOffsets = new Map<number, number>()\n\n for (const n of nodes) {\n sourceOffsets.set(n.index, 0)\n targetOffsets.set(n.index, 0)\n }\n\n // Sort links by target position for visual clarity\n links.sort((a, b) => {\n const na = nodes[a.target]!\n const nb = nodes[b.target]!\n return na.y - nb.y || na.column - nb.column\n })\n\n for (const link of links) {\n const src = nodes[link.source]!\n const tgt = nodes[link.target]!\n\n const srcTotal = Math.max(src.totalOut, 1)\n const tgtTotal = Math.max(tgt.totalIn, 1)\n\n link.width = (link.value / srcTotal) * src.height\n const tgtWidth = (link.value / tgtTotal) * tgt.height\n\n link.sy = sourceOffsets.get(link.source)!\n link.ty = targetOffsets.get(link.target)!\n\n sourceOffsets.set(link.source, link.sy + link.width)\n targetOffsets.set(link.target, link.ty + tgtWidth)\n }\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- var chunkXHQWWR5M_cjs = require('./chunk-XHQWWR5M.cjs');
3
+ var chunk3TLJCGGQ_cjs = require('./chunk-3TLJCGGQ.cjs');
4
4
 
5
5
  // src/charts/range/range-type.ts
6
6
  var rangeChartType = {
@@ -11,7 +11,7 @@ var rangeChartType = {
11
11
  prepareData(data, options) {
12
12
  const opts = options;
13
13
  const range = opts.range;
14
- const prepared = chunkXHQWWR5M_cjs.prepareData(data, options);
14
+ const prepared = chunk3TLJCGGQ_cjs.prepareData(data, options);
15
15
  if (range) {
16
16
  let yMin = prepared.bounds.yMin;
17
17
  let yMax = prepared.bounds.yMax;
@@ -38,7 +38,7 @@ var rangeChartType = {
38
38
  const showPoints = opts.showPoints ?? false;
39
39
  const bandOpacity = opts.bandOpacity ?? 0.2;
40
40
  const seriesNodes = [];
41
- const pb = new chunkXHQWWR5M_cjs.PathBuilder();
41
+ const pb = new chunk3TLJCGGQ_cjs.PathBuilder();
42
42
  const n = range.upper.length;
43
43
  let bandStarted = false;
44
44
  for (let i = 0; i < n; i++) {
@@ -57,14 +57,14 @@ var rangeChartType = {
57
57
  pb.lineTo(x, y);
58
58
  }
59
59
  if (bandStarted) pb.close();
60
- seriesNodes.push(chunkXHQWWR5M_cjs.path(pb.build(), {
60
+ seriesNodes.push(chunk3TLJCGGQ_cjs.path(pb.build(), {
61
61
  class: "chartts-range-band",
62
62
  fill: opts.bandColor ?? series.color,
63
63
  fillOpacity: bandOpacity,
64
64
  "data-series": 0
65
65
  }));
66
66
  const upperPath = buildLinePath(range.upper, xScale, yScale);
67
- seriesNodes.push(chunkXHQWWR5M_cjs.path(upperPath, {
67
+ seriesNodes.push(chunk3TLJCGGQ_cjs.path(upperPath, {
68
68
  class: "chartts-range-bound",
69
69
  stroke: series.color,
70
70
  strokeWidth: 1,
@@ -73,7 +73,7 @@ var rangeChartType = {
73
73
  "data-series": 0
74
74
  }));
75
75
  const lowerPath = buildLinePath(range.lower, xScale, yScale);
76
- seriesNodes.push(chunkXHQWWR5M_cjs.path(lowerPath, {
76
+ seriesNodes.push(chunk3TLJCGGQ_cjs.path(lowerPath, {
77
77
  class: "chartts-range-bound",
78
78
  stroke: series.color,
79
79
  strokeWidth: 1,
@@ -83,7 +83,7 @@ var rangeChartType = {
83
83
  }));
84
84
  if (showCenter && series.values.length > 0) {
85
85
  const centerPath = buildLinePath(series.values, xScale, yScale);
86
- seriesNodes.push(chunkXHQWWR5M_cjs.path(centerPath, {
86
+ seriesNodes.push(chunk3TLJCGGQ_cjs.path(centerPath, {
87
87
  class: "chartts-range-center",
88
88
  stroke: series.color,
89
89
  strokeWidth: theme.lineWidth,
@@ -94,10 +94,10 @@ var rangeChartType = {
94
94
  if (isNaN(series.values[i])) continue;
95
95
  const x = xScale.map(i);
96
96
  const y = yScale.map(series.values[i]);
97
- seriesNodes.push(chunkXHQWWR5M_cjs.circle(x, y, theme.pointRadius, {
97
+ seriesNodes.push(chunk3TLJCGGQ_cjs.circle(x, y, theme.pointRadius, {
98
98
  class: "chartts-point",
99
99
  fill: series.color,
100
- stroke: `var(${chunkXHQWWR5M_cjs.CSS_PREFIX}-bg, #fff)`,
100
+ stroke: `var(${chunk3TLJCGGQ_cjs.CSS_PREFIX}-bg, #fff)`,
101
101
  strokeWidth: 2,
102
102
  "data-series": 0,
103
103
  "data-index": i,
@@ -108,7 +108,7 @@ var rangeChartType = {
108
108
  }
109
109
  }
110
110
  }
111
- nodes.push(chunkXHQWWR5M_cjs.group(seriesNodes, {
111
+ nodes.push(chunk3TLJCGGQ_cjs.group(seriesNodes, {
112
112
  class: "chartts-series chartts-series-0",
113
113
  "data-series-name": series.name
114
114
  }));
@@ -135,7 +135,7 @@ var rangeChartType = {
135
135
  };
136
136
  function buildLinePath(values, xScale, yScale) {
137
137
  if (values.length === 0) return "";
138
- const pb = new chunkXHQWWR5M_cjs.PathBuilder();
138
+ const pb = new chunk3TLJCGGQ_cjs.PathBuilder();
139
139
  let started = false;
140
140
  for (let i = 0; i < values.length; i++) {
141
141
  if (isNaN(values[i])) {
@@ -153,5 +153,5 @@ function buildLinePath(values, xScale, yScale) {
153
153
  }
154
154
 
155
155
  exports.rangeChartType = rangeChartType;
156
- //# sourceMappingURL=chunk-Y54XVNXB.cjs.map
157
- //# sourceMappingURL=chunk-Y54XVNXB.cjs.map
156
+ //# sourceMappingURL=chunk-FEQKBVCZ.cjs.map
157
+ //# sourceMappingURL=chunk-FEQKBVCZ.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/range/range-type.ts"],"names":["prepareData","PathBuilder","path","circle","CSS_PREFIX","group"],"mappings":";;;;;AA+BO,IAAM,cAAA,GAAkC;AAAA,EAC7C,IAAA,EAAM,OAAA;AAAA,EAEN,aAAA,GAAgD;AAC9C,IAAA,OAAO,EAAE,CAAA,EAAG,aAAA,EAAe,CAAA,EAAG,QAAA,EAAS;AAAA,EACzC,CAAA;AAAA,EAEA,WAAA,CAAY,MAAiB,OAAA,EAAwC;AACnE,IAAA,MAAM,IAAA,GAAO,OAAA;AACb,IAAA,MAAM,QAAQ,IAAA,CAAK,KAAA;AACnB,IAAA,MAAM,QAAA,GAAWA,6BAAA,CAAY,IAAA,EAAM,OAAO,CAAA;AAE1C,IAAA,IAAI,KAAA,EAAO;AACT,MAAA,IAAI,IAAA,GAAO,SAAS,MAAA,CAAO,IAAA;AAC3B,MAAA,IAAI,IAAA,GAAO,SAAS,MAAA,CAAO,IAAA;AAC3B,MAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,KAAA,CAAM,KAAA,CAAM,QAAQ,CAAA,EAAA,EAAK;AAC3C,QAAA,MAAM,CAAA,GAAI,KAAA,CAAM,KAAA,CAAM,CAAC,CAAA;AACvB,QAAA,MAAM,CAAA,GAAI,KAAA,CAAM,KAAA,CAAM,CAAC,CAAA;AACvB,QAAA,IAAI,CAAC,KAAA,CAAM,CAAC,CAAA,IAAK,CAAA,GAAI,MAAM,IAAA,GAAO,CAAA;AAClC,QAAA,IAAI,CAAC,KAAA,CAAM,CAAC,CAAA,IAAK,CAAA,GAAI,MAAM,IAAA,GAAO,CAAA;AAAA,MACpC;AACA,MAAA,QAAA,CAAS,OAAO,IAAA,GAAO,IAAA;AACvB,MAAA,QAAA,CAAS,OAAO,IAAA,GAAO,IAAA;AAAA,IACzB;AAEA,IAAA,OAAO,QAAA;AAAA,EACT,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,MAAM,EAAE,IAAA,EAAM,MAAA,EAAQ,MAAA,EAAQ,OAAA,EAAS,OAAM,GAAI,GAAA;AACjD,IAAA,MAAM,QAAsB,EAAC;AAE7B,IAAA,MAAM,IAAA,GAAO,OAAA;AACb,IAAA,MAAM,QAAQ,IAAA,CAAK,KAAA;AACnB,IAAA,IAAI,CAAC,OAAO,OAAO,KAAA;AAEnB,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA;AAC5B,IAAA,IAAI,CAAC,QAAQ,OAAO,KAAA;AAEpB,IAAA,MAAM,UAAA,GAAa,KAAK,UAAA,IAAc,IAAA;AACtC,IAAA,MAAM,UAAA,GAAa,KAAK,UAAA,IAAc,KAAA;AACtC,IAAA,MAAM,WAAA,GAAc,KAAK,WAAA,IAAe,GAAA;AAExC,IAAA,MAAM,cAA4B,EAAC;AAGnC,IAAA,MAAM,EAAA,GAAK,IAAIC,6BAAA,EAAY;AAC3B,IAAA,MAAM,CAAA,GAAI,MAAM,KAAA,CAAM,MAAA;AAGtB,IAAA,IAAI,WAAA,GAAc,KAAA;AAClB,IAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,CAAA,EAAG,CAAA,EAAA,EAAK;AAC1B,MAAA,IAAI,KAAA,CAAM,KAAA,CAAM,KAAA,CAAM,CAAC,CAAE,CAAA,EAAG;AAC5B,MAAA,MAAM,CAAA,GAAI,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACtB,MAAA,MAAM,IAAI,MAAA,CAAO,GAAA,CAAI,KAAA,CAAM,KAAA,CAAM,CAAC,CAAE,CAAA;AACpC,MAAA,IAAI,CAAC,WAAA,EAAa;AAAE,QAAA,EAAA,CAAG,MAAA,CAAO,GAAG,CAAC,CAAA;AAAG,QAAA,WAAA,GAAc,IAAA;AAAA,MAAK,CAAA,MACnD,EAAA,CAAG,MAAA,CAAO,CAAA,EAAG,CAAC,CAAA;AAAA,IACrB;AAGA,IAAA,KAAA,IAAS,CAAA,GAAI,CAAA,GAAI,CAAA,EAAG,CAAA,IAAK,GAAG,CAAA,EAAA,EAAK;AAC/B,MAAA,IAAI,KAAA,CAAM,KAAA,CAAM,KAAA,CAAM,CAAC,CAAE,CAAA,EAAG;AAC5B,MAAA,MAAM,CAAA,GAAI,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACtB,MAAA,MAAM,IAAI,MAAA,CAAO,GAAA,CAAI,KAAA,CAAM,KAAA,CAAM,CAAC,CAAE,CAAA;AACpC,MAAA,EAAA,CAAG,MAAA,CAAO,GAAG,CAAC,CAAA;AAAA,IAChB;AACA,IAAA,IAAI,WAAA,KAAgB,KAAA,EAAM;AAE1B,IAAA,WAAA,CAAY,IAAA,CAAKC,sBAAA,CAAK,EAAA,CAAG,KAAA,EAAM,EAAG;AAAA,MAChC,KAAA,EAAO,oBAAA;AAAA,MACP,IAAA,EAAM,IAAA,CAAK,SAAA,IAAa,MAAA,CAAO,KAAA;AAAA,MAC/B,WAAA,EAAa,WAAA;AAAA,MACb,aAAA,EAAe;AAAA,KAChB,CAAC,CAAA;AAGF,IAAA,MAAM,SAAA,GAAY,aAAA,CAAc,KAAA,CAAM,KAAA,EAAO,QAAQ,MAAM,CAAA;AAC3D,IAAA,WAAA,CAAY,IAAA,CAAKA,uBAAK,SAAA,EAAW;AAAA,MAC/B,KAAA,EAAO,qBAAA;AAAA,MACP,QAAQ,MAAA,CAAO,KAAA;AAAA,MACf,WAAA,EAAa,CAAA;AAAA,MACb,eAAA,EAAiB,KAAA;AAAA,MACjB,OAAA,EAAS,GAAA;AAAA,MACT,aAAA,EAAe;AAAA,KAChB,CAAC,CAAA;AAGF,IAAA,MAAM,SAAA,GAAY,aAAA,CAAc,KAAA,CAAM,KAAA,EAAO,QAAQ,MAAM,CAAA;AAC3D,IAAA,WAAA,CAAY,IAAA,CAAKA,uBAAK,SAAA,EAAW;AAAA,MAC/B,KAAA,EAAO,qBAAA;AAAA,MACP,QAAQ,MAAA,CAAO,KAAA;AAAA,MACf,WAAA,EAAa,CAAA;AAAA,MACb,eAAA,EAAiB,KAAA;AAAA,MACjB,OAAA,EAAS,GAAA;AAAA,MACT,aAAA,EAAe;AAAA,KAChB,CAAC,CAAA;AAGF,IAAA,IAAI,UAAA,IAAc,MAAA,CAAO,MAAA,CAAO,MAAA,GAAS,CAAA,EAAG;AAC1C,MAAA,MAAM,UAAA,GAAa,aAAA,CAAc,MAAA,CAAO,MAAA,EAAQ,QAAQ,MAAM,CAAA;AAC9D,MAAA,WAAA,CAAY,IAAA,CAAKA,uBAAK,UAAA,EAAY;AAAA,QAChC,KAAA,EAAO,sBAAA;AAAA,QACP,QAAQ,MAAA,CAAO,KAAA;AAAA,QACf,aAAa,KAAA,CAAM,SAAA;AAAA,QACnB,aAAA,EAAe;AAAA,OAChB,CAAC,CAAA;AAEF,MAAA,IAAI,UAAA,EAAY;AACd,QAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AAC7C,UAAA,IAAI,KAAA,CAAM,MAAA,CAAO,MAAA,CAAO,CAAC,CAAE,CAAA,EAAG;AAC9B,UAAA,MAAM,CAAA,GAAI,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACtB,UAAA,MAAM,IAAI,MAAA,CAAO,GAAA,CAAI,MAAA,CAAO,MAAA,CAAO,CAAC,CAAE,CAAA;AACtC,UAAA,WAAA,CAAY,IAAA,CAAKC,wBAAA,CAAO,CAAA,EAAG,CAAA,EAAG,MAAM,WAAA,EAAa;AAAA,YAC/C,KAAA,EAAO,eAAA;AAAA,YACP,MAAM,MAAA,CAAO,KAAA;AAAA,YACb,MAAA,EAAQ,OAAOC,4BAAU,CAAA,UAAA,CAAA;AAAA,YACzB,WAAA,EAAa,CAAA;AAAA,YACb,aAAA,EAAe,CAAA;AAAA,YACf,YAAA,EAAc,CAAA;AAAA,YACd,QAAA,EAAU,CAAA;AAAA,YACV,IAAA,EAAM,KAAA;AAAA,YACN,SAAA,EAAW,GAAG,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA,IAAK,CAAC,KAAK,MAAA,CAAO,MAAA,CAAO,CAAC,CAAC,CAAA,EAAA,EAAK,MAAM,KAAA,CAAM,CAAC,CAAC,CAAA,MAAA,EAAI,KAAA,CAAM,KAAA,CAAM,CAAC,CAAC,CAAA,CAAA;AAAA,WAC5F,CAAC,CAAA;AAAA,QACJ;AAAA,MACF;AAAA,IACF;AAEA,IAAA,KAAA,CAAM,IAAA,CAAKC,wBAAM,WAAA,EAAa;AAAA,MAC5B,KAAA,EAAO,iCAAA;AAAA,MACP,oBAAoB,MAAA,CAAO;AAAA,KAC5B,CAAC,CAAA;AAEF,IAAA,OAAO,KAAA;AAAA,EACT,CAAA;AAAA,EAEA,OAAA,CAAQ,GAAA,EAAoB,EAAA,EAAY,EAAA,EAA8B;AACpE,IAAA,MAAM,EAAE,IAAA,EAAM,MAAA,EAAQ,MAAA,EAAO,GAAI,GAAA;AACjC,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA;AAC5B,IAAA,IAAI,CAAC,QAAQ,OAAO,IAAA;AAEpB,IAAA,IAAI,IAAA,GAAyB,IAAA;AAC7B,IAAA,IAAI,QAAA,GAAW,QAAA;AAEf,IAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AAC7C,MAAA,IAAI,KAAA,CAAM,MAAA,CAAO,MAAA,CAAO,CAAC,CAAE,CAAA,EAAG;AAC9B,MAAA,MAAM,CAAA,GAAI,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACtB,MAAA,MAAM,IAAI,MAAA,CAAO,GAAA,CAAI,MAAA,CAAO,MAAA,CAAO,CAAC,CAAE,CAAA;AACtC,MAAA,MAAM,IAAA,GAAO,KAAK,IAAA,CAAA,CAAM,EAAA,GAAK,MAAM,CAAA,GAAA,CAAK,EAAA,GAAK,MAAM,CAAC,CAAA;AACpD,MAAA,IAAI,OAAO,QAAA,EAAU;AACnB,QAAA,QAAA,GAAW,IAAA;AACX,QAAA,IAAA,GAAO,EAAE,WAAA,EAAa,CAAA,EAAG,UAAA,EAAY,CAAA,EAAG,UAAU,IAAA,EAAK;AAAA,MACzD;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,IAAQ,IAAA,CAAK,QAAA,GAAW,EAAA,GAAK,IAAA,GAAO,IAAA;AAAA,EAC7C;AACF;AAEA,SAAS,aAAA,CACP,MAAA,EACA,MAAA,EACA,MAAA,EACQ;AACR,EAAA,IAAI,MAAA,CAAO,MAAA,KAAW,CAAA,EAAG,OAAO,EAAA;AAChC,EAAA,MAAM,EAAA,GAAK,IAAIJ,6BAAA,EAAY;AAC3B,EAAA,IAAI,OAAA,GAAU,KAAA;AACd,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AACtC,IAAA,IAAI,KAAA,CAAM,MAAA,CAAO,CAAC,CAAE,CAAA,EAAG;AAAE,MAAA,OAAA,GAAU,KAAA;AAAO,MAAA;AAAA,IAAS;AACnD,IAAA,MAAM,CAAA,GAAI,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACtB,IAAA,MAAM,CAAA,GAAI,MAAA,CAAO,GAAA,CAAI,MAAA,CAAO,CAAC,CAAE,CAAA;AAC/B,IAAA,IAAI,CAAC,OAAA,EAAS;AAAE,MAAA,EAAA,CAAG,MAAA,CAAO,GAAG,CAAC,CAAA;AAAG,MAAA,OAAA,GAAU,IAAA;AAAA,IAAK,CAAA,MAC3C,EAAA,CAAG,MAAA,CAAO,CAAA,EAAG,CAAC,CAAA;AAAA,EACrB;AACA,EAAA,OAAO,GAAG,KAAA,EAAM;AAClB","file":"chunk-Y54XVNXB.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { CSS_PREFIX } from '../../constants'\nimport { prepareData } from '../../data/prepare'\nimport { group, path, circle } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\nexport interface RangeOptions {\n /** Upper and lower bound arrays. */\n range?: {\n upper: number[]\n lower: number[]\n }\n /** Band fill color. Default uses series color with opacity. */\n bandColor?: string\n /** Band fill opacity. Default 0.2. */\n bandOpacity?: number\n /** Show center line (series[0].values). Default true. */\n showCenter?: boolean\n /** Show data points on center line. Default false. */\n showPoints?: boolean\n}\n\n/**\n * Range / Band chart — shaded area between upper and lower bounds.\n *\n * Used for: Bollinger bands, confidence intervals, forecast ranges,\n * bid-ask spread visualization.\n */\nexport const rangeChartType: ChartTypePlugin = {\n type: 'range',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const opts = options as unknown as RangeOptions\n const range = opts.range\n const prepared = prepareData(data, options)\n\n if (range) {\n let yMin = prepared.bounds.yMin\n let yMax = prepared.bounds.yMax\n for (let i = 0; i < range.upper.length; i++) {\n const u = range.upper[i]!\n const l = range.lower[i]!\n if (!isNaN(u) && u > yMax) yMax = u\n if (!isNaN(l) && l < yMin) yMin = l\n }\n prepared.bounds.yMin = yMin\n prepared.bounds.yMax = yMax\n }\n\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, xScale, yScale, options, theme } = ctx\n const nodes: RenderNode[] = []\n\n const opts = options as unknown as RangeOptions\n const range = opts.range\n if (!range) return nodes\n\n const series = data.series[0]\n if (!series) return nodes\n\n const showCenter = opts.showCenter ?? true\n const showPoints = opts.showPoints ?? false\n const bandOpacity = opts.bandOpacity ?? 0.2\n\n const seriesNodes: RenderNode[] = []\n\n // Build band polygon: upper path forward, lower path backward\n const pb = new PathBuilder()\n const n = range.upper.length\n\n // Upper path (left to right) — skip NaN\n let bandStarted = false\n for (let i = 0; i < n; i++) {\n if (isNaN(range.upper[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(range.upper[i]!)\n if (!bandStarted) { pb.moveTo(x, y); bandStarted = true }\n else pb.lineTo(x, y)\n }\n\n // Lower path (right to left) — skip NaN\n for (let i = n - 1; i >= 0; i--) {\n if (isNaN(range.lower[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(range.lower[i]!)\n pb.lineTo(x, y)\n }\n if (bandStarted) pb.close()\n\n seriesNodes.push(path(pb.build(), {\n class: 'chartts-range-band',\n fill: opts.bandColor ?? series.color,\n fillOpacity: bandOpacity,\n 'data-series': 0,\n }))\n\n // Upper bound line\n const upperPath = buildLinePath(range.upper, xScale, yScale)\n seriesNodes.push(path(upperPath, {\n class: 'chartts-range-bound',\n stroke: series.color,\n strokeWidth: 1,\n strokeDasharray: '4,3',\n opacity: 0.6,\n 'data-series': 0,\n }))\n\n // Lower bound line\n const lowerPath = buildLinePath(range.lower, xScale, yScale)\n seriesNodes.push(path(lowerPath, {\n class: 'chartts-range-bound',\n stroke: series.color,\n strokeWidth: 1,\n strokeDasharray: '4,3',\n opacity: 0.6,\n 'data-series': 0,\n }))\n\n // Center line\n if (showCenter && series.values.length > 0) {\n const centerPath = buildLinePath(series.values, xScale, yScale)\n seriesNodes.push(path(centerPath, {\n class: 'chartts-range-center',\n stroke: series.color,\n strokeWidth: theme.lineWidth,\n 'data-series': 0,\n }))\n\n if (showPoints) {\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n seriesNodes.push(circle(x, y, theme.pointRadius, {\n class: 'chartts-point',\n fill: series.color,\n stroke: `var(${CSS_PREFIX}-bg, #fff)`,\n strokeWidth: 2,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i] ?? i}: ${series.values[i]} [${range.lower[i]}–${range.upper[i]}]`,\n }))\n }\n }\n }\n\n nodes.push(group(seriesNodes, {\n class: 'chartts-series chartts-series-0',\n 'data-series-name': series.name,\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 series = data.series[0]\n if (!series) return null\n\n let best: HitResult | null = null\n let bestDist = Infinity\n\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2)\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: 0, pointIndex: i, distance: dist }\n }\n }\n\n return best && best.distance < 30 ? best : null\n },\n}\n\nfunction buildLinePath(\n values: number[],\n xScale: { map(v: number | string | Date): number },\n yScale: { map(v: number | string | Date): number },\n): string {\n if (values.length === 0) return ''\n const pb = new PathBuilder()\n let started = false\n for (let i = 0; i < values.length; i++) {\n if (isNaN(values[i]!)) { started = false; continue }\n const x = xScale.map(i)\n const y = yScale.map(values[i]!)\n if (!started) { pb.moveTo(x, y); started = true }\n else pb.lineTo(x, y)\n }\n return pb.build()\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/range/range-type.ts"],"names":["prepareData","PathBuilder","path","circle","CSS_PREFIX","group"],"mappings":"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","file":"chunk-FEQKBVCZ.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { CSS_PREFIX } from '../../constants'\nimport { prepareData } from '../../data/prepare'\nimport { group, path, circle } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\nexport interface RangeOptions {\n /** Upper and lower bound arrays. */\n range?: {\n upper: number[]\n lower: number[]\n }\n /** Band fill color. Default uses series color with opacity. */\n bandColor?: string\n /** Band fill opacity. Default 0.2. */\n bandOpacity?: number\n /** Show center line (series[0].values). Default true. */\n showCenter?: boolean\n /** Show data points on center line. Default false. */\n showPoints?: boolean\n}\n\n/**\n * Range / Band chart — shaded area between upper and lower bounds.\n *\n * Used for: Bollinger bands, confidence intervals, forecast ranges,\n * bid-ask spread visualization.\n */\nexport const rangeChartType: ChartTypePlugin = {\n type: 'range',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const opts = options as unknown as RangeOptions\n const range = opts.range\n const prepared = prepareData(data, options)\n\n if (range) {\n let yMin = prepared.bounds.yMin\n let yMax = prepared.bounds.yMax\n for (let i = 0; i < range.upper.length; i++) {\n const u = range.upper[i]!\n const l = range.lower[i]!\n if (!isNaN(u) && u > yMax) yMax = u\n if (!isNaN(l) && l < yMin) yMin = l\n }\n prepared.bounds.yMin = yMin\n prepared.bounds.yMax = yMax\n }\n\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, xScale, yScale, options, theme } = ctx\n const nodes: RenderNode[] = []\n\n const opts = options as unknown as RangeOptions\n const range = opts.range\n if (!range) return nodes\n\n const series = data.series[0]\n if (!series) return nodes\n\n const showCenter = opts.showCenter ?? true\n const showPoints = opts.showPoints ?? false\n const bandOpacity = opts.bandOpacity ?? 0.2\n\n const seriesNodes: RenderNode[] = []\n\n // Build band polygon: upper path forward, lower path backward\n const pb = new PathBuilder()\n const n = range.upper.length\n\n // Upper path (left to right) — skip NaN\n let bandStarted = false\n for (let i = 0; i < n; i++) {\n if (isNaN(range.upper[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(range.upper[i]!)\n if (!bandStarted) { pb.moveTo(x, y); bandStarted = true }\n else pb.lineTo(x, y)\n }\n\n // Lower path (right to left) — skip NaN\n for (let i = n - 1; i >= 0; i--) {\n if (isNaN(range.lower[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(range.lower[i]!)\n pb.lineTo(x, y)\n }\n if (bandStarted) pb.close()\n\n seriesNodes.push(path(pb.build(), {\n class: 'chartts-range-band',\n fill: opts.bandColor ?? series.color,\n fillOpacity: bandOpacity,\n 'data-series': 0,\n }))\n\n // Upper bound line\n const upperPath = buildLinePath(range.upper, xScale, yScale)\n seriesNodes.push(path(upperPath, {\n class: 'chartts-range-bound',\n stroke: series.color,\n strokeWidth: 1,\n strokeDasharray: '4,3',\n opacity: 0.6,\n 'data-series': 0,\n }))\n\n // Lower bound line\n const lowerPath = buildLinePath(range.lower, xScale, yScale)\n seriesNodes.push(path(lowerPath, {\n class: 'chartts-range-bound',\n stroke: series.color,\n strokeWidth: 1,\n strokeDasharray: '4,3',\n opacity: 0.6,\n 'data-series': 0,\n }))\n\n // Center line\n if (showCenter && series.values.length > 0) {\n const centerPath = buildLinePath(series.values, xScale, yScale)\n seriesNodes.push(path(centerPath, {\n class: 'chartts-range-center',\n stroke: series.color,\n strokeWidth: theme.lineWidth,\n 'data-series': 0,\n }))\n\n if (showPoints) {\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n seriesNodes.push(circle(x, y, theme.pointRadius, {\n class: 'chartts-point',\n fill: series.color,\n stroke: `var(${CSS_PREFIX}-bg, #fff)`,\n strokeWidth: 2,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i] ?? i}: ${series.values[i]} [${range.lower[i]}–${range.upper[i]}]`,\n }))\n }\n }\n }\n\n nodes.push(group(seriesNodes, {\n class: 'chartts-series chartts-series-0',\n 'data-series-name': series.name,\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 series = data.series[0]\n if (!series) return null\n\n let best: HitResult | null = null\n let bestDist = Infinity\n\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2)\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: 0, pointIndex: i, distance: dist }\n }\n }\n\n return best && best.distance < 30 ? best : null\n },\n}\n\nfunction buildLinePath(\n values: number[],\n xScale: { map(v: number | string | Date): number },\n yScale: { map(v: number | string | Date): number },\n): string {\n if (values.length === 0) return ''\n const pb = new PathBuilder()\n let started = false\n for (let i = 0; i < values.length; i++) {\n if (isNaN(values[i]!)) { started = false; continue }\n const x = xScale.map(i)\n const y = yScale.map(values[i]!)\n if (!started) { pb.moveTo(x, y); started = true }\n else pb.lineTo(x, y)\n }\n return pb.build()\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
3
  var chunkNHGKZMD7_cjs = require('./chunk-NHGKZMD7.cjs');
4
- var chunkXHQWWR5M_cjs = require('./chunk-XHQWWR5M.cjs');
4
+ var chunk3TLJCGGQ_cjs = require('./chunk-3TLJCGGQ.cjs');
5
5
 
6
6
  // src/charts/lollipop/lollipop-type.ts
7
7
  var lollipopChartType = {
@@ -10,7 +10,7 @@ var lollipopChartType = {
10
10
  return { x: "categorical", y: "linear" };
11
11
  },
12
12
  prepareData(data, options) {
13
- const prepared = chunkXHQWWR5M_cjs.prepareData(data, options);
13
+ const prepared = chunk3TLJCGGQ_cjs.prepareData(data, options);
14
14
  if (options.yMin === void 0 && prepared.bounds.yMin > 0) {
15
15
  prepared.bounds.yMin = 0;
16
16
  }
@@ -33,12 +33,12 @@ var lollipopChartType = {
33
33
  const cx = xScale.map(i) + (series.index - (seriesCount - 1) / 2) * stemGap;
34
34
  const vy = yScale.map(series.values[i]);
35
35
  const color = options.colors[series.index % options.colors.length];
36
- seriesNodes.push(chunkXHQWWR5M_cjs.line(cx, baselineY, cx, vy, {
36
+ seriesNodes.push(chunk3TLJCGGQ_cjs.line(cx, baselineY, cx, vy, {
37
37
  class: "chartts-lollipop-stem",
38
38
  stroke: color,
39
39
  strokeWidth: 2
40
40
  }));
41
- seriesNodes.push(chunkXHQWWR5M_cjs.circle(cx, vy, dotR, {
41
+ seriesNodes.push(chunk3TLJCGGQ_cjs.circle(cx, vy, dotR, {
42
42
  class: "chartts-lollipop-dot",
43
43
  fill: color,
44
44
  stroke: "#fff",
@@ -50,7 +50,7 @@ var lollipopChartType = {
50
50
  ariaLabel: `${series.name}: ${series.values[i]}`
51
51
  }));
52
52
  }
53
- nodes.push(chunkXHQWWR5M_cjs.group(seriesNodes, {
53
+ nodes.push(chunk3TLJCGGQ_cjs.group(seriesNodes, {
54
54
  class: `chartts-series chartts-series-${series.index}`,
55
55
  "data-series-name": series.name
56
56
  }));
@@ -85,5 +85,5 @@ var lollipopChartType = {
85
85
  };
86
86
 
87
87
  exports.lollipopChartType = lollipopChartType;
88
- //# sourceMappingURL=chunk-UQBDGCS6.cjs.map
89
- //# sourceMappingURL=chunk-UQBDGCS6.cjs.map
88
+ //# sourceMappingURL=chunk-FIAKZSRR.cjs.map
89
+ //# sourceMappingURL=chunk-FIAKZSRR.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/lollipop/lollipop-type.ts"],"names":["prepareData","getBandwidth","line","circle","group"],"mappings":"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","file":"chunk-UQBDGCS6.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, line, circle } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Lollipop chart — stem line + circle at end.\n *\n * A modern, cleaner alternative to bar charts.\n * Vertical stems from baseline to value with a prominent circle dot.\n */\nexport const lollipopChartType: ChartTypePlugin = {\n type: 'lollipop',\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 return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n const bw = getBandwidth(xScale)\n const groupWidth = bw * 0.8\n const stemGap = groupWidth / seriesCount\n const dotR = Math.min(6, stemGap * 0.35)\n const baselineY = yScale.map(0)\n\n for (const series of data.series) {\n const seriesNodes: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i) + (series.index - (seriesCount - 1) / 2) * stemGap\n const vy = yScale.map(series.values[i]!)\n const color = options.colors[series.index % options.colors.length]!\n\n // Stem line\n seriesNodes.push(line(cx, baselineY, cx, vy, {\n class: 'chartts-lollipop-stem',\n stroke: color,\n strokeWidth: 2,\n }))\n\n // Dot\n seriesNodes.push(circle(cx, vy, dotR, {\n class: 'chartts-lollipop-dot',\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(seriesNodes, {\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 seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return null\n\n const bw = getBandwidth(xScale)\n const groupWidth = bw * 0.8\n const stemGap = groupWidth / seriesCount\n\n let best: HitResult | null = null\n let bestDist = 20 // tolerance\n\n for (const series of data.series) {\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i) + (series.index - (seriesCount - 1) / 2) * stemGap\n const vy = yScale.map(series.values[i]!)\n const dx = mx - cx\n const dy = my - vy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist }\n }\n }\n }\n\n return best\n },\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/lollipop/lollipop-type.ts"],"names":["prepareData","getBandwidth","line","circle","group"],"mappings":"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","file":"chunk-FIAKZSRR.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, line, circle } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Lollipop chart — stem line + circle at end.\n *\n * A modern, cleaner alternative to bar charts.\n * Vertical stems from baseline to value with a prominent circle dot.\n */\nexport const lollipopChartType: ChartTypePlugin = {\n type: 'lollipop',\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 return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n const bw = getBandwidth(xScale)\n const groupWidth = bw * 0.8\n const stemGap = groupWidth / seriesCount\n const dotR = Math.min(6, stemGap * 0.35)\n const baselineY = yScale.map(0)\n\n for (const series of data.series) {\n const seriesNodes: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i) + (series.index - (seriesCount - 1) / 2) * stemGap\n const vy = yScale.map(series.values[i]!)\n const color = options.colors[series.index % options.colors.length]!\n\n // Stem line\n seriesNodes.push(line(cx, baselineY, cx, vy, {\n class: 'chartts-lollipop-stem',\n stroke: color,\n strokeWidth: 2,\n }))\n\n // Dot\n seriesNodes.push(circle(cx, vy, dotR, {\n class: 'chartts-lollipop-dot',\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(seriesNodes, {\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 seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return null\n\n const bw = getBandwidth(xScale)\n const groupWidth = bw * 0.8\n const stemGap = groupWidth / seriesCount\n\n let best: HitResult | null = null\n let bestDist = 20 // tolerance\n\n for (const series of data.series) {\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i) + (series.index - (seriesCount - 1) / 2) * stemGap\n const vy = yScale.map(series.values[i]!)\n const dx = mx - cx\n const dy = my - vy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist }\n }\n }\n }\n\n return best\n },\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
- var chunk5QOQR5FE_cjs = require('./chunk-5QOQR5FE.cjs');
4
- var chunkXHQWWR5M_cjs = require('./chunk-XHQWWR5M.cjs');
3
+ var chunkHOPFELRP_cjs = require('./chunk-HOPFELRP.cjs');
4
+ var chunk3TLJCGGQ_cjs = require('./chunk-3TLJCGGQ.cjs');
5
5
 
6
6
  // src/charts/treemap/treemap-type.ts
7
7
  var treemapChartType = {
@@ -10,7 +10,7 @@ var treemapChartType = {
10
10
  return { x: "categorical", y: "linear" };
11
11
  },
12
12
  prepareData(data, options) {
13
- return chunk5QOQR5FE_cjs.prepareNoAxes(data, options);
13
+ return chunkHOPFELRP_cjs.prepareNoAxes(data, options);
14
14
  },
15
15
  render(ctx) {
16
16
  const { data, area, theme, options } = ctx;
@@ -29,7 +29,7 @@ var treemapChartType = {
29
29
  const color = options.colors[colorIndex];
30
30
  const label = String(data.labels[item.index] ?? `Item ${item.index + 1}`);
31
31
  const cellNodes = [];
32
- cellNodes.push(chunkXHQWWR5M_cjs.rect(r.x + gap / 2, r.y + gap / 2, r.w - gap, r.h - gap, {
32
+ cellNodes.push(chunk3TLJCGGQ_cjs.rect(r.x + gap / 2, r.y + gap / 2, r.w - gap, r.h - gap, {
33
33
  class: "chartts-treemap-cell",
34
34
  fill: color,
35
35
  fillOpacity: 0.75,
@@ -43,7 +43,7 @@ var treemapChartType = {
43
43
  }));
44
44
  if (r.w > 30 && r.h > 20) {
45
45
  const fontSize = Math.min(theme.fontSizeSmall, r.w * 0.15, r.h * 0.3);
46
- cellNodes.push(chunkXHQWWR5M_cjs.text(r.x + r.w / 2, r.y + r.h / 2 - fontSize * 0.3, label, {
46
+ cellNodes.push(chunk3TLJCGGQ_cjs.text(r.x + r.w / 2, r.y + r.h / 2 - fontSize * 0.3, label, {
47
47
  class: "chartts-treemap-label",
48
48
  fill: "#fff",
49
49
  textAnchor: "middle",
@@ -53,7 +53,7 @@ var treemapChartType = {
53
53
  fontWeight: 600
54
54
  }));
55
55
  if (r.h > 35) {
56
- cellNodes.push(chunkXHQWWR5M_cjs.text(r.x + r.w / 2, r.y + r.h / 2 + fontSize * 0.8, String(series.values[item.index]), {
56
+ cellNodes.push(chunk3TLJCGGQ_cjs.text(r.x + r.w / 2, r.y + r.h / 2 + fontSize * 0.8, String(series.values[item.index]), {
57
57
  class: "chartts-treemap-value",
58
58
  fill: "rgba(255,255,255,0.7)",
59
59
  textAnchor: "middle",
@@ -63,7 +63,7 @@ var treemapChartType = {
63
63
  }));
64
64
  }
65
65
  }
66
- nodes.push(chunkXHQWWR5M_cjs.group(cellNodes, {
66
+ nodes.push(chunk3TLJCGGQ_cjs.group(cellNodes, {
67
67
  class: `chartts-series chartts-series-${item.index}`,
68
68
  "data-series-name": label
69
69
  }));
@@ -149,5 +149,5 @@ function layoutRow(values, start, x, y, w, h, rects) {
149
149
  }
150
150
 
151
151
  exports.treemapChartType = treemapChartType;
152
- //# sourceMappingURL=chunk-HB4EGHJ7.cjs.map
153
- //# sourceMappingURL=chunk-HB4EGHJ7.cjs.map
152
+ //# sourceMappingURL=chunk-FKAA5FNG.cjs.map
153
+ //# sourceMappingURL=chunk-FKAA5FNG.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/treemap/treemap-type.ts"],"names":["prepareNoAxes","rect","text","group","rowThickness"],"mappings":"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","file":"chunk-HB4EGHJ7.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, rect, text } from '../../render/tree'\n\n/**\n * Treemap chart — rectangular space-filling visualization.\n *\n * Uses the first series' values as areas. Labels are cell labels.\n * Implements a simple squarified treemap layout.\n */\nexport const treemapChartType: ChartTypePlugin = {\n type: 'treemap',\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 items sorted by value descending\n const items = series.values\n .map((v, i) => ({ value: Math.abs(v), index: i }))\n .filter(d => d.value > 0)\n .sort((a, b) => b.value - a.value)\n\n if (items.length === 0) return nodes\n\n const total = items.reduce((s, d) => s + d.value, 0)\n const gap = 2\n\n // Layout using slice-and-dice (simpler, works well)\n const rects = squarify(items.map(d => d.value / total), area.x, area.y, area.width, area.height)\n\n for (let k = 0; k < items.length; k++) {\n const item = items[k]!\n const r = rects[k]!\n const colorIndex = item.index % options.colors.length\n const color = options.colors[colorIndex]!\n const label = String(data.labels[item.index] ?? `Item ${item.index + 1}`)\n\n const cellNodes: RenderNode[] = []\n\n cellNodes.push(rect(r.x + gap / 2, r.y + gap / 2, r.w - gap, r.h - gap, {\n class: 'chartts-treemap-cell',\n fill: color,\n fillOpacity: 0.75,\n rx: 5,\n ry: 5,\n 'data-series': 0,\n 'data-index': item.index,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label}: ${series.values[item.index]}`,\n }))\n\n // Only show label if cell is big enough\n if (r.w > 30 && r.h > 20) {\n const fontSize = Math.min(theme.fontSizeSmall, r.w * 0.15, r.h * 0.3)\n cellNodes.push(text(r.x + r.w / 2, r.y + r.h / 2 - fontSize * 0.3, label, {\n class: 'chartts-treemap-label',\n fill: '#fff',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n\n // Show value below label\n if (r.h > 35) {\n cellNodes.push(text(r.x + r.w / 2, r.y + r.h / 2 + fontSize * 0.8, String(series.values[item.index]), {\n class: 'chartts-treemap-value',\n fill: 'rgba(255,255,255,0.7)',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: fontSize * 0.85,\n fontFamily: theme.fontFamily,\n }))\n }\n }\n\n nodes.push(group(cellNodes, {\n class: `chartts-series chartts-series-${item.index}`,\n 'data-series-name': label,\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 items = series.values\n .map((v, i) => ({ value: Math.abs(v), index: i }))\n .filter(d => d.value > 0)\n .sort((a, b) => b.value - a.value)\n\n if (items.length === 0) return null\n const total = items.reduce((s, d) => s + d.value, 0)\n const rects = squarify(items.map(d => d.value / total), area.x, area.y, area.width, area.height)\n\n for (let k = 0; k < items.length; k++) {\n const r = rects[k]!\n if (mx >= r.x && mx <= r.x + r.w && my >= r.y && my <= r.y + r.h) {\n return { seriesIndex: 0, pointIndex: items[k]!.index, distance: 0 }\n }\n }\n\n return null\n },\n}\n\ninterface Rect { x: number; y: number; w: number; h: number }\n\n/**\n * Squarified treemap layout.\n * Takes normalized values (sum to 1) and fills a rectangle.\n */\nfunction squarify(values: number[], x: number, y: number, w: number, h: number): Rect[] {\n const rects: Rect[] = []\n layoutRow(values, 0, x, y, w, h, rects)\n return rects\n}\n\nfunction layoutRow(\n values: number[], start: number,\n x: number, y: number, w: number, h: number,\n rects: Rect[],\n): void {\n if (start >= values.length) return\n if (values.length - start === 1) {\n rects.push({ x, y, w, h })\n return\n }\n\n const isWide = w >= h\n\n // Greedily add items to the current row until aspect ratio gets worse\n let rowSum = 0\n let bestWorst = Infinity\n let rowEnd = start\n\n for (let i = start; i < values.length; i++) {\n const newSum = rowSum + values[i]!\n\n // Compute row takes up fraction of the short side\n const rowFraction = newSum\n const rowThickness = isWide ? w * rowFraction : h * rowFraction\n const count = i - start + 1\n\n if (rowThickness <= 0) { rowSum = newSum; rowEnd = i + 1; continue }\n\n // Worst aspect ratio in this row\n let worst = 0\n for (let j = start; j <= i; j++) {\n const cellFrac = values[j]! / newSum\n const cellLen = isWide ? h * cellFrac : w * cellFrac\n const ar = Math.max(rowThickness / cellLen, cellLen / rowThickness)\n if (ar > worst) worst = ar\n }\n\n if (count === 1 || worst <= bestWorst) {\n bestWorst = worst\n rowSum = newSum\n rowEnd = i + 1\n } else {\n break\n }\n }\n\n if (rowEnd === start) rowEnd = start + 1\n const finalSum = values.slice(start, rowEnd).reduce((a, b) => a + b, 0)\n\n // Lay out this row\n const rowThickness = isWide ? w * finalSum : h * finalSum\n let offset = 0\n\n for (let i = start; i < rowEnd; i++) {\n const frac = finalSum > 0 ? values[i]! / finalSum : 0\n const cellLen = isWide ? h * frac : w * frac\n\n if (isWide) {\n rects.push({ x, y: y + offset, w: rowThickness, h: cellLen })\n } else {\n rects.push({ x: x + offset, y, w: cellLen, h: rowThickness })\n }\n offset += cellLen\n }\n\n // Recurse for remaining items\n if (isWide) {\n layoutRow(values, rowEnd, x + rowThickness, y, w - rowThickness, h, rects)\n } else {\n layoutRow(values, rowEnd, x, y + rowThickness, w, h - rowThickness, rects)\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/treemap/treemap-type.ts"],"names":["prepareNoAxes","rect","text","group","rowThickness"],"mappings":"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","file":"chunk-FKAA5FNG.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, rect, text } from '../../render/tree'\n\n/**\n * Treemap chart — rectangular space-filling visualization.\n *\n * Uses the first series' values as areas. Labels are cell labels.\n * Implements a simple squarified treemap layout.\n */\nexport const treemapChartType: ChartTypePlugin = {\n type: 'treemap',\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 items sorted by value descending\n const items = series.values\n .map((v, i) => ({ value: Math.abs(v), index: i }))\n .filter(d => d.value > 0)\n .sort((a, b) => b.value - a.value)\n\n if (items.length === 0) return nodes\n\n const total = items.reduce((s, d) => s + d.value, 0)\n const gap = 2\n\n // Layout using slice-and-dice (simpler, works well)\n const rects = squarify(items.map(d => d.value / total), area.x, area.y, area.width, area.height)\n\n for (let k = 0; k < items.length; k++) {\n const item = items[k]!\n const r = rects[k]!\n const colorIndex = item.index % options.colors.length\n const color = options.colors[colorIndex]!\n const label = String(data.labels[item.index] ?? `Item ${item.index + 1}`)\n\n const cellNodes: RenderNode[] = []\n\n cellNodes.push(rect(r.x + gap / 2, r.y + gap / 2, r.w - gap, r.h - gap, {\n class: 'chartts-treemap-cell',\n fill: color,\n fillOpacity: 0.75,\n rx: 5,\n ry: 5,\n 'data-series': 0,\n 'data-index': item.index,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label}: ${series.values[item.index]}`,\n }))\n\n // Only show label if cell is big enough\n if (r.w > 30 && r.h > 20) {\n const fontSize = Math.min(theme.fontSizeSmall, r.w * 0.15, r.h * 0.3)\n cellNodes.push(text(r.x + r.w / 2, r.y + r.h / 2 - fontSize * 0.3, label, {\n class: 'chartts-treemap-label',\n fill: '#fff',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n\n // Show value below label\n if (r.h > 35) {\n cellNodes.push(text(r.x + r.w / 2, r.y + r.h / 2 + fontSize * 0.8, String(series.values[item.index]), {\n class: 'chartts-treemap-value',\n fill: 'rgba(255,255,255,0.7)',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: fontSize * 0.85,\n fontFamily: theme.fontFamily,\n }))\n }\n }\n\n nodes.push(group(cellNodes, {\n class: `chartts-series chartts-series-${item.index}`,\n 'data-series-name': label,\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 items = series.values\n .map((v, i) => ({ value: Math.abs(v), index: i }))\n .filter(d => d.value > 0)\n .sort((a, b) => b.value - a.value)\n\n if (items.length === 0) return null\n const total = items.reduce((s, d) => s + d.value, 0)\n const rects = squarify(items.map(d => d.value / total), area.x, area.y, area.width, area.height)\n\n for (let k = 0; k < items.length; k++) {\n const r = rects[k]!\n if (mx >= r.x && mx <= r.x + r.w && my >= r.y && my <= r.y + r.h) {\n return { seriesIndex: 0, pointIndex: items[k]!.index, distance: 0 }\n }\n }\n\n return null\n },\n}\n\ninterface Rect { x: number; y: number; w: number; h: number }\n\n/**\n * Squarified treemap layout.\n * Takes normalized values (sum to 1) and fills a rectangle.\n */\nfunction squarify(values: number[], x: number, y: number, w: number, h: number): Rect[] {\n const rects: Rect[] = []\n layoutRow(values, 0, x, y, w, h, rects)\n return rects\n}\n\nfunction layoutRow(\n values: number[], start: number,\n x: number, y: number, w: number, h: number,\n rects: Rect[],\n): void {\n if (start >= values.length) return\n if (values.length - start === 1) {\n rects.push({ x, y, w, h })\n return\n }\n\n const isWide = w >= h\n\n // Greedily add items to the current row until aspect ratio gets worse\n let rowSum = 0\n let bestWorst = Infinity\n let rowEnd = start\n\n for (let i = start; i < values.length; i++) {\n const newSum = rowSum + values[i]!\n\n // Compute row takes up fraction of the short side\n const rowFraction = newSum\n const rowThickness = isWide ? w * rowFraction : h * rowFraction\n const count = i - start + 1\n\n if (rowThickness <= 0) { rowSum = newSum; rowEnd = i + 1; continue }\n\n // Worst aspect ratio in this row\n let worst = 0\n for (let j = start; j <= i; j++) {\n const cellFrac = values[j]! / newSum\n const cellLen = isWide ? h * cellFrac : w * cellFrac\n const ar = Math.max(rowThickness / cellLen, cellLen / rowThickness)\n if (ar > worst) worst = ar\n }\n\n if (count === 1 || worst <= bestWorst) {\n bestWorst = worst\n rowSum = newSum\n rowEnd = i + 1\n } else {\n break\n }\n }\n\n if (rowEnd === start) rowEnd = start + 1\n const finalSum = values.slice(start, rowEnd).reduce((a, b) => a + b, 0)\n\n // Lay out this row\n const rowThickness = isWide ? w * finalSum : h * finalSum\n let offset = 0\n\n for (let i = start; i < rowEnd; i++) {\n const frac = finalSum > 0 ? values[i]! / finalSum : 0\n const cellLen = isWide ? h * frac : w * frac\n\n if (isWide) {\n rects.push({ x, y: y + offset, w: rowThickness, h: cellLen })\n } else {\n rects.push({ x: x + offset, y, w: cellLen, h: rowThickness })\n }\n offset += cellLen\n }\n\n // Recurse for remaining items\n if (isWide) {\n layoutRow(values, rowEnd, x + rowThickness, y, w - rowThickness, h, rects)\n } else {\n layoutRow(values, rowEnd, x, y + rowThickness, w, h - rowThickness, rects)\n }\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  import { getBandwidth } from './chunk-E6PR75X7.js';
2
- import { line, circle, group, prepareData } from './chunk-3BRQGYDX.js';
2
+ import { line, circle, group, prepareData } from './chunk-BMTVFAX2.js';
3
3
 
4
4
  // src/charts/lollipop/lollipop-type.ts
5
5
  var lollipopChartType = {
@@ -83,5 +83,5 @@ var lollipopChartType = {
83
83
  };
84
84
 
85
85
  export { lollipopChartType };
86
- //# sourceMappingURL=chunk-NYVFC2SF.js.map
87
- //# sourceMappingURL=chunk-NYVFC2SF.js.map
86
+ //# sourceMappingURL=chunk-FKVYS4RB.js.map
87
+ //# sourceMappingURL=chunk-FKVYS4RB.js.map