@chartts/core 0.1.4 → 0.1.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (359) hide show
  1. package/dist/area.cjs +10 -10
  2. package/dist/area.js +5 -5
  3. package/dist/bar.cjs +9 -9
  4. package/dist/bar.js +4 -4
  5. package/dist/baseline.cjs +9 -9
  6. package/dist/baseline.js +4 -4
  7. package/dist/boxplot.cjs +9 -9
  8. package/dist/boxplot.js +4 -4
  9. package/dist/bubble.cjs +9 -9
  10. package/dist/bubble.js +4 -4
  11. package/dist/bullet.cjs +10 -10
  12. package/dist/bullet.js +5 -5
  13. package/dist/calendar.cjs +10 -10
  14. package/dist/calendar.js +5 -5
  15. package/dist/candlestick.cjs +9 -9
  16. package/dist/candlestick.js +4 -4
  17. package/dist/chord.cjs +10 -10
  18. package/dist/chord.js +5 -5
  19. package/dist/chunk-2OWMJBRN.js +122 -0
  20. package/dist/chunk-2OWMJBRN.js.map +1 -0
  21. package/dist/{chunk-62DBXI4N.js → chunk-2VHG2N75.js} +4 -4
  22. package/dist/{chunk-62DBXI4N.js.map → chunk-2VHG2N75.js.map} +1 -1
  23. package/dist/{chunk-VJXUBN7J.js → chunk-2X7UIG3G.js} +3 -3
  24. package/dist/{chunk-VJXUBN7J.js.map → chunk-2X7UIG3G.js.map} +1 -1
  25. package/dist/{chunk-ESJMEDLY.cjs → chunk-35XUPEAD.cjs} +4 -4
  26. package/dist/{chunk-ESJMEDLY.cjs.map → chunk-35XUPEAD.cjs.map} +1 -1
  27. package/dist/{chunk-Y6CVUI6A.cjs → chunk-3HBRAGJA.cjs} +13 -13
  28. package/dist/{chunk-Y6CVUI6A.cjs.map → chunk-3HBRAGJA.cjs.map} +1 -1
  29. package/dist/{chunk-ZOEN3ARN.js → chunk-45Y77XDM.js} +3 -3
  30. package/dist/{chunk-ZOEN3ARN.js.map → chunk-45Y77XDM.js.map} +1 -1
  31. package/dist/{chunk-PCAYYCLY.cjs → chunk-47R2QUID.cjs} +10 -10
  32. package/dist/{chunk-PCAYYCLY.cjs.map → chunk-47R2QUID.cjs.map} +1 -1
  33. package/dist/{chunk-IF6RQ53Q.cjs → chunk-4C5IV57Z.cjs} +9 -9
  34. package/dist/{chunk-IF6RQ53Q.cjs.map → chunk-4C5IV57Z.cjs.map} +1 -1
  35. package/dist/{chunk-2BUIZDOB.js → chunk-4EV5UN6V.js} +3 -3
  36. package/dist/{chunk-2BUIZDOB.js.map → chunk-4EV5UN6V.js.map} +1 -1
  37. package/dist/{chunk-THHZMRFU.js → chunk-5JDHVXPE.js} +3 -3
  38. package/dist/{chunk-THHZMRFU.js.map → chunk-5JDHVXPE.js.map} +1 -1
  39. package/dist/{chunk-PKXW45G4.js → chunk-5VI5F5XA.js} +3 -3
  40. package/dist/{chunk-PKXW45G4.js.map → chunk-5VI5F5XA.js.map} +1 -1
  41. package/dist/{chunk-TEZNWW3R.cjs → chunk-64B7FGFP.cjs} +8 -8
  42. package/dist/{chunk-TEZNWW3R.cjs.map → chunk-64B7FGFP.cjs.map} +1 -1
  43. package/dist/{chunk-5HZEDCJG.js → chunk-66GE7TI3.js} +3 -3
  44. package/dist/{chunk-5HZEDCJG.js.map → chunk-66GE7TI3.js.map} +1 -1
  45. package/dist/{chunk-CWZADOJ6.js → chunk-6H34P4AG.js} +3 -3
  46. package/dist/{chunk-CWZADOJ6.js.map → chunk-6H34P4AG.js.map} +1 -1
  47. package/dist/{chunk-BGGESAAG.cjs → chunk-6KNS32OH.cjs} +7 -7
  48. package/dist/{chunk-BGGESAAG.cjs.map → chunk-6KNS32OH.cjs.map} +1 -1
  49. package/dist/{chunk-GBL4R3GH.cjs → chunk-6S2NCXNP.cjs} +6 -6
  50. package/dist/{chunk-GBL4R3GH.cjs.map → chunk-6S2NCXNP.cjs.map} +1 -1
  51. package/dist/{chunk-FVLVTY5D.cjs → chunk-6XD3VSAM.cjs} +6 -6
  52. package/dist/{chunk-FVLVTY5D.cjs.map → chunk-6XD3VSAM.cjs.map} +1 -1
  53. package/dist/{chunk-KWSVJRXX.cjs → chunk-6XWZSV6M.cjs} +4 -4
  54. package/dist/{chunk-KWSVJRXX.cjs.map → chunk-6XWZSV6M.cjs.map} +1 -1
  55. package/dist/{chunk-N35UAFEU.js → chunk-7FUQMZGT.js} +4 -4
  56. package/dist/{chunk-N35UAFEU.js.map → chunk-7FUQMZGT.js.map} +1 -1
  57. package/dist/chunk-7LZVSOZR.cjs +172 -0
  58. package/dist/chunk-7LZVSOZR.cjs.map +1 -0
  59. package/dist/{chunk-A5G32G2R.cjs → chunk-7XOK2HLV.cjs} +9 -9
  60. package/dist/{chunk-A5G32G2R.cjs.map → chunk-7XOK2HLV.cjs.map} +1 -1
  61. package/dist/{chunk-SGZUUUXU.js → chunk-ACN4JCSF.js} +4 -4
  62. package/dist/{chunk-SGZUUUXU.js.map → chunk-ACN4JCSF.js.map} +1 -1
  63. package/dist/{chunk-3NHH6C4K.cjs → chunk-AOZ47DTE.cjs} +13 -13
  64. package/dist/{chunk-3NHH6C4K.cjs.map → chunk-AOZ47DTE.cjs.map} +1 -1
  65. package/dist/{chunk-WZCES5M6.js → chunk-AYEXPYFE.js} +4 -4
  66. package/dist/{chunk-WZCES5M6.js.map → chunk-AYEXPYFE.js.map} +1 -1
  67. package/dist/{chunk-D5QUAWF3.cjs → chunk-BPXEQPZU.cjs} +10 -10
  68. package/dist/{chunk-D5QUAWF3.cjs.map → chunk-BPXEQPZU.cjs.map} +1 -1
  69. package/dist/{chunk-YZXRD6K6.cjs → chunk-BQUMYOBP.cjs} +7 -7
  70. package/dist/{chunk-YZXRD6K6.cjs.map → chunk-BQUMYOBP.cjs.map} +1 -1
  71. package/dist/{chunk-FGHSUT6X.cjs → chunk-CG4KMZRU.cjs} +6 -6
  72. package/dist/{chunk-FGHSUT6X.cjs.map → chunk-CG4KMZRU.cjs.map} +1 -1
  73. package/dist/{chunk-BFBVJ6MU.js → chunk-CLBVCWJG.js} +3 -3
  74. package/dist/{chunk-BFBVJ6MU.js.map → chunk-CLBVCWJG.js.map} +1 -1
  75. package/dist/{chunk-754Z4OR6.cjs → chunk-CVKWXLXW.cjs} +10 -10
  76. package/dist/{chunk-754Z4OR6.cjs.map → chunk-CVKWXLXW.cjs.map} +1 -1
  77. package/dist/{chunk-5E7FXDBM.js → chunk-D4RP2H6A.js} +4 -4
  78. package/dist/{chunk-5E7FXDBM.js.map → chunk-D4RP2H6A.js.map} +1 -1
  79. package/dist/{chunk-HCIBBUV5.js → chunk-DMBUUJGU.js} +3 -3
  80. package/dist/{chunk-HCIBBUV5.js.map → chunk-DMBUUJGU.js.map} +1 -1
  81. package/dist/{chunk-EWVXMQRW.js → chunk-DQAFYVCX.js} +5 -5
  82. package/dist/{chunk-EWVXMQRW.js.map → chunk-DQAFYVCX.js.map} +1 -1
  83. package/dist/{chunk-ATMSGQCW.cjs → chunk-EXA5HCX7.cjs} +9 -9
  84. package/dist/{chunk-ATMSGQCW.cjs.map → chunk-EXA5HCX7.cjs.map} +1 -1
  85. package/dist/{chunk-TLHQ6JCK.cjs → chunk-F3TVVAYG.cjs} +11 -11
  86. package/dist/{chunk-TLHQ6JCK.cjs.map → chunk-F3TVVAYG.cjs.map} +1 -1
  87. package/dist/{chunk-HCK2VUWD.cjs → chunk-FCDKWHIV.cjs} +8 -8
  88. package/dist/{chunk-HCK2VUWD.cjs.map → chunk-FCDKWHIV.cjs.map} +1 -1
  89. package/dist/{chunk-IDZTDJLH.js → chunk-FWKYNE3A.js} +3 -3
  90. package/dist/{chunk-IDZTDJLH.js.map → chunk-FWKYNE3A.js.map} +1 -1
  91. package/dist/{chunk-6QMV75NT.js → chunk-GAXX6YK5.js} +4 -4
  92. package/dist/{chunk-6QMV75NT.js.map → chunk-GAXX6YK5.js.map} +1 -1
  93. package/dist/{chunk-OMAW52LY.cjs → chunk-H2DHSBPO.cjs} +6 -6
  94. package/dist/{chunk-OMAW52LY.cjs.map → chunk-H2DHSBPO.cjs.map} +1 -1
  95. package/dist/{chunk-DX77WSIB.js → chunk-I7HB3FBC.js} +5 -5
  96. package/dist/{chunk-DX77WSIB.js.map → chunk-I7HB3FBC.js.map} +1 -1
  97. package/dist/{chunk-MJY25P44.js → chunk-IGIAGPC5.js} +3 -3
  98. package/dist/{chunk-MJY25P44.js.map → chunk-IGIAGPC5.js.map} +1 -1
  99. package/dist/{chunk-4QRND2V5.js → chunk-ILD5ZZHH.js} +3 -3
  100. package/dist/{chunk-4QRND2V5.js.map → chunk-ILD5ZZHH.js.map} +1 -1
  101. package/dist/{chunk-CU5ZXVZQ.js → chunk-IN7SCXMD.js} +4 -4
  102. package/dist/{chunk-CU5ZXVZQ.js.map → chunk-IN7SCXMD.js.map} +1 -1
  103. package/dist/chunk-IRBGJP2E.js +170 -0
  104. package/dist/chunk-IRBGJP2E.js.map +1 -0
  105. package/dist/{chunk-7GLCJPV5.js → chunk-J6A72I5K.js} +4 -4
  106. package/dist/{chunk-7GLCJPV5.js.map → chunk-J6A72I5K.js.map} +1 -1
  107. package/dist/chunk-JRTD6Y34.cjs +148 -0
  108. package/dist/chunk-JRTD6Y34.cjs.map +1 -0
  109. package/dist/{chunk-KNMEXOKJ.js → chunk-K7NVM76W.js} +4 -4
  110. package/dist/{chunk-KNMEXOKJ.js.map → chunk-K7NVM76W.js.map} +1 -1
  111. package/dist/chunk-KNUMF6K2.cjs +156 -0
  112. package/dist/chunk-KNUMF6K2.cjs.map +1 -0
  113. package/dist/chunk-KQJZJADP.js +146 -0
  114. package/dist/chunk-KQJZJADP.js.map +1 -0
  115. package/dist/{chunk-OMSHGBV3.js → chunk-KRLKDJPM.js} +4 -4
  116. package/dist/{chunk-OMSHGBV3.js.map → chunk-KRLKDJPM.js.map} +1 -1
  117. package/dist/{chunk-ZNKVOTPB.cjs → chunk-KSCMLSUI.cjs} +15 -15
  118. package/dist/{chunk-ZNKVOTPB.cjs.map → chunk-KSCMLSUI.cjs.map} +1 -1
  119. package/dist/{chunk-OTXHJHXU.cjs → chunk-KT4LY42Y.cjs} +11 -11
  120. package/dist/{chunk-OTXHJHXU.cjs.map → chunk-KT4LY42Y.cjs.map} +1 -1
  121. package/dist/chunk-KX4ZBUHB.cjs +211 -0
  122. package/dist/chunk-KX4ZBUHB.cjs.map +1 -0
  123. package/dist/{chunk-56BN43J4.js → chunk-KXJOIVL5.js} +5 -5
  124. package/dist/{chunk-56BN43J4.js.map → chunk-KXJOIVL5.js.map} +1 -1
  125. package/dist/{chunk-EPUWA3ZW.js → chunk-LFV46XLH.js} +4 -4
  126. package/dist/{chunk-EPUWA3ZW.js.map → chunk-LFV46XLH.js.map} +1 -1
  127. package/dist/{chunk-T7SCCACB.js → chunk-LKSKGQX7.js} +3 -3
  128. package/dist/{chunk-T7SCCACB.js.map → chunk-LKSKGQX7.js.map} +1 -1
  129. package/dist/{chunk-LARNENXE.cjs → chunk-LQ26WSLH.cjs} +10 -10
  130. package/dist/{chunk-LARNENXE.cjs.map → chunk-LQ26WSLH.cjs.map} +1 -1
  131. package/dist/{chunk-NRULNA5F.js → chunk-LROB73B4.js} +4 -4
  132. package/dist/{chunk-NRULNA5F.js.map → chunk-LROB73B4.js.map} +1 -1
  133. package/dist/{chunk-34DQGCPP.js → chunk-LXBBM6IF.js} +4 -4
  134. package/dist/{chunk-34DQGCPP.js.map → chunk-LXBBM6IF.js.map} +1 -1
  135. package/dist/{chunk-QPHWRD25.js → chunk-MCORUYWB.js} +3 -3
  136. package/dist/{chunk-QPHWRD25.js.map → chunk-MCORUYWB.js.map} +1 -1
  137. package/dist/{chunk-2JYK52HV.js → chunk-MJFCMUIY.js} +4 -4
  138. package/dist/{chunk-2JYK52HV.js.map → chunk-MJFCMUIY.js.map} +1 -1
  139. package/dist/{chunk-7PHOSSLJ.cjs → chunk-NHSPO4BN.cjs} +9 -9
  140. package/dist/{chunk-7PHOSSLJ.cjs.map → chunk-NHSPO4BN.cjs.map} +1 -1
  141. package/dist/{chunk-5QT67VYJ.cjs → chunk-NR5NQ6TV.cjs} +10 -10
  142. package/dist/{chunk-5QT67VYJ.cjs.map → chunk-NR5NQ6TV.cjs.map} +1 -1
  143. package/dist/{chunk-DT4GG5BF.cjs → chunk-NRMQMPUE.cjs} +7 -7
  144. package/dist/{chunk-DT4GG5BF.cjs.map → chunk-NRMQMPUE.cjs.map} +1 -1
  145. package/dist/{chunk-FGBIJ6PL.js → chunk-NW4JBVY2.js} +4 -4
  146. package/dist/{chunk-FGBIJ6PL.js.map → chunk-NW4JBVY2.js.map} +1 -1
  147. package/dist/{chunk-2QRCHYTZ.cjs → chunk-OLY33H6E.cjs} +7 -7
  148. package/dist/{chunk-2QRCHYTZ.cjs.map → chunk-OLY33H6E.cjs.map} +1 -1
  149. package/dist/{chunk-2IWLOBSF.cjs → chunk-OUQ63IJQ.cjs} +6 -6
  150. package/dist/{chunk-2IWLOBSF.cjs.map → chunk-OUQ63IJQ.cjs.map} +1 -1
  151. package/dist/{chunk-VUHNBLFA.js → chunk-PHFBF5ON.js} +3 -3
  152. package/dist/{chunk-VUHNBLFA.js.map → chunk-PHFBF5ON.js.map} +1 -1
  153. package/dist/{chunk-4MNVJVK3.cjs → chunk-PL3M46GS.cjs} +6 -6
  154. package/dist/{chunk-4MNVJVK3.cjs.map → chunk-PL3M46GS.cjs.map} +1 -1
  155. package/dist/{chunk-JYVRX3BX.cjs → chunk-PNHDHEBQ.cjs} +8 -8
  156. package/dist/{chunk-JYVRX3BX.cjs.map → chunk-PNHDHEBQ.cjs.map} +1 -1
  157. package/dist/{chunk-QYI7ZV3B.cjs → chunk-PX7MLSIH.cjs} +369 -124
  158. package/dist/chunk-PX7MLSIH.cjs.map +1 -0
  159. package/dist/{chunk-YCL43UQM.cjs → chunk-QCEC2KBW.cjs} +12 -12
  160. package/dist/{chunk-YCL43UQM.cjs.map → chunk-QCEC2KBW.cjs.map} +1 -1
  161. package/dist/{chunk-ZFGLBJYC.js → chunk-QRVTY6UU.js} +3 -3
  162. package/dist/{chunk-ZFGLBJYC.js.map → chunk-QRVTY6UU.js.map} +1 -1
  163. package/dist/chunk-QS6GR2CQ.js +154 -0
  164. package/dist/chunk-QS6GR2CQ.js.map +1 -0
  165. package/dist/{chunk-QPHUAF3R.cjs → chunk-QVQKYVD2.cjs} +8 -8
  166. package/dist/{chunk-QPHUAF3R.cjs.map → chunk-QVQKYVD2.cjs.map} +1 -1
  167. package/dist/{chunk-CUIPBYMG.cjs → chunk-RIJPMRKC.cjs} +8 -8
  168. package/dist/{chunk-CUIPBYMG.cjs.map → chunk-RIJPMRKC.cjs.map} +1 -1
  169. package/dist/{chunk-5QVUBGM7.js → chunk-RKX7GKOU.js} +4 -4
  170. package/dist/{chunk-5QVUBGM7.js.map → chunk-RKX7GKOU.js.map} +1 -1
  171. package/dist/{chunk-3SVNEKXE.cjs → chunk-ROUFAI5M.cjs} +11 -11
  172. package/dist/{chunk-3SVNEKXE.cjs.map → chunk-ROUFAI5M.cjs.map} +1 -1
  173. package/dist/{chunk-55ZTXQQQ.cjs → chunk-S52RCLDQ.cjs} +12 -12
  174. package/dist/{chunk-55ZTXQQQ.cjs.map → chunk-S52RCLDQ.cjs.map} +1 -1
  175. package/dist/{chunk-GRXHW5S3.cjs → chunk-SEOHPUXV.cjs} +12 -12
  176. package/dist/{chunk-GRXHW5S3.cjs.map → chunk-SEOHPUXV.cjs.map} +1 -1
  177. package/dist/{chunk-KHG3G2ZX.js → chunk-SI4VJK4A.js} +3 -3
  178. package/dist/{chunk-KHG3G2ZX.js.map → chunk-SI4VJK4A.js.map} +1 -1
  179. package/dist/{chunk-VGJD4F4H.js → chunk-SUB5WML4.js} +3 -3
  180. package/dist/{chunk-VGJD4F4H.js.map → chunk-SUB5WML4.js.map} +1 -1
  181. package/dist/{chunk-CA42BCSM.cjs → chunk-T5NDUMLD.cjs} +8 -8
  182. package/dist/{chunk-CA42BCSM.cjs.map → chunk-T5NDUMLD.cjs.map} +1 -1
  183. package/dist/{chunk-QEPMEEZC.cjs → chunk-TKHYY3B5.cjs} +6 -6
  184. package/dist/{chunk-QEPMEEZC.cjs.map → chunk-TKHYY3B5.cjs.map} +1 -1
  185. package/dist/{chunk-LXYNL7BI.cjs → chunk-TMQ2V5B2.cjs} +10 -10
  186. package/dist/{chunk-LXYNL7BI.cjs.map → chunk-TMQ2V5B2.cjs.map} +1 -1
  187. package/dist/{chunk-R2W3RJFW.cjs → chunk-TNIMRV3N.cjs} +13 -13
  188. package/dist/{chunk-R2W3RJFW.cjs.map → chunk-TNIMRV3N.cjs.map} +1 -1
  189. package/dist/{chunk-NQ7Y6ZKH.js → chunk-TUPPYHUR.js} +3 -3
  190. package/dist/{chunk-NQ7Y6ZKH.js.map → chunk-TUPPYHUR.js.map} +1 -1
  191. package/dist/{chunk-MSCRIA2U.cjs → chunk-U456ET3M.cjs} +12 -12
  192. package/dist/{chunk-MSCRIA2U.cjs.map → chunk-U456ET3M.cjs.map} +1 -1
  193. package/dist/{chunk-NE2W2MF3.cjs → chunk-UMS2MPYC.cjs} +10 -10
  194. package/dist/{chunk-NE2W2MF3.cjs.map → chunk-UMS2MPYC.cjs.map} +1 -1
  195. package/dist/{chunk-DAAU5H24.js → chunk-UNQBXGX5.js} +3 -3
  196. package/dist/{chunk-DAAU5H24.js.map → chunk-UNQBXGX5.js.map} +1 -1
  197. package/dist/{chunk-VBMLJUBE.js → chunk-V3AENTZB.js} +4 -4
  198. package/dist/{chunk-VBMLJUBE.js.map → chunk-V3AENTZB.js.map} +1 -1
  199. package/dist/{chunk-3JB4JBBK.js → chunk-V5LLTYOY.js} +4 -4
  200. package/dist/{chunk-3JB4JBBK.js.map → chunk-V5LLTYOY.js.map} +1 -1
  201. package/dist/chunk-VALFF4NG.cjs +124 -0
  202. package/dist/chunk-VALFF4NG.cjs.map +1 -0
  203. package/dist/{chunk-MEERXUZS.js → chunk-VJT5UA7J.js} +4 -4
  204. package/dist/{chunk-MEERXUZS.js.map → chunk-VJT5UA7J.js.map} +1 -1
  205. package/dist/{chunk-JVVGQLJQ.cjs → chunk-W626EAS5.cjs} +100 -6
  206. package/dist/chunk-W626EAS5.cjs.map +1 -0
  207. package/dist/{chunk-IOV77VHP.js → chunk-WHGNA44O.js} +4 -4
  208. package/dist/{chunk-IOV77VHP.js.map → chunk-WHGNA44O.js.map} +1 -1
  209. package/dist/{chunk-ZYXRRVR6.js → chunk-WIA4MDRX.js} +3 -3
  210. package/dist/{chunk-ZYXRRVR6.js.map → chunk-WIA4MDRX.js.map} +1 -1
  211. package/dist/{chunk-OEGSDOJ2.cjs → chunk-WOYVHVXC.cjs} +7 -7
  212. package/dist/{chunk-OEGSDOJ2.cjs.map → chunk-WOYVHVXC.cjs.map} +1 -1
  213. package/dist/{chunk-V5Q6UNUK.cjs → chunk-X5SG6MFS.cjs} +4 -4
  214. package/dist/{chunk-V5Q6UNUK.cjs.map → chunk-X5SG6MFS.cjs.map} +1 -1
  215. package/dist/{chunk-LRHMLNPW.js → chunk-XB5K7OYD.js} +353 -108
  216. package/dist/chunk-XB5K7OYD.js.map +1 -0
  217. package/dist/{chunk-AEQXFDL7.js → chunk-XIVC32HU.js} +100 -6
  218. package/dist/chunk-XIVC32HU.js.map +1 -0
  219. package/dist/{chunk-TC3H6ZED.js → chunk-XQ7BTVV3.js} +4 -4
  220. package/dist/{chunk-TC3H6ZED.js.map → chunk-XQ7BTVV3.js.map} +1 -1
  221. package/dist/{chunk-4D6PVH2C.cjs → chunk-YMOQGTGJ.cjs} +9 -9
  222. package/dist/{chunk-4D6PVH2C.cjs.map → chunk-YMOQGTGJ.cjs.map} +1 -1
  223. package/dist/{chunk-2IMUTDTD.cjs → chunk-YOK3JGW5.cjs} +10 -10
  224. package/dist/{chunk-2IMUTDTD.cjs.map → chunk-YOK3JGW5.cjs.map} +1 -1
  225. package/dist/{chunk-24557PYN.js → chunk-YUIHMAHA.js} +3 -3
  226. package/dist/{chunk-24557PYN.js.map → chunk-YUIHMAHA.js.map} +1 -1
  227. package/dist/chunk-ZBWBLCY2.js +209 -0
  228. package/dist/chunk-ZBWBLCY2.js.map +1 -0
  229. package/dist/{chunk-W476ER4X.cjs → chunk-ZCLW4B5S.cjs} +17 -17
  230. package/dist/{chunk-W476ER4X.cjs.map → chunk-ZCLW4B5S.cjs.map} +1 -1
  231. package/dist/combo.cjs +9 -9
  232. package/dist/combo.js +4 -4
  233. package/dist/custom.cjs +10 -10
  234. package/dist/custom.js +5 -5
  235. package/dist/donut.cjs +11 -11
  236. package/dist/donut.js +6 -6
  237. package/dist/dumbbell.cjs +10 -10
  238. package/dist/dumbbell.js +5 -5
  239. package/dist/funnel.cjs +10 -10
  240. package/dist/funnel.js +5 -5
  241. package/dist/gauge.cjs +10 -10
  242. package/dist/gauge.js +5 -5
  243. package/dist/geo.cjs +12 -12
  244. package/dist/geo.js +5 -5
  245. package/dist/graph-type-Cyb5U1y2.d.ts +5 -0
  246. package/dist/graph-type-DRbMI2E9.d.cts +5 -0
  247. package/dist/graph.cjs +10 -10
  248. package/dist/graph.d.cts +1 -1
  249. package/dist/graph.d.ts +1 -1
  250. package/dist/graph.js +5 -5
  251. package/dist/heatmap.cjs +10 -10
  252. package/dist/heatmap.js +5 -5
  253. package/dist/histogram.cjs +9 -9
  254. package/dist/histogram.js +4 -4
  255. package/dist/horizontal-bar.cjs +9 -9
  256. package/dist/horizontal-bar.js +4 -4
  257. package/dist/index.cjs +242 -192
  258. package/dist/index.cjs.map +1 -1
  259. package/dist/index.d.cts +12 -2
  260. package/dist/index.d.ts +12 -2
  261. package/dist/index.js +123 -93
  262. package/dist/index.js.map +1 -1
  263. package/dist/kagi.cjs +10 -10
  264. package/dist/kagi.js +5 -5
  265. package/dist/line.cjs +9 -9
  266. package/dist/line.js +4 -4
  267. package/dist/lines.cjs +10 -10
  268. package/dist/lines.js +5 -5
  269. package/dist/lollipop.cjs +9 -9
  270. package/dist/lollipop.js +4 -4
  271. package/dist/matrix.cjs +10 -10
  272. package/dist/matrix.js +5 -5
  273. package/dist/ohlc.cjs +9 -9
  274. package/dist/ohlc.js +4 -4
  275. package/dist/pack-type-CdtdkPBR.d.cts +10 -0
  276. package/dist/pack-type-Dm27RLC-.d.ts +10 -0
  277. package/dist/pack.cjs +33 -0
  278. package/dist/pack.cjs.map +1 -0
  279. package/dist/pack.d.cts +8 -0
  280. package/dist/pack.d.ts +8 -0
  281. package/dist/pack.js +12 -0
  282. package/dist/pack.js.map +1 -0
  283. package/dist/parallel.cjs +10 -10
  284. package/dist/parallel.js +5 -5
  285. package/dist/pictorialbar.cjs +10 -10
  286. package/dist/pictorialbar.js +5 -5
  287. package/dist/pie.cjs +11 -11
  288. package/dist/pie.js +6 -6
  289. package/dist/pillar-type-CIcSuZdu.d.cts +11 -0
  290. package/dist/pillar-type-DNpR_98h.d.ts +11 -0
  291. package/dist/pillar.cjs +33 -0
  292. package/dist/pillar.cjs.map +1 -0
  293. package/dist/pillar.d.cts +8 -0
  294. package/dist/pillar.d.ts +8 -0
  295. package/dist/pillar.js +12 -0
  296. package/dist/pillar.js.map +1 -0
  297. package/dist/polar.cjs +11 -11
  298. package/dist/polar.js +6 -6
  299. package/dist/radar.cjs +10 -10
  300. package/dist/radar.js +5 -5
  301. package/dist/radialbar.cjs +10 -10
  302. package/dist/radialbar.js +5 -5
  303. package/dist/range.cjs +9 -9
  304. package/dist/range.js +4 -4
  305. package/dist/renko.cjs +10 -10
  306. package/dist/renko.js +5 -5
  307. package/dist/sankey.cjs +10 -10
  308. package/dist/sankey.js +5 -5
  309. package/dist/scatter.cjs +9 -9
  310. package/dist/scatter.js +4 -4
  311. package/dist/sparkline.cjs +9 -9
  312. package/dist/sparkline.js +4 -4
  313. package/dist/stacked-bar.cjs +9 -9
  314. package/dist/stacked-bar.js +4 -4
  315. package/dist/step.cjs +10 -10
  316. package/dist/step.js +5 -5
  317. package/dist/sunburst.cjs +11 -11
  318. package/dist/sunburst.js +6 -6
  319. package/dist/themeriver.cjs +10 -10
  320. package/dist/themeriver.js +5 -5
  321. package/dist/tree.cjs +10 -10
  322. package/dist/tree.js +5 -5
  323. package/dist/treemap.cjs +10 -10
  324. package/dist/treemap.js +5 -5
  325. package/dist/violin-type-6KmTiJNp.d.cts +5 -0
  326. package/dist/violin-type-BOmiulQc.d.ts +5 -0
  327. package/dist/violin.cjs +33 -0
  328. package/dist/violin.cjs.map +1 -0
  329. package/dist/violin.d.cts +8 -0
  330. package/dist/violin.d.ts +8 -0
  331. package/dist/violin.js +12 -0
  332. package/dist/violin.js.map +1 -0
  333. package/dist/volume.cjs +9 -9
  334. package/dist/volume.js +4 -4
  335. package/dist/voronoi-type-BU5WnrcT.d.cts +12 -0
  336. package/dist/voronoi-type-D7n4mFNp.d.ts +12 -0
  337. package/dist/voronoi.cjs +33 -0
  338. package/dist/voronoi.cjs.map +1 -0
  339. package/dist/voronoi.d.cts +8 -0
  340. package/dist/voronoi.d.ts +8 -0
  341. package/dist/voronoi.js +12 -0
  342. package/dist/voronoi.js.map +1 -0
  343. package/dist/waterfall.cjs +9 -9
  344. package/dist/waterfall.js +4 -4
  345. package/dist/wordcloud-type-C6X9ORRR.d.ts +11 -0
  346. package/dist/wordcloud-type-CCm8rWK7.d.cts +11 -0
  347. package/dist/wordcloud.cjs +33 -0
  348. package/dist/wordcloud.cjs.map +1 -0
  349. package/dist/wordcloud.d.cts +8 -0
  350. package/dist/wordcloud.d.ts +8 -0
  351. package/dist/wordcloud.js +12 -0
  352. package/dist/wordcloud.js.map +1 -0
  353. package/package.json +1 -1
  354. package/dist/chunk-AEQXFDL7.js.map +0 -1
  355. package/dist/chunk-JVVGQLJQ.cjs.map +0 -1
  356. package/dist/chunk-LRHMLNPW.js.map +0 -1
  357. package/dist/chunk-QYI7ZV3B.cjs.map +0 -1
  358. package/dist/graph-type-Bg04GFeS.d.ts +0 -15
  359. package/dist/graph-type-DF-vww8T.d.cts +0 -15
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/lollipop/lollipop-type.ts"],"names":[],"mappings":"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","file":"chunk-QPHWRD25.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, line, circle } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Lollipop chart — stem line + circle at end.\n *\n * A modern, cleaner alternative to bar charts.\n * Vertical stems from baseline to value with a prominent circle dot.\n */\nexport const lollipopChartType: ChartTypePlugin = {\n type: 'lollipop',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, options)\n if (options.yMin === undefined && prepared.bounds.yMin > 0) {\n prepared.bounds.yMin = 0\n }\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n const bw = getBandwidth(xScale)\n const groupWidth = bw * 0.8\n const stemGap = groupWidth / seriesCount\n const dotR = Math.min(8, stemGap * 0.4)\n const baselineY = yScale.map(0)\n\n for (const series of data.series) {\n const seriesNodes: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i) + (series.index - (seriesCount - 1) / 2) * stemGap\n const vy = yScale.map(series.values[i]!)\n const color = options.colors[series.index % options.colors.length]!\n\n // Stem line — rounded cap, slightly thicker\n seriesNodes.push(line(cx, baselineY, cx, vy, {\n class: 'chartts-lollipop-stem',\n stroke: color,\n strokeWidth: 2.5,\n strokeLinecap: 'round',\n strokeOpacity: 0.6,\n }))\n\n // Ambient glow behind dot\n seriesNodes.push(circle(cx, vy, dotR * 2, {\n class: 'chartts-lollipop-glow',\n fill: color,\n fillOpacity: 0.12,\n }))\n\n // Dot — bigger, with theme-aware stroke\n seriesNodes.push(circle(cx, vy, dotR, {\n class: 'chartts-lollipop-dot',\n fill: color,\n stroke: `var(--chartts-bg, #fff)`,\n strokeWidth: 2.5,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\n }\n\n nodes.push(group(seriesNodes, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale } = ctx\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return null\n\n const bw = getBandwidth(xScale)\n const groupWidth = bw * 0.8\n const stemGap = groupWidth / seriesCount\n\n let best: HitResult | null = null\n let bestDist = 20 // tolerance\n\n for (const series of data.series) {\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i) + (series.index - (seriesCount - 1) / 2) * stemGap\n const vy = yScale.map(series.values[i]!)\n const dx = mx - cx\n const dy = my - vy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist, x: cx, y: vy }\n }\n }\n }\n\n return best\n },\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/lollipop/lollipop-type.ts"],"names":[],"mappings":"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","file":"chunk-MCORUYWB.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, line, circle } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Lollipop chart — stem line + circle at end.\n *\n * A modern, cleaner alternative to bar charts.\n * Vertical stems from baseline to value with a prominent circle dot.\n */\nexport const lollipopChartType: ChartTypePlugin = {\n type: 'lollipop',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, options)\n if (options.yMin === undefined && prepared.bounds.yMin > 0) {\n prepared.bounds.yMin = 0\n }\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n const bw = getBandwidth(xScale)\n const groupWidth = bw * 0.8\n const stemGap = groupWidth / seriesCount\n const dotR = Math.min(8, stemGap * 0.4)\n const baselineY = yScale.map(0)\n\n for (const series of data.series) {\n const seriesNodes: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i) + (series.index - (seriesCount - 1) / 2) * stemGap\n const vy = yScale.map(series.values[i]!)\n const color = options.colors[series.index % options.colors.length]!\n\n // Stem line — rounded cap, slightly thicker\n seriesNodes.push(line(cx, baselineY, cx, vy, {\n class: 'chartts-lollipop-stem',\n stroke: color,\n strokeWidth: 2.5,\n strokeLinecap: 'round',\n strokeOpacity: 0.6,\n }))\n\n // Ambient glow behind dot\n seriesNodes.push(circle(cx, vy, dotR * 2, {\n class: 'chartts-lollipop-glow',\n fill: color,\n fillOpacity: 0.12,\n }))\n\n // Dot — bigger, with theme-aware stroke\n seriesNodes.push(circle(cx, vy, dotR, {\n class: 'chartts-lollipop-dot',\n fill: color,\n stroke: `var(--chartts-bg, #fff)`,\n strokeWidth: 2.5,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\n }\n\n nodes.push(group(seriesNodes, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale } = ctx\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return null\n\n const bw = getBandwidth(xScale)\n const groupWidth = bw * 0.8\n const stemGap = groupWidth / seriesCount\n\n let best: HitResult | null = null\n let bestDist = 20 // tolerance\n\n for (const series of data.series) {\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i) + (series.index - (seriesCount - 1) / 2) * stemGap\n const vy = yScale.map(series.values[i]!)\n const dx = mx - cx\n const dy = my - vy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist, x: cx, y: vy }\n }\n }\n }\n\n return best\n },\n}\n"]}
@@ -1,5 +1,5 @@
1
- import { prepareNoAxes } from './chunk-T7SCCACB.js';
2
- import { path, PathBuilder, circle, text } from './chunk-AEQXFDL7.js';
1
+ import { prepareNoAxes } from './chunk-LKSKGQX7.js';
2
+ import { path, PathBuilder, circle, text } from './chunk-XIVC32HU.js';
3
3
 
4
4
  // src/charts/gauge/gauge-type.ts
5
5
  var gaugeChartType = {
@@ -140,5 +140,5 @@ function strokeArc(cx, cy, r, startAngle, endAngle) {
140
140
  }
141
141
 
142
142
  export { gaugeChartType };
143
- //# sourceMappingURL=chunk-2JYK52HV.js.map
144
- //# sourceMappingURL=chunk-2JYK52HV.js.map
143
+ //# sourceMappingURL=chunk-MJFCMUIY.js.map
144
+ //# sourceMappingURL=chunk-MJFCMUIY.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/gauge/gauge-type.ts"],"names":[],"mappings":"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","file":"chunk-2JYK52HV.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { path, circle, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\nexport interface GaugeOptions {\n /** Minimum value. Default 0. */\n gaugeMin?: number\n /** Maximum value. Default 100. */\n gaugeMax?: number\n /** Show value text in center. Default true. */\n showValue?: boolean\n /** Value format function. Default: round to int. */\n valueFormat?: (v: number) => string\n}\n\n/**\n * Gauge / Meter chart — single-value 240° arc with stroke-based rendering.\n *\n * Uses stroke-linecap:round for clean rounded endcaps. No fill-based donut arcs.\n * Looks like a modern dashboard gauge (Grafana, Material style).\n */\nexport const gaugeChartType: ChartTypePlugin = {\n type: 'gauge',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n const gOpts = options as unknown as GaugeOptions\n const min = gOpts.gaugeMin ?? 0\n const max = gOpts.gaugeMax ?? 100\n const showValue = gOpts.showValue ?? true\n const valueFormat = gOpts.valueFormat ?? ((v: number) => String(Math.round(v)))\n\n const value = series.values[0]!\n const pct = Math.max(0, Math.min(1, (value - min) / (max - min || 1)))\n\n // ----- Layout -----\n const cx = area.x + area.width / 2\n\n // Arc angles: 240° sweep, opening at the bottom\n // Start at 150° (bottom-left), sweep CW to 30° (bottom-right)\n const toRad = (d: number) => (d * Math.PI) / 180\n const startRad = toRad(150)\n const endRad = toRad(390) // 390° = 30° but keeps sweep direction clear\n\n // Size the arc to fit within the area with padding for labels\n // The arc bottom-most points are at 150° and 30° — y = cy + r*sin(30°) = cy + r*0.5\n // The arc top is at cy - r\n // Below the arc we need ~50px for value text, label, min/max\n const labelSpace = Math.min(60, area.height * 0.22)\n const availH = area.height - labelSpace\n // Arc top to arc bottom-endpoints: r + r*sin(30°) = r*1.5\n // So r*1.5 + strokeW <= availH\n const maxRadiusH = (availH - 8) / 1.55\n const maxRadiusW = (area.width - 16) / 2\n const radius = Math.min(maxRadiusH, maxRadiusW)\n const strokeW = Math.max(12, Math.min(radius * 0.18, 28))\n\n // Position: the top of the arc (cy - radius - strokeW/2) should be just inside area.y\n const cy = area.y + radius + strokeW / 2 + 4\n\n // Arc bottom-left/right y coordinate\n const arcBottomY = cy + radius * Math.sin(toRad(30))\n\n // ----- Track arc (background) -----\n nodes.push(path(strokeArc(cx, cy, radius, startRad, endRad), {\n class: 'chartts-gauge-track',\n stroke: theme.gridColor,\n strokeWidth: strokeW,\n fill: 'none',\n opacity: 0.3,\n style: 'stroke-linecap:round',\n }))\n\n // ----- Value arc -----\n const color = options.colors[0]!\n if (pct > 0.005) {\n const valueRad = startRad + (endRad - startRad) * pct\n nodes.push(path(strokeArc(cx, cy, radius, startRad, valueRad), {\n class: 'chartts-gauge-fill',\n stroke: color,\n strokeWidth: strokeW,\n fill: 'none',\n style: 'stroke-linecap:round',\n 'data-series': 0,\n 'data-index': 0,\n }))\n }\n\n // ----- Needle -----\n const needleAngle = startRad + (endRad - startRad) * pct\n const needleLen = radius - strokeW / 2 - 2\n const needleTipX = cx + needleLen * Math.cos(needleAngle)\n const needleTipY = cy + needleLen * Math.sin(needleAngle)\n\n // Tapered needle triangle\n const baseR = 3.5\n const bAngle1 = needleAngle + Math.PI / 2\n const bAngle2 = needleAngle - Math.PI / 2\n const npb = new PathBuilder()\n npb.moveTo(needleTipX, needleTipY)\n npb.lineTo(cx + baseR * Math.cos(bAngle1), cy + baseR * Math.sin(bAngle1))\n npb.lineTo(cx + baseR * Math.cos(bAngle2), cy + baseR * Math.sin(bAngle2))\n npb.close()\n\n nodes.push(path(npb.build(), {\n class: 'chartts-gauge-needle',\n fill: color,\n opacity: 0.85,\n }))\n\n // Center cap\n nodes.push(circle(cx, cy, 5, {\n class: 'chartts-gauge-needle-cap',\n fill: color,\n }))\n\n // ----- Labels -----\n if (showValue) {\n // Big value — in the gap below the arc center\n const valueFontSize = Math.max(16, Math.min(radius * 0.35, 40))\n const valueY = arcBottomY + labelSpace * 0.28\n nodes.push(text(cx, valueY, valueFormat(value), {\n class: 'chartts-gauge-value',\n fill: theme.textColor,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: valueFontSize,\n fontFamily: theme.fontFamily,\n fontWeight: 700,\n }))\n\n // Series name\n if (series.name) {\n nodes.push(text(cx, valueY + valueFontSize * 0.85, series.name, {\n class: 'chartts-gauge-label',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Min / Max at arc endpoints\n const minX = cx + radius * Math.cos(startRad)\n const minY = cy + radius * Math.sin(startRad) + strokeW / 2 + 12\n nodes.push(text(minX, minY, valueFormat(min), {\n class: 'chartts-gauge-min',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n const maxX = cx + radius * Math.cos(toRad(30))\n const maxY = cy + radius * Math.sin(toRad(30)) + strokeW / 2 + 12\n nodes.push(text(maxX, maxY, valueFormat(max), {\n class: 'chartts-gauge-max',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n }\n\n return nodes\n },\n\n hitTest(): HitResult | null {\n return null\n },\n}\n\n/**\n * Stroke-based arc path (open, for use with thick stroke + stroke-linecap:round).\n * Angles in radians, CW from positive X axis (SVG convention).\n */\nfunction strokeArc(\n cx: number, cy: number, r: number,\n startAngle: number, endAngle: number,\n): string {\n const pb = new PathBuilder()\n const x1 = cx + r * Math.cos(startAngle)\n const y1 = cy + r * Math.sin(startAngle)\n const x2 = cx + r * Math.cos(endAngle)\n const y2 = cy + r * Math.sin(endAngle)\n\n let span = endAngle - startAngle\n if (span < 0) span += 2 * Math.PI\n const largeArc = span > Math.PI\n\n pb.moveTo(x1, y1)\n pb.arc(r, r, 0, largeArc, true, x2, y2)\n return pb.build()\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/gauge/gauge-type.ts"],"names":[],"mappings":"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","file":"chunk-MJFCMUIY.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { path, circle, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\nexport interface GaugeOptions {\n /** Minimum value. Default 0. */\n gaugeMin?: number\n /** Maximum value. Default 100. */\n gaugeMax?: number\n /** Show value text in center. Default true. */\n showValue?: boolean\n /** Value format function. Default: round to int. */\n valueFormat?: (v: number) => string\n}\n\n/**\n * Gauge / Meter chart — single-value 240° arc with stroke-based rendering.\n *\n * Uses stroke-linecap:round for clean rounded endcaps. No fill-based donut arcs.\n * Looks like a modern dashboard gauge (Grafana, Material style).\n */\nexport const gaugeChartType: ChartTypePlugin = {\n type: 'gauge',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n const gOpts = options as unknown as GaugeOptions\n const min = gOpts.gaugeMin ?? 0\n const max = gOpts.gaugeMax ?? 100\n const showValue = gOpts.showValue ?? true\n const valueFormat = gOpts.valueFormat ?? ((v: number) => String(Math.round(v)))\n\n const value = series.values[0]!\n const pct = Math.max(0, Math.min(1, (value - min) / (max - min || 1)))\n\n // ----- Layout -----\n const cx = area.x + area.width / 2\n\n // Arc angles: 240° sweep, opening at the bottom\n // Start at 150° (bottom-left), sweep CW to 30° (bottom-right)\n const toRad = (d: number) => (d * Math.PI) / 180\n const startRad = toRad(150)\n const endRad = toRad(390) // 390° = 30° but keeps sweep direction clear\n\n // Size the arc to fit within the area with padding for labels\n // The arc bottom-most points are at 150° and 30° — y = cy + r*sin(30°) = cy + r*0.5\n // The arc top is at cy - r\n // Below the arc we need ~50px for value text, label, min/max\n const labelSpace = Math.min(60, area.height * 0.22)\n const availH = area.height - labelSpace\n // Arc top to arc bottom-endpoints: r + r*sin(30°) = r*1.5\n // So r*1.5 + strokeW <= availH\n const maxRadiusH = (availH - 8) / 1.55\n const maxRadiusW = (area.width - 16) / 2\n const radius = Math.min(maxRadiusH, maxRadiusW)\n const strokeW = Math.max(12, Math.min(radius * 0.18, 28))\n\n // Position: the top of the arc (cy - radius - strokeW/2) should be just inside area.y\n const cy = area.y + radius + strokeW / 2 + 4\n\n // Arc bottom-left/right y coordinate\n const arcBottomY = cy + radius * Math.sin(toRad(30))\n\n // ----- Track arc (background) -----\n nodes.push(path(strokeArc(cx, cy, radius, startRad, endRad), {\n class: 'chartts-gauge-track',\n stroke: theme.gridColor,\n strokeWidth: strokeW,\n fill: 'none',\n opacity: 0.3,\n style: 'stroke-linecap:round',\n }))\n\n // ----- Value arc -----\n const color = options.colors[0]!\n if (pct > 0.005) {\n const valueRad = startRad + (endRad - startRad) * pct\n nodes.push(path(strokeArc(cx, cy, radius, startRad, valueRad), {\n class: 'chartts-gauge-fill',\n stroke: color,\n strokeWidth: strokeW,\n fill: 'none',\n style: 'stroke-linecap:round',\n 'data-series': 0,\n 'data-index': 0,\n }))\n }\n\n // ----- Needle -----\n const needleAngle = startRad + (endRad - startRad) * pct\n const needleLen = radius - strokeW / 2 - 2\n const needleTipX = cx + needleLen * Math.cos(needleAngle)\n const needleTipY = cy + needleLen * Math.sin(needleAngle)\n\n // Tapered needle triangle\n const baseR = 3.5\n const bAngle1 = needleAngle + Math.PI / 2\n const bAngle2 = needleAngle - Math.PI / 2\n const npb = new PathBuilder()\n npb.moveTo(needleTipX, needleTipY)\n npb.lineTo(cx + baseR * Math.cos(bAngle1), cy + baseR * Math.sin(bAngle1))\n npb.lineTo(cx + baseR * Math.cos(bAngle2), cy + baseR * Math.sin(bAngle2))\n npb.close()\n\n nodes.push(path(npb.build(), {\n class: 'chartts-gauge-needle',\n fill: color,\n opacity: 0.85,\n }))\n\n // Center cap\n nodes.push(circle(cx, cy, 5, {\n class: 'chartts-gauge-needle-cap',\n fill: color,\n }))\n\n // ----- Labels -----\n if (showValue) {\n // Big value — in the gap below the arc center\n const valueFontSize = Math.max(16, Math.min(radius * 0.35, 40))\n const valueY = arcBottomY + labelSpace * 0.28\n nodes.push(text(cx, valueY, valueFormat(value), {\n class: 'chartts-gauge-value',\n fill: theme.textColor,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: valueFontSize,\n fontFamily: theme.fontFamily,\n fontWeight: 700,\n }))\n\n // Series name\n if (series.name) {\n nodes.push(text(cx, valueY + valueFontSize * 0.85, series.name, {\n class: 'chartts-gauge-label',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Min / Max at arc endpoints\n const minX = cx + radius * Math.cos(startRad)\n const minY = cy + radius * Math.sin(startRad) + strokeW / 2 + 12\n nodes.push(text(minX, minY, valueFormat(min), {\n class: 'chartts-gauge-min',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n const maxX = cx + radius * Math.cos(toRad(30))\n const maxY = cy + radius * Math.sin(toRad(30)) + strokeW / 2 + 12\n nodes.push(text(maxX, maxY, valueFormat(max), {\n class: 'chartts-gauge-max',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n }\n\n return nodes\n },\n\n hitTest(): HitResult | null {\n return null\n },\n}\n\n/**\n * Stroke-based arc path (open, for use with thick stroke + stroke-linecap:round).\n * Angles in radians, CW from positive X axis (SVG convention).\n */\nfunction strokeArc(\n cx: number, cy: number, r: number,\n startAngle: number, endAngle: number,\n): string {\n const pb = new PathBuilder()\n const x1 = cx + r * Math.cos(startAngle)\n const y1 = cy + r * Math.sin(startAngle)\n const x2 = cx + r * Math.cos(endAngle)\n const y2 = cy + r * Math.sin(endAngle)\n\n let span = endAngle - startAngle\n if (span < 0) span += 2 * Math.PI\n const largeArc = span > Math.PI\n\n pb.moveTo(x1, y1)\n pb.arc(r, r, 0, largeArc, true, x2, y2)\n return pb.build()\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
- var chunkV5Q6UNUK_cjs = require('./chunk-V5Q6UNUK.cjs');
4
- var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
3
+ var chunkX5SG6MFS_cjs = require('./chunk-X5SG6MFS.cjs');
4
+ var chunkW626EAS5_cjs = require('./chunk-W626EAS5.cjs');
5
5
 
6
6
  // src/charts/kagi/kagi-type.ts
7
7
  var kagiChartType = {
@@ -10,7 +10,7 @@ var kagiChartType = {
10
10
  return { x: "categorical", y: "linear" };
11
11
  },
12
12
  prepareData(data, options) {
13
- return chunkV5Q6UNUK_cjs.prepareNoAxes(data, options);
13
+ return chunkX5SG6MFS_cjs.prepareNoAxes(data, options);
14
14
  },
15
15
  render(ctx) {
16
16
  const { data, area, options, theme } = ctx;
@@ -47,13 +47,13 @@ var kagiChartType = {
47
47
  const y2 = mapY(seg.priceEnd);
48
48
  const color = seg.isYang ? yangColor : yinColor;
49
49
  const width = seg.isYang ? yangWidth : yinWidth;
50
- const pb = new chunkJVVGQLJQ_cjs.PathBuilder();
50
+ const pb = new chunkW626EAS5_cjs.PathBuilder();
51
51
  pb.moveTo(x, y1).lineTo(x, y2);
52
52
  if (i < segments.length - 1) {
53
53
  const nextX = xOffset + (i + 1) * actualColWidth;
54
54
  pb.lineTo(nextX, y2);
55
55
  }
56
- kagiNodes.push(chunkJVVGQLJQ_cjs.path(pb.build(), {
56
+ kagiNodes.push(chunkW626EAS5_cjs.path(pb.build(), {
57
57
  class: "chartts-kagi-line",
58
58
  stroke: color,
59
59
  strokeWidth: width,
@@ -63,7 +63,7 @@ var kagiChartType = {
63
63
  "data-index": i
64
64
  }));
65
65
  if (showLabels && (i === 0 || i === segments.length - 1)) {
66
- kagiNodes.push(chunkJVVGQLJQ_cjs.text(x, y2 + (seg.priceEnd > seg.priceStart ? -8 : 14), seg.priceEnd.toFixed(1), {
66
+ kagiNodes.push(chunkW626EAS5_cjs.text(x, y2 + (seg.priceEnd > seg.priceStart ? -8 : 14), seg.priceEnd.toFixed(1), {
67
67
  class: "chartts-kagi-label",
68
68
  fill: theme.textMuted,
69
69
  fontSize: theme.fontSizeSmall,
@@ -71,7 +71,7 @@ var kagiChartType = {
71
71
  }));
72
72
  }
73
73
  }
74
- nodes.push(chunkJVVGQLJQ_cjs.group(kagiNodes, {
74
+ nodes.push(chunkW626EAS5_cjs.group(kagiNodes, {
75
75
  class: "chartts-series chartts-series-0",
76
76
  "data-series-name": series.name
77
77
  }));
@@ -152,5 +152,5 @@ function computeKagiSegments(values, reversal) {
152
152
  }
153
153
 
154
154
  exports.kagiChartType = kagiChartType;
155
- //# sourceMappingURL=chunk-7PHOSSLJ.cjs.map
156
- //# sourceMappingURL=chunk-7PHOSSLJ.cjs.map
155
+ //# sourceMappingURL=chunk-NHSPO4BN.cjs.map
156
+ //# sourceMappingURL=chunk-NHSPO4BN.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/kagi/kagi-type.ts"],"names":["prepareNoAxes","PathBuilder","path","text","group"],"mappings":"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","file":"chunk-7PHOSSLJ.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, path, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\nexport interface KagiOptions {\n /** Reversal amount. If < 1, treated as percentage of range. Default 0.04 (4%). */\n reversalAmount?: number\n /** Yang (up-trend) color. Default green. */\n yangColor?: string\n /** Yin (down-trend) color. Default red. */\n yinColor?: string\n /** Yang line width (thick). Default 3. */\n yangWidth?: number\n /** Yin line width (thin). Default 1.5. */\n yinWidth?: number\n /** Show price labels at turning points. Default false. */\n showLabels?: boolean\n}\n\ninterface KagiSegment {\n startY: number\n endY: number\n x: number\n isYang: boolean // thick = up trend\n priceStart: number\n priceEnd: number\n}\n\n/**\n * Kagi chart — Japanese reversal chart.\n *\n * Lines change direction only on significant price moves.\n * Thick lines (yang) = up trend, thin lines (yin) = down trend.\n * Thickness changes when price breaks prior high/low.\n */\nexport const kagiChartType: ChartTypePlugin = {\n type: 'kagi',\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, options, theme } = ctx\n const nodes: RenderNode[] = []\n\n const series = data.series[0]\n if (!series || series.values.length < 2) return nodes\n\n const opts = options as unknown as KagiOptions\n const yangColor = opts.yangColor ?? 'var(--color-emerald-500, #10b981)'\n const yinColor = opts.yinColor ?? 'var(--color-red-500, #ef4444)'\n const yangWidth = opts.yangWidth ?? 3\n const yinWidth = opts.yinWidth ?? 1.5\n const showLabels = opts.showLabels ?? false\n\n const values = series.values\n const vMin = Math.min(...values)\n const vMax = Math.max(...values)\n const vRange = vMax - vMin || 1\n\n // Reversal amount\n let reversal = opts.reversalAmount ?? 0.04\n if (reversal < 1) reversal = reversal * vRange\n\n // Build kagi segments\n const segments = computeKagiSegments(values, reversal)\n if (segments.length === 0) return nodes\n\n // Map to pixel coordinates\n const padding = 20\n const usableWidth = area.width - padding * 2\n const usableHeight = area.height - padding * 2\n const colWidth = segments.length > 1 ? usableWidth / (segments.length - 1) : usableWidth\n\n const mapY = (v: number) => area.y + padding + (1 - (v - vMin) / vRange) * usableHeight\n const actualColWidth = Math.min(colWidth, 20)\n const totalWidth = actualColWidth * (segments.length - 1)\n const xOffset = area.x + (area.width - totalWidth) / 2\n\n const kagiNodes: RenderNode[] = []\n\n // Draw segments\n for (let i = 0; i < segments.length; i++) {\n const seg = segments[i]!\n const x = xOffset + i * actualColWidth\n const y1 = mapY(seg.priceStart)\n const y2 = mapY(seg.priceEnd)\n const color = seg.isYang ? yangColor : yinColor\n const width = seg.isYang ? yangWidth : yinWidth\n\n // Vertical segment\n const pb = new PathBuilder()\n pb.moveTo(x, y1).lineTo(x, y2)\n\n // Horizontal connector to next segment\n if (i < segments.length - 1) {\n const nextX = xOffset + (i + 1) * actualColWidth\n pb.lineTo(nextX, y2)\n }\n\n kagiNodes.push(path(pb.build(), {\n class: 'chartts-kagi-line',\n stroke: color,\n strokeWidth: width,\n strokeLinecap: 'round',\n strokeLinejoin: 'round',\n 'data-series': 0,\n 'data-index': i,\n }))\n\n // Price labels at turning points\n if (showLabels && (i === 0 || i === segments.length - 1)) {\n kagiNodes.push(text(x, y2 + (seg.priceEnd > seg.priceStart ? -8 : 14), seg.priceEnd.toFixed(1), {\n class: 'chartts-kagi-label',\n fill: theme.textMuted,\n fontSize: theme.fontSizeSmall,\n textAnchor: 'middle',\n }))\n }\n }\n\n nodes.push(group(kagiNodes, {\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, area } = ctx\n const series = data.series[0]\n if (!series || series.values.length < 2) return null\n\n // Approximate: map mouse X to data index\n const frac = (mx - area.x) / area.width\n const idx = Math.round(frac * (series.values.length - 1))\n if (idx >= 0 && idx < series.values.length) {\n return { seriesIndex: 0, pointIndex: idx, distance: 10, x: mx, y: my }\n }\n return null\n },\n}\n\n/**\n * Compute kagi line segments from raw price data.\n */\nfunction computeKagiSegments(values: number[], reversal: number): KagiSegment[] {\n const segments: KagiSegment[] = []\n if (values.length < 2) return segments\n\n let direction: 'up' | 'down' = values[1]! >= values[0]! ? 'up' : 'down'\n let currentStart = values[0]!\n let currentEnd = values[1]!\n let priorHigh = Math.max(values[0]!, values[1]!)\n let priorLow = Math.min(values[0]!, values[1]!)\n let isYang = direction === 'up'\n\n for (let i = 2; i < values.length; i++) {\n const v = values[i]!\n\n if (direction === 'up') {\n if (v >= currentEnd) {\n // Continue up\n currentEnd = v\n if (v > priorHigh) isYang = true\n } else if (currentEnd - v >= reversal) {\n // Reversal down\n segments.push({\n startY: 0, endY: 0, x: 0,\n isYang,\n priceStart: currentStart,\n priceEnd: currentEnd,\n })\n priorHigh = currentEnd\n currentStart = currentEnd\n currentEnd = v\n direction = 'down'\n if (v < priorLow) isYang = false\n }\n } else {\n if (v <= currentEnd) {\n // Continue down\n currentEnd = v\n if (v < priorLow) isYang = false\n } else if (v - currentEnd >= reversal) {\n // Reversal up\n segments.push({\n startY: 0, endY: 0, x: 0,\n isYang,\n priceStart: currentStart,\n priceEnd: currentEnd,\n })\n priorLow = currentEnd\n currentStart = currentEnd\n currentEnd = v\n direction = 'up'\n if (v > priorHigh) isYang = true\n }\n }\n }\n\n // Push final segment\n segments.push({\n startY: 0, endY: 0, x: 0,\n isYang,\n priceStart: currentStart,\n priceEnd: currentEnd,\n })\n\n return segments\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/kagi/kagi-type.ts"],"names":["prepareNoAxes","PathBuilder","path","text","group"],"mappings":"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","file":"chunk-NHSPO4BN.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, path, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\nexport interface KagiOptions {\n /** Reversal amount. If < 1, treated as percentage of range. Default 0.04 (4%). */\n reversalAmount?: number\n /** Yang (up-trend) color. Default green. */\n yangColor?: string\n /** Yin (down-trend) color. Default red. */\n yinColor?: string\n /** Yang line width (thick). Default 3. */\n yangWidth?: number\n /** Yin line width (thin). Default 1.5. */\n yinWidth?: number\n /** Show price labels at turning points. Default false. */\n showLabels?: boolean\n}\n\ninterface KagiSegment {\n startY: number\n endY: number\n x: number\n isYang: boolean // thick = up trend\n priceStart: number\n priceEnd: number\n}\n\n/**\n * Kagi chart — Japanese reversal chart.\n *\n * Lines change direction only on significant price moves.\n * Thick lines (yang) = up trend, thin lines (yin) = down trend.\n * Thickness changes when price breaks prior high/low.\n */\nexport const kagiChartType: ChartTypePlugin = {\n type: 'kagi',\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, options, theme } = ctx\n const nodes: RenderNode[] = []\n\n const series = data.series[0]\n if (!series || series.values.length < 2) return nodes\n\n const opts = options as unknown as KagiOptions\n const yangColor = opts.yangColor ?? 'var(--color-emerald-500, #10b981)'\n const yinColor = opts.yinColor ?? 'var(--color-red-500, #ef4444)'\n const yangWidth = opts.yangWidth ?? 3\n const yinWidth = opts.yinWidth ?? 1.5\n const showLabels = opts.showLabels ?? false\n\n const values = series.values\n const vMin = Math.min(...values)\n const vMax = Math.max(...values)\n const vRange = vMax - vMin || 1\n\n // Reversal amount\n let reversal = opts.reversalAmount ?? 0.04\n if (reversal < 1) reversal = reversal * vRange\n\n // Build kagi segments\n const segments = computeKagiSegments(values, reversal)\n if (segments.length === 0) return nodes\n\n // Map to pixel coordinates\n const padding = 20\n const usableWidth = area.width - padding * 2\n const usableHeight = area.height - padding * 2\n const colWidth = segments.length > 1 ? usableWidth / (segments.length - 1) : usableWidth\n\n const mapY = (v: number) => area.y + padding + (1 - (v - vMin) / vRange) * usableHeight\n const actualColWidth = Math.min(colWidth, 20)\n const totalWidth = actualColWidth * (segments.length - 1)\n const xOffset = area.x + (area.width - totalWidth) / 2\n\n const kagiNodes: RenderNode[] = []\n\n // Draw segments\n for (let i = 0; i < segments.length; i++) {\n const seg = segments[i]!\n const x = xOffset + i * actualColWidth\n const y1 = mapY(seg.priceStart)\n const y2 = mapY(seg.priceEnd)\n const color = seg.isYang ? yangColor : yinColor\n const width = seg.isYang ? yangWidth : yinWidth\n\n // Vertical segment\n const pb = new PathBuilder()\n pb.moveTo(x, y1).lineTo(x, y2)\n\n // Horizontal connector to next segment\n if (i < segments.length - 1) {\n const nextX = xOffset + (i + 1) * actualColWidth\n pb.lineTo(nextX, y2)\n }\n\n kagiNodes.push(path(pb.build(), {\n class: 'chartts-kagi-line',\n stroke: color,\n strokeWidth: width,\n strokeLinecap: 'round',\n strokeLinejoin: 'round',\n 'data-series': 0,\n 'data-index': i,\n }))\n\n // Price labels at turning points\n if (showLabels && (i === 0 || i === segments.length - 1)) {\n kagiNodes.push(text(x, y2 + (seg.priceEnd > seg.priceStart ? -8 : 14), seg.priceEnd.toFixed(1), {\n class: 'chartts-kagi-label',\n fill: theme.textMuted,\n fontSize: theme.fontSizeSmall,\n textAnchor: 'middle',\n }))\n }\n }\n\n nodes.push(group(kagiNodes, {\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, area } = ctx\n const series = data.series[0]\n if (!series || series.values.length < 2) return null\n\n // Approximate: map mouse X to data index\n const frac = (mx - area.x) / area.width\n const idx = Math.round(frac * (series.values.length - 1))\n if (idx >= 0 && idx < series.values.length) {\n return { seriesIndex: 0, pointIndex: idx, distance: 10, x: mx, y: my }\n }\n return null\n },\n}\n\n/**\n * Compute kagi line segments from raw price data.\n */\nfunction computeKagiSegments(values: number[], reversal: number): KagiSegment[] {\n const segments: KagiSegment[] = []\n if (values.length < 2) return segments\n\n let direction: 'up' | 'down' = values[1]! >= values[0]! ? 'up' : 'down'\n let currentStart = values[0]!\n let currentEnd = values[1]!\n let priorHigh = Math.max(values[0]!, values[1]!)\n let priorLow = Math.min(values[0]!, values[1]!)\n let isYang = direction === 'up'\n\n for (let i = 2; i < values.length; i++) {\n const v = values[i]!\n\n if (direction === 'up') {\n if (v >= currentEnd) {\n // Continue up\n currentEnd = v\n if (v > priorHigh) isYang = true\n } else if (currentEnd - v >= reversal) {\n // Reversal down\n segments.push({\n startY: 0, endY: 0, x: 0,\n isYang,\n priceStart: currentStart,\n priceEnd: currentEnd,\n })\n priorHigh = currentEnd\n currentStart = currentEnd\n currentEnd = v\n direction = 'down'\n if (v < priorLow) isYang = false\n }\n } else {\n if (v <= currentEnd) {\n // Continue down\n currentEnd = v\n if (v < priorLow) isYang = false\n } else if (v - currentEnd >= reversal) {\n // Reversal up\n segments.push({\n startY: 0, endY: 0, x: 0,\n isYang,\n priceStart: currentStart,\n priceEnd: currentEnd,\n })\n priorLow = currentEnd\n currentStart = currentEnd\n currentEnd = v\n direction = 'up'\n if (v > priorHigh) isYang = true\n }\n }\n }\n\n // Push final segment\n segments.push({\n startY: 0, endY: 0, x: 0,\n isYang,\n priceStart: currentStart,\n priceEnd: currentEnd,\n })\n\n return segments\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
- var chunkV5Q6UNUK_cjs = require('./chunk-V5Q6UNUK.cjs');
4
- var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
3
+ var chunkX5SG6MFS_cjs = require('./chunk-X5SG6MFS.cjs');
4
+ var chunkW626EAS5_cjs = require('./chunk-W626EAS5.cjs');
5
5
 
6
6
  // src/charts/chord/chord-type.ts
7
7
  var chordChartType = {
@@ -10,7 +10,7 @@ var chordChartType = {
10
10
  return { x: "categorical", y: "linear" };
11
11
  },
12
12
  prepareData(data, options) {
13
- return chunkV5Q6UNUK_cjs.prepareNoAxes(data, options);
13
+ return chunkX5SG6MFS_cjs.prepareNoAxes(data, options);
14
14
  },
15
15
  render(ctx) {
16
16
  const { data, area, theme, options } = ctx;
@@ -24,7 +24,7 @@ var chordChartType = {
24
24
  for (const arc of arcs) {
25
25
  if (arc.endAngle - arc.startAngle < 0.01) continue;
26
26
  const color = options.colors[arc.index % options.colors.length];
27
- const pb = new chunkJVVGQLJQ_cjs.PathBuilder();
27
+ const pb = new chunkW626EAS5_cjs.PathBuilder();
28
28
  const x1o = cx + outerR * Math.cos(arc.startAngle);
29
29
  const y1o = cy + outerR * Math.sin(arc.startAngle);
30
30
  const x2o = cx + outerR * Math.cos(arc.endAngle);
@@ -39,7 +39,7 @@ var chordChartType = {
39
39
  pb.lineTo(x1i, y1i);
40
40
  pb.arc(innerR, innerR, 0, largeArc, false, x2i, y2i);
41
41
  pb.close();
42
- nodes.push(chunkJVVGQLJQ_cjs.path(pb.build(), {
42
+ nodes.push(chunkW626EAS5_cjs.path(pb.build(), {
43
43
  class: "chartts-chord-arc",
44
44
  fill: color,
45
45
  stroke: color,
@@ -55,7 +55,7 @@ var chordChartType = {
55
55
  const lx = cx + labelR * Math.cos(midAngle);
56
56
  const ly = cy + labelR * Math.sin(midAngle);
57
57
  const anchor = Math.abs(Math.cos(midAngle)) < 0.01 ? "middle" : Math.cos(midAngle) > 0 ? "start" : "end";
58
- nodes.push(chunkJVVGQLJQ_cjs.text(lx, ly, arc.name, {
58
+ nodes.push(chunkW626EAS5_cjs.text(lx, ly, arc.name, {
59
59
  class: "chartts-chord-label",
60
60
  fill: theme.textColor,
61
61
  textAnchor: anchor,
@@ -67,7 +67,7 @@ var chordChartType = {
67
67
  for (let ri = 0; ri < ribbons.length; ri++) {
68
68
  const ribbon = ribbons[ri];
69
69
  const color = options.colors[ribbon.source % options.colors.length];
70
- const pb = new chunkJVVGQLJQ_cjs.PathBuilder();
70
+ const pb = new chunkW626EAS5_cjs.PathBuilder();
71
71
  const sx1 = cx + innerR * Math.cos(ribbon.sourceStart);
72
72
  const sy1 = cy + innerR * Math.sin(ribbon.sourceStart);
73
73
  const sx2 = cx + innerR * Math.cos(ribbon.sourceEnd);
@@ -84,7 +84,7 @@ var chordChartType = {
84
84
  pb.arc(innerR, innerR, 0, tgtLarge, true, tx2, ty2);
85
85
  pb.quadTo(cx, cy, sx1, sy1);
86
86
  pb.close();
87
- nodes.push(chunkJVVGQLJQ_cjs.path(pb.build(), {
87
+ nodes.push(chunkW626EAS5_cjs.path(pb.build(), {
88
88
  class: "chartts-chord-ribbon",
89
89
  fill: color,
90
90
  fillOpacity: 0.35,
@@ -218,5 +218,5 @@ function buildChordLayout(data, _options) {
218
218
  }
219
219
 
220
220
  exports.chordChartType = chordChartType;
221
- //# sourceMappingURL=chunk-5QT67VYJ.cjs.map
222
- //# sourceMappingURL=chunk-5QT67VYJ.cjs.map
221
+ //# sourceMappingURL=chunk-NR5NQ6TV.cjs.map
222
+ //# sourceMappingURL=chunk-NR5NQ6TV.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/chord/chord-type.ts"],"names":["prepareNoAxes","PathBuilder","path","text"],"mappings":"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","file":"chunk-5QT67VYJ.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { path, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Chord diagram — shows relationships between entities via ribbons\n * connecting arcs on a circle.\n *\n * Data convention:\n * - labels: entity names (placed around the circle as arcs)\n * - series[i].values[j]: flow from entity i to entity j (adjacency matrix)\n * series.length should equal labels.length for a square matrix.\n *\n * Alternative: arrow notation like Sankey\n * - series names contain \"→\" or \"->\" (e.g., \"A → B\")\n */\n\ninterface ChordArc {\n index: number\n name: string\n total: number\n startAngle: number\n endAngle: number\n}\n\ninterface ChordRibbon {\n source: number\n target: number\n value: number\n sourceStart: number\n sourceEnd: number\n targetStart: number\n targetEnd: number\n}\n\nexport const chordChartType: ChartTypePlugin = {\n type: 'chord',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const { arcs, ribbons } = buildChordLayout(data, options)\n if (arcs.length === 0) return nodes\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR - 14\n\n // Render arcs\n for (const arc of arcs) {\n if (arc.endAngle - arc.startAngle < 0.01) continue\n\n const color = options.colors[arc.index % options.colors.length]!\n const pb = new PathBuilder()\n\n const x1o = cx + outerR * Math.cos(arc.startAngle)\n const y1o = cy + outerR * Math.sin(arc.startAngle)\n const x2o = cx + outerR * Math.cos(arc.endAngle)\n const y2o = cy + outerR * Math.sin(arc.endAngle)\n const x1i = cx + innerR * Math.cos(arc.endAngle)\n const y1i = cy + innerR * Math.sin(arc.endAngle)\n const x2i = cx + innerR * Math.cos(arc.startAngle)\n const y2i = cy + innerR * Math.sin(arc.startAngle)\n const largeArc = (arc.endAngle - arc.startAngle) > Math.PI\n\n pb.moveTo(x1o, y1o)\n pb.arc(outerR, outerR, 0, largeArc, true, x2o, y2o)\n pb.lineTo(x1i, y1i)\n pb.arc(innerR, innerR, 0, largeArc, false, x2i, y2i)\n pb.close()\n\n nodes.push(path(pb.build(), {\n class: 'chartts-chord-arc',\n fill: color,\n stroke: color,\n strokeWidth: 0.5,\n 'data-series': arc.index,\n 'data-index': 0,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${arc.name}: ${arc.total}`,\n }))\n\n // Label\n const midAngle = (arc.startAngle + arc.endAngle) / 2\n const labelR = outerR + 12\n const lx = cx + labelR * Math.cos(midAngle)\n const ly = cy + labelR * Math.sin(midAngle)\n const anchor = Math.abs(Math.cos(midAngle)) < 0.01 ? 'middle' as const\n : Math.cos(midAngle) > 0 ? 'start' as const : 'end' as const\n\n nodes.push(text(lx, ly, arc.name, {\n class: 'chartts-chord-label',\n fill: theme.textColor,\n textAnchor: anchor,\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Render ribbons\n for (let ri = 0; ri < ribbons.length; ri++) {\n const ribbon = ribbons[ri]!\n const color = options.colors[ribbon.source % options.colors.length]!\n\n const pb = new PathBuilder()\n // Source arc on inner ring\n const sx1 = cx + innerR * Math.cos(ribbon.sourceStart)\n const sy1 = cy + innerR * Math.sin(ribbon.sourceStart)\n const sx2 = cx + innerR * Math.cos(ribbon.sourceEnd)\n const sy2 = cy + innerR * Math.sin(ribbon.sourceEnd)\n // Target arc on inner ring\n const tx1 = cx + innerR * Math.cos(ribbon.targetStart)\n const ty1 = cy + innerR * Math.sin(ribbon.targetStart)\n const tx2 = cx + innerR * Math.cos(ribbon.targetEnd)\n const ty2 = cy + innerR * Math.sin(ribbon.targetEnd)\n\n const srcLarge = (ribbon.sourceEnd - ribbon.sourceStart) > Math.PI\n const tgtLarge = (ribbon.targetEnd - ribbon.targetStart) > Math.PI\n\n pb.moveTo(sx1, sy1)\n pb.arc(innerR, innerR, 0, srcLarge, true, sx2, sy2)\n // Bezier to target\n pb.quadTo(cx, cy, tx1, ty1)\n pb.arc(innerR, innerR, 0, tgtLarge, true, tx2, ty2)\n // Bezier back to source\n pb.quadTo(cx, cy, sx1, sy1)\n pb.close()\n\n nodes.push(path(pb.build(), {\n class: 'chartts-chord-ribbon',\n fill: color,\n fillOpacity: 0.35,\n stroke: color,\n strokeWidth: 0.3,\n 'data-series': ribbon.source,\n 'data-index': ri,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${arcs[ribbon.source]!.name} → ${arcs[ribbon.target]!.name}: ${ribbon.value}`,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area, options } = ctx\n const { arcs } = buildChordLayout(data, options)\n if (arcs.length === 0) return null\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR - 14\n\n const dx = mx - cx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n // Check arc hits\n if (dist >= innerR && dist <= outerR) {\n let angle = Math.atan2(dy, dx)\n if (angle < -Math.PI / 2) angle += Math.PI * 2\n\n for (const arc of arcs) {\n if (angle >= arc.startAngle && angle <= arc.endAngle) {\n const midAngle = (arc.startAngle + arc.endAngle) / 2\n const midR = (innerR + outerR) / 2\n return { seriesIndex: arc.index, pointIndex: 0, distance: 0, x: cx + midR * Math.cos(midAngle), y: cy + midR * Math.sin(midAngle) }\n }\n }\n }\n\n return null\n },\n}\n\n// ---------------------------------------------------------------------------\n// Layout computation\n// ---------------------------------------------------------------------------\n\nfunction buildChordLayout(\n data: PreparedData,\n _options: ResolvedOptions,\n): { arcs: ChordArc[]; ribbons: ChordRibbon[]; matrix: number[][] } {\n const arcs: ChordArc[] = []\n const ribbons: ChordRibbon[] = []\n\n // Check for arrow notation\n const hasArrows = data.series.some(s => s.name.includes('→') || s.name.includes('->'))\n\n // Build adjacency matrix\n const nodeNames: string[] = []\n const nodeMap = new Map<string, number>()\n\n function getOrCreate(name: string): number {\n if (nodeMap.has(name)) return nodeMap.get(name)!\n const idx = nodeNames.length\n nodeMap.set(name, idx)\n nodeNames.push(name)\n return idx\n }\n\n if (hasArrows) {\n // Parse arrow notation\n for (const series of data.series) {\n const parts = series.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length < 2) continue\n getOrCreate(parts[0]!.trim())\n getOrCreate(parts[1]!.trim())\n }\n } else {\n for (let i = 0; i < data.labels.length; i++) {\n getOrCreate(String(data.labels[i]))\n }\n }\n\n const n = nodeNames.length\n if (n === 0) return { arcs, ribbons, matrix: [] }\n\n const matrix: number[][] = Array.from({ length: n }, () => new Array(n).fill(0))\n\n if (hasArrows) {\n for (const series of data.series) {\n const parts = series.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length < 2) continue\n const src = getOrCreate(parts[0]!.trim())\n const tgt = getOrCreate(parts[1]!.trim())\n const val = series.values[0] ?? 0\n if (val > 0) matrix[src]![tgt]! += val\n }\n } else {\n for (let si = 0; si < data.series.length && si < n; si++) {\n for (let j = 0; j < data.series[si]!.values.length && j < n; j++) {\n const val = data.series[si]!.values[j]!\n if (val > 0) matrix[si]![j]! = val\n }\n }\n }\n\n // Compute totals per node\n const totals = nodeNames.map((_, i) => {\n let total = 0\n for (let j = 0; j < n; j++) {\n total += matrix[i]![j]!\n total += matrix[j]![i]!\n }\n return total\n })\n\n const grandTotal = totals.reduce((s, t) => s + t, 0)\n if (grandTotal === 0) return { arcs, ribbons, matrix }\n\n // Layout arcs\n const padAngle = 0.04\n const totalPad = padAngle * n\n const available = Math.PI * 2 - totalPad\n\n let angle = -Math.PI / 2\n for (let i = 0; i < n; i++) {\n const span = (totals[i]! / grandTotal) * available\n arcs.push({\n index: i,\n name: nodeNames[i]!,\n total: totals[i]!,\n startAngle: angle,\n endAngle: angle + span,\n })\n angle += span + padAngle\n }\n\n // Layout ribbons — track offsets within each arc\n const arcOffsets = arcs.map(a => a.startAngle)\n\n for (let i = 0; i < n; i++) {\n for (let j = i; j < n; j++) {\n const val = matrix[i]![j]! + matrix[j]![i]!\n if (val <= 0) continue\n\n const srcSpan = (matrix[i]![j]! / Math.max(totals[i]!, 1)) * (arcs[i]!.endAngle - arcs[i]!.startAngle)\n const tgtSpan = (matrix[j]![i]! / Math.max(totals[j]!, 1)) * (arcs[j]!.endAngle - arcs[j]!.startAngle)\n\n ribbons.push({\n source: i,\n target: j,\n value: val,\n sourceStart: arcOffsets[i]!,\n sourceEnd: arcOffsets[i]! + srcSpan,\n targetStart: arcOffsets[j]!,\n targetEnd: arcOffsets[j]! + tgtSpan,\n })\n\n arcOffsets[i]! += srcSpan\n arcOffsets[j]! += tgtSpan\n }\n }\n\n return { arcs, ribbons, matrix }\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/chord/chord-type.ts"],"names":["prepareNoAxes","PathBuilder","path","text"],"mappings":"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","file":"chunk-NR5NQ6TV.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { path, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Chord diagram — shows relationships between entities via ribbons\n * connecting arcs on a circle.\n *\n * Data convention:\n * - labels: entity names (placed around the circle as arcs)\n * - series[i].values[j]: flow from entity i to entity j (adjacency matrix)\n * series.length should equal labels.length for a square matrix.\n *\n * Alternative: arrow notation like Sankey\n * - series names contain \"→\" or \"->\" (e.g., \"A → B\")\n */\n\ninterface ChordArc {\n index: number\n name: string\n total: number\n startAngle: number\n endAngle: number\n}\n\ninterface ChordRibbon {\n source: number\n target: number\n value: number\n sourceStart: number\n sourceEnd: number\n targetStart: number\n targetEnd: number\n}\n\nexport const chordChartType: ChartTypePlugin = {\n type: 'chord',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const { arcs, ribbons } = buildChordLayout(data, options)\n if (arcs.length === 0) return nodes\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR - 14\n\n // Render arcs\n for (const arc of arcs) {\n if (arc.endAngle - arc.startAngle < 0.01) continue\n\n const color = options.colors[arc.index % options.colors.length]!\n const pb = new PathBuilder()\n\n const x1o = cx + outerR * Math.cos(arc.startAngle)\n const y1o = cy + outerR * Math.sin(arc.startAngle)\n const x2o = cx + outerR * Math.cos(arc.endAngle)\n const y2o = cy + outerR * Math.sin(arc.endAngle)\n const x1i = cx + innerR * Math.cos(arc.endAngle)\n const y1i = cy + innerR * Math.sin(arc.endAngle)\n const x2i = cx + innerR * Math.cos(arc.startAngle)\n const y2i = cy + innerR * Math.sin(arc.startAngle)\n const largeArc = (arc.endAngle - arc.startAngle) > Math.PI\n\n pb.moveTo(x1o, y1o)\n pb.arc(outerR, outerR, 0, largeArc, true, x2o, y2o)\n pb.lineTo(x1i, y1i)\n pb.arc(innerR, innerR, 0, largeArc, false, x2i, y2i)\n pb.close()\n\n nodes.push(path(pb.build(), {\n class: 'chartts-chord-arc',\n fill: color,\n stroke: color,\n strokeWidth: 0.5,\n 'data-series': arc.index,\n 'data-index': 0,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${arc.name}: ${arc.total}`,\n }))\n\n // Label\n const midAngle = (arc.startAngle + arc.endAngle) / 2\n const labelR = outerR + 12\n const lx = cx + labelR * Math.cos(midAngle)\n const ly = cy + labelR * Math.sin(midAngle)\n const anchor = Math.abs(Math.cos(midAngle)) < 0.01 ? 'middle' as const\n : Math.cos(midAngle) > 0 ? 'start' as const : 'end' as const\n\n nodes.push(text(lx, ly, arc.name, {\n class: 'chartts-chord-label',\n fill: theme.textColor,\n textAnchor: anchor,\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Render ribbons\n for (let ri = 0; ri < ribbons.length; ri++) {\n const ribbon = ribbons[ri]!\n const color = options.colors[ribbon.source % options.colors.length]!\n\n const pb = new PathBuilder()\n // Source arc on inner ring\n const sx1 = cx + innerR * Math.cos(ribbon.sourceStart)\n const sy1 = cy + innerR * Math.sin(ribbon.sourceStart)\n const sx2 = cx + innerR * Math.cos(ribbon.sourceEnd)\n const sy2 = cy + innerR * Math.sin(ribbon.sourceEnd)\n // Target arc on inner ring\n const tx1 = cx + innerR * Math.cos(ribbon.targetStart)\n const ty1 = cy + innerR * Math.sin(ribbon.targetStart)\n const tx2 = cx + innerR * Math.cos(ribbon.targetEnd)\n const ty2 = cy + innerR * Math.sin(ribbon.targetEnd)\n\n const srcLarge = (ribbon.sourceEnd - ribbon.sourceStart) > Math.PI\n const tgtLarge = (ribbon.targetEnd - ribbon.targetStart) > Math.PI\n\n pb.moveTo(sx1, sy1)\n pb.arc(innerR, innerR, 0, srcLarge, true, sx2, sy2)\n // Bezier to target\n pb.quadTo(cx, cy, tx1, ty1)\n pb.arc(innerR, innerR, 0, tgtLarge, true, tx2, ty2)\n // Bezier back to source\n pb.quadTo(cx, cy, sx1, sy1)\n pb.close()\n\n nodes.push(path(pb.build(), {\n class: 'chartts-chord-ribbon',\n fill: color,\n fillOpacity: 0.35,\n stroke: color,\n strokeWidth: 0.3,\n 'data-series': ribbon.source,\n 'data-index': ri,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${arcs[ribbon.source]!.name} → ${arcs[ribbon.target]!.name}: ${ribbon.value}`,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area, options } = ctx\n const { arcs } = buildChordLayout(data, options)\n if (arcs.length === 0) return null\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR - 14\n\n const dx = mx - cx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n // Check arc hits\n if (dist >= innerR && dist <= outerR) {\n let angle = Math.atan2(dy, dx)\n if (angle < -Math.PI / 2) angle += Math.PI * 2\n\n for (const arc of arcs) {\n if (angle >= arc.startAngle && angle <= arc.endAngle) {\n const midAngle = (arc.startAngle + arc.endAngle) / 2\n const midR = (innerR + outerR) / 2\n return { seriesIndex: arc.index, pointIndex: 0, distance: 0, x: cx + midR * Math.cos(midAngle), y: cy + midR * Math.sin(midAngle) }\n }\n }\n }\n\n return null\n },\n}\n\n// ---------------------------------------------------------------------------\n// Layout computation\n// ---------------------------------------------------------------------------\n\nfunction buildChordLayout(\n data: PreparedData,\n _options: ResolvedOptions,\n): { arcs: ChordArc[]; ribbons: ChordRibbon[]; matrix: number[][] } {\n const arcs: ChordArc[] = []\n const ribbons: ChordRibbon[] = []\n\n // Check for arrow notation\n const hasArrows = data.series.some(s => s.name.includes('→') || s.name.includes('->'))\n\n // Build adjacency matrix\n const nodeNames: string[] = []\n const nodeMap = new Map<string, number>()\n\n function getOrCreate(name: string): number {\n if (nodeMap.has(name)) return nodeMap.get(name)!\n const idx = nodeNames.length\n nodeMap.set(name, idx)\n nodeNames.push(name)\n return idx\n }\n\n if (hasArrows) {\n // Parse arrow notation\n for (const series of data.series) {\n const parts = series.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length < 2) continue\n getOrCreate(parts[0]!.trim())\n getOrCreate(parts[1]!.trim())\n }\n } else {\n for (let i = 0; i < data.labels.length; i++) {\n getOrCreate(String(data.labels[i]))\n }\n }\n\n const n = nodeNames.length\n if (n === 0) return { arcs, ribbons, matrix: [] }\n\n const matrix: number[][] = Array.from({ length: n }, () => new Array(n).fill(0))\n\n if (hasArrows) {\n for (const series of data.series) {\n const parts = series.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length < 2) continue\n const src = getOrCreate(parts[0]!.trim())\n const tgt = getOrCreate(parts[1]!.trim())\n const val = series.values[0] ?? 0\n if (val > 0) matrix[src]![tgt]! += val\n }\n } else {\n for (let si = 0; si < data.series.length && si < n; si++) {\n for (let j = 0; j < data.series[si]!.values.length && j < n; j++) {\n const val = data.series[si]!.values[j]!\n if (val > 0) matrix[si]![j]! = val\n }\n }\n }\n\n // Compute totals per node\n const totals = nodeNames.map((_, i) => {\n let total = 0\n for (let j = 0; j < n; j++) {\n total += matrix[i]![j]!\n total += matrix[j]![i]!\n }\n return total\n })\n\n const grandTotal = totals.reduce((s, t) => s + t, 0)\n if (grandTotal === 0) return { arcs, ribbons, matrix }\n\n // Layout arcs\n const padAngle = 0.04\n const totalPad = padAngle * n\n const available = Math.PI * 2 - totalPad\n\n let angle = -Math.PI / 2\n for (let i = 0; i < n; i++) {\n const span = (totals[i]! / grandTotal) * available\n arcs.push({\n index: i,\n name: nodeNames[i]!,\n total: totals[i]!,\n startAngle: angle,\n endAngle: angle + span,\n })\n angle += span + padAngle\n }\n\n // Layout ribbons — track offsets within each arc\n const arcOffsets = arcs.map(a => a.startAngle)\n\n for (let i = 0; i < n; i++) {\n for (let j = i; j < n; j++) {\n const val = matrix[i]![j]! + matrix[j]![i]!\n if (val <= 0) continue\n\n const srcSpan = (matrix[i]![j]! / Math.max(totals[i]!, 1)) * (arcs[i]!.endAngle - arcs[i]!.startAngle)\n const tgtSpan = (matrix[j]![i]! / Math.max(totals[j]!, 1)) * (arcs[j]!.endAngle - arcs[j]!.startAngle)\n\n ribbons.push({\n source: i,\n target: j,\n value: val,\n sourceStart: arcOffsets[i]!,\n sourceEnd: arcOffsets[i]! + srcSpan,\n targetStart: arcOffsets[j]!,\n targetEnd: arcOffsets[j]! + tgtSpan,\n })\n\n arcOffsets[i]! += srcSpan\n arcOffsets[j]! += tgtSpan\n }\n }\n\n return { arcs, ribbons, matrix }\n}\n"]}
@@ -2,7 +2,7 @@
2
2
 
3
3
  var chunkNHGKZMD7_cjs = require('./chunk-NHGKZMD7.cjs');
4
4
  var chunkLU35QDPN_cjs = require('./chunk-LU35QDPN.cjs');
5
- var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
5
+ var chunkW626EAS5_cjs = require('./chunk-W626EAS5.cjs');
6
6
 
7
7
  // src/charts/bar/stacked-bar-type.ts
8
8
  var stackedBarChartType = {
@@ -11,7 +11,7 @@ var stackedBarChartType = {
11
11
  return { x: "categorical", y: "linear" };
12
12
  },
13
13
  prepareData(data, options) {
14
- const prepared = chunkJVVGQLJQ_cjs.prepareData(data, options);
14
+ const prepared = chunkW626EAS5_cjs.prepareData(data, options);
15
15
  const pointCount = prepared.series[0]?.values.length ?? 0;
16
16
  let maxTotal = 0;
17
17
  let minTotal = 0;
@@ -59,7 +59,7 @@ var stackedBarChartType = {
59
59
  }
60
60
  const barFill = `url(#chartts-bar-${series.index})`;
61
61
  const r = Math.min(options.barRadius, barWidth / 2, h / 2);
62
- const barNode = r > 0 && h > r * 2 ? chunkJVVGQLJQ_cjs.path(
62
+ const barNode = r > 0 && h > r * 2 ? chunkW626EAS5_cjs.path(
63
63
  `M${chunkLU35QDPN_cjs.formatNum(barX)},${chunkLU35QDPN_cjs.formatNum(y + h)}V${chunkLU35QDPN_cjs.formatNum(y + r)}Q${chunkLU35QDPN_cjs.formatNum(barX)},${chunkLU35QDPN_cjs.formatNum(y)},${chunkLU35QDPN_cjs.formatNum(barX + r)},${chunkLU35QDPN_cjs.formatNum(y)}H${chunkLU35QDPN_cjs.formatNum(barX + barWidth - r)}Q${chunkLU35QDPN_cjs.formatNum(barX + barWidth)},${chunkLU35QDPN_cjs.formatNum(y)},${chunkLU35QDPN_cjs.formatNum(barX + barWidth)},${chunkLU35QDPN_cjs.formatNum(y + r)}V${chunkLU35QDPN_cjs.formatNum(y + h)}Z`,
64
64
  {
65
65
  class: "chartts-bar",
@@ -70,7 +70,7 @@ var stackedBarChartType = {
70
70
  role: "img",
71
71
  ariaLabel: `${series.name}: ${value}`
72
72
  }
73
- ) : chunkJVVGQLJQ_cjs.rect(barX, y, barWidth, h, {
73
+ ) : chunkW626EAS5_cjs.rect(barX, y, barWidth, h, {
74
74
  class: "chartts-bar",
75
75
  fill: barFill,
76
76
  "data-series": series.index,
@@ -79,7 +79,7 @@ var stackedBarChartType = {
79
79
  role: "img",
80
80
  ariaLabel: `${series.name}: ${value}`
81
81
  });
82
- nodes.push(chunkJVVGQLJQ_cjs.group([barNode], {
82
+ nodes.push(chunkW626EAS5_cjs.group([barNode], {
83
83
  class: `chartts-series chartts-series-${series.index}`,
84
84
  "data-series-name": series.name
85
85
  }));
@@ -124,5 +124,5 @@ var stackedBarChartType = {
124
124
  };
125
125
 
126
126
  exports.stackedBarChartType = stackedBarChartType;
127
- //# sourceMappingURL=chunk-DT4GG5BF.cjs.map
128
- //# sourceMappingURL=chunk-DT4GG5BF.cjs.map
127
+ //# sourceMappingURL=chunk-NRMQMPUE.cjs.map
128
+ //# sourceMappingURL=chunk-NRMQMPUE.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/bar/stacked-bar-type.ts"],"names":["prepareData","getBandwidth","path","formatNum","rect","group"],"mappings":"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","file":"chunk-DT4GG5BF.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, path } from '../../render/tree'\nimport { formatNum } from '../../utils/format'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Stacked bar chart — all series at the same x position are stacked vertically.\n */\nexport const stackedBarChartType: ChartTypePlugin = {\n type: 'stacked-bar',\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 // y-axis range should cover cumulative totals per x-index\n const pointCount = prepared.series[0]?.values.length ?? 0\n let maxTotal = 0\n let minTotal = 0\n\n for (let i = 0; i < pointCount; i++) {\n let posSum = 0\n let negSum = 0\n for (const s of prepared.series) {\n const v = s.values[i] ?? 0\n if (v >= 0) posSum += v\n else negSum += v\n }\n if (posSum > maxTotal) maxTotal = posSum\n if (negSum < minTotal) minTotal = negSum\n }\n\n if (options.yMin === undefined) prepared.bounds.yMin = Math.min(0, minTotal)\n if (options.yMax === undefined) prepared.bounds.yMax = Math.max(0, maxTotal)\n\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - options.barGap)\n const barOffset = -barWidth / 2\n const baseline = yScale.map(0)\n\n for (let i = 0; i < pointCount; i++) {\n let posY = baseline // tracks current top of positive stack\n let negY = baseline // tracks current bottom of negative stack\n\n for (const series of data.series) {\n const value = series.values[i] ?? 0\n if (value === 0) continue\n\n const cx = xScale.map(i)\n const barX = cx + barOffset\n const vy = yScale.map(Math.abs(value))\n const h = Math.abs(vy - baseline)\n\n let y: number\n if (value >= 0) {\n y = posY - h\n posY = y\n } else {\n y = negY\n negY = y + h\n }\n\n const barFill = `url(#chartts-bar-${series.index})`\n const r = Math.min(options.barRadius, barWidth / 2, h / 2)\n\n const barNode = (r > 0 && h > r * 2)\n ? path(\n `M${formatNum(barX)},${formatNum(y + h)}V${formatNum(y + r)}Q${formatNum(barX)},${formatNum(y)},${formatNum(barX + r)},${formatNum(y)}H${formatNum(barX + barWidth - r)}Q${formatNum(barX + barWidth)},${formatNum(y)},${formatNum(barX + barWidth)},${formatNum(y + r)}V${formatNum(y + h)}Z`,\n {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${value}`,\n },\n )\n : rect(barX, y, barWidth, h, {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${value}`,\n })\n\n // Wrap each series segment in its own group for hover isolation\n nodes.push(group([barNode], {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\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 const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return null\n\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - options.barGap)\n const barOffset = -barWidth / 2\n const baseline = yScale.map(0)\n\n for (let i = 0; i < pointCount; i++) {\n const cx = xScale.map(i)\n const barX = cx + barOffset\n\n if (mx < barX - 2 || mx > barX + barWidth + 2) continue\n\n let posY = baseline\n let negY = baseline\n\n for (const series of data.series) {\n const value = series.values[i] ?? 0\n if (value === 0) continue\n\n const vy = yScale.map(Math.abs(value))\n const h = Math.abs(vy - baseline)\n let y: number\n if (value >= 0) { y = posY - h; posY = y }\n else { y = negY; negY = y + h }\n\n if (my >= y - 2 && my <= y + h + 2) {\n return { seriesIndex: series.index, pointIndex: i, distance: 0, x: cx, y }\n }\n }\n }\n\n return null\n },\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/bar/stacked-bar-type.ts"],"names":["prepareData","getBandwidth","path","formatNum","rect","group"],"mappings":"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","file":"chunk-NRMQMPUE.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, path } from '../../render/tree'\nimport { formatNum } from '../../utils/format'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Stacked bar chart — all series at the same x position are stacked vertically.\n */\nexport const stackedBarChartType: ChartTypePlugin = {\n type: 'stacked-bar',\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 // y-axis range should cover cumulative totals per x-index\n const pointCount = prepared.series[0]?.values.length ?? 0\n let maxTotal = 0\n let minTotal = 0\n\n for (let i = 0; i < pointCount; i++) {\n let posSum = 0\n let negSum = 0\n for (const s of prepared.series) {\n const v = s.values[i] ?? 0\n if (v >= 0) posSum += v\n else negSum += v\n }\n if (posSum > maxTotal) maxTotal = posSum\n if (negSum < minTotal) minTotal = negSum\n }\n\n if (options.yMin === undefined) prepared.bounds.yMin = Math.min(0, minTotal)\n if (options.yMax === undefined) prepared.bounds.yMax = Math.max(0, maxTotal)\n\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - options.barGap)\n const barOffset = -barWidth / 2\n const baseline = yScale.map(0)\n\n for (let i = 0; i < pointCount; i++) {\n let posY = baseline // tracks current top of positive stack\n let negY = baseline // tracks current bottom of negative stack\n\n for (const series of data.series) {\n const value = series.values[i] ?? 0\n if (value === 0) continue\n\n const cx = xScale.map(i)\n const barX = cx + barOffset\n const vy = yScale.map(Math.abs(value))\n const h = Math.abs(vy - baseline)\n\n let y: number\n if (value >= 0) {\n y = posY - h\n posY = y\n } else {\n y = negY\n negY = y + h\n }\n\n const barFill = `url(#chartts-bar-${series.index})`\n const r = Math.min(options.barRadius, barWidth / 2, h / 2)\n\n const barNode = (r > 0 && h > r * 2)\n ? path(\n `M${formatNum(barX)},${formatNum(y + h)}V${formatNum(y + r)}Q${formatNum(barX)},${formatNum(y)},${formatNum(barX + r)},${formatNum(y)}H${formatNum(barX + barWidth - r)}Q${formatNum(barX + barWidth)},${formatNum(y)},${formatNum(barX + barWidth)},${formatNum(y + r)}V${formatNum(y + h)}Z`,\n {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${value}`,\n },\n )\n : rect(barX, y, barWidth, h, {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${value}`,\n })\n\n // Wrap each series segment in its own group for hover isolation\n nodes.push(group([barNode], {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\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 const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return null\n\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - options.barGap)\n const barOffset = -barWidth / 2\n const baseline = yScale.map(0)\n\n for (let i = 0; i < pointCount; i++) {\n const cx = xScale.map(i)\n const barX = cx + barOffset\n\n if (mx < barX - 2 || mx > barX + barWidth + 2) continue\n\n let posY = baseline\n let negY = baseline\n\n for (const series of data.series) {\n const value = series.values[i] ?? 0\n if (value === 0) continue\n\n const vy = yScale.map(Math.abs(value))\n const h = Math.abs(vy - baseline)\n let y: number\n if (value >= 0) { y = posY - h; posY = y }\n else { y = negY; negY = y + h }\n\n if (my >= y - 2 && my <= y + h + 2) {\n return { seriesIndex: series.index, pointIndex: i, distance: 0, x: cx, y }\n }\n }\n }\n\n return null\n },\n}\n"]}
@@ -1,5 +1,5 @@
1
- import { prepareNoAxes } from './chunk-T7SCCACB.js';
2
- import { rect, text, group } from './chunk-AEQXFDL7.js';
1
+ import { prepareNoAxes } from './chunk-LKSKGQX7.js';
2
+ import { rect, text, group } from './chunk-XIVC32HU.js';
3
3
 
4
4
  // src/charts/heatmap/heatmap-type.ts
5
5
  var heatmapChartType = {
@@ -145,5 +145,5 @@ function interpolateColor(baseColor, t) {
145
145
  }
146
146
 
147
147
  export { heatmapChartType };
148
- //# sourceMappingURL=chunk-FGBIJ6PL.js.map
149
- //# sourceMappingURL=chunk-FGBIJ6PL.js.map
148
+ //# sourceMappingURL=chunk-NW4JBVY2.js.map
149
+ //# sourceMappingURL=chunk-NW4JBVY2.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/charts/heatmap/heatmap-type.ts"],"names":[],"mappings":"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","file":"chunk-FGBIJ6PL.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, rect, text } from '../../render/tree'\n\n/**\n * Heatmap chart — displays a matrix of colored cells.\n *\n * Data format: each series is a row, each value is a cell.\n * Labels are column headers, series names are row headers.\n * Cell color intensity is proportional to value.\n */\nexport const heatmapChartType: ChartTypePlugin = {\n type: 'heatmap',\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 rowCount = data.series.length\n const colCount = data.labels.length\n if (rowCount === 0 || colCount === 0) return nodes\n\n // Find min/max values for color interpolation\n let vMin = Infinity\n let vMax = -Infinity\n for (const s of data.series) {\n for (const v of s.values) {\n if (v < vMin) vMin = v\n if (v > vMax) vMax = v\n }\n }\n if (vMin === vMax) vMax = vMin + 1\n\n // Layout: leave space for labels\n const labelW = Math.min(60, area.width * 0.15)\n const labelH = Math.min(24, area.height * 0.1)\n const gridX = area.x + labelW\n const gridY = area.y + labelH\n const gridW = area.width - labelW\n const gridH = area.height - labelH\n const cellW = gridW / colCount\n const cellH = gridH / rowCount\n const gap = 1.5\n\n // Column labels (top)\n for (let c = 0; c < colCount; c++) {\n const x = gridX + cellW * (c + 0.5)\n nodes.push(text(x, area.y + labelH * 0.5, String(data.labels[c]!), {\n class: 'chartts-heatmap-col-label',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, cellW * 0.35),\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Row labels (left) + cells\n for (let r = 0; r < rowCount; r++) {\n const series = data.series[r]!\n const ry = gridY + cellH * r\n\n // Row label\n nodes.push(text(area.x + labelW - 4, ry + cellH / 2, series.name, {\n class: 'chartts-heatmap-row-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, cellH * 0.45),\n fontFamily: theme.fontFamily,\n }))\n\n const cellNodes: RenderNode[] = []\n\n for (let c = 0; c < colCount; c++) {\n const value = series.values[c] ?? 0\n const t = (value - vMin) / (vMax - vMin)\n const color = interpolateColor(options.colors[0]!, t)\n\n cellNodes.push(rect(\n gridX + cellW * c + gap / 2,\n ry + gap / 2,\n cellW - gap,\n cellH - gap,\n {\n class: 'chartts-heatmap-cell',\n fill: color,\n rx: 4,\n ry: 2,\n 'data-series': r,\n 'data-index': c,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}, ${data.labels[c]}: ${value}`,\n },\n ))\n }\n\n nodes.push(group(cellNodes, {\n class: `chartts-series chartts-series-${r}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n getHighlightNodes(ctx: RenderContext, hit: HitResult): RenderNode[] {\n const { data, area, options } = ctx\n const rowCount = data.series.length\n const colCount = data.labels.length\n if (rowCount === 0 || colCount === 0) return []\n\n const labelW = Math.min(60, area.width * 0.15)\n const labelH = Math.min(24, area.height * 0.1)\n const gridX = area.x + labelW\n const gridY = area.y + labelH\n const gridW = area.width - labelW\n const gridH = area.height - labelH\n const cellW = gridW / colCount\n const cellH = gridH / rowCount\n\n const col = hit.pointIndex\n const row = hit.seriesIndex\n const color = options.colors[0] ?? '#3b82f6'\n\n return [\n rect(gridX + cellW * col, gridY + cellH * row, cellW, cellH, {\n class: 'chartts-highlight-cell',\n fill: 'none',\n stroke: color,\n strokeWidth: 2,\n }),\n ]\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const rowCount = data.series.length\n const colCount = data.labels.length\n if (rowCount === 0 || colCount === 0) return null\n\n const labelW = Math.min(60, area.width * 0.15)\n const labelH = Math.min(24, area.height * 0.1)\n const gridX = area.x + labelW\n const gridY = area.y + labelH\n const gridW = area.width - labelW\n const gridH = area.height - labelH\n const cellW = gridW / colCount\n const cellH = gridH / rowCount\n\n if (mx < gridX || mx > gridX + gridW || my < gridY || my > gridY + gridH) return null\n\n const col = Math.floor((mx - gridX) / cellW)\n const row = Math.floor((my - gridY) / cellH)\n\n if (row >= 0 && row < rowCount && col >= 0 && col < colCount) {\n return { seriesIndex: row, pointIndex: col, distance: 0, x: gridX + col * cellW + cellW / 2, y: gridY + row * cellH + cellH / 2 }\n }\n\n return null\n },\n}\n\n/** Interpolate from transparent to the given color based on t (0..1) */\nfunction interpolateColor(baseColor: string, t: number): string {\n // Extract hex fallback from var(--color-xxx, #hex) format\n const hexMatch = baseColor.match(/#([0-9a-fA-F]{6})/)\n if (!hexMatch) return `rgba(59, 130, 246, ${(0.1 + t * 0.9).toFixed(2)})`\n\n const hex = hexMatch[1]!\n const r = parseInt(hex.slice(0, 2), 16)\n const g = parseInt(hex.slice(2, 4), 16)\n const b = parseInt(hex.slice(4, 6), 16)\n\n const opacity = 0.1 + t * 0.9\n return `rgba(${r}, ${g}, ${b}, ${opacity.toFixed(2)})`\n}\n"]}
1
+ {"version":3,"sources":["../src/charts/heatmap/heatmap-type.ts"],"names":[],"mappings":"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","file":"chunk-NW4JBVY2.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, rect, text } from '../../render/tree'\n\n/**\n * Heatmap chart — displays a matrix of colored cells.\n *\n * Data format: each series is a row, each value is a cell.\n * Labels are column headers, series names are row headers.\n * Cell color intensity is proportional to value.\n */\nexport const heatmapChartType: ChartTypePlugin = {\n type: 'heatmap',\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 rowCount = data.series.length\n const colCount = data.labels.length\n if (rowCount === 0 || colCount === 0) return nodes\n\n // Find min/max values for color interpolation\n let vMin = Infinity\n let vMax = -Infinity\n for (const s of data.series) {\n for (const v of s.values) {\n if (v < vMin) vMin = v\n if (v > vMax) vMax = v\n }\n }\n if (vMin === vMax) vMax = vMin + 1\n\n // Layout: leave space for labels\n const labelW = Math.min(60, area.width * 0.15)\n const labelH = Math.min(24, area.height * 0.1)\n const gridX = area.x + labelW\n const gridY = area.y + labelH\n const gridW = area.width - labelW\n const gridH = area.height - labelH\n const cellW = gridW / colCount\n const cellH = gridH / rowCount\n const gap = 1.5\n\n // Column labels (top)\n for (let c = 0; c < colCount; c++) {\n const x = gridX + cellW * (c + 0.5)\n nodes.push(text(x, area.y + labelH * 0.5, String(data.labels[c]!), {\n class: 'chartts-heatmap-col-label',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, cellW * 0.35),\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Row labels (left) + cells\n for (let r = 0; r < rowCount; r++) {\n const series = data.series[r]!\n const ry = gridY + cellH * r\n\n // Row label\n nodes.push(text(area.x + labelW - 4, ry + cellH / 2, series.name, {\n class: 'chartts-heatmap-row-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, cellH * 0.45),\n fontFamily: theme.fontFamily,\n }))\n\n const cellNodes: RenderNode[] = []\n\n for (let c = 0; c < colCount; c++) {\n const value = series.values[c] ?? 0\n const t = (value - vMin) / (vMax - vMin)\n const color = interpolateColor(options.colors[0]!, t)\n\n cellNodes.push(rect(\n gridX + cellW * c + gap / 2,\n ry + gap / 2,\n cellW - gap,\n cellH - gap,\n {\n class: 'chartts-heatmap-cell',\n fill: color,\n rx: 4,\n ry: 2,\n 'data-series': r,\n 'data-index': c,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}, ${data.labels[c]}: ${value}`,\n },\n ))\n }\n\n nodes.push(group(cellNodes, {\n class: `chartts-series chartts-series-${r}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n getHighlightNodes(ctx: RenderContext, hit: HitResult): RenderNode[] {\n const { data, area, options } = ctx\n const rowCount = data.series.length\n const colCount = data.labels.length\n if (rowCount === 0 || colCount === 0) return []\n\n const labelW = Math.min(60, area.width * 0.15)\n const labelH = Math.min(24, area.height * 0.1)\n const gridX = area.x + labelW\n const gridY = area.y + labelH\n const gridW = area.width - labelW\n const gridH = area.height - labelH\n const cellW = gridW / colCount\n const cellH = gridH / rowCount\n\n const col = hit.pointIndex\n const row = hit.seriesIndex\n const color = options.colors[0] ?? '#3b82f6'\n\n return [\n rect(gridX + cellW * col, gridY + cellH * row, cellW, cellH, {\n class: 'chartts-highlight-cell',\n fill: 'none',\n stroke: color,\n strokeWidth: 2,\n }),\n ]\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const rowCount = data.series.length\n const colCount = data.labels.length\n if (rowCount === 0 || colCount === 0) return null\n\n const labelW = Math.min(60, area.width * 0.15)\n const labelH = Math.min(24, area.height * 0.1)\n const gridX = area.x + labelW\n const gridY = area.y + labelH\n const gridW = area.width - labelW\n const gridH = area.height - labelH\n const cellW = gridW / colCount\n const cellH = gridH / rowCount\n\n if (mx < gridX || mx > gridX + gridW || my < gridY || my > gridY + gridH) return null\n\n const col = Math.floor((mx - gridX) / cellW)\n const row = Math.floor((my - gridY) / cellH)\n\n if (row >= 0 && row < rowCount && col >= 0 && col < colCount) {\n return { seriesIndex: row, pointIndex: col, distance: 0, x: gridX + col * cellW + cellW / 2, y: gridY + row * cellH + cellH / 2 }\n }\n\n return null\n },\n}\n\n/** Interpolate from transparent to the given color based on t (0..1) */\nfunction interpolateColor(baseColor: string, t: number): string {\n // Extract hex fallback from var(--color-xxx, #hex) format\n const hexMatch = baseColor.match(/#([0-9a-fA-F]{6})/)\n if (!hexMatch) return `rgba(59, 130, 246, ${(0.1 + t * 0.9).toFixed(2)})`\n\n const hex = hexMatch[1]!\n const r = parseInt(hex.slice(0, 2), 16)\n const g = parseInt(hex.slice(2, 4), 16)\n const b = parseInt(hex.slice(4, 6), 16)\n\n const opacity = 0.1 + t * 0.9\n return `rgba(${r}, ${g}, ${b}, ${opacity.toFixed(2)})`\n}\n"]}