@chartts/core 0.1.3 → 0.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (291) 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-XKERO5K2.js → chunk-24557PYN.js} +3 -3
  20. package/dist/{chunk-XKERO5K2.js.map → chunk-24557PYN.js.map} +1 -1
  21. package/dist/{chunk-5YNIOIKK.js → chunk-2BUIZDOB.js} +3 -3
  22. package/dist/{chunk-5YNIOIKK.js.map → chunk-2BUIZDOB.js.map} +1 -1
  23. package/dist/{chunk-EHKHXQ46.cjs → chunk-2IMUTDTD.cjs} +10 -10
  24. package/dist/{chunk-EHKHXQ46.cjs.map → chunk-2IMUTDTD.cjs.map} +1 -1
  25. package/dist/{chunk-7ZPHLIFP.cjs → chunk-2IWLOBSF.cjs} +6 -6
  26. package/dist/{chunk-7ZPHLIFP.cjs.map → chunk-2IWLOBSF.cjs.map} +1 -1
  27. package/dist/{chunk-F5AOBHQY.js → chunk-2JYK52HV.js} +4 -4
  28. package/dist/{chunk-F5AOBHQY.js.map → chunk-2JYK52HV.js.map} +1 -1
  29. package/dist/{chunk-WVQVGQJO.cjs → chunk-2QRCHYTZ.cjs} +7 -7
  30. package/dist/{chunk-WVQVGQJO.cjs.map → chunk-2QRCHYTZ.cjs.map} +1 -1
  31. package/dist/{chunk-XWCY67K5.js → chunk-34DQGCPP.js} +4 -4
  32. package/dist/{chunk-XWCY67K5.js.map → chunk-34DQGCPP.js.map} +1 -1
  33. package/dist/{chunk-5J26EN5I.js → chunk-3JB4JBBK.js} +4 -4
  34. package/dist/{chunk-5J26EN5I.js.map → chunk-3JB4JBBK.js.map} +1 -1
  35. package/dist/{chunk-EHNX3MG3.cjs → chunk-3NHH6C4K.cjs} +13 -13
  36. package/dist/{chunk-EHNX3MG3.cjs.map → chunk-3NHH6C4K.cjs.map} +1 -1
  37. package/dist/{chunk-ECB3UPTC.cjs → chunk-3SVNEKXE.cjs} +11 -11
  38. package/dist/{chunk-ECB3UPTC.cjs.map → chunk-3SVNEKXE.cjs.map} +1 -1
  39. package/dist/{chunk-BYB3LQAT.cjs → chunk-4D6PVH2C.cjs} +9 -9
  40. package/dist/{chunk-BYB3LQAT.cjs.map → chunk-4D6PVH2C.cjs.map} +1 -1
  41. package/dist/{chunk-NG7DRWWT.cjs → chunk-4MNVJVK3.cjs} +6 -6
  42. package/dist/{chunk-NG7DRWWT.cjs.map → chunk-4MNVJVK3.cjs.map} +1 -1
  43. package/dist/{chunk-RQJRVKAH.js → chunk-4QRND2V5.js} +3 -3
  44. package/dist/{chunk-RQJRVKAH.js.map → chunk-4QRND2V5.js.map} +1 -1
  45. package/dist/{chunk-NGKUI7XE.cjs → chunk-55ZTXQQQ.cjs} +12 -12
  46. package/dist/{chunk-NGKUI7XE.cjs.map → chunk-55ZTXQQQ.cjs.map} +1 -1
  47. package/dist/{chunk-2MWA7H6J.js → chunk-56BN43J4.js} +5 -5
  48. package/dist/{chunk-2MWA7H6J.js.map → chunk-56BN43J4.js.map} +1 -1
  49. package/dist/{chunk-RJIPFWW7.js → chunk-5E7FXDBM.js} +4 -4
  50. package/dist/{chunk-RJIPFWW7.js.map → chunk-5E7FXDBM.js.map} +1 -1
  51. package/dist/{chunk-ILCWDAKD.js → chunk-5HZEDCJG.js} +3 -3
  52. package/dist/{chunk-ILCWDAKD.js.map → chunk-5HZEDCJG.js.map} +1 -1
  53. package/dist/{chunk-DKXW2FQC.cjs → chunk-5QT67VYJ.cjs} +10 -10
  54. package/dist/{chunk-DKXW2FQC.cjs.map → chunk-5QT67VYJ.cjs.map} +1 -1
  55. package/dist/{chunk-XE5ZYFGM.js → chunk-5QVUBGM7.js} +4 -4
  56. package/dist/{chunk-XE5ZYFGM.js.map → chunk-5QVUBGM7.js.map} +1 -1
  57. package/dist/{chunk-DR5MQC3W.js → chunk-62DBXI4N.js} +4 -4
  58. package/dist/{chunk-DR5MQC3W.js.map → chunk-62DBXI4N.js.map} +1 -1
  59. package/dist/{chunk-HMB2RIEE.js → chunk-6QMV75NT.js} +4 -4
  60. package/dist/{chunk-HMB2RIEE.js.map → chunk-6QMV75NT.js.map} +1 -1
  61. package/dist/{chunk-OUN3MWRQ.cjs → chunk-754Z4OR6.cjs} +10 -10
  62. package/dist/{chunk-OUN3MWRQ.cjs.map → chunk-754Z4OR6.cjs.map} +1 -1
  63. package/dist/{chunk-3SOKHPAO.js → chunk-7GLCJPV5.js} +4 -4
  64. package/dist/{chunk-3SOKHPAO.js.map → chunk-7GLCJPV5.js.map} +1 -1
  65. package/dist/{chunk-PQCHNZHM.cjs → chunk-7PHOSSLJ.cjs} +9 -9
  66. package/dist/{chunk-PQCHNZHM.cjs.map → chunk-7PHOSSLJ.cjs.map} +1 -1
  67. package/dist/{chunk-VBEZS3Q4.cjs → chunk-A5G32G2R.cjs} +9 -9
  68. package/dist/{chunk-VBEZS3Q4.cjs.map → chunk-A5G32G2R.cjs.map} +1 -1
  69. package/dist/{chunk-DX4FBN3I.js → chunk-AEQXFDL7.js} +14 -9
  70. package/dist/chunk-AEQXFDL7.js.map +1 -0
  71. package/dist/{chunk-RHTVKBRC.cjs → chunk-ATMSGQCW.cjs} +9 -9
  72. package/dist/{chunk-RHTVKBRC.cjs.map → chunk-ATMSGQCW.cjs.map} +1 -1
  73. package/dist/{chunk-2ITF366P.js → chunk-BFBVJ6MU.js} +3 -3
  74. package/dist/{chunk-2ITF366P.js.map → chunk-BFBVJ6MU.js.map} +1 -1
  75. package/dist/{chunk-E43H3A3G.cjs → chunk-BGGESAAG.cjs} +7 -7
  76. package/dist/{chunk-E43H3A3G.cjs.map → chunk-BGGESAAG.cjs.map} +1 -1
  77. package/dist/{chunk-R6ZDSXN7.cjs → chunk-CA42BCSM.cjs} +8 -8
  78. package/dist/{chunk-R6ZDSXN7.cjs.map → chunk-CA42BCSM.cjs.map} +1 -1
  79. package/dist/{chunk-FV7R2LLD.js → chunk-CU5ZXVZQ.js} +4 -4
  80. package/dist/{chunk-FV7R2LLD.js.map → chunk-CU5ZXVZQ.js.map} +1 -1
  81. package/dist/{chunk-JNQ4NL3R.cjs → chunk-CUIPBYMG.cjs} +8 -8
  82. package/dist/{chunk-JNQ4NL3R.cjs.map → chunk-CUIPBYMG.cjs.map} +1 -1
  83. package/dist/{chunk-CCMLOCTH.js → chunk-CWZADOJ6.js} +3 -3
  84. package/dist/{chunk-CCMLOCTH.js.map → chunk-CWZADOJ6.js.map} +1 -1
  85. package/dist/{chunk-FZIBM3G5.cjs → chunk-D5QUAWF3.cjs} +10 -10
  86. package/dist/{chunk-FZIBM3G5.cjs.map → chunk-D5QUAWF3.cjs.map} +1 -1
  87. package/dist/{chunk-YZQROIJY.js → chunk-DAAU5H24.js} +3 -3
  88. package/dist/{chunk-YZQROIJY.js.map → chunk-DAAU5H24.js.map} +1 -1
  89. package/dist/{chunk-GAWIUMAK.cjs → chunk-DT4GG5BF.cjs} +7 -7
  90. package/dist/{chunk-GAWIUMAK.cjs.map → chunk-DT4GG5BF.cjs.map} +1 -1
  91. package/dist/{chunk-4L62MAZA.js → chunk-DX77WSIB.js} +5 -5
  92. package/dist/{chunk-4L62MAZA.js.map → chunk-DX77WSIB.js.map} +1 -1
  93. package/dist/{chunk-4ORSJM2I.js → chunk-EPUWA3ZW.js} +4 -4
  94. package/dist/{chunk-4ORSJM2I.js.map → chunk-EPUWA3ZW.js.map} +1 -1
  95. package/dist/{chunk-ZTUKOCJN.cjs → chunk-ESJMEDLY.cjs} +4 -4
  96. package/dist/{chunk-ZTUKOCJN.cjs.map → chunk-ESJMEDLY.cjs.map} +1 -1
  97. package/dist/{chunk-6JNW43SE.js → chunk-EWVXMQRW.js} +5 -5
  98. package/dist/{chunk-6JNW43SE.js.map → chunk-EWVXMQRW.js.map} +1 -1
  99. package/dist/{chunk-LIY7MYRG.js → chunk-FGBIJ6PL.js} +4 -4
  100. package/dist/{chunk-LIY7MYRG.js.map → chunk-FGBIJ6PL.js.map} +1 -1
  101. package/dist/{chunk-OFEROCC5.cjs → chunk-FGHSUT6X.cjs} +6 -6
  102. package/dist/{chunk-OFEROCC5.cjs.map → chunk-FGHSUT6X.cjs.map} +1 -1
  103. package/dist/{chunk-QKJUAMRK.cjs → chunk-FVLVTY5D.cjs} +6 -6
  104. package/dist/{chunk-QKJUAMRK.cjs.map → chunk-FVLVTY5D.cjs.map} +1 -1
  105. package/dist/{chunk-YX6RW6ZW.cjs → chunk-GBL4R3GH.cjs} +6 -6
  106. package/dist/{chunk-YX6RW6ZW.cjs.map → chunk-GBL4R3GH.cjs.map} +1 -1
  107. package/dist/{chunk-SXVMEC6N.cjs → chunk-GRXHW5S3.cjs} +12 -12
  108. package/dist/{chunk-SXVMEC6N.cjs.map → chunk-GRXHW5S3.cjs.map} +1 -1
  109. package/dist/{chunk-K5TPJVOK.js → chunk-HCIBBUV5.js} +3 -3
  110. package/dist/{chunk-K5TPJVOK.js.map → chunk-HCIBBUV5.js.map} +1 -1
  111. package/dist/{chunk-HFWO37RY.cjs → chunk-HCK2VUWD.cjs} +8 -8
  112. package/dist/{chunk-HFWO37RY.cjs.map → chunk-HCK2VUWD.cjs.map} +1 -1
  113. package/dist/{chunk-FSDI3NJV.js → chunk-IDZTDJLH.js} +3 -3
  114. package/dist/{chunk-FSDI3NJV.js.map → chunk-IDZTDJLH.js.map} +1 -1
  115. package/dist/{chunk-FDNJNVKA.cjs → chunk-IF6RQ53Q.cjs} +9 -9
  116. package/dist/{chunk-FDNJNVKA.cjs.map → chunk-IF6RQ53Q.cjs.map} +1 -1
  117. package/dist/{chunk-PVPTFMJJ.js → chunk-IOV77VHP.js} +4 -4
  118. package/dist/{chunk-PVPTFMJJ.js.map → chunk-IOV77VHP.js.map} +1 -1
  119. package/dist/{chunk-UMIJYYF3.cjs → chunk-JVVGQLJQ.cjs} +14 -9
  120. package/dist/chunk-JVVGQLJQ.cjs.map +1 -0
  121. package/dist/{chunk-MY4KMVJ5.cjs → chunk-JYVRX3BX.cjs} +8 -8
  122. package/dist/{chunk-MY4KMVJ5.cjs.map → chunk-JYVRX3BX.cjs.map} +1 -1
  123. package/dist/{chunk-ZY7ETQD6.js → chunk-KHG3G2ZX.js} +3 -3
  124. package/dist/{chunk-ZY7ETQD6.js.map → chunk-KHG3G2ZX.js.map} +1 -1
  125. package/dist/{chunk-ASNAQ35U.js → chunk-KNMEXOKJ.js} +4 -4
  126. package/dist/{chunk-ASNAQ35U.js.map → chunk-KNMEXOKJ.js.map} +1 -1
  127. package/dist/{chunk-WYIIWTIR.cjs → chunk-KWSVJRXX.cjs} +4 -4
  128. package/dist/{chunk-WYIIWTIR.cjs.map → chunk-KWSVJRXX.cjs.map} +1 -1
  129. package/dist/{chunk-OAL5RS2X.cjs → chunk-LARNENXE.cjs} +10 -10
  130. package/dist/{chunk-OAL5RS2X.cjs.map → chunk-LARNENXE.cjs.map} +1 -1
  131. package/dist/{chunk-MYXLKVJE.js → chunk-LRHMLNPW.js} +12 -4
  132. package/dist/chunk-LRHMLNPW.js.map +1 -0
  133. package/dist/{chunk-66BHM3UN.cjs → chunk-LXYNL7BI.cjs} +10 -10
  134. package/dist/{chunk-66BHM3UN.cjs.map → chunk-LXYNL7BI.cjs.map} +1 -1
  135. package/dist/{chunk-V45C74EB.js → chunk-MEERXUZS.js} +4 -4
  136. package/dist/{chunk-V45C74EB.js.map → chunk-MEERXUZS.js.map} +1 -1
  137. package/dist/{chunk-YJHB2GHQ.js → chunk-MJY25P44.js} +3 -3
  138. package/dist/{chunk-YJHB2GHQ.js.map → chunk-MJY25P44.js.map} +1 -1
  139. package/dist/{chunk-6UWYKNFN.cjs → chunk-MSCRIA2U.cjs} +12 -12
  140. package/dist/{chunk-6UWYKNFN.cjs.map → chunk-MSCRIA2U.cjs.map} +1 -1
  141. package/dist/{chunk-UZH6PVHD.js → chunk-N35UAFEU.js} +4 -4
  142. package/dist/{chunk-UZH6PVHD.js.map → chunk-N35UAFEU.js.map} +1 -1
  143. package/dist/{chunk-6E6ZDWZD.cjs → chunk-NE2W2MF3.cjs} +10 -10
  144. package/dist/{chunk-6E6ZDWZD.cjs.map → chunk-NE2W2MF3.cjs.map} +1 -1
  145. package/dist/{chunk-7PNCJ4OQ.js → chunk-NQ7Y6ZKH.js} +3 -3
  146. package/dist/{chunk-7PNCJ4OQ.js.map → chunk-NQ7Y6ZKH.js.map} +1 -1
  147. package/dist/{chunk-LK2A3HBT.js → chunk-NRULNA5F.js} +4 -4
  148. package/dist/{chunk-LK2A3HBT.js.map → chunk-NRULNA5F.js.map} +1 -1
  149. package/dist/{chunk-47EP245Y.cjs → chunk-OEGSDOJ2.cjs} +7 -7
  150. package/dist/{chunk-47EP245Y.cjs.map → chunk-OEGSDOJ2.cjs.map} +1 -1
  151. package/dist/{chunk-ZFSFOD5W.cjs → chunk-OMAW52LY.cjs} +6 -6
  152. package/dist/{chunk-ZFSFOD5W.cjs.map → chunk-OMAW52LY.cjs.map} +1 -1
  153. package/dist/{chunk-YOLF5DYU.js → chunk-OMSHGBV3.js} +4 -4
  154. package/dist/{chunk-YOLF5DYU.js.map → chunk-OMSHGBV3.js.map} +1 -1
  155. package/dist/{chunk-4H2LGLGI.cjs → chunk-OTXHJHXU.cjs} +11 -11
  156. package/dist/{chunk-4H2LGLGI.cjs.map → chunk-OTXHJHXU.cjs.map} +1 -1
  157. package/dist/{chunk-DRIJNFWP.cjs → chunk-PCAYYCLY.cjs} +10 -10
  158. package/dist/{chunk-DRIJNFWP.cjs.map → chunk-PCAYYCLY.cjs.map} +1 -1
  159. package/dist/{chunk-QERWC7U6.js → chunk-PKXW45G4.js} +3 -3
  160. package/dist/{chunk-QERWC7U6.js.map → chunk-PKXW45G4.js.map} +1 -1
  161. package/dist/{chunk-YDQDZWZ7.cjs → chunk-QEPMEEZC.cjs} +6 -6
  162. package/dist/{chunk-YDQDZWZ7.cjs.map → chunk-QEPMEEZC.cjs.map} +1 -1
  163. package/dist/{chunk-G6R6MSRF.cjs → chunk-QPHUAF3R.cjs} +8 -8
  164. package/dist/{chunk-G6R6MSRF.cjs.map → chunk-QPHUAF3R.cjs.map} +1 -1
  165. package/dist/{chunk-RFEKSP62.js → chunk-QPHWRD25.js} +3 -3
  166. package/dist/{chunk-RFEKSP62.js.map → chunk-QPHWRD25.js.map} +1 -1
  167. package/dist/{chunk-XN6YS55F.cjs → chunk-QYI7ZV3B.cjs} +30 -22
  168. package/dist/chunk-QYI7ZV3B.cjs.map +1 -0
  169. package/dist/{chunk-3V64BDKG.cjs → chunk-R2W3RJFW.cjs} +13 -13
  170. package/dist/{chunk-3V64BDKG.cjs.map → chunk-R2W3RJFW.cjs.map} +1 -1
  171. package/dist/{chunk-46ZZTP5B.js → chunk-SGZUUUXU.js} +4 -4
  172. package/dist/{chunk-46ZZTP5B.js.map → chunk-SGZUUUXU.js.map} +1 -1
  173. package/dist/{chunk-MPQECPE3.js → chunk-T7SCCACB.js} +3 -3
  174. package/dist/{chunk-MPQECPE3.js.map → chunk-T7SCCACB.js.map} +1 -1
  175. package/dist/{chunk-GPSNBZPX.js → chunk-TC3H6ZED.js} +4 -4
  176. package/dist/{chunk-GPSNBZPX.js.map → chunk-TC3H6ZED.js.map} +1 -1
  177. package/dist/{chunk-AG7VY6MJ.cjs → chunk-TEZNWW3R.cjs} +8 -8
  178. package/dist/{chunk-AG7VY6MJ.cjs.map → chunk-TEZNWW3R.cjs.map} +1 -1
  179. package/dist/{chunk-KTCP23W6.js → chunk-THHZMRFU.js} +3 -3
  180. package/dist/{chunk-KTCP23W6.js.map → chunk-THHZMRFU.js.map} +1 -1
  181. package/dist/{chunk-RWQH5EO5.cjs → chunk-TLHQ6JCK.cjs} +11 -11
  182. package/dist/{chunk-RWQH5EO5.cjs.map → chunk-TLHQ6JCK.cjs.map} +1 -1
  183. package/dist/{chunk-CDS2NXGT.cjs → chunk-V5Q6UNUK.cjs} +4 -4
  184. package/dist/{chunk-CDS2NXGT.cjs.map → chunk-V5Q6UNUK.cjs.map} +1 -1
  185. package/dist/{chunk-BT5H3WMI.js → chunk-VBMLJUBE.js} +4 -4
  186. package/dist/{chunk-BT5H3WMI.js.map → chunk-VBMLJUBE.js.map} +1 -1
  187. package/dist/{chunk-UFMPALRH.js → chunk-VGJD4F4H.js} +3 -3
  188. package/dist/{chunk-UFMPALRH.js.map → chunk-VGJD4F4H.js.map} +1 -1
  189. package/dist/{chunk-RN7NNB6I.js → chunk-VJXUBN7J.js} +3 -3
  190. package/dist/{chunk-RN7NNB6I.js.map → chunk-VJXUBN7J.js.map} +1 -1
  191. package/dist/{chunk-TVDQNLGJ.js → chunk-VUHNBLFA.js} +3 -3
  192. package/dist/{chunk-TVDQNLGJ.js.map → chunk-VUHNBLFA.js.map} +1 -1
  193. package/dist/{chunk-OAIMES5S.cjs → chunk-W476ER4X.cjs} +17 -17
  194. package/dist/{chunk-OAIMES5S.cjs.map → chunk-W476ER4X.cjs.map} +1 -1
  195. package/dist/{chunk-4XVJYNOT.js → chunk-WZCES5M6.js} +4 -4
  196. package/dist/{chunk-4XVJYNOT.js.map → chunk-WZCES5M6.js.map} +1 -1
  197. package/dist/{chunk-2EZ2TVYT.cjs → chunk-Y6CVUI6A.cjs} +13 -13
  198. package/dist/{chunk-2EZ2TVYT.cjs.map → chunk-Y6CVUI6A.cjs.map} +1 -1
  199. package/dist/{chunk-4WQUX2B4.cjs → chunk-YCL43UQM.cjs} +12 -12
  200. package/dist/{chunk-4WQUX2B4.cjs.map → chunk-YCL43UQM.cjs.map} +1 -1
  201. package/dist/{chunk-XWN43PZF.cjs → chunk-YZXRD6K6.cjs} +7 -7
  202. package/dist/{chunk-XWN43PZF.cjs.map → chunk-YZXRD6K6.cjs.map} +1 -1
  203. package/dist/{chunk-IRUIWMH6.js → chunk-ZFGLBJYC.js} +3 -3
  204. package/dist/{chunk-IRUIWMH6.js.map → chunk-ZFGLBJYC.js.map} +1 -1
  205. package/dist/{chunk-6EGHZDZI.cjs → chunk-ZNKVOTPB.cjs} +15 -15
  206. package/dist/{chunk-6EGHZDZI.cjs.map → chunk-ZNKVOTPB.cjs.map} +1 -1
  207. package/dist/{chunk-WJP6CRML.js → chunk-ZOEN3ARN.js} +3 -3
  208. package/dist/{chunk-WJP6CRML.js.map → chunk-ZOEN3ARN.js.map} +1 -1
  209. package/dist/{chunk-TWSWD4PU.js → chunk-ZYXRRVR6.js} +3 -3
  210. package/dist/{chunk-TWSWD4PU.js.map → chunk-ZYXRRVR6.js.map} +1 -1
  211. package/dist/combo.cjs +9 -9
  212. package/dist/combo.js +4 -4
  213. package/dist/custom.cjs +10 -10
  214. package/dist/custom.js +5 -5
  215. package/dist/donut.cjs +11 -11
  216. package/dist/donut.js +6 -6
  217. package/dist/dumbbell.cjs +10 -10
  218. package/dist/dumbbell.js +5 -5
  219. package/dist/funnel.cjs +10 -10
  220. package/dist/funnel.js +5 -5
  221. package/dist/gauge.cjs +10 -10
  222. package/dist/gauge.js +5 -5
  223. package/dist/geo.cjs +12 -12
  224. package/dist/geo.js +5 -5
  225. package/dist/graph.cjs +10 -10
  226. package/dist/graph.js +5 -5
  227. package/dist/heatmap.cjs +10 -10
  228. package/dist/heatmap.js +5 -5
  229. package/dist/histogram.cjs +9 -9
  230. package/dist/histogram.js +4 -4
  231. package/dist/horizontal-bar.cjs +9 -9
  232. package/dist/horizontal-bar.js +4 -4
  233. package/dist/index.cjs +180 -180
  234. package/dist/index.d.cts +4 -0
  235. package/dist/index.d.ts +4 -0
  236. package/dist/index.js +92 -92
  237. package/dist/kagi.cjs +10 -10
  238. package/dist/kagi.js +5 -5
  239. package/dist/line.cjs +9 -9
  240. package/dist/line.js +4 -4
  241. package/dist/lines.cjs +10 -10
  242. package/dist/lines.js +5 -5
  243. package/dist/lollipop.cjs +9 -9
  244. package/dist/lollipop.js +4 -4
  245. package/dist/matrix.cjs +10 -10
  246. package/dist/matrix.js +5 -5
  247. package/dist/ohlc.cjs +9 -9
  248. package/dist/ohlc.js +4 -4
  249. package/dist/parallel.cjs +10 -10
  250. package/dist/parallel.js +5 -5
  251. package/dist/pictorialbar.cjs +10 -10
  252. package/dist/pictorialbar.js +5 -5
  253. package/dist/pie.cjs +11 -11
  254. package/dist/pie.js +6 -6
  255. package/dist/polar.cjs +11 -11
  256. package/dist/polar.js +6 -6
  257. package/dist/radar.cjs +10 -10
  258. package/dist/radar.js +5 -5
  259. package/dist/radialbar.cjs +10 -10
  260. package/dist/radialbar.js +5 -5
  261. package/dist/range.cjs +9 -9
  262. package/dist/range.js +4 -4
  263. package/dist/renko.cjs +10 -10
  264. package/dist/renko.js +5 -5
  265. package/dist/sankey.cjs +10 -10
  266. package/dist/sankey.js +5 -5
  267. package/dist/scatter.cjs +9 -9
  268. package/dist/scatter.js +4 -4
  269. package/dist/sparkline.cjs +9 -9
  270. package/dist/sparkline.js +4 -4
  271. package/dist/stacked-bar.cjs +9 -9
  272. package/dist/stacked-bar.js +4 -4
  273. package/dist/step.cjs +10 -10
  274. package/dist/step.js +5 -5
  275. package/dist/sunburst.cjs +11 -11
  276. package/dist/sunburst.js +6 -6
  277. package/dist/themeriver.cjs +10 -10
  278. package/dist/themeriver.js +5 -5
  279. package/dist/tree.cjs +10 -10
  280. package/dist/tree.js +5 -5
  281. package/dist/treemap.cjs +10 -10
  282. package/dist/treemap.js +5 -5
  283. package/dist/volume.cjs +9 -9
  284. package/dist/volume.js +4 -4
  285. package/dist/waterfall.cjs +9 -9
  286. package/dist/waterfall.js +4 -4
  287. package/package.json +1 -1
  288. package/dist/chunk-DX4FBN3I.js.map +0 -1
  289. package/dist/chunk-MYXLKVJE.js.map +0 -1
  290. package/dist/chunk-UMIJYYF3.cjs.map +0 -1
  291. package/dist/chunk-XN6YS55F.cjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/radar/radar-type.ts"],"names":["prepareNoAxes","PathBuilder","path","text","circle","group"],"mappings":";;;;;;AAYO,IAAM,cAAA,GAAkC;AAAA,EAC7C,IAAA,EAAM,OAAA;AAAA,EAEN,aAAA,GAAgD;AAC9C,IAAA,OAAO,EAAE,CAAA,EAAG,aAAA,EAAe,CAAA,EAAG,QAAA,EAAS;AAAA,EACzC,CAAA;AAAA,EAEA,WAAA,CAAY,MAAiB,OAAA,EAAwC;AACnE,IAAA,OAAOA,+BAAA,CAAc,MAAM,OAAO,CAAA;AAAA,EACpC,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,MAAM,EAAE,IAAA,EAAM,IAAA,EAAM,KAAA,EAAM,GAAI,GAAA;AAC9B,IAAA,MAAM,QAAsB,EAAC;AAE7B,IAAA,MAAM,UAAA,GAAa,KAAK,MAAA,CAAO,MAAA;AAC/B,IAAA,IAAI,UAAA,GAAa,GAAG,OAAO,KAAA;AAE3B,IAAA,MAAM,EAAA,GAAK,IAAA,CAAK,CAAA,GAAI,IAAA,CAAK,KAAA,GAAQ,CAAA;AACjC,IAAA,MAAM,EAAA,GAAK,IAAA,CAAK,CAAA,GAAI,IAAA,CAAK,MAAA,GAAS,CAAA;AAClC,IAAA,MAAM,MAAA,GAAS,KAAK,GAAA,CAAI,IAAA,CAAK,OAAO,IAAA,CAAK,MAAM,IAAI,CAAA,GAAI,EAAA;AAGvD,IAAA,IAAI,MAAA,GAAS,CAAA;AACb,IAAA,KAAA,MAAW,MAAA,IAAU,KAAK,MAAA,EAAQ;AAChC,MAAA,KAAA,MAAW,CAAA,IAAK,OAAO,MAAA,EAAQ;AAC7B,QAAA,IAAI,IAAA,CAAK,IAAI,CAAC,CAAA,GAAI,QAAQ,MAAA,GAAS,IAAA,CAAK,IAAI,CAAC,CAAA;AAAA,MAC/C;AAAA,IACF;AACA,IAAA,IAAI,MAAA,KAAW,GAAG,MAAA,GAAS,CAAA;AAE3B,IAAA,MAAM,SAAA,GAAa,IAAA,CAAK,EAAA,GAAK,CAAA,GAAK,UAAA;AAClC,IAAA,MAAM,UAAA,GAAa,CAAC,IAAA,CAAK,EAAA,GAAK,CAAA;AAG9B,IAAA,MAAM,UAAA,GAAa,CAAA;AACnB,IAAA,KAAA,IAAS,KAAA,GAAQ,CAAA,EAAG,KAAA,IAAS,UAAA,EAAY,KAAA,EAAA,EAAS;AAChD,MAAA,MAAM,CAAA,GAAK,SAAS,KAAA,GAAS,UAAA;AAC7B,MAAA,MAAM,EAAA,GAAK,IAAIC,6BAAA,EAAY;AAC3B,MAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,IAAK,UAAA,EAAY,CAAA,EAAA,EAAK;AACpC,QAAA,MAAM,KAAA,GAAQ,UAAA,GAAc,CAAA,GAAI,UAAA,GAAc,SAAA;AAC9C,QAAA,MAAM,CAAA,GAAI,EAAA,GAAK,CAAA,GAAI,IAAA,CAAK,IAAI,KAAK,CAAA;AACjC,QAAA,MAAM,CAAA,GAAI,EAAA,GAAK,CAAA,GAAI,IAAA,CAAK,IAAI,KAAK,CAAA;AACjC,QAAA,IAAI,CAAA,KAAM,CAAA,EAAG,EAAA,CAAG,MAAA,CAAO,GAAG,CAAC,CAAA;AAAA,aACtB,EAAA,CAAG,MAAA,CAAO,CAAA,EAAG,CAAC,CAAA;AAAA,MACrB;AACA,MAAA,KAAA,CAAM,IAAA,CAAKC,sBAAA,CAAK,EAAA,CAAG,KAAA,EAAM,EAAG;AAAA,QAC1B,KAAA,EAAO,oBAAA;AAAA,QACP,QAAQ,KAAA,CAAM,SAAA;AAAA,QACd,aAAa,KAAA,CAAM,SAAA;AAAA,QACnB,WAAA,EAAa,CAAA;AAAA,QACb,IAAA,EAAM;AAAA,OACP,CAAC,CAAA;AAAA,IACJ;AAGA,IAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,UAAA,EAAY,CAAA,EAAA,EAAK;AACnC,MAAA,MAAM,KAAA,GAAQ,aAAa,CAAA,GAAI,SAAA;AAC/B,MAAA,MAAM,CAAA,GAAI,EAAA,GAAK,MAAA,GAAS,IAAA,CAAK,IAAI,KAAK,CAAA;AACtC,MAAA,MAAM,CAAA,GAAI,EAAA,GAAK,MAAA,GAAS,IAAA,CAAK,IAAI,KAAK,CAAA;AAEtC,MAAA,KAAA,CAAM,IAAA,CAAK;AAAA,QACT,IAAA,EAAM,MAAA;AAAA,QACN,EAAA,EAAI,EAAA;AAAA,QACJ,EAAA,EAAI,EAAA;AAAA,QACJ,EAAA,EAAI,CAAA;AAAA,QACJ,EAAA,EAAI,CAAA;AAAA,QACJ,KAAA,EAAO;AAAA,UACL,KAAA,EAAO,oBAAA;AAAA,UACP,QAAQ,KAAA,CAAM,SAAA;AAAA,UACd,aAAa,KAAA,CAAM;AAAA;AACrB,OACD,CAAA;AAGD,MAAA,MAAM,SAAS,MAAA,GAAS,EAAA;AACxB,MAAA,MAAM,EAAA,GAAK,EAAA,GAAK,MAAA,GAAS,IAAA,CAAK,IAAI,KAAK,CAAA;AACvC,MAAA,MAAM,EAAA,GAAK,EAAA,GAAK,MAAA,GAAS,IAAA,CAAK,IAAI,KAAK,CAAA;AACvC,MAAA,MAAM,MAAA,GAAS,IAAA,CAAK,GAAA,CAAI,IAAA,CAAK,IAAI,KAAK,CAAC,CAAA,GAAI,IAAA,GAAO,WAC9C,IAAA,CAAK,GAAA,CAAI,KAAK,CAAA,GAAI,IAAI,OAAA,GAAmB,KAAA;AAE7C,MAAA,KAAA,CAAM,IAAA,CAAKC,uBAAK,EAAA,EAAI,EAAA,EAAI,OAAO,IAAA,CAAK,MAAA,CAAO,CAAC,CAAE,CAAA,EAAG;AAAA,QAC/C,KAAA,EAAO,qBAAA;AAAA,QACP,MAAM,KAAA,CAAM,SAAA;AAAA,QACZ,UAAA,EAAY,MAAA;AAAA,QACZ,gBAAA,EAAkB,SAAA;AAAA,QAClB,UAAU,KAAA,CAAM,aAAA;AAAA,QAChB,YAAY,KAAA,CAAM;AAAA,OACnB,CAAC,CAAA;AAAA,IACJ;AAGA,IAAA,KAAA,MAAW,MAAA,IAAU,KAAK,MAAA,EAAQ;AAChC,MAAA,MAAM,EAAA,GAAK,IAAIF,6BAAA,EAAY;AAC3B,MAAA,MAAM,SAAqC,EAAC;AAE5C,MAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,UAAA,EAAY,CAAA,EAAA,EAAK;AACnC,QAAA,MAAM,GAAA,GAAM,MAAA,CAAO,MAAA,CAAO,CAAC,CAAA,IAAK,CAAA;AAChC,QAAA,MAAM,CAAA,GAAK,IAAA,CAAK,GAAA,CAAI,GAAG,IAAI,MAAA,GAAU,MAAA;AACrC,QAAA,MAAM,KAAA,GAAQ,aAAa,CAAA,GAAI,SAAA;AAC/B,QAAA,MAAM,CAAA,GAAI,EAAA,GAAK,CAAA,GAAI,IAAA,CAAK,IAAI,KAAK,CAAA;AACjC,QAAA,MAAM,CAAA,GAAI,EAAA,GAAK,CAAA,GAAI,IAAA,CAAK,IAAI,KAAK,CAAA;AACjC,QAAA,MAAA,CAAO,IAAA,CAAK,EAAE,CAAA,EAAG,CAAA,EAAG,CAAA;AAEpB,QAAA,IAAI,CAAA,KAAM,CAAA,EAAG,EAAA,CAAG,MAAA,CAAO,GAAG,CAAC,CAAA;AAAA,aACtB,EAAA,CAAG,MAAA,CAAO,CAAA,EAAG,CAAC,CAAA;AAAA,MACrB;AACA,MAAA,EAAA,CAAG,KAAA,EAAM;AAET,MAAA,MAAM,cAA4B,EAAC;AAGnC,MAAA,WAAA,CAAY,IAAA,CAAKC,sBAAA,CAAK,EAAA,CAAG,KAAA,EAAM,EAAG;AAAA,QAChC,KAAA,EAAO,oBAAA;AAAA,QACP,MAAM,MAAA,CAAO,KAAA;AAAA,QACb,WAAA,EAAa,GAAA;AAAA,QACb,QAAQ,MAAA,CAAO,KAAA;AAAA,QACf,aAAa,KAAA,CAAM,SAAA;AAAA,QACnB,eAAe,MAAA,CAAO;AAAA,OACvB,CAAC,CAAA;AAGF,MAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AACtC,QAAA,WAAA,CAAY,IAAA,CAAKE,wBAAA,CAAO,MAAA,CAAO,CAAC,CAAA,CAAG,CAAA,EAAG,MAAA,CAAO,CAAC,CAAA,CAAG,CAAA,EAAG,KAAA,CAAM,WAAA,EAAa;AAAA,UACrE,KAAA,EAAO,qBAAA;AAAA,UACP,MAAM,MAAA,CAAO,KAAA;AAAA,UACb,eAAe,MAAA,CAAO,KAAA;AAAA,UACtB,YAAA,EAAc,CAAA;AAAA,UACd,QAAA,EAAU,CAAA;AAAA,UACV,IAAA,EAAM,KAAA;AAAA,UACN,SAAA,EAAW,CAAA,EAAG,MAAA,CAAO,IAAI,CAAA,CAAA,EAAI,IAAA,CAAK,MAAA,CAAO,CAAC,CAAC,CAAA,EAAA,EAAK,MAAA,CAAO,MAAA,CAAO,CAAC,CAAC,CAAA;AAAA,SACjE,CAAC,CAAA;AAAA,MACJ;AAEA,MAAA,KAAA,CAAM,IAAA,CAAKC,wBAAM,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,IAAA,EAAK,GAAI,GAAA;AACvB,IAAA,MAAM,UAAA,GAAa,KAAK,MAAA,CAAO,MAAA;AAC/B,IAAA,IAAI,UAAA,GAAa,GAAG,OAAO,IAAA;AAE3B,IAAA,MAAM,EAAA,GAAK,IAAA,CAAK,CAAA,GAAI,IAAA,CAAK,KAAA,GAAQ,CAAA;AACjC,IAAA,MAAM,EAAA,GAAK,IAAA,CAAK,CAAA,GAAI,IAAA,CAAK,MAAA,GAAS,CAAA;AAClC,IAAA,MAAM,MAAA,GAAS,KAAK,GAAA,CAAI,IAAA,CAAK,OAAO,IAAA,CAAK,MAAM,IAAI,CAAA,GAAI,EAAA;AACvD,IAAA,MAAM,SAAA,GAAa,IAAA,CAAK,EAAA,GAAK,CAAA,GAAK,UAAA;AAClC,IAAA,MAAM,UAAA,GAAa,CAAC,IAAA,CAAK,EAAA,GAAK,CAAA;AAE9B,IAAA,IAAI,MAAA,GAAS,CAAA;AACb,IAAA,KAAA,MAAW,MAAA,IAAU,KAAK,MAAA,EAAQ;AAChC,MAAA,KAAA,MAAW,CAAA,IAAK,OAAO,MAAA,EAAQ;AAC7B,QAAA,IAAI,IAAA,CAAK,IAAI,CAAC,CAAA,GAAI,QAAQ,MAAA,GAAS,IAAA,CAAK,IAAI,CAAC,CAAA;AAAA,MAC/C;AAAA,IACF;AACA,IAAA,IAAI,MAAA,KAAW,GAAG,OAAO,IAAA;AAEzB,IAAA,IAAI,IAAA,GAAyB,IAAA;AAC7B,IAAA,IAAI,QAAA,GAAW,QAAA;AACf,IAAA,MAAM,SAAA,GAAY,EAAA;AAElB,IAAA,KAAA,MAAW,MAAA,IAAU,KAAK,MAAA,EAAQ;AAChC,MAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,UAAA,EAAY,CAAA,EAAA,EAAK;AACnC,QAAA,MAAM,GAAA,GAAM,MAAA,CAAO,MAAA,CAAO,CAAC,CAAA,IAAK,CAAA;AAChC,QAAA,MAAM,CAAA,GAAK,IAAA,CAAK,GAAA,CAAI,GAAG,IAAI,MAAA,GAAU,MAAA;AACrC,QAAA,MAAM,KAAA,GAAQ,aAAa,CAAA,GAAI,SAAA;AAC/B,QAAA,MAAM,EAAA,GAAK,EAAA,GAAK,CAAA,GAAI,IAAA,CAAK,IAAI,KAAK,CAAA;AAClC,QAAA,MAAM,EAAA,GAAK,EAAA,GAAK,CAAA,GAAI,IAAA,CAAK,IAAI,KAAK,CAAA;AAClC,QAAA,MAAM,IAAA,GAAO,KAAK,IAAA,CAAA,CAAM,EAAA,GAAK,OAAO,CAAA,GAAA,CAAK,EAAA,GAAK,OAAO,CAAC,CAAA;AACtD,QAAA,IAAI,IAAA,GAAO,QAAA,IAAY,IAAA,GAAO,SAAA,EAAW;AACvC,UAAA,QAAA,GAAW,IAAA;AACX,UAAA,IAAA,GAAO,EAAE,WAAA,EAAa,MAAA,CAAO,KAAA,EAAO,UAAA,EAAY,CAAA,EAAG,QAAA,EAAU,IAAA,EAAM,CAAA,EAAG,EAAA,EAAI,CAAA,EAAG,EAAA,EAAG;AAAA,QAClF;AAAA,MACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AACF","file":"chunk-6UWYKNFN.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, path, circle, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Radar / Spider chart — plots multi-dimensional data on radial axes.\n * Each category becomes an axis radiating from center.\n */\nexport const radarChartType: ChartTypePlugin = {\n type: 'radar',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme } = ctx\n const nodes: RenderNode[] = []\n\n const labelCount = data.labels.length\n if (labelCount < 3) return nodes\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const radius = Math.min(area.width, area.height) / 2 - 24\n\n // Find the max value across all series for scaling\n let maxVal = 0\n for (const series of data.series) {\n for (const v of series.values) {\n if (Math.abs(v) > maxVal) maxVal = Math.abs(v)\n }\n }\n if (maxVal === 0) maxVal = 1\n\n const angleStep = (Math.PI * 2) / labelCount\n const startAngle = -Math.PI / 2 // start from top\n\n // Draw grid rings (3 levels)\n const gridLevels = 3\n for (let level = 1; level <= gridLevels; level++) {\n const r = (radius * level) / gridLevels\n const pb = new PathBuilder()\n for (let i = 0; i <= labelCount; i++) {\n const angle = startAngle + (i % labelCount) * angleStep\n const x = cx + r * Math.cos(angle)\n const y = cy + r * Math.sin(angle)\n if (i === 0) pb.moveTo(x, y)\n else pb.lineTo(x, y)\n }\n nodes.push(path(pb.build(), {\n class: 'chartts-radar-grid',\n stroke: theme.gridColor,\n strokeWidth: theme.gridWidth,\n fillOpacity: 0,\n fill: 'none',\n }))\n }\n\n // Draw axis lines from center to each vertex\n for (let i = 0; i < labelCount; i++) {\n const angle = startAngle + i * angleStep\n const x = cx + radius * Math.cos(angle)\n const y = cy + radius * Math.sin(angle)\n\n nodes.push({\n type: 'line',\n x1: cx,\n y1: cy,\n x2: x,\n y2: y,\n attrs: {\n class: 'chartts-radar-axis',\n stroke: theme.gridColor,\n strokeWidth: theme.gridWidth,\n },\n })\n\n // Label at vertex\n const labelR = radius + 14\n const lx = cx + labelR * Math.cos(angle)\n const ly = cy + labelR * Math.sin(angle)\n const anchor = Math.abs(Math.cos(angle)) < 0.01 ? 'middle' as const\n : Math.cos(angle) > 0 ? 'start' as const : 'end' as const\n\n nodes.push(text(lx, ly, String(data.labels[i]!), {\n class: 'chartts-radar-label',\n fill: theme.textMuted,\n textAnchor: anchor,\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Draw series polygons\n for (const series of data.series) {\n const pb = new PathBuilder()\n const points: { x: number; y: number }[] = []\n\n for (let i = 0; i < labelCount; i++) {\n const val = series.values[i] ?? 0\n const r = (Math.abs(val) / maxVal) * radius\n const angle = startAngle + i * angleStep\n const x = cx + r * Math.cos(angle)\n const y = cy + r * Math.sin(angle)\n points.push({ x, y })\n\n if (i === 0) pb.moveTo(x, y)\n else pb.lineTo(x, y)\n }\n pb.close()\n\n const seriesNodes: RenderNode[] = []\n\n // Fill\n seriesNodes.push(path(pb.build(), {\n class: 'chartts-radar-area',\n fill: series.color,\n fillOpacity: 0.2,\n stroke: series.color,\n strokeWidth: theme.lineWidth,\n 'data-series': series.index,\n }))\n\n // Points\n for (let i = 0; i < points.length; i++) {\n seriesNodes.push(circle(points[i]!.x, points[i]!.y, theme.pointRadius, {\n class: 'chartts-radar-point',\n fill: series.color,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name} ${data.labels[i]}: ${series.values[i]}`,\n }))\n }\n\n nodes.push(group(seriesNodes, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const labelCount = data.labels.length\n if (labelCount < 3) return null\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const radius = Math.min(area.width, area.height) / 2 - 24\n const angleStep = (Math.PI * 2) / labelCount\n const startAngle = -Math.PI / 2\n\n let maxVal = 0\n for (const series of data.series) {\n for (const v of series.values) {\n if (Math.abs(v) > maxVal) maxVal = Math.abs(v)\n }\n }\n if (maxVal === 0) return null\n\n let best: HitResult | null = null\n let bestDist = Infinity\n const hitRadius = 15\n\n for (const series of data.series) {\n for (let i = 0; i < labelCount; i++) {\n const val = series.values[i] ?? 0\n const r = (Math.abs(val) / maxVal) * radius\n const angle = startAngle + i * angleStep\n const px = cx + r * Math.cos(angle)\n const py = cy + r * Math.sin(angle)\n const dist = Math.sqrt((mx - px) ** 2 + (my - py) ** 2)\n if (dist < bestDist && dist < hitRadius) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist, x: px, y: py }\n }\n }\n }\n\n return best\n },\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/radar/radar-type.ts"],"names":["prepareNoAxes","PathBuilder","path","text","circle","group"],"mappings":"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","file":"chunk-MSCRIA2U.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, path, circle, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Radar / Spider chart — plots multi-dimensional data on radial axes.\n * Each category becomes an axis radiating from center.\n */\nexport const radarChartType: ChartTypePlugin = {\n type: 'radar',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme } = ctx\n const nodes: RenderNode[] = []\n\n const labelCount = data.labels.length\n if (labelCount < 3) return nodes\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const radius = Math.min(area.width, area.height) / 2 - 24\n\n // Find the max value across all series for scaling\n let maxVal = 0\n for (const series of data.series) {\n for (const v of series.values) {\n if (Math.abs(v) > maxVal) maxVal = Math.abs(v)\n }\n }\n if (maxVal === 0) maxVal = 1\n\n const angleStep = (Math.PI * 2) / labelCount\n const startAngle = -Math.PI / 2 // start from top\n\n // Draw grid rings (3 levels)\n const gridLevels = 3\n for (let level = 1; level <= gridLevels; level++) {\n const r = (radius * level) / gridLevels\n const pb = new PathBuilder()\n for (let i = 0; i <= labelCount; i++) {\n const angle = startAngle + (i % labelCount) * angleStep\n const x = cx + r * Math.cos(angle)\n const y = cy + r * Math.sin(angle)\n if (i === 0) pb.moveTo(x, y)\n else pb.lineTo(x, y)\n }\n nodes.push(path(pb.build(), {\n class: 'chartts-radar-grid',\n stroke: theme.gridColor,\n strokeWidth: theme.gridWidth,\n fillOpacity: 0,\n fill: 'none',\n }))\n }\n\n // Draw axis lines from center to each vertex\n for (let i = 0; i < labelCount; i++) {\n const angle = startAngle + i * angleStep\n const x = cx + radius * Math.cos(angle)\n const y = cy + radius * Math.sin(angle)\n\n nodes.push({\n type: 'line',\n x1: cx,\n y1: cy,\n x2: x,\n y2: y,\n attrs: {\n class: 'chartts-radar-axis',\n stroke: theme.gridColor,\n strokeWidth: theme.gridWidth,\n },\n })\n\n // Label at vertex\n const labelR = radius + 14\n const lx = cx + labelR * Math.cos(angle)\n const ly = cy + labelR * Math.sin(angle)\n const anchor = Math.abs(Math.cos(angle)) < 0.01 ? 'middle' as const\n : Math.cos(angle) > 0 ? 'start' as const : 'end' as const\n\n nodes.push(text(lx, ly, String(data.labels[i]!), {\n class: 'chartts-radar-label',\n fill: theme.textMuted,\n textAnchor: anchor,\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Draw series polygons\n for (const series of data.series) {\n const pb = new PathBuilder()\n const points: { x: number; y: number }[] = []\n\n for (let i = 0; i < labelCount; i++) {\n const val = series.values[i] ?? 0\n const r = (Math.abs(val) / maxVal) * radius\n const angle = startAngle + i * angleStep\n const x = cx + r * Math.cos(angle)\n const y = cy + r * Math.sin(angle)\n points.push({ x, y })\n\n if (i === 0) pb.moveTo(x, y)\n else pb.lineTo(x, y)\n }\n pb.close()\n\n const seriesNodes: RenderNode[] = []\n\n // Fill\n seriesNodes.push(path(pb.build(), {\n class: 'chartts-radar-area',\n fill: series.color,\n fillOpacity: 0.2,\n stroke: series.color,\n strokeWidth: theme.lineWidth,\n 'data-series': series.index,\n }))\n\n // Points\n for (let i = 0; i < points.length; i++) {\n seriesNodes.push(circle(points[i]!.x, points[i]!.y, theme.pointRadius, {\n class: 'chartts-radar-point',\n fill: series.color,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name} ${data.labels[i]}: ${series.values[i]}`,\n }))\n }\n\n nodes.push(group(seriesNodes, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const labelCount = data.labels.length\n if (labelCount < 3) return null\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const radius = Math.min(area.width, area.height) / 2 - 24\n const angleStep = (Math.PI * 2) / labelCount\n const startAngle = -Math.PI / 2\n\n let maxVal = 0\n for (const series of data.series) {\n for (const v of series.values) {\n if (Math.abs(v) > maxVal) maxVal = Math.abs(v)\n }\n }\n if (maxVal === 0) return null\n\n let best: HitResult | null = null\n let bestDist = Infinity\n const hitRadius = 15\n\n for (const series of data.series) {\n for (let i = 0; i < labelCount; i++) {\n const val = series.values[i] ?? 0\n const r = (Math.abs(val) / maxVal) * radius\n const angle = startAngle + i * angleStep\n const px = cx + r * Math.cos(angle)\n const py = cy + r * Math.sin(angle)\n const dist = Math.sqrt((mx - px) ** 2 + (my - py) ** 2)\n if (dist < bestDist && dist < hitRadius) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist, x: px, y: py }\n }\n }\n }\n\n return best\n },\n}\n"]}
@@ -1,5 +1,5 @@
1
- import { prepareNoAxes } from './chunk-MPQECPE3.js';
2
- import { PathBuilder, path, text } from './chunk-DX4FBN3I.js';
1
+ import { prepareNoAxes } from './chunk-T7SCCACB.js';
2
+ import { PathBuilder, path, text } from './chunk-AEQXFDL7.js';
3
3
 
4
4
  // src/charts/themeriver/themeriver-type.ts
5
5
  var themeRiverChartType = {
@@ -163,5 +163,5 @@ var themeRiverChartType = {
163
163
  };
164
164
 
165
165
  export { themeRiverChartType };
166
- //# sourceMappingURL=chunk-UZH6PVHD.js.map
167
- //# sourceMappingURL=chunk-UZH6PVHD.js.map
166
+ //# sourceMappingURL=chunk-N35UAFEU.js.map
167
+ //# sourceMappingURL=chunk-N35UAFEU.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/themeriver/themeriver-type.ts"],"names":[],"mappings":"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","file":"chunk-UZH6PVHD.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { path, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * ThemeRiver / StreamGraph chart — stacked area chart with a center baseline.\n *\n * Data convention:\n * - labels: time points (x-axis categories)\n * - series[i]: a stream layer. values[j] = thickness at time j\n *\n * The streams are stacked symmetrically around the horizontal center,\n * creating an organic river-like visualization.\n */\n\nexport const themeRiverChartType: ChartTypePlugin = {\n type: 'themeriver',\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 timeCount = data.labels.length\n if (timeCount < 2 || data.series.length === 0) return nodes\n\n const seriesCount = data.series.length\n\n // Compute stacked values\n const stacks: number[][] = []\n for (let t = 0; t < timeCount; t++) {\n const column: number[] = []\n for (let si = 0; si < seriesCount; si++) {\n column.push(Math.abs(data.series[si]!.values[t] ?? 0))\n }\n stacks.push(column)\n }\n\n // Compute baseline offsets (wiggle / silhouette centering)\n const baselines: number[] = []\n for (let t = 0; t < timeCount; t++) {\n const total = stacks[t]!.reduce((s, v) => s + v, 0)\n baselines.push(-total / 2) // Center around 0\n }\n\n // Find global min/max for y-scale\n let yMin = Infinity\n let yMax = -Infinity\n for (let t = 0; t < timeCount; t++) {\n let cumulative = baselines[t]!\n if (cumulative < yMin) yMin = cumulative\n for (let si = 0; si < seriesCount; si++) {\n cumulative += stacks[t]![si]!\n }\n if (cumulative > yMax) yMax = cumulative\n }\n if (yMin === yMax) { yMin -= 1; yMax += 1 }\n\n const xStep = area.width / Math.max(timeCount - 1, 1)\n const mapX = (t: number) => area.x + t * xStep\n const mapY = (val: number) => {\n const frac = (val - yMin) / (yMax - yMin)\n return area.y + area.height - frac * area.height\n }\n\n // Render each series as a stream band\n for (let si = 0; si < seriesCount; si++) {\n const series = data.series[si]!\n const color = series.color ?? options.colors[si % options.colors.length]!\n\n // Compute top and bottom edges for this series\n const tops: { x: number; y: number }[] = []\n const bottoms: { x: number; y: number }[] = []\n\n for (let t = 0; t < timeCount; t++) {\n let cumBottom = baselines[t]!\n for (let s = 0; s < si; s++) {\n cumBottom += stacks[t]![s]!\n }\n const cumTop = cumBottom + stacks[t]![si]!\n\n tops.push({ x: mapX(t), y: mapY(cumTop) })\n bottoms.push({ x: mapX(t), y: mapY(cumBottom) })\n }\n\n // Build smooth path: top edge forward, bottom edge backward\n const pb = new PathBuilder()\n\n // Top edge (left to right)\n pb.moveTo(tops[0]!.x, tops[0]!.y)\n for (let t = 1; t < timeCount; t++) {\n const prev = tops[t - 1]!\n const curr = tops[t]!\n const cpx = (prev.x + curr.x) / 2\n pb.curveTo(cpx, prev.y, cpx, curr.y, curr.x, curr.y)\n }\n\n // Bottom edge (right to left)\n pb.lineTo(bottoms[timeCount - 1]!.x, bottoms[timeCount - 1]!.y)\n for (let t = timeCount - 2; t >= 0; t--) {\n const prev = bottoms[t + 1]!\n const curr = bottoms[t]!\n const cpx = (prev.x + curr.x) / 2\n pb.curveTo(cpx, prev.y, cpx, curr.y, curr.x, curr.y)\n }\n\n pb.close()\n\n nodes.push(path(pb.build(), {\n class: 'chartts-themeriver-stream',\n fill: color,\n fillOpacity: 0.75,\n stroke: color,\n strokeWidth: 0.5,\n 'data-series': si,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}`,\n }))\n\n // Label at the widest point\n let maxWidth = 0\n let maxT = 0\n for (let t = 0; t < timeCount; t++) {\n const width = Math.abs(tops[t]!.y - bottoms[t]!.y)\n if (width > maxWidth) {\n maxWidth = width\n maxT = t\n }\n }\n\n if (maxWidth > 16) {\n const midY = (tops[maxT]!.y + bottoms[maxT]!.y) / 2\n const fontSize = Math.min(theme.fontSizeSmall, maxWidth * 0.4)\n nodes.push(text(tops[maxT]!.x, midY, series.name, {\n class: 'chartts-themeriver-label',\n fill: '#fff',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\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 timeCount = data.labels.length\n if (timeCount < 2 || data.series.length === 0) return null\n\n const seriesCount = data.series.length\n const xStep = area.width / Math.max(timeCount - 1, 1)\n\n // Find closest time index\n const t = Math.round((mx - area.x) / xStep)\n if (t < 0 || t >= timeCount) return null\n\n // Compute stacks at this time\n const column: number[] = []\n for (let si = 0; si < seriesCount; si++) {\n column.push(Math.abs(data.series[si]!.values[t] ?? 0))\n }\n const total = column.reduce((s, v) => s + v, 0)\n const baseline = -total / 2\n\n // Find global scale\n let yMin = Infinity\n let yMax = -Infinity\n for (let tt = 0; tt < timeCount; tt++) {\n let cum = 0\n for (let si = 0; si < seriesCount; si++) {\n cum += Math.abs(data.series[si]!.values[tt] ?? 0)\n }\n const bl = -cum / 2\n if (bl < yMin) yMin = bl\n if (bl + cum > yMax) yMax = bl + cum\n }\n if (yMin === yMax) { yMin -= 1; yMax += 1 }\n\n const mapY = (val: number) => {\n const frac = (val - yMin) / (yMax - yMin)\n return area.y + area.height - frac * area.height\n }\n\n // Check which stream the y coordinate falls in\n let cumBottom = baseline\n for (let si = 0; si < seriesCount; si++) {\n const cumTop = cumBottom + column[si]!\n const topY = mapY(cumTop)\n const bottomY = mapY(cumBottom)\n\n if (my >= topY && my <= bottomY) {\n return { seriesIndex: si, pointIndex: t, distance: 0, x: area.x + t * xStep, y: mapY((cumBottom + cumTop) / 2) }\n }\n cumBottom = cumTop\n }\n\n return null\n },\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/themeriver/themeriver-type.ts"],"names":[],"mappings":"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","file":"chunk-N35UAFEU.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { path, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * ThemeRiver / StreamGraph chart — stacked area chart with a center baseline.\n *\n * Data convention:\n * - labels: time points (x-axis categories)\n * - series[i]: a stream layer. values[j] = thickness at time j\n *\n * The streams are stacked symmetrically around the horizontal center,\n * creating an organic river-like visualization.\n */\n\nexport const themeRiverChartType: ChartTypePlugin = {\n type: 'themeriver',\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 timeCount = data.labels.length\n if (timeCount < 2 || data.series.length === 0) return nodes\n\n const seriesCount = data.series.length\n\n // Compute stacked values\n const stacks: number[][] = []\n for (let t = 0; t < timeCount; t++) {\n const column: number[] = []\n for (let si = 0; si < seriesCount; si++) {\n column.push(Math.abs(data.series[si]!.values[t] ?? 0))\n }\n stacks.push(column)\n }\n\n // Compute baseline offsets (wiggle / silhouette centering)\n const baselines: number[] = []\n for (let t = 0; t < timeCount; t++) {\n const total = stacks[t]!.reduce((s, v) => s + v, 0)\n baselines.push(-total / 2) // Center around 0\n }\n\n // Find global min/max for y-scale\n let yMin = Infinity\n let yMax = -Infinity\n for (let t = 0; t < timeCount; t++) {\n let cumulative = baselines[t]!\n if (cumulative < yMin) yMin = cumulative\n for (let si = 0; si < seriesCount; si++) {\n cumulative += stacks[t]![si]!\n }\n if (cumulative > yMax) yMax = cumulative\n }\n if (yMin === yMax) { yMin -= 1; yMax += 1 }\n\n const xStep = area.width / Math.max(timeCount - 1, 1)\n const mapX = (t: number) => area.x + t * xStep\n const mapY = (val: number) => {\n const frac = (val - yMin) / (yMax - yMin)\n return area.y + area.height - frac * area.height\n }\n\n // Render each series as a stream band\n for (let si = 0; si < seriesCount; si++) {\n const series = data.series[si]!\n const color = series.color ?? options.colors[si % options.colors.length]!\n\n // Compute top and bottom edges for this series\n const tops: { x: number; y: number }[] = []\n const bottoms: { x: number; y: number }[] = []\n\n for (let t = 0; t < timeCount; t++) {\n let cumBottom = baselines[t]!\n for (let s = 0; s < si; s++) {\n cumBottom += stacks[t]![s]!\n }\n const cumTop = cumBottom + stacks[t]![si]!\n\n tops.push({ x: mapX(t), y: mapY(cumTop) })\n bottoms.push({ x: mapX(t), y: mapY(cumBottom) })\n }\n\n // Build smooth path: top edge forward, bottom edge backward\n const pb = new PathBuilder()\n\n // Top edge (left to right)\n pb.moveTo(tops[0]!.x, tops[0]!.y)\n for (let t = 1; t < timeCount; t++) {\n const prev = tops[t - 1]!\n const curr = tops[t]!\n const cpx = (prev.x + curr.x) / 2\n pb.curveTo(cpx, prev.y, cpx, curr.y, curr.x, curr.y)\n }\n\n // Bottom edge (right to left)\n pb.lineTo(bottoms[timeCount - 1]!.x, bottoms[timeCount - 1]!.y)\n for (let t = timeCount - 2; t >= 0; t--) {\n const prev = bottoms[t + 1]!\n const curr = bottoms[t]!\n const cpx = (prev.x + curr.x) / 2\n pb.curveTo(cpx, prev.y, cpx, curr.y, curr.x, curr.y)\n }\n\n pb.close()\n\n nodes.push(path(pb.build(), {\n class: 'chartts-themeriver-stream',\n fill: color,\n fillOpacity: 0.75,\n stroke: color,\n strokeWidth: 0.5,\n 'data-series': si,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}`,\n }))\n\n // Label at the widest point\n let maxWidth = 0\n let maxT = 0\n for (let t = 0; t < timeCount; t++) {\n const width = Math.abs(tops[t]!.y - bottoms[t]!.y)\n if (width > maxWidth) {\n maxWidth = width\n maxT = t\n }\n }\n\n if (maxWidth > 16) {\n const midY = (tops[maxT]!.y + bottoms[maxT]!.y) / 2\n const fontSize = Math.min(theme.fontSizeSmall, maxWidth * 0.4)\n nodes.push(text(tops[maxT]!.x, midY, series.name, {\n class: 'chartts-themeriver-label',\n fill: '#fff',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\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 timeCount = data.labels.length\n if (timeCount < 2 || data.series.length === 0) return null\n\n const seriesCount = data.series.length\n const xStep = area.width / Math.max(timeCount - 1, 1)\n\n // Find closest time index\n const t = Math.round((mx - area.x) / xStep)\n if (t < 0 || t >= timeCount) return null\n\n // Compute stacks at this time\n const column: number[] = []\n for (let si = 0; si < seriesCount; si++) {\n column.push(Math.abs(data.series[si]!.values[t] ?? 0))\n }\n const total = column.reduce((s, v) => s + v, 0)\n const baseline = -total / 2\n\n // Find global scale\n let yMin = Infinity\n let yMax = -Infinity\n for (let tt = 0; tt < timeCount; tt++) {\n let cum = 0\n for (let si = 0; si < seriesCount; si++) {\n cum += Math.abs(data.series[si]!.values[tt] ?? 0)\n }\n const bl = -cum / 2\n if (bl < yMin) yMin = bl\n if (bl + cum > yMax) yMax = bl + cum\n }\n if (yMin === yMax) { yMin -= 1; yMax += 1 }\n\n const mapY = (val: number) => {\n const frac = (val - yMin) / (yMax - yMin)\n return area.y + area.height - frac * area.height\n }\n\n // Check which stream the y coordinate falls in\n let cumBottom = baseline\n for (let si = 0; si < seriesCount; si++) {\n const cumTop = cumBottom + column[si]!\n const topY = mapY(cumTop)\n const bottomY = mapY(cumBottom)\n\n if (my >= topY && my <= bottomY) {\n return { seriesIndex: si, pointIndex: t, distance: 0, x: area.x + t * xStep, y: mapY((cumBottom + cumTop) / 2) }\n }\n cumBottom = cumTop\n }\n\n return null\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 chunkV5Q6UNUK_cjs = require('./chunk-V5Q6UNUK.cjs');
4
+ var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
5
5
 
6
6
  // src/charts/matrix/matrix-type.ts
7
7
  var matrixChartType = {
@@ -10,7 +10,7 @@ var matrixChartType = {
10
10
  return { x: "categorical", y: "categorical" };
11
11
  },
12
12
  prepareData(data, options) {
13
- return chunkCDS2NXGT_cjs.prepareNoAxes(data, options);
13
+ return chunkV5Q6UNUK_cjs.prepareNoAxes(data, options);
14
14
  },
15
15
  render(ctx) {
16
16
  const { data, area, theme, options } = ctx;
@@ -43,7 +43,7 @@ var matrixChartType = {
43
43
  const gridY = area.y + labelPadTop;
44
44
  for (let c = 0; c < cols; c++) {
45
45
  const cx = gridX + c * (cellW + gap) + cellW / 2;
46
- nodes.push(chunkUMIJYYF3_cjs.text(cx, gridY - 8, String(data.labels[c] ?? ""), {
46
+ nodes.push(chunkJVVGQLJQ_cjs.text(cx, gridY - 8, String(data.labels[c] ?? ""), {
47
47
  class: "chartts-matrix-col-label",
48
48
  fill: theme.textMuted,
49
49
  textAnchor: "middle",
@@ -55,7 +55,7 @@ var matrixChartType = {
55
55
  for (let r = 0; r < rows; r++) {
56
56
  const series = data.series[r];
57
57
  const ry = gridY + r * (cellH + gap);
58
- nodes.push(chunkUMIJYYF3_cjs.text(gridX - 6, ry + cellH / 2, series.name, {
58
+ nodes.push(chunkJVVGQLJQ_cjs.text(gridX - 6, ry + cellH / 2, series.name, {
59
59
  class: "chartts-matrix-row-label",
60
60
  fill: theme.textMuted,
61
61
  textAnchor: "end",
@@ -69,7 +69,7 @@ var matrixChartType = {
69
69
  const cx = gridX + c * (cellW + gap);
70
70
  const color = getCellColor(val, allMin, allMax, valRange, colorScale, options.colors);
71
71
  const textColor = getContrastColor(val, allMin, allMax, valRange, colorScale);
72
- rowNodes.push(chunkUMIJYYF3_cjs.rect(cx, ry, cellW, cellH, {
72
+ rowNodes.push(chunkJVVGQLJQ_cjs.rect(cx, ry, cellW, cellH, {
73
73
  class: "chartts-matrix-cell",
74
74
  fill: color,
75
75
  rx: cellRadius,
@@ -82,7 +82,7 @@ var matrixChartType = {
82
82
  }));
83
83
  if (showValues && cellW > 18 && cellH > 14) {
84
84
  const displayVal = Number.isInteger(val) ? String(val) : Math.abs(val) < 10 ? val.toFixed(2) : val.toFixed(1);
85
- rowNodes.push(chunkUMIJYYF3_cjs.text(cx + cellW / 2, ry + cellH / 2, displayVal, {
85
+ rowNodes.push(chunkJVVGQLJQ_cjs.text(cx + cellW / 2, ry + cellH / 2, displayVal, {
86
86
  class: "chartts-matrix-value",
87
87
  fill: textColor,
88
88
  textAnchor: "middle",
@@ -94,7 +94,7 @@ var matrixChartType = {
94
94
  }));
95
95
  }
96
96
  }
97
- nodes.push(chunkUMIJYYF3_cjs.group(rowNodes, {
97
+ nodes.push(chunkJVVGQLJQ_cjs.group(rowNodes, {
98
98
  class: `chartts-series chartts-series-${r}`,
99
99
  "data-series-name": series.name
100
100
  }));
@@ -155,5 +155,5 @@ function interpolateOpacity(baseColor, opacity) {
155
155
  }
156
156
 
157
157
  exports.matrixChartType = matrixChartType;
158
- //# sourceMappingURL=chunk-6E6ZDWZD.cjs.map
159
- //# sourceMappingURL=chunk-6E6ZDWZD.cjs.map
158
+ //# sourceMappingURL=chunk-NE2W2MF3.cjs.map
159
+ //# sourceMappingURL=chunk-NE2W2MF3.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/matrix/matrix-type.ts"],"names":["prepareNoAxes","text","rect","group","t"],"mappings":";;;;;;AA8BO,IAAM,eAAA,GAAmC;AAAA,EAC9C,IAAA,EAAM,QAAA;AAAA,EAEN,aAAA,GAAgD;AAC9C,IAAA,OAAO,EAAE,CAAA,EAAG,aAAA,EAAe,CAAA,EAAG,aAAA,EAAc;AAAA,EAC9C,CAAA;AAAA,EAEA,WAAA,CAAY,MAAiB,OAAA,EAAwC;AACnE,IAAA,OAAOA,+BAAA,CAAc,MAAM,OAAO,CAAA;AAAA,EACpC,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,MAAM,EAAE,IAAA,EAAM,IAAA,EAAM,KAAA,EAAO,SAAQ,GAAI,GAAA;AACvC,IAAA,MAAM,QAAsB,EAAC;AAE7B,IAAA,MAAM,KAAA,GAAQ,OAAA;AACd,IAAA,MAAM,UAAA,GAAa,MAAM,UAAA,KAAe,KAAA;AACxC,IAAA,MAAM,UAAA,GAAa,MAAM,UAAA,IAAc,CAAA;AACvC,IAAA,MAAM,UAAA,GAAa,MAAM,UAAA,IAAc,YAAA;AAEvC,IAAA,MAAM,IAAA,GAAO,KAAK,MAAA,CAAO,MAAA;AACzB,IAAA,MAAM,IAAA,GAAO,KAAK,MAAA,CAAO,MAAA;AACzB,IAAA,IAAI,IAAA,KAAS,CAAA,IAAK,IAAA,KAAS,CAAA,EAAG,OAAO,KAAA;AAGrC,IAAA,IAAI,MAAA,GAAS,UAAU,MAAA,GAAS,CAAA,QAAA;AAChC,IAAA,KAAA,MAAW,CAAA,IAAK,KAAK,MAAA,EAAQ;AAC3B,MAAA,KAAA,MAAW,CAAA,IAAK,EAAE,MAAA,EAAQ;AACxB,QAAA,IAAI,CAAA,GAAI,QAAQ,MAAA,GAAS,CAAA;AACzB,QAAA,IAAI,CAAA,GAAI,QAAQ,MAAA,GAAS,CAAA;AAAA,MAC3B;AAAA,IACF;AACA,IAAA,IAAI,CAAC,QAAA,CAAS,MAAM,CAAA,EAAG,MAAA,GAAS,CAAA;AAChC,IAAA,IAAI,CAAC,QAAA,CAAS,MAAM,CAAA,EAAG,MAAA,GAAS,CAAA;AAChC,IAAA,MAAM,QAAA,GAAW,SAAS,MAAA,IAAU,CAAA;AAGpC,IAAA,MAAM,YAAA,GAAe,EAAA;AACrB,IAAA,MAAM,WAAA,GAAc,EAAA;AACpB,IAAA,MAAM,GAAA,GAAM,CAAA;AACZ,IAAA,MAAM,KAAA,GAAQ,IAAA,CAAK,KAAA,GAAQ,YAAA,GAAe,EAAA;AAC1C,IAAA,MAAM,KAAA,GAAQ,IAAA,CAAK,MAAA,GAAS,WAAA,GAAc,EAAA;AAC1C,IAAA,MAAM,KAAA,GAAA,CAAS,KAAA,GAAQ,GAAA,IAAO,IAAA,GAAO,CAAA,CAAA,IAAM,IAAA;AAC3C,IAAA,MAAM,KAAA,GAAA,CAAS,KAAA,GAAQ,GAAA,IAAO,IAAA,GAAO,CAAA,CAAA,IAAM,IAAA;AAC3C,IAAA,MAAM,KAAA,GAAQ,KAAK,CAAA,GAAI,YAAA;AACvB,IAAA,MAAM,KAAA,GAAQ,KAAK,CAAA,GAAI,WAAA;AAGvB,IAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,IAAA,EAAM,CAAA,EAAA,EAAK;AAC7B,MAAA,MAAM,EAAA,GAAK,KAAA,GAAQ,CAAA,IAAK,KAAA,GAAQ,OAAO,KAAA,GAAQ,CAAA;AAC/C,MAAA,KAAA,CAAM,IAAA,CAAKC,sBAAA,CAAK,EAAA,EAAI,KAAA,GAAQ,CAAA,EAAG,MAAA,CAAO,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA,IAAK,EAAE,CAAA,EAAG;AAAA,QAC3D,KAAA,EAAO,0BAAA;AAAA,QACP,MAAM,KAAA,CAAM,SAAA;AAAA,QACZ,UAAA,EAAY,QAAA;AAAA,QACZ,gBAAA,EAAkB,MAAA;AAAA,QAClB,UAAU,IAAA,CAAK,GAAA,CAAI,KAAA,CAAM,aAAA,EAAe,QAAQ,IAAI,CAAA;AAAA,QACpD,YAAY,KAAA,CAAM;AAAA,OACnB,CAAC,CAAA;AAAA,IACJ;AAGA,IAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,IAAA,EAAM,CAAA,EAAA,EAAK;AAC7B,MAAA,MAAM,MAAA,GAAS,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA;AAC5B,MAAA,MAAM,EAAA,GAAK,KAAA,GAAQ,CAAA,IAAK,KAAA,GAAQ,GAAA,CAAA;AAGhC,MAAA,KAAA,CAAM,IAAA,CAAKA,uBAAK,KAAA,GAAQ,CAAA,EAAG,KAAK,KAAA,GAAQ,CAAA,EAAG,OAAO,IAAA,EAAM;AAAA,QACtD,KAAA,EAAO,0BAAA;AAAA,QACP,MAAM,KAAA,CAAM,SAAA;AAAA,QACZ,UAAA,EAAY,KAAA;AAAA,QACZ,gBAAA,EAAkB,SAAA;AAAA,QAClB,UAAU,IAAA,CAAK,GAAA,CAAI,KAAA,CAAM,aAAA,EAAe,QAAQ,GAAG,CAAA;AAAA,QACnD,YAAY,KAAA,CAAM;AAAA,OACnB,CAAC,CAAA;AAEF,MAAA,MAAM,WAAyB,EAAC;AAChC,MAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,IAAA,EAAM,CAAA,EAAA,EAAK;AAC7B,QAAA,MAAM,GAAA,GAAM,MAAA,CAAO,MAAA,CAAO,CAAC,CAAA,IAAK,CAAA;AAChC,QAAA,MAAM,EAAA,GAAK,KAAA,GAAQ,CAAA,IAAK,KAAA,GAAQ,GAAA,CAAA;AAGhC,QAAA,MAAM,KAAA,GAAQ,aAAa,GAAA,EAAK,MAAA,EAAQ,QAAQ,QAAA,EAAU,UAAA,EAAY,QAAQ,MAAM,CAAA;AACpF,QAAA,MAAM,YAAY,gBAAA,CAAiB,GAAA,EAAK,MAAA,EAAQ,MAAA,EAAQ,UAAU,UAAU,CAAA;AAE5E,QAAA,QAAA,CAAS,IAAA,CAAKC,sBAAA,CAAK,EAAA,EAAI,EAAA,EAAI,OAAO,KAAA,EAAO;AAAA,UACvC,KAAA,EAAO,qBAAA;AAAA,UACP,IAAA,EAAM,KAAA;AAAA,UACN,EAAA,EAAI,UAAA;AAAA,UACJ,EAAA,EAAI,UAAA;AAAA,UACJ,aAAA,EAAe,CAAA;AAAA,UACf,YAAA,EAAc,CAAA;AAAA,UACd,QAAA,EAAU,CAAA;AAAA,UACV,IAAA,EAAM,KAAA;AAAA,UACN,SAAA,EAAW,CAAA,EAAG,MAAA,CAAO,IAAI,CAAA,MAAA,EAAM,KAAK,MAAA,CAAO,CAAC,CAAC,CAAA,EAAA,EAAK,GAAG,CAAA;AAAA,SACtD,CAAC,CAAA;AAGF,QAAA,IAAI,UAAA,IAAc,KAAA,GAAQ,EAAA,IAAM,KAAA,GAAQ,EAAA,EAAI;AAC1C,UAAA,MAAM,aAAa,MAAA,CAAO,SAAA,CAAU,GAAG,CAAA,GAAI,MAAA,CAAO,GAAG,CAAA,GACjD,IAAA,CAAK,IAAI,GAAG,CAAA,GAAI,KAAK,GAAA,CAAI,OAAA,CAAQ,CAAC,CAAA,GAAI,GAAA,CAAI,QAAQ,CAAC,CAAA;AAEvD,UAAA,QAAA,CAAS,IAAA,CAAKD,uBAAK,EAAA,GAAK,KAAA,GAAQ,GAAG,EAAA,GAAK,KAAA,GAAQ,GAAG,UAAA,EAAY;AAAA,YAC7D,KAAA,EAAO,sBAAA;AAAA,YACP,IAAA,EAAM,SAAA;AAAA,YACN,UAAA,EAAY,QAAA;AAAA,YACZ,gBAAA,EAAkB,SAAA;AAAA,YAClB,QAAA,EAAU,KAAK,GAAA,CAAI,KAAA,CAAM,eAAe,KAAA,GAAQ,GAAA,EAAK,QAAQ,GAAG,CAAA;AAAA,YAChE,YAAY,KAAA,CAAM,UAAA;AAAA,YAClB,UAAA,EAAY,GAAA;AAAA,YACZ,aAAA,EAAe;AAAA,WAChB,CAAC,CAAA;AAAA,QACJ;AAAA,MACF;AAEA,MAAA,KAAA,CAAM,IAAA,CAAKE,wBAAM,QAAA,EAAU;AAAA,QACzB,KAAA,EAAO,iCAAiC,CAAC,CAAA,CAAA;AAAA,QACzC,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,IAAA,EAAK,GAAI,GAAA;AACvB,IAAA,MAAM,IAAA,GAAO,KAAK,MAAA,CAAO,MAAA;AACzB,IAAA,MAAM,IAAA,GAAO,KAAK,MAAA,CAAO,MAAA;AACzB,IAAA,IAAI,IAAA,KAAS,CAAA,IAAK,IAAA,KAAS,CAAA,EAAG,OAAO,IAAA;AAErC,IAAA,MAAM,YAAA,GAAe,EAAA;AACrB,IAAA,MAAM,WAAA,GAAc,EAAA;AACpB,IAAA,MAAM,GAAA,GAAM,CAAA;AACZ,IAAA,MAAM,KAAA,GAAQ,IAAA,CAAK,KAAA,GAAQ,YAAA,GAAe,EAAA;AAC1C,IAAA,MAAM,KAAA,GAAQ,IAAA,CAAK,MAAA,GAAS,WAAA,GAAc,EAAA;AAC1C,IAAA,MAAM,KAAA,GAAA,CAAS,KAAA,GAAQ,GAAA,IAAO,IAAA,GAAO,CAAA,CAAA,IAAM,IAAA;AAC3C,IAAA,MAAM,KAAA,GAAA,CAAS,KAAA,GAAQ,GAAA,IAAO,IAAA,GAAO,CAAA,CAAA,IAAM,IAAA;AAC3C,IAAA,MAAM,KAAA,GAAQ,KAAK,CAAA,GAAI,YAAA;AACvB,IAAA,MAAM,KAAA,GAAQ,KAAK,CAAA,GAAI,WAAA;AAEvB,IAAA,MAAM,MAAM,IAAA,CAAK,KAAA,CAAA,CAAO,EAAA,GAAK,KAAA,KAAU,QAAQ,GAAA,CAAI,CAAA;AACnD,IAAA,MAAM,MAAM,IAAA,CAAK,KAAA,CAAA,CAAO,EAAA,GAAK,KAAA,KAAU,QAAQ,GAAA,CAAI,CAAA;AAEnD,IAAA,IAAI,OAAO,CAAA,IAAK,GAAA,GAAM,QAAQ,GAAA,IAAO,CAAA,IAAK,MAAM,IAAA,EAAM;AACpD,MAAA,OAAO,EAAE,aAAa,GAAA,EAAK,UAAA,EAAY,KAAK,QAAA,EAAU,CAAA,EAAG,GAAG,KAAA,GAAQ,GAAA,IAAO,QAAQ,GAAA,CAAA,GAAO,KAAA,GAAQ,GAAG,CAAA,EAAG,KAAA,GAAQ,OAAO,KAAA,GAAQ,GAAA,CAAA,GAAO,QAAQ,CAAA,EAAE;AAAA,IAClJ;AACA,IAAA,OAAO,IAAA;AAAA,EACT;AACF;AAMA,SAAS,aACP,GAAA,EAAa,GAAA,EAAa,GAAA,EAAa,KAAA,EACvC,OAAe,MAAA,EACP;AACR,EAAA,IAAI,UAAU,WAAA,EAAa;AACzB,IAAA,MAAM,GAAA,GAAA,CAAO,MAAM,GAAA,IAAO,CAAA;AAC1B,IAAA,IAAI,OAAO,GAAA,EAAK;AACd,MAAA,MAAMC,EAAAA,GAAAA,CAAK,GAAA,GAAM,GAAA,KAAS,GAAA,GAAM,GAAA,IAAQ,CAAA,CAAA;AACxC,MAAA,OAAO,mBAAmB,MAAA,CAAO,CAAC,KAAK,SAAA,EAAW,IAAA,GAAOA,KAAI,IAAI,CAAA;AAAA,IACnE,CAAA,MAAO;AACL,MAAA,MAAMA,EAAAA,GAAAA,CAAK,GAAA,GAAM,GAAA,KAAS,GAAA,GAAM,GAAA,IAAQ,CAAA,CAAA;AACxC,MAAA,OAAO,mBAAmB,MAAA,CAAO,CAAC,KAAK,SAAA,EAAW,IAAA,GAAOA,KAAI,IAAI,CAAA;AAAA,IACnE;AAAA,EACF;AAEA,EAAA,MAAM,CAAA,GAAA,CAAK,MAAM,GAAA,IAAO,KAAA;AACxB,EAAA,OAAO,mBAAmB,MAAA,CAAO,CAAC,KAAK,SAAA,EAAW,IAAA,GAAO,IAAI,GAAG,CAAA;AAClE;AAEA,SAAS,gBAAA,CACP,GAAA,EAAa,GAAA,EAAa,GAAA,EAAa,OAAe,KAAA,EAC9C;AACR,EAAA,IAAI,UAAU,WAAA,EAAa;AACzB,IAAA,MAAM,GAAA,GAAA,CAAO,MAAM,GAAA,IAAO,CAAA;AAC1B,IAAA,MAAMA,EAAAA,GAAI,KAAK,GAAA,CAAI,GAAA,GAAM,GAAG,CAAA,IAAA,CAAM,GAAA,GAAM,OAAO,CAAA,IAAK,CAAA,CAAA;AACpD,IAAA,OAAOA,EAAAA,GAAI,MAAM,SAAA,GAAY,SAAA;AAAA,EAC/B;AACA,EAAA,MAAM,CAAA,GAAA,CAAK,MAAM,GAAA,IAAO,KAAA;AACxB,EAAA,OAAO,CAAA,GAAI,OAAO,SAAA,GAAY,SAAA;AAChC;AAEA,SAAS,kBAAA,CAAmB,WAAmB,OAAA,EAAyB;AAGtE,EAAA,MAAM,GAAA,GAAM,SAAA,CAAU,QAAA,CAAS,GAAG,IAAI,SAAA,GAAY,SAAA;AAClD,EAAA,MAAM,CAAA,GAAI,SAAS,GAAA,CAAI,KAAA,CAAM,GAAG,CAAC,CAAA,EAAG,EAAE,CAAA,IAAK,EAAA;AAC3C,EAAA,MAAM,CAAA,GAAI,SAAS,GAAA,CAAI,KAAA,CAAM,GAAG,CAAC,CAAA,EAAG,EAAE,CAAA,IAAK,GAAA;AAC3C,EAAA,MAAM,CAAA,GAAI,SAAS,GAAA,CAAI,KAAA,CAAM,GAAG,CAAC,CAAA,EAAG,EAAE,CAAA,IAAK,GAAA;AAC3C,EAAA,OAAO,CAAA,KAAA,EAAQ,CAAC,CAAA,CAAA,EAAI,CAAC,CAAA,CAAA,EAAI,CAAC,CAAA,CAAA,EAAI,OAAA,CAAQ,OAAA,CAAQ,CAAC,CAAC,CAAA,CAAA,CAAA;AAClD","file":"chunk-6E6ZDWZD.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { rect, text, group } from '../../render/tree'\n\n/**\n * Matrix chart — grid layout with color-coded cells.\n *\n * Data convention:\n * - labels: row/column names (for square matrices) or column names\n * - series[i].name: row name, series[i].values[j]: cell value at row i, col j\n *\n * Options:\n * - showValues: display values in cells (default true)\n * - cellRadius: border-radius for cells (default 2)\n * - colorScale: 'sequential' | 'diverging' (default 'sequential')\n * - minColor: color for minimum value\n * - maxColor: color for maximum value\n */\n\nexport interface MatrixOptions {\n showValues?: boolean\n cellRadius?: number\n colorScale?: 'sequential' | 'diverging'\n minColor?: string\n maxColor?: string\n}\n\nexport const matrixChartType: ChartTypePlugin = {\n type: 'matrix',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'categorical' }\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 mOpts = options as unknown as MatrixOptions\n const showValues = mOpts.showValues !== false\n const cellRadius = mOpts.cellRadius ?? 2\n const colorScale = mOpts.colorScale ?? 'sequential'\n\n const rows = data.series.length\n const cols = data.labels.length\n if (rows === 0 || cols === 0) return nodes\n\n // Gather all values for color scale\n let allMin = Infinity, allMax = -Infinity\n for (const s of data.series) {\n for (const v of s.values) {\n if (v < allMin) allMin = v\n if (v > allMax) allMax = v\n }\n }\n if (!isFinite(allMin)) allMin = 0\n if (!isFinite(allMax)) allMax = 1\n const valRange = allMax - allMin || 1\n\n // Layout\n const labelPadLeft = 60\n const labelPadTop = 30\n const gap = 2\n const gridW = area.width - labelPadLeft - 10\n const gridH = area.height - labelPadTop - 10\n const cellW = (gridW - gap * (cols - 1)) / cols\n const cellH = (gridH - gap * (rows - 1)) / rows\n const gridX = area.x + labelPadLeft\n const gridY = area.y + labelPadTop\n\n // Column headers\n for (let c = 0; c < cols; c++) {\n const cx = gridX + c * (cellW + gap) + cellW / 2\n nodes.push(text(cx, gridY - 8, String(data.labels[c] ?? ''), {\n class: 'chartts-matrix-col-label',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: Math.min(theme.fontSizeSmall, cellW * 0.35),\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Row labels + cells\n for (let r = 0; r < rows; r++) {\n const series = data.series[r]!\n const ry = gridY + r * (cellH + gap)\n\n // Row label\n nodes.push(text(gridX - 6, ry + cellH / 2, series.name, {\n class: 'chartts-matrix-row-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, cellH * 0.4),\n fontFamily: theme.fontFamily,\n }))\n\n const rowNodes: RenderNode[] = []\n for (let c = 0; c < cols; c++) {\n const val = series.values[c] ?? 0\n const cx = gridX + c * (cellW + gap)\n\n // Color interpolation\n const color = getCellColor(val, allMin, allMax, valRange, colorScale, options.colors)\n const textColor = getContrastColor(val, allMin, allMax, valRange, colorScale)\n\n rowNodes.push(rect(cx, ry, cellW, cellH, {\n class: 'chartts-matrix-cell',\n fill: color,\n rx: cellRadius,\n ry: cellRadius,\n 'data-series': r,\n 'data-index': c,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name} × ${data.labels[c]}: ${val}`,\n }))\n\n // Value text\n if (showValues && cellW > 18 && cellH > 14) {\n const displayVal = Number.isInteger(val) ? String(val)\n : Math.abs(val) < 10 ? val.toFixed(2) : val.toFixed(1)\n\n rowNodes.push(text(cx + cellW / 2, ry + cellH / 2, displayVal, {\n class: 'chartts-matrix-value',\n fill: textColor,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, cellW * 0.3, cellH * 0.4),\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n pointerEvents: 'none',\n }))\n }\n }\n\n nodes.push(group(rowNodes, {\n class: `chartts-series chartts-series-${r}`,\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, area } = ctx\n const rows = data.series.length\n const cols = data.labels.length\n if (rows === 0 || cols === 0) return null\n\n const labelPadLeft = 60\n const labelPadTop = 30\n const gap = 2\n const gridW = area.width - labelPadLeft - 10\n const gridH = area.height - labelPadTop - 10\n const cellW = (gridW - gap * (cols - 1)) / cols\n const cellH = (gridH - gap * (rows - 1)) / rows\n const gridX = area.x + labelPadLeft\n const gridY = area.y + labelPadTop\n\n const col = Math.floor((mx - gridX) / (cellW + gap))\n const row = Math.floor((my - gridY) / (cellH + gap))\n\n if (row >= 0 && row < rows && col >= 0 && col < cols) {\n return { seriesIndex: row, pointIndex: col, distance: 0, x: gridX + col * (cellW + gap) + cellW / 2, y: gridY + row * (cellH + gap) + cellH / 2 }\n }\n return null\n },\n}\n\n// ---------------------------------------------------------------------------\n// Color helpers\n// ---------------------------------------------------------------------------\n\nfunction getCellColor(\n val: number, min: number, max: number, range: number,\n scale: string, colors: readonly string[],\n): string {\n if (scale === 'diverging') {\n const mid = (min + max) / 2\n if (val >= mid) {\n const t = (val - mid) / ((max - mid) || 1)\n return interpolateOpacity(colors[0] ?? '#3b82f6', 0.15 + t * 0.85)\n } else {\n const t = (mid - val) / ((mid - min) || 1)\n return interpolateOpacity(colors[1] ?? '#ef4444', 0.15 + t * 0.85)\n }\n }\n // Sequential\n const t = (val - min) / range\n return interpolateOpacity(colors[0] ?? '#3b82f6', 0.08 + t * 0.9)\n}\n\nfunction getContrastColor(\n val: number, min: number, max: number, range: number, scale: string,\n): string {\n if (scale === 'diverging') {\n const mid = (min + max) / 2\n const t = Math.abs(val - mid) / ((max - min) / 2 || 1)\n return t > 0.5 ? '#ffffff' : '#1f2937'\n }\n const t = (val - min) / range\n return t > 0.55 ? '#ffffff' : '#1f2937'\n}\n\nfunction interpolateOpacity(baseColor: string, opacity: number): string {\n // For CSS var() colors, we use opacity approach\n // Return as rgba-compatible format\n const hex = baseColor.includes('#') ? baseColor : '#3b82f6'\n const r = parseInt(hex.slice(1, 3), 16) || 59\n const g = parseInt(hex.slice(3, 5), 16) || 130\n const b = parseInt(hex.slice(5, 7), 16) || 246\n return `rgba(${r},${g},${b},${opacity.toFixed(2)})`\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/matrix/matrix-type.ts"],"names":["prepareNoAxes","text","rect","group","t"],"mappings":"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","file":"chunk-NE2W2MF3.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { rect, text, group } from '../../render/tree'\n\n/**\n * Matrix chart — grid layout with color-coded cells.\n *\n * Data convention:\n * - labels: row/column names (for square matrices) or column names\n * - series[i].name: row name, series[i].values[j]: cell value at row i, col j\n *\n * Options:\n * - showValues: display values in cells (default true)\n * - cellRadius: border-radius for cells (default 2)\n * - colorScale: 'sequential' | 'diverging' (default 'sequential')\n * - minColor: color for minimum value\n * - maxColor: color for maximum value\n */\n\nexport interface MatrixOptions {\n showValues?: boolean\n cellRadius?: number\n colorScale?: 'sequential' | 'diverging'\n minColor?: string\n maxColor?: string\n}\n\nexport const matrixChartType: ChartTypePlugin = {\n type: 'matrix',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'categorical' }\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 mOpts = options as unknown as MatrixOptions\n const showValues = mOpts.showValues !== false\n const cellRadius = mOpts.cellRadius ?? 2\n const colorScale = mOpts.colorScale ?? 'sequential'\n\n const rows = data.series.length\n const cols = data.labels.length\n if (rows === 0 || cols === 0) return nodes\n\n // Gather all values for color scale\n let allMin = Infinity, allMax = -Infinity\n for (const s of data.series) {\n for (const v of s.values) {\n if (v < allMin) allMin = v\n if (v > allMax) allMax = v\n }\n }\n if (!isFinite(allMin)) allMin = 0\n if (!isFinite(allMax)) allMax = 1\n const valRange = allMax - allMin || 1\n\n // Layout\n const labelPadLeft = 60\n const labelPadTop = 30\n const gap = 2\n const gridW = area.width - labelPadLeft - 10\n const gridH = area.height - labelPadTop - 10\n const cellW = (gridW - gap * (cols - 1)) / cols\n const cellH = (gridH - gap * (rows - 1)) / rows\n const gridX = area.x + labelPadLeft\n const gridY = area.y + labelPadTop\n\n // Column headers\n for (let c = 0; c < cols; c++) {\n const cx = gridX + c * (cellW + gap) + cellW / 2\n nodes.push(text(cx, gridY - 8, String(data.labels[c] ?? ''), {\n class: 'chartts-matrix-col-label',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: Math.min(theme.fontSizeSmall, cellW * 0.35),\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Row labels + cells\n for (let r = 0; r < rows; r++) {\n const series = data.series[r]!\n const ry = gridY + r * (cellH + gap)\n\n // Row label\n nodes.push(text(gridX - 6, ry + cellH / 2, series.name, {\n class: 'chartts-matrix-row-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, cellH * 0.4),\n fontFamily: theme.fontFamily,\n }))\n\n const rowNodes: RenderNode[] = []\n for (let c = 0; c < cols; c++) {\n const val = series.values[c] ?? 0\n const cx = gridX + c * (cellW + gap)\n\n // Color interpolation\n const color = getCellColor(val, allMin, allMax, valRange, colorScale, options.colors)\n const textColor = getContrastColor(val, allMin, allMax, valRange, colorScale)\n\n rowNodes.push(rect(cx, ry, cellW, cellH, {\n class: 'chartts-matrix-cell',\n fill: color,\n rx: cellRadius,\n ry: cellRadius,\n 'data-series': r,\n 'data-index': c,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name} × ${data.labels[c]}: ${val}`,\n }))\n\n // Value text\n if (showValues && cellW > 18 && cellH > 14) {\n const displayVal = Number.isInteger(val) ? String(val)\n : Math.abs(val) < 10 ? val.toFixed(2) : val.toFixed(1)\n\n rowNodes.push(text(cx + cellW / 2, ry + cellH / 2, displayVal, {\n class: 'chartts-matrix-value',\n fill: textColor,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, cellW * 0.3, cellH * 0.4),\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n pointerEvents: 'none',\n }))\n }\n }\n\n nodes.push(group(rowNodes, {\n class: `chartts-series chartts-series-${r}`,\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, area } = ctx\n const rows = data.series.length\n const cols = data.labels.length\n if (rows === 0 || cols === 0) return null\n\n const labelPadLeft = 60\n const labelPadTop = 30\n const gap = 2\n const gridW = area.width - labelPadLeft - 10\n const gridH = area.height - labelPadTop - 10\n const cellW = (gridW - gap * (cols - 1)) / cols\n const cellH = (gridH - gap * (rows - 1)) / rows\n const gridX = area.x + labelPadLeft\n const gridY = area.y + labelPadTop\n\n const col = Math.floor((mx - gridX) / (cellW + gap))\n const row = Math.floor((my - gridY) / (cellH + gap))\n\n if (row >= 0 && row < rows && col >= 0 && col < cols) {\n return { seriesIndex: row, pointIndex: col, distance: 0, x: gridX + col * (cellW + gap) + cellW / 2, y: gridY + row * (cellH + gap) + cellH / 2 }\n }\n return null\n },\n}\n\n// ---------------------------------------------------------------------------\n// Color helpers\n// ---------------------------------------------------------------------------\n\nfunction getCellColor(\n val: number, min: number, max: number, range: number,\n scale: string, colors: readonly string[],\n): string {\n if (scale === 'diverging') {\n const mid = (min + max) / 2\n if (val >= mid) {\n const t = (val - mid) / ((max - mid) || 1)\n return interpolateOpacity(colors[0] ?? '#3b82f6', 0.15 + t * 0.85)\n } else {\n const t = (mid - val) / ((mid - min) || 1)\n return interpolateOpacity(colors[1] ?? '#ef4444', 0.15 + t * 0.85)\n }\n }\n // Sequential\n const t = (val - min) / range\n return interpolateOpacity(colors[0] ?? '#3b82f6', 0.08 + t * 0.9)\n}\n\nfunction getContrastColor(\n val: number, min: number, max: number, range: number, scale: string,\n): string {\n if (scale === 'diverging') {\n const mid = (min + max) / 2\n const t = Math.abs(val - mid) / ((max - min) / 2 || 1)\n return t > 0.5 ? '#ffffff' : '#1f2937'\n }\n const t = (val - min) / range\n return t > 0.55 ? '#ffffff' : '#1f2937'\n}\n\nfunction interpolateOpacity(baseColor: string, opacity: number): string {\n // For CSS var() colors, we use opacity approach\n // Return as rgba-compatible format\n const hex = baseColor.includes('#') ? baseColor : '#3b82f6'\n const r = parseInt(hex.slice(1, 3), 16) || 59\n const g = parseInt(hex.slice(3, 5), 16) || 130\n const b = parseInt(hex.slice(5, 7), 16) || 246\n return `rgba(${r},${g},${b},${opacity.toFixed(2)})`\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  import { getBandwidth } from './chunk-E6PR75X7.js';
2
- import { line, rect, group, prepareData } from './chunk-DX4FBN3I.js';
2
+ import { line, rect, group, prepareData } from './chunk-AEQXFDL7.js';
3
3
 
4
4
  // src/charts/boxplot/boxplot-type.ts
5
5
  var boxplotChartType = {
@@ -126,5 +126,5 @@ var boxplotChartType = {
126
126
  };
127
127
 
128
128
  export { boxplotChartType };
129
- //# sourceMappingURL=chunk-7PNCJ4OQ.js.map
130
- //# sourceMappingURL=chunk-7PNCJ4OQ.js.map
129
+ //# sourceMappingURL=chunk-NQ7Y6ZKH.js.map
130
+ //# sourceMappingURL=chunk-NQ7Y6ZKH.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/boxplot/boxplot-type.ts"],"names":[],"mappings":"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","file":"chunk-7PNCJ4OQ.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect, line } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Boxplot / Whisker chart — displays statistical distribution for each category.\n *\n * Data format: each series has exactly 5 values per label:\n * [min, Q1, median, Q3, max]\n *\n * For simplicity, if there are N labels, series[0] has N*5 values:\n * [min1, q1_1, med1, q3_1, max1, min2, q1_2, med2, q3_2, max2, ...]\n *\n * Or use multiple series where each series has 5 values for its category.\n */\nexport interface BoxplotOptions {\n /** Width ratio of boxes. Default 0.6. */\n boxWidth?: number\n}\n\nexport const boxplotChartType: ChartTypePlugin = {\n type: 'boxplot',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n // Boxplot: single series with N*5 values. Create synthetic labels if needed.\n // We need to trick the validator: expand labels to match values length.\n const labelCount = data.labels?.length ?? 0\n const valLen = data.series[0]?.values.length ?? 0\n const syntheticData = { ...data }\n if (labelCount > 0 && valLen > labelCount) {\n // Pad labels to match values length (validator needs them equal)\n const padded: string[] = (data.labels ?? []).map(String)\n while (padded.length < valLen) padded.push('')\n syntheticData.labels = padded\n }\n\n const prepared = prepareData(syntheticData, options)\n\n // Restore original labels for rendering\n if (data.labels && data.labels.length < valLen) {\n prepared.labels = [...data.labels]\n }\n\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n // Each series represents one boxplot: 5 values = [min, Q1, median, Q3, max]\n const seriesCount = data.series.length\n if (seriesCount === 0) return nodes\n\n const bOpts = options as unknown as BoxplotOptions\n const boxWidthRatio = bOpts.boxWidth ?? 0.6\n\n const bw = getBandwidth(xScale)\n const boxWidth = bw * boxWidthRatio\n\n for (let i = 0; i < data.labels.length; i++) {\n // Collect the 5 values for this label from all series,\n // or if single series with N*5 values, extract 5 at offset i*5\n let vals: number[]\n if (data.series.length === 1) {\n const s = data.series[0]!\n if (s.values.length >= (i + 1) * 5) {\n vals = s.values.slice(i * 5, i * 5 + 5)\n } else continue\n } else if (data.series.length > i && data.series[i]!.values.length >= 5) {\n vals = data.series[i]!.values.slice(0, 5)\n } else continue\n\n const [vMin, q1, median, q3, vMax] = vals as [number, number, number, number, number]\n const cx = xScale.map(i)\n const boxX = cx - boxWidth / 2\n\n const yMin = yScale.map(vMin)\n const yQ1 = yScale.map(q1)\n const yMed = yScale.map(median)\n const yQ3 = yScale.map(q3)\n const yMax = yScale.map(vMax)\n\n const color = options.colors[i % options.colors.length]!\n const seriesIdx = Math.min(i, data.series.length - 1)\n const boxNodes: RenderNode[] = []\n\n // Whisker line (min to max)\n boxNodes.push(line(cx, yMin, cx, yMax, {\n class: 'chartts-boxplot-whisker',\n stroke: color,\n strokeWidth: 1.5,\n }))\n\n // Min whisker cap\n boxNodes.push(line(cx - boxWidth * 0.3, yMin, cx + boxWidth * 0.3, yMin, {\n class: 'chartts-boxplot-cap',\n stroke: color,\n strokeWidth: 1.5,\n }))\n\n // Max whisker cap\n boxNodes.push(line(cx - boxWidth * 0.3, yMax, cx + boxWidth * 0.3, yMax, {\n class: 'chartts-boxplot-cap',\n stroke: color,\n strokeWidth: 1.5,\n }))\n\n // IQR box (Q1 to Q3)\n const boxTop = Math.min(yQ1, yQ3)\n const boxH = Math.abs(yQ3 - yQ1)\n boxNodes.push(rect(boxX, boxTop, boxWidth, boxH, {\n class: 'chartts-boxplot-box',\n fill: color,\n fillOpacity: 0.25,\n stroke: color,\n strokeWidth: 1.5,\n rx: 4,\n ry: 4,\n 'data-series': seriesIdx,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i]}: min=${vMin}, Q1=${q1}, median=${median}, Q3=${q3}, max=${vMax}`,\n }))\n\n // Median line\n boxNodes.push(line(boxX, yMed, boxX + boxWidth, yMed, {\n class: 'chartts-boxplot-median',\n stroke: color,\n strokeWidth: 2.5,\n }))\n\n nodes.push(group(boxNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': String(data.labels[i]),\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale, options } = ctx\n if (data.labels.length === 0) return null\n\n const bOpts = options as unknown as BoxplotOptions\n const boxWidthRatio = bOpts.boxWidth ?? 0.6\n const bw = getBandwidth(xScale)\n const boxWidth = bw * boxWidthRatio\n\n for (let i = 0; i < data.labels.length; i++) {\n let vals: number[]\n if (data.series.length === 1) {\n const s = data.series[0]!\n if (s.values.length >= (i + 1) * 5) vals = s.values.slice(i * 5, i * 5 + 5)\n else continue\n } else if (data.series.length > i && data.series[i]!.values.length >= 5) {\n vals = data.series[i]!.values.slice(0, 5)\n } else continue\n\n const cx = xScale.map(i)\n const yMin = yScale.map(vals[0]!)\n const yMax = yScale.map(vals[4]!)\n\n const top = Math.min(yMin, yMax)\n const bottom = Math.max(yMin, yMax)\n\n if (mx >= cx - boxWidth / 2 - 4 && mx <= cx + boxWidth / 2 + 4 &&\n my >= top - 4 && my <= bottom + 4) {\n const seriesIdx = Math.min(i, data.series.length - 1)\n return { seriesIndex: seriesIdx, pointIndex: i, distance: 0, x: cx, y: yScale.map(vals[2]!) }\n }\n }\n\n return null\n },\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/boxplot/boxplot-type.ts"],"names":[],"mappings":"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","file":"chunk-NQ7Y6ZKH.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect, line } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Boxplot / Whisker chart — displays statistical distribution for each category.\n *\n * Data format: each series has exactly 5 values per label:\n * [min, Q1, median, Q3, max]\n *\n * For simplicity, if there are N labels, series[0] has N*5 values:\n * [min1, q1_1, med1, q3_1, max1, min2, q1_2, med2, q3_2, max2, ...]\n *\n * Or use multiple series where each series has 5 values for its category.\n */\nexport interface BoxplotOptions {\n /** Width ratio of boxes. Default 0.6. */\n boxWidth?: number\n}\n\nexport const boxplotChartType: ChartTypePlugin = {\n type: 'boxplot',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n // Boxplot: single series with N*5 values. Create synthetic labels if needed.\n // We need to trick the validator: expand labels to match values length.\n const labelCount = data.labels?.length ?? 0\n const valLen = data.series[0]?.values.length ?? 0\n const syntheticData = { ...data }\n if (labelCount > 0 && valLen > labelCount) {\n // Pad labels to match values length (validator needs them equal)\n const padded: string[] = (data.labels ?? []).map(String)\n while (padded.length < valLen) padded.push('')\n syntheticData.labels = padded\n }\n\n const prepared = prepareData(syntheticData, options)\n\n // Restore original labels for rendering\n if (data.labels && data.labels.length < valLen) {\n prepared.labels = [...data.labels]\n }\n\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n // Each series represents one boxplot: 5 values = [min, Q1, median, Q3, max]\n const seriesCount = data.series.length\n if (seriesCount === 0) return nodes\n\n const bOpts = options as unknown as BoxplotOptions\n const boxWidthRatio = bOpts.boxWidth ?? 0.6\n\n const bw = getBandwidth(xScale)\n const boxWidth = bw * boxWidthRatio\n\n for (let i = 0; i < data.labels.length; i++) {\n // Collect the 5 values for this label from all series,\n // or if single series with N*5 values, extract 5 at offset i*5\n let vals: number[]\n if (data.series.length === 1) {\n const s = data.series[0]!\n if (s.values.length >= (i + 1) * 5) {\n vals = s.values.slice(i * 5, i * 5 + 5)\n } else continue\n } else if (data.series.length > i && data.series[i]!.values.length >= 5) {\n vals = data.series[i]!.values.slice(0, 5)\n } else continue\n\n const [vMin, q1, median, q3, vMax] = vals as [number, number, number, number, number]\n const cx = xScale.map(i)\n const boxX = cx - boxWidth / 2\n\n const yMin = yScale.map(vMin)\n const yQ1 = yScale.map(q1)\n const yMed = yScale.map(median)\n const yQ3 = yScale.map(q3)\n const yMax = yScale.map(vMax)\n\n const color = options.colors[i % options.colors.length]!\n const seriesIdx = Math.min(i, data.series.length - 1)\n const boxNodes: RenderNode[] = []\n\n // Whisker line (min to max)\n boxNodes.push(line(cx, yMin, cx, yMax, {\n class: 'chartts-boxplot-whisker',\n stroke: color,\n strokeWidth: 1.5,\n }))\n\n // Min whisker cap\n boxNodes.push(line(cx - boxWidth * 0.3, yMin, cx + boxWidth * 0.3, yMin, {\n class: 'chartts-boxplot-cap',\n stroke: color,\n strokeWidth: 1.5,\n }))\n\n // Max whisker cap\n boxNodes.push(line(cx - boxWidth * 0.3, yMax, cx + boxWidth * 0.3, yMax, {\n class: 'chartts-boxplot-cap',\n stroke: color,\n strokeWidth: 1.5,\n }))\n\n // IQR box (Q1 to Q3)\n const boxTop = Math.min(yQ1, yQ3)\n const boxH = Math.abs(yQ3 - yQ1)\n boxNodes.push(rect(boxX, boxTop, boxWidth, boxH, {\n class: 'chartts-boxplot-box',\n fill: color,\n fillOpacity: 0.25,\n stroke: color,\n strokeWidth: 1.5,\n rx: 4,\n ry: 4,\n 'data-series': seriesIdx,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i]}: min=${vMin}, Q1=${q1}, median=${median}, Q3=${q3}, max=${vMax}`,\n }))\n\n // Median line\n boxNodes.push(line(boxX, yMed, boxX + boxWidth, yMed, {\n class: 'chartts-boxplot-median',\n stroke: color,\n strokeWidth: 2.5,\n }))\n\n nodes.push(group(boxNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': String(data.labels[i]),\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale, options } = ctx\n if (data.labels.length === 0) return null\n\n const bOpts = options as unknown as BoxplotOptions\n const boxWidthRatio = bOpts.boxWidth ?? 0.6\n const bw = getBandwidth(xScale)\n const boxWidth = bw * boxWidthRatio\n\n for (let i = 0; i < data.labels.length; i++) {\n let vals: number[]\n if (data.series.length === 1) {\n const s = data.series[0]!\n if (s.values.length >= (i + 1) * 5) vals = s.values.slice(i * 5, i * 5 + 5)\n else continue\n } else if (data.series.length > i && data.series[i]!.values.length >= 5) {\n vals = data.series[i]!.values.slice(0, 5)\n } else continue\n\n const cx = xScale.map(i)\n const yMin = yScale.map(vals[0]!)\n const yMax = yScale.map(vals[4]!)\n\n const top = Math.min(yMin, yMax)\n const bottom = Math.max(yMin, yMax)\n\n if (mx >= cx - boxWidth / 2 - 4 && mx <= cx + boxWidth / 2 + 4 &&\n my >= top - 4 && my <= bottom + 4) {\n const seriesIdx = Math.min(i, data.series.length - 1)\n return { seriesIndex: seriesIdx, pointIndex: i, distance: 0, x: cx, y: yScale.map(vals[2]!) }\n }\n }\n\n return null\n },\n}\n"]}
@@ -1,5 +1,5 @@
1
- import { prepareNoAxes } from './chunk-MPQECPE3.js';
2
- import { PathBuilder, path, circle, text, group } from './chunk-DX4FBN3I.js';
1
+ import { prepareNoAxes } from './chunk-T7SCCACB.js';
2
+ import { PathBuilder, path, circle, text, group } from './chunk-AEQXFDL7.js';
3
3
 
4
4
  // src/charts/lines/lines-type.ts
5
5
  var linesChartType = {
@@ -172,5 +172,5 @@ var linesChartType = {
172
172
  };
173
173
 
174
174
  export { linesChartType };
175
- //# sourceMappingURL=chunk-LK2A3HBT.js.map
176
- //# sourceMappingURL=chunk-LK2A3HBT.js.map
175
+ //# sourceMappingURL=chunk-NRULNA5F.js.map
176
+ //# sourceMappingURL=chunk-NRULNA5F.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/lines/lines-type.ts"],"names":[],"mappings":"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","file":"chunk-LK2A3HBT.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { circle, text, group } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\nimport { path } from '../../render/tree'\n\n/**\n * Lines (flow lines) chart — curved connection lines between named points.\n *\n * Data convention:\n * - labels: point/city names\n * - series use arrow notation: \"A → B\" with values[0] = flow magnitude\n *\n * Options:\n * - points: array of {name, x, y} defining positions in 0..1 normalized space\n * - showNodes: show circles at point positions (default true)\n * - showArrows: show arrowheads (default true)\n * - showLabels: show point name labels (default true)\n * - curvature: bezier curve amount 0..1 (default 0.3)\n */\n\nexport interface LinesPoint {\n name: string\n x: number // 0..1 normalized\n y: number // 0..1 normalized\n}\n\nexport interface LinesOptions {\n points?: LinesPoint[]\n showNodes?: boolean\n showArrows?: boolean\n showLabels?: boolean\n curvature?: number\n}\n\ninterface ParsedFlow {\n source: string\n target: string\n value: number\n}\n\nexport const linesChartType: ChartTypePlugin = {\n type: 'lines',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const lOpts = options as unknown as LinesOptions\n const showNodes = lOpts.showNodes !== false\n const showArrows = lOpts.showArrows !== false\n const showLabels = lOpts.showLabels !== false\n const curvature = lOpts.curvature ?? 0.3\n\n // Build point positions\n const pointMap = new Map<string, { x: number; y: number }>()\n\n if (lOpts.points) {\n for (const p of lOpts.points) {\n pointMap.set(p.name, {\n x: area.x + p.x * area.width,\n y: area.y + p.y * area.height,\n })\n }\n } else {\n // Auto-layout: arrange points in a circle\n const names = new Set<string>()\n for (const s of data.series) {\n const parts = s.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length >= 2) {\n names.add(parts[0]!.trim())\n names.add(parts[1]!.trim())\n }\n }\n // Also add labels\n for (const l of data.labels) names.add(String(l))\n\n const nameArr = [...names]\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const r = Math.min(area.width, area.height) / 2 - 40\n\n nameArr.forEach((name, i) => {\n const angle = (i / nameArr.length) * Math.PI * 2 - Math.PI / 2\n pointMap.set(name, {\n x: cx + r * Math.cos(angle),\n y: cy + r * Math.sin(angle),\n })\n })\n }\n\n // Parse flows from series\n const flows: ParsedFlow[] = []\n for (const s of data.series) {\n const parts = s.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length >= 2) {\n flows.push({\n source: parts[0]!.trim(),\n target: parts[1]!.trim(),\n value: s.values[0] ?? 1,\n })\n }\n }\n\n if (flows.length === 0 && pointMap.size === 0) return nodes\n\n // Max flow for line width scaling\n const maxFlow = Math.max(...flows.map(f => Math.abs(f.value)), 1)\n\n // Render flow lines\n for (let fi = 0; fi < flows.length; fi++) {\n const flow = flows[fi]!\n const src = pointMap.get(flow.source)\n const tgt = pointMap.get(flow.target)\n if (!src || !tgt) continue\n\n const color = options.colors[fi % options.colors.length]!\n const lineWidth = 1 + (Math.abs(flow.value) / maxFlow) * 4\n\n // Curved bezier\n const dx = tgt.x - src.x\n const dy = tgt.y - src.y\n const mx = (src.x + tgt.x) / 2\n const my = (src.y + tgt.y) / 2\n const cpx = mx - dy * curvature\n const cpy = my + dx * curvature\n\n const pb = new PathBuilder()\n pb.moveTo(src.x, src.y)\n pb.quadTo(cpx, cpy, tgt.x, tgt.y)\n\n nodes.push(path(pb.build(), {\n class: 'chartts-lines-flow',\n fill: 'none',\n stroke: color,\n strokeWidth: lineWidth,\n strokeOpacity: 0.6,\n strokeLinecap: 'round',\n 'data-series': fi,\n 'data-index': 0,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${flow.source} → ${flow.target}: ${flow.value}`,\n }))\n\n // Arrowhead at target\n if (showArrows) {\n const t = 0.95 // position along curve for arrow direction\n const ax = (1 - t) * (1 - t) * src.x + 2 * (1 - t) * t * cpx + t * t * tgt.x\n const ay = (1 - t) * (1 - t) * src.y + 2 * (1 - t) * t * cpy + t * t * tgt.y\n const angle = Math.atan2(tgt.y - ay, tgt.x - ax)\n const arrowSize = 6 + lineWidth\n\n const apb = new PathBuilder()\n apb.moveTo(tgt.x, tgt.y)\n apb.lineTo(\n tgt.x - arrowSize * Math.cos(angle - 0.4),\n tgt.y - arrowSize * Math.sin(angle - 0.4),\n )\n apb.lineTo(\n tgt.x - arrowSize * Math.cos(angle + 0.4),\n tgt.y - arrowSize * Math.sin(angle + 0.4),\n )\n apb.close()\n\n nodes.push(path(apb.build(), {\n class: 'chartts-lines-arrow',\n fill: color,\n fillOpacity: 0.8,\n }))\n }\n }\n\n // Render nodes\n if (showNodes) {\n const nodeNodes: RenderNode[] = []\n let idx = 0\n for (const [name, pos] of pointMap) {\n const color = options.colors[idx % options.colors.length]!\n\n nodeNodes.push(circle(pos.x, pos.y, 6, {\n class: 'chartts-lines-node',\n fill: color,\n stroke: theme.background === 'transparent' ? '#fff' : theme.background,\n strokeWidth: 2,\n 'data-series': idx,\n 'data-index': 0,\n }))\n\n if (showLabels) {\n nodeNodes.push(text(pos.x, pos.y - 14, name, {\n class: 'chartts-lines-label',\n fill: theme.textColor,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n }\n idx++\n }\n nodes.push(group(nodeNodes, { class: 'chartts-lines-nodes' }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { options } = ctx\n const lOpts = options as unknown as LinesOptions\n const pointMap = new Map<string, { x: number; y: number }>()\n\n if (lOpts.points) {\n const { area } = ctx\n for (const p of lOpts.points) {\n pointMap.set(p.name, {\n x: area.x + p.x * area.width,\n y: area.y + p.y * area.height,\n })\n }\n }\n\n let idx = 0\n for (const [, pos] of pointMap) {\n const dx = mx - pos.x\n const dy = my - pos.y\n const dist = Math.sqrt(dx * dx + dy * dy)\n if (dist < 12) {\n return { seriesIndex: idx, pointIndex: 0, distance: dist, x: pos.x, y: pos.y }\n }\n idx++\n }\n return null\n },\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/lines/lines-type.ts"],"names":[],"mappings":"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","file":"chunk-NRULNA5F.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { circle, text, group } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\nimport { path } from '../../render/tree'\n\n/**\n * Lines (flow lines) chart — curved connection lines between named points.\n *\n * Data convention:\n * - labels: point/city names\n * - series use arrow notation: \"A → B\" with values[0] = flow magnitude\n *\n * Options:\n * - points: array of {name, x, y} defining positions in 0..1 normalized space\n * - showNodes: show circles at point positions (default true)\n * - showArrows: show arrowheads (default true)\n * - showLabels: show point name labels (default true)\n * - curvature: bezier curve amount 0..1 (default 0.3)\n */\n\nexport interface LinesPoint {\n name: string\n x: number // 0..1 normalized\n y: number // 0..1 normalized\n}\n\nexport interface LinesOptions {\n points?: LinesPoint[]\n showNodes?: boolean\n showArrows?: boolean\n showLabels?: boolean\n curvature?: number\n}\n\ninterface ParsedFlow {\n source: string\n target: string\n value: number\n}\n\nexport const linesChartType: ChartTypePlugin = {\n type: 'lines',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const lOpts = options as unknown as LinesOptions\n const showNodes = lOpts.showNodes !== false\n const showArrows = lOpts.showArrows !== false\n const showLabels = lOpts.showLabels !== false\n const curvature = lOpts.curvature ?? 0.3\n\n // Build point positions\n const pointMap = new Map<string, { x: number; y: number }>()\n\n if (lOpts.points) {\n for (const p of lOpts.points) {\n pointMap.set(p.name, {\n x: area.x + p.x * area.width,\n y: area.y + p.y * area.height,\n })\n }\n } else {\n // Auto-layout: arrange points in a circle\n const names = new Set<string>()\n for (const s of data.series) {\n const parts = s.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length >= 2) {\n names.add(parts[0]!.trim())\n names.add(parts[1]!.trim())\n }\n }\n // Also add labels\n for (const l of data.labels) names.add(String(l))\n\n const nameArr = [...names]\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const r = Math.min(area.width, area.height) / 2 - 40\n\n nameArr.forEach((name, i) => {\n const angle = (i / nameArr.length) * Math.PI * 2 - Math.PI / 2\n pointMap.set(name, {\n x: cx + r * Math.cos(angle),\n y: cy + r * Math.sin(angle),\n })\n })\n }\n\n // Parse flows from series\n const flows: ParsedFlow[] = []\n for (const s of data.series) {\n const parts = s.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length >= 2) {\n flows.push({\n source: parts[0]!.trim(),\n target: parts[1]!.trim(),\n value: s.values[0] ?? 1,\n })\n }\n }\n\n if (flows.length === 0 && pointMap.size === 0) return nodes\n\n // Max flow for line width scaling\n const maxFlow = Math.max(...flows.map(f => Math.abs(f.value)), 1)\n\n // Render flow lines\n for (let fi = 0; fi < flows.length; fi++) {\n const flow = flows[fi]!\n const src = pointMap.get(flow.source)\n const tgt = pointMap.get(flow.target)\n if (!src || !tgt) continue\n\n const color = options.colors[fi % options.colors.length]!\n const lineWidth = 1 + (Math.abs(flow.value) / maxFlow) * 4\n\n // Curved bezier\n const dx = tgt.x - src.x\n const dy = tgt.y - src.y\n const mx = (src.x + tgt.x) / 2\n const my = (src.y + tgt.y) / 2\n const cpx = mx - dy * curvature\n const cpy = my + dx * curvature\n\n const pb = new PathBuilder()\n pb.moveTo(src.x, src.y)\n pb.quadTo(cpx, cpy, tgt.x, tgt.y)\n\n nodes.push(path(pb.build(), {\n class: 'chartts-lines-flow',\n fill: 'none',\n stroke: color,\n strokeWidth: lineWidth,\n strokeOpacity: 0.6,\n strokeLinecap: 'round',\n 'data-series': fi,\n 'data-index': 0,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${flow.source} → ${flow.target}: ${flow.value}`,\n }))\n\n // Arrowhead at target\n if (showArrows) {\n const t = 0.95 // position along curve for arrow direction\n const ax = (1 - t) * (1 - t) * src.x + 2 * (1 - t) * t * cpx + t * t * tgt.x\n const ay = (1 - t) * (1 - t) * src.y + 2 * (1 - t) * t * cpy + t * t * tgt.y\n const angle = Math.atan2(tgt.y - ay, tgt.x - ax)\n const arrowSize = 6 + lineWidth\n\n const apb = new PathBuilder()\n apb.moveTo(tgt.x, tgt.y)\n apb.lineTo(\n tgt.x - arrowSize * Math.cos(angle - 0.4),\n tgt.y - arrowSize * Math.sin(angle - 0.4),\n )\n apb.lineTo(\n tgt.x - arrowSize * Math.cos(angle + 0.4),\n tgt.y - arrowSize * Math.sin(angle + 0.4),\n )\n apb.close()\n\n nodes.push(path(apb.build(), {\n class: 'chartts-lines-arrow',\n fill: color,\n fillOpacity: 0.8,\n }))\n }\n }\n\n // Render nodes\n if (showNodes) {\n const nodeNodes: RenderNode[] = []\n let idx = 0\n for (const [name, pos] of pointMap) {\n const color = options.colors[idx % options.colors.length]!\n\n nodeNodes.push(circle(pos.x, pos.y, 6, {\n class: 'chartts-lines-node',\n fill: color,\n stroke: theme.background === 'transparent' ? '#fff' : theme.background,\n strokeWidth: 2,\n 'data-series': idx,\n 'data-index': 0,\n }))\n\n if (showLabels) {\n nodeNodes.push(text(pos.x, pos.y - 14, name, {\n class: 'chartts-lines-label',\n fill: theme.textColor,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n }\n idx++\n }\n nodes.push(group(nodeNodes, { class: 'chartts-lines-nodes' }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { options } = ctx\n const lOpts = options as unknown as LinesOptions\n const pointMap = new Map<string, { x: number; y: number }>()\n\n if (lOpts.points) {\n const { area } = ctx\n for (const p of lOpts.points) {\n pointMap.set(p.name, {\n x: area.x + p.x * area.width,\n y: area.y + p.y * area.height,\n })\n }\n }\n\n let idx = 0\n for (const [, pos] of pointMap) {\n const dx = mx - pos.x\n const dy = my - pos.y\n const dist = Math.sqrt(dx * dx + dy * dy)\n if (dist < 12) {\n return { seriesIndex: idx, pointIndex: 0, distance: dist, x: pos.x, y: pos.y }\n }\n idx++\n }\n return null\n },\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
3
  var chunkNHGKZMD7_cjs = require('./chunk-NHGKZMD7.cjs');
4
- var chunkUMIJYYF3_cjs = require('./chunk-UMIJYYF3.cjs');
4
+ var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
5
5
 
6
6
  // src/charts/waterfall/waterfall-type.ts
7
7
  var waterfallChartType = {
@@ -10,7 +10,7 @@ var waterfallChartType = {
10
10
  return { x: "categorical", y: "linear" };
11
11
  },
12
12
  prepareData(data, options) {
13
- const prepared = chunkUMIJYYF3_cjs.prepareData(data, options);
13
+ const prepared = chunkJVVGQLJQ_cjs.prepareData(data, options);
14
14
  const wOpts = options;
15
15
  const series = data.series[0];
16
16
  if (!series) return prepared;
@@ -68,7 +68,7 @@ var waterfallChartType = {
68
68
  color = val >= 0 ? upColor : downColor;
69
69
  }
70
70
  const barH = Math.max(barBottom - barTop, 1);
71
- barNodes.push(chunkUMIJYYF3_cjs.rect(cx - barWidth / 2, barTop, barWidth, barH, {
71
+ barNodes.push(chunkJVVGQLJQ_cjs.rect(cx - barWidth / 2, barTop, barWidth, barH, {
72
72
  rx: 3,
73
73
  ry: 3,
74
74
  class: "chartts-waterfall-bar",
@@ -97,9 +97,9 @@ var waterfallChartType = {
97
97
  prevTop = barTop;
98
98
  }
99
99
  if (connectorNodes.length > 0) {
100
- nodes.push(chunkUMIJYYF3_cjs.group(connectorNodes, { class: "chartts-waterfall-connectors" }));
100
+ nodes.push(chunkJVVGQLJQ_cjs.group(connectorNodes, { class: "chartts-waterfall-connectors" }));
101
101
  }
102
- nodes.push(chunkUMIJYYF3_cjs.group(barNodes, {
102
+ nodes.push(chunkJVVGQLJQ_cjs.group(barNodes, {
103
103
  class: "chartts-series chartts-series-0",
104
104
  "data-series-name": series.name
105
105
  }));
@@ -132,5 +132,5 @@ var waterfallChartType = {
132
132
  };
133
133
 
134
134
  exports.waterfallChartType = waterfallChartType;
135
- //# sourceMappingURL=chunk-47EP245Y.cjs.map
136
- //# sourceMappingURL=chunk-47EP245Y.cjs.map
135
+ //# sourceMappingURL=chunk-OEGSDOJ2.cjs.map
136
+ //# sourceMappingURL=chunk-OEGSDOJ2.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/waterfall/waterfall-type.ts"],"names":["prepareData","getBandwidth","rect","group"],"mappings":"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","file":"chunk-47EP245Y.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\nexport interface WaterfallOptions {\n /** Indices that represent totals (absolute, not cumulative). Default: last index. */\n totals?: number[]\n /** Up color. Default emerald. */\n upColor?: string\n /** Down color. Default red. */\n downColor?: string\n /** Total color. Default blue. */\n totalColor?: string\n /** Show connector lines between bars. Default true. */\n connectors?: boolean\n}\n\n/**\n * Waterfall chart — running totals with floating bars.\n * Each value is a delta from the previous running total.\n * Positive = up (green), negative = down (red), totals = absolute (blue).\n */\nexport const waterfallChartType: ChartTypePlugin = {\n type: 'waterfall',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, options)\n\n const wOpts = options as unknown as WaterfallOptions\n const series = data.series[0]\n if (!series) return prepared\n\n const totals = new Set(wOpts.totals ?? [series.values.length - 1])\n\n // Compute running totals to find proper y bounds\n let running = 0\n let yMin = 0\n let yMax = 0\n for (let i = 0; i < series.values.length; i++) {\n if (totals.has(i)) {\n running = series.values[i]!\n } else {\n running += series.values[i]!\n }\n if (running < yMin) yMin = running\n if (running > yMax) yMax = running\n }\n\n // Include 0 in range\n prepared.bounds.yMin = Math.min(0, yMin)\n prepared.bounds.yMax = Math.max(0, yMax)\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 series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n const wOpts = options as unknown as WaterfallOptions\n const totals = new Set(wOpts.totals ?? [series.values.length - 1])\n const upColor = wOpts.upColor ?? 'var(--color-emerald-500, #10b981)'\n const downColor = wOpts.downColor ?? 'var(--color-red-500, #ef4444)'\n const totalColor = wOpts.totalColor ?? 'var(--color-blue-500, #3b82f6)'\n const showConnectors = wOpts.connectors ?? true\n\n const bw = getBandwidth(xScale)\n const barWidth = bw * 0.6\n const barNodes: RenderNode[] = []\n const connectorNodes: RenderNode[] = []\n\n let running = 0\n let prevTop = yScale.map(0)\n\n for (let i = 0; i < series.values.length; i++) {\n const val = series.values[i]!\n const cx = xScale.map(i)\n const isTotal = totals.has(i)\n\n let barTop: number\n let barBottom: number\n let color: string\n\n if (isTotal) {\n // Total bar: from 0 to the value\n running = val\n barTop = yScale.map(Math.max(0, val))\n barBottom = yScale.map(Math.min(0, val))\n color = totalColor\n } else {\n // Delta bar: from running to running + val\n const from = running\n running += val\n barTop = yScale.map(Math.max(from, running))\n barBottom = yScale.map(Math.min(from, running))\n color = val >= 0 ? upColor : downColor\n }\n\n const barH = Math.max(barBottom - barTop, 1)\n\n barNodes.push(rect(cx - barWidth / 2, barTop, barWidth, barH, {\n rx: 3, ry: 3,\n class: 'chartts-waterfall-bar',\n fill: color,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i] ?? i}: ${val}${isTotal ? ' (total)' : ''}`,\n }))\n\n // Connector line from previous bar's end to this bar's start\n if (showConnectors && i > 0 && !isTotal) {\n connectorNodes.push({\n type: 'line',\n x1: xScale.map(i - 1) + barWidth / 2,\n y1: prevTop,\n x2: cx - barWidth / 2,\n y2: prevTop,\n attrs: {\n class: 'chartts-waterfall-connector',\n stroke: theme.gridColor,\n strokeWidth: 1,\n strokeDasharray: '3,2',\n },\n })\n }\n\n prevTop = barTop\n }\n\n if (connectorNodes.length > 0) {\n nodes.push(group(connectorNodes, { class: 'chartts-waterfall-connectors' }))\n }\n\n nodes.push(group(barNodes, {\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, options } = ctx\n const series = data.series[0]\n if (!series) return null\n\n const wOpts = options as unknown as WaterfallOptions\n const totals = new Set(wOpts.totals ?? [series.values.length - 1])\n const bw = getBandwidth(xScale)\n const barWidth = bw * 0.6\n\n let running = 0\n for (let i = 0; i < series.values.length; i++) {\n const val = series.values[i]!\n const isTotal = totals.has(i)\n if (isTotal) {\n running = val\n } else {\n running += val\n }\n\n const cx = xScale.map(i)\n if (mx >= cx - barWidth / 2 - 4 && mx <= cx + barWidth / 2 + 4) {\n return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx), x: cx, y: yScale.map(running) }\n }\n }\n\n return null\n },\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/waterfall/waterfall-type.ts"],"names":["prepareData","getBandwidth","rect","group"],"mappings":"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","file":"chunk-OEGSDOJ2.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\nexport interface WaterfallOptions {\n /** Indices that represent totals (absolute, not cumulative). Default: last index. */\n totals?: number[]\n /** Up color. Default emerald. */\n upColor?: string\n /** Down color. Default red. */\n downColor?: string\n /** Total color. Default blue. */\n totalColor?: string\n /** Show connector lines between bars. Default true. */\n connectors?: boolean\n}\n\n/**\n * Waterfall chart — running totals with floating bars.\n * Each value is a delta from the previous running total.\n * Positive = up (green), negative = down (red), totals = absolute (blue).\n */\nexport const waterfallChartType: ChartTypePlugin = {\n type: 'waterfall',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, options)\n\n const wOpts = options as unknown as WaterfallOptions\n const series = data.series[0]\n if (!series) return prepared\n\n const totals = new Set(wOpts.totals ?? [series.values.length - 1])\n\n // Compute running totals to find proper y bounds\n let running = 0\n let yMin = 0\n let yMax = 0\n for (let i = 0; i < series.values.length; i++) {\n if (totals.has(i)) {\n running = series.values[i]!\n } else {\n running += series.values[i]!\n }\n if (running < yMin) yMin = running\n if (running > yMax) yMax = running\n }\n\n // Include 0 in range\n prepared.bounds.yMin = Math.min(0, yMin)\n prepared.bounds.yMax = Math.max(0, yMax)\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 series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n const wOpts = options as unknown as WaterfallOptions\n const totals = new Set(wOpts.totals ?? [series.values.length - 1])\n const upColor = wOpts.upColor ?? 'var(--color-emerald-500, #10b981)'\n const downColor = wOpts.downColor ?? 'var(--color-red-500, #ef4444)'\n const totalColor = wOpts.totalColor ?? 'var(--color-blue-500, #3b82f6)'\n const showConnectors = wOpts.connectors ?? true\n\n const bw = getBandwidth(xScale)\n const barWidth = bw * 0.6\n const barNodes: RenderNode[] = []\n const connectorNodes: RenderNode[] = []\n\n let running = 0\n let prevTop = yScale.map(0)\n\n for (let i = 0; i < series.values.length; i++) {\n const val = series.values[i]!\n const cx = xScale.map(i)\n const isTotal = totals.has(i)\n\n let barTop: number\n let barBottom: number\n let color: string\n\n if (isTotal) {\n // Total bar: from 0 to the value\n running = val\n barTop = yScale.map(Math.max(0, val))\n barBottom = yScale.map(Math.min(0, val))\n color = totalColor\n } else {\n // Delta bar: from running to running + val\n const from = running\n running += val\n barTop = yScale.map(Math.max(from, running))\n barBottom = yScale.map(Math.min(from, running))\n color = val >= 0 ? upColor : downColor\n }\n\n const barH = Math.max(barBottom - barTop, 1)\n\n barNodes.push(rect(cx - barWidth / 2, barTop, barWidth, barH, {\n rx: 3, ry: 3,\n class: 'chartts-waterfall-bar',\n fill: color,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i] ?? i}: ${val}${isTotal ? ' (total)' : ''}`,\n }))\n\n // Connector line from previous bar's end to this bar's start\n if (showConnectors && i > 0 && !isTotal) {\n connectorNodes.push({\n type: 'line',\n x1: xScale.map(i - 1) + barWidth / 2,\n y1: prevTop,\n x2: cx - barWidth / 2,\n y2: prevTop,\n attrs: {\n class: 'chartts-waterfall-connector',\n stroke: theme.gridColor,\n strokeWidth: 1,\n strokeDasharray: '3,2',\n },\n })\n }\n\n prevTop = barTop\n }\n\n if (connectorNodes.length > 0) {\n nodes.push(group(connectorNodes, { class: 'chartts-waterfall-connectors' }))\n }\n\n nodes.push(group(barNodes, {\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, options } = ctx\n const series = data.series[0]\n if (!series) return null\n\n const wOpts = options as unknown as WaterfallOptions\n const totals = new Set(wOpts.totals ?? [series.values.length - 1])\n const bw = getBandwidth(xScale)\n const barWidth = bw * 0.6\n\n let running = 0\n for (let i = 0; i < series.values.length; i++) {\n const val = series.values[i]!\n const isTotal = totals.has(i)\n if (isTotal) {\n running = val\n } else {\n running += val\n }\n\n const cx = xScale.map(i)\n if (mx >= cx - barWidth / 2 - 4 && mx <= cx + barWidth / 2 + 4) {\n return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx), x: cx, y: yScale.map(running) }\n }\n }\n\n return null\n },\n}\n"]}