@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/bullet/bullet-type.ts"],"names":[],"mappings":";;;;AAiBO,IAAM,eAAA,GAAmC;AAAA,EAC9C,IAAA,EAAM,QAAA;AAAA,EAEN,aAAA,GAAgD;AAC9C,IAAA,OAAO,EAAE,CAAA,EAAG,aAAA,EAAe,CAAA,EAAG,QAAA,EAAS;AAAA,EACzC,CAAA;AAAA,EAEA,WAAA,CAAY,MAAiB,OAAA,EAAwC;AACnE,IAAA,OAAO,aAAA,CAAc,MAAM,OAAO,CAAA;AAAA,EACpC,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,MAAM,EAAE,IAAA,EAAM,IAAA,EAAM,KAAA,EAAO,SAAQ,GAAI,GAAA;AACvC,IAAA,MAAM,QAAsB,EAAC;AAE7B,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA;AAC5B,IAAA,IAAI,CAAC,MAAA,IAAU,MAAA,CAAO,MAAA,CAAO,MAAA,KAAW,GAAG,OAAO,KAAA;AAElD,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA;AAC5B,IAAA,MAAM,KAAA,GAAQ,OAAO,MAAA,CAAO,MAAA;AAC5B,IAAA,MAAM,aAAa,IAAA,CAAK,GAAA,CAAI,EAAA,EAAI,IAAA,CAAK,QAAQ,GAAG,CAAA;AAChD,IAAA,MAAM,MAAA,GAAS,KAAK,CAAA,GAAI,UAAA;AACxB,IAAA,MAAM,MAAA,GAAS,KAAK,KAAA,GAAQ,UAAA;AAE5B,IAAA,MAAM,SAAA,GAAY,KAAK,MAAA,GAAS,KAAA;AAChC,IAAA,MAAM,SAAA,GAAY,IAAA,CAAK,GAAA,CAAI,SAAA,GAAY,KAAK,EAAE,CAAA;AAC9C,IAAA,MAAM,WAAA,GAAc,IAAA,CAAK,GAAA,CAAI,SAAA,GAAY,KAAK,EAAE,CAAA;AAGhD,IAAA,IAAI,MAAA,GAAS,CAAA;AACb,IAAA,KAAA,MAAW,CAAA,IAAK,OAAO,MAAA,EAAQ;AAC7B,MAAA,IAAI,IAAA,CAAK,IAAI,CAAC,CAAA,GAAI,QAAQ,MAAA,GAAS,IAAA,CAAK,IAAI,CAAC,CAAA;AAAA,IAC/C;AACA,IAAA,IAAI,MAAA,EAAQ;AACV,MAAA,KAAA,MAAW,CAAA,IAAK,OAAO,MAAA,EAAQ;AAC7B,QAAA,IAAI,IAAA,CAAK,IAAI,CAAC,CAAA,GAAI,QAAQ,MAAA,GAAS,IAAA,CAAK,IAAI,CAAC,CAAA;AAAA,MAC/C;AAAA,IACF;AAEA,IAAA,MAAA,GAAS,MAAA,GAAS,GAAA;AAClB,IAAA,IAAI,MAAA,KAAW,GAAG,MAAA,GAAS,CAAA;AAE3B,IAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,KAAA,EAAO,CAAA,EAAA,EAAK;AAC9B,MAAA,MAAM,EAAA,GAAK,IAAA,CAAK,CAAA,GAAI,SAAA,IAAa,CAAA,GAAI,GAAA,CAAA;AACrC,MAAA,MAAM,GAAA,GAAM,MAAA,CAAO,MAAA,CAAO,CAAC,CAAA;AAC3B,MAAA,MAAM,KAAA,GAAQ,OAAO,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA,IAAK,CAAA,KAAA,EAAQ,CAAA,GAAI,CAAC,CAAA,CAAE,CAAA;AACtD,MAAA,MAAM,QAAQ,OAAA,CAAQ,MAAA,CAAO,CAAA,GAAI,OAAA,CAAQ,OAAO,MAAM,CAAA;AACtD,MAAA,MAAM,cAA4B,EAAC;AAGnC,MAAA,WAAA,CAAY,KAAK,IAAA,CAAK,IAAA,CAAK,IAAI,UAAA,GAAa,CAAA,EAAG,IAAI,KAAA,EAAO;AAAA,QACxD,KAAA,EAAO,sBAAA;AAAA,QACP,MAAM,KAAA,CAAM,SAAA;AAAA,QACZ,UAAA,EAAY,KAAA;AAAA,QACZ,gBAAA,EAAkB,SAAA;AAAA,QAClB,UAAU,KAAA,CAAM,aAAA;AAAA,QAChB,YAAY,KAAA,CAAM;AAAA,OACnB,CAAC,CAAA;AAGF,MAAA,MAAM,KAAA,GAAQ,CAAC,CAAA,EAAK,IAAA,EAAM,GAAG,CAAA;AAC7B,MAAA,MAAM,SAAA,GAAY,CAAC,GAAA,EAAK,IAAA,EAAM,IAAI,CAAA;AAClC,MAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,KAAA,CAAM,QAAQ,CAAA,EAAA,EAAK;AACrC,QAAA,MAAM,EAAA,GAAK,MAAA,GAAS,KAAA,CAAM,CAAC,CAAA;AAC3B,QAAA,WAAA,CAAY,KAAK,IAAA,CAAK,MAAA,EAAQ,KAAK,WAAA,GAAc,CAAA,EAAG,IAAI,WAAA,EAAa;AAAA,UACnE,EAAA,EAAI,CAAA;AAAA,UAAG,EAAA,EAAI,CAAA;AAAA,UACX,KAAA,EAAO,sBAAA;AAAA,UACP,MAAM,KAAA,CAAM,SAAA;AAAA,UACZ,OAAA,EAAS,UAAU,CAAC;AAAA,SACrB,CAAC,CAAA;AAAA,MACJ;AAGA,MAAA,MAAM,IAAA,GAAQ,IAAA,CAAK,GAAA,CAAI,GAAG,IAAI,MAAA,GAAU,MAAA;AACxC,MAAA,WAAA,CAAY,KAAK,IAAA,CAAK,MAAA,EAAQ,KAAK,SAAA,GAAY,CAAA,EAAG,MAAM,SAAA,EAAW;AAAA,QACjE,EAAA,EAAI,CAAA;AAAA,QAAG,EAAA,EAAI,CAAA;AAAA,QACX,KAAA,EAAO,oBAAA;AAAA,QACP,IAAA,EAAM,KAAA;AAAA,QACN,aAAA,EAAe,CAAA;AAAA,QACf,YAAA,EAAc,CAAA;AAAA,QACd,QAAA,EAAU,CAAA;AAAA,QACV,IAAA,EAAM,KAAA;AAAA,QACN,SAAA,EAAW,CAAA,EAAG,KAAK,CAAA,EAAA,EAAK,GAAG,CAAA,EAAG,MAAA,GAAS,CAAA,UAAA,EAAa,MAAA,CAAO,MAAA,CAAO,CAAC,CAAC,KAAK,EAAE,CAAA;AAAA,OAC5E,CAAC,CAAA;AAGF,MAAA,IAAI,MAAA,IAAU,MAAA,CAAO,MAAA,CAAO,CAAC,KAAK,IAAA,EAAM;AACtC,QAAA,MAAM,EAAA,GAAK,SAAU,IAAA,CAAK,GAAA,CAAI,OAAO,MAAA,CAAO,CAAC,CAAE,CAAA,GAAI,MAAA,GAAU,MAAA;AAC7D,QAAA,MAAM,UAAU,WAAA,GAAc,GAAA;AAC9B,QAAA,WAAA,CAAY,IAAA,CAAK,KAAK,EAAA,EAAI,EAAA,GAAK,UAAU,CAAA,EAAG,EAAA,EAAI,EAAA,GAAK,OAAA,GAAU,CAAA,EAAG;AAAA,UAChE,KAAA,EAAO,uBAAA;AAAA,UACP,QAAQ,KAAA,CAAM,SAAA;AAAA,UACd,WAAA,EAAa;AAAA,SACd,CAAC,CAAA;AAAA,MACJ;AAEA,MAAA,KAAA,CAAM,IAAA,CAAK,MAAM,WAAA,EAAa;AAAA,QAC5B,KAAA,EAAO,iCAAiC,CAAC,CAAA,CAAA;AAAA,QACzC,kBAAA,EAAoB;AAAA,OACrB,CAAC,CAAA;AAAA,IACJ;AAEA,IAAA,OAAO,KAAA;AAAA,EACT,CAAA;AAAA,EAEA,OAAA,CAAQ,GAAA,EAAoB,EAAA,EAAY,EAAA,EAA8B;AACpE,IAAA,MAAM,EAAE,IAAA,EAAM,IAAA,EAAK,GAAI,GAAA;AACvB,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA;AAC5B,IAAA,IAAI,CAAC,MAAA,IAAU,MAAA,CAAO,MAAA,CAAO,MAAA,KAAW,GAAG,OAAO,IAAA;AAElD,IAAA,MAAM,KAAA,GAAQ,OAAO,MAAA,CAAO,MAAA;AAC5B,IAAA,MAAM,aAAa,IAAA,CAAK,GAAA,CAAI,EAAA,EAAI,IAAA,CAAK,QAAQ,GAAG,CAAA;AAChD,IAAA,MAAM,SAAA,GAAY,KAAK,MAAA,GAAS,KAAA;AAEhC,IAAA,IAAI,EAAA,GAAK,IAAA,CAAK,CAAA,GAAI,UAAA,EAAY,OAAO,IAAA;AAErC,IAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,KAAA,EAAO,CAAA,EAAA,EAAK;AAC9B,MAAA,MAAM,EAAA,GAAK,IAAA,CAAK,CAAA,GAAI,SAAA,IAAa,CAAA,GAAI,GAAA,CAAA;AACrC,MAAA,MAAM,WAAA,GAAc,IAAA,CAAK,GAAA,CAAI,SAAA,GAAY,KAAK,EAAE,CAAA;AAEhD,MAAA,IAAI,MAAM,EAAA,GAAK,WAAA,GAAc,KAAK,EAAA,IAAM,EAAA,GAAK,cAAc,CAAA,EAAG;AAC5D,QAAA,OAAO,EAAE,WAAA,EAAa,CAAA,EAAG,UAAA,EAAY,CAAA,EAAG,UAAU,CAAA,EAAG,CAAA,EAAG,EAAA,EAAI,CAAA,EAAG,EAAA,EAAG;AAAA,MACpE;AAAA,IACF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AACF","file":"chunk-
|
|
1
|
+
{"version":3,"sources":["../src/charts/bullet/bullet-type.ts"],"names":[],"mappings":"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","file":"chunk-SGZUUUXU.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, line, text } from '../../render/tree'\n\n/**\n * Bullet chart — compact horizontal gauge.\n *\n * Data format: each label is a metric.\n * - series[0]: actual values\n * - series[1] (optional): target values (shown as a marker line)\n *\n * Qualitative ranges (poor/satisfactory/good) are auto-generated\n * from the max value.\n */\nexport const bulletChartType: ChartTypePlugin = {\n type: 'bullet',\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 actual = data.series[0]\n if (!actual || actual.values.length === 0) return nodes\n\n const target = data.series[1]\n const count = actual.values.length\n const labelWidth = Math.min(80, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n\n const rowHeight = area.height / count\n const barHeight = Math.min(rowHeight * 0.4, 20)\n const rangeHeight = Math.min(rowHeight * 0.7, 32)\n\n // Find global max for scaling\n let maxVal = 0\n for (const v of actual.values) {\n if (Math.abs(v) > maxVal) maxVal = Math.abs(v)\n }\n if (target) {\n for (const v of target.values) {\n if (Math.abs(v) > maxVal) maxVal = Math.abs(v)\n }\n }\n // Extend max to give headroom for ranges\n maxVal = maxVal * 1.2\n if (maxVal === 0) maxVal = 1\n\n for (let i = 0; i < count; i++) {\n const cy = area.y + rowHeight * (i + 0.5)\n const val = actual.values[i]!\n const label = String(data.labels[i] ?? `Item ${i + 1}`)\n const color = options.colors[i % options.colors.length]!\n const bulletNodes: RenderNode[] = []\n\n // Label\n bulletNodes.push(text(area.x + labelWidth - 8, cy, label, {\n class: 'chartts-bullet-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n // Qualitative ranges (3 bands: poor, satisfactory, good)\n const bands = [1.0, 0.75, 0.5]\n const opacities = [0.1, 0.18, 0.28]\n for (let b = 0; b < bands.length; b++) {\n const bw = chartW * bands[b]!\n bulletNodes.push(rect(chartX, cy - rangeHeight / 2, bw, rangeHeight, {\n rx: 4, ry: 4,\n class: 'chartts-bullet-range',\n fill: theme.textColor,\n opacity: opacities[b],\n }))\n }\n\n // Actual value bar\n const barW = (Math.abs(val) / maxVal) * chartW\n bulletNodes.push(rect(chartX, cy - barHeight / 2, barW, barHeight, {\n rx: 3, ry: 3,\n class: 'chartts-bullet-bar',\n fill: color,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label}: ${val}${target ? `, target: ${target.values[i]}` : ''}`,\n }))\n\n // Target marker\n if (target && target.values[i] != null) {\n const tx = chartX + (Math.abs(target.values[i]!) / maxVal) * chartW\n const markerH = rangeHeight * 0.9\n bulletNodes.push(line(tx, cy - markerH / 2, tx, cy + markerH / 2, {\n class: 'chartts-bullet-target',\n stroke: theme.textColor,\n strokeWidth: 2.5,\n }))\n }\n\n nodes.push(group(bulletNodes, {\n class: `chartts-series chartts-series-${i}`,\n 'data-series-name': label,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const actual = data.series[0]\n if (!actual || actual.values.length === 0) return null\n\n const count = actual.values.length\n const labelWidth = Math.min(80, area.width * 0.2)\n const rowHeight = area.height / count\n\n if (mx < area.x + labelWidth) return null\n\n for (let i = 0; i < count; i++) {\n const cy = area.y + rowHeight * (i + 0.5)\n const rangeHeight = Math.min(rowHeight * 0.7, 32)\n\n if (my >= cy - rangeHeight / 2 && my <= cy + rangeHeight / 2) {\n return { seriesIndex: 0, pointIndex: i, distance: 0, x: mx, y: cy }\n }\n }\n\n return null\n },\n}\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { prepareData } from './chunk-
|
|
1
|
+
import { prepareData } from './chunk-AEQXFDL7.js';
|
|
2
2
|
|
|
3
3
|
// src/utils/prepare.ts
|
|
4
4
|
function prepareNoAxes(data, options) {
|
|
@@ -13,5 +13,5 @@ function prepareNoAxes(data, options) {
|
|
|
13
13
|
}
|
|
14
14
|
|
|
15
15
|
export { prepareNoAxes };
|
|
16
|
-
//# sourceMappingURL=chunk-
|
|
17
|
-
//# sourceMappingURL=chunk-
|
|
16
|
+
//# sourceMappingURL=chunk-T7SCCACB.js.map
|
|
17
|
+
//# sourceMappingURL=chunk-T7SCCACB.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/utils/prepare.ts"],"names":[],"mappings":";;;AAOO,SAAS,aAAA,CAAc,MAAiB,OAAA,EAAwC;AACrF,EAAA,OAAO,YAAY,IAAA,EAAM;AAAA,IACvB,GAAG,OAAA;AAAA,IACH,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,MAAA,EAAQ;AAAA,GACT,CAAA;AACH","file":"chunk-
|
|
1
|
+
{"version":3,"sources":["../src/utils/prepare.ts"],"names":[],"mappings":";;;AAOO,SAAS,aAAA,CAAc,MAAiB,OAAA,EAAwC;AACrF,EAAA,OAAO,YAAY,IAAA,EAAM;AAAA,IACvB,GAAG,OAAA;AAAA,IACH,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,MAAA,EAAQ;AAAA,GACT,CAAA;AACH","file":"chunk-T7SCCACB.js","sourcesContent":["import type { ChartData, ResolvedOptions, PreparedData } from '../types'\nimport { prepareData } from '../data/prepare'\n\n/**\n * Prepare data with axes, grid, and legend suppressed.\n * Used by chart types that render their own layout (pie, gauge, treemap, etc.).\n */\nexport function prepareNoAxes(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareData(data, {\n ...options,\n xAxis: false,\n yAxis: false,\n xGrid: false,\n yGrid: false,\n legend: false,\n })\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { prepareNoAxes } from './chunk-
|
|
2
|
-
import { text, rect, group } from './chunk-
|
|
1
|
+
import { prepareNoAxes } from './chunk-T7SCCACB.js';
|
|
2
|
+
import { text, rect, group } from './chunk-AEQXFDL7.js';
|
|
3
3
|
|
|
4
4
|
// src/charts/matrix/matrix-type.ts
|
|
5
5
|
var matrixChartType = {
|
|
@@ -153,5 +153,5 @@ function interpolateOpacity(baseColor, opacity) {
|
|
|
153
153
|
}
|
|
154
154
|
|
|
155
155
|
export { matrixChartType };
|
|
156
|
-
//# sourceMappingURL=chunk-
|
|
157
|
-
//# sourceMappingURL=chunk-
|
|
156
|
+
//# sourceMappingURL=chunk-TC3H6ZED.js.map
|
|
157
|
+
//# sourceMappingURL=chunk-TC3H6ZED.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/matrix/matrix-type.ts"],"names":["t"],"mappings":"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","file":"chunk-GPSNBZPX.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { rect, text, group } from '../../render/tree'\n\n/**\n * Matrix chart — grid layout with color-coded cells.\n *\n * Data convention:\n * - labels: row/column names (for square matrices) or column names\n * - series[i].name: row name, series[i].values[j]: cell value at row i, col j\n *\n * Options:\n * - showValues: display values in cells (default true)\n * - cellRadius: border-radius for cells (default 2)\n * - colorScale: 'sequential' | 'diverging' (default 'sequential')\n * - minColor: color for minimum value\n * - maxColor: color for maximum value\n */\n\nexport interface MatrixOptions {\n showValues?: boolean\n cellRadius?: number\n colorScale?: 'sequential' | 'diverging'\n minColor?: string\n maxColor?: string\n}\n\nexport const matrixChartType: ChartTypePlugin = {\n type: 'matrix',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'categorical' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const mOpts = options as unknown as MatrixOptions\n const showValues = mOpts.showValues !== false\n const cellRadius = mOpts.cellRadius ?? 2\n const colorScale = mOpts.colorScale ?? 'sequential'\n\n const rows = data.series.length\n const cols = data.labels.length\n if (rows === 0 || cols === 0) return nodes\n\n // Gather all values for color scale\n let allMin = Infinity, allMax = -Infinity\n for (const s of data.series) {\n for (const v of s.values) {\n if (v < allMin) allMin = v\n if (v > allMax) allMax = v\n }\n }\n if (!isFinite(allMin)) allMin = 0\n if (!isFinite(allMax)) allMax = 1\n const valRange = allMax - allMin || 1\n\n // Layout\n const labelPadLeft = 60\n const labelPadTop = 30\n const gap = 2\n const gridW = area.width - labelPadLeft - 10\n const gridH = area.height - labelPadTop - 10\n const cellW = (gridW - gap * (cols - 1)) / cols\n const cellH = (gridH - gap * (rows - 1)) / rows\n const gridX = area.x + labelPadLeft\n const gridY = area.y + labelPadTop\n\n // Column headers\n for (let c = 0; c < cols; c++) {\n const cx = gridX + c * (cellW + gap) + cellW / 2\n nodes.push(text(cx, gridY - 8, String(data.labels[c] ?? ''), {\n class: 'chartts-matrix-col-label',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: Math.min(theme.fontSizeSmall, cellW * 0.35),\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Row labels + cells\n for (let r = 0; r < rows; r++) {\n const series = data.series[r]!\n const ry = gridY + r * (cellH + gap)\n\n // Row label\n nodes.push(text(gridX - 6, ry + cellH / 2, series.name, {\n class: 'chartts-matrix-row-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, cellH * 0.4),\n fontFamily: theme.fontFamily,\n }))\n\n const rowNodes: RenderNode[] = []\n for (let c = 0; c < cols; c++) {\n const val = series.values[c] ?? 0\n const cx = gridX + c * (cellW + gap)\n\n // Color interpolation\n const color = getCellColor(val, allMin, allMax, valRange, colorScale, options.colors)\n const textColor = getContrastColor(val, allMin, allMax, valRange, colorScale)\n\n rowNodes.push(rect(cx, ry, cellW, cellH, {\n class: 'chartts-matrix-cell',\n fill: color,\n rx: cellRadius,\n ry: cellRadius,\n 'data-series': r,\n 'data-index': c,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name} × ${data.labels[c]}: ${val}`,\n }))\n\n // Value text\n if (showValues && cellW > 18 && cellH > 14) {\n const displayVal = Number.isInteger(val) ? String(val)\n : Math.abs(val) < 10 ? val.toFixed(2) : val.toFixed(1)\n\n rowNodes.push(text(cx + cellW / 2, ry + cellH / 2, displayVal, {\n class: 'chartts-matrix-value',\n fill: textColor,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, cellW * 0.3, cellH * 0.4),\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n pointerEvents: 'none',\n }))\n }\n }\n\n nodes.push(group(rowNodes, {\n class: `chartts-series chartts-series-${r}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const rows = data.series.length\n const cols = data.labels.length\n if (rows === 0 || cols === 0) return null\n\n const labelPadLeft = 60\n const labelPadTop = 30\n const gap = 2\n const gridW = area.width - labelPadLeft - 10\n const gridH = area.height - labelPadTop - 10\n const cellW = (gridW - gap * (cols - 1)) / cols\n const cellH = (gridH - gap * (rows - 1)) / rows\n const gridX = area.x + labelPadLeft\n const gridY = area.y + labelPadTop\n\n const col = Math.floor((mx - gridX) / (cellW + gap))\n const row = Math.floor((my - gridY) / (cellH + gap))\n\n if (row >= 0 && row < rows && col >= 0 && col < cols) {\n return { seriesIndex: row, pointIndex: col, distance: 0, x: gridX + col * (cellW + gap) + cellW / 2, y: gridY + row * (cellH + gap) + cellH / 2 }\n }\n return null\n },\n}\n\n// ---------------------------------------------------------------------------\n// Color helpers\n// ---------------------------------------------------------------------------\n\nfunction getCellColor(\n val: number, min: number, max: number, range: number,\n scale: string, colors: readonly string[],\n): string {\n if (scale === 'diverging') {\n const mid = (min + max) / 2\n if (val >= mid) {\n const t = (val - mid) / ((max - mid) || 1)\n return interpolateOpacity(colors[0] ?? '#3b82f6', 0.15 + t * 0.85)\n } else {\n const t = (mid - val) / ((mid - min) || 1)\n return interpolateOpacity(colors[1] ?? '#ef4444', 0.15 + t * 0.85)\n }\n }\n // Sequential\n const t = (val - min) / range\n return interpolateOpacity(colors[0] ?? '#3b82f6', 0.08 + t * 0.9)\n}\n\nfunction getContrastColor(\n val: number, min: number, max: number, range: number, scale: string,\n): string {\n if (scale === 'diverging') {\n const mid = (min + max) / 2\n const t = Math.abs(val - mid) / ((max - min) / 2 || 1)\n return t > 0.5 ? '#ffffff' : '#1f2937'\n }\n const t = (val - min) / range\n return t > 0.55 ? '#ffffff' : '#1f2937'\n}\n\nfunction interpolateOpacity(baseColor: string, opacity: number): string {\n // For CSS var() colors, we use opacity approach\n // Return as rgba-compatible format\n const hex = baseColor.includes('#') ? baseColor : '#3b82f6'\n const r = parseInt(hex.slice(1, 3), 16) || 59\n const g = parseInt(hex.slice(3, 5), 16) || 130\n const b = parseInt(hex.slice(5, 7), 16) || 246\n return `rgba(${r},${g},${b},${opacity.toFixed(2)})`\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/charts/matrix/matrix-type.ts"],"names":["t"],"mappings":"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","file":"chunk-TC3H6ZED.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { rect, text, group } from '../../render/tree'\n\n/**\n * Matrix chart — grid layout with color-coded cells.\n *\n * Data convention:\n * - labels: row/column names (for square matrices) or column names\n * - series[i].name: row name, series[i].values[j]: cell value at row i, col j\n *\n * Options:\n * - showValues: display values in cells (default true)\n * - cellRadius: border-radius for cells (default 2)\n * - colorScale: 'sequential' | 'diverging' (default 'sequential')\n * - minColor: color for minimum value\n * - maxColor: color for maximum value\n */\n\nexport interface MatrixOptions {\n showValues?: boolean\n cellRadius?: number\n colorScale?: 'sequential' | 'diverging'\n minColor?: string\n maxColor?: string\n}\n\nexport const matrixChartType: ChartTypePlugin = {\n type: 'matrix',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'categorical' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const mOpts = options as unknown as MatrixOptions\n const showValues = mOpts.showValues !== false\n const cellRadius = mOpts.cellRadius ?? 2\n const colorScale = mOpts.colorScale ?? 'sequential'\n\n const rows = data.series.length\n const cols = data.labels.length\n if (rows === 0 || cols === 0) return nodes\n\n // Gather all values for color scale\n let allMin = Infinity, allMax = -Infinity\n for (const s of data.series) {\n for (const v of s.values) {\n if (v < allMin) allMin = v\n if (v > allMax) allMax = v\n }\n }\n if (!isFinite(allMin)) allMin = 0\n if (!isFinite(allMax)) allMax = 1\n const valRange = allMax - allMin || 1\n\n // Layout\n const labelPadLeft = 60\n const labelPadTop = 30\n const gap = 2\n const gridW = area.width - labelPadLeft - 10\n const gridH = area.height - labelPadTop - 10\n const cellW = (gridW - gap * (cols - 1)) / cols\n const cellH = (gridH - gap * (rows - 1)) / rows\n const gridX = area.x + labelPadLeft\n const gridY = area.y + labelPadTop\n\n // Column headers\n for (let c = 0; c < cols; c++) {\n const cx = gridX + c * (cellW + gap) + cellW / 2\n nodes.push(text(cx, gridY - 8, String(data.labels[c] ?? ''), {\n class: 'chartts-matrix-col-label',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: Math.min(theme.fontSizeSmall, cellW * 0.35),\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Row labels + cells\n for (let r = 0; r < rows; r++) {\n const series = data.series[r]!\n const ry = gridY + r * (cellH + gap)\n\n // Row label\n nodes.push(text(gridX - 6, ry + cellH / 2, series.name, {\n class: 'chartts-matrix-row-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, cellH * 0.4),\n fontFamily: theme.fontFamily,\n }))\n\n const rowNodes: RenderNode[] = []\n for (let c = 0; c < cols; c++) {\n const val = series.values[c] ?? 0\n const cx = gridX + c * (cellW + gap)\n\n // Color interpolation\n const color = getCellColor(val, allMin, allMax, valRange, colorScale, options.colors)\n const textColor = getContrastColor(val, allMin, allMax, valRange, colorScale)\n\n rowNodes.push(rect(cx, ry, cellW, cellH, {\n class: 'chartts-matrix-cell',\n fill: color,\n rx: cellRadius,\n ry: cellRadius,\n 'data-series': r,\n 'data-index': c,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name} × ${data.labels[c]}: ${val}`,\n }))\n\n // Value text\n if (showValues && cellW > 18 && cellH > 14) {\n const displayVal = Number.isInteger(val) ? String(val)\n : Math.abs(val) < 10 ? val.toFixed(2) : val.toFixed(1)\n\n rowNodes.push(text(cx + cellW / 2, ry + cellH / 2, displayVal, {\n class: 'chartts-matrix-value',\n fill: textColor,\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall, cellW * 0.3, cellH * 0.4),\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n pointerEvents: 'none',\n }))\n }\n }\n\n nodes.push(group(rowNodes, {\n class: `chartts-series chartts-series-${r}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const rows = data.series.length\n const cols = data.labels.length\n if (rows === 0 || cols === 0) return null\n\n const labelPadLeft = 60\n const labelPadTop = 30\n const gap = 2\n const gridW = area.width - labelPadLeft - 10\n const gridH = area.height - labelPadTop - 10\n const cellW = (gridW - gap * (cols - 1)) / cols\n const cellH = (gridH - gap * (rows - 1)) / rows\n const gridX = area.x + labelPadLeft\n const gridY = area.y + labelPadTop\n\n const col = Math.floor((mx - gridX) / (cellW + gap))\n const row = Math.floor((my - gridY) / (cellH + gap))\n\n if (row >= 0 && row < rows && col >= 0 && col < cols) {\n return { seriesIndex: row, pointIndex: col, distance: 0, x: gridX + col * (cellW + gap) + cellW / 2, y: gridY + row * (cellH + gap) + cellH / 2 }\n }\n return null\n },\n}\n\n// ---------------------------------------------------------------------------\n// Color helpers\n// ---------------------------------------------------------------------------\n\nfunction getCellColor(\n val: number, min: number, max: number, range: number,\n scale: string, colors: readonly string[],\n): string {\n if (scale === 'diverging') {\n const mid = (min + max) / 2\n if (val >= mid) {\n const t = (val - mid) / ((max - mid) || 1)\n return interpolateOpacity(colors[0] ?? '#3b82f6', 0.15 + t * 0.85)\n } else {\n const t = (mid - val) / ((mid - min) || 1)\n return interpolateOpacity(colors[1] ?? '#ef4444', 0.15 + t * 0.85)\n }\n }\n // Sequential\n const t = (val - min) / range\n return interpolateOpacity(colors[0] ?? '#3b82f6', 0.08 + t * 0.9)\n}\n\nfunction getContrastColor(\n val: number, min: number, max: number, range: number, scale: string,\n): string {\n if (scale === 'diverging') {\n const mid = (min + max) / 2\n const t = Math.abs(val - mid) / ((max - min) / 2 || 1)\n return t > 0.5 ? '#ffffff' : '#1f2937'\n }\n const t = (val - min) / range\n return t > 0.55 ? '#ffffff' : '#1f2937'\n}\n\nfunction interpolateOpacity(baseColor: string, opacity: number): string {\n // For CSS var() colors, we use opacity approach\n // Return as rgba-compatible format\n const hex = baseColor.includes('#') ? baseColor : '#3b82f6'\n const r = parseInt(hex.slice(1, 3), 16) || 59\n const g = parseInt(hex.slice(3, 5), 16) || 130\n const b = parseInt(hex.slice(5, 7), 16) || 246\n return `rgba(${r},${g},${b},${opacity.toFixed(2)})`\n}\n"]}
|
|
@@ -1,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/lollipop/lollipop-type.ts
|
|
7
7
|
var lollipopChartType = {
|
|
@@ -10,7 +10,7 @@ var lollipopChartType = {
|
|
|
10
10
|
return { x: "categorical", y: "linear" };
|
|
11
11
|
},
|
|
12
12
|
prepareData(data, options) {
|
|
13
|
-
const prepared =
|
|
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
|
}
|
|
@@ -33,19 +33,19 @@ var lollipopChartType = {
|
|
|
33
33
|
const cx = xScale.map(i) + (series.index - (seriesCount - 1) / 2) * stemGap;
|
|
34
34
|
const vy = yScale.map(series.values[i]);
|
|
35
35
|
const color = options.colors[series.index % options.colors.length];
|
|
36
|
-
seriesNodes.push(
|
|
36
|
+
seriesNodes.push(chunkJVVGQLJQ_cjs.line(cx, baselineY, cx, vy, {
|
|
37
37
|
class: "chartts-lollipop-stem",
|
|
38
38
|
stroke: color,
|
|
39
39
|
strokeWidth: 2.5,
|
|
40
40
|
strokeLinecap: "round",
|
|
41
41
|
strokeOpacity: 0.6
|
|
42
42
|
}));
|
|
43
|
-
seriesNodes.push(
|
|
43
|
+
seriesNodes.push(chunkJVVGQLJQ_cjs.circle(cx, vy, dotR * 2, {
|
|
44
44
|
class: "chartts-lollipop-glow",
|
|
45
45
|
fill: color,
|
|
46
46
|
fillOpacity: 0.12
|
|
47
47
|
}));
|
|
48
|
-
seriesNodes.push(
|
|
48
|
+
seriesNodes.push(chunkJVVGQLJQ_cjs.circle(cx, vy, dotR, {
|
|
49
49
|
class: "chartts-lollipop-dot",
|
|
50
50
|
fill: color,
|
|
51
51
|
stroke: `var(--chartts-bg, #fff)`,
|
|
@@ -57,7 +57,7 @@ var lollipopChartType = {
|
|
|
57
57
|
ariaLabel: `${series.name}: ${series.values[i]}`
|
|
58
58
|
}));
|
|
59
59
|
}
|
|
60
|
-
nodes.push(
|
|
60
|
+
nodes.push(chunkJVVGQLJQ_cjs.group(seriesNodes, {
|
|
61
61
|
class: `chartts-series chartts-series-${series.index}`,
|
|
62
62
|
"data-series-name": series.name
|
|
63
63
|
}));
|
|
@@ -92,5 +92,5 @@ var lollipopChartType = {
|
|
|
92
92
|
};
|
|
93
93
|
|
|
94
94
|
exports.lollipopChartType = lollipopChartType;
|
|
95
|
-
//# sourceMappingURL=chunk-
|
|
96
|
-
//# sourceMappingURL=chunk-
|
|
95
|
+
//# sourceMappingURL=chunk-TEZNWW3R.cjs.map
|
|
96
|
+
//# sourceMappingURL=chunk-TEZNWW3R.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/lollipop/lollipop-type.ts"],"names":["prepareData","getBandwidth","line","circle","group"],"mappings":"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","file":"chunk-
|
|
1
|
+
{"version":3,"sources":["../src/charts/lollipop/lollipop-type.ts"],"names":["prepareData","getBandwidth","line","circle","group"],"mappings":"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","file":"chunk-TEZNWW3R.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, line, circle } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\n/**\n * Lollipop chart — stem line + circle at end.\n *\n * A modern, cleaner alternative to bar charts.\n * Vertical stems from baseline to value with a prominent circle dot.\n */\nexport const lollipopChartType: ChartTypePlugin = {\n type: 'lollipop',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, options)\n if (options.yMin === undefined && prepared.bounds.yMin > 0) {\n prepared.bounds.yMin = 0\n }\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, options, xScale, yScale } = ctx\n const nodes: RenderNode[] = []\n\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n const bw = getBandwidth(xScale)\n const groupWidth = bw * 0.8\n const stemGap = groupWidth / seriesCount\n const dotR = Math.min(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,4 +1,4 @@
|
|
|
1
|
-
import { path, PathBuilder, circle, CSS_PREFIX, group, line, prepareData } from './chunk-
|
|
1
|
+
import { path, PathBuilder, circle, CSS_PREFIX, group, line, prepareData } from './chunk-AEQXFDL7.js';
|
|
2
2
|
|
|
3
3
|
// src/charts/baseline/baseline-type.ts
|
|
4
4
|
var baselineChartType = {
|
|
@@ -159,5 +159,5 @@ function buildClippedArea(points, baseY, side) {
|
|
|
159
159
|
}
|
|
160
160
|
|
|
161
161
|
export { baselineChartType };
|
|
162
|
-
//# sourceMappingURL=chunk-
|
|
163
|
-
//# sourceMappingURL=chunk-
|
|
162
|
+
//# sourceMappingURL=chunk-THHZMRFU.js.map
|
|
163
|
+
//# sourceMappingURL=chunk-THHZMRFU.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/baseline/baseline-type.ts"],"names":[],"mappings":"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","file":"chunk-KTCP23W6.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { CSS_PREFIX } from '../../constants'\nimport { prepareData } from '../../data/prepare'\nimport { group, path, circle, line } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\nexport interface BaselineOptions {\n /** Reference value for positive/negative split. Default 0. */\n baseline?: number\n /** Color for values above baseline. Default green. */\n positiveColor?: string\n /** Color for values below baseline. Default red. */\n negativeColor?: string\n /** Fill opacity for shaded areas. Default 0.15. */\n fillOpacity?: number\n /** Show the baseline reference line. Default true. */\n showBaseline?: boolean\n /** Show data points. Default true. */\n showPoints?: boolean\n}\n\n/**\n * Baseline chart — line with positive/negative shading.\n *\n * Values above the baseline are shaded green, below shaded red.\n * Used for: performance vs benchmark, P&L, temperature anomalies.\n */\nexport const baselineChartType: ChartTypePlugin = {\n type: 'baseline',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const opts = options as unknown as BaselineOptions\n const bv = opts.baseline ?? 0\n const prepared = prepareData(data, options)\n // Ensure baseline value is visible in the scale\n if (bv < prepared.bounds.yMin) prepared.bounds.yMin = bv\n if (bv > prepared.bounds.yMax) prepared.bounds.yMax = bv\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, xScale, yScale, area, options, theme } = ctx\n const nodes: RenderNode[] = []\n\n const opts = options as unknown as BaselineOptions\n const bv = opts.baseline ?? 0\n const posColor = opts.positiveColor ?? 'var(--color-emerald-500, #10b981)'\n const negColor = opts.negativeColor ?? 'var(--color-red-500, #ef4444)'\n const fillOp = opts.fillOpacity ?? 0.15\n const showBaseline = opts.showBaseline ?? true\n const showPoints = opts.showPoints ?? true\n\n const baseY = yScale.map(bv)\n\n for (const series of data.series) {\n const seriesNodes: RenderNode[] = []\n const values = series.values\n if (values.length === 0) continue\n\n // Filter out NaN for path building — only use valid data points\n const validPoints: { x: number; y: number; idx: number; val: number }[] = []\n for (let i = 0; i < values.length; i++) {\n if (!isNaN(values[i]!)) {\n validPoints.push({ x: xScale.map(i), y: yScale.map(values[i]!), idx: i, val: values[i]! })\n }\n }\n const points = validPoints.map(p => ({ x: p.x, y: p.y }))\n\n // Positive fill (above baseline, clipped at baseline)\n const posFill = buildClippedArea(points, baseY, 'above')\n if (posFill) {\n seriesNodes.push(path(posFill, {\n class: 'chartts-baseline-pos',\n fill: posColor,\n fillOpacity: fillOp,\n 'data-series': series.index,\n }))\n }\n\n // Negative fill (below baseline, clipped at baseline)\n const negFill = buildClippedArea(points, baseY, 'below')\n if (negFill) {\n seriesNodes.push(path(negFill, {\n class: 'chartts-baseline-neg',\n fill: negColor,\n fillOpacity: fillOp,\n 'data-series': series.index,\n }))\n }\n\n // Main line (using valid points only)\n const linePath = new PathBuilder()\n if (points.length > 0) {\n linePath.moveTo(points[0]!.x, points[0]!.y)\n for (let i = 1; i < points.length; i++) {\n linePath.lineTo(points[i]!.x, points[i]!.y)\n }\n }\n seriesNodes.push(path(linePath.build(), {\n class: 'chartts-baseline-line',\n stroke: series.color,\n strokeWidth: theme.lineWidth,\n 'data-series': series.index,\n }))\n\n // Data points (only for valid points)\n if (showPoints) {\n for (const vp of validPoints) {\n const color = vp.val >= bv ? posColor : negColor\n seriesNodes.push(circle(vp.x, vp.y, theme.pointRadius, {\n class: 'chartts-point',\n fill: color,\n stroke: `var(${CSS_PREFIX}-bg, #fff)`,\n strokeWidth: 2,\n 'data-series': series.index,\n 'data-index': vp.idx,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${vp.val} (${vp.val >= bv ? '+' : ''}${(vp.val - bv).toFixed(1)})`,\n }))\n }\n }\n\n nodes.push(group(seriesNodes, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n // Baseline reference line\n if (showBaseline) {\n nodes.push(line(area.x, baseY, area.x + area.width, baseY, {\n class: 'chartts-baseline-ref',\n stroke: theme.textMuted,\n strokeWidth: 1,\n strokeDasharray: '6,4',\n opacity: 0.5,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale } = ctx\n let best: HitResult | null = null\n let bestDist = Infinity\n\n for (const series of data.series) {\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2)\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist, x, y }\n }\n }\n }\n\n return best && best.distance < 30 ? best : null\n },\n}\n\n/**\n * Build a filled area path clipped to one side of the baseline.\n * Interpolates intersection points where the line crosses the baseline.\n */\nfunction buildClippedArea(\n points: { x: number; y: number }[],\n baseY: number,\n side: 'above' | 'below',\n): string | null {\n if (points.length < 2) return null\n\n // Collect segments that are on the desired side\n const segments: { x: number; y: number }[][] = []\n let current: { x: number; y: number }[] = []\n\n for (let i = 0; i < points.length; i++) {\n const p = points[i]!\n const onSide = side === 'above' ? p.y <= baseY : p.y >= baseY\n\n if (i > 0) {\n const prev = points[i - 1]!\n const prevOnSide = side === 'above' ? prev.y <= baseY : prev.y >= baseY\n\n // Crossing detected — compute intersection\n if (onSide !== prevOnSide) {\n const t = (baseY - prev.y) / (p.y - prev.y)\n const ix = prev.x + t * (p.x - prev.x)\n const cross = { x: ix, y: baseY }\n\n if (prevOnSide) {\n // Was on side, now leaving — close current segment\n current.push(cross)\n if (current.length >= 2) segments.push(current)\n current = []\n } else {\n // Was off side, now entering — start new segment\n current = [cross]\n }\n }\n }\n\n if (onSide) current.push(p)\n }\n if (current.length >= 2) segments.push(current)\n if (segments.length === 0) return null\n\n // Build SVG path for all segments\n const pb = new PathBuilder()\n for (const seg of segments) {\n pb.moveTo(seg[0]!.x, seg[0]!.y)\n for (let i = 1; i < seg.length; i++) {\n pb.lineTo(seg[i]!.x, seg[i]!.y)\n }\n // Close down/up to baseline\n pb.lineTo(seg[seg.length - 1]!.x, baseY)\n pb.lineTo(seg[0]!.x, baseY)\n pb.close()\n }\n\n return pb.build()\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/charts/baseline/baseline-type.ts"],"names":[],"mappings":"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","file":"chunk-THHZMRFU.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { CSS_PREFIX } from '../../constants'\nimport { prepareData } from '../../data/prepare'\nimport { group, path, circle, line } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\nexport interface BaselineOptions {\n /** Reference value for positive/negative split. Default 0. */\n baseline?: number\n /** Color for values above baseline. Default green. */\n positiveColor?: string\n /** Color for values below baseline. Default red. */\n negativeColor?: string\n /** Fill opacity for shaded areas. Default 0.15. */\n fillOpacity?: number\n /** Show the baseline reference line. Default true. */\n showBaseline?: boolean\n /** Show data points. Default true. */\n showPoints?: boolean\n}\n\n/**\n * Baseline chart — line with positive/negative shading.\n *\n * Values above the baseline are shaded green, below shaded red.\n * Used for: performance vs benchmark, P&L, temperature anomalies.\n */\nexport const baselineChartType: ChartTypePlugin = {\n type: 'baseline',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const opts = options as unknown as BaselineOptions\n const bv = opts.baseline ?? 0\n const prepared = prepareData(data, options)\n // Ensure baseline value is visible in the scale\n if (bv < prepared.bounds.yMin) prepared.bounds.yMin = bv\n if (bv > prepared.bounds.yMax) prepared.bounds.yMax = bv\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, xScale, yScale, area, options, theme } = ctx\n const nodes: RenderNode[] = []\n\n const opts = options as unknown as BaselineOptions\n const bv = opts.baseline ?? 0\n const posColor = opts.positiveColor ?? 'var(--color-emerald-500, #10b981)'\n const negColor = opts.negativeColor ?? 'var(--color-red-500, #ef4444)'\n const fillOp = opts.fillOpacity ?? 0.15\n const showBaseline = opts.showBaseline ?? true\n const showPoints = opts.showPoints ?? true\n\n const baseY = yScale.map(bv)\n\n for (const series of data.series) {\n const seriesNodes: RenderNode[] = []\n const values = series.values\n if (values.length === 0) continue\n\n // Filter out NaN for path building — only use valid data points\n const validPoints: { x: number; y: number; idx: number; val: number }[] = []\n for (let i = 0; i < values.length; i++) {\n if (!isNaN(values[i]!)) {\n validPoints.push({ x: xScale.map(i), y: yScale.map(values[i]!), idx: i, val: values[i]! })\n }\n }\n const points = validPoints.map(p => ({ x: p.x, y: p.y }))\n\n // Positive fill (above baseline, clipped at baseline)\n const posFill = buildClippedArea(points, baseY, 'above')\n if (posFill) {\n seriesNodes.push(path(posFill, {\n class: 'chartts-baseline-pos',\n fill: posColor,\n fillOpacity: fillOp,\n 'data-series': series.index,\n }))\n }\n\n // Negative fill (below baseline, clipped at baseline)\n const negFill = buildClippedArea(points, baseY, 'below')\n if (negFill) {\n seriesNodes.push(path(negFill, {\n class: 'chartts-baseline-neg',\n fill: negColor,\n fillOpacity: fillOp,\n 'data-series': series.index,\n }))\n }\n\n // Main line (using valid points only)\n const linePath = new PathBuilder()\n if (points.length > 0) {\n linePath.moveTo(points[0]!.x, points[0]!.y)\n for (let i = 1; i < points.length; i++) {\n linePath.lineTo(points[i]!.x, points[i]!.y)\n }\n }\n seriesNodes.push(path(linePath.build(), {\n class: 'chartts-baseline-line',\n stroke: series.color,\n strokeWidth: theme.lineWidth,\n 'data-series': series.index,\n }))\n\n // Data points (only for valid points)\n if (showPoints) {\n for (const vp of validPoints) {\n const color = vp.val >= bv ? posColor : negColor\n seriesNodes.push(circle(vp.x, vp.y, theme.pointRadius, {\n class: 'chartts-point',\n fill: color,\n stroke: `var(${CSS_PREFIX}-bg, #fff)`,\n strokeWidth: 2,\n 'data-series': series.index,\n 'data-index': vp.idx,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${vp.val} (${vp.val >= bv ? '+' : ''}${(vp.val - bv).toFixed(1)})`,\n }))\n }\n }\n\n nodes.push(group(seriesNodes, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n // Baseline reference line\n if (showBaseline) {\n nodes.push(line(area.x, baseY, area.x + area.width, baseY, {\n class: 'chartts-baseline-ref',\n stroke: theme.textMuted,\n strokeWidth: 1,\n strokeDasharray: '6,4',\n opacity: 0.5,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, xScale, yScale } = ctx\n let best: HitResult | null = null\n let bestDist = Infinity\n\n for (const series of data.series) {\n for (let i = 0; i < series.values.length; i++) {\n if (isNaN(series.values[i]!)) continue\n const x = xScale.map(i)\n const y = yScale.map(series.values[i]!)\n const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2)\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: series.index, pointIndex: i, distance: dist, x, y }\n }\n }\n }\n\n return best && best.distance < 30 ? best : null\n },\n}\n\n/**\n * Build a filled area path clipped to one side of the baseline.\n * Interpolates intersection points where the line crosses the baseline.\n */\nfunction buildClippedArea(\n points: { x: number; y: number }[],\n baseY: number,\n side: 'above' | 'below',\n): string | null {\n if (points.length < 2) return null\n\n // Collect segments that are on the desired side\n const segments: { x: number; y: number }[][] = []\n let current: { x: number; y: number }[] = []\n\n for (let i = 0; i < points.length; i++) {\n const p = points[i]!\n const onSide = side === 'above' ? p.y <= baseY : p.y >= baseY\n\n if (i > 0) {\n const prev = points[i - 1]!\n const prevOnSide = side === 'above' ? prev.y <= baseY : prev.y >= baseY\n\n // Crossing detected — compute intersection\n if (onSide !== prevOnSide) {\n const t = (baseY - prev.y) / (p.y - prev.y)\n const ix = prev.x + t * (p.x - prev.x)\n const cross = { x: ix, y: baseY }\n\n if (prevOnSide) {\n // Was on side, now leaving — close current segment\n current.push(cross)\n if (current.length >= 2) segments.push(current)\n current = []\n } else {\n // Was off side, now entering — start new segment\n current = [cross]\n }\n }\n }\n\n if (onSide) current.push(p)\n }\n if (current.length >= 2) segments.push(current)\n if (segments.length === 0) return null\n\n // Build SVG path for all segments\n const pb = new PathBuilder()\n for (const seg of segments) {\n pb.moveTo(seg[0]!.x, seg[0]!.y)\n for (let i = 1; i < seg.length; i++) {\n pb.lineTo(seg[i]!.x, seg[i]!.y)\n }\n // Close down/up to baseline\n pb.lineTo(seg[seg.length - 1]!.x, baseY)\n pb.lineTo(seg[0]!.x, baseY)\n pb.close()\n }\n\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/parallel/parallel-type.ts
|
|
7
7
|
var parallelChartType = {
|
|
@@ -10,7 +10,7 @@ var parallelChartType = {
|
|
|
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;
|
|
@@ -43,12 +43,12 @@ var parallelChartType = {
|
|
|
43
43
|
};
|
|
44
44
|
for (let d = 0; d < dimCount; d++) {
|
|
45
45
|
const x = axisX(d);
|
|
46
|
-
nodes.push(
|
|
46
|
+
nodes.push(chunkJVVGQLJQ_cjs.line(x, axisTop, x, axisBottom, {
|
|
47
47
|
class: "chartts-parallel-axis",
|
|
48
48
|
stroke: theme.axisColor,
|
|
49
49
|
strokeWidth: theme.axisWidth
|
|
50
50
|
}));
|
|
51
|
-
nodes.push(
|
|
51
|
+
nodes.push(chunkJVVGQLJQ_cjs.text(x, axisBottom + 14, String(data.labels[d]), {
|
|
52
52
|
class: "chartts-parallel-label",
|
|
53
53
|
fill: theme.textMuted,
|
|
54
54
|
textAnchor: "middle",
|
|
@@ -56,7 +56,7 @@ var parallelChartType = {
|
|
|
56
56
|
fontSize: theme.fontSizeSmall,
|
|
57
57
|
fontFamily: theme.fontFamily
|
|
58
58
|
}));
|
|
59
|
-
nodes.push(
|
|
59
|
+
nodes.push(chunkJVVGQLJQ_cjs.text(x - 6, axisTop, String(Math.round(maxs[d])), {
|
|
60
60
|
class: "chartts-parallel-tick",
|
|
61
61
|
fill: theme.textMuted,
|
|
62
62
|
textAnchor: "end",
|
|
@@ -64,7 +64,7 @@ var parallelChartType = {
|
|
|
64
64
|
fontSize: theme.fontSizeSmall * 0.85,
|
|
65
65
|
fontFamily: theme.fontFamily
|
|
66
66
|
}));
|
|
67
|
-
nodes.push(
|
|
67
|
+
nodes.push(chunkJVVGQLJQ_cjs.text(x - 6, axisBottom, String(Math.round(mins[d])), {
|
|
68
68
|
class: "chartts-parallel-tick",
|
|
69
69
|
fill: theme.textMuted,
|
|
70
70
|
textAnchor: "end",
|
|
@@ -76,14 +76,14 @@ var parallelChartType = {
|
|
|
76
76
|
for (let si = 0; si < data.series.length; si++) {
|
|
77
77
|
const series = data.series[si];
|
|
78
78
|
const color = series.color ?? options.colors[si % options.colors.length];
|
|
79
|
-
const pb = new
|
|
79
|
+
const pb = new chunkJVVGQLJQ_cjs.PathBuilder();
|
|
80
80
|
for (let d = 0; d < dimCount; d++) {
|
|
81
81
|
const x = axisX(d);
|
|
82
82
|
const y = valueToY(d, series.values[d] ?? 0);
|
|
83
83
|
if (d === 0) pb.moveTo(x, y);
|
|
84
84
|
else pb.lineTo(x, y);
|
|
85
85
|
}
|
|
86
|
-
nodes.push(
|
|
86
|
+
nodes.push(chunkJVVGQLJQ_cjs.path(pb.build(), {
|
|
87
87
|
class: "chartts-parallel-line",
|
|
88
88
|
stroke: color,
|
|
89
89
|
strokeWidth: theme.lineWidth,
|
|
@@ -145,5 +145,5 @@ var parallelChartType = {
|
|
|
145
145
|
};
|
|
146
146
|
|
|
147
147
|
exports.parallelChartType = parallelChartType;
|
|
148
|
-
//# sourceMappingURL=chunk-
|
|
149
|
-
//# sourceMappingURL=chunk-
|
|
148
|
+
//# sourceMappingURL=chunk-TLHQ6JCK.cjs.map
|
|
149
|
+
//# sourceMappingURL=chunk-TLHQ6JCK.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/parallel/parallel-type.ts"],"names":["prepareNoAxes","line","text","PathBuilder","path"],"mappings":"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","file":"chunk-RWQH5EO5.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, line } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Parallel coordinates chart — multi-dimensional data on parallel vertical axes.\n *\n * Data convention:\n * - labels: axis names (dimensions), one per axis\n * - series[i]: one data record. series[i].values[j] = value for dimension j\n *\n * Each series becomes a polyline crossing all axes.\n */\n\nexport const parallelChartType: ChartTypePlugin = {\n type: 'parallel',\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 dimCount = data.labels.length\n if (dimCount < 2 || data.series.length === 0) return nodes\n\n const padding = 24\n const axisSpacing = (area.width - padding * 2) / Math.max(dimCount - 1, 1)\n const axisTop = area.y + padding\n const axisBottom = area.y + area.height - padding\n\n // Compute min/max per dimension\n const mins: number[] = new Array(dimCount).fill(Infinity)\n const maxs: number[] = new Array(dimCount).fill(-Infinity)\n for (const series of data.series) {\n for (let d = 0; d < dimCount; d++) {\n const v = series.values[d] ?? 0\n if (v < mins[d]!) mins[d] = v\n if (v > maxs[d]!) maxs[d] = v\n }\n }\n\n // Ensure min !== max\n for (let d = 0; d < dimCount; d++) {\n if (mins[d] === maxs[d]) {\n mins[d] = mins[d]! - 1\n maxs[d] = maxs[d]! + 1\n }\n }\n\n const axisX = (dim: number) => area.x + padding + dim * axisSpacing\n const valueToY = (dim: number, value: number) => {\n const frac = (value - mins[dim]!) / (maxs[dim]! - mins[dim]!)\n return axisBottom - frac * (axisBottom - axisTop) // invert: higher values = higher on axis\n }\n\n // Draw axes\n for (let d = 0; d < dimCount; d++) {\n const x = axisX(d)\n\n // Axis line\n nodes.push(line(x, axisTop, x, axisBottom, {\n class: 'chartts-parallel-axis',\n stroke: theme.axisColor,\n strokeWidth: theme.axisWidth,\n }))\n\n // Axis label at bottom\n nodes.push(text(x, axisBottom + 14, String(data.labels[d]!), {\n class: 'chartts-parallel-label',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n // Min/max ticks\n nodes.push(text(x - 6, axisTop, String(Math.round(maxs[d]!)), {\n class: 'chartts-parallel-tick',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall * 0.85,\n fontFamily: theme.fontFamily,\n }))\n nodes.push(text(x - 6, axisBottom, String(Math.round(mins[d]!)), {\n class: 'chartts-parallel-tick',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall * 0.85,\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Draw series lines\n for (let si = 0; si < data.series.length; si++) {\n const series = data.series[si]!\n const color = series.color ?? options.colors[si % options.colors.length]!\n\n const pb = new PathBuilder()\n for (let d = 0; d < dimCount; d++) {\n const x = axisX(d)\n const y = valueToY(d, series.values[d] ?? 0)\n if (d === 0) pb.moveTo(x, y)\n else pb.lineTo(x, y)\n }\n\n nodes.push(path(pb.build(), {\n class: 'chartts-parallel-line',\n stroke: color,\n strokeWidth: theme.lineWidth,\n fill: 'none',\n fillOpacity: 0,\n opacity: Math.max(0.3, 1 - data.series.length * 0.03),\n 'data-series': si,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values.join(', ')}`,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const dimCount = data.labels.length\n if (dimCount < 2 || data.series.length === 0) return null\n\n const padding = 24\n const axisSpacing = (area.width - padding * 2) / Math.max(dimCount - 1, 1)\n const axisTop = area.y + padding\n const axisBottom = area.y + area.height - padding\n\n const mins: number[] = new Array(dimCount).fill(Infinity)\n const maxs: number[] = new Array(dimCount).fill(-Infinity)\n for (const series of data.series) {\n for (let d = 0; d < dimCount; d++) {\n const v = series.values[d] ?? 0\n if (v < mins[d]!) mins[d] = v\n if (v > maxs[d]!) maxs[d] = v\n }\n }\n for (let d = 0; d < dimCount; d++) {\n if (mins[d] === maxs[d]) { mins[d] = mins[d]! - 1; maxs[d] = maxs[d]! + 1 }\n }\n\n const axisX = (dim: number) => area.x + padding + dim * axisSpacing\n const valueToY = (dim: number, value: number) => {\n const frac = (value - mins[dim]!) / (maxs[dim]! - mins[dim]!)\n return axisBottom - frac * (axisBottom - axisTop)\n }\n\n // Find closest series line\n let best: HitResult | null = null\n let bestDist = 20 // max hit distance\n\n for (let si = 0; si < data.series.length; si++) {\n const series = data.series[si]!\n for (let d = 0; d < dimCount; d++) {\n const x = axisX(d)\n const y = valueToY(d, series.values[d] ?? 0)\n const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2)\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: si, pointIndex: d, distance: dist, x, y }\n }\n }\n }\n\n return best\n },\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/charts/parallel/parallel-type.ts"],"names":["prepareNoAxes","line","text","PathBuilder","path"],"mappings":"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","file":"chunk-TLHQ6JCK.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, line } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Parallel coordinates chart — multi-dimensional data on parallel vertical axes.\n *\n * Data convention:\n * - labels: axis names (dimensions), one per axis\n * - series[i]: one data record. series[i].values[j] = value for dimension j\n *\n * Each series becomes a polyline crossing all axes.\n */\n\nexport const parallelChartType: ChartTypePlugin = {\n type: 'parallel',\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 dimCount = data.labels.length\n if (dimCount < 2 || data.series.length === 0) return nodes\n\n const padding = 24\n const axisSpacing = (area.width - padding * 2) / Math.max(dimCount - 1, 1)\n const axisTop = area.y + padding\n const axisBottom = area.y + area.height - padding\n\n // Compute min/max per dimension\n const mins: number[] = new Array(dimCount).fill(Infinity)\n const maxs: number[] = new Array(dimCount).fill(-Infinity)\n for (const series of data.series) {\n for (let d = 0; d < dimCount; d++) {\n const v = series.values[d] ?? 0\n if (v < mins[d]!) mins[d] = v\n if (v > maxs[d]!) maxs[d] = v\n }\n }\n\n // Ensure min !== max\n for (let d = 0; d < dimCount; d++) {\n if (mins[d] === maxs[d]) {\n mins[d] = mins[d]! - 1\n maxs[d] = maxs[d]! + 1\n }\n }\n\n const axisX = (dim: number) => area.x + padding + dim * axisSpacing\n const valueToY = (dim: number, value: number) => {\n const frac = (value - mins[dim]!) / (maxs[dim]! - mins[dim]!)\n return axisBottom - frac * (axisBottom - axisTop) // invert: higher values = higher on axis\n }\n\n // Draw axes\n for (let d = 0; d < dimCount; d++) {\n const x = axisX(d)\n\n // Axis line\n nodes.push(line(x, axisTop, x, axisBottom, {\n class: 'chartts-parallel-axis',\n stroke: theme.axisColor,\n strokeWidth: theme.axisWidth,\n }))\n\n // Axis label at bottom\n nodes.push(text(x, axisBottom + 14, String(data.labels[d]!), {\n class: 'chartts-parallel-label',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n // Min/max ticks\n nodes.push(text(x - 6, axisTop, String(Math.round(maxs[d]!)), {\n class: 'chartts-parallel-tick',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall * 0.85,\n fontFamily: theme.fontFamily,\n }))\n nodes.push(text(x - 6, axisBottom, String(Math.round(mins[d]!)), {\n class: 'chartts-parallel-tick',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall * 0.85,\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Draw series lines\n for (let si = 0; si < data.series.length; si++) {\n const series = data.series[si]!\n const color = series.color ?? options.colors[si % options.colors.length]!\n\n const pb = new PathBuilder()\n for (let d = 0; d < dimCount; d++) {\n const x = axisX(d)\n const y = valueToY(d, series.values[d] ?? 0)\n if (d === 0) pb.moveTo(x, y)\n else pb.lineTo(x, y)\n }\n\n nodes.push(path(pb.build(), {\n class: 'chartts-parallel-line',\n stroke: color,\n strokeWidth: theme.lineWidth,\n fill: 'none',\n fillOpacity: 0,\n opacity: Math.max(0.3, 1 - data.series.length * 0.03),\n 'data-series': si,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values.join(', ')}`,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const dimCount = data.labels.length\n if (dimCount < 2 || data.series.length === 0) return null\n\n const padding = 24\n const axisSpacing = (area.width - padding * 2) / Math.max(dimCount - 1, 1)\n const axisTop = area.y + padding\n const axisBottom = area.y + area.height - padding\n\n const mins: number[] = new Array(dimCount).fill(Infinity)\n const maxs: number[] = new Array(dimCount).fill(-Infinity)\n for (const series of data.series) {\n for (let d = 0; d < dimCount; d++) {\n const v = series.values[d] ?? 0\n if (v < mins[d]!) mins[d] = v\n if (v > maxs[d]!) maxs[d] = v\n }\n }\n for (let d = 0; d < dimCount; d++) {\n if (mins[d] === maxs[d]) { mins[d] = mins[d]! - 1; maxs[d] = maxs[d]! + 1 }\n }\n\n const axisX = (dim: number) => area.x + padding + dim * axisSpacing\n const valueToY = (dim: number, value: number) => {\n const frac = (value - mins[dim]!) / (maxs[dim]! - mins[dim]!)\n return axisBottom - frac * (axisBottom - axisTop)\n }\n\n // Find closest series line\n let best: HitResult | null = null\n let bestDist = 20 // max hit distance\n\n for (let si = 0; si < data.series.length; si++) {\n const series = data.series[si]!\n for (let d = 0; d < dimCount; d++) {\n const x = axisX(d)\n const y = valueToY(d, series.values[d] ?? 0)\n const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2)\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: si, pointIndex: d, distance: dist, x, y }\n }\n }\n }\n\n return best\n },\n}\n"]}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
|
|
4
4
|
|
|
5
5
|
// src/utils/prepare.ts
|
|
6
6
|
function prepareNoAxes(data, options) {
|
|
7
|
-
return
|
|
7
|
+
return chunkJVVGQLJQ_cjs.prepareData(data, {
|
|
8
8
|
...options,
|
|
9
9
|
xAxis: false,
|
|
10
10
|
yAxis: false,
|
|
@@ -15,5 +15,5 @@ function prepareNoAxes(data, options) {
|
|
|
15
15
|
}
|
|
16
16
|
|
|
17
17
|
exports.prepareNoAxes = prepareNoAxes;
|
|
18
|
-
//# sourceMappingURL=chunk-
|
|
19
|
-
//# sourceMappingURL=chunk-
|
|
18
|
+
//# sourceMappingURL=chunk-V5Q6UNUK.cjs.map
|
|
19
|
+
//# sourceMappingURL=chunk-V5Q6UNUK.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/utils/prepare.ts"],"names":["prepareData"],"mappings":";;;;;AAOO,SAAS,aAAA,CAAc,MAAiB,OAAA,EAAwC;AACrF,EAAA,OAAOA,8BAAY,IAAA,EAAM;AAAA,IACvB,GAAG,OAAA;AAAA,IACH,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,MAAA,EAAQ;AAAA,GACT,CAAA;AACH","file":"chunk-
|
|
1
|
+
{"version":3,"sources":["../src/utils/prepare.ts"],"names":["prepareData"],"mappings":";;;;;AAOO,SAAS,aAAA,CAAc,MAAiB,OAAA,EAAwC;AACrF,EAAA,OAAOA,8BAAY,IAAA,EAAM;AAAA,IACvB,GAAG,OAAA;AAAA,IACH,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,KAAA,EAAO,KAAA;AAAA,IACP,MAAA,EAAQ;AAAA,GACT,CAAA;AACH","file":"chunk-V5Q6UNUK.cjs","sourcesContent":["import type { ChartData, ResolvedOptions, PreparedData } from '../types'\nimport { prepareData } from '../data/prepare'\n\n/**\n * Prepare data with axes, grid, and legend suppressed.\n * Used by chart types that render their own layout (pie, gauge, treemap, etc.).\n */\nexport function prepareNoAxes(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareData(data, {\n ...options,\n xAxis: false,\n yAxis: false,\n xGrid: false,\n yGrid: false,\n legend: false,\n })\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { prepareNoAxes } from './chunk-
|
|
2
|
-
import { PathBuilder, path, text, group } from './chunk-
|
|
1
|
+
import { prepareNoAxes } from './chunk-T7SCCACB.js';
|
|
2
|
+
import { PathBuilder, path, text, group } from './chunk-AEQXFDL7.js';
|
|
3
3
|
|
|
4
4
|
// src/charts/kagi/kagi-type.ts
|
|
5
5
|
var kagiChartType = {
|
|
@@ -150,5 +150,5 @@ function computeKagiSegments(values, reversal) {
|
|
|
150
150
|
}
|
|
151
151
|
|
|
152
152
|
export { kagiChartType };
|
|
153
|
-
//# sourceMappingURL=chunk-
|
|
154
|
-
//# sourceMappingURL=chunk-
|
|
153
|
+
//# sourceMappingURL=chunk-VBMLJUBE.js.map
|
|
154
|
+
//# sourceMappingURL=chunk-VBMLJUBE.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/kagi/kagi-type.ts"],"names":[],"mappings":"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","file":"chunk-BT5H3WMI.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, path, 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":[],"mappings":"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","file":"chunk-VBMLJUBE.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, path, 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"]}
|