@chartts/core 0.1.3 → 0.1.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/area.cjs +10 -10
- package/dist/area.js +5 -5
- package/dist/bar.cjs +9 -9
- package/dist/bar.js +4 -4
- package/dist/baseline.cjs +9 -9
- package/dist/baseline.js +4 -4
- package/dist/boxplot.cjs +9 -9
- package/dist/boxplot.js +4 -4
- package/dist/bubble.cjs +9 -9
- package/dist/bubble.js +4 -4
- package/dist/bullet.cjs +10 -10
- package/dist/bullet.js +5 -5
- package/dist/calendar.cjs +10 -10
- package/dist/calendar.js +5 -5
- package/dist/candlestick.cjs +9 -9
- package/dist/candlestick.js +4 -4
- package/dist/chord.cjs +10 -10
- package/dist/chord.js +5 -5
- package/dist/{chunk-XKERO5K2.js → chunk-24557PYN.js} +3 -3
- package/dist/{chunk-XKERO5K2.js.map → chunk-24557PYN.js.map} +1 -1
- package/dist/{chunk-5YNIOIKK.js → chunk-2BUIZDOB.js} +3 -3
- package/dist/{chunk-5YNIOIKK.js.map → chunk-2BUIZDOB.js.map} +1 -1
- package/dist/{chunk-EHKHXQ46.cjs → chunk-2IMUTDTD.cjs} +10 -10
- package/dist/{chunk-EHKHXQ46.cjs.map → chunk-2IMUTDTD.cjs.map} +1 -1
- package/dist/{chunk-7ZPHLIFP.cjs → chunk-2IWLOBSF.cjs} +6 -6
- package/dist/{chunk-7ZPHLIFP.cjs.map → chunk-2IWLOBSF.cjs.map} +1 -1
- package/dist/{chunk-F5AOBHQY.js → chunk-2JYK52HV.js} +4 -4
- package/dist/{chunk-F5AOBHQY.js.map → chunk-2JYK52HV.js.map} +1 -1
- package/dist/{chunk-WVQVGQJO.cjs → chunk-2QRCHYTZ.cjs} +7 -7
- package/dist/{chunk-WVQVGQJO.cjs.map → chunk-2QRCHYTZ.cjs.map} +1 -1
- package/dist/{chunk-XWCY67K5.js → chunk-34DQGCPP.js} +4 -4
- package/dist/{chunk-XWCY67K5.js.map → chunk-34DQGCPP.js.map} +1 -1
- package/dist/{chunk-5J26EN5I.js → chunk-3JB4JBBK.js} +4 -4
- package/dist/{chunk-5J26EN5I.js.map → chunk-3JB4JBBK.js.map} +1 -1
- package/dist/{chunk-EHNX3MG3.cjs → chunk-3NHH6C4K.cjs} +13 -13
- package/dist/{chunk-EHNX3MG3.cjs.map → chunk-3NHH6C4K.cjs.map} +1 -1
- package/dist/{chunk-ECB3UPTC.cjs → chunk-3SVNEKXE.cjs} +11 -11
- package/dist/{chunk-ECB3UPTC.cjs.map → chunk-3SVNEKXE.cjs.map} +1 -1
- package/dist/{chunk-BYB3LQAT.cjs → chunk-4D6PVH2C.cjs} +9 -9
- package/dist/{chunk-BYB3LQAT.cjs.map → chunk-4D6PVH2C.cjs.map} +1 -1
- package/dist/{chunk-NG7DRWWT.cjs → chunk-4MNVJVK3.cjs} +6 -6
- package/dist/{chunk-NG7DRWWT.cjs.map → chunk-4MNVJVK3.cjs.map} +1 -1
- package/dist/{chunk-RQJRVKAH.js → chunk-4QRND2V5.js} +3 -3
- package/dist/{chunk-RQJRVKAH.js.map → chunk-4QRND2V5.js.map} +1 -1
- package/dist/{chunk-NGKUI7XE.cjs → chunk-55ZTXQQQ.cjs} +12 -12
- package/dist/{chunk-NGKUI7XE.cjs.map → chunk-55ZTXQQQ.cjs.map} +1 -1
- package/dist/{chunk-2MWA7H6J.js → chunk-56BN43J4.js} +5 -5
- package/dist/{chunk-2MWA7H6J.js.map → chunk-56BN43J4.js.map} +1 -1
- package/dist/{chunk-RJIPFWW7.js → chunk-5E7FXDBM.js} +4 -4
- package/dist/{chunk-RJIPFWW7.js.map → chunk-5E7FXDBM.js.map} +1 -1
- package/dist/{chunk-ILCWDAKD.js → chunk-5HZEDCJG.js} +3 -3
- package/dist/{chunk-ILCWDAKD.js.map → chunk-5HZEDCJG.js.map} +1 -1
- package/dist/{chunk-DKXW2FQC.cjs → chunk-5QT67VYJ.cjs} +10 -10
- package/dist/{chunk-DKXW2FQC.cjs.map → chunk-5QT67VYJ.cjs.map} +1 -1
- package/dist/{chunk-XE5ZYFGM.js → chunk-5QVUBGM7.js} +4 -4
- package/dist/{chunk-XE5ZYFGM.js.map → chunk-5QVUBGM7.js.map} +1 -1
- package/dist/{chunk-DR5MQC3W.js → chunk-62DBXI4N.js} +4 -4
- package/dist/{chunk-DR5MQC3W.js.map → chunk-62DBXI4N.js.map} +1 -1
- package/dist/{chunk-HMB2RIEE.js → chunk-6QMV75NT.js} +4 -4
- package/dist/{chunk-HMB2RIEE.js.map → chunk-6QMV75NT.js.map} +1 -1
- package/dist/{chunk-OUN3MWRQ.cjs → chunk-754Z4OR6.cjs} +10 -10
- package/dist/{chunk-OUN3MWRQ.cjs.map → chunk-754Z4OR6.cjs.map} +1 -1
- package/dist/{chunk-3SOKHPAO.js → chunk-7GLCJPV5.js} +4 -4
- package/dist/{chunk-3SOKHPAO.js.map → chunk-7GLCJPV5.js.map} +1 -1
- package/dist/{chunk-PQCHNZHM.cjs → chunk-7PHOSSLJ.cjs} +9 -9
- package/dist/{chunk-PQCHNZHM.cjs.map → chunk-7PHOSSLJ.cjs.map} +1 -1
- package/dist/{chunk-VBEZS3Q4.cjs → chunk-A5G32G2R.cjs} +9 -9
- package/dist/{chunk-VBEZS3Q4.cjs.map → chunk-A5G32G2R.cjs.map} +1 -1
- package/dist/{chunk-DX4FBN3I.js → chunk-AEQXFDL7.js} +14 -9
- package/dist/chunk-AEQXFDL7.js.map +1 -0
- package/dist/{chunk-RHTVKBRC.cjs → chunk-ATMSGQCW.cjs} +9 -9
- package/dist/{chunk-RHTVKBRC.cjs.map → chunk-ATMSGQCW.cjs.map} +1 -1
- package/dist/{chunk-2ITF366P.js → chunk-BFBVJ6MU.js} +3 -3
- package/dist/{chunk-2ITF366P.js.map → chunk-BFBVJ6MU.js.map} +1 -1
- package/dist/{chunk-E43H3A3G.cjs → chunk-BGGESAAG.cjs} +7 -7
- package/dist/{chunk-E43H3A3G.cjs.map → chunk-BGGESAAG.cjs.map} +1 -1
- package/dist/{chunk-R6ZDSXN7.cjs → chunk-CA42BCSM.cjs} +8 -8
- package/dist/{chunk-R6ZDSXN7.cjs.map → chunk-CA42BCSM.cjs.map} +1 -1
- package/dist/{chunk-FV7R2LLD.js → chunk-CU5ZXVZQ.js} +4 -4
- package/dist/{chunk-FV7R2LLD.js.map → chunk-CU5ZXVZQ.js.map} +1 -1
- package/dist/{chunk-JNQ4NL3R.cjs → chunk-CUIPBYMG.cjs} +8 -8
- package/dist/{chunk-JNQ4NL3R.cjs.map → chunk-CUIPBYMG.cjs.map} +1 -1
- package/dist/{chunk-CCMLOCTH.js → chunk-CWZADOJ6.js} +3 -3
- package/dist/{chunk-CCMLOCTH.js.map → chunk-CWZADOJ6.js.map} +1 -1
- package/dist/{chunk-FZIBM3G5.cjs → chunk-D5QUAWF3.cjs} +10 -10
- package/dist/{chunk-FZIBM3G5.cjs.map → chunk-D5QUAWF3.cjs.map} +1 -1
- package/dist/{chunk-YZQROIJY.js → chunk-DAAU5H24.js} +3 -3
- package/dist/{chunk-YZQROIJY.js.map → chunk-DAAU5H24.js.map} +1 -1
- package/dist/{chunk-GAWIUMAK.cjs → chunk-DT4GG5BF.cjs} +7 -7
- package/dist/{chunk-GAWIUMAK.cjs.map → chunk-DT4GG5BF.cjs.map} +1 -1
- package/dist/{chunk-4L62MAZA.js → chunk-DX77WSIB.js} +5 -5
- package/dist/{chunk-4L62MAZA.js.map → chunk-DX77WSIB.js.map} +1 -1
- package/dist/{chunk-4ORSJM2I.js → chunk-EPUWA3ZW.js} +4 -4
- package/dist/{chunk-4ORSJM2I.js.map → chunk-EPUWA3ZW.js.map} +1 -1
- package/dist/{chunk-ZTUKOCJN.cjs → chunk-ESJMEDLY.cjs} +4 -4
- package/dist/{chunk-ZTUKOCJN.cjs.map → chunk-ESJMEDLY.cjs.map} +1 -1
- package/dist/{chunk-6JNW43SE.js → chunk-EWVXMQRW.js} +5 -5
- package/dist/{chunk-6JNW43SE.js.map → chunk-EWVXMQRW.js.map} +1 -1
- package/dist/{chunk-LIY7MYRG.js → chunk-FGBIJ6PL.js} +4 -4
- package/dist/{chunk-LIY7MYRG.js.map → chunk-FGBIJ6PL.js.map} +1 -1
- package/dist/{chunk-OFEROCC5.cjs → chunk-FGHSUT6X.cjs} +6 -6
- package/dist/{chunk-OFEROCC5.cjs.map → chunk-FGHSUT6X.cjs.map} +1 -1
- package/dist/{chunk-QKJUAMRK.cjs → chunk-FVLVTY5D.cjs} +6 -6
- package/dist/{chunk-QKJUAMRK.cjs.map → chunk-FVLVTY5D.cjs.map} +1 -1
- package/dist/{chunk-YX6RW6ZW.cjs → chunk-GBL4R3GH.cjs} +6 -6
- package/dist/{chunk-YX6RW6ZW.cjs.map → chunk-GBL4R3GH.cjs.map} +1 -1
- package/dist/{chunk-SXVMEC6N.cjs → chunk-GRXHW5S3.cjs} +12 -12
- package/dist/{chunk-SXVMEC6N.cjs.map → chunk-GRXHW5S3.cjs.map} +1 -1
- package/dist/{chunk-K5TPJVOK.js → chunk-HCIBBUV5.js} +3 -3
- package/dist/{chunk-K5TPJVOK.js.map → chunk-HCIBBUV5.js.map} +1 -1
- package/dist/{chunk-HFWO37RY.cjs → chunk-HCK2VUWD.cjs} +8 -8
- package/dist/{chunk-HFWO37RY.cjs.map → chunk-HCK2VUWD.cjs.map} +1 -1
- package/dist/{chunk-FSDI3NJV.js → chunk-IDZTDJLH.js} +3 -3
- package/dist/{chunk-FSDI3NJV.js.map → chunk-IDZTDJLH.js.map} +1 -1
- package/dist/{chunk-FDNJNVKA.cjs → chunk-IF6RQ53Q.cjs} +9 -9
- package/dist/{chunk-FDNJNVKA.cjs.map → chunk-IF6RQ53Q.cjs.map} +1 -1
- package/dist/{chunk-PVPTFMJJ.js → chunk-IOV77VHP.js} +4 -4
- package/dist/{chunk-PVPTFMJJ.js.map → chunk-IOV77VHP.js.map} +1 -1
- package/dist/{chunk-UMIJYYF3.cjs → chunk-JVVGQLJQ.cjs} +14 -9
- package/dist/chunk-JVVGQLJQ.cjs.map +1 -0
- package/dist/{chunk-MY4KMVJ5.cjs → chunk-JYVRX3BX.cjs} +8 -8
- package/dist/{chunk-MY4KMVJ5.cjs.map → chunk-JYVRX3BX.cjs.map} +1 -1
- package/dist/{chunk-ZY7ETQD6.js → chunk-KHG3G2ZX.js} +3 -3
- package/dist/{chunk-ZY7ETQD6.js.map → chunk-KHG3G2ZX.js.map} +1 -1
- package/dist/{chunk-ASNAQ35U.js → chunk-KNMEXOKJ.js} +4 -4
- package/dist/{chunk-ASNAQ35U.js.map → chunk-KNMEXOKJ.js.map} +1 -1
- package/dist/{chunk-WYIIWTIR.cjs → chunk-KWSVJRXX.cjs} +4 -4
- package/dist/{chunk-WYIIWTIR.cjs.map → chunk-KWSVJRXX.cjs.map} +1 -1
- package/dist/{chunk-OAL5RS2X.cjs → chunk-LARNENXE.cjs} +10 -10
- package/dist/{chunk-OAL5RS2X.cjs.map → chunk-LARNENXE.cjs.map} +1 -1
- package/dist/{chunk-MYXLKVJE.js → chunk-LRHMLNPW.js} +12 -4
- package/dist/chunk-LRHMLNPW.js.map +1 -0
- package/dist/{chunk-66BHM3UN.cjs → chunk-LXYNL7BI.cjs} +10 -10
- package/dist/{chunk-66BHM3UN.cjs.map → chunk-LXYNL7BI.cjs.map} +1 -1
- package/dist/{chunk-V45C74EB.js → chunk-MEERXUZS.js} +4 -4
- package/dist/{chunk-V45C74EB.js.map → chunk-MEERXUZS.js.map} +1 -1
- package/dist/{chunk-YJHB2GHQ.js → chunk-MJY25P44.js} +3 -3
- package/dist/{chunk-YJHB2GHQ.js.map → chunk-MJY25P44.js.map} +1 -1
- package/dist/{chunk-6UWYKNFN.cjs → chunk-MSCRIA2U.cjs} +12 -12
- package/dist/{chunk-6UWYKNFN.cjs.map → chunk-MSCRIA2U.cjs.map} +1 -1
- package/dist/{chunk-UZH6PVHD.js → chunk-N35UAFEU.js} +4 -4
- package/dist/{chunk-UZH6PVHD.js.map → chunk-N35UAFEU.js.map} +1 -1
- package/dist/{chunk-6E6ZDWZD.cjs → chunk-NE2W2MF3.cjs} +10 -10
- package/dist/{chunk-6E6ZDWZD.cjs.map → chunk-NE2W2MF3.cjs.map} +1 -1
- package/dist/{chunk-7PNCJ4OQ.js → chunk-NQ7Y6ZKH.js} +3 -3
- package/dist/{chunk-7PNCJ4OQ.js.map → chunk-NQ7Y6ZKH.js.map} +1 -1
- package/dist/{chunk-LK2A3HBT.js → chunk-NRULNA5F.js} +4 -4
- package/dist/{chunk-LK2A3HBT.js.map → chunk-NRULNA5F.js.map} +1 -1
- package/dist/{chunk-47EP245Y.cjs → chunk-OEGSDOJ2.cjs} +7 -7
- package/dist/{chunk-47EP245Y.cjs.map → chunk-OEGSDOJ2.cjs.map} +1 -1
- package/dist/{chunk-ZFSFOD5W.cjs → chunk-OMAW52LY.cjs} +6 -6
- package/dist/{chunk-ZFSFOD5W.cjs.map → chunk-OMAW52LY.cjs.map} +1 -1
- package/dist/{chunk-YOLF5DYU.js → chunk-OMSHGBV3.js} +4 -4
- package/dist/{chunk-YOLF5DYU.js.map → chunk-OMSHGBV3.js.map} +1 -1
- package/dist/{chunk-4H2LGLGI.cjs → chunk-OTXHJHXU.cjs} +11 -11
- package/dist/{chunk-4H2LGLGI.cjs.map → chunk-OTXHJHXU.cjs.map} +1 -1
- package/dist/{chunk-DRIJNFWP.cjs → chunk-PCAYYCLY.cjs} +10 -10
- package/dist/{chunk-DRIJNFWP.cjs.map → chunk-PCAYYCLY.cjs.map} +1 -1
- package/dist/{chunk-QERWC7U6.js → chunk-PKXW45G4.js} +3 -3
- package/dist/{chunk-QERWC7U6.js.map → chunk-PKXW45G4.js.map} +1 -1
- package/dist/{chunk-YDQDZWZ7.cjs → chunk-QEPMEEZC.cjs} +6 -6
- package/dist/{chunk-YDQDZWZ7.cjs.map → chunk-QEPMEEZC.cjs.map} +1 -1
- package/dist/{chunk-G6R6MSRF.cjs → chunk-QPHUAF3R.cjs} +8 -8
- package/dist/{chunk-G6R6MSRF.cjs.map → chunk-QPHUAF3R.cjs.map} +1 -1
- package/dist/{chunk-RFEKSP62.js → chunk-QPHWRD25.js} +3 -3
- package/dist/{chunk-RFEKSP62.js.map → chunk-QPHWRD25.js.map} +1 -1
- package/dist/{chunk-XN6YS55F.cjs → chunk-QYI7ZV3B.cjs} +30 -22
- package/dist/chunk-QYI7ZV3B.cjs.map +1 -0
- package/dist/{chunk-3V64BDKG.cjs → chunk-R2W3RJFW.cjs} +13 -13
- package/dist/{chunk-3V64BDKG.cjs.map → chunk-R2W3RJFW.cjs.map} +1 -1
- package/dist/{chunk-46ZZTP5B.js → chunk-SGZUUUXU.js} +4 -4
- package/dist/{chunk-46ZZTP5B.js.map → chunk-SGZUUUXU.js.map} +1 -1
- package/dist/{chunk-MPQECPE3.js → chunk-T7SCCACB.js} +3 -3
- package/dist/{chunk-MPQECPE3.js.map → chunk-T7SCCACB.js.map} +1 -1
- package/dist/{chunk-GPSNBZPX.js → chunk-TC3H6ZED.js} +4 -4
- package/dist/{chunk-GPSNBZPX.js.map → chunk-TC3H6ZED.js.map} +1 -1
- package/dist/{chunk-AG7VY6MJ.cjs → chunk-TEZNWW3R.cjs} +8 -8
- package/dist/{chunk-AG7VY6MJ.cjs.map → chunk-TEZNWW3R.cjs.map} +1 -1
- package/dist/{chunk-KTCP23W6.js → chunk-THHZMRFU.js} +3 -3
- package/dist/{chunk-KTCP23W6.js.map → chunk-THHZMRFU.js.map} +1 -1
- package/dist/{chunk-RWQH5EO5.cjs → chunk-TLHQ6JCK.cjs} +11 -11
- package/dist/{chunk-RWQH5EO5.cjs.map → chunk-TLHQ6JCK.cjs.map} +1 -1
- package/dist/{chunk-CDS2NXGT.cjs → chunk-V5Q6UNUK.cjs} +4 -4
- package/dist/{chunk-CDS2NXGT.cjs.map → chunk-V5Q6UNUK.cjs.map} +1 -1
- package/dist/{chunk-BT5H3WMI.js → chunk-VBMLJUBE.js} +4 -4
- package/dist/{chunk-BT5H3WMI.js.map → chunk-VBMLJUBE.js.map} +1 -1
- package/dist/{chunk-UFMPALRH.js → chunk-VGJD4F4H.js} +3 -3
- package/dist/{chunk-UFMPALRH.js.map → chunk-VGJD4F4H.js.map} +1 -1
- package/dist/{chunk-RN7NNB6I.js → chunk-VJXUBN7J.js} +3 -3
- package/dist/{chunk-RN7NNB6I.js.map → chunk-VJXUBN7J.js.map} +1 -1
- package/dist/{chunk-TVDQNLGJ.js → chunk-VUHNBLFA.js} +3 -3
- package/dist/{chunk-TVDQNLGJ.js.map → chunk-VUHNBLFA.js.map} +1 -1
- package/dist/{chunk-OAIMES5S.cjs → chunk-W476ER4X.cjs} +17 -17
- package/dist/{chunk-OAIMES5S.cjs.map → chunk-W476ER4X.cjs.map} +1 -1
- package/dist/{chunk-4XVJYNOT.js → chunk-WZCES5M6.js} +4 -4
- package/dist/{chunk-4XVJYNOT.js.map → chunk-WZCES5M6.js.map} +1 -1
- package/dist/{chunk-2EZ2TVYT.cjs → chunk-Y6CVUI6A.cjs} +13 -13
- package/dist/{chunk-2EZ2TVYT.cjs.map → chunk-Y6CVUI6A.cjs.map} +1 -1
- package/dist/{chunk-4WQUX2B4.cjs → chunk-YCL43UQM.cjs} +12 -12
- package/dist/{chunk-4WQUX2B4.cjs.map → chunk-YCL43UQM.cjs.map} +1 -1
- package/dist/{chunk-XWN43PZF.cjs → chunk-YZXRD6K6.cjs} +7 -7
- package/dist/{chunk-XWN43PZF.cjs.map → chunk-YZXRD6K6.cjs.map} +1 -1
- package/dist/{chunk-IRUIWMH6.js → chunk-ZFGLBJYC.js} +3 -3
- package/dist/{chunk-IRUIWMH6.js.map → chunk-ZFGLBJYC.js.map} +1 -1
- package/dist/{chunk-6EGHZDZI.cjs → chunk-ZNKVOTPB.cjs} +15 -15
- package/dist/{chunk-6EGHZDZI.cjs.map → chunk-ZNKVOTPB.cjs.map} +1 -1
- package/dist/{chunk-WJP6CRML.js → chunk-ZOEN3ARN.js} +3 -3
- package/dist/{chunk-WJP6CRML.js.map → chunk-ZOEN3ARN.js.map} +1 -1
- package/dist/{chunk-TWSWD4PU.js → chunk-ZYXRRVR6.js} +3 -3
- package/dist/{chunk-TWSWD4PU.js.map → chunk-ZYXRRVR6.js.map} +1 -1
- package/dist/combo.cjs +9 -9
- package/dist/combo.js +4 -4
- package/dist/custom.cjs +10 -10
- package/dist/custom.js +5 -5
- package/dist/donut.cjs +11 -11
- package/dist/donut.js +6 -6
- package/dist/dumbbell.cjs +10 -10
- package/dist/dumbbell.js +5 -5
- package/dist/funnel.cjs +10 -10
- package/dist/funnel.js +5 -5
- package/dist/gauge.cjs +10 -10
- package/dist/gauge.js +5 -5
- package/dist/geo.cjs +12 -12
- package/dist/geo.js +5 -5
- package/dist/graph.cjs +10 -10
- package/dist/graph.js +5 -5
- package/dist/heatmap.cjs +10 -10
- package/dist/heatmap.js +5 -5
- package/dist/histogram.cjs +9 -9
- package/dist/histogram.js +4 -4
- package/dist/horizontal-bar.cjs +9 -9
- package/dist/horizontal-bar.js +4 -4
- package/dist/index.cjs +180 -180
- package/dist/index.d.cts +4 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.js +92 -92
- package/dist/kagi.cjs +10 -10
- package/dist/kagi.js +5 -5
- package/dist/line.cjs +9 -9
- package/dist/line.js +4 -4
- package/dist/lines.cjs +10 -10
- package/dist/lines.js +5 -5
- package/dist/lollipop.cjs +9 -9
- package/dist/lollipop.js +4 -4
- package/dist/matrix.cjs +10 -10
- package/dist/matrix.js +5 -5
- package/dist/ohlc.cjs +9 -9
- package/dist/ohlc.js +4 -4
- package/dist/parallel.cjs +10 -10
- package/dist/parallel.js +5 -5
- package/dist/pictorialbar.cjs +10 -10
- package/dist/pictorialbar.js +5 -5
- package/dist/pie.cjs +11 -11
- package/dist/pie.js +6 -6
- package/dist/polar.cjs +11 -11
- package/dist/polar.js +6 -6
- package/dist/radar.cjs +10 -10
- package/dist/radar.js +5 -5
- package/dist/radialbar.cjs +10 -10
- package/dist/radialbar.js +5 -5
- package/dist/range.cjs +9 -9
- package/dist/range.js +4 -4
- package/dist/renko.cjs +10 -10
- package/dist/renko.js +5 -5
- package/dist/sankey.cjs +10 -10
- package/dist/sankey.js +5 -5
- package/dist/scatter.cjs +9 -9
- package/dist/scatter.js +4 -4
- package/dist/sparkline.cjs +9 -9
- package/dist/sparkline.js +4 -4
- package/dist/stacked-bar.cjs +9 -9
- package/dist/stacked-bar.js +4 -4
- package/dist/step.cjs +10 -10
- package/dist/step.js +5 -5
- package/dist/sunburst.cjs +11 -11
- package/dist/sunburst.js +6 -6
- package/dist/themeriver.cjs +10 -10
- package/dist/themeriver.js +5 -5
- package/dist/tree.cjs +10 -10
- package/dist/tree.js +5 -5
- package/dist/treemap.cjs +10 -10
- package/dist/treemap.js +5 -5
- package/dist/volume.cjs +9 -9
- package/dist/volume.js +4 -4
- package/dist/waterfall.cjs +9 -9
- package/dist/waterfall.js +4 -4
- package/package.json +1 -1
- package/dist/chunk-DX4FBN3I.js.map +0 -1
- package/dist/chunk-MYXLKVJE.js.map +0 -1
- package/dist/chunk-UMIJYYF3.cjs.map +0 -1
- package/dist/chunk-XN6YS55F.cjs.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/combo/combo-type.ts"],"names":[],"mappings":"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","file":"chunk-5YNIOIKK.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect, path, circle } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\nimport { formatNum } from '../../utils/format'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Combo / Mixed chart — overlays bar + line on the same axes.\n *\n * Convention: series with `fill: true` or series at index 0 render as bars.\n * Remaining series render as lines with points.\n * Use the series `fill` flag to control: fill=false (or omitted after first) → line.\n *\n * Simple heuristic:\n * - series[0] → bars\n * - series[1..N] → lines\n */\nexport const comboChartType: ChartTypePlugin = {\n type: 'combo',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, options)\n if (options.yMin === undefined && prepared.bounds.yMin > 0) {\n prepared.bounds.yMin = 0\n }\n if (options.yMax === undefined && prepared.bounds.yMax < 0) {\n prepared.bounds.yMax = 0\n }\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n if (data.series.length === 0) return nodes\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n // Bars for series[0]\n const barSeries = data.series[0]!\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - options.barGap)\n const baseline = yScale.map(Math.max(0, yScale.getDomain()[0] as number))\n\n const barNodes: RenderNode[] = []\n for (let i = 0; i < barSeries.values.length; i++) {\n if (isNaN(barSeries.values[i]!)) continue // skip missing data\n const cx = xScale.map(i)\n const barX = cx - barWidth / 2\n const vy = yScale.map(barSeries.values[i]!)\n const isPositive = barSeries.values[i]! >= 0\n const y = isPositive ? vy : baseline\n const h = Math.abs(vy - baseline)\n\n const barFill = `url(#chartts-bar-${barSeries.index})`\n const r = Math.min(options.barRadius, barWidth / 2, h / 2)\n\n if (r > 0 && h > r * 2) {\n const d = isPositive\n ? `M${formatNum(barX)},${formatNum(y + h)}V${formatNum(y + r)}Q${formatNum(barX)},${formatNum(y)},${formatNum(barX + r)},${formatNum(y)}H${formatNum(barX + barWidth - r)}Q${formatNum(barX + barWidth)},${formatNum(y)},${formatNum(barX + barWidth)},${formatNum(y + r)}V${formatNum(y + h)}Z`\n : `M${formatNum(barX)},${formatNum(y)}V${formatNum(y + h - r)}Q${formatNum(barX)},${formatNum(y + h)},${formatNum(barX + r)},${formatNum(y + h)}H${formatNum(barX + barWidth - r)}Q${formatNum(barX + barWidth)},${formatNum(y + h)},${formatNum(barX + barWidth)},${formatNum(y + h - r)}V${formatNum(y)}Z`\n barNodes.push(path(d, {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': barSeries.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${barSeries.name}: ${barSeries.values[i]}`,\n }))\n } else {\n barNodes.push(rect(barX, y, barWidth, h, {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': barSeries.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${barSeries.name}: ${barSeries.values[i]}`,\n }))\n }\n }\n nodes.push(group(barNodes, {\n class: `chartts-series chartts-series-${barSeries.index}`,\n 'data-series-name': barSeries.name,\n }))\n\n // Lines for series[1..N]\n for (let si = 1; si < data.series.length; si++) {\n const series = data.series[si]!\n const color = options.colors[series.index % options.colors.length]!\n const lineNodes: RenderNode[] = []\n\n // Build line path\n const pb = new PathBuilder()\n let started = false\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) { started = false; continue } // break line at NaN\n const px = xScale.map(i)\n const py = yScale.map(series.values[i]!)\n if (!started) {\n pb.moveTo(px, py)\n started = true\n } else {\n pb.lineTo(px, py)\n }\n }\n\n lineNodes.push(path(pb.build(), {\n class: 'chartts-line chartts-combo-line',\n stroke: color,\n strokeWidth: 2,\n fill: 'none',\n }))\n\n // Points\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue // skip missing data\n const px = xScale.map(i)\n const py = yScale.map(series.values[i]!)\n lineNodes.push(circle(px, py, 4, {\n class: 'chartts-point chartts-combo-point',\n fill: color,\n stroke: '#fff',\n strokeWidth: 1.5,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\n }\n\n nodes.push(group(lineNodes, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale, options } = ctx\n if (data.series.length === 0) return null\n\n let best: HitResult | null = null\n let bestDist = Infinity\n\n // Check bar hits first (series[0])\n const barSeries = data.series[0]!\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - options.barGap)\n const baseline = yScale.map(Math.max(0, yScale.getDomain()[0] as number))\n\n for (let i = 0; i < barSeries.values.length; i++) {\n if (isNaN(barSeries.values[i]!)) continue\n const cx = xScale.map(i)\n const barX = cx - barWidth / 2\n const vy = yScale.map(barSeries.values[i]!)\n const y = barSeries.values[i]! >= 0 ? vy : baseline\n const h = Math.abs(vy - baseline)\n\n if (mx >= barX - 2 && mx <= barX + barWidth + 2 && my >= y - 2 && my <= y + h + 2) {\n best = { seriesIndex: barSeries.index, pointIndex: i, distance: 0, x: cx, y: vy }\n return best\n }\n }\n\n // Check line point hits (series[1..N])\n for (let si = 1; si < data.series.length; si++) {\n const series = data.series[si]!\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue\n const px = xScale.map(i)\n const py = yScale.map(series.values[i]!)\n const dx = mx - px\n const dy = my - py\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist < bestDist && dist < 20) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist, x: px, y: py }\n }\n }\n }\n\n return best\n },\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/charts/combo/combo-type.ts"],"names":[],"mappings":"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","file":"chunk-2BUIZDOB.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect, path, circle } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\nimport { formatNum } from '../../utils/format'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Combo / Mixed chart — overlays bar + line on the same axes.\n *\n * Convention: series with `fill: true` or series at index 0 render as bars.\n * Remaining series render as lines with points.\n * Use the series `fill` flag to control: fill=false (or omitted after first) → line.\n *\n * Simple heuristic:\n * - series[0] → bars\n * - series[1..N] → lines\n */\nexport const comboChartType: ChartTypePlugin = {\n type: 'combo',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, options)\n if (options.yMin === undefined && prepared.bounds.yMin > 0) {\n prepared.bounds.yMin = 0\n }\n if (options.yMax === undefined && prepared.bounds.yMax < 0) {\n prepared.bounds.yMax = 0\n }\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n if (data.series.length === 0) return nodes\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n // Bars for series[0]\n const barSeries = data.series[0]!\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - options.barGap)\n const baseline = yScale.map(Math.max(0, yScale.getDomain()[0] as number))\n\n const barNodes: RenderNode[] = []\n for (let i = 0; i < barSeries.values.length; i++) {\n if (isNaN(barSeries.values[i]!)) continue // skip missing data\n const cx = xScale.map(i)\n const barX = cx - barWidth / 2\n const vy = yScale.map(barSeries.values[i]!)\n const isPositive = barSeries.values[i]! >= 0\n const y = isPositive ? vy : baseline\n const h = Math.abs(vy - baseline)\n\n const barFill = `url(#chartts-bar-${barSeries.index})`\n const r = Math.min(options.barRadius, barWidth / 2, h / 2)\n\n if (r > 0 && h > r * 2) {\n const d = isPositive\n ? `M${formatNum(barX)},${formatNum(y + h)}V${formatNum(y + r)}Q${formatNum(barX)},${formatNum(y)},${formatNum(barX + r)},${formatNum(y)}H${formatNum(barX + barWidth - r)}Q${formatNum(barX + barWidth)},${formatNum(y)},${formatNum(barX + barWidth)},${formatNum(y + r)}V${formatNum(y + h)}Z`\n : `M${formatNum(barX)},${formatNum(y)}V${formatNum(y + h - r)}Q${formatNum(barX)},${formatNum(y + h)},${formatNum(barX + r)},${formatNum(y + h)}H${formatNum(barX + barWidth - r)}Q${formatNum(barX + barWidth)},${formatNum(y + h)},${formatNum(barX + barWidth)},${formatNum(y + h - r)}V${formatNum(y)}Z`\n barNodes.push(path(d, {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': barSeries.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${barSeries.name}: ${barSeries.values[i]}`,\n }))\n } else {\n barNodes.push(rect(barX, y, barWidth, h, {\n class: 'chartts-bar',\n fill: barFill,\n 'data-series': barSeries.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${barSeries.name}: ${barSeries.values[i]}`,\n }))\n }\n }\n nodes.push(group(barNodes, {\n class: `chartts-series chartts-series-${barSeries.index}`,\n 'data-series-name': barSeries.name,\n }))\n\n // Lines for series[1..N]\n for (let si = 1; si < data.series.length; si++) {\n const series = data.series[si]!\n const color = options.colors[series.index % options.colors.length]!\n const lineNodes: RenderNode[] = []\n\n // Build line path\n const pb = new PathBuilder()\n let started = false\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) { started = false; continue } // break line at NaN\n const px = xScale.map(i)\n const py = yScale.map(series.values[i]!)\n if (!started) {\n pb.moveTo(px, py)\n started = true\n } else {\n pb.lineTo(px, py)\n }\n }\n\n lineNodes.push(path(pb.build(), {\n class: 'chartts-line chartts-combo-line',\n stroke: color,\n strokeWidth: 2,\n fill: 'none',\n }))\n\n // Points\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue // skip missing data\n const px = xScale.map(i)\n const py = yScale.map(series.values[i]!)\n lineNodes.push(circle(px, py, 4, {\n class: 'chartts-point chartts-combo-point',\n fill: color,\n stroke: '#fff',\n strokeWidth: 1.5,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\n }\n\n nodes.push(group(lineNodes, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale, options } = ctx\n if (data.series.length === 0) return null\n\n let best: HitResult | null = null\n let bestDist = Infinity\n\n // Check bar hits first (series[0])\n const barSeries = data.series[0]!\n const bw = getBandwidth(xScale)\n const barWidth = bw * (1 - options.barGap)\n const baseline = yScale.map(Math.max(0, yScale.getDomain()[0] as number))\n\n for (let i = 0; i < barSeries.values.length; i++) {\n if (isNaN(barSeries.values[i]!)) continue\n const cx = xScale.map(i)\n const barX = cx - barWidth / 2\n const vy = yScale.map(barSeries.values[i]!)\n const y = barSeries.values[i]! >= 0 ? vy : baseline\n const h = Math.abs(vy - baseline)\n\n if (mx >= barX - 2 && mx <= barX + barWidth + 2 && my >= y - 2 && my <= y + h + 2) {\n best = { seriesIndex: barSeries.index, pointIndex: i, distance: 0, x: cx, y: vy }\n return best\n }\n }\n\n // Check line point hits (series[1..N])\n for (let si = 1; si < data.series.length; si++) {\n const series = data.series[si]!\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue\n const px = xScale.map(i)\n const py = yScale.map(series.values[i]!)\n const dx = mx - px\n const dy = my - py\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n if (dist < bestDist && dist < 20) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist, x: px, y: py }\n }\n }\n }\n\n return best\n },\n}\n"]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var
|
|
4
|
-
var
|
|
3
|
+
var chunkV5Q6UNUK_cjs = require('./chunk-V5Q6UNUK.cjs');
|
|
4
|
+
var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
|
|
5
5
|
|
|
6
6
|
// src/charts/tree/tree-type.ts
|
|
7
7
|
var treeChartType = {
|
|
@@ -10,7 +10,7 @@ var treeChartType = {
|
|
|
10
10
|
return { x: "categorical", y: "linear" };
|
|
11
11
|
},
|
|
12
12
|
prepareData(data, options) {
|
|
13
|
-
return
|
|
13
|
+
return chunkV5Q6UNUK_cjs.prepareNoAxes(data, options);
|
|
14
14
|
},
|
|
15
15
|
render(ctx) {
|
|
16
16
|
const { data, area, theme, options } = ctx;
|
|
@@ -40,7 +40,7 @@ var treeChartType = {
|
|
|
40
40
|
const renderTreeNode = (node) => {
|
|
41
41
|
const color = options.colors[node.depth % options.colors.length];
|
|
42
42
|
const nodeGroup = [];
|
|
43
|
-
nodeGroup.push(
|
|
43
|
+
nodeGroup.push(chunkJVVGQLJQ_cjs.circle(node.x, node.y, nodeRadius, {
|
|
44
44
|
class: "chartts-tree-node",
|
|
45
45
|
fill: color,
|
|
46
46
|
stroke: theme.background === "transparent" ? "#fff" : theme.background,
|
|
@@ -69,7 +69,7 @@ var treeChartType = {
|
|
|
69
69
|
anchor = "middle";
|
|
70
70
|
}
|
|
71
71
|
}
|
|
72
|
-
nodeGroup.push(
|
|
72
|
+
nodeGroup.push(chunkJVVGQLJQ_cjs.text(labelX, labelY, node.name, {
|
|
73
73
|
class: "chartts-tree-label",
|
|
74
74
|
fill: theme.textColor,
|
|
75
75
|
textAnchor: anchor,
|
|
@@ -78,7 +78,7 @@ var treeChartType = {
|
|
|
78
78
|
fontFamily: theme.fontFamily
|
|
79
79
|
}));
|
|
80
80
|
}
|
|
81
|
-
nodes.push(
|
|
81
|
+
nodes.push(chunkJVVGQLJQ_cjs.group(nodeGroup, {
|
|
82
82
|
class: `chartts-series chartts-series-${nodeIdx}`,
|
|
83
83
|
"data-series-name": node.name
|
|
84
84
|
}));
|
|
@@ -248,7 +248,7 @@ function layoutHorizontal(node, leftX, topY, bottomY, levelWidth) {
|
|
|
248
248
|
}
|
|
249
249
|
function renderEdges(node, nodes, theme, isHorizontal) {
|
|
250
250
|
for (const child of node.children) {
|
|
251
|
-
const pb = new
|
|
251
|
+
const pb = new chunkJVVGQLJQ_cjs.PathBuilder();
|
|
252
252
|
if (isHorizontal) {
|
|
253
253
|
const midX = (node.x + child.x) / 2;
|
|
254
254
|
pb.moveTo(node.x, node.y);
|
|
@@ -258,7 +258,7 @@ function renderEdges(node, nodes, theme, isHorizontal) {
|
|
|
258
258
|
pb.moveTo(node.x, node.y);
|
|
259
259
|
pb.curveTo(node.x, midY, child.x, midY, child.x, child.y);
|
|
260
260
|
}
|
|
261
|
-
nodes.push(
|
|
261
|
+
nodes.push(chunkJVVGQLJQ_cjs.path(pb.build(), {
|
|
262
262
|
class: "chartts-tree-edge",
|
|
263
263
|
stroke: theme.gridColor,
|
|
264
264
|
strokeWidth: 1.5,
|
|
@@ -269,5 +269,5 @@ function renderEdges(node, nodes, theme, isHorizontal) {
|
|
|
269
269
|
}
|
|
270
270
|
|
|
271
271
|
exports.treeChartType = treeChartType;
|
|
272
|
-
//# sourceMappingURL=chunk-
|
|
273
|
-
//# sourceMappingURL=chunk-
|
|
272
|
+
//# sourceMappingURL=chunk-2IMUTDTD.cjs.map
|
|
273
|
+
//# sourceMappingURL=chunk-2IMUTDTD.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/tree/tree-type.ts"],"names":["prepareNoAxes","circle","text","group","PathBuilder","path"],"mappings":"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","file":"chunk-EHKHXQ46.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, path, circle, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Tree chart — hierarchical node-link diagram.\n *\n * Data convention:\n * - labels: node names. Hierarchy encoded via \"Parent/Child/Grandchild\" separators.\n * - series[0].values: node values (sizes for circles, optional).\n *\n * Layout: top-to-bottom by default. Configurable via treeLayout option.\n */\n\ninterface TreeNode {\n name: string\n value: number\n children: TreeNode[]\n depth: number\n index: number\n // Computed during layout\n x: number\n y: number\n leafCount: number\n}\n\nexport interface TreeOptions {\n /** Layout direction. Default 'top-down'. */\n treeLayout?: 'top-down' | 'left-right' | 'radial'\n /** Node radius. Default 6. */\n nodeRadius?: number\n /** Show labels. Default true. */\n showLabels?: boolean\n}\n\nexport const treeChartType: ChartTypePlugin = {\n type: 'tree',\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 treeOpts = options as unknown as TreeOptions\n const layout = treeOpts.treeLayout ?? 'top-down'\n const nodeRadius = treeOpts.nodeRadius ?? 6\n const showLabels = treeOpts.showLabels ?? true\n\n // Build tree\n const root = buildTree(data.labels, series.values)\n if (!root) return nodes\n\n // Compute leaf counts for spacing\n computeLeafCounts(root)\n\n // Layout nodes\n const maxDepth = getMaxDepth(root)\n const isHorizontal = layout === 'left-right'\n\n if (isHorizontal) {\n const levelWidth = area.width / Math.max(maxDepth + 1, 1)\n layoutHorizontal(root, area.x, area.y, area.y + area.height, levelWidth)\n } else {\n const levelHeight = area.height / Math.max(maxDepth + 1, 1)\n layoutVertical(root, area.y, area.x, area.x + area.width, levelHeight)\n }\n\n // Render edges first (below nodes)\n const edgeNodes: RenderNode[] = []\n renderEdges(root, edgeNodes, theme, isHorizontal)\n nodes.push(...edgeNodes)\n\n // Render nodes\n let nodeIdx = 0\n const renderTreeNode = (node: TreeNode) => {\n const color = options.colors[node.depth % options.colors.length]!\n const nodeGroup: RenderNode[] = []\n\n nodeGroup.push(circle(node.x, node.y, nodeRadius, {\n class: 'chartts-tree-node',\n fill: color,\n stroke: theme.background === 'transparent' ? '#fff' : theme.background,\n strokeWidth: 1.5,\n 'data-series': 0,\n 'data-index': nodeIdx,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${node.name}: ${node.value}`,\n }))\n\n if (showLabels) {\n const fontSize = theme.fontSizeSmall\n let labelX: number, labelY: number\n let anchor: 'start' | 'middle' | 'end'\n\n if (isHorizontal) {\n labelX = node.x\n labelY = node.y - nodeRadius - 4\n anchor = 'middle'\n } else {\n labelX = node.x + nodeRadius + 4\n labelY = node.y\n anchor = 'start'\n // For root, put label above\n if (node.depth === 0) {\n labelX = node.x\n labelY = node.y - nodeRadius - 4\n anchor = 'middle'\n }\n }\n\n nodeGroup.push(text(labelX, labelY, node.name, {\n class: 'chartts-tree-label',\n fill: theme.textColor,\n textAnchor: anchor,\n dominantBaseline: 'central',\n fontSize,\n fontFamily: theme.fontFamily,\n }))\n }\n\n nodes.push(group(nodeGroup, {\n class: `chartts-series chartts-series-${nodeIdx}`,\n 'data-series-name': node.name,\n }))\n\n nodeIdx++\n for (const child of node.children) {\n renderTreeNode(child)\n }\n }\n\n renderTreeNode(root)\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area, options } = ctx\n const series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const treeOpts = options as unknown as TreeOptions\n const layout = treeOpts.treeLayout ?? 'top-down'\n const nodeRadius = treeOpts.nodeRadius ?? 6\n const hitRadius = nodeRadius + 5\n\n const root = buildTree(data.labels, series.values)\n if (!root) return null\n\n computeLeafCounts(root)\n const maxDepth = getMaxDepth(root)\n const isHorizontal = layout === 'left-right'\n\n if (isHorizontal) {\n const levelWidth = area.width / Math.max(maxDepth + 1, 1)\n layoutHorizontal(root, area.x, area.y, area.y + area.height, levelWidth)\n } else {\n const levelHeight = area.height / Math.max(maxDepth + 1, 1)\n layoutVertical(root, area.y, area.x, area.x + area.width, levelHeight)\n }\n\n let best: HitResult | null = null\n let bestDist = Infinity\n let idx = 0\n\n const checkNode = (node: TreeNode) => {\n const dist = Math.sqrt((mx - node.x) ** 2 + (my - node.y) ** 2)\n if (dist < bestDist && dist < hitRadius) {\n bestDist = dist\n best = { seriesIndex: 0, pointIndex: idx, distance: dist, x: node.x, y: node.y }\n }\n idx++\n for (const child of node.children) {\n checkNode(child)\n }\n }\n\n checkNode(root)\n return best\n },\n}\n\n// ---------------------------------------------------------------------------\n// Tree building\n// ---------------------------------------------------------------------------\n\nfunction buildTree(labels: (string | number | Date)[], values: number[]): TreeNode | null {\n const root: TreeNode = {\n name: 'Root', value: 0, children: [], depth: 0, index: 0,\n x: 0, y: 0, leafCount: 0,\n }\n\n // Check if labels use \"/\" separators for hierarchy\n const hasHierarchy = labels.some(l => String(l).includes('/'))\n\n if (hasHierarchy) {\n for (let i = 0; i < labels.length; i++) {\n const parts = String(labels[i] ?? '').split('/')\n const value = Math.abs(values[i] ?? 1)\n let current = root\n\n for (let p = 0; p < parts.length; p++) {\n const part = parts[p]!.trim()\n if (!part) continue\n\n let child = current.children.find(c => c.name === part)\n if (!child) {\n child = {\n name: part, value: 0, children: [], depth: current.depth + 1,\n index: i, x: 0, y: 0, leafCount: 0,\n }\n current.children.push(child)\n }\n if (p === parts.length - 1) {\n child.value = value\n }\n current = child\n }\n }\n } else {\n // Flat list — all labels are direct children of root\n root.name = String(labels[0] ?? 'Root')\n root.value = Math.abs(values[0] ?? 1)\n\n for (let i = 1; i < labels.length; i++) {\n root.children.push({\n name: String(labels[i] ?? `Node ${i}`),\n value: Math.abs(values[i] ?? 1),\n children: [],\n depth: 1,\n index: i,\n x: 0, y: 0, leafCount: 0,\n })\n }\n }\n\n if (root.children.length === 0 && labels.length > 0) {\n // Single node\n root.name = String(labels[0] ?? 'Root')\n root.value = Math.abs(values[0] ?? 1)\n }\n\n return root\n}\n\nfunction computeLeafCounts(node: TreeNode): number {\n if (node.children.length === 0) {\n node.leafCount = 1\n return 1\n }\n let count = 0\n for (const child of node.children) {\n count += computeLeafCounts(child)\n }\n node.leafCount = count\n return count\n}\n\nfunction getMaxDepth(node: TreeNode): number {\n if (node.children.length === 0) return node.depth\n let max = node.depth\n for (const child of node.children) {\n max = Math.max(max, getMaxDepth(child))\n }\n return max\n}\n\n// ---------------------------------------------------------------------------\n// Layout\n// ---------------------------------------------------------------------------\n\nfunction layoutVertical(\n node: TreeNode, topY: number, leftX: number, rightX: number, levelHeight: number,\n): void {\n node.y = topY + node.depth * levelHeight + levelHeight / 2\n const totalLeaves = node.leafCount || 1\n const slotWidth = (rightX - leftX) / totalLeaves\n\n if (node.children.length === 0) {\n node.x = leftX + slotWidth / 2\n return\n }\n\n let currentX = leftX\n for (const child of node.children) {\n const childWidth = (child.leafCount / totalLeaves) * (rightX - leftX)\n layoutVertical(child, topY, currentX, currentX + childWidth, levelHeight)\n currentX += childWidth\n }\n\n // Center parent above children\n const firstChild = node.children[0]!\n const lastChild = node.children[node.children.length - 1]!\n node.x = (firstChild.x + lastChild.x) / 2\n}\n\nfunction layoutHorizontal(\n node: TreeNode, leftX: number, topY: number, bottomY: number, levelWidth: number,\n): void {\n node.x = leftX + node.depth * levelWidth + levelWidth / 2\n const totalLeaves = node.leafCount || 1\n const slotHeight = (bottomY - topY) / totalLeaves\n\n if (node.children.length === 0) {\n node.y = topY + slotHeight / 2\n return\n }\n\n let currentY = topY\n for (const child of node.children) {\n const childHeight = (child.leafCount / totalLeaves) * (bottomY - topY)\n layoutHorizontal(child, leftX, currentY, currentY + childHeight, levelWidth)\n currentY += childHeight\n }\n\n const firstChild = node.children[0]!\n const lastChild = node.children[node.children.length - 1]!\n node.y = (firstChild.y + lastChild.y) / 2\n}\n\n// ---------------------------------------------------------------------------\n// Rendering edges\n// ---------------------------------------------------------------------------\n\nfunction renderEdges(\n node: TreeNode,\n nodes: RenderNode[],\n theme: RenderContext['theme'],\n isHorizontal: boolean,\n): void {\n for (const child of node.children) {\n const pb = new PathBuilder()\n if (isHorizontal) {\n const midX = (node.x + child.x) / 2\n pb.moveTo(node.x, node.y)\n pb.curveTo(midX, node.y, midX, child.y, child.x, child.y)\n } else {\n const midY = (node.y + child.y) / 2\n pb.moveTo(node.x, node.y)\n pb.curveTo(node.x, midY, child.x, midY, child.x, child.y)\n }\n\n nodes.push(path(pb.build(), {\n class: 'chartts-tree-edge',\n stroke: theme.gridColor,\n strokeWidth: 1.5,\n fill: 'none',\n }))\n\n renderEdges(child, nodes, theme, isHorizontal)\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/charts/tree/tree-type.ts"],"names":["prepareNoAxes","circle","text","group","PathBuilder","path"],"mappings":"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","file":"chunk-2IMUTDTD.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, path, circle, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Tree chart — hierarchical node-link diagram.\n *\n * Data convention:\n * - labels: node names. Hierarchy encoded via \"Parent/Child/Grandchild\" separators.\n * - series[0].values: node values (sizes for circles, optional).\n *\n * Layout: top-to-bottom by default. Configurable via treeLayout option.\n */\n\ninterface TreeNode {\n name: string\n value: number\n children: TreeNode[]\n depth: number\n index: number\n // Computed during layout\n x: number\n y: number\n leafCount: number\n}\n\nexport interface TreeOptions {\n /** Layout direction. Default 'top-down'. */\n treeLayout?: 'top-down' | 'left-right' | 'radial'\n /** Node radius. Default 6. */\n nodeRadius?: number\n /** Show labels. Default true. */\n showLabels?: boolean\n}\n\nexport const treeChartType: ChartTypePlugin = {\n type: 'tree',\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 treeOpts = options as unknown as TreeOptions\n const layout = treeOpts.treeLayout ?? 'top-down'\n const nodeRadius = treeOpts.nodeRadius ?? 6\n const showLabels = treeOpts.showLabels ?? true\n\n // Build tree\n const root = buildTree(data.labels, series.values)\n if (!root) return nodes\n\n // Compute leaf counts for spacing\n computeLeafCounts(root)\n\n // Layout nodes\n const maxDepth = getMaxDepth(root)\n const isHorizontal = layout === 'left-right'\n\n if (isHorizontal) {\n const levelWidth = area.width / Math.max(maxDepth + 1, 1)\n layoutHorizontal(root, area.x, area.y, area.y + area.height, levelWidth)\n } else {\n const levelHeight = area.height / Math.max(maxDepth + 1, 1)\n layoutVertical(root, area.y, area.x, area.x + area.width, levelHeight)\n }\n\n // Render edges first (below nodes)\n const edgeNodes: RenderNode[] = []\n renderEdges(root, edgeNodes, theme, isHorizontal)\n nodes.push(...edgeNodes)\n\n // Render nodes\n let nodeIdx = 0\n const renderTreeNode = (node: TreeNode) => {\n const color = options.colors[node.depth % options.colors.length]!\n const nodeGroup: RenderNode[] = []\n\n nodeGroup.push(circle(node.x, node.y, nodeRadius, {\n class: 'chartts-tree-node',\n fill: color,\n stroke: theme.background === 'transparent' ? '#fff' : theme.background,\n strokeWidth: 1.5,\n 'data-series': 0,\n 'data-index': nodeIdx,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${node.name}: ${node.value}`,\n }))\n\n if (showLabels) {\n const fontSize = theme.fontSizeSmall\n let labelX: number, labelY: number\n let anchor: 'start' | 'middle' | 'end'\n\n if (isHorizontal) {\n labelX = node.x\n labelY = node.y - nodeRadius - 4\n anchor = 'middle'\n } else {\n labelX = node.x + nodeRadius + 4\n labelY = node.y\n anchor = 'start'\n // For root, put label above\n if (node.depth === 0) {\n labelX = node.x\n labelY = node.y - nodeRadius - 4\n anchor = 'middle'\n }\n }\n\n nodeGroup.push(text(labelX, labelY, node.name, {\n class: 'chartts-tree-label',\n fill: theme.textColor,\n textAnchor: anchor,\n dominantBaseline: 'central',\n fontSize,\n fontFamily: theme.fontFamily,\n }))\n }\n\n nodes.push(group(nodeGroup, {\n class: `chartts-series chartts-series-${nodeIdx}`,\n 'data-series-name': node.name,\n }))\n\n nodeIdx++\n for (const child of node.children) {\n renderTreeNode(child)\n }\n }\n\n renderTreeNode(root)\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area, options } = ctx\n const series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const treeOpts = options as unknown as TreeOptions\n const layout = treeOpts.treeLayout ?? 'top-down'\n const nodeRadius = treeOpts.nodeRadius ?? 6\n const hitRadius = nodeRadius + 5\n\n const root = buildTree(data.labels, series.values)\n if (!root) return null\n\n computeLeafCounts(root)\n const maxDepth = getMaxDepth(root)\n const isHorizontal = layout === 'left-right'\n\n if (isHorizontal) {\n const levelWidth = area.width / Math.max(maxDepth + 1, 1)\n layoutHorizontal(root, area.x, area.y, area.y + area.height, levelWidth)\n } else {\n const levelHeight = area.height / Math.max(maxDepth + 1, 1)\n layoutVertical(root, area.y, area.x, area.x + area.width, levelHeight)\n }\n\n let best: HitResult | null = null\n let bestDist = Infinity\n let idx = 0\n\n const checkNode = (node: TreeNode) => {\n const dist = Math.sqrt((mx - node.x) ** 2 + (my - node.y) ** 2)\n if (dist < bestDist && dist < hitRadius) {\n bestDist = dist\n best = { seriesIndex: 0, pointIndex: idx, distance: dist, x: node.x, y: node.y }\n }\n idx++\n for (const child of node.children) {\n checkNode(child)\n }\n }\n\n checkNode(root)\n return best\n },\n}\n\n// ---------------------------------------------------------------------------\n// Tree building\n// ---------------------------------------------------------------------------\n\nfunction buildTree(labels: (string | number | Date)[], values: number[]): TreeNode | null {\n const root: TreeNode = {\n name: 'Root', value: 0, children: [], depth: 0, index: 0,\n x: 0, y: 0, leafCount: 0,\n }\n\n // Check if labels use \"/\" separators for hierarchy\n const hasHierarchy = labels.some(l => String(l).includes('/'))\n\n if (hasHierarchy) {\n for (let i = 0; i < labels.length; i++) {\n const parts = String(labels[i] ?? '').split('/')\n const value = Math.abs(values[i] ?? 1)\n let current = root\n\n for (let p = 0; p < parts.length; p++) {\n const part = parts[p]!.trim()\n if (!part) continue\n\n let child = current.children.find(c => c.name === part)\n if (!child) {\n child = {\n name: part, value: 0, children: [], depth: current.depth + 1,\n index: i, x: 0, y: 0, leafCount: 0,\n }\n current.children.push(child)\n }\n if (p === parts.length - 1) {\n child.value = value\n }\n current = child\n }\n }\n } else {\n // Flat list — all labels are direct children of root\n root.name = String(labels[0] ?? 'Root')\n root.value = Math.abs(values[0] ?? 1)\n\n for (let i = 1; i < labels.length; i++) {\n root.children.push({\n name: String(labels[i] ?? `Node ${i}`),\n value: Math.abs(values[i] ?? 1),\n children: [],\n depth: 1,\n index: i,\n x: 0, y: 0, leafCount: 0,\n })\n }\n }\n\n if (root.children.length === 0 && labels.length > 0) {\n // Single node\n root.name = String(labels[0] ?? 'Root')\n root.value = Math.abs(values[0] ?? 1)\n }\n\n return root\n}\n\nfunction computeLeafCounts(node: TreeNode): number {\n if (node.children.length === 0) {\n node.leafCount = 1\n return 1\n }\n let count = 0\n for (const child of node.children) {\n count += computeLeafCounts(child)\n }\n node.leafCount = count\n return count\n}\n\nfunction getMaxDepth(node: TreeNode): number {\n if (node.children.length === 0) return node.depth\n let max = node.depth\n for (const child of node.children) {\n max = Math.max(max, getMaxDepth(child))\n }\n return max\n}\n\n// ---------------------------------------------------------------------------\n// Layout\n// ---------------------------------------------------------------------------\n\nfunction layoutVertical(\n node: TreeNode, topY: number, leftX: number, rightX: number, levelHeight: number,\n): void {\n node.y = topY + node.depth * levelHeight + levelHeight / 2\n const totalLeaves = node.leafCount || 1\n const slotWidth = (rightX - leftX) / totalLeaves\n\n if (node.children.length === 0) {\n node.x = leftX + slotWidth / 2\n return\n }\n\n let currentX = leftX\n for (const child of node.children) {\n const childWidth = (child.leafCount / totalLeaves) * (rightX - leftX)\n layoutVertical(child, topY, currentX, currentX + childWidth, levelHeight)\n currentX += childWidth\n }\n\n // Center parent above children\n const firstChild = node.children[0]!\n const lastChild = node.children[node.children.length - 1]!\n node.x = (firstChild.x + lastChild.x) / 2\n}\n\nfunction layoutHorizontal(\n node: TreeNode, leftX: number, topY: number, bottomY: number, levelWidth: number,\n): void {\n node.x = leftX + node.depth * levelWidth + levelWidth / 2\n const totalLeaves = node.leafCount || 1\n const slotHeight = (bottomY - topY) / totalLeaves\n\n if (node.children.length === 0) {\n node.y = topY + slotHeight / 2\n return\n }\n\n let currentY = topY\n for (const child of node.children) {\n const childHeight = (child.leafCount / totalLeaves) * (bottomY - topY)\n layoutHorizontal(child, leftX, currentY, currentY + childHeight, levelWidth)\n currentY += childHeight\n }\n\n const firstChild = node.children[0]!\n const lastChild = node.children[node.children.length - 1]!\n node.y = (firstChild.y + lastChild.y) / 2\n}\n\n// ---------------------------------------------------------------------------\n// Rendering edges\n// ---------------------------------------------------------------------------\n\nfunction renderEdges(\n node: TreeNode,\n nodes: RenderNode[],\n theme: RenderContext['theme'],\n isHorizontal: boolean,\n): void {\n for (const child of node.children) {\n const pb = new PathBuilder()\n if (isHorizontal) {\n const midX = (node.x + child.x) / 2\n pb.moveTo(node.x, node.y)\n pb.curveTo(midX, node.y, midX, child.y, child.x, child.y)\n } else {\n const midY = (node.y + child.y) / 2\n pb.moveTo(node.x, node.y)\n pb.curveTo(node.x, midY, child.x, midY, child.x, child.y)\n }\n\n nodes.push(path(pb.build(), {\n class: 'chartts-tree-edge',\n stroke: theme.gridColor,\n strokeWidth: 1.5,\n fill: 'none',\n }))\n\n renderEdges(child, nodes, theme, isHorizontal)\n }\n}\n"]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var chunkNHGKZMD7_cjs = require('./chunk-NHGKZMD7.cjs');
|
|
4
|
-
var
|
|
4
|
+
var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
|
|
5
5
|
|
|
6
6
|
// src/charts/histogram/histogram-type.ts
|
|
7
7
|
var histogramChartType = {
|
|
@@ -10,7 +10,7 @@ var histogramChartType = {
|
|
|
10
10
|
return { x: "categorical", y: "linear" };
|
|
11
11
|
},
|
|
12
12
|
prepareData(data, options) {
|
|
13
|
-
const prepared =
|
|
13
|
+
const prepared = chunkJVVGQLJQ_cjs.prepareData(data, options);
|
|
14
14
|
if (options.yMin === void 0 && prepared.bounds.yMin > 0) {
|
|
15
15
|
prepared.bounds.yMin = 0;
|
|
16
16
|
}
|
|
@@ -35,7 +35,7 @@ var histogramChartType = {
|
|
|
35
35
|
if (h < 0.5) continue;
|
|
36
36
|
const colorIndex = i % options.colors.length;
|
|
37
37
|
const barFill = `url(#chartts-bar-${colorIndex})`;
|
|
38
|
-
barNodes.push(
|
|
38
|
+
barNodes.push(chunkJVVGQLJQ_cjs.rect(barX, y, barWidth, h, {
|
|
39
39
|
rx: 2,
|
|
40
40
|
ry: 2,
|
|
41
41
|
class: "chartts-bar chartts-histogram-bar",
|
|
@@ -49,7 +49,7 @@ var histogramChartType = {
|
|
|
49
49
|
ariaLabel: `${data.labels[i]}: ${value}`
|
|
50
50
|
}));
|
|
51
51
|
}
|
|
52
|
-
nodes.push(
|
|
52
|
+
nodes.push(chunkJVVGQLJQ_cjs.group(barNodes, {
|
|
53
53
|
class: "chartts-series chartts-series-0",
|
|
54
54
|
"data-series-name": series.name
|
|
55
55
|
}));
|
|
@@ -77,5 +77,5 @@ var histogramChartType = {
|
|
|
77
77
|
};
|
|
78
78
|
|
|
79
79
|
exports.histogramChartType = histogramChartType;
|
|
80
|
-
//# sourceMappingURL=chunk-
|
|
81
|
-
//# sourceMappingURL=chunk-
|
|
80
|
+
//# sourceMappingURL=chunk-2IWLOBSF.cjs.map
|
|
81
|
+
//# sourceMappingURL=chunk-2IWLOBSF.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/histogram/histogram-type.ts"],"names":["prepareData","getBandwidth","rect","group"],"mappings":"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","file":"chunk-
|
|
1
|
+
{"version":3,"sources":["../src/charts/histogram/histogram-type.ts"],"names":["prepareData","getBandwidth","rect","group"],"mappings":"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","file":"chunk-2IWLOBSF.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Histogram chart — bars touch each other (no gap), representing frequency distribution.\n *\n * Uses the same data format as bar chart. The key differences:\n * - Zero gap between bars\n * - Bars fill the full bandwidth\n * - Designed for continuous data ranges\n */\nexport const histogramChartType: ChartTypePlugin = {\n type: 'histogram',\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 series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n const bw = getBandwidth(xScale)\n // Histograms have no gap — bars touch\n const barWidth = bw\n const baseline = yScale.map(Math.max(0, yScale.getDomain()[0] as number))\n\n const barNodes: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const value = series.values[i]!\n const cx = xScale.map(i)\n const barX = cx - barWidth / 2\n const vy = yScale.map(value)\n\n const y = value >= 0 ? vy : baseline\n const h = Math.abs(vy - baseline)\n if (h < 0.5) continue\n\n const colorIndex = i % options.colors.length\n const barFill = `url(#chartts-bar-${colorIndex})`\n\n barNodes.push(rect(barX, y, barWidth, h, {\n rx: 2, ry: 2,\n class: 'chartts-bar chartts-histogram-bar',\n fill: barFill,\n stroke: series.color,\n strokeWidth: 0.5,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i]}: ${value}`,\n }))\n }\n\n nodes.push(group(barNodes, {\n class: 'chartts-series chartts-series-0',\n 'data-series-name': series.name,\n }))\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale } = ctx\n const series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const bw = getBandwidth(xScale)\n const barWidth = bw\n const baseline = yScale.map(Math.max(0, yScale.getDomain()[0] as number))\n\n for (let i = 0; i < series.values.length; i++) {\n const cx = xScale.map(i)\n const barX = cx - barWidth / 2\n const vy = yScale.map(series.values[i]!)\n const y = series.values[i]! >= 0 ? vy : baseline\n const h = Math.abs(vy - baseline)\n\n if (mx >= barX - 1 && mx <= barX + barWidth + 1 && my >= y - 2 && my <= y + h + 2) {\n return { seriesIndex: 0, pointIndex: i, distance: 0, x: cx, y: vy }\n }\n }\n\n return null\n },\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { prepareNoAxes } from './chunk-
|
|
2
|
-
import { path, PathBuilder, circle, text } from './chunk-
|
|
1
|
+
import { prepareNoAxes } from './chunk-T7SCCACB.js';
|
|
2
|
+
import { path, PathBuilder, circle, text } from './chunk-AEQXFDL7.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-
|
|
144
|
-
//# sourceMappingURL=chunk-
|
|
143
|
+
//# sourceMappingURL=chunk-2JYK52HV.js.map
|
|
144
|
+
//# sourceMappingURL=chunk-2JYK52HV.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/gauge/gauge-type.ts"],"names":[],"mappings":"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","file":"chunk-F5AOBHQY.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-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,7 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var
|
|
4
|
-
var
|
|
3
|
+
var chunkV5Q6UNUK_cjs = require('./chunk-V5Q6UNUK.cjs');
|
|
4
|
+
var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
|
|
5
5
|
|
|
6
6
|
// src/charts/renko/renko-type.ts
|
|
7
7
|
var renkoChartType = {
|
|
@@ -10,7 +10,7 @@ var renkoChartType = {
|
|
|
10
10
|
return { x: "categorical", y: "linear" };
|
|
11
11
|
},
|
|
12
12
|
prepareData(data, options) {
|
|
13
|
-
return
|
|
13
|
+
return chunkV5Q6UNUK_cjs.prepareNoAxes(data, options);
|
|
14
14
|
},
|
|
15
15
|
render(ctx) {
|
|
16
16
|
const { data, area, options } = ctx;
|
|
@@ -58,7 +58,7 @@ var renkoChartType = {
|
|
|
58
58
|
const x = xStart + i * (brickWidth + gap);
|
|
59
59
|
const yTop = mapY(Math.max(b.open, b.close));
|
|
60
60
|
const h = Math.max(brickPixelHeight, 3);
|
|
61
|
-
brickNodes.push(
|
|
61
|
+
brickNodes.push(chunkJVVGQLJQ_cjs.rect(x, yTop, brickWidth, h, {
|
|
62
62
|
rx: borderRadius,
|
|
63
63
|
ry: borderRadius,
|
|
64
64
|
class: "chartts-renko-brick",
|
|
@@ -73,7 +73,7 @@ var renkoChartType = {
|
|
|
73
73
|
ariaLabel: `Brick ${i + 1}: ${b.isUp ? "Up" : "Down"} ${b.open.toFixed(1)}\u2192${b.close.toFixed(1)}`
|
|
74
74
|
}));
|
|
75
75
|
}
|
|
76
|
-
nodes.push(
|
|
76
|
+
nodes.push(chunkJVVGQLJQ_cjs.group(brickNodes, {
|
|
77
77
|
class: "chartts-series chartts-series-0",
|
|
78
78
|
"data-series-name": series.name
|
|
79
79
|
}));
|
|
@@ -112,5 +112,5 @@ function computeRenkoBricks(values, brickSize) {
|
|
|
112
112
|
}
|
|
113
113
|
|
|
114
114
|
exports.renkoChartType = renkoChartType;
|
|
115
|
-
//# sourceMappingURL=chunk-
|
|
116
|
-
//# sourceMappingURL=chunk-
|
|
115
|
+
//# sourceMappingURL=chunk-2QRCHYTZ.cjs.map
|
|
116
|
+
//# sourceMappingURL=chunk-2QRCHYTZ.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/renko/renko-type.ts"],"names":["prepareNoAxes","rect","group"],"mappings":"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","file":"chunk-WVQVGQJO.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, rect } from '../../render/tree'\n\nexport interface RenkoOptions {\n /** Brick size in data units. Auto-calculated from ATR if omitted. */\n brickSize?: number\n /** Up brick color. Default green. */\n upColor?: string\n /** Down brick color. Default red. */\n downColor?: string\n /** Gap between bricks in pixels. Default 1. */\n gap?: number\n /** Corner radius for bricks. Default 2. */\n borderRadius?: number\n}\n\ninterface RenkoBrick {\n open: number\n close: number\n isUp: boolean\n}\n\n/**\n * Renko chart — brick-based reversal chart.\n *\n * Uniform bricks form only when price moves by the brick size.\n * Up bricks (green) for rising prices, down bricks (red) for falling.\n * Filters out noise and shows pure price action.\n */\nexport const renkoChartType: ChartTypePlugin = {\n type: 'renko',\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 } = 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 RenkoOptions\n const upColor = opts.upColor ?? 'var(--color-emerald-500, #10b981)'\n const downColor = opts.downColor ?? 'var(--color-red-500, #ef4444)'\n const gap = opts.gap ?? 1\n const borderRadius = opts.borderRadius ?? 2\n\n const values = series.values\n\n // Auto-calculate brick size: ATR-like approach (average absolute change)\n let brickSize = opts.brickSize\n if (!brickSize) {\n let totalChange = 0\n for (let i = 1; i < values.length; i++) {\n totalChange += Math.abs(values[i]! - values[i - 1]!)\n }\n const avgChange = totalChange / (values.length - 1)\n brickSize = Math.max(avgChange * 1.5, (Math.max(...values) - Math.min(...values)) / 20)\n }\n\n // Build bricks\n const bricks = computeRenkoBricks(values, brickSize)\n if (bricks.length === 0) return nodes\n\n // Find price range from bricks\n let minPrice = Infinity\n let maxPrice = -Infinity\n for (const b of bricks) {\n minPrice = Math.min(minPrice, b.open, b.close)\n maxPrice = Math.max(maxPrice, b.open, b.close)\n }\n const priceRange = maxPrice - minPrice || 1\n\n // Layout: each brick gets equal horizontal space\n const padding = 16\n const usableWidth = area.width - padding * 2\n const usableHeight = area.height - padding * 2\n const brickWidth = Math.min(\n (usableWidth - gap * (bricks.length - 1)) / bricks.length,\n 30,\n )\n\n const totalBrickWidth = bricks.length * brickWidth + (bricks.length - 1) * gap\n const xStart = area.x + (area.width - totalBrickWidth) / 2\n\n const mapY = (v: number) => area.y + padding + (1 - (v - minPrice) / priceRange) * usableHeight\n const brickPixelHeight = (brickSize / priceRange) * usableHeight\n\n const brickNodes: RenderNode[] = []\n\n for (let i = 0; i < bricks.length; i++) {\n const b = bricks[i]!\n const x = xStart + i * (brickWidth + gap)\n const yTop = mapY(Math.max(b.open, b.close))\n const h = Math.max(brickPixelHeight, 3)\n\n brickNodes.push(rect(x, yTop, brickWidth, h, {\n rx: borderRadius, ry: borderRadius,\n class: 'chartts-renko-brick',\n fill: b.isUp ? upColor : downColor,\n fillOpacity: b.isUp ? 0.9 : 0.9,\n stroke: b.isUp ? upColor : downColor,\n strokeWidth: 1,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `Brick ${i + 1}: ${b.isUp ? 'Up' : 'Down'} ${b.open.toFixed(1)}→${b.close.toFixed(1)}`,\n }))\n }\n\n nodes.push(group(brickNodes, {\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) return null\n\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 renko bricks from raw price data.\n */\nfunction computeRenkoBricks(values: number[], brickSize: number): RenkoBrick[] {\n const bricks: RenkoBrick[] = []\n if (values.length < 2 || brickSize <= 0) return bricks\n\n let currentPrice = Math.round(values[0]! / brickSize) * brickSize\n\n for (let i = 1; i < values.length; i++) {\n const v = values[i]!\n const diff = v - currentPrice\n\n if (Math.abs(diff) >= brickSize) {\n const numBricks = Math.floor(Math.abs(diff) / brickSize)\n const isUp = diff > 0\n\n for (let j = 0; j < numBricks; j++) {\n const open = currentPrice\n currentPrice += isUp ? brickSize : -brickSize\n bricks.push({ open, close: currentPrice, isUp })\n }\n }\n }\n\n return bricks\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/charts/renko/renko-type.ts"],"names":["prepareNoAxes","rect","group"],"mappings":"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","file":"chunk-2QRCHYTZ.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, rect } from '../../render/tree'\n\nexport interface RenkoOptions {\n /** Brick size in data units. Auto-calculated from ATR if omitted. */\n brickSize?: number\n /** Up brick color. Default green. */\n upColor?: string\n /** Down brick color. Default red. */\n downColor?: string\n /** Gap between bricks in pixels. Default 1. */\n gap?: number\n /** Corner radius for bricks. Default 2. */\n borderRadius?: number\n}\n\ninterface RenkoBrick {\n open: number\n close: number\n isUp: boolean\n}\n\n/**\n * Renko chart — brick-based reversal chart.\n *\n * Uniform bricks form only when price moves by the brick size.\n * Up bricks (green) for rising prices, down bricks (red) for falling.\n * Filters out noise and shows pure price action.\n */\nexport const renkoChartType: ChartTypePlugin = {\n type: 'renko',\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 } = 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 RenkoOptions\n const upColor = opts.upColor ?? 'var(--color-emerald-500, #10b981)'\n const downColor = opts.downColor ?? 'var(--color-red-500, #ef4444)'\n const gap = opts.gap ?? 1\n const borderRadius = opts.borderRadius ?? 2\n\n const values = series.values\n\n // Auto-calculate brick size: ATR-like approach (average absolute change)\n let brickSize = opts.brickSize\n if (!brickSize) {\n let totalChange = 0\n for (let i = 1; i < values.length; i++) {\n totalChange += Math.abs(values[i]! - values[i - 1]!)\n }\n const avgChange = totalChange / (values.length - 1)\n brickSize = Math.max(avgChange * 1.5, (Math.max(...values) - Math.min(...values)) / 20)\n }\n\n // Build bricks\n const bricks = computeRenkoBricks(values, brickSize)\n if (bricks.length === 0) return nodes\n\n // Find price range from bricks\n let minPrice = Infinity\n let maxPrice = -Infinity\n for (const b of bricks) {\n minPrice = Math.min(minPrice, b.open, b.close)\n maxPrice = Math.max(maxPrice, b.open, b.close)\n }\n const priceRange = maxPrice - minPrice || 1\n\n // Layout: each brick gets equal horizontal space\n const padding = 16\n const usableWidth = area.width - padding * 2\n const usableHeight = area.height - padding * 2\n const brickWidth = Math.min(\n (usableWidth - gap * (bricks.length - 1)) / bricks.length,\n 30,\n )\n\n const totalBrickWidth = bricks.length * brickWidth + (bricks.length - 1) * gap\n const xStart = area.x + (area.width - totalBrickWidth) / 2\n\n const mapY = (v: number) => area.y + padding + (1 - (v - minPrice) / priceRange) * usableHeight\n const brickPixelHeight = (brickSize / priceRange) * usableHeight\n\n const brickNodes: RenderNode[] = []\n\n for (let i = 0; i < bricks.length; i++) {\n const b = bricks[i]!\n const x = xStart + i * (brickWidth + gap)\n const yTop = mapY(Math.max(b.open, b.close))\n const h = Math.max(brickPixelHeight, 3)\n\n brickNodes.push(rect(x, yTop, brickWidth, h, {\n rx: borderRadius, ry: borderRadius,\n class: 'chartts-renko-brick',\n fill: b.isUp ? upColor : downColor,\n fillOpacity: b.isUp ? 0.9 : 0.9,\n stroke: b.isUp ? upColor : downColor,\n strokeWidth: 1,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `Brick ${i + 1}: ${b.isUp ? 'Up' : 'Down'} ${b.open.toFixed(1)}→${b.close.toFixed(1)}`,\n }))\n }\n\n nodes.push(group(brickNodes, {\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) return null\n\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 renko bricks from raw price data.\n */\nfunction computeRenkoBricks(values: number[], brickSize: number): RenkoBrick[] {\n const bricks: RenkoBrick[] = []\n if (values.length < 2 || brickSize <= 0) return bricks\n\n let currentPrice = Math.round(values[0]! / brickSize) * brickSize\n\n for (let i = 1; i < values.length; i++) {\n const v = values[i]!\n const diff = v - currentPrice\n\n if (Math.abs(diff) >= brickSize) {\n const numBricks = Math.floor(Math.abs(diff) / brickSize)\n const isUp = diff > 0\n\n for (let j = 0; j < numBricks; j++) {\n const open = currentPrice\n currentPrice += isUp ? brickSize : -brickSize\n bricks.push({ open, close: currentPrice, isUp })\n }\n }\n }\n\n return bricks\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { prepareNoAxes } from './chunk-
|
|
2
|
-
import { PathBuilder, path, circle, text, group } from './chunk-
|
|
1
|
+
import { prepareNoAxes } from './chunk-T7SCCACB.js';
|
|
2
|
+
import { PathBuilder, path, circle, text, group } from './chunk-AEQXFDL7.js';
|
|
3
3
|
|
|
4
4
|
// src/charts/tree/tree-type.ts
|
|
5
5
|
var treeChartType = {
|
|
@@ -267,5 +267,5 @@ function renderEdges(node, nodes, theme, isHorizontal) {
|
|
|
267
267
|
}
|
|
268
268
|
|
|
269
269
|
export { treeChartType };
|
|
270
|
-
//# sourceMappingURL=chunk-
|
|
271
|
-
//# sourceMappingURL=chunk-
|
|
270
|
+
//# sourceMappingURL=chunk-34DQGCPP.js.map
|
|
271
|
+
//# sourceMappingURL=chunk-34DQGCPP.js.map
|