@chartts/core 0.1.3 → 0.1.5

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 (359) hide show
  1. package/dist/area.cjs +10 -10
  2. package/dist/area.js +5 -5
  3. package/dist/bar.cjs +9 -9
  4. package/dist/bar.js +4 -4
  5. package/dist/baseline.cjs +9 -9
  6. package/dist/baseline.js +4 -4
  7. package/dist/boxplot.cjs +9 -9
  8. package/dist/boxplot.js +4 -4
  9. package/dist/bubble.cjs +9 -9
  10. package/dist/bubble.js +4 -4
  11. package/dist/bullet.cjs +10 -10
  12. package/dist/bullet.js +5 -5
  13. package/dist/calendar.cjs +10 -10
  14. package/dist/calendar.js +5 -5
  15. package/dist/candlestick.cjs +9 -9
  16. package/dist/candlestick.js +4 -4
  17. package/dist/chord.cjs +10 -10
  18. package/dist/chord.js +5 -5
  19. package/dist/chunk-2OWMJBRN.js +122 -0
  20. package/dist/chunk-2OWMJBRN.js.map +1 -0
  21. package/dist/{chunk-DR5MQC3W.js → chunk-2VHG2N75.js} +4 -4
  22. package/dist/{chunk-DR5MQC3W.js.map → chunk-2VHG2N75.js.map} +1 -1
  23. package/dist/{chunk-RN7NNB6I.js → chunk-2X7UIG3G.js} +3 -3
  24. package/dist/{chunk-RN7NNB6I.js.map → chunk-2X7UIG3G.js.map} +1 -1
  25. package/dist/{chunk-ZTUKOCJN.cjs → chunk-35XUPEAD.cjs} +4 -4
  26. package/dist/{chunk-ZTUKOCJN.cjs.map → chunk-35XUPEAD.cjs.map} +1 -1
  27. package/dist/{chunk-2EZ2TVYT.cjs → chunk-3HBRAGJA.cjs} +13 -13
  28. package/dist/{chunk-2EZ2TVYT.cjs.map → chunk-3HBRAGJA.cjs.map} +1 -1
  29. package/dist/{chunk-WJP6CRML.js → chunk-45Y77XDM.js} +3 -3
  30. package/dist/{chunk-WJP6CRML.js.map → chunk-45Y77XDM.js.map} +1 -1
  31. package/dist/{chunk-DRIJNFWP.cjs → chunk-47R2QUID.cjs} +10 -10
  32. package/dist/{chunk-DRIJNFWP.cjs.map → chunk-47R2QUID.cjs.map} +1 -1
  33. package/dist/{chunk-FDNJNVKA.cjs → chunk-4C5IV57Z.cjs} +9 -9
  34. package/dist/{chunk-FDNJNVKA.cjs.map → chunk-4C5IV57Z.cjs.map} +1 -1
  35. package/dist/{chunk-5YNIOIKK.js → chunk-4EV5UN6V.js} +3 -3
  36. package/dist/{chunk-5YNIOIKK.js.map → chunk-4EV5UN6V.js.map} +1 -1
  37. package/dist/{chunk-KTCP23W6.js → chunk-5JDHVXPE.js} +3 -3
  38. package/dist/{chunk-KTCP23W6.js.map → chunk-5JDHVXPE.js.map} +1 -1
  39. package/dist/{chunk-QERWC7U6.js → chunk-5VI5F5XA.js} +3 -3
  40. package/dist/{chunk-QERWC7U6.js.map → chunk-5VI5F5XA.js.map} +1 -1
  41. package/dist/{chunk-AG7VY6MJ.cjs → chunk-64B7FGFP.cjs} +8 -8
  42. package/dist/{chunk-AG7VY6MJ.cjs.map → chunk-64B7FGFP.cjs.map} +1 -1
  43. package/dist/{chunk-ILCWDAKD.js → chunk-66GE7TI3.js} +3 -3
  44. package/dist/{chunk-ILCWDAKD.js.map → chunk-66GE7TI3.js.map} +1 -1
  45. package/dist/{chunk-CCMLOCTH.js → chunk-6H34P4AG.js} +3 -3
  46. package/dist/{chunk-CCMLOCTH.js.map → chunk-6H34P4AG.js.map} +1 -1
  47. package/dist/{chunk-E43H3A3G.cjs → chunk-6KNS32OH.cjs} +7 -7
  48. package/dist/{chunk-E43H3A3G.cjs.map → chunk-6KNS32OH.cjs.map} +1 -1
  49. package/dist/{chunk-YX6RW6ZW.cjs → chunk-6S2NCXNP.cjs} +6 -6
  50. package/dist/{chunk-YX6RW6ZW.cjs.map → chunk-6S2NCXNP.cjs.map} +1 -1
  51. package/dist/{chunk-QKJUAMRK.cjs → chunk-6XD3VSAM.cjs} +6 -6
  52. package/dist/{chunk-QKJUAMRK.cjs.map → chunk-6XD3VSAM.cjs.map} +1 -1
  53. package/dist/{chunk-WYIIWTIR.cjs → chunk-6XWZSV6M.cjs} +4 -4
  54. package/dist/{chunk-WYIIWTIR.cjs.map → chunk-6XWZSV6M.cjs.map} +1 -1
  55. package/dist/{chunk-UZH6PVHD.js → chunk-7FUQMZGT.js} +4 -4
  56. package/dist/{chunk-UZH6PVHD.js.map → chunk-7FUQMZGT.js.map} +1 -1
  57. package/dist/chunk-7LZVSOZR.cjs +172 -0
  58. package/dist/chunk-7LZVSOZR.cjs.map +1 -0
  59. package/dist/{chunk-VBEZS3Q4.cjs → chunk-7XOK2HLV.cjs} +9 -9
  60. package/dist/{chunk-VBEZS3Q4.cjs.map → chunk-7XOK2HLV.cjs.map} +1 -1
  61. package/dist/{chunk-46ZZTP5B.js → chunk-ACN4JCSF.js} +4 -4
  62. package/dist/{chunk-46ZZTP5B.js.map → chunk-ACN4JCSF.js.map} +1 -1
  63. package/dist/{chunk-EHNX3MG3.cjs → chunk-AOZ47DTE.cjs} +13 -13
  64. package/dist/{chunk-EHNX3MG3.cjs.map → chunk-AOZ47DTE.cjs.map} +1 -1
  65. package/dist/{chunk-4XVJYNOT.js → chunk-AYEXPYFE.js} +4 -4
  66. package/dist/{chunk-4XVJYNOT.js.map → chunk-AYEXPYFE.js.map} +1 -1
  67. package/dist/{chunk-FZIBM3G5.cjs → chunk-BPXEQPZU.cjs} +10 -10
  68. package/dist/{chunk-FZIBM3G5.cjs.map → chunk-BPXEQPZU.cjs.map} +1 -1
  69. package/dist/{chunk-XWN43PZF.cjs → chunk-BQUMYOBP.cjs} +7 -7
  70. package/dist/{chunk-XWN43PZF.cjs.map → chunk-BQUMYOBP.cjs.map} +1 -1
  71. package/dist/{chunk-OFEROCC5.cjs → chunk-CG4KMZRU.cjs} +6 -6
  72. package/dist/{chunk-OFEROCC5.cjs.map → chunk-CG4KMZRU.cjs.map} +1 -1
  73. package/dist/{chunk-2ITF366P.js → chunk-CLBVCWJG.js} +3 -3
  74. package/dist/{chunk-2ITF366P.js.map → chunk-CLBVCWJG.js.map} +1 -1
  75. package/dist/{chunk-OUN3MWRQ.cjs → chunk-CVKWXLXW.cjs} +10 -10
  76. package/dist/{chunk-OUN3MWRQ.cjs.map → chunk-CVKWXLXW.cjs.map} +1 -1
  77. package/dist/{chunk-RJIPFWW7.js → chunk-D4RP2H6A.js} +4 -4
  78. package/dist/{chunk-RJIPFWW7.js.map → chunk-D4RP2H6A.js.map} +1 -1
  79. package/dist/{chunk-K5TPJVOK.js → chunk-DMBUUJGU.js} +3 -3
  80. package/dist/{chunk-K5TPJVOK.js.map → chunk-DMBUUJGU.js.map} +1 -1
  81. package/dist/{chunk-6JNW43SE.js → chunk-DQAFYVCX.js} +5 -5
  82. package/dist/{chunk-6JNW43SE.js.map → chunk-DQAFYVCX.js.map} +1 -1
  83. package/dist/{chunk-RHTVKBRC.cjs → chunk-EXA5HCX7.cjs} +9 -9
  84. package/dist/{chunk-RHTVKBRC.cjs.map → chunk-EXA5HCX7.cjs.map} +1 -1
  85. package/dist/{chunk-RWQH5EO5.cjs → chunk-F3TVVAYG.cjs} +11 -11
  86. package/dist/{chunk-RWQH5EO5.cjs.map → chunk-F3TVVAYG.cjs.map} +1 -1
  87. package/dist/{chunk-HFWO37RY.cjs → chunk-FCDKWHIV.cjs} +8 -8
  88. package/dist/{chunk-HFWO37RY.cjs.map → chunk-FCDKWHIV.cjs.map} +1 -1
  89. package/dist/{chunk-FSDI3NJV.js → chunk-FWKYNE3A.js} +3 -3
  90. package/dist/{chunk-FSDI3NJV.js.map → chunk-FWKYNE3A.js.map} +1 -1
  91. package/dist/{chunk-HMB2RIEE.js → chunk-GAXX6YK5.js} +4 -4
  92. package/dist/{chunk-HMB2RIEE.js.map → chunk-GAXX6YK5.js.map} +1 -1
  93. package/dist/{chunk-ZFSFOD5W.cjs → chunk-H2DHSBPO.cjs} +6 -6
  94. package/dist/{chunk-ZFSFOD5W.cjs.map → chunk-H2DHSBPO.cjs.map} +1 -1
  95. package/dist/{chunk-4L62MAZA.js → chunk-I7HB3FBC.js} +5 -5
  96. package/dist/{chunk-4L62MAZA.js.map → chunk-I7HB3FBC.js.map} +1 -1
  97. package/dist/{chunk-YJHB2GHQ.js → chunk-IGIAGPC5.js} +3 -3
  98. package/dist/{chunk-YJHB2GHQ.js.map → chunk-IGIAGPC5.js.map} +1 -1
  99. package/dist/{chunk-RQJRVKAH.js → chunk-ILD5ZZHH.js} +3 -3
  100. package/dist/{chunk-RQJRVKAH.js.map → chunk-ILD5ZZHH.js.map} +1 -1
  101. package/dist/{chunk-FV7R2LLD.js → chunk-IN7SCXMD.js} +4 -4
  102. package/dist/{chunk-FV7R2LLD.js.map → chunk-IN7SCXMD.js.map} +1 -1
  103. package/dist/chunk-IRBGJP2E.js +170 -0
  104. package/dist/chunk-IRBGJP2E.js.map +1 -0
  105. package/dist/{chunk-3SOKHPAO.js → chunk-J6A72I5K.js} +4 -4
  106. package/dist/{chunk-3SOKHPAO.js.map → chunk-J6A72I5K.js.map} +1 -1
  107. package/dist/chunk-JRTD6Y34.cjs +148 -0
  108. package/dist/chunk-JRTD6Y34.cjs.map +1 -0
  109. package/dist/{chunk-ASNAQ35U.js → chunk-K7NVM76W.js} +4 -4
  110. package/dist/{chunk-ASNAQ35U.js.map → chunk-K7NVM76W.js.map} +1 -1
  111. package/dist/chunk-KNUMF6K2.cjs +156 -0
  112. package/dist/chunk-KNUMF6K2.cjs.map +1 -0
  113. package/dist/chunk-KQJZJADP.js +146 -0
  114. package/dist/chunk-KQJZJADP.js.map +1 -0
  115. package/dist/{chunk-YOLF5DYU.js → chunk-KRLKDJPM.js} +4 -4
  116. package/dist/{chunk-YOLF5DYU.js.map → chunk-KRLKDJPM.js.map} +1 -1
  117. package/dist/{chunk-6EGHZDZI.cjs → chunk-KSCMLSUI.cjs} +15 -15
  118. package/dist/{chunk-6EGHZDZI.cjs.map → chunk-KSCMLSUI.cjs.map} +1 -1
  119. package/dist/{chunk-4H2LGLGI.cjs → chunk-KT4LY42Y.cjs} +11 -11
  120. package/dist/{chunk-4H2LGLGI.cjs.map → chunk-KT4LY42Y.cjs.map} +1 -1
  121. package/dist/chunk-KX4ZBUHB.cjs +211 -0
  122. package/dist/chunk-KX4ZBUHB.cjs.map +1 -0
  123. package/dist/{chunk-2MWA7H6J.js → chunk-KXJOIVL5.js} +5 -5
  124. package/dist/{chunk-2MWA7H6J.js.map → chunk-KXJOIVL5.js.map} +1 -1
  125. package/dist/{chunk-4ORSJM2I.js → chunk-LFV46XLH.js} +4 -4
  126. package/dist/{chunk-4ORSJM2I.js.map → chunk-LFV46XLH.js.map} +1 -1
  127. package/dist/{chunk-MPQECPE3.js → chunk-LKSKGQX7.js} +3 -3
  128. package/dist/{chunk-MPQECPE3.js.map → chunk-LKSKGQX7.js.map} +1 -1
  129. package/dist/{chunk-OAL5RS2X.cjs → chunk-LQ26WSLH.cjs} +10 -10
  130. package/dist/{chunk-OAL5RS2X.cjs.map → chunk-LQ26WSLH.cjs.map} +1 -1
  131. package/dist/{chunk-LK2A3HBT.js → chunk-LROB73B4.js} +4 -4
  132. package/dist/{chunk-LK2A3HBT.js.map → chunk-LROB73B4.js.map} +1 -1
  133. package/dist/{chunk-XWCY67K5.js → chunk-LXBBM6IF.js} +4 -4
  134. package/dist/{chunk-XWCY67K5.js.map → chunk-LXBBM6IF.js.map} +1 -1
  135. package/dist/{chunk-RFEKSP62.js → chunk-MCORUYWB.js} +3 -3
  136. package/dist/{chunk-RFEKSP62.js.map → chunk-MCORUYWB.js.map} +1 -1
  137. package/dist/{chunk-F5AOBHQY.js → chunk-MJFCMUIY.js} +4 -4
  138. package/dist/{chunk-F5AOBHQY.js.map → chunk-MJFCMUIY.js.map} +1 -1
  139. package/dist/{chunk-PQCHNZHM.cjs → chunk-NHSPO4BN.cjs} +9 -9
  140. package/dist/{chunk-PQCHNZHM.cjs.map → chunk-NHSPO4BN.cjs.map} +1 -1
  141. package/dist/{chunk-DKXW2FQC.cjs → chunk-NR5NQ6TV.cjs} +10 -10
  142. package/dist/{chunk-DKXW2FQC.cjs.map → chunk-NR5NQ6TV.cjs.map} +1 -1
  143. package/dist/{chunk-GAWIUMAK.cjs → chunk-NRMQMPUE.cjs} +7 -7
  144. package/dist/{chunk-GAWIUMAK.cjs.map → chunk-NRMQMPUE.cjs.map} +1 -1
  145. package/dist/{chunk-LIY7MYRG.js → chunk-NW4JBVY2.js} +4 -4
  146. package/dist/{chunk-LIY7MYRG.js.map → chunk-NW4JBVY2.js.map} +1 -1
  147. package/dist/{chunk-WVQVGQJO.cjs → chunk-OLY33H6E.cjs} +7 -7
  148. package/dist/{chunk-WVQVGQJO.cjs.map → chunk-OLY33H6E.cjs.map} +1 -1
  149. package/dist/{chunk-7ZPHLIFP.cjs → chunk-OUQ63IJQ.cjs} +6 -6
  150. package/dist/{chunk-7ZPHLIFP.cjs.map → chunk-OUQ63IJQ.cjs.map} +1 -1
  151. package/dist/{chunk-TVDQNLGJ.js → chunk-PHFBF5ON.js} +3 -3
  152. package/dist/{chunk-TVDQNLGJ.js.map → chunk-PHFBF5ON.js.map} +1 -1
  153. package/dist/{chunk-NG7DRWWT.cjs → chunk-PL3M46GS.cjs} +6 -6
  154. package/dist/{chunk-NG7DRWWT.cjs.map → chunk-PL3M46GS.cjs.map} +1 -1
  155. package/dist/{chunk-MY4KMVJ5.cjs → chunk-PNHDHEBQ.cjs} +8 -8
  156. package/dist/{chunk-MY4KMVJ5.cjs.map → chunk-PNHDHEBQ.cjs.map} +1 -1
  157. package/dist/{chunk-XN6YS55F.cjs → chunk-PX7MLSIH.cjs} +377 -124
  158. package/dist/chunk-PX7MLSIH.cjs.map +1 -0
  159. package/dist/{chunk-4WQUX2B4.cjs → chunk-QCEC2KBW.cjs} +12 -12
  160. package/dist/{chunk-4WQUX2B4.cjs.map → chunk-QCEC2KBW.cjs.map} +1 -1
  161. package/dist/{chunk-IRUIWMH6.js → chunk-QRVTY6UU.js} +3 -3
  162. package/dist/{chunk-IRUIWMH6.js.map → chunk-QRVTY6UU.js.map} +1 -1
  163. package/dist/chunk-QS6GR2CQ.js +154 -0
  164. package/dist/chunk-QS6GR2CQ.js.map +1 -0
  165. package/dist/{chunk-G6R6MSRF.cjs → chunk-QVQKYVD2.cjs} +8 -8
  166. package/dist/{chunk-G6R6MSRF.cjs.map → chunk-QVQKYVD2.cjs.map} +1 -1
  167. package/dist/{chunk-JNQ4NL3R.cjs → chunk-RIJPMRKC.cjs} +8 -8
  168. package/dist/{chunk-JNQ4NL3R.cjs.map → chunk-RIJPMRKC.cjs.map} +1 -1
  169. package/dist/{chunk-XE5ZYFGM.js → chunk-RKX7GKOU.js} +4 -4
  170. package/dist/{chunk-XE5ZYFGM.js.map → chunk-RKX7GKOU.js.map} +1 -1
  171. package/dist/{chunk-ECB3UPTC.cjs → chunk-ROUFAI5M.cjs} +11 -11
  172. package/dist/{chunk-ECB3UPTC.cjs.map → chunk-ROUFAI5M.cjs.map} +1 -1
  173. package/dist/{chunk-NGKUI7XE.cjs → chunk-S52RCLDQ.cjs} +12 -12
  174. package/dist/{chunk-NGKUI7XE.cjs.map → chunk-S52RCLDQ.cjs.map} +1 -1
  175. package/dist/{chunk-SXVMEC6N.cjs → chunk-SEOHPUXV.cjs} +12 -12
  176. package/dist/{chunk-SXVMEC6N.cjs.map → chunk-SEOHPUXV.cjs.map} +1 -1
  177. package/dist/{chunk-ZY7ETQD6.js → chunk-SI4VJK4A.js} +3 -3
  178. package/dist/{chunk-ZY7ETQD6.js.map → chunk-SI4VJK4A.js.map} +1 -1
  179. package/dist/{chunk-UFMPALRH.js → chunk-SUB5WML4.js} +3 -3
  180. package/dist/{chunk-UFMPALRH.js.map → chunk-SUB5WML4.js.map} +1 -1
  181. package/dist/{chunk-R6ZDSXN7.cjs → chunk-T5NDUMLD.cjs} +8 -8
  182. package/dist/{chunk-R6ZDSXN7.cjs.map → chunk-T5NDUMLD.cjs.map} +1 -1
  183. package/dist/{chunk-YDQDZWZ7.cjs → chunk-TKHYY3B5.cjs} +6 -6
  184. package/dist/{chunk-YDQDZWZ7.cjs.map → chunk-TKHYY3B5.cjs.map} +1 -1
  185. package/dist/{chunk-66BHM3UN.cjs → chunk-TMQ2V5B2.cjs} +10 -10
  186. package/dist/{chunk-66BHM3UN.cjs.map → chunk-TMQ2V5B2.cjs.map} +1 -1
  187. package/dist/{chunk-3V64BDKG.cjs → chunk-TNIMRV3N.cjs} +13 -13
  188. package/dist/{chunk-3V64BDKG.cjs.map → chunk-TNIMRV3N.cjs.map} +1 -1
  189. package/dist/{chunk-7PNCJ4OQ.js → chunk-TUPPYHUR.js} +3 -3
  190. package/dist/{chunk-7PNCJ4OQ.js.map → chunk-TUPPYHUR.js.map} +1 -1
  191. package/dist/{chunk-6UWYKNFN.cjs → chunk-U456ET3M.cjs} +12 -12
  192. package/dist/{chunk-6UWYKNFN.cjs.map → chunk-U456ET3M.cjs.map} +1 -1
  193. package/dist/{chunk-6E6ZDWZD.cjs → chunk-UMS2MPYC.cjs} +10 -10
  194. package/dist/{chunk-6E6ZDWZD.cjs.map → chunk-UMS2MPYC.cjs.map} +1 -1
  195. package/dist/{chunk-YZQROIJY.js → chunk-UNQBXGX5.js} +3 -3
  196. package/dist/{chunk-YZQROIJY.js.map → chunk-UNQBXGX5.js.map} +1 -1
  197. package/dist/{chunk-BT5H3WMI.js → chunk-V3AENTZB.js} +4 -4
  198. package/dist/{chunk-BT5H3WMI.js.map → chunk-V3AENTZB.js.map} +1 -1
  199. package/dist/{chunk-5J26EN5I.js → chunk-V5LLTYOY.js} +4 -4
  200. package/dist/{chunk-5J26EN5I.js.map → chunk-V5LLTYOY.js.map} +1 -1
  201. package/dist/chunk-VALFF4NG.cjs +124 -0
  202. package/dist/chunk-VALFF4NG.cjs.map +1 -0
  203. package/dist/{chunk-V45C74EB.js → chunk-VJT5UA7J.js} +4 -4
  204. package/dist/{chunk-V45C74EB.js.map → chunk-VJT5UA7J.js.map} +1 -1
  205. package/dist/{chunk-UMIJYYF3.cjs → chunk-W626EAS5.cjs} +112 -13
  206. package/dist/chunk-W626EAS5.cjs.map +1 -0
  207. package/dist/{chunk-PVPTFMJJ.js → chunk-WHGNA44O.js} +4 -4
  208. package/dist/{chunk-PVPTFMJJ.js.map → chunk-WHGNA44O.js.map} +1 -1
  209. package/dist/{chunk-TWSWD4PU.js → chunk-WIA4MDRX.js} +3 -3
  210. package/dist/{chunk-TWSWD4PU.js.map → chunk-WIA4MDRX.js.map} +1 -1
  211. package/dist/{chunk-47EP245Y.cjs → chunk-WOYVHVXC.cjs} +7 -7
  212. package/dist/{chunk-47EP245Y.cjs.map → chunk-WOYVHVXC.cjs.map} +1 -1
  213. package/dist/{chunk-CDS2NXGT.cjs → chunk-X5SG6MFS.cjs} +4 -4
  214. package/dist/{chunk-CDS2NXGT.cjs.map → chunk-X5SG6MFS.cjs.map} +1 -1
  215. package/dist/{chunk-MYXLKVJE.js → chunk-XB5K7OYD.js} +361 -108
  216. package/dist/chunk-XB5K7OYD.js.map +1 -0
  217. package/dist/{chunk-DX4FBN3I.js → chunk-XIVC32HU.js} +112 -13
  218. package/dist/chunk-XIVC32HU.js.map +1 -0
  219. package/dist/{chunk-GPSNBZPX.js → chunk-XQ7BTVV3.js} +4 -4
  220. package/dist/{chunk-GPSNBZPX.js.map → chunk-XQ7BTVV3.js.map} +1 -1
  221. package/dist/{chunk-BYB3LQAT.cjs → chunk-YMOQGTGJ.cjs} +9 -9
  222. package/dist/{chunk-BYB3LQAT.cjs.map → chunk-YMOQGTGJ.cjs.map} +1 -1
  223. package/dist/{chunk-EHKHXQ46.cjs → chunk-YOK3JGW5.cjs} +10 -10
  224. package/dist/{chunk-EHKHXQ46.cjs.map → chunk-YOK3JGW5.cjs.map} +1 -1
  225. package/dist/{chunk-XKERO5K2.js → chunk-YUIHMAHA.js} +3 -3
  226. package/dist/{chunk-XKERO5K2.js.map → chunk-YUIHMAHA.js.map} +1 -1
  227. package/dist/chunk-ZBWBLCY2.js +209 -0
  228. package/dist/chunk-ZBWBLCY2.js.map +1 -0
  229. package/dist/{chunk-OAIMES5S.cjs → chunk-ZCLW4B5S.cjs} +17 -17
  230. package/dist/{chunk-OAIMES5S.cjs.map → chunk-ZCLW4B5S.cjs.map} +1 -1
  231. package/dist/combo.cjs +9 -9
  232. package/dist/combo.js +4 -4
  233. package/dist/custom.cjs +10 -10
  234. package/dist/custom.js +5 -5
  235. package/dist/donut.cjs +11 -11
  236. package/dist/donut.js +6 -6
  237. package/dist/dumbbell.cjs +10 -10
  238. package/dist/dumbbell.js +5 -5
  239. package/dist/funnel.cjs +10 -10
  240. package/dist/funnel.js +5 -5
  241. package/dist/gauge.cjs +10 -10
  242. package/dist/gauge.js +5 -5
  243. package/dist/geo.cjs +12 -12
  244. package/dist/geo.js +5 -5
  245. package/dist/graph-type-Cyb5U1y2.d.ts +5 -0
  246. package/dist/graph-type-DRbMI2E9.d.cts +5 -0
  247. package/dist/graph.cjs +10 -10
  248. package/dist/graph.d.cts +1 -1
  249. package/dist/graph.d.ts +1 -1
  250. package/dist/graph.js +5 -5
  251. package/dist/heatmap.cjs +10 -10
  252. package/dist/heatmap.js +5 -5
  253. package/dist/histogram.cjs +9 -9
  254. package/dist/histogram.js +4 -4
  255. package/dist/horizontal-bar.cjs +9 -9
  256. package/dist/horizontal-bar.js +4 -4
  257. package/dist/index.cjs +242 -192
  258. package/dist/index.cjs.map +1 -1
  259. package/dist/index.d.cts +16 -2
  260. package/dist/index.d.ts +16 -2
  261. package/dist/index.js +123 -93
  262. package/dist/index.js.map +1 -1
  263. package/dist/kagi.cjs +10 -10
  264. package/dist/kagi.js +5 -5
  265. package/dist/line.cjs +9 -9
  266. package/dist/line.js +4 -4
  267. package/dist/lines.cjs +10 -10
  268. package/dist/lines.js +5 -5
  269. package/dist/lollipop.cjs +9 -9
  270. package/dist/lollipop.js +4 -4
  271. package/dist/matrix.cjs +10 -10
  272. package/dist/matrix.js +5 -5
  273. package/dist/ohlc.cjs +9 -9
  274. package/dist/ohlc.js +4 -4
  275. package/dist/pack-type-CdtdkPBR.d.cts +10 -0
  276. package/dist/pack-type-Dm27RLC-.d.ts +10 -0
  277. package/dist/pack.cjs +33 -0
  278. package/dist/pack.cjs.map +1 -0
  279. package/dist/pack.d.cts +8 -0
  280. package/dist/pack.d.ts +8 -0
  281. package/dist/pack.js +12 -0
  282. package/dist/pack.js.map +1 -0
  283. package/dist/parallel.cjs +10 -10
  284. package/dist/parallel.js +5 -5
  285. package/dist/pictorialbar.cjs +10 -10
  286. package/dist/pictorialbar.js +5 -5
  287. package/dist/pie.cjs +11 -11
  288. package/dist/pie.js +6 -6
  289. package/dist/pillar-type-CIcSuZdu.d.cts +11 -0
  290. package/dist/pillar-type-DNpR_98h.d.ts +11 -0
  291. package/dist/pillar.cjs +33 -0
  292. package/dist/pillar.cjs.map +1 -0
  293. package/dist/pillar.d.cts +8 -0
  294. package/dist/pillar.d.ts +8 -0
  295. package/dist/pillar.js +12 -0
  296. package/dist/pillar.js.map +1 -0
  297. package/dist/polar.cjs +11 -11
  298. package/dist/polar.js +6 -6
  299. package/dist/radar.cjs +10 -10
  300. package/dist/radar.js +5 -5
  301. package/dist/radialbar.cjs +10 -10
  302. package/dist/radialbar.js +5 -5
  303. package/dist/range.cjs +9 -9
  304. package/dist/range.js +4 -4
  305. package/dist/renko.cjs +10 -10
  306. package/dist/renko.js +5 -5
  307. package/dist/sankey.cjs +10 -10
  308. package/dist/sankey.js +5 -5
  309. package/dist/scatter.cjs +9 -9
  310. package/dist/scatter.js +4 -4
  311. package/dist/sparkline.cjs +9 -9
  312. package/dist/sparkline.js +4 -4
  313. package/dist/stacked-bar.cjs +9 -9
  314. package/dist/stacked-bar.js +4 -4
  315. package/dist/step.cjs +10 -10
  316. package/dist/step.js +5 -5
  317. package/dist/sunburst.cjs +11 -11
  318. package/dist/sunburst.js +6 -6
  319. package/dist/themeriver.cjs +10 -10
  320. package/dist/themeriver.js +5 -5
  321. package/dist/tree.cjs +10 -10
  322. package/dist/tree.js +5 -5
  323. package/dist/treemap.cjs +10 -10
  324. package/dist/treemap.js +5 -5
  325. package/dist/violin-type-6KmTiJNp.d.cts +5 -0
  326. package/dist/violin-type-BOmiulQc.d.ts +5 -0
  327. package/dist/violin.cjs +33 -0
  328. package/dist/violin.cjs.map +1 -0
  329. package/dist/violin.d.cts +8 -0
  330. package/dist/violin.d.ts +8 -0
  331. package/dist/violin.js +12 -0
  332. package/dist/violin.js.map +1 -0
  333. package/dist/volume.cjs +9 -9
  334. package/dist/volume.js +4 -4
  335. package/dist/voronoi-type-BU5WnrcT.d.cts +12 -0
  336. package/dist/voronoi-type-D7n4mFNp.d.ts +12 -0
  337. package/dist/voronoi.cjs +33 -0
  338. package/dist/voronoi.cjs.map +1 -0
  339. package/dist/voronoi.d.cts +8 -0
  340. package/dist/voronoi.d.ts +8 -0
  341. package/dist/voronoi.js +12 -0
  342. package/dist/voronoi.js.map +1 -0
  343. package/dist/waterfall.cjs +9 -9
  344. package/dist/waterfall.js +4 -4
  345. package/dist/wordcloud-type-C6X9ORRR.d.ts +11 -0
  346. package/dist/wordcloud-type-CCm8rWK7.d.cts +11 -0
  347. package/dist/wordcloud.cjs +33 -0
  348. package/dist/wordcloud.cjs.map +1 -0
  349. package/dist/wordcloud.d.cts +8 -0
  350. package/dist/wordcloud.d.ts +8 -0
  351. package/dist/wordcloud.js +12 -0
  352. package/dist/wordcloud.js.map +1 -0
  353. package/package.json +1 -1
  354. package/dist/chunk-DX4FBN3I.js.map +0 -1
  355. package/dist/chunk-MYXLKVJE.js.map +0 -1
  356. package/dist/chunk-UMIJYYF3.cjs.map +0 -1
  357. package/dist/chunk-XN6YS55F.cjs.map +0 -1
  358. package/dist/graph-type-Bg04GFeS.d.ts +0 -15
  359. package/dist/graph-type-DF-vww8T.d.cts +0 -15
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/charts/wordcloud/wordcloud-type.ts"],"names":[],"mappings":"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","file":"chunk-2OWMJBRN.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { text } from '../../render/tree'\n\n/**\n * Word Cloud chart — words sized proportional to their value.\n *\n * Labels are the words, series[0] values control font size.\n * Uses Archimedean spiral placement with bounding-box collision detection.\n */\nexport const wordcloudChartType: ChartTypePlugin = {\n type: 'wordcloud',\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 values = series.values\n const maxVal = Math.max(...values.map(Math.abs))\n const minVal = Math.min(...values.filter(v => v > 0))\n const valRange = maxVal - minVal || 1\n\n // Map values to font sizes\n const minFont = Math.max(10, area.height * 0.03)\n const maxFont = Math.min(area.height * 0.15, area.width * 0.08)\n\n const items = values\n .map((v, i) => ({\n index: i,\n label: String(data.labels[i] ?? ''),\n value: Math.abs(v),\n fontSize: minFont + ((Math.abs(v) - minVal) / valRange) * (maxFont - minFont),\n }))\n .filter(d => d.value > 0 && d.label.length > 0)\n .sort((a, b) => b.value - a.value)\n\n if (items.length === 0) return nodes\n\n // Place words using Archimedean spiral\n const placed = placeWords(items, area)\n\n for (let idx = 0; idx < placed.length; idx++) {\n const pw = placed[idx]!\n const color = options.colors[pw.index % options.colors.length]!\n const opacity = 0.5 + (pw.value - minVal) / valRange * 0.5\n\n nodes.push(text(pw.x, pw.y, pw.label, {\n class: 'chartts-wordcloud-word',\n fill: color,\n fillOpacity: opacity,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: pw.fontSize,\n fontFamily: theme.fontFamily,\n fontWeight: pw.fontSize > (minFont + maxFont) / 2 ? 700 : 500,\n style: `--chartts-i:${idx}`,\n 'data-series': 0,\n 'data-index': pw.index,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${pw.label}: ${pw.value}`,\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 values = series.values\n const maxVal = Math.max(...values.map(Math.abs))\n const minVal = Math.min(...values.filter(v => v > 0))\n const valRange = maxVal - minVal || 1\n const minFont = Math.max(10, area.height * 0.03)\n const maxFont = Math.min(area.height * 0.15, area.width * 0.08)\n\n const items = values\n .map((v, i) => ({\n index: i,\n label: String(data.labels[i] ?? ''),\n value: Math.abs(v),\n fontSize: minFont + ((Math.abs(v) - minVal) / valRange) * (maxFont - minFont),\n }))\n .filter(d => d.value > 0 && d.label.length > 0)\n .sort((a, b) => b.value - a.value)\n\n const placed = placeWords(items, area)\n\n // Check bounding boxes (smallest first for specificity)\n for (let i = placed.length - 1; i >= 0; i--) {\n const pw = placed[i]!\n const halfW = pw.label.length * pw.fontSize * 0.35\n const halfH = pw.fontSize * 0.6\n\n if (mx >= pw.x - halfW && mx <= pw.x + halfW &&\n my >= pw.y - halfH && my <= pw.y + halfH) {\n return { seriesIndex: 0, pointIndex: pw.index, distance: 0, x: pw.x, y: pw.y }\n }\n }\n\n return null\n },\n}\n\ninterface WordItem {\n index: number\n label: string\n value: number\n fontSize: number\n}\n\ninterface PlacedWord extends WordItem {\n x: number\n y: number\n}\n\ninterface BBox {\n x1: number; y1: number; x2: number; y2: number\n}\n\nfunction placeWords(\n items: WordItem[],\n area: { x: number; y: number; width: number; height: number },\n): PlacedWord[] {\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const placed: PlacedWord[] = []\n const boxes: BBox[] = []\n\n for (const item of items) {\n // Approximate word bbox dimensions\n const halfW = item.label.length * item.fontSize * 0.35\n const halfH = item.fontSize * 0.6\n\n // Archimedean spiral search\n let found = false\n for (let t = 0; t < 600; t++) {\n const angle = t * 0.15\n const r = 2 * angle\n const x = cx + r * Math.cos(angle) * (area.width / area.height)\n const y = cy + r * Math.sin(angle)\n\n // Check bounds\n if (x - halfW < area.x || x + halfW > area.x + area.width ||\n y - halfH < area.y || y + halfH > area.y + area.height) {\n continue\n }\n\n // Check overlap with placed words\n const newBox: BBox = { x1: x - halfW, y1: y - halfH, x2: x + halfW, y2: y + halfH }\n let overlaps = false\n\n for (const box of boxes) {\n if (newBox.x1 < box.x2 && newBox.x2 > box.x1 &&\n newBox.y1 < box.y2 && newBox.y2 > box.y1) {\n overlaps = true\n break\n }\n }\n\n if (!overlaps) {\n placed.push({ ...item, x, y })\n boxes.push(newBox)\n found = true\n break\n }\n }\n\n // Skip words that don't fit\n if (!found) continue\n }\n\n return placed\n}\n"]}
@@ -1,5 +1,5 @@
1
- import { prepareNoAxes } from './chunk-MPQECPE3.js';
2
- import { text } from './chunk-DX4FBN3I.js';
1
+ import { prepareNoAxes } from './chunk-LKSKGQX7.js';
2
+ import { text } from './chunk-XIVC32HU.js';
3
3
 
4
4
  // src/charts/custom/custom-type.ts
5
5
  var customChartType = {
@@ -46,5 +46,5 @@ var customChartType = {
46
46
  };
47
47
 
48
48
  export { customChartType };
49
- //# sourceMappingURL=chunk-DR5MQC3W.js.map
50
- //# sourceMappingURL=chunk-DR5MQC3W.js.map
49
+ //# sourceMappingURL=chunk-2VHG2N75.js.map
50
+ //# sourceMappingURL=chunk-2VHG2N75.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/custom/custom-type.ts"],"names":[],"mappings":";;;;AAwBO,IAAM,eAAA,GAAmC;AAAA,EAC9C,IAAA,EAAM,QAAA;AAAA,EAEN,aAAA,CAAc,OAAmB,OAAA,EAA2D;AAC1F,IAAA,MAAM,KAAA,GAAQ,OAAA;AACd,IAAA,OAAO,OAAO,UAAA,IAAc,EAAE,CAAA,EAAG,aAAA,EAAe,GAAG,QAAA,EAAS;AAAA,EAC9D,CAAA;AAAA,EAEA,WAAA,CAAY,MAAiB,OAAA,EAAwC;AACnE,IAAA,OAAO,aAAA,CAAc,MAAM,OAAO,CAAA;AAAA,EACpC,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,MAAM,QAAQ,GAAA,CAAI,OAAA;AAElB,IAAA,IAAI,MAAM,QAAA,EAAU;AAClB,MAAA,OAAO,KAAA,CAAM,SAAS,GAAG,CAAA;AAAA,IAC3B;AAGA,IAAA,MAAM,EAAE,IAAA,EAAM,KAAA,EAAM,GAAI,GAAA;AACxB,IAAA,OAAO;AAAA,MACL,IAAA;AAAA,QACE,IAAA,CAAK,CAAA,GAAI,IAAA,CAAK,KAAA,GAAQ,CAAA;AAAA,QACtB,IAAA,CAAK,CAAA,GAAI,IAAA,CAAK,MAAA,GAAS,CAAA;AAAA,QACvB,iDAAA;AAAA,QACA;AAAA,UACE,KAAA,EAAO,4BAAA;AAAA,UACP,MAAM,KAAA,CAAM,SAAA;AAAA,UACZ,UAAA,EAAY,QAAA;AAAA,UACZ,gBAAA,EAAkB,SAAA;AAAA,UAClB,UAAU,KAAA,CAAM,QAAA;AAAA,UAChB,YAAY,KAAA,CAAM;AAAA;AACpB;AACF,KACF;AAAA,EACF,CAAA;AAAA,EAEA,OAAA,CAAQ,GAAA,EAAoB,EAAA,EAAY,EAAA,EAA8B;AACpE,IAAA,MAAM,QAAQ,GAAA,CAAI,OAAA;AAClB,IAAA,IAAI,MAAM,SAAA,EAAW;AACnB,MAAA,MAAM,MAAA,GAAS,KAAA,CAAM,SAAA,CAAU,GAAA,EAAK,IAAI,EAAE,CAAA;AAC1C,MAAA,IAAI,MAAA,IAAU,MAAA,CAAO,CAAA,KAAM,MAAA,SAAkB,CAAA,GAAI,EAAA;AACjD,MAAA,IAAI,MAAA,IAAU,MAAA,CAAO,CAAA,KAAM,MAAA,SAAkB,CAAA,GAAI,EAAA;AACjD,MAAA,OAAO,MAAA;AAAA,IACT;AACA,IAAA,OAAO,IAAA;AAAA,EACT;AACF","file":"chunk-DR5MQC3W.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { text } from '../../render/tree'\n\n/**\n * Custom chart — meta chart type that delegates rendering to a user function.\n *\n * Options:\n * - renderFn: (ctx: RenderContext) => RenderNode[]\n * - hitTestFn: (ctx: RenderContext, mx: number, my: number) => HitResult | null\n * - scaleTypes: { x: ScaleType; y: ScaleType } (default categorical/linear)\n *\n * If no renderFn is provided, renders a placeholder message.\n */\n\nexport interface CustomChartOptions {\n renderFn?: (ctx: RenderContext) => RenderNode[]\n hitTestFn?: (ctx: RenderContext, mx: number, my: number) => HitResult | null\n scaleTypes?: { x: ScaleType; y: ScaleType }\n}\n\nexport const customChartType: ChartTypePlugin = {\n type: 'custom',\n\n getScaleTypes(_data?: ChartData, options?: ResolvedOptions): { x: ScaleType; y: ScaleType } {\n const cOpts = options as unknown as CustomChartOptions | undefined\n return cOpts?.scaleTypes ?? { 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 cOpts = ctx.options as unknown as CustomChartOptions\n\n if (cOpts.renderFn) {\n return cOpts.renderFn(ctx)\n }\n\n // Placeholder when no render function is provided\n const { area, theme } = ctx\n return [\n text(\n area.x + area.width / 2,\n area.y + area.height / 2,\n 'Custom chart — provide renderFn in options',\n {\n class: 'chartts-custom-placeholder',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: theme.fontSize,\n fontFamily: theme.fontFamily,\n },\n ),\n ]\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const cOpts = ctx.options as unknown as CustomChartOptions\n if (cOpts.hitTestFn) {\n const result = cOpts.hitTestFn(ctx, mx, my)\n if (result && result.x === undefined) result.x = mx\n if (result && result.y === undefined) result.y = my\n return result\n }\n return null\n },\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/custom/custom-type.ts"],"names":[],"mappings":";;;;AAwBO,IAAM,eAAA,GAAmC;AAAA,EAC9C,IAAA,EAAM,QAAA;AAAA,EAEN,aAAA,CAAc,OAAmB,OAAA,EAA2D;AAC1F,IAAA,MAAM,KAAA,GAAQ,OAAA;AACd,IAAA,OAAO,OAAO,UAAA,IAAc,EAAE,CAAA,EAAG,aAAA,EAAe,GAAG,QAAA,EAAS;AAAA,EAC9D,CAAA;AAAA,EAEA,WAAA,CAAY,MAAiB,OAAA,EAAwC;AACnE,IAAA,OAAO,aAAA,CAAc,MAAM,OAAO,CAAA;AAAA,EACpC,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,MAAM,QAAQ,GAAA,CAAI,OAAA;AAElB,IAAA,IAAI,MAAM,QAAA,EAAU;AAClB,MAAA,OAAO,KAAA,CAAM,SAAS,GAAG,CAAA;AAAA,IAC3B;AAGA,IAAA,MAAM,EAAE,IAAA,EAAM,KAAA,EAAM,GAAI,GAAA;AACxB,IAAA,OAAO;AAAA,MACL,IAAA;AAAA,QACE,IAAA,CAAK,CAAA,GAAI,IAAA,CAAK,KAAA,GAAQ,CAAA;AAAA,QACtB,IAAA,CAAK,CAAA,GAAI,IAAA,CAAK,MAAA,GAAS,CAAA;AAAA,QACvB,iDAAA;AAAA,QACA;AAAA,UACE,KAAA,EAAO,4BAAA;AAAA,UACP,MAAM,KAAA,CAAM,SAAA;AAAA,UACZ,UAAA,EAAY,QAAA;AAAA,UACZ,gBAAA,EAAkB,SAAA;AAAA,UAClB,UAAU,KAAA,CAAM,QAAA;AAAA,UAChB,YAAY,KAAA,CAAM;AAAA;AACpB;AACF,KACF;AAAA,EACF,CAAA;AAAA,EAEA,OAAA,CAAQ,GAAA,EAAoB,EAAA,EAAY,EAAA,EAA8B;AACpE,IAAA,MAAM,QAAQ,GAAA,CAAI,OAAA;AAClB,IAAA,IAAI,MAAM,SAAA,EAAW;AACnB,MAAA,MAAM,MAAA,GAAS,KAAA,CAAM,SAAA,CAAU,GAAA,EAAK,IAAI,EAAE,CAAA;AAC1C,MAAA,IAAI,MAAA,IAAU,MAAA,CAAO,CAAA,KAAM,MAAA,SAAkB,CAAA,GAAI,EAAA;AACjD,MAAA,IAAI,MAAA,IAAU,MAAA,CAAO,CAAA,KAAM,MAAA,SAAkB,CAAA,GAAI,EAAA;AACjD,MAAA,OAAO,MAAA;AAAA,IACT;AACA,IAAA,OAAO,IAAA;AAAA,EACT;AACF","file":"chunk-2VHG2N75.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { text } from '../../render/tree'\n\n/**\n * Custom chart — meta chart type that delegates rendering to a user function.\n *\n * Options:\n * - renderFn: (ctx: RenderContext) => RenderNode[]\n * - hitTestFn: (ctx: RenderContext, mx: number, my: number) => HitResult | null\n * - scaleTypes: { x: ScaleType; y: ScaleType } (default categorical/linear)\n *\n * If no renderFn is provided, renders a placeholder message.\n */\n\nexport interface CustomChartOptions {\n renderFn?: (ctx: RenderContext) => RenderNode[]\n hitTestFn?: (ctx: RenderContext, mx: number, my: number) => HitResult | null\n scaleTypes?: { x: ScaleType; y: ScaleType }\n}\n\nexport const customChartType: ChartTypePlugin = {\n type: 'custom',\n\n getScaleTypes(_data?: ChartData, options?: ResolvedOptions): { x: ScaleType; y: ScaleType } {\n const cOpts = options as unknown as CustomChartOptions | undefined\n return cOpts?.scaleTypes ?? { 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 cOpts = ctx.options as unknown as CustomChartOptions\n\n if (cOpts.renderFn) {\n return cOpts.renderFn(ctx)\n }\n\n // Placeholder when no render function is provided\n const { area, theme } = ctx\n return [\n text(\n area.x + area.width / 2,\n area.y + area.height / 2,\n 'Custom chart — provide renderFn in options',\n {\n class: 'chartts-custom-placeholder',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: theme.fontSize,\n fontFamily: theme.fontFamily,\n },\n ),\n ]\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const cOpts = ctx.options as unknown as CustomChartOptions\n if (cOpts.hitTestFn) {\n const result = cOpts.hitTestFn(ctx, mx, my)\n if (result && result.x === undefined) result.x = mx\n if (result && result.y === undefined) result.y = my\n return result\n }\n return null\n },\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { PathBuilder, path, circle, CSS_PREFIX, group, prepareData } from './chunk-DX4FBN3I.js';
1
+ import { PathBuilder, path, circle, CSS_PREFIX, group, prepareData } from './chunk-XIVC32HU.js';
2
2
 
3
3
  // src/charts/range/range-type.ts
4
4
  var rangeChartType = {
@@ -151,5 +151,5 @@ function buildLinePath(values, xScale, yScale) {
151
151
  }
152
152
 
153
153
  export { rangeChartType };
154
- //# sourceMappingURL=chunk-RN7NNB6I.js.map
155
- //# sourceMappingURL=chunk-RN7NNB6I.js.map
154
+ //# sourceMappingURL=chunk-2X7UIG3G.js.map
155
+ //# sourceMappingURL=chunk-2X7UIG3G.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/range/range-type.ts"],"names":[],"mappings":"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","file":"chunk-RN7NNB6I.js","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, x, y }\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":[],"mappings":"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","file":"chunk-2X7UIG3G.js","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, x, y }\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,15 +1,15 @@
1
1
  'use strict';
2
2
 
3
- var chunkUMIJYYF3_cjs = require('./chunk-UMIJYYF3.cjs');
3
+ var chunkW626EAS5_cjs = require('./chunk-W626EAS5.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 chunkUMIJYYF3_cjs.createChart(target, chartType, data, options);
9
+ return chunkW626EAS5_cjs.createChart(target, chartType, data, options);
10
10
  };
11
11
  }
12
12
 
13
13
  exports.createConvenience = createConvenience;
14
- //# sourceMappingURL=chunk-ZTUKOCJN.cjs.map
15
- //# sourceMappingURL=chunk-ZTUKOCJN.cjs.map
14
+ //# sourceMappingURL=chunk-35XUPEAD.cjs.map
15
+ //# sourceMappingURL=chunk-35XUPEAD.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-ZTUKOCJN.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-35XUPEAD.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,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- var chunkUMIJYYF3_cjs = require('./chunk-UMIJYYF3.cjs');
3
+ var chunkW626EAS5_cjs = require('./chunk-W626EAS5.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 = chunkUMIJYYF3_cjs.prepareData(data, options);
14
+ const prepared = chunkW626EAS5_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 chunkUMIJYYF3_cjs.PathBuilder();
41
+ const pb = new chunkW626EAS5_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(chunkUMIJYYF3_cjs.path(pb.build(), {
60
+ seriesNodes.push(chunkW626EAS5_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(chunkUMIJYYF3_cjs.path(upperPath, {
67
+ seriesNodes.push(chunkW626EAS5_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(chunkUMIJYYF3_cjs.path(lowerPath, {
76
+ seriesNodes.push(chunkW626EAS5_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(chunkUMIJYYF3_cjs.path(centerPath, {
86
+ seriesNodes.push(chunkW626EAS5_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(chunkUMIJYYF3_cjs.circle(x, y, theme.pointRadius, {
97
+ seriesNodes.push(chunkW626EAS5_cjs.circle(x, y, theme.pointRadius, {
98
98
  class: "chartts-point",
99
99
  fill: series.color,
100
- stroke: `var(${chunkUMIJYYF3_cjs.CSS_PREFIX}-bg, #fff)`,
100
+ stroke: `var(${chunkW626EAS5_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(chunkUMIJYYF3_cjs.group(seriesNodes, {
111
+ nodes.push(chunkW626EAS5_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 chunkUMIJYYF3_cjs.PathBuilder();
138
+ const pb = new chunkW626EAS5_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-2EZ2TVYT.cjs.map
157
- //# sourceMappingURL=chunk-2EZ2TVYT.cjs.map
156
+ //# sourceMappingURL=chunk-3HBRAGJA.cjs.map
157
+ //# sourceMappingURL=chunk-3HBRAGJA.cjs.map
@@ -1 +1 @@
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-2EZ2TVYT.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, x, y }\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-3HBRAGJA.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, x, y }\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,5 +1,5 @@
1
1
  import { formatNum } from './chunk-OGSZO22B.js';
2
- import { path, circle, CSS_PREFIX, group, prepareData, PathBuilder } from './chunk-DX4FBN3I.js';
2
+ import { path, circle, CSS_PREFIX, group, prepareData, PathBuilder } from './chunk-XIVC32HU.js';
3
3
 
4
4
  // src/charts/line/line-type.ts
5
5
  var lineChartType = {
@@ -183,5 +183,5 @@ function buildMonotonePath(points) {
183
183
  }
184
184
 
185
185
  export { lineChartType };
186
- //# sourceMappingURL=chunk-WJP6CRML.js.map
187
- //# sourceMappingURL=chunk-WJP6CRML.js.map
186
+ //# sourceMappingURL=chunk-45Y77XDM.js.map
187
+ //# sourceMappingURL=chunk-45Y77XDM.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/line/line-type.ts"],"names":[],"mappings":";;;;AAUO,IAAM,aAAA,GAAiC;AAAA,EAC5C,IAAA,EAAM,MAAA;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,OAAO,WAAA,CAAY,MAAM,OAAO,CAAA;AAAA,EAClC,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,MAAM,EAAE,IAAA,EAAM,OAAA,EAAS,MAAM,MAAA,EAAQ,MAAA,EAAQ,OAAM,GAAI,GAAA;AACvD,IAAA,MAAM,QAAsB,EAAC;AAE7B,IAAA,KAAA,MAAW,MAAA,IAAU,KAAK,MAAA,EAAQ;AAChC,MAAA,MAAM,cAA4B,EAAC;AAGnC,MAAA,MAAM,WAAW,aAAA,CAAc,MAAA,CAAO,QAAQ,MAAA,EAAQ,MAAA,EAAQ,QAAQ,KAAK,CAAA;AAG3E,MAAA,IAAI,OAAO,IAAA,EAAM;AACf,QAAA,MAAM,QAAA,GAAW,aAAA;AAAA,UACf,MAAA,CAAO,MAAA;AAAA,UAAQ,MAAA;AAAA,UAAQ,MAAA;AAAA,UAAQ,IAAA;AAAA,UAAM,OAAA,CAAQ;AAAA,SAC/C;AACA,QAAA,WAAA,CAAY,IAAA,CAAK,KAAK,QAAA,EAAU;AAAA,UAC9B,KAAA,EAAO,cAAA;AAAA,UACP,IAAA,EAAM,CAAA,kBAAA,EAAqB,MAAA,CAAO,KAAK,CAAA,CAAA,CAAA;AAAA,UACvC,eAAe,MAAA,CAAO;AAAA,SACvB,CAAC,CAAA;AAAA,MACJ;AAEA,MAAA,MAAM,IAAA,GAAO,OAAO,KAAA,KAAU,QAAA,GAAW,QACrC,MAAA,CAAO,KAAA,KAAU,WAAW,KAAA,GAAQ,MAAA;AAGxC,MAAA,WAAA,CAAY,IAAA,CAAK,KAAK,QAAA,EAAU;AAAA,QAC9B,KAAA,EAAO,cAAA;AAAA,QACP,QAAQ,MAAA,CAAO,KAAA;AAAA,QACf,aAAa,KAAA,CAAM,SAAA;AAAA,QACnB,eAAA,EAAiB,IAAA;AAAA,QACjB,eAAe,MAAA,CAAO;AAAA,OACvB,CAAC,CAAA;AAGF,MAAA,IAAI,OAAO,UAAA,EAAY;AACrB,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;AAGtC,UAAA,WAAA,CAAY,KAAK,MAAA,CAAO,CAAA,EAAG,CAAA,EAAG,KAAA,CAAM,cAAc,CAAA,EAAG;AAAA,YACnD,KAAA,EAAO,oBAAA;AAAA,YACP,IAAA,EAAM,CAAA,mBAAA,EAAsB,MAAA,CAAO,KAAK,CAAA,CAAA;AAAA,WACzC,CAAC,CAAA;AAEF,UAAA,WAAA,CAAY,IAAA,CAAK,MAAA,CAAO,CAAA,EAAG,CAAA,EAAG,MAAM,WAAA,EAAa;AAAA,YAC/C,KAAA,EAAO,eAAA;AAAA,YACP,MAAM,MAAA,CAAO,KAAA;AAAA,YACb,MAAA,EAAQ,OAAO,UAAU,CAAA,UAAA,CAAA;AAAA,YACzB,WAAA,EAAa,CAAA;AAAA,YACb,eAAe,MAAA,CAAO,KAAA;AAAA,YACtB,YAAA,EAAc,CAAA;AAAA,YACd,QAAA,EAAU,CAAA;AAAA,YACV,IAAA,EAAM,KAAA;AAAA,YACN,SAAA,EAAW,GAAG,MAAA,CAAO,IAAI,KAAK,MAAA,CAAO,MAAA,CAAO,CAAC,CAAC,CAAA;AAAA,WAC/C,CAAC,CAAA;AAAA,QACJ;AAAA,MACF;AAEA,MAAA,KAAA,CAAM,IAAA,CAAK,MAAM,WAAA,EAAa;AAAA,QAC5B,KAAA,EAAO,CAAA,8BAAA,EAAiC,MAAA,CAAO,KAAK,CAAA,CAAA;AAAA,QACpD,oBAAoB,MAAA,CAAO;AAAA,OAC5B,CAAC,CAAA;AAAA,IACJ;AAEA,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,IAAI,IAAA,GAAyB,IAAA;AAC7B,IAAA,IAAI,QAAA,GAAW,QAAA;AAEf,IAAA,KAAA,MAAW,MAAA,IAAU,KAAK,MAAA,EAAQ;AAChC,MAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AAC7C,QAAA,IAAI,KAAA,CAAM,MAAA,CAAO,MAAA,CAAO,CAAC,CAAE,CAAA,EAAG;AAC9B,QAAA,MAAM,CAAA,GAAI,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA;AACtB,QAAA,MAAM,IAAI,MAAA,CAAO,GAAA,CAAI,MAAA,CAAO,MAAA,CAAO,CAAC,CAAE,CAAA;AACtC,QAAA,MAAM,IAAA,GAAO,KAAK,IAAA,CAAA,CAAM,EAAA,GAAK,MAAM,CAAA,GAAA,CAAK,EAAA,GAAK,MAAM,CAAC,CAAA;AACpD,QAAA,IAAI,OAAO,QAAA,EAAU;AACnB,UAAA,QAAA,GAAW,IAAA;AACX,UAAA,IAAA,GAAO,EAAE,aAAa,MAAA,CAAO,KAAA,EAAO,YAAY,CAAA,EAAG,QAAA,EAAU,IAAA,EAAM,CAAA,EAAG,CAAA,EAAE;AAAA,QAC1E;AAAA,MACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,IAAQ,IAAA,CAAK,QAAA,GAAW,EAAA,GAAK,IAAA,GAAO,IAAA;AAAA,EAC7C;AACF;AAGA,SAAS,aAAA,CACP,MAAA,EACA,MAAA,EACA,MAAA,EACA,KAAA,EACQ;AACR,EAAA,IAAI,MAAA,CAAO,MAAA,KAAW,CAAA,EAAG,OAAO,EAAA;AAGhC,EAAA,MAAM,WAAyC,EAAC;AAChD,EAAA,IAAI,UAAsC,EAAC;AAC3C,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;AACrB,MAAA,IAAI,OAAA,CAAQ,SAAS,CAAA,EAAG;AAAE,QAAA,QAAA,CAAS,KAAK,OAAO,CAAA;AAAG,QAAA,OAAA,GAAU,EAAC;AAAA,MAAE;AAAA,IACjE,CAAA,MAAO;AACL,MAAA,OAAA,CAAQ,IAAA,CAAK,EAAE,CAAA,EAAG,MAAA,CAAO,IAAI,CAAC,CAAA,EAAG,CAAA,EAAG,MAAA,CAAO,GAAA,CAAI,MAAA,CAAO,CAAC,CAAE,GAAG,CAAA;AAAA,IAC9D;AAAA,EACF;AACA,EAAA,IAAI,OAAA,CAAQ,MAAA,GAAS,CAAA,EAAG,QAAA,CAAS,KAAK,OAAO,CAAA;AAG7C,EAAA,MAAM,UAAU,KAAA,KAAU,MAAA,GAAS,aAAA,GAC/B,KAAA,KAAU,aAAa,iBAAA,GACvB,eAAA;AACJ,EAAA,OAAO,QAAA,CAAS,IAAI,CAAA,CAAA,KAAK,OAAA,CAAQ,CAAC,CAAC,CAAA,CAAE,KAAK,EAAE,CAAA;AAC9C;AAGA,SAAS,aAAA,CACP,MAAA,EACA,MAAA,EACA,MAAA,EACA,MACA,KAAA,EACQ;AACR,EAAA,IAAI,MAAA,CAAO,MAAA,KAAW,CAAA,EAAG,OAAO,EAAA;AAEhC,EAAA,MAAM,QAAA,GAAW,IAAA,CAAK,CAAA,GAAI,IAAA,CAAK,MAAA;AAC/B,EAAA,MAAM,UAAU,KAAA,KAAU,UAAA,GAAa,iBAAA,GACnC,KAAA,KAAU,SAAS,aAAA,GACnB,eAAA;AAGJ,EAAA,MAAM,WAAyC,EAAC;AAChD,EAAA,IAAI,UAAsC,EAAC;AAC3C,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;AACrB,MAAA,IAAI,OAAA,CAAQ,SAAS,CAAA,EAAG;AAAE,QAAA,QAAA,CAAS,KAAK,OAAO,CAAA;AAAG,QAAA,OAAA,GAAU,EAAC;AAAA,MAAE;AAAA,IACjE,CAAA,MAAO;AACL,MAAA,OAAA,CAAQ,IAAA,CAAK,EAAE,CAAA,EAAG,MAAA,CAAO,IAAI,CAAC,CAAA,EAAG,CAAA,EAAG,MAAA,CAAO,GAAA,CAAI,MAAA,CAAO,CAAC,CAAE,GAAG,CAAA;AAAA,IAC9D;AAAA,EACF;AACA,EAAA,IAAI,OAAA,CAAQ,MAAA,GAAS,CAAA,EAAG,QAAA,CAAS,KAAK,OAAO,CAAA;AAG7C,EAAA,OAAO,QAAA,CAAS,IAAI,CAAA,GAAA,KAAO;AACzB,IAAA,MAAM,QAAA,GAAW,QAAQ,GAAG,CAAA;AAC5B,IAAA,MAAM,KAAA,GAAQ,IAAI,CAAC,CAAA;AACnB,IAAA,MAAM,IAAA,GAAO,GAAA,CAAI,GAAA,CAAI,MAAA,GAAS,CAAC,CAAA;AAC/B,IAAA,OAAO,GAAG,QAAQ,CAAA,CAAA,EAAI,UAAU,IAAA,CAAK,CAAC,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,QAAQ,CAAC,CAAA,CAAA,EAAI,UAAU,KAAA,CAAM,CAAC,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,QAAQ,CAAC,CAAA,CAAA,CAAA;AAAA,EAC7G,CAAC,CAAA,CAAE,IAAA,CAAK,EAAE,CAAA;AACZ;AAEA,SAAS,gBAAgB,MAAA,EAA4C;AACnE,EAAA,MAAM,EAAA,GAAK,IAAI,WAAA,EAAY;AAC3B,EAAA,EAAA,CAAG,MAAA,CAAO,OAAO,CAAC,CAAA,CAAG,GAAG,MAAA,CAAO,CAAC,EAAG,CAAC,CAAA;AACpC,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AACtC,IAAA,EAAA,CAAG,MAAA,CAAO,OAAO,CAAC,CAAA,CAAG,GAAG,MAAA,CAAO,CAAC,EAAG,CAAC,CAAA;AAAA,EACtC;AACA,EAAA,OAAO,GAAG,KAAA,EAAM;AAClB;AAEA,SAAS,cAAc,MAAA,EAA4C;AACjE,EAAA,MAAM,EAAA,GAAK,IAAI,WAAA,EAAY;AAC3B,EAAA,EAAA,CAAG,MAAA,CAAO,OAAO,CAAC,CAAA,CAAG,GAAG,MAAA,CAAO,CAAC,EAAG,CAAC,CAAA;AACpC,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AACtC,IAAA,MAAM,IAAA,GAAA,CAAQ,OAAO,CAAA,GAAI,CAAC,EAAG,CAAA,GAAI,MAAA,CAAO,CAAC,CAAA,CAAG,CAAA,IAAK,CAAA;AACjD,IAAA,EAAA,CAAG,GAAA,CAAI,IAAI,CAAA,CAAE,GAAA,CAAI,MAAA,CAAO,CAAC,CAAA,CAAG,CAAC,CAAA,CAAE,GAAA,CAAI,MAAA,CAAO,CAAC,EAAG,CAAC,CAAA;AAAA,EACjD;AACA,EAAA,OAAO,GAAG,KAAA,EAAM;AAClB;AAMA,SAAS,kBAAkB,MAAA,EAA4C;AACrE,EAAA,IAAI,MAAA,CAAO,MAAA,GAAS,CAAA,EAAG,OAAO,gBAAgB,MAAM,CAAA;AACpD,EAAA,IAAI,MAAA,CAAO,MAAA,KAAW,CAAA,EAAG,OAAO,gBAAgB,MAAM,CAAA;AAEtD,EAAA,MAAM,IAAI,MAAA,CAAO,MAAA;AACjB,EAAA,MAAM,KAAe,EAAC;AACtB,EAAA,MAAM,KAAe,EAAC;AACtB,EAAA,MAAM,IAAc,EAAC;AAGrB,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,CAAA,GAAI,GAAG,CAAA,EAAA,EAAK;AAC9B,IAAA,EAAA,CAAG,IAAA,CAAK,OAAO,CAAA,GAAI,CAAC,EAAG,CAAA,GAAI,MAAA,CAAO,CAAC,CAAA,CAAG,CAAC,CAAA;AACvC,IAAA,EAAA,CAAG,IAAA,CAAK,OAAO,CAAA,GAAI,CAAC,EAAG,CAAA,GAAI,MAAA,CAAO,CAAC,CAAA,CAAG,CAAC,CAAA;AACvC,IAAA,CAAA,CAAE,KAAK,EAAA,CAAG,CAAC,KAAM,EAAA,CAAG,CAAC,KAAM,CAAA,CAAE,CAAA;AAAA,EAC/B;AAGA,EAAA,MAAM,QAAA,GAAqB,CAAC,CAAA,CAAE,CAAC,CAAE,CAAA;AACjC,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,CAAA,GAAI,GAAG,CAAA,EAAA,EAAK;AAC9B,IAAA,IAAI,EAAE,CAAA,GAAI,CAAC,IAAK,CAAA,CAAE,CAAC,KAAM,CAAA,EAAG;AAC1B,MAAA,QAAA,CAAS,KAAK,CAAC,CAAA;AAAA,IACjB,CAAA,MAAO;AACL,MAAA,QAAA,CAAS,IAAA,CAAA,CAAM,EAAE,CAAA,GAAI,CAAC,IAAK,CAAA,CAAE,CAAC,KAAM,CAAC,CAAA;AAAA,IACvC;AAAA,EACF;AACA,EAAA,QAAA,CAAS,IAAA,CAAK,CAAA,CAAE,CAAA,GAAI,CAAC,CAAE,CAAA;AAGvB,EAAA,MAAM,EAAA,GAAK,IAAI,WAAA,EAAY;AAC3B,EAAA,EAAA,CAAG,MAAA,CAAO,OAAO,CAAC,CAAA,CAAG,GAAG,MAAA,CAAO,CAAC,EAAG,CAAC,CAAA;AAEpC,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,CAAA,GAAI,GAAG,CAAA,EAAA,EAAK;AAC9B,IAAA,MAAM,CAAA,GAAI,EAAA,CAAG,CAAC,CAAA,GAAK,CAAA;AACnB,IAAA,EAAA,CAAG,OAAA;AAAA,MACD,MAAA,CAAO,CAAC,CAAA,CAAG,CAAA,GAAI,CAAA;AAAA,MACf,OAAO,CAAC,CAAA,CAAG,CAAA,GAAI,QAAA,CAAS,CAAC,CAAA,GAAK,CAAA;AAAA,MAC9B,MAAA,CAAO,CAAA,GAAI,CAAC,CAAA,CAAG,CAAA,GAAI,CAAA;AAAA,MACnB,MAAA,CAAO,IAAI,CAAC,CAAA,CAAG,IAAI,QAAA,CAAS,CAAA,GAAI,CAAC,CAAA,GAAK,CAAA;AAAA,MACtC,MAAA,CAAO,CAAA,GAAI,CAAC,CAAA,CAAG,CAAA;AAAA,MACf,MAAA,CAAO,CAAA,GAAI,CAAC,CAAA,CAAG;AAAA,KACjB;AAAA,EACF;AAEA,EAAA,OAAO,GAAG,KAAA,EAAM;AAClB","file":"chunk-WJP6CRML.js","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'\nimport { formatNum } from '../../utils/format'\n\nexport const lineChartType: ChartTypePlugin = {\n type: 'line',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareData(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, area, xScale, yScale, theme } = ctx\n const nodes: RenderNode[] = []\n\n for (const series of data.series) {\n const seriesNodes: RenderNode[] = []\n\n // Build line path\n const linePath = buildLinePath(series.values, xScale, yScale, options.curve)\n\n // Area fill (if enabled) — use gradient for premium look\n if (series.fill) {\n const areaPath = buildAreaPath(\n series.values, xScale, yScale, area, options.curve,\n )\n seriesNodes.push(path(areaPath, {\n class: 'chartts-area',\n fill: `url(#chartts-area-${series.index})`,\n 'data-series': series.index,\n }))\n }\n\n const dash = series.style === 'dashed' ? '6,4'\n : series.style === 'dotted' ? '2,3' : undefined\n\n // Main line\n seriesNodes.push(path(linePath, {\n class: 'chartts-line',\n stroke: series.color,\n strokeWidth: theme.lineWidth,\n strokeDasharray: dash,\n 'data-series': series.index,\n }))\n\n // Data points with ambient glow\n if (series.showPoints) {\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue // skip missing data\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n\n // Ambient glow behind point\n seriesNodes.push(circle(x, y, theme.pointRadius * 3, {\n class: 'chartts-point-glow',\n fill: `url(#chartts-pglow-${series.index})`,\n }))\n\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': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\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 let best: HitResult | null = null\n let bestDist = Infinity\n\n for (const series of data.series) {\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue // skip missing data\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: series.index, pointIndex: i, distance: dist, x, y }\n }\n }\n }\n\n return best && best.distance < 30 ? best : null\n },\n}\n\n/** Build a line path string using specified interpolation, skipping NaN gaps */\nfunction buildLinePath(\n values: number[],\n xScale: { map(v: number | string | Date): number },\n yScale: { map(v: number | string | Date): number },\n curve: 'linear' | 'monotone' | 'step',\n): string {\n if (values.length === 0) return ''\n\n // Split into contiguous segments (break at NaN)\n const segments: { x: number; y: number }[][] = []\n let current: { x: number; y: number }[] = []\n for (let i = 0; i < values.length; i++) {\n if (isNaN(values[i]!)) {\n if (current.length > 0) { segments.push(current); current = [] }\n } else {\n current.push({ x: xScale.map(i), y: yScale.map(values[i]!) })\n }\n }\n if (current.length > 0) segments.push(current)\n\n // Build path for each segment\n const builder = curve === 'step' ? buildStepPath\n : curve === 'monotone' ? buildMonotonePath\n : buildLinearPath\n return segments.map(s => builder(s)).join('')\n}\n\n/** Build an area fill path (line path + close along x-axis), skipping NaN gaps */\nfunction buildAreaPath(\n values: number[],\n xScale: { map(v: number | string | Date): number },\n yScale: { map(v: number | string | Date): number },\n area: { y: number; height: number },\n curve: 'linear' | 'monotone' | 'step',\n): string {\n if (values.length === 0) return ''\n\n const baseline = area.y + area.height\n const builder = curve === 'monotone' ? buildMonotonePath\n : curve === 'step' ? buildStepPath\n : buildLinearPath\n\n // Split into contiguous segments (break at NaN)\n const segments: { x: number; y: number }[][] = []\n let current: { x: number; y: number }[] = []\n for (let i = 0; i < values.length; i++) {\n if (isNaN(values[i]!)) {\n if (current.length > 0) { segments.push(current); current = [] }\n } else {\n current.push({ x: xScale.map(i), y: yScale.map(values[i]!) })\n }\n }\n if (current.length > 0) segments.push(current)\n\n // Build closed area for each segment\n return segments.map(pts => {\n const linePart = builder(pts)\n const first = pts[0]!\n const last = pts[pts.length - 1]!\n return `${linePart}L${formatNum(last.x)},${formatNum(baseline)}L${formatNum(first.x)},${formatNum(baseline)}Z`\n }).join('')\n}\n\nfunction buildLinearPath(points: { x: number; y: number }[]): string {\n const pb = new PathBuilder()\n pb.moveTo(points[0]!.x, points[0]!.y)\n for (let i = 1; i < points.length; i++) {\n pb.lineTo(points[i]!.x, points[i]!.y)\n }\n return pb.build()\n}\n\nfunction buildStepPath(points: { x: number; y: number }[]): string {\n const pb = new PathBuilder()\n pb.moveTo(points[0]!.x, points[0]!.y)\n for (let i = 1; i < points.length; i++) {\n const midX = (points[i - 1]!.x + points[i]!.x) / 2\n pb.hTo(midX).vTo(points[i]!.y).hTo(points[i]!.x)\n }\n return pb.build()\n}\n\n/**\n * Monotone cubic interpolation (Fritsch–Carlson).\n * Produces smooth curves that never overshoot the data.\n */\nfunction buildMonotonePath(points: { x: number; y: number }[]): string {\n if (points.length < 2) return buildLinearPath(points)\n if (points.length === 2) return buildLinearPath(points)\n\n const n = points.length\n const dx: number[] = []\n const dy: number[] = []\n const m: number[] = []\n\n // Compute slopes\n for (let i = 0; i < n - 1; i++) {\n dx.push(points[i + 1]!.x - points[i]!.x)\n dy.push(points[i + 1]!.y - points[i]!.y)\n m.push(dy[i]! / (dx[i]! || 1))\n }\n\n // Compute tangents (Fritsch–Carlson)\n const tangents: number[] = [m[0]!]\n for (let i = 1; i < n - 1; i++) {\n if (m[i - 1]! * m[i]! <= 0) {\n tangents.push(0)\n } else {\n tangents.push((m[i - 1]! + m[i]!) / 2)\n }\n }\n tangents.push(m[n - 2]!)\n\n // Build path\n const pb = new PathBuilder()\n pb.moveTo(points[0]!.x, points[0]!.y)\n\n for (let i = 0; i < n - 1; i++) {\n const d = dx[i]! / 3\n pb.curveTo(\n points[i]!.x + d,\n points[i]!.y + tangents[i]! * d,\n points[i + 1]!.x - d,\n points[i + 1]!.y - tangents[i + 1]! * d,\n points[i + 1]!.x,\n points[i + 1]!.y,\n )\n }\n\n return pb.build()\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/line/line-type.ts"],"names":[],"mappings":"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","file":"chunk-45Y77XDM.js","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'\nimport { formatNum } from '../../utils/format'\n\nexport const lineChartType: ChartTypePlugin = {\n type: 'line',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareData(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, area, xScale, yScale, theme } = ctx\n const nodes: RenderNode[] = []\n\n for (const series of data.series) {\n const seriesNodes: RenderNode[] = []\n\n // Build line path\n const linePath = buildLinePath(series.values, xScale, yScale, options.curve)\n\n // Area fill (if enabled) — use gradient for premium look\n if (series.fill) {\n const areaPath = buildAreaPath(\n series.values, xScale, yScale, area, options.curve,\n )\n seriesNodes.push(path(areaPath, {\n class: 'chartts-area',\n fill: `url(#chartts-area-${series.index})`,\n 'data-series': series.index,\n }))\n }\n\n const dash = series.style === 'dashed' ? '6,4'\n : series.style === 'dotted' ? '2,3' : undefined\n\n // Main line\n seriesNodes.push(path(linePath, {\n class: 'chartts-line',\n stroke: series.color,\n strokeWidth: theme.lineWidth,\n strokeDasharray: dash,\n 'data-series': series.index,\n }))\n\n // Data points with ambient glow\n if (series.showPoints) {\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue // skip missing data\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n\n // Ambient glow behind point\n seriesNodes.push(circle(x, y, theme.pointRadius * 3, {\n class: 'chartts-point-glow',\n fill: `url(#chartts-pglow-${series.index})`,\n }))\n\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': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\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 let best: HitResult | null = null\n let bestDist = Infinity\n\n for (const series of data.series) {\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue // skip missing data\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: series.index, pointIndex: i, distance: dist, x, y }\n }\n }\n }\n\n return best && best.distance < 30 ? best : null\n },\n}\n\n/** Build a line path string using specified interpolation, skipping NaN gaps */\nfunction buildLinePath(\n values: number[],\n xScale: { map(v: number | string | Date): number },\n yScale: { map(v: number | string | Date): number },\n curve: 'linear' | 'monotone' | 'step',\n): string {\n if (values.length === 0) return ''\n\n // Split into contiguous segments (break at NaN)\n const segments: { x: number; y: number }[][] = []\n let current: { x: number; y: number }[] = []\n for (let i = 0; i < values.length; i++) {\n if (isNaN(values[i]!)) {\n if (current.length > 0) { segments.push(current); current = [] }\n } else {\n current.push({ x: xScale.map(i), y: yScale.map(values[i]!) })\n }\n }\n if (current.length > 0) segments.push(current)\n\n // Build path for each segment\n const builder = curve === 'step' ? buildStepPath\n : curve === 'monotone' ? buildMonotonePath\n : buildLinearPath\n return segments.map(s => builder(s)).join('')\n}\n\n/** Build an area fill path (line path + close along x-axis), skipping NaN gaps */\nfunction buildAreaPath(\n values: number[],\n xScale: { map(v: number | string | Date): number },\n yScale: { map(v: number | string | Date): number },\n area: { y: number; height: number },\n curve: 'linear' | 'monotone' | 'step',\n): string {\n if (values.length === 0) return ''\n\n const baseline = area.y + area.height\n const builder = curve === 'monotone' ? buildMonotonePath\n : curve === 'step' ? buildStepPath\n : buildLinearPath\n\n // Split into contiguous segments (break at NaN)\n const segments: { x: number; y: number }[][] = []\n let current: { x: number; y: number }[] = []\n for (let i = 0; i < values.length; i++) {\n if (isNaN(values[i]!)) {\n if (current.length > 0) { segments.push(current); current = [] }\n } else {\n current.push({ x: xScale.map(i), y: yScale.map(values[i]!) })\n }\n }\n if (current.length > 0) segments.push(current)\n\n // Build closed area for each segment\n return segments.map(pts => {\n const linePart = builder(pts)\n const first = pts[0]!\n const last = pts[pts.length - 1]!\n return `${linePart}L${formatNum(last.x)},${formatNum(baseline)}L${formatNum(first.x)},${formatNum(baseline)}Z`\n }).join('')\n}\n\nfunction buildLinearPath(points: { x: number; y: number }[]): string {\n const pb = new PathBuilder()\n pb.moveTo(points[0]!.x, points[0]!.y)\n for (let i = 1; i < points.length; i++) {\n pb.lineTo(points[i]!.x, points[i]!.y)\n }\n return pb.build()\n}\n\nfunction buildStepPath(points: { x: number; y: number }[]): string {\n const pb = new PathBuilder()\n pb.moveTo(points[0]!.x, points[0]!.y)\n for (let i = 1; i < points.length; i++) {\n const midX = (points[i - 1]!.x + points[i]!.x) / 2\n pb.hTo(midX).vTo(points[i]!.y).hTo(points[i]!.x)\n }\n return pb.build()\n}\n\n/**\n * Monotone cubic interpolation (Fritsch–Carlson).\n * Produces smooth curves that never overshoot the data.\n */\nfunction buildMonotonePath(points: { x: number; y: number }[]): string {\n if (points.length < 2) return buildLinearPath(points)\n if (points.length === 2) return buildLinearPath(points)\n\n const n = points.length\n const dx: number[] = []\n const dy: number[] = []\n const m: number[] = []\n\n // Compute slopes\n for (let i = 0; i < n - 1; i++) {\n dx.push(points[i + 1]!.x - points[i]!.x)\n dy.push(points[i + 1]!.y - points[i]!.y)\n m.push(dy[i]! / (dx[i]! || 1))\n }\n\n // Compute tangents (Fritsch–Carlson)\n const tangents: number[] = [m[0]!]\n for (let i = 1; i < n - 1; i++) {\n if (m[i - 1]! * m[i]! <= 0) {\n tangents.push(0)\n } else {\n tangents.push((m[i - 1]! + m[i]!) / 2)\n }\n }\n tangents.push(m[n - 2]!)\n\n // Build path\n const pb = new PathBuilder()\n pb.moveTo(points[0]!.x, points[0]!.y)\n\n for (let i = 0; i < n - 1; i++) {\n const d = dx[i]! / 3\n pb.curveTo(\n points[i]!.x + d,\n points[i]!.y + tangents[i]! * d,\n points[i + 1]!.x - d,\n points[i + 1]!.y - tangents[i + 1]! * d,\n points[i + 1]!.x,\n points[i + 1]!.y,\n )\n }\n\n return pb.build()\n}\n"]}
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
3
  var chunkNHGKZMD7_cjs = require('./chunk-NHGKZMD7.cjs');
4
- var chunkCDS2NXGT_cjs = require('./chunk-CDS2NXGT.cjs');
5
- var chunkUMIJYYF3_cjs = require('./chunk-UMIJYYF3.cjs');
4
+ var chunkX5SG6MFS_cjs = require('./chunk-X5SG6MFS.cjs');
5
+ var chunkW626EAS5_cjs = require('./chunk-W626EAS5.cjs');
6
6
 
7
7
  // src/charts/dumbbell/dumbbell-type.ts
8
8
  var dumbbellChartType = {
@@ -11,7 +11,7 @@ var dumbbellChartType = {
11
11
  return { x: "categorical", y: "linear" };
12
12
  },
13
13
  prepareData(data, options) {
14
- return chunkCDS2NXGT_cjs.prepareNoAxes(data, options);
14
+ return chunkX5SG6MFS_cjs.prepareNoAxes(data, options);
15
15
  },
16
16
  render(ctx) {
17
17
  const { data, area, theme, options, yScale } = ctx;
@@ -37,7 +37,7 @@ var dumbbellChartType = {
37
37
  const x2 = valueToX(v2);
38
38
  const label = String(data.labels[i] ?? `Item ${i + 1}`);
39
39
  const rowNodes = [];
40
- rowNodes.push(chunkUMIJYYF3_cjs.text(area.x + labelWidth - 8, cy, label, {
40
+ rowNodes.push(chunkW626EAS5_cjs.text(area.x + labelWidth - 8, cy, label, {
41
41
  class: "chartts-dumbbell-label",
42
42
  fill: theme.textMuted,
43
43
  textAnchor: "end",
@@ -45,12 +45,12 @@ var dumbbellChartType = {
45
45
  fontSize: theme.fontSizeSmall,
46
46
  fontFamily: theme.fontFamily
47
47
  }));
48
- rowNodes.push(chunkUMIJYYF3_cjs.line(x1, cy, x2, cy, {
48
+ rowNodes.push(chunkW626EAS5_cjs.line(x1, cy, x2, cy, {
49
49
  class: "chartts-dumbbell-connector",
50
50
  stroke: theme.gridColor,
51
51
  strokeWidth: 2
52
52
  }));
53
- rowNodes.push(chunkUMIJYYF3_cjs.circle(x1, cy, dotR, {
53
+ rowNodes.push(chunkW626EAS5_cjs.circle(x1, cy, dotR, {
54
54
  class: "chartts-dumbbell-dot",
55
55
  fill: color1,
56
56
  stroke: "#fff",
@@ -61,7 +61,7 @@ var dumbbellChartType = {
61
61
  role: "img",
62
62
  ariaLabel: `${label} \u2014 ${s1.name}: ${v1}`
63
63
  }));
64
- rowNodes.push(chunkUMIJYYF3_cjs.circle(x2, cy, dotR, {
64
+ rowNodes.push(chunkW626EAS5_cjs.circle(x2, cy, dotR, {
65
65
  class: "chartts-dumbbell-dot",
66
66
  fill: color2,
67
67
  stroke: "#fff",
@@ -72,7 +72,7 @@ var dumbbellChartType = {
72
72
  role: "img",
73
73
  ariaLabel: `${label} \u2014 ${s2.name}: ${v2}`
74
74
  }));
75
- nodes.push(chunkUMIJYYF3_cjs.group(rowNodes, {
75
+ nodes.push(chunkW626EAS5_cjs.group(rowNodes, {
76
76
  class: `chartts-series chartts-series-${i}`,
77
77
  "data-series-name": label
78
78
  }));
@@ -111,5 +111,5 @@ var dumbbellChartType = {
111
111
  };
112
112
 
113
113
  exports.dumbbellChartType = dumbbellChartType;
114
- //# sourceMappingURL=chunk-DRIJNFWP.cjs.map
115
- //# sourceMappingURL=chunk-DRIJNFWP.cjs.map
114
+ //# sourceMappingURL=chunk-47R2QUID.cjs.map
115
+ //# sourceMappingURL=chunk-47R2QUID.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/dumbbell/dumbbell-type.ts"],"names":["prepareNoAxes","createHorizontalMapper","text","line","circle","group"],"mappings":"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","file":"chunk-DRIJNFWP.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, line, circle, text } from '../../render/tree'\nimport { createHorizontalMapper } from '../../utils/scale'\n\n/**\n * Dumbbell / connected dot chart.\n *\n * Two dots per category connected by a line.\n * Horizontal layout — categories on y-axis, values on x-axis.\n * Requires exactly 2 series. Shows before/after or comparison.\n */\nexport const dumbbellChartType: ChartTypePlugin = {\n type: 'dumbbell',\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, yScale } = ctx\n const nodes: RenderNode[] = []\n\n if (data.series.length < 2) return nodes\n const s1 = data.series[0]!\n const s2 = data.series[1]!\n const count = Math.min(s1.values.length, s2.values.length)\n if (count === 0) return nodes\n\n const labelWidth = Math.min(80, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n const rowHeight = area.height / count\n const dotR = Math.min(6, rowHeight * 0.2)\n\n const color1 = options.colors[0]!\n const color2 = options.colors[1 % options.colors.length]!\n\n const valueToX = createHorizontalMapper(yScale, area, chartX, chartW)\n\n for (let i = 0; i < count; i++) {\n const cy = area.y + rowHeight * (i + 0.5)\n const v1 = s1.values[i]!\n const v2 = s2.values[i]!\n const x1 = valueToX(v1)\n const x2 = valueToX(v2)\n const label = String(data.labels[i] ?? `Item ${i + 1}`)\n\n const rowNodes: RenderNode[] = []\n\n // Label\n rowNodes.push(text(area.x + labelWidth - 8, cy, label, {\n class: 'chartts-dumbbell-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n // Connecting line\n rowNodes.push(line(x1, cy, x2, cy, {\n class: 'chartts-dumbbell-connector',\n stroke: theme.gridColor,\n strokeWidth: 2,\n }))\n\n // Dot 1 (series 0)\n rowNodes.push(circle(x1, cy, dotR, {\n class: 'chartts-dumbbell-dot',\n fill: color1,\n stroke: '#fff',\n strokeWidth: 1.5,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label} — ${s1.name}: ${v1}`,\n }))\n\n // Dot 2 (series 1)\n rowNodes.push(circle(x2, cy, dotR, {\n class: 'chartts-dumbbell-dot',\n fill: color2,\n stroke: '#fff',\n strokeWidth: 1.5,\n 'data-series': 1,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label} — ${s2.name}: ${v2}`,\n }))\n\n nodes.push(group(rowNodes, {\n class: `chartts-series chartts-series-${i}`,\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, yScale } = ctx\n if (data.series.length < 2) return null\n const s1 = data.series[0]!\n const s2 = data.series[1]!\n const count = Math.min(s1.values.length, s2.values.length)\n if (count === 0) return null\n\n const labelWidth = Math.min(80, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n const rowHeight = area.height / count\n\n const valueToX = createHorizontalMapper(yScale, area, chartX, chartW)\n\n let best: HitResult | null = null\n let bestDist = 15\n\n for (let i = 0; i < count; i++) {\n const cy = area.y + rowHeight * (i + 0.5)\n\n for (const [si, series] of [s1, s2].entries()) {\n const vx = valueToX(series.values[i]!)\n const dx = mx - vx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: si, pointIndex: i, distance: dist, x: vx, y: cy }\n }\n }\n }\n\n return best\n },\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/dumbbell/dumbbell-type.ts"],"names":["prepareNoAxes","createHorizontalMapper","text","line","circle","group"],"mappings":"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","file":"chunk-47R2QUID.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, line, circle, text } from '../../render/tree'\nimport { createHorizontalMapper } from '../../utils/scale'\n\n/**\n * Dumbbell / connected dot chart.\n *\n * Two dots per category connected by a line.\n * Horizontal layout — categories on y-axis, values on x-axis.\n * Requires exactly 2 series. Shows before/after or comparison.\n */\nexport const dumbbellChartType: ChartTypePlugin = {\n type: 'dumbbell',\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, yScale } = ctx\n const nodes: RenderNode[] = []\n\n if (data.series.length < 2) return nodes\n const s1 = data.series[0]!\n const s2 = data.series[1]!\n const count = Math.min(s1.values.length, s2.values.length)\n if (count === 0) return nodes\n\n const labelWidth = Math.min(80, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n const rowHeight = area.height / count\n const dotR = Math.min(6, rowHeight * 0.2)\n\n const color1 = options.colors[0]!\n const color2 = options.colors[1 % options.colors.length]!\n\n const valueToX = createHorizontalMapper(yScale, area, chartX, chartW)\n\n for (let i = 0; i < count; i++) {\n const cy = area.y + rowHeight * (i + 0.5)\n const v1 = s1.values[i]!\n const v2 = s2.values[i]!\n const x1 = valueToX(v1)\n const x2 = valueToX(v2)\n const label = String(data.labels[i] ?? `Item ${i + 1}`)\n\n const rowNodes: RenderNode[] = []\n\n // Label\n rowNodes.push(text(area.x + labelWidth - 8, cy, label, {\n class: 'chartts-dumbbell-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n // Connecting line\n rowNodes.push(line(x1, cy, x2, cy, {\n class: 'chartts-dumbbell-connector',\n stroke: theme.gridColor,\n strokeWidth: 2,\n }))\n\n // Dot 1 (series 0)\n rowNodes.push(circle(x1, cy, dotR, {\n class: 'chartts-dumbbell-dot',\n fill: color1,\n stroke: '#fff',\n strokeWidth: 1.5,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label} — ${s1.name}: ${v1}`,\n }))\n\n // Dot 2 (series 1)\n rowNodes.push(circle(x2, cy, dotR, {\n class: 'chartts-dumbbell-dot',\n fill: color2,\n stroke: '#fff',\n strokeWidth: 1.5,\n 'data-series': 1,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label} — ${s2.name}: ${v2}`,\n }))\n\n nodes.push(group(rowNodes, {\n class: `chartts-series chartts-series-${i}`,\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, yScale } = ctx\n if (data.series.length < 2) return null\n const s1 = data.series[0]!\n const s2 = data.series[1]!\n const count = Math.min(s1.values.length, s2.values.length)\n if (count === 0) return null\n\n const labelWidth = Math.min(80, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n const rowHeight = area.height / count\n\n const valueToX = createHorizontalMapper(yScale, area, chartX, chartW)\n\n let best: HitResult | null = null\n let bestDist = 15\n\n for (let i = 0; i < count; i++) {\n const cy = area.y + rowHeight * (i + 0.5)\n\n for (const [si, series] of [s1, s2].entries()) {\n const vx = valueToX(series.values[i]!)\n const dx = mx - vx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: si, pointIndex: i, distance: dist, x: vx, y: cy }\n }\n }\n }\n\n return best\n },\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
- var chunkCDS2NXGT_cjs = require('./chunk-CDS2NXGT.cjs');
4
- var chunkUMIJYYF3_cjs = require('./chunk-UMIJYYF3.cjs');
3
+ var chunkX5SG6MFS_cjs = require('./chunk-X5SG6MFS.cjs');
4
+ var chunkW626EAS5_cjs = require('./chunk-W626EAS5.cjs');
5
5
 
6
6
  // src/charts/funnel/funnel-type.ts
7
7
  var funnelChartType = {
@@ -10,7 +10,7 @@ var funnelChartType = {
10
10
  return { x: "categorical", y: "linear" };
11
11
  },
12
12
  prepareData(data, options) {
13
- return chunkCDS2NXGT_cjs.prepareNoAxes(data, options);
13
+ return chunkX5SG6MFS_cjs.prepareNoAxes(data, options);
14
14
  },
15
15
  render(ctx) {
16
16
  const { data, area, theme, options } = ctx;
@@ -35,7 +35,7 @@ var funnelChartType = {
35
35
  const bottomWidth = nextVal / maxVal * area.width;
36
36
  const y = area.y + i * (stepHeight + stepGap);
37
37
  const color = options.colors[i % options.colors.length];
38
- const pb = new chunkUMIJYYF3_cjs.PathBuilder();
38
+ const pb = new chunkW626EAS5_cjs.PathBuilder();
39
39
  pb.moveTo(centerX - topWidth / 2, y);
40
40
  pb.lineTo(centerX + topWidth / 2, y);
41
41
  pb.lineTo(centerX + bottomWidth / 2, y + stepHeight);
@@ -43,7 +43,7 @@ var funnelChartType = {
43
43
  pb.close();
44
44
  const stepNodes = [];
45
45
  const colorIndex = i % options.colors.length;
46
- stepNodes.push(chunkUMIJYYF3_cjs.path(pb.build(), {
46
+ stepNodes.push(chunkW626EAS5_cjs.path(pb.build(), {
47
47
  class: "chartts-funnel-step",
48
48
  fill: `url(#chartts-bar-${colorIndex})`,
49
49
  stroke: color,
@@ -59,7 +59,7 @@ var funnelChartType = {
59
59
  const label = String(data.labels[i] ?? `Step ${i + 1}`);
60
60
  const pct = maxVal > 0 ? Math.round(val / maxVal * 100) : 0;
61
61
  const labelStr = showValues ? `${label}: ${values[i]} (${pct}%)` : `${label} (${pct}%)`;
62
- stepNodes.push(chunkUMIJYYF3_cjs.text(centerX, textY, labelStr, {
62
+ stepNodes.push(chunkW626EAS5_cjs.text(centerX, textY, labelStr, {
63
63
  class: "chartts-funnel-label",
64
64
  fill: "#fff",
65
65
  textAnchor: "middle",
@@ -69,7 +69,7 @@ var funnelChartType = {
69
69
  fontWeight: 600
70
70
  }));
71
71
  }
72
- nodes.push(chunkUMIJYYF3_cjs.group(stepNodes, {
72
+ nodes.push(chunkW626EAS5_cjs.group(stepNodes, {
73
73
  class: `chartts-series chartts-series-${i}`,
74
74
  "data-series-name": String(data.labels[i] ?? `Step ${i + 1}`)
75
75
  }));
@@ -96,5 +96,5 @@ var funnelChartType = {
96
96
  };
97
97
 
98
98
  exports.funnelChartType = funnelChartType;
99
- //# sourceMappingURL=chunk-FDNJNVKA.cjs.map
100
- //# sourceMappingURL=chunk-FDNJNVKA.cjs.map
99
+ //# sourceMappingURL=chunk-4C5IV57Z.cjs.map
100
+ //# sourceMappingURL=chunk-4C5IV57Z.cjs.map