@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,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/themeriver/themeriver-type.ts
|
|
7
7
|
var themeRiverChartType = {
|
|
@@ -10,7 +10,7 @@ var themeRiverChartType = {
|
|
|
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;
|
|
@@ -65,7 +65,7 @@ var themeRiverChartType = {
|
|
|
65
65
|
tops.push({ x: mapX(t), y: mapY(cumTop) });
|
|
66
66
|
bottoms.push({ x: mapX(t), y: mapY(cumBottom) });
|
|
67
67
|
}
|
|
68
|
-
const pb = new
|
|
68
|
+
const pb = new chunkJVVGQLJQ_cjs.PathBuilder();
|
|
69
69
|
pb.moveTo(tops[0].x, tops[0].y);
|
|
70
70
|
for (let t = 1; t < timeCount; t++) {
|
|
71
71
|
const prev = tops[t - 1];
|
|
@@ -81,7 +81,7 @@ var themeRiverChartType = {
|
|
|
81
81
|
pb.curveTo(cpx, prev.y, cpx, curr.y, curr.x, curr.y);
|
|
82
82
|
}
|
|
83
83
|
pb.close();
|
|
84
|
-
nodes.push(
|
|
84
|
+
nodes.push(chunkJVVGQLJQ_cjs.path(pb.build(), {
|
|
85
85
|
class: "chartts-themeriver-stream",
|
|
86
86
|
fill: color,
|
|
87
87
|
fillOpacity: 0.75,
|
|
@@ -104,7 +104,7 @@ var themeRiverChartType = {
|
|
|
104
104
|
if (maxWidth > 16) {
|
|
105
105
|
const midY = (tops[maxT].y + bottoms[maxT].y) / 2;
|
|
106
106
|
const fontSize = Math.min(theme.fontSizeSmall, maxWidth * 0.4);
|
|
107
|
-
nodes.push(
|
|
107
|
+
nodes.push(chunkJVVGQLJQ_cjs.text(tops[maxT].x, midY, series.name, {
|
|
108
108
|
class: "chartts-themeriver-label",
|
|
109
109
|
fill: "#fff",
|
|
110
110
|
textAnchor: "middle",
|
|
@@ -165,5 +165,5 @@ var themeRiverChartType = {
|
|
|
165
165
|
};
|
|
166
166
|
|
|
167
167
|
exports.themeRiverChartType = themeRiverChartType;
|
|
168
|
-
//# sourceMappingURL=chunk-
|
|
169
|
-
//# sourceMappingURL=chunk-
|
|
168
|
+
//# sourceMappingURL=chunk-JYVRX3BX.cjs.map
|
|
169
|
+
//# sourceMappingURL=chunk-JYVRX3BX.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/themeriver/themeriver-type.ts"],"names":["prepareNoAxes","PathBuilder","path","text"],"mappings":"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","file":"chunk-MY4KMVJ5.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { path, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * ThemeRiver / StreamGraph chart — stacked area chart with a center baseline.\n *\n * Data convention:\n * - labels: time points (x-axis categories)\n * - series[i]: a stream layer. values[j] = thickness at time j\n *\n * The streams are stacked symmetrically around the horizontal center,\n * creating an organic river-like visualization.\n */\n\nexport const themeRiverChartType: ChartTypePlugin = {\n type: 'themeriver',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const timeCount = data.labels.length\n if (timeCount < 2 || data.series.length === 0) return nodes\n\n const seriesCount = data.series.length\n\n // Compute stacked values\n const stacks: number[][] = []\n for (let t = 0; t < timeCount; t++) {\n const column: number[] = []\n for (let si = 0; si < seriesCount; si++) {\n column.push(Math.abs(data.series[si]!.values[t] ?? 0))\n }\n stacks.push(column)\n }\n\n // Compute baseline offsets (wiggle / silhouette centering)\n const baselines: number[] = []\n for (let t = 0; t < timeCount; t++) {\n const total = stacks[t]!.reduce((s, v) => s + v, 0)\n baselines.push(-total / 2) // Center around 0\n }\n\n // Find global min/max for y-scale\n let yMin = Infinity\n let yMax = -Infinity\n for (let t = 0; t < timeCount; t++) {\n let cumulative = baselines[t]!\n if (cumulative < yMin) yMin = cumulative\n for (let si = 0; si < seriesCount; si++) {\n cumulative += stacks[t]![si]!\n }\n if (cumulative > yMax) yMax = cumulative\n }\n if (yMin === yMax) { yMin -= 1; yMax += 1 }\n\n const xStep = area.width / Math.max(timeCount - 1, 1)\n const mapX = (t: number) => area.x + t * xStep\n const mapY = (val: number) => {\n const frac = (val - yMin) / (yMax - yMin)\n return area.y + area.height - frac * area.height\n }\n\n // Render each series as a stream band\n for (let si = 0; si < seriesCount; si++) {\n const series = data.series[si]!\n const color = series.color ?? options.colors[si % options.colors.length]!\n\n // Compute top and bottom edges for this series\n const tops: { x: number; y: number }[] = []\n const bottoms: { x: number; y: number }[] = []\n\n for (let t = 0; t < timeCount; t++) {\n let cumBottom = baselines[t]!\n for (let s = 0; s < si; s++) {\n cumBottom += stacks[t]![s]!\n }\n const cumTop = cumBottom + stacks[t]![si]!\n\n tops.push({ x: mapX(t), y: mapY(cumTop) })\n bottoms.push({ x: mapX(t), y: mapY(cumBottom) })\n }\n\n // Build smooth path: top edge forward, bottom edge backward\n const pb = new PathBuilder()\n\n // Top edge (left to right)\n pb.moveTo(tops[0]!.x, tops[0]!.y)\n for (let t = 1; t < timeCount; t++) {\n const prev = tops[t - 1]!\n const curr = tops[t]!\n const cpx = (prev.x + curr.x) / 2\n pb.curveTo(cpx, prev.y, cpx, curr.y, curr.x, curr.y)\n }\n\n // Bottom edge (right to left)\n pb.lineTo(bottoms[timeCount - 1]!.x, bottoms[timeCount - 1]!.y)\n for (let t = timeCount - 2; t >= 0; t--) {\n const prev = bottoms[t + 1]!\n const curr = bottoms[t]!\n const cpx = (prev.x + curr.x) / 2\n pb.curveTo(cpx, prev.y, cpx, curr.y, curr.x, curr.y)\n }\n\n pb.close()\n\n nodes.push(path(pb.build(), {\n class: 'chartts-themeriver-stream',\n fill: color,\n fillOpacity: 0.75,\n stroke: color,\n strokeWidth: 0.5,\n 'data-series': si,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}`,\n }))\n\n // Label at the widest point\n let maxWidth = 0\n let maxT = 0\n for (let t = 0; t < timeCount; t++) {\n const width = Math.abs(tops[t]!.y - bottoms[t]!.y)\n if (width > maxWidth) {\n maxWidth = width\n maxT = t\n }\n }\n\n if (maxWidth > 16) {\n const midY = (tops[maxT]!.y + bottoms[maxT]!.y) / 2\n const fontSize = Math.min(theme.fontSizeSmall, maxWidth * 0.4)\n nodes.push(text(tops[maxT]!.x, midY, series.name, {\n class: 'chartts-themeriver-label',\n fill: '#fff',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n }\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const timeCount = data.labels.length\n if (timeCount < 2 || data.series.length === 0) return null\n\n const seriesCount = data.series.length\n const xStep = area.width / Math.max(timeCount - 1, 1)\n\n // Find closest time index\n const t = Math.round((mx - area.x) / xStep)\n if (t < 0 || t >= timeCount) return null\n\n // Compute stacks at this time\n const column: number[] = []\n for (let si = 0; si < seriesCount; si++) {\n column.push(Math.abs(data.series[si]!.values[t] ?? 0))\n }\n const total = column.reduce((s, v) => s + v, 0)\n const baseline = -total / 2\n\n // Find global scale\n let yMin = Infinity\n let yMax = -Infinity\n for (let tt = 0; tt < timeCount; tt++) {\n let cum = 0\n for (let si = 0; si < seriesCount; si++) {\n cum += Math.abs(data.series[si]!.values[tt] ?? 0)\n }\n const bl = -cum / 2\n if (bl < yMin) yMin = bl\n if (bl + cum > yMax) yMax = bl + cum\n }\n if (yMin === yMax) { yMin -= 1; yMax += 1 }\n\n const mapY = (val: number) => {\n const frac = (val - yMin) / (yMax - yMin)\n return area.y + area.height - frac * area.height\n }\n\n // Check which stream the y coordinate falls in\n let cumBottom = baseline\n for (let si = 0; si < seriesCount; si++) {\n const cumTop = cumBottom + column[si]!\n const topY = mapY(cumTop)\n const bottomY = mapY(cumBottom)\n\n if (my >= topY && my <= bottomY) {\n return { seriesIndex: si, pointIndex: t, distance: 0, x: area.x + t * xStep, y: mapY((cumBottom + cumTop) / 2) }\n }\n cumBottom = cumTop\n }\n\n return null\n },\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/charts/themeriver/themeriver-type.ts"],"names":["prepareNoAxes","PathBuilder","path","text"],"mappings":"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","file":"chunk-JYVRX3BX.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { path, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * ThemeRiver / StreamGraph chart — stacked area chart with a center baseline.\n *\n * Data convention:\n * - labels: time points (x-axis categories)\n * - series[i]: a stream layer. values[j] = thickness at time j\n *\n * The streams are stacked symmetrically around the horizontal center,\n * creating an organic river-like visualization.\n */\n\nexport const themeRiverChartType: ChartTypePlugin = {\n type: 'themeriver',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const timeCount = data.labels.length\n if (timeCount < 2 || data.series.length === 0) return nodes\n\n const seriesCount = data.series.length\n\n // Compute stacked values\n const stacks: number[][] = []\n for (let t = 0; t < timeCount; t++) {\n const column: number[] = []\n for (let si = 0; si < seriesCount; si++) {\n column.push(Math.abs(data.series[si]!.values[t] ?? 0))\n }\n stacks.push(column)\n }\n\n // Compute baseline offsets (wiggle / silhouette centering)\n const baselines: number[] = []\n for (let t = 0; t < timeCount; t++) {\n const total = stacks[t]!.reduce((s, v) => s + v, 0)\n baselines.push(-total / 2) // Center around 0\n }\n\n // Find global min/max for y-scale\n let yMin = Infinity\n let yMax = -Infinity\n for (let t = 0; t < timeCount; t++) {\n let cumulative = baselines[t]!\n if (cumulative < yMin) yMin = cumulative\n for (let si = 0; si < seriesCount; si++) {\n cumulative += stacks[t]![si]!\n }\n if (cumulative > yMax) yMax = cumulative\n }\n if (yMin === yMax) { yMin -= 1; yMax += 1 }\n\n const xStep = area.width / Math.max(timeCount - 1, 1)\n const mapX = (t: number) => area.x + t * xStep\n const mapY = (val: number) => {\n const frac = (val - yMin) / (yMax - yMin)\n return area.y + area.height - frac * area.height\n }\n\n // Render each series as a stream band\n for (let si = 0; si < seriesCount; si++) {\n const series = data.series[si]!\n const color = series.color ?? options.colors[si % options.colors.length]!\n\n // Compute top and bottom edges for this series\n const tops: { x: number; y: number }[] = []\n const bottoms: { x: number; y: number }[] = []\n\n for (let t = 0; t < timeCount; t++) {\n let cumBottom = baselines[t]!\n for (let s = 0; s < si; s++) {\n cumBottom += stacks[t]![s]!\n }\n const cumTop = cumBottom + stacks[t]![si]!\n\n tops.push({ x: mapX(t), y: mapY(cumTop) })\n bottoms.push({ x: mapX(t), y: mapY(cumBottom) })\n }\n\n // Build smooth path: top edge forward, bottom edge backward\n const pb = new PathBuilder()\n\n // Top edge (left to right)\n pb.moveTo(tops[0]!.x, tops[0]!.y)\n for (let t = 1; t < timeCount; t++) {\n const prev = tops[t - 1]!\n const curr = tops[t]!\n const cpx = (prev.x + curr.x) / 2\n pb.curveTo(cpx, prev.y, cpx, curr.y, curr.x, curr.y)\n }\n\n // Bottom edge (right to left)\n pb.lineTo(bottoms[timeCount - 1]!.x, bottoms[timeCount - 1]!.y)\n for (let t = timeCount - 2; t >= 0; t--) {\n const prev = bottoms[t + 1]!\n const curr = bottoms[t]!\n const cpx = (prev.x + curr.x) / 2\n pb.curveTo(cpx, prev.y, cpx, curr.y, curr.x, curr.y)\n }\n\n pb.close()\n\n nodes.push(path(pb.build(), {\n class: 'chartts-themeriver-stream',\n fill: color,\n fillOpacity: 0.75,\n stroke: color,\n strokeWidth: 0.5,\n 'data-series': si,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}`,\n }))\n\n // Label at the widest point\n let maxWidth = 0\n let maxT = 0\n for (let t = 0; t < timeCount; t++) {\n const width = Math.abs(tops[t]!.y - bottoms[t]!.y)\n if (width > maxWidth) {\n maxWidth = width\n maxT = t\n }\n }\n\n if (maxWidth > 16) {\n const midY = (tops[maxT]!.y + bottoms[maxT]!.y) / 2\n const fontSize = Math.min(theme.fontSizeSmall, maxWidth * 0.4)\n nodes.push(text(tops[maxT]!.x, midY, series.name, {\n class: 'chartts-themeriver-label',\n fill: '#fff',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n }\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const timeCount = data.labels.length\n if (timeCount < 2 || data.series.length === 0) return null\n\n const seriesCount = data.series.length\n const xStep = area.width / Math.max(timeCount - 1, 1)\n\n // Find closest time index\n const t = Math.round((mx - area.x) / xStep)\n if (t < 0 || t >= timeCount) return null\n\n // Compute stacks at this time\n const column: number[] = []\n for (let si = 0; si < seriesCount; si++) {\n column.push(Math.abs(data.series[si]!.values[t] ?? 0))\n }\n const total = column.reduce((s, v) => s + v, 0)\n const baseline = -total / 2\n\n // Find global scale\n let yMin = Infinity\n let yMax = -Infinity\n for (let tt = 0; tt < timeCount; tt++) {\n let cum = 0\n for (let si = 0; si < seriesCount; si++) {\n cum += Math.abs(data.series[si]!.values[tt] ?? 0)\n }\n const bl = -cum / 2\n if (bl < yMin) yMin = bl\n if (bl + cum > yMax) yMax = bl + cum\n }\n if (yMin === yMax) { yMin -= 1; yMax += 1 }\n\n const mapY = (val: number) => {\n const frac = (val - yMin) / (yMax - yMin)\n return area.y + area.height - frac * area.height\n }\n\n // Check which stream the y coordinate falls in\n let cumBottom = baseline\n for (let si = 0; si < seriesCount; si++) {\n const cumTop = cumBottom + column[si]!\n const topY = mapY(cumTop)\n const bottomY = mapY(cumBottom)\n\n if (my >= topY && my <= bottomY) {\n return { seriesIndex: si, pointIndex: t, distance: 0, x: area.x + t * xStep, y: mapY((cumBottom + cumTop) / 2) }\n }\n cumBottom = cumTop\n }\n\n return null\n },\n}\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { lineChartType } from './chunk-
|
|
1
|
+
import { lineChartType } from './chunk-ZOEN3ARN.js';
|
|
2
2
|
|
|
3
3
|
// src/charts/area/area-type.ts
|
|
4
4
|
var areaChartType = {
|
|
@@ -26,5 +26,5 @@ var areaChartType = {
|
|
|
26
26
|
};
|
|
27
27
|
|
|
28
28
|
export { areaChartType };
|
|
29
|
-
//# sourceMappingURL=chunk-
|
|
30
|
-
//# sourceMappingURL=chunk-
|
|
29
|
+
//# sourceMappingURL=chunk-KHG3G2ZX.js.map
|
|
30
|
+
//# sourceMappingURL=chunk-KHG3G2ZX.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/area/area-type.ts"],"names":[],"mappings":";;;AAUO,IAAM,aAAA,GAAiC;AAAA,EAC5C,IAAA,EAAM,MAAA;AAAA,EAEN,aAAA,GAAgD;AAC9C,IAAA,OAAO,EAAE,CAAA,EAAG,aAAA,EAAe,CAAA,EAAG,QAAA,EAAS;AAAA,EACzC,CAAA;AAAA,EAEA,WAAA,CAAY,MAAiB,OAAA,EAAwC;AAEnE,IAAA,MAAM,MAAA,GAAoB;AAAA,MACxB,GAAG,IAAA;AAAA,MACH,MAAA,EAAQ,IAAA,CAAK,MAAA,CAAO,GAAA,CAAI,CAAA,CAAA,MAAM;AAAA,QAC5B,GAAG,CAAA;AAAA,QACH,IAAA,EAAM,EAAE,IAAA,IAAQ,IAAA;AAAA,QAChB,WAAA,EAAa,EAAE,WAAA,IAAe;AAAA,OAChC,CAAE;AAAA,KACJ;AACA,IAAA,OAAO,aAAA,CAAc,WAAA,CAAY,MAAA,EAAQ,OAAO,CAAA;AAAA,EAClD,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,OAAO,aAAA,CAAc,OAAO,GAAG,CAAA;AAAA,EACjC,CAAA;AAAA,EAEA,OAAA,CAAQ,GAAA,EAAoB,EAAA,EAAY,EAAA,EAA8B;AACpE,IAAA,OAAO,aAAA,CAAc,OAAA,CAAQ,GAAA,EAAK,EAAA,EAAI,EAAE,CAAA;AAAA,EAC1C;AACF","file":"chunk-
|
|
1
|
+
{"version":3,"sources":["../src/charts/area/area-type.ts"],"names":[],"mappings":";;;AAUO,IAAM,aAAA,GAAiC;AAAA,EAC5C,IAAA,EAAM,MAAA;AAAA,EAEN,aAAA,GAAgD;AAC9C,IAAA,OAAO,EAAE,CAAA,EAAG,aAAA,EAAe,CAAA,EAAG,QAAA,EAAS;AAAA,EACzC,CAAA;AAAA,EAEA,WAAA,CAAY,MAAiB,OAAA,EAAwC;AAEnE,IAAA,MAAM,MAAA,GAAoB;AAAA,MACxB,GAAG,IAAA;AAAA,MACH,MAAA,EAAQ,IAAA,CAAK,MAAA,CAAO,GAAA,CAAI,CAAA,CAAA,MAAM;AAAA,QAC5B,GAAG,CAAA;AAAA,QACH,IAAA,EAAM,EAAE,IAAA,IAAQ,IAAA;AAAA,QAChB,WAAA,EAAa,EAAE,WAAA,IAAe;AAAA,OAChC,CAAE;AAAA,KACJ;AACA,IAAA,OAAO,aAAA,CAAc,WAAA,CAAY,MAAA,EAAQ,OAAO,CAAA;AAAA,EAClD,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,OAAO,aAAA,CAAc,OAAO,GAAG,CAAA;AAAA,EACjC,CAAA;AAAA,EAEA,OAAA,CAAQ,GAAA,EAAoB,EAAA,EAAY,EAAA,EAA8B;AACpE,IAAA,OAAO,aAAA,CAAc,OAAA,CAAQ,GAAA,EAAK,EAAA,EAAI,EAAE,CAAA;AAAA,EAC1C;AACF","file":"chunk-KHG3G2ZX.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { lineChartType } from '../line/line-type'\n\n/**\n * Area chart — line chart with fill enabled on all series by default.\n * Delegates entirely to lineChartType after forcing fill:true.\n */\nexport const areaChartType: ChartTypePlugin = {\n type: 'area',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n // Force fill on all series\n const filled: ChartData = {\n ...data,\n series: data.series.map(s => ({\n ...s,\n fill: s.fill ?? true,\n fillOpacity: s.fillOpacity ?? 0.25,\n })),\n }\n return lineChartType.prepareData(filled, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n return lineChartType.render(ctx)\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n return lineChartType.hitTest(ctx, mx, my)\n },\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { prepareNoAxes } from './chunk-
|
|
2
|
-
import { rect, text, group } from './chunk-
|
|
1
|
+
import { prepareNoAxes } from './chunk-T7SCCACB.js';
|
|
2
|
+
import { rect, text, group } from './chunk-AEQXFDL7.js';
|
|
3
3
|
|
|
4
4
|
// src/charts/treemap/treemap-type.ts
|
|
5
5
|
var treemapChartType = {
|
|
@@ -147,5 +147,5 @@ function layoutRow(values, start, x, y, w, h, rects) {
|
|
|
147
147
|
}
|
|
148
148
|
|
|
149
149
|
export { treemapChartType };
|
|
150
|
-
//# sourceMappingURL=chunk-
|
|
151
|
-
//# sourceMappingURL=chunk-
|
|
150
|
+
//# sourceMappingURL=chunk-KNMEXOKJ.js.map
|
|
151
|
+
//# sourceMappingURL=chunk-KNMEXOKJ.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/treemap/treemap-type.ts"],"names":["rowThickness"],"mappings":"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","file":"chunk-ASNAQ35U.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, rect, text } from '../../render/tree'\n\n/**\n * Treemap chart — rectangular space-filling visualization.\n *\n * Uses the first series' values as areas. Labels are cell labels.\n * Implements a simple squarified treemap layout.\n */\nexport const treemapChartType: ChartTypePlugin = {\n type: 'treemap',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n // Build items sorted by value descending\n const items = series.values\n .map((v, i) => ({ value: Math.abs(v), index: i }))\n .filter(d => d.value > 0)\n .sort((a, b) => b.value - a.value)\n\n if (items.length === 0) return nodes\n\n const total = items.reduce((s, d) => s + d.value, 0)\n const gap = 2\n\n // Layout using slice-and-dice (simpler, works well)\n const rects = squarify(items.map(d => d.value / total), area.x, area.y, area.width, area.height)\n\n for (let k = 0; k < items.length; k++) {\n const item = items[k]!\n const r = rects[k]!\n const colorIndex = item.index % options.colors.length\n const color = options.colors[colorIndex]!\n const label = String(data.labels[item.index] ?? `Item ${item.index + 1}`)\n\n const cellNodes: RenderNode[] = []\n\n cellNodes.push(rect(r.x + gap / 2, r.y + gap / 2, r.w - gap, r.h - gap, {\n class: 'chartts-treemap-cell',\n fill: color,\n fillOpacity: 0.75,\n rx: 5,\n ry: 5,\n 'data-series': 0,\n 'data-index': item.index,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label}: ${series.values[item.index]}`,\n }))\n\n // Only show label if cell is big enough\n if (r.w > 30 && r.h > 20) {\n const fontSize = Math.min(theme.fontSizeSmall, r.w * 0.15, r.h * 0.3)\n cellNodes.push(text(r.x + r.w / 2, r.y + r.h / 2 - fontSize * 0.3, label, {\n class: 'chartts-treemap-label',\n fill: '#fff',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n\n // Show value below label\n if (r.h > 35) {\n cellNodes.push(text(r.x + r.w / 2, r.y + r.h / 2 + fontSize * 0.8, String(series.values[item.index]), {\n class: 'chartts-treemap-value',\n fill: 'rgba(255,255,255,0.7)',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: fontSize * 0.85,\n fontFamily: theme.fontFamily,\n }))\n }\n }\n\n nodes.push(group(cellNodes, {\n class: `chartts-series chartts-series-${item.index}`,\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 series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const items = series.values\n .map((v, i) => ({ value: Math.abs(v), index: i }))\n .filter(d => d.value > 0)\n .sort((a, b) => b.value - a.value)\n\n if (items.length === 0) return null\n const total = items.reduce((s, d) => s + d.value, 0)\n const rects = squarify(items.map(d => d.value / total), area.x, area.y, area.width, area.height)\n\n for (let k = 0; k < items.length; k++) {\n const r = rects[k]!\n if (mx >= r.x && mx <= r.x + r.w && my >= r.y && my <= r.y + r.h) {\n return { seriesIndex: 0, pointIndex: items[k]!.index, distance: 0, x: r.x + r.w / 2, y: r.y + r.h / 2 }\n }\n }\n\n return null\n },\n}\n\ninterface Rect { x: number; y: number; w: number; h: number }\n\n/**\n * Squarified treemap layout.\n * Takes normalized values (sum to 1) and fills a rectangle.\n */\nfunction squarify(values: number[], x: number, y: number, w: number, h: number): Rect[] {\n const rects: Rect[] = []\n layoutRow(values, 0, x, y, w, h, rects)\n return rects\n}\n\nfunction layoutRow(\n values: number[], start: number,\n x: number, y: number, w: number, h: number,\n rects: Rect[],\n): void {\n if (start >= values.length) return\n if (values.length - start === 1) {\n rects.push({ x, y, w, h })\n return\n }\n\n const isWide = w >= h\n\n // Greedily add items to the current row until aspect ratio gets worse\n let rowSum = 0\n let bestWorst = Infinity\n let rowEnd = start\n\n for (let i = start; i < values.length; i++) {\n const newSum = rowSum + values[i]!\n\n // Compute row takes up fraction of the short side\n const rowFraction = newSum\n const rowThickness = isWide ? w * rowFraction : h * rowFraction\n const count = i - start + 1\n\n if (rowThickness <= 0) { rowSum = newSum; rowEnd = i + 1; continue }\n\n // Worst aspect ratio in this row\n let worst = 0\n for (let j = start; j <= i; j++) {\n const cellFrac = values[j]! / newSum\n const cellLen = isWide ? h * cellFrac : w * cellFrac\n const ar = Math.max(rowThickness / cellLen, cellLen / rowThickness)\n if (ar > worst) worst = ar\n }\n\n if (count === 1 || worst <= bestWorst) {\n bestWorst = worst\n rowSum = newSum\n rowEnd = i + 1\n } else {\n break\n }\n }\n\n if (rowEnd === start) rowEnd = start + 1\n const finalSum = values.slice(start, rowEnd).reduce((a, b) => a + b, 0)\n\n // Lay out this row\n const rowThickness = isWide ? w * finalSum : h * finalSum\n let offset = 0\n\n for (let i = start; i < rowEnd; i++) {\n const frac = finalSum > 0 ? values[i]! / finalSum : 0\n const cellLen = isWide ? h * frac : w * frac\n\n if (isWide) {\n rects.push({ x, y: y + offset, w: rowThickness, h: cellLen })\n } else {\n rects.push({ x: x + offset, y, w: cellLen, h: rowThickness })\n }\n offset += cellLen\n }\n\n // Recurse for remaining items\n if (isWide) {\n layoutRow(values, rowEnd, x + rowThickness, y, w - rowThickness, h, rects)\n } else {\n layoutRow(values, rowEnd, x, y + rowThickness, w, h - rowThickness, rects)\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/charts/treemap/treemap-type.ts"],"names":["rowThickness"],"mappings":"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","file":"chunk-KNMEXOKJ.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, rect, text } from '../../render/tree'\n\n/**\n * Treemap chart — rectangular space-filling visualization.\n *\n * Uses the first series' values as areas. Labels are cell labels.\n * Implements a simple squarified treemap layout.\n */\nexport const treemapChartType: ChartTypePlugin = {\n type: 'treemap',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n // Build items sorted by value descending\n const items = series.values\n .map((v, i) => ({ value: Math.abs(v), index: i }))\n .filter(d => d.value > 0)\n .sort((a, b) => b.value - a.value)\n\n if (items.length === 0) return nodes\n\n const total = items.reduce((s, d) => s + d.value, 0)\n const gap = 2\n\n // Layout using slice-and-dice (simpler, works well)\n const rects = squarify(items.map(d => d.value / total), area.x, area.y, area.width, area.height)\n\n for (let k = 0; k < items.length; k++) {\n const item = items[k]!\n const r = rects[k]!\n const colorIndex = item.index % options.colors.length\n const color = options.colors[colorIndex]!\n const label = String(data.labels[item.index] ?? `Item ${item.index + 1}`)\n\n const cellNodes: RenderNode[] = []\n\n cellNodes.push(rect(r.x + gap / 2, r.y + gap / 2, r.w - gap, r.h - gap, {\n class: 'chartts-treemap-cell',\n fill: color,\n fillOpacity: 0.75,\n rx: 5,\n ry: 5,\n 'data-series': 0,\n 'data-index': item.index,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${label}: ${series.values[item.index]}`,\n }))\n\n // Only show label if cell is big enough\n if (r.w > 30 && r.h > 20) {\n const fontSize = Math.min(theme.fontSizeSmall, r.w * 0.15, r.h * 0.3)\n cellNodes.push(text(r.x + r.w / 2, r.y + r.h / 2 - fontSize * 0.3, label, {\n class: 'chartts-treemap-label',\n fill: '#fff',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize,\n fontFamily: theme.fontFamily,\n fontWeight: 600,\n }))\n\n // Show value below label\n if (r.h > 35) {\n cellNodes.push(text(r.x + r.w / 2, r.y + r.h / 2 + fontSize * 0.8, String(series.values[item.index]), {\n class: 'chartts-treemap-value',\n fill: 'rgba(255,255,255,0.7)',\n textAnchor: 'middle',\n dominantBaseline: 'central',\n fontSize: fontSize * 0.85,\n fontFamily: theme.fontFamily,\n }))\n }\n }\n\n nodes.push(group(cellNodes, {\n class: `chartts-series chartts-series-${item.index}`,\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 series = data.series[0]\n if (!series || series.values.length === 0) return null\n\n const items = series.values\n .map((v, i) => ({ value: Math.abs(v), index: i }))\n .filter(d => d.value > 0)\n .sort((a, b) => b.value - a.value)\n\n if (items.length === 0) return null\n const total = items.reduce((s, d) => s + d.value, 0)\n const rects = squarify(items.map(d => d.value / total), area.x, area.y, area.width, area.height)\n\n for (let k = 0; k < items.length; k++) {\n const r = rects[k]!\n if (mx >= r.x && mx <= r.x + r.w && my >= r.y && my <= r.y + r.h) {\n return { seriesIndex: 0, pointIndex: items[k]!.index, distance: 0, x: r.x + r.w / 2, y: r.y + r.h / 2 }\n }\n }\n\n return null\n },\n}\n\ninterface Rect { x: number; y: number; w: number; h: number }\n\n/**\n * Squarified treemap layout.\n * Takes normalized values (sum to 1) and fills a rectangle.\n */\nfunction squarify(values: number[], x: number, y: number, w: number, h: number): Rect[] {\n const rects: Rect[] = []\n layoutRow(values, 0, x, y, w, h, rects)\n return rects\n}\n\nfunction layoutRow(\n values: number[], start: number,\n x: number, y: number, w: number, h: number,\n rects: Rect[],\n): void {\n if (start >= values.length) return\n if (values.length - start === 1) {\n rects.push({ x, y, w, h })\n return\n }\n\n const isWide = w >= h\n\n // Greedily add items to the current row until aspect ratio gets worse\n let rowSum = 0\n let bestWorst = Infinity\n let rowEnd = start\n\n for (let i = start; i < values.length; i++) {\n const newSum = rowSum + values[i]!\n\n // Compute row takes up fraction of the short side\n const rowFraction = newSum\n const rowThickness = isWide ? w * rowFraction : h * rowFraction\n const count = i - start + 1\n\n if (rowThickness <= 0) { rowSum = newSum; rowEnd = i + 1; continue }\n\n // Worst aspect ratio in this row\n let worst = 0\n for (let j = start; j <= i; j++) {\n const cellFrac = values[j]! / newSum\n const cellLen = isWide ? h * cellFrac : w * cellFrac\n const ar = Math.max(rowThickness / cellLen, cellLen / rowThickness)\n if (ar > worst) worst = ar\n }\n\n if (count === 1 || worst <= bestWorst) {\n bestWorst = worst\n rowSum = newSum\n rowEnd = i + 1\n } else {\n break\n }\n }\n\n if (rowEnd === start) rowEnd = start + 1\n const finalSum = values.slice(start, rowEnd).reduce((a, b) => a + b, 0)\n\n // Lay out this row\n const rowThickness = isWide ? w * finalSum : h * finalSum\n let offset = 0\n\n for (let i = start; i < rowEnd; i++) {\n const frac = finalSum > 0 ? values[i]! / finalSum : 0\n const cellLen = isWide ? h * frac : w * frac\n\n if (isWide) {\n rects.push({ x, y: y + offset, w: rowThickness, h: cellLen })\n } else {\n rects.push({ x: x + offset, y, w: cellLen, h: rowThickness })\n }\n offset += cellLen\n }\n\n // Recurse for remaining items\n if (isWide) {\n layoutRow(values, rowEnd, x + rowThickness, y, w - rowThickness, h, rects)\n } else {\n layoutRow(values, rowEnd, x, y + rowThickness, w, h - rowThickness, rects)\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/slice-path.ts
|
|
6
6
|
function roundedSlicePath(cx, cy, outerR, innerR, outerStart, outerEnd, innerStart, innerEnd, cornerRadius) {
|
|
7
|
-
const pb = new
|
|
7
|
+
const pb = new chunkJVVGQLJQ_cjs.PathBuilder();
|
|
8
8
|
const outerSliceAngle = outerEnd - outerStart;
|
|
9
9
|
const innerSliceAngle = innerEnd - innerStart;
|
|
10
10
|
const radialThickness = outerR - innerR;
|
|
@@ -124,5 +124,5 @@ function roundedSlicePath(cx, cy, outerR, innerR, outerStart, outerEnd, innerSta
|
|
|
124
124
|
}
|
|
125
125
|
|
|
126
126
|
exports.roundedSlicePath = roundedSlicePath;
|
|
127
|
-
//# sourceMappingURL=chunk-
|
|
128
|
-
//# sourceMappingURL=chunk-
|
|
127
|
+
//# sourceMappingURL=chunk-KWSVJRXX.cjs.map
|
|
128
|
+
//# sourceMappingURL=chunk-KWSVJRXX.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/utils/slice-path.ts"],"names":["PathBuilder"],"mappings":"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","file":"chunk-WYIIWTIR.cjs","sourcesContent":["import { PathBuilder } from '../render/tree'\n\n/**\n * Build a rounded annular sector (pie/donut slice) SVG path string.\n *\n * Supports different angular offsets at inner vs outer radius for uniform\n * pixel-width gaps between slices.\n *\n * @param cx - Center x\n * @param cy - Center y\n * @param outerR - Outer radius\n * @param innerR - Inner radius (0 for full pie, >0 for donut)\n * @param outerStart - Start angle on outer arc (radians)\n * @param outerEnd - End angle on outer arc (radians)\n * @param innerStart - Start angle on inner arc (radians)\n * @param innerEnd - End angle on inner arc (radians)\n * @param cornerRadius - Corner rounding radius in px\n */\nexport function roundedSlicePath(\n cx: number, cy: number,\n outerR: number, innerR: number,\n outerStart: number, outerEnd: number,\n innerStart: number, innerEnd: number,\n cornerRadius: number,\n): string {\n const pb = new PathBuilder()\n const outerSliceAngle = outerEnd - outerStart\n const innerSliceAngle = innerEnd - innerStart\n const radialThickness = outerR - innerR\n const outerArcLen = outerSliceAngle * outerR\n const innerArcLen = innerSliceAngle * innerR\n\n // Separate corner radii for outer and inner edges.\n // Inner corners need aggressive clamping — when innerR is small, the angular\n // span of a corner becomes huge relative to the slice, causing path distortion.\n const outerCr = Math.min(\n cornerRadius,\n radialThickness / 2,\n outerArcLen / 4,\n )\n // Skip inner rounding entirely when inner radius is too small (<20px)\n // — the angular span of any rounding would dominate the inner edge.\n const innerCr = innerR >= 20\n ? Math.min(\n cornerRadius,\n radialThickness / 2,\n innerArcLen / 4,\n innerR * 0.25,\n )\n : 0\n\n if (outerCr < 0.5 && innerCr < 0.5) {\n // No rounding — standard path with per-radius angles\n const x1o = cx + outerR * Math.cos(outerStart)\n const y1o = cy + outerR * Math.sin(outerStart)\n const x2o = cx + outerR * Math.cos(outerEnd)\n const y2o = cy + outerR * Math.sin(outerEnd)\n const x1i = cx + innerR * Math.cos(innerEnd)\n const y1i = cy + innerR * Math.sin(innerEnd)\n const x2i = cx + innerR * Math.cos(innerStart)\n const y2i = cy + innerR * Math.sin(innerStart)\n\n pb.moveTo(x1o, y1o)\n pb.arc(outerR, outerR, 0, outerSliceAngle > Math.PI, true, x2o, y2o)\n pb.lineTo(x1i, y1i)\n if (innerR > 0) {\n pb.arc(innerR, innerR, 0, innerSliceAngle > Math.PI, false, x2i, y2i)\n }\n pb.close()\n return pb.build()\n }\n\n // Angular offsets for rounding on each arc (separate for outer/inner)\n const outerCrAngle = outerCr / outerR\n const innerCrAngle = innerR > 0 && innerCr > 0.5 ? innerCr / innerR : 0\n\n // Outer arc inset by corner angles\n const oa1 = outerStart + outerCrAngle\n const oa2 = outerEnd - outerCrAngle\n // Inner arc inset by corner angles (reverse direction)\n const ia1 = innerEnd - innerCrAngle\n const ia2 = innerStart + innerCrAngle\n\n // -- Corner 1: outer-start (start radial meets outer arc) --\n pb.moveTo(\n cx + (outerR - outerCr) * Math.cos(outerStart),\n cy + (outerR - outerCr) * Math.sin(outerStart),\n )\n if (outerCr >= 0.5) {\n pb.quadTo(\n cx + outerR * Math.cos(outerStart),\n cy + outerR * Math.sin(outerStart),\n cx + outerR * Math.cos(oa1),\n cy + outerR * Math.sin(oa1),\n )\n }\n\n // -- Outer arc from oa1 to oa2 --\n if (oa2 > oa1) {\n pb.arc(outerR, outerR, 0, (oa2 - oa1) > Math.PI, true,\n cx + outerR * Math.cos(oa2),\n cy + outerR * Math.sin(oa2),\n )\n }\n\n // -- Corner 2: outer-end (outer arc meets end radial) --\n if (outerCr >= 0.5) {\n pb.quadTo(\n cx + outerR * Math.cos(outerEnd),\n cy + outerR * Math.sin(outerEnd),\n cx + (outerR - outerCr) * Math.cos(outerEnd),\n cy + (outerR - outerCr) * Math.sin(outerEnd),\n )\n }\n\n // -- Inner edge --\n if (innerCr >= 0.5 && innerR > 0) {\n // Line down to inner-end corner\n pb.lineTo(\n cx + (innerR + innerCr) * Math.cos(innerEnd),\n cy + (innerR + innerCr) * Math.sin(innerEnd),\n )\n\n // Corner 3: inner-end (end radial meets inner arc)\n pb.quadTo(\n cx + innerR * Math.cos(innerEnd),\n cy + innerR * Math.sin(innerEnd),\n cx + innerR * Math.cos(ia1),\n cy + innerR * Math.sin(ia1),\n )\n\n // Inner arc from ia1 to ia2 (reverse)\n if (ia1 > ia2) {\n pb.arc(innerR, innerR, 0, (ia1 - ia2) > Math.PI, false,\n cx + innerR * Math.cos(ia2),\n cy + innerR * Math.sin(ia2),\n )\n }\n\n // Corner 4: inner-start (inner arc meets start radial)\n pb.quadTo(\n cx + innerR * Math.cos(innerStart),\n cy + innerR * Math.sin(innerStart),\n cx + (innerR + innerCr) * Math.cos(innerStart),\n cy + (innerR + innerCr) * Math.sin(innerStart),\n )\n } else if (innerR > 0) {\n // No inner rounding — sharp inner corners\n pb.lineTo(\n cx + innerR * Math.cos(innerEnd),\n cy + innerR * Math.sin(innerEnd),\n )\n pb.arc(innerR, innerR, 0, innerSliceAngle > Math.PI, false,\n cx + innerR * Math.cos(innerStart),\n cy + innerR * Math.sin(innerStart),\n )\n }\n\n pb.close()\n return pb.build()\n}\n\n/**\n * Compute angular offsets for a uniform pixel gap at different radii.\n * Returns the padded start/end angles for both outer and inner arcs.\n */\nexport function uniformGapAngles(\n startAngle: number, endAngle: number,\n outerR: number, innerR: number,\n gapPx: number,\n): { outerStart: number; outerEnd: number; innerStart: number; innerEnd: number } {\n const halfGap = gapPx / 2\n const outerPad = halfGap / outerR\n const innerPad = innerR > 0 ? halfGap / innerR : 0\n return {\n outerStart: startAngle + outerPad,\n outerEnd: endAngle - outerPad,\n innerStart: startAngle + innerPad,\n innerEnd: endAngle - innerPad,\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/utils/slice-path.ts"],"names":["PathBuilder"],"mappings":"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","file":"chunk-KWSVJRXX.cjs","sourcesContent":["import { PathBuilder } from '../render/tree'\n\n/**\n * Build a rounded annular sector (pie/donut slice) SVG path string.\n *\n * Supports different angular offsets at inner vs outer radius for uniform\n * pixel-width gaps between slices.\n *\n * @param cx - Center x\n * @param cy - Center y\n * @param outerR - Outer radius\n * @param innerR - Inner radius (0 for full pie, >0 for donut)\n * @param outerStart - Start angle on outer arc (radians)\n * @param outerEnd - End angle on outer arc (radians)\n * @param innerStart - Start angle on inner arc (radians)\n * @param innerEnd - End angle on inner arc (radians)\n * @param cornerRadius - Corner rounding radius in px\n */\nexport function roundedSlicePath(\n cx: number, cy: number,\n outerR: number, innerR: number,\n outerStart: number, outerEnd: number,\n innerStart: number, innerEnd: number,\n cornerRadius: number,\n): string {\n const pb = new PathBuilder()\n const outerSliceAngle = outerEnd - outerStart\n const innerSliceAngle = innerEnd - innerStart\n const radialThickness = outerR - innerR\n const outerArcLen = outerSliceAngle * outerR\n const innerArcLen = innerSliceAngle * innerR\n\n // Separate corner radii for outer and inner edges.\n // Inner corners need aggressive clamping — when innerR is small, the angular\n // span of a corner becomes huge relative to the slice, causing path distortion.\n const outerCr = Math.min(\n cornerRadius,\n radialThickness / 2,\n outerArcLen / 4,\n )\n // Skip inner rounding entirely when inner radius is too small (<20px)\n // — the angular span of any rounding would dominate the inner edge.\n const innerCr = innerR >= 20\n ? Math.min(\n cornerRadius,\n radialThickness / 2,\n innerArcLen / 4,\n innerR * 0.25,\n )\n : 0\n\n if (outerCr < 0.5 && innerCr < 0.5) {\n // No rounding — standard path with per-radius angles\n const x1o = cx + outerR * Math.cos(outerStart)\n const y1o = cy + outerR * Math.sin(outerStart)\n const x2o = cx + outerR * Math.cos(outerEnd)\n const y2o = cy + outerR * Math.sin(outerEnd)\n const x1i = cx + innerR * Math.cos(innerEnd)\n const y1i = cy + innerR * Math.sin(innerEnd)\n const x2i = cx + innerR * Math.cos(innerStart)\n const y2i = cy + innerR * Math.sin(innerStart)\n\n pb.moveTo(x1o, y1o)\n pb.arc(outerR, outerR, 0, outerSliceAngle > Math.PI, true, x2o, y2o)\n pb.lineTo(x1i, y1i)\n if (innerR > 0) {\n pb.arc(innerR, innerR, 0, innerSliceAngle > Math.PI, false, x2i, y2i)\n }\n pb.close()\n return pb.build()\n }\n\n // Angular offsets for rounding on each arc (separate for outer/inner)\n const outerCrAngle = outerCr / outerR\n const innerCrAngle = innerR > 0 && innerCr > 0.5 ? innerCr / innerR : 0\n\n // Outer arc inset by corner angles\n const oa1 = outerStart + outerCrAngle\n const oa2 = outerEnd - outerCrAngle\n // Inner arc inset by corner angles (reverse direction)\n const ia1 = innerEnd - innerCrAngle\n const ia2 = innerStart + innerCrAngle\n\n // -- Corner 1: outer-start (start radial meets outer arc) --\n pb.moveTo(\n cx + (outerR - outerCr) * Math.cos(outerStart),\n cy + (outerR - outerCr) * Math.sin(outerStart),\n )\n if (outerCr >= 0.5) {\n pb.quadTo(\n cx + outerR * Math.cos(outerStart),\n cy + outerR * Math.sin(outerStart),\n cx + outerR * Math.cos(oa1),\n cy + outerR * Math.sin(oa1),\n )\n }\n\n // -- Outer arc from oa1 to oa2 --\n if (oa2 > oa1) {\n pb.arc(outerR, outerR, 0, (oa2 - oa1) > Math.PI, true,\n cx + outerR * Math.cos(oa2),\n cy + outerR * Math.sin(oa2),\n )\n }\n\n // -- Corner 2: outer-end (outer arc meets end radial) --\n if (outerCr >= 0.5) {\n pb.quadTo(\n cx + outerR * Math.cos(outerEnd),\n cy + outerR * Math.sin(outerEnd),\n cx + (outerR - outerCr) * Math.cos(outerEnd),\n cy + (outerR - outerCr) * Math.sin(outerEnd),\n )\n }\n\n // -- Inner edge --\n if (innerCr >= 0.5 && innerR > 0) {\n // Line down to inner-end corner\n pb.lineTo(\n cx + (innerR + innerCr) * Math.cos(innerEnd),\n cy + (innerR + innerCr) * Math.sin(innerEnd),\n )\n\n // Corner 3: inner-end (end radial meets inner arc)\n pb.quadTo(\n cx + innerR * Math.cos(innerEnd),\n cy + innerR * Math.sin(innerEnd),\n cx + innerR * Math.cos(ia1),\n cy + innerR * Math.sin(ia1),\n )\n\n // Inner arc from ia1 to ia2 (reverse)\n if (ia1 > ia2) {\n pb.arc(innerR, innerR, 0, (ia1 - ia2) > Math.PI, false,\n cx + innerR * Math.cos(ia2),\n cy + innerR * Math.sin(ia2),\n )\n }\n\n // Corner 4: inner-start (inner arc meets start radial)\n pb.quadTo(\n cx + innerR * Math.cos(innerStart),\n cy + innerR * Math.sin(innerStart),\n cx + (innerR + innerCr) * Math.cos(innerStart),\n cy + (innerR + innerCr) * Math.sin(innerStart),\n )\n } else if (innerR > 0) {\n // No inner rounding — sharp inner corners\n pb.lineTo(\n cx + innerR * Math.cos(innerEnd),\n cy + innerR * Math.sin(innerEnd),\n )\n pb.arc(innerR, innerR, 0, innerSliceAngle > Math.PI, false,\n cx + innerR * Math.cos(innerStart),\n cy + innerR * Math.sin(innerStart),\n )\n }\n\n pb.close()\n return pb.build()\n}\n\n/**\n * Compute angular offsets for a uniform pixel gap at different radii.\n * Returns the padded start/end angles for both outer and inner arcs.\n */\nexport function uniformGapAngles(\n startAngle: number, endAngle: number,\n outerR: number, innerR: number,\n gapPx: number,\n): { outerStart: number; outerEnd: number; innerStart: number; innerEnd: number } {\n const halfGap = gapPx / 2\n const outerPad = halfGap / outerR\n const innerPad = innerR > 0 ? halfGap / innerR : 0\n return {\n outerStart: startAngle + outerPad,\n outerEnd: endAngle - outerPad,\n innerStart: startAngle + innerPad,\n innerEnd: endAngle - innerPad,\n }\n}\n"]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var
|
|
4
|
-
var
|
|
3
|
+
var chunkV5Q6UNUK_cjs = require('./chunk-V5Q6UNUK.cjs');
|
|
4
|
+
var chunkJVVGQLJQ_cjs = require('./chunk-JVVGQLJQ.cjs');
|
|
5
5
|
|
|
6
6
|
// src/charts/sankey/sankey-type.ts
|
|
7
7
|
var sankeyChartType = {
|
|
@@ -10,7 +10,7 @@ var sankeyChartType = {
|
|
|
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;
|
|
@@ -42,7 +42,7 @@ var sankeyChartType = {
|
|
|
42
42
|
const y0 = src.y + link.sy;
|
|
43
43
|
const y1 = tgt.y + link.ty;
|
|
44
44
|
const w = link.width;
|
|
45
|
-
const pb = new
|
|
45
|
+
const pb = new chunkJVVGQLJQ_cjs.PathBuilder();
|
|
46
46
|
const cx = (x0 + x1) / 2;
|
|
47
47
|
pb.moveTo(x0, y0);
|
|
48
48
|
pb.curveTo(cx, y0, cx, y1, x1, y1);
|
|
@@ -50,7 +50,7 @@ var sankeyChartType = {
|
|
|
50
50
|
pb.curveTo(cx, y1 + w, cx, y0 + w, x0, y0 + w);
|
|
51
51
|
pb.close();
|
|
52
52
|
const color = options.colors[link.source % options.colors.length];
|
|
53
|
-
nodes.push(
|
|
53
|
+
nodes.push(chunkJVVGQLJQ_cjs.path(pb.build(), {
|
|
54
54
|
class: "chartts-sankey-link",
|
|
55
55
|
fill: color,
|
|
56
56
|
fillOpacity: 0.3,
|
|
@@ -66,7 +66,7 @@ var sankeyChartType = {
|
|
|
66
66
|
const x = getNodeX(node, columns, area, nodeWidth);
|
|
67
67
|
const color = options.colors[ni % options.colors.length];
|
|
68
68
|
const nodeGroup = [];
|
|
69
|
-
nodeGroup.push(
|
|
69
|
+
nodeGroup.push(chunkJVVGQLJQ_cjs.rect(x, node.y, nodeWidth, Math.max(node.height, 2), {
|
|
70
70
|
rx: 3,
|
|
71
71
|
ry: 3,
|
|
72
72
|
class: "chartts-sankey-node",
|
|
@@ -80,7 +80,7 @@ var sankeyChartType = {
|
|
|
80
80
|
const isLeft = node.column < columns.length / 2;
|
|
81
81
|
const labelX = isLeft ? x + nodeWidth + 6 : x - 6;
|
|
82
82
|
const anchor = isLeft ? "start" : "end";
|
|
83
|
-
nodeGroup.push(
|
|
83
|
+
nodeGroup.push(chunkJVVGQLJQ_cjs.text(labelX, node.y + node.height / 2, node.name, {
|
|
84
84
|
class: "chartts-sankey-label",
|
|
85
85
|
fill: theme.textColor,
|
|
86
86
|
textAnchor: anchor,
|
|
@@ -88,7 +88,7 @@ var sankeyChartType = {
|
|
|
88
88
|
fontSize: theme.fontSizeSmall,
|
|
89
89
|
fontFamily: theme.fontFamily
|
|
90
90
|
}));
|
|
91
|
-
nodes.push(
|
|
91
|
+
nodes.push(chunkJVVGQLJQ_cjs.group(nodeGroup, {
|
|
92
92
|
class: `chartts-series chartts-series-${ni}`,
|
|
93
93
|
"data-series-name": node.name
|
|
94
94
|
}));
|
|
@@ -247,5 +247,5 @@ function computeLinkPositions(nodes, links) {
|
|
|
247
247
|
}
|
|
248
248
|
|
|
249
249
|
exports.sankeyChartType = sankeyChartType;
|
|
250
|
-
//# sourceMappingURL=chunk-
|
|
251
|
-
//# sourceMappingURL=chunk-
|
|
250
|
+
//# sourceMappingURL=chunk-LARNENXE.cjs.map
|
|
251
|
+
//# sourceMappingURL=chunk-LARNENXE.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/charts/sankey/sankey-type.ts"],"names":["prepareNoAxes","PathBuilder","path","rect","text","group"],"mappings":"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","file":"chunk-OAL5RS2X.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, path, rect, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Sankey / flow diagram.\n *\n * Data convention:\n * - labels: node names (unique). First N are source layer, rest are target layer.\n * - series[i]: a flow. series[i].name = \"Source → Target\", series[i].values = [flowValue]\n *\n * Alternative (simpler): encode flows as a flat list.\n * - labels: all unique node names\n * - series[0].values: flat list of flow values\n * - options.links: array of { source: number, target: number, value: number }\n *\n * This implementation auto-detects the format:\n * If series names contain \"→\" or \"->\", parse as source→target flows.\n * Otherwise treat as adjacency: series[i] = from node i, values[j] = flow to node j.\n */\n\ninterface SankeyNode {\n name: string\n index: number\n column: number\n y: number\n height: number\n totalIn: number\n totalOut: number\n}\n\ninterface SankeyLink {\n source: number\n target: number\n value: number\n sy: number // source y offset\n ty: number // target y offset\n width: number\n}\n\nexport const sankeyChartType: ChartTypePlugin = {\n type: 'sankey',\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 { sankeyNodes, sankeyLinks } = parseSankeyData(data, options)\n if (sankeyNodes.length === 0 || sankeyLinks.length === 0) return nodes\n\n // Layout\n const columns = layoutColumns(sankeyNodes, sankeyLinks, area)\n const nodeWidth = Math.min(20, area.width * 0.04)\n const nodePadding = 8\n\n // Position nodes within columns\n for (const col of columns) {\n const colNodes = sankeyNodes.filter(n => n.column === col)\n const totalHeight = colNodes.reduce((s, n) => s + n.height, 0)\n const gaps = Math.max(0, colNodes.length - 1) * nodePadding\n const scale = (area.height - gaps) / Math.max(totalHeight, 1)\n\n let y = area.y\n for (const node of colNodes) {\n node.height = node.height * scale\n node.y = y\n y += node.height + nodePadding\n }\n }\n\n // Compute link positions\n computeLinkPositions(sankeyNodes, sankeyLinks)\n\n // Render links (curved bands)\n for (let li = 0; li < sankeyLinks.length; li++) {\n const link = sankeyLinks[li]!\n const src = sankeyNodes[link.source]!\n const tgt = sankeyNodes[link.target]!\n const x0 = src.y !== undefined ? getNodeX(src, columns, area, nodeWidth) + nodeWidth : 0\n const x1 = tgt.y !== undefined ? getNodeX(tgt, columns, area, nodeWidth) : 0\n const y0 = src.y + link.sy\n const y1 = tgt.y + link.ty\n const w = link.width\n\n const pb = new PathBuilder()\n const cx = (x0 + x1) / 2\n pb.moveTo(x0, y0)\n pb.curveTo(cx, y0, cx, y1, x1, y1)\n pb.vTo(y1 + w)\n pb.curveTo(cx, y1 + w, cx, y0 + w, x0, y0 + w)\n pb.close()\n\n const color = options.colors[link.source % options.colors.length]!\n\n nodes.push(path(pb.build(), {\n class: 'chartts-sankey-link',\n fill: color,\n fillOpacity: 0.3,\n 'data-series': link.source,\n 'data-index': li,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${src.name} → ${tgt.name}: ${link.value}`,\n }))\n }\n\n // Render nodes (rectangles + labels)\n for (let ni = 0; ni < sankeyNodes.length; ni++) {\n const node = sankeyNodes[ni]!\n const x = getNodeX(node, columns, area, nodeWidth)\n const color = options.colors[ni % options.colors.length]!\n const nodeGroup: RenderNode[] = []\n\n nodeGroup.push(rect(x, node.y, nodeWidth, Math.max(node.height, 2), {\n rx: 3, ry: 3,\n class: 'chartts-sankey-node',\n fill: color,\n 'data-series': ni,\n 'data-index': 0,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${node.name}: ${Math.max(node.totalIn, node.totalOut)}`,\n }))\n\n // Label\n const isLeft = node.column < columns.length / 2\n const labelX = isLeft ? x + nodeWidth + 6 : x - 6\n const anchor = isLeft ? 'start' : 'end'\n\n nodeGroup.push(text(labelX, node.y + node.height / 2, node.name, {\n class: 'chartts-sankey-label',\n fill: theme.textColor,\n textAnchor: anchor as 'start' | 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n nodes.push(group(nodeGroup, {\n class: `chartts-series chartts-series-${ni}`,\n 'data-series-name': node.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area, options } = ctx\n const { sankeyNodes, sankeyLinks } = parseSankeyData(data, options)\n if (sankeyNodes.length === 0) return null\n\n const columns = layoutColumns(sankeyNodes, sankeyLinks, area)\n const nodeWidth = Math.min(20, area.width * 0.04)\n const nodePadding = 8\n\n // Re-layout (same as render)\n for (const col of columns) {\n const colNodes = sankeyNodes.filter(n => n.column === col)\n const totalHeight = colNodes.reduce((s, n) => s + n.height, 0)\n const gaps = Math.max(0, colNodes.length - 1) * nodePadding\n const scale = (area.height - gaps) / Math.max(totalHeight, 1)\n let y = area.y\n for (const node of colNodes) {\n node.height = node.height * scale\n node.y = y\n y += node.height + nodePadding\n }\n }\n\n // Check node hits\n for (let ni = 0; ni < sankeyNodes.length; ni++) {\n const node = sankeyNodes[ni]!\n const x = getNodeX(node, columns, area, nodeWidth)\n if (mx >= x && mx <= x + nodeWidth && my >= node.y && my <= node.y + node.height) {\n return { seriesIndex: ni, pointIndex: 0, distance: 0, x: x + nodeWidth / 2, y: node.y + node.height / 2 }\n }\n }\n\n return null\n },\n}\n\n// ---------------------------------------------------------------------------\n// Parsing helpers\n// ---------------------------------------------------------------------------\n\nfunction parseSankeyData(\n data: PreparedData,\n _options: ResolvedOptions,\n): { sankeyNodes: SankeyNode[]; sankeyLinks: SankeyLink[] } {\n const sankeyNodes: SankeyNode[] = []\n const sankeyLinks: SankeyLink[] = []\n const nodeMap = new Map<string, number>()\n\n function getOrCreateNode(name: string): number {\n if (nodeMap.has(name)) return nodeMap.get(name)!\n const idx = sankeyNodes.length\n nodeMap.set(name, idx)\n sankeyNodes.push({\n name,\n index: idx,\n column: -1,\n y: 0,\n height: 0,\n totalIn: 0,\n totalOut: 0,\n })\n return idx\n }\n\n // Check if series names contain arrow notation\n const hasArrows = data.series.some(s => s.name.includes('→') || s.name.includes('->'))\n\n if (hasArrows) {\n // Format: each series is a flow \"Source → Target\"\n for (const series of data.series) {\n const parts = series.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length < 2) continue\n const srcName = parts[0]!.trim()\n const tgtName = parts[1]!.trim()\n const value = series.values[0] ?? 0\n if (value <= 0) continue\n\n const src = getOrCreateNode(srcName)\n const tgt = getOrCreateNode(tgtName)\n sankeyLinks.push({ source: src, target: tgt, value, sy: 0, ty: 0, width: 0 })\n sankeyNodes[src]!.totalOut += value\n sankeyNodes[tgt]!.totalIn += value\n }\n } else {\n // Format: adjacency matrix. labels = node names, series[i].values[j] = flow i→j\n for (let i = 0; i < data.labels.length; i++) {\n getOrCreateNode(String(data.labels[i]))\n }\n for (let si = 0; si < data.series.length; si++) {\n for (let j = 0; j < data.series[si]!.values.length; j++) {\n const value = data.series[si]!.values[j]!\n if (value <= 0 || si === j) continue\n if (si >= sankeyNodes.length || j >= sankeyNodes.length) continue\n sankeyLinks.push({ source: si, target: j, value, sy: 0, ty: 0, width: 0 })\n sankeyNodes[si]!.totalOut += value\n sankeyNodes[j]!.totalIn += value\n }\n }\n }\n\n return { sankeyNodes, sankeyLinks }\n}\n\n// ---------------------------------------------------------------------------\n// Layout\n// ---------------------------------------------------------------------------\n\nfunction layoutColumns(\n nodes: SankeyNode[],\n links: SankeyLink[],\n _area: { width: number; height: number },\n): number[] {\n // Assign columns via topological ordering (longest path from source)\n const adj = new Map<number, number[]>()\n const inDegree = new Map<number, number>()\n\n for (const n of nodes) {\n adj.set(n.index, [])\n inDegree.set(n.index, 0)\n }\n for (const l of links) {\n adj.get(l.source)!.push(l.target)\n inDegree.set(l.target, (inDegree.get(l.target) ?? 0) + 1)\n }\n\n // BFS for column assignment\n const queue: number[] = []\n for (const n of nodes) {\n if ((inDegree.get(n.index) ?? 0) === 0) {\n n.column = 0\n queue.push(n.index)\n }\n }\n\n while (queue.length > 0) {\n const idx = queue.shift()!\n const node = nodes[idx]!\n for (const tgt of adj.get(idx)!) {\n const tgtNode = nodes[tgt]!\n tgtNode.column = Math.max(tgtNode.column, node.column + 1)\n // Only add to queue once all predecessors processed\n const allPredsDone = links\n .filter(l => l.target === tgt)\n .every(l => nodes[l.source]!.column >= 0)\n if (allPredsDone && !queue.includes(tgt)) {\n queue.push(tgt)\n }\n }\n }\n\n // Handle any unassigned nodes (cycles or disconnected)\n for (const n of nodes) {\n if (n.column < 0) n.column = 0\n }\n\n // Set initial heights proportional to flow\n for (const n of nodes) {\n n.height = Math.max(n.totalIn, n.totalOut, 1)\n }\n\n // Get unique columns sorted\n const cols = [...new Set(nodes.map(n => n.column))].sort((a, b) => a - b)\n return cols\n}\n\nfunction getNodeX(\n node: SankeyNode,\n columns: number[],\n area: { x: number; width: number },\n nodeWidth: number,\n): number {\n const maxCol = Math.max(...columns, 1)\n if (maxCol === 0) return area.x\n const usableWidth = area.width - nodeWidth\n return area.x + (node.column / maxCol) * usableWidth\n}\n\nfunction computeLinkPositions(nodes: SankeyNode[], links: SankeyLink[]): void {\n // Total flow for normalization\n const sourceOffsets = new Map<number, number>()\n const targetOffsets = new Map<number, number>()\n\n for (const n of nodes) {\n sourceOffsets.set(n.index, 0)\n targetOffsets.set(n.index, 0)\n }\n\n // Sort links by target position for visual clarity\n links.sort((a, b) => {\n const na = nodes[a.target]!\n const nb = nodes[b.target]!\n return na.y - nb.y || na.column - nb.column\n })\n\n for (const link of links) {\n const src = nodes[link.source]!\n const tgt = nodes[link.target]!\n\n const srcTotal = Math.max(src.totalOut, 1)\n const tgtTotal = Math.max(tgt.totalIn, 1)\n\n link.width = (link.value / srcTotal) * src.height\n const tgtWidth = (link.value / tgtTotal) * tgt.height\n\n link.sy = sourceOffsets.get(link.source)!\n link.ty = targetOffsets.get(link.target)!\n\n sourceOffsets.set(link.source, link.sy + link.width)\n targetOffsets.set(link.target, link.ty + tgtWidth)\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/charts/sankey/sankey-type.ts"],"names":["prepareNoAxes","PathBuilder","path","rect","text","group"],"mappings":"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","file":"chunk-LARNENXE.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, path, rect, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Sankey / flow diagram.\n *\n * Data convention:\n * - labels: node names (unique). First N are source layer, rest are target layer.\n * - series[i]: a flow. series[i].name = \"Source → Target\", series[i].values = [flowValue]\n *\n * Alternative (simpler): encode flows as a flat list.\n * - labels: all unique node names\n * - series[0].values: flat list of flow values\n * - options.links: array of { source: number, target: number, value: number }\n *\n * This implementation auto-detects the format:\n * If series names contain \"→\" or \"->\", parse as source→target flows.\n * Otherwise treat as adjacency: series[i] = from node i, values[j] = flow to node j.\n */\n\ninterface SankeyNode {\n name: string\n index: number\n column: number\n y: number\n height: number\n totalIn: number\n totalOut: number\n}\n\ninterface SankeyLink {\n source: number\n target: number\n value: number\n sy: number // source y offset\n ty: number // target y offset\n width: number\n}\n\nexport const sankeyChartType: ChartTypePlugin = {\n type: 'sankey',\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 { sankeyNodes, sankeyLinks } = parseSankeyData(data, options)\n if (sankeyNodes.length === 0 || sankeyLinks.length === 0) return nodes\n\n // Layout\n const columns = layoutColumns(sankeyNodes, sankeyLinks, area)\n const nodeWidth = Math.min(20, area.width * 0.04)\n const nodePadding = 8\n\n // Position nodes within columns\n for (const col of columns) {\n const colNodes = sankeyNodes.filter(n => n.column === col)\n const totalHeight = colNodes.reduce((s, n) => s + n.height, 0)\n const gaps = Math.max(0, colNodes.length - 1) * nodePadding\n const scale = (area.height - gaps) / Math.max(totalHeight, 1)\n\n let y = area.y\n for (const node of colNodes) {\n node.height = node.height * scale\n node.y = y\n y += node.height + nodePadding\n }\n }\n\n // Compute link positions\n computeLinkPositions(sankeyNodes, sankeyLinks)\n\n // Render links (curved bands)\n for (let li = 0; li < sankeyLinks.length; li++) {\n const link = sankeyLinks[li]!\n const src = sankeyNodes[link.source]!\n const tgt = sankeyNodes[link.target]!\n const x0 = src.y !== undefined ? getNodeX(src, columns, area, nodeWidth) + nodeWidth : 0\n const x1 = tgt.y !== undefined ? getNodeX(tgt, columns, area, nodeWidth) : 0\n const y0 = src.y + link.sy\n const y1 = tgt.y + link.ty\n const w = link.width\n\n const pb = new PathBuilder()\n const cx = (x0 + x1) / 2\n pb.moveTo(x0, y0)\n pb.curveTo(cx, y0, cx, y1, x1, y1)\n pb.vTo(y1 + w)\n pb.curveTo(cx, y1 + w, cx, y0 + w, x0, y0 + w)\n pb.close()\n\n const color = options.colors[link.source % options.colors.length]!\n\n nodes.push(path(pb.build(), {\n class: 'chartts-sankey-link',\n fill: color,\n fillOpacity: 0.3,\n 'data-series': link.source,\n 'data-index': li,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${src.name} → ${tgt.name}: ${link.value}`,\n }))\n }\n\n // Render nodes (rectangles + labels)\n for (let ni = 0; ni < sankeyNodes.length; ni++) {\n const node = sankeyNodes[ni]!\n const x = getNodeX(node, columns, area, nodeWidth)\n const color = options.colors[ni % options.colors.length]!\n const nodeGroup: RenderNode[] = []\n\n nodeGroup.push(rect(x, node.y, nodeWidth, Math.max(node.height, 2), {\n rx: 3, ry: 3,\n class: 'chartts-sankey-node',\n fill: color,\n 'data-series': ni,\n 'data-index': 0,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${node.name}: ${Math.max(node.totalIn, node.totalOut)}`,\n }))\n\n // Label\n const isLeft = node.column < columns.length / 2\n const labelX = isLeft ? x + nodeWidth + 6 : x - 6\n const anchor = isLeft ? 'start' : 'end'\n\n nodeGroup.push(text(labelX, node.y + node.height / 2, node.name, {\n class: 'chartts-sankey-label',\n fill: theme.textColor,\n textAnchor: anchor as 'start' | 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n nodes.push(group(nodeGroup, {\n class: `chartts-series chartts-series-${ni}`,\n 'data-series-name': node.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area, options } = ctx\n const { sankeyNodes, sankeyLinks } = parseSankeyData(data, options)\n if (sankeyNodes.length === 0) return null\n\n const columns = layoutColumns(sankeyNodes, sankeyLinks, area)\n const nodeWidth = Math.min(20, area.width * 0.04)\n const nodePadding = 8\n\n // Re-layout (same as render)\n for (const col of columns) {\n const colNodes = sankeyNodes.filter(n => n.column === col)\n const totalHeight = colNodes.reduce((s, n) => s + n.height, 0)\n const gaps = Math.max(0, colNodes.length - 1) * nodePadding\n const scale = (area.height - gaps) / Math.max(totalHeight, 1)\n let y = area.y\n for (const node of colNodes) {\n node.height = node.height * scale\n node.y = y\n y += node.height + nodePadding\n }\n }\n\n // Check node hits\n for (let ni = 0; ni < sankeyNodes.length; ni++) {\n const node = sankeyNodes[ni]!\n const x = getNodeX(node, columns, area, nodeWidth)\n if (mx >= x && mx <= x + nodeWidth && my >= node.y && my <= node.y + node.height) {\n return { seriesIndex: ni, pointIndex: 0, distance: 0, x: x + nodeWidth / 2, y: node.y + node.height / 2 }\n }\n }\n\n return null\n },\n}\n\n// ---------------------------------------------------------------------------\n// Parsing helpers\n// ---------------------------------------------------------------------------\n\nfunction parseSankeyData(\n data: PreparedData,\n _options: ResolvedOptions,\n): { sankeyNodes: SankeyNode[]; sankeyLinks: SankeyLink[] } {\n const sankeyNodes: SankeyNode[] = []\n const sankeyLinks: SankeyLink[] = []\n const nodeMap = new Map<string, number>()\n\n function getOrCreateNode(name: string): number {\n if (nodeMap.has(name)) return nodeMap.get(name)!\n const idx = sankeyNodes.length\n nodeMap.set(name, idx)\n sankeyNodes.push({\n name,\n index: idx,\n column: -1,\n y: 0,\n height: 0,\n totalIn: 0,\n totalOut: 0,\n })\n return idx\n }\n\n // Check if series names contain arrow notation\n const hasArrows = data.series.some(s => s.name.includes('→') || s.name.includes('->'))\n\n if (hasArrows) {\n // Format: each series is a flow \"Source → Target\"\n for (const series of data.series) {\n const parts = series.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length < 2) continue\n const srcName = parts[0]!.trim()\n const tgtName = parts[1]!.trim()\n const value = series.values[0] ?? 0\n if (value <= 0) continue\n\n const src = getOrCreateNode(srcName)\n const tgt = getOrCreateNode(tgtName)\n sankeyLinks.push({ source: src, target: tgt, value, sy: 0, ty: 0, width: 0 })\n sankeyNodes[src]!.totalOut += value\n sankeyNodes[tgt]!.totalIn += value\n }\n } else {\n // Format: adjacency matrix. labels = node names, series[i].values[j] = flow i→j\n for (let i = 0; i < data.labels.length; i++) {\n getOrCreateNode(String(data.labels[i]))\n }\n for (let si = 0; si < data.series.length; si++) {\n for (let j = 0; j < data.series[si]!.values.length; j++) {\n const value = data.series[si]!.values[j]!\n if (value <= 0 || si === j) continue\n if (si >= sankeyNodes.length || j >= sankeyNodes.length) continue\n sankeyLinks.push({ source: si, target: j, value, sy: 0, ty: 0, width: 0 })\n sankeyNodes[si]!.totalOut += value\n sankeyNodes[j]!.totalIn += value\n }\n }\n }\n\n return { sankeyNodes, sankeyLinks }\n}\n\n// ---------------------------------------------------------------------------\n// Layout\n// ---------------------------------------------------------------------------\n\nfunction layoutColumns(\n nodes: SankeyNode[],\n links: SankeyLink[],\n _area: { width: number; height: number },\n): number[] {\n // Assign columns via topological ordering (longest path from source)\n const adj = new Map<number, number[]>()\n const inDegree = new Map<number, number>()\n\n for (const n of nodes) {\n adj.set(n.index, [])\n inDegree.set(n.index, 0)\n }\n for (const l of links) {\n adj.get(l.source)!.push(l.target)\n inDegree.set(l.target, (inDegree.get(l.target) ?? 0) + 1)\n }\n\n // BFS for column assignment\n const queue: number[] = []\n for (const n of nodes) {\n if ((inDegree.get(n.index) ?? 0) === 0) {\n n.column = 0\n queue.push(n.index)\n }\n }\n\n while (queue.length > 0) {\n const idx = queue.shift()!\n const node = nodes[idx]!\n for (const tgt of adj.get(idx)!) {\n const tgtNode = nodes[tgt]!\n tgtNode.column = Math.max(tgtNode.column, node.column + 1)\n // Only add to queue once all predecessors processed\n const allPredsDone = links\n .filter(l => l.target === tgt)\n .every(l => nodes[l.source]!.column >= 0)\n if (allPredsDone && !queue.includes(tgt)) {\n queue.push(tgt)\n }\n }\n }\n\n // Handle any unassigned nodes (cycles or disconnected)\n for (const n of nodes) {\n if (n.column < 0) n.column = 0\n }\n\n // Set initial heights proportional to flow\n for (const n of nodes) {\n n.height = Math.max(n.totalIn, n.totalOut, 1)\n }\n\n // Get unique columns sorted\n const cols = [...new Set(nodes.map(n => n.column))].sort((a, b) => a - b)\n return cols\n}\n\nfunction getNodeX(\n node: SankeyNode,\n columns: number[],\n area: { x: number; width: number },\n nodeWidth: number,\n): number {\n const maxCol = Math.max(...columns, 1)\n if (maxCol === 0) return area.x\n const usableWidth = area.width - nodeWidth\n return area.x + (node.column / maxCol) * usableWidth\n}\n\nfunction computeLinkPositions(nodes: SankeyNode[], links: SankeyLink[]): void {\n // Total flow for normalization\n const sourceOffsets = new Map<number, number>()\n const targetOffsets = new Map<number, number>()\n\n for (const n of nodes) {\n sourceOffsets.set(n.index, 0)\n targetOffsets.set(n.index, 0)\n }\n\n // Sort links by target position for visual clarity\n links.sort((a, b) => {\n const na = nodes[a.target]!\n const nb = nodes[b.target]!\n return na.y - nb.y || na.column - nb.column\n })\n\n for (const link of links) {\n const src = nodes[link.source]!\n const tgt = nodes[link.target]!\n\n const srcTotal = Math.max(src.totalOut, 1)\n const tgtTotal = Math.max(tgt.totalIn, 1)\n\n link.width = (link.value / srcTotal) * src.height\n const tgtWidth = (link.value / tgtTotal) * tgt.height\n\n link.sy = sourceOffsets.get(link.source)!\n link.ty = targetOffsets.get(link.target)!\n\n sourceOffsets.set(link.source, link.sy + link.width)\n targetOffsets.set(link.target, link.ty + tgtWidth)\n }\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { prepareNoAxes } from './chunk-
|
|
2
|
-
import { group, line, PathBuilder, path, rect, text, circle } from './chunk-
|
|
1
|
+
import { prepareNoAxes } from './chunk-T7SCCACB.js';
|
|
2
|
+
import { group, line, PathBuilder, path, rect, text, circle } from './chunk-AEQXFDL7.js';
|
|
3
3
|
|
|
4
4
|
// src/charts/graph/parse.ts
|
|
5
5
|
function parseGraphData(data, options) {
|
|
@@ -778,6 +778,14 @@ var graphChartType = {
|
|
|
778
778
|
return { x: "categorical", y: "linear" };
|
|
779
779
|
},
|
|
780
780
|
prepareData(data, options) {
|
|
781
|
+
const opts = options;
|
|
782
|
+
if ((opts.nodes || opts.edges) && (!data.series.length || data.series.every((s) => s.values.length === 0))) {
|
|
783
|
+
return {
|
|
784
|
+
series: [],
|
|
785
|
+
labels: [],
|
|
786
|
+
bounds: { xMin: 0, xMax: 1, yMin: 0, yMax: 1 }
|
|
787
|
+
};
|
|
788
|
+
}
|
|
781
789
|
return prepareNoAxes(data, options);
|
|
782
790
|
},
|
|
783
791
|
render(ctx) {
|
|
@@ -885,5 +893,5 @@ function shapeDistance(node, mx, my) {
|
|
|
885
893
|
}
|
|
886
894
|
|
|
887
895
|
export { graphChartType };
|
|
888
|
-
//# sourceMappingURL=chunk-
|
|
889
|
-
//# sourceMappingURL=chunk-
|
|
896
|
+
//# sourceMappingURL=chunk-LRHMLNPW.js.map
|
|
897
|
+
//# sourceMappingURL=chunk-LRHMLNPW.js.map
|