@chartts/core 0.1.0
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-type-B3CtuIIP.d.cts +9 -0
- package/dist/area-type-DmB6fTVf.d.ts +9 -0
- package/dist/area.cjs +34 -0
- package/dist/area.cjs.map +1 -0
- package/dist/area.d.cts +8 -0
- package/dist/area.d.ts +8 -0
- package/dist/area.js +13 -0
- package/dist/area.js.map +1 -0
- package/dist/bar-type-Bne_khsO.d.ts +5 -0
- package/dist/bar-type-CkI-kkrC.d.cts +5 -0
- package/dist/bar.cjs +34 -0
- package/dist/bar.cjs.map +1 -0
- package/dist/bar.d.cts +8 -0
- package/dist/bar.d.ts +8 -0
- package/dist/bar.js +13 -0
- package/dist/bar.js.map +1 -0
- package/dist/baseline-type-B1O4XHT3.d.ts +25 -0
- package/dist/baseline-type-BAPrZJ5W.d.cts +25 -0
- package/dist/baseline.cjs +32 -0
- package/dist/baseline.cjs.map +1 -0
- package/dist/baseline.d.cts +8 -0
- package/dist/baseline.d.ts +8 -0
- package/dist/baseline.js +11 -0
- package/dist/baseline.js.map +1 -0
- package/dist/boxplot-type-CEWf7p5X.d.ts +5 -0
- package/dist/boxplot-type-Da8_smoe.d.cts +5 -0
- package/dist/boxplot.cjs +33 -0
- package/dist/boxplot.cjs.map +1 -0
- package/dist/boxplot.d.cts +8 -0
- package/dist/boxplot.d.ts +8 -0
- package/dist/boxplot.js +12 -0
- package/dist/boxplot.js.map +1 -0
- package/dist/bubble-type-Dxb2JCKv.d.cts +9 -0
- package/dist/bubble-type-pru5MgB7.d.ts +9 -0
- package/dist/bubble.cjs +32 -0
- package/dist/bubble.cjs.map +1 -0
- package/dist/bubble.d.cts +8 -0
- package/dist/bubble.d.ts +8 -0
- package/dist/bubble.js +11 -0
- package/dist/bubble.js.map +1 -0
- package/dist/bullet-type-CPEYkEvt.d.ts +15 -0
- package/dist/bullet-type-khCmwFqH.d.cts +15 -0
- package/dist/bullet.cjs +33 -0
- package/dist/bullet.cjs.map +1 -0
- package/dist/bullet.d.cts +8 -0
- package/dist/bullet.d.ts +8 -0
- package/dist/bullet.js +12 -0
- package/dist/bullet.js.map +1 -0
- package/dist/calendar-type-Br5mpdea.d.cts +15 -0
- package/dist/calendar-type-yJWPY6qT.d.ts +15 -0
- package/dist/calendar.cjs +33 -0
- package/dist/calendar.cjs.map +1 -0
- package/dist/calendar.d.cts +8 -0
- package/dist/calendar.d.ts +8 -0
- package/dist/calendar.js +12 -0
- package/dist/calendar.js.map +1 -0
- package/dist/candlestick-type-CazXUb77.d.cts +22 -0
- package/dist/candlestick-type-CtLZy_uC.d.ts +22 -0
- package/dist/candlestick.cjs +33 -0
- package/dist/candlestick.cjs.map +1 -0
- package/dist/candlestick.d.cts +8 -0
- package/dist/candlestick.d.ts +8 -0
- package/dist/candlestick.js +12 -0
- package/dist/candlestick.js.map +1 -0
- package/dist/chord-type-ChIZaOZd.d.cts +5 -0
- package/dist/chord-type-ruvHboZl.d.ts +5 -0
- package/dist/chord.cjs +33 -0
- package/dist/chord.cjs.map +1 -0
- package/dist/chord.d.cts +8 -0
- package/dist/chord.d.ts +8 -0
- package/dist/chord.js +12 -0
- package/dist/chord.js.map +1 -0
- package/dist/chunk-22LR6CFM.js +176 -0
- package/dist/chunk-22LR6CFM.js.map +1 -0
- package/dist/chunk-2TWYS3BT.cjs +199 -0
- package/dist/chunk-2TWYS3BT.cjs.map +1 -0
- package/dist/chunk-3BRQGYDX.js +4859 -0
- package/dist/chunk-3BRQGYDX.js.map +1 -0
- package/dist/chunk-3TTTELGB.cjs +146 -0
- package/dist/chunk-3TTTELGB.cjs.map +1 -0
- package/dist/chunk-3XVGEBR4.js +17 -0
- package/dist/chunk-3XVGEBR4.js.map +1 -0
- package/dist/chunk-4HK4RM3X.cjs +128 -0
- package/dist/chunk-4HK4RM3X.cjs.map +1 -0
- package/dist/chunk-4VG47RLS.js +130 -0
- package/dist/chunk-4VG47RLS.js.map +1 -0
- package/dist/chunk-4YJPBUX2.cjs +68 -0
- package/dist/chunk-4YJPBUX2.cjs.map +1 -0
- package/dist/chunk-5QOQR5FE.cjs +19 -0
- package/dist/chunk-5QOQR5FE.cjs.map +1 -0
- package/dist/chunk-66HSJRRH.js +112 -0
- package/dist/chunk-66HSJRRH.js.map +1 -0
- package/dist/chunk-6KNBJ4CE.js +144 -0
- package/dist/chunk-6KNBJ4CE.js.map +1 -0
- package/dist/chunk-6LKN3HRX.js +79 -0
- package/dist/chunk-6LKN3HRX.js.map +1 -0
- package/dist/chunk-6N66T7VQ.js +103 -0
- package/dist/chunk-6N66T7VQ.js.map +1 -0
- package/dist/chunk-6YKFTEX4.js +336 -0
- package/dist/chunk-6YKFTEX4.js.map +1 -0
- package/dist/chunk-7CGXK7KT.js +124 -0
- package/dist/chunk-7CGXK7KT.js.map +1 -0
- package/dist/chunk-7HDAYWK3.cjs +358 -0
- package/dist/chunk-7HDAYWK3.cjs.map +1 -0
- package/dist/chunk-7SEHTEMR.js +91 -0
- package/dist/chunk-7SEHTEMR.js.map +1 -0
- package/dist/chunk-7YV56WPE.js +157 -0
- package/dist/chunk-7YV56WPE.js.map +1 -0
- package/dist/chunk-B54L2CPW.cjs +165 -0
- package/dist/chunk-B54L2CPW.cjs.map +1 -0
- package/dist/chunk-BC6KW2OG.js +197 -0
- package/dist/chunk-BC6KW2OG.js.map +1 -0
- package/dist/chunk-BEYG2HQ4.cjs +178 -0
- package/dist/chunk-BEYG2HQ4.cjs.map +1 -0
- package/dist/chunk-BR3KTAGW.js +113 -0
- package/dist/chunk-BR3KTAGW.js.map +1 -0
- package/dist/chunk-BRSHEDTZ.js +30 -0
- package/dist/chunk-BRSHEDTZ.js.map +1 -0
- package/dist/chunk-BXX2EPFE.cjs +160 -0
- package/dist/chunk-BXX2EPFE.cjs.map +1 -0
- package/dist/chunk-BYXRFTEI.cjs +114 -0
- package/dist/chunk-BYXRFTEI.cjs.map +1 -0
- package/dist/chunk-CMEXNS5V.js +158 -0
- package/dist/chunk-CMEXNS5V.js.map +1 -0
- package/dist/chunk-D2SV6YT3.js +47 -0
- package/dist/chunk-D2SV6YT3.js.map +1 -0
- package/dist/chunk-DL7P72FA.cjs +273 -0
- package/dist/chunk-DL7P72FA.cjs.map +1 -0
- package/dist/chunk-DNQ6N3VG.js +208 -0
- package/dist/chunk-DNQ6N3VG.js.map +1 -0
- package/dist/chunk-E2S7RAT2.js +126 -0
- package/dist/chunk-E2S7RAT2.js.map +1 -0
- package/dist/chunk-E6PR75X7.js +15 -0
- package/dist/chunk-E6PR75X7.js.map +1 -0
- package/dist/chunk-EGQ4JCFU.cjs +109 -0
- package/dist/chunk-EGQ4JCFU.cjs.map +1 -0
- package/dist/chunk-ETPZGEL7.cjs +105 -0
- package/dist/chunk-ETPZGEL7.cjs.map +1 -0
- package/dist/chunk-FFJ6BVEY.cjs +132 -0
- package/dist/chunk-FFJ6BVEY.cjs.map +1 -0
- package/dist/chunk-FKYNRMPX.js +133 -0
- package/dist/chunk-FKYNRMPX.js.map +1 -0
- package/dist/chunk-FRWC6GUR.cjs +126 -0
- package/dist/chunk-FRWC6GUR.cjs.map +1 -0
- package/dist/chunk-FUZFNUCJ.js +104 -0
- package/dist/chunk-FUZFNUCJ.js.map +1 -0
- package/dist/chunk-GM3ZO5WV.js +13 -0
- package/dist/chunk-GM3ZO5WV.js.map +1 -0
- package/dist/chunk-GNRRK7TZ.cjs +149 -0
- package/dist/chunk-GNRRK7TZ.cjs.map +1 -0
- package/dist/chunk-H2AE7JMU.js +128 -0
- package/dist/chunk-H2AE7JMU.js.map +1 -0
- package/dist/chunk-H4RNJ7FK.cjs +115 -0
- package/dist/chunk-H4RNJ7FK.cjs.map +1 -0
- package/dist/chunk-HB4EGHJ7.cjs +153 -0
- package/dist/chunk-HB4EGHJ7.cjs.map +1 -0
- package/dist/chunk-HDWWUEPD.js +122 -0
- package/dist/chunk-HDWWUEPD.js.map +1 -0
- package/dist/chunk-HOOOCSU4.js +216 -0
- package/dist/chunk-HOOOCSU4.js.map +1 -0
- package/dist/chunk-J6NPRKT4.cjs +49 -0
- package/dist/chunk-J6NPRKT4.cjs.map +1 -0
- package/dist/chunk-JO6U4YR4.js +355 -0
- package/dist/chunk-JO6U4YR4.js.map +1 -0
- package/dist/chunk-KE7ILTM4.cjs +162 -0
- package/dist/chunk-KE7ILTM4.cjs.map +1 -0
- package/dist/chunk-KSRROKYC.cjs +135 -0
- package/dist/chunk-KSRROKYC.cjs.map +1 -0
- package/dist/chunk-KVI6DN3R.js +147 -0
- package/dist/chunk-KVI6DN3R.js.map +1 -0
- package/dist/chunk-L54BZYAI.cjs +111 -0
- package/dist/chunk-L54BZYAI.cjs.map +1 -0
- package/dist/chunk-LB4MV5CG.js +109 -0
- package/dist/chunk-LB4MV5CG.js.map +1 -0
- package/dist/chunk-LEJGLR2P.cjs +106 -0
- package/dist/chunk-LEJGLR2P.cjs.map +1 -0
- package/dist/chunk-LU35QDPN.cjs +30 -0
- package/dist/chunk-LU35QDPN.cjs.map +1 -0
- package/dist/chunk-LUTU4WW3.js +151 -0
- package/dist/chunk-LUTU4WW3.js.map +1 -0
- package/dist/chunk-M4AQD6WX.cjs +220 -0
- package/dist/chunk-M4AQD6WX.cjs.map +1 -0
- package/dist/chunk-M4UST3UU.cjs +159 -0
- package/dist/chunk-M4UST3UU.cjs.map +1 -0
- package/dist/chunk-MLD5ZIDO.cjs +359 -0
- package/dist/chunk-MLD5ZIDO.cjs.map +1 -0
- package/dist/chunk-MLX3EO2C.js +107 -0
- package/dist/chunk-MLX3EO2C.js.map +1 -0
- package/dist/chunk-MVWERW4G.cjs +28 -0
- package/dist/chunk-MVWERW4G.cjs.map +1 -0
- package/dist/chunk-MYPCA25Y.cjs +115 -0
- package/dist/chunk-MYPCA25Y.cjs.map +1 -0
- package/dist/chunk-N6IVODRJ.js +114 -0
- package/dist/chunk-N6IVODRJ.js.map +1 -0
- package/dist/chunk-NFD6VAVM.js +155 -0
- package/dist/chunk-NFD6VAVM.js.map +1 -0
- package/dist/chunk-NHGKZMD7.cjs +18 -0
- package/dist/chunk-NHGKZMD7.cjs.map +1 -0
- package/dist/chunk-NMLDPXOL.js +167 -0
- package/dist/chunk-NMLDPXOL.js.map +1 -0
- package/dist/chunk-NONU7KUN.cjs +32 -0
- package/dist/chunk-NONU7KUN.cjs.map +1 -0
- package/dist/chunk-NQSC7CKN.js +130 -0
- package/dist/chunk-NQSC7CKN.js.map +1 -0
- package/dist/chunk-NYVFC2SF.js +87 -0
- package/dist/chunk-NYVFC2SF.js.map +1 -0
- package/dist/chunk-O5KGKQSU.js +218 -0
- package/dist/chunk-O5KGKQSU.js.map +1 -0
- package/dist/chunk-OGSZO22B.js +26 -0
- package/dist/chunk-OGSZO22B.js.map +1 -0
- package/dist/chunk-Q2BDB5ZA.cjs +218 -0
- package/dist/chunk-Q2BDB5ZA.cjs.map +1 -0
- package/dist/chunk-Q6U5D2ZB.cjs +210 -0
- package/dist/chunk-Q6U5D2ZB.cjs.map +1 -0
- package/dist/chunk-QAYX6XN3.js +26 -0
- package/dist/chunk-QAYX6XN3.js.map +1 -0
- package/dist/chunk-QHJHYV3H.cjs +15 -0
- package/dist/chunk-QHJHYV3H.cjs.map +1 -0
- package/dist/chunk-QIJZZOX7.js +249 -0
- package/dist/chunk-QIJZZOX7.js.map +1 -0
- package/dist/chunk-QLRK46YY.cjs +93 -0
- package/dist/chunk-QLRK46YY.cjs.map +1 -0
- package/dist/chunk-QZ4ZYTP6.js +124 -0
- package/dist/chunk-QZ4ZYTP6.js.map +1 -0
- package/dist/chunk-RCVRZCCC.cjs +156 -0
- package/dist/chunk-RCVRZCCC.cjs.map +1 -0
- package/dist/chunk-ROYZ7W4M.cjs +81 -0
- package/dist/chunk-ROYZ7W4M.cjs.map +1 -0
- package/dist/chunk-SJS4ISBA.js +163 -0
- package/dist/chunk-SJS4ISBA.js.map +1 -0
- package/dist/chunk-SKVCPG5R.cjs +124 -0
- package/dist/chunk-SKVCPG5R.cjs.map +1 -0
- package/dist/chunk-SQJAKZ4W.js +113 -0
- package/dist/chunk-SQJAKZ4W.js.map +1 -0
- package/dist/chunk-SUNC3CPV.js +79 -0
- package/dist/chunk-SUNC3CPV.js.map +1 -0
- package/dist/chunk-SWYCVF46.js +145 -0
- package/dist/chunk-SWYCVF46.js.map +1 -0
- package/dist/chunk-SZVK6RRQ.js +98 -0
- package/dist/chunk-SZVK6RRQ.js.map +1 -0
- package/dist/chunk-TOS2RYHQ.js +154 -0
- package/dist/chunk-TOS2RYHQ.js.map +1 -0
- package/dist/chunk-TTOX27BZ.cjs +116 -0
- package/dist/chunk-TTOX27BZ.cjs.map +1 -0
- package/dist/chunk-TW6KPQIS.js +160 -0
- package/dist/chunk-TW6KPQIS.js.map +1 -0
- package/dist/chunk-UN7K3YQG.cjs +81 -0
- package/dist/chunk-UN7K3YQG.cjs.map +1 -0
- package/dist/chunk-UQBDGCS6.cjs +89 -0
- package/dist/chunk-UQBDGCS6.cjs.map +1 -0
- package/dist/chunk-VPI7UGB3.cjs +130 -0
- package/dist/chunk-VPI7UGB3.cjs.map +1 -0
- package/dist/chunk-X2JNB5UN.js +271 -0
- package/dist/chunk-X2JNB5UN.js.map +1 -0
- package/dist/chunk-XBIM73HV.cjs +126 -0
- package/dist/chunk-XBIM73HV.cjs.map +1 -0
- package/dist/chunk-XHQWWR5M.cjs +4892 -0
- package/dist/chunk-XHQWWR5M.cjs.map +1 -0
- package/dist/chunk-Y2JZHX3P.cjs +169 -0
- package/dist/chunk-Y2JZHX3P.cjs.map +1 -0
- package/dist/chunk-Y4P4VY7A.cjs +251 -0
- package/dist/chunk-Y4P4VY7A.cjs.map +1 -0
- package/dist/chunk-Y54XVNXB.cjs +157 -0
- package/dist/chunk-Y54XVNXB.cjs.map +1 -0
- package/dist/chunk-Z6E3XVP2.cjs +132 -0
- package/dist/chunk-Z6E3XVP2.cjs.map +1 -0
- package/dist/chunk-ZDYCIP6N.cjs +100 -0
- package/dist/chunk-ZDYCIP6N.cjs.map +1 -0
- package/dist/chunk-ZDZQG3GH.cjs +148 -0
- package/dist/chunk-ZDZQG3GH.cjs.map +1 -0
- package/dist/chunk-ZL25X5WW.js +66 -0
- package/dist/chunk-ZL25X5WW.js.map +1 -0
- package/dist/combo-type-BdSohVyy.d.ts +16 -0
- package/dist/combo-type-wodyLq1f.d.cts +16 -0
- package/dist/combo.cjs +34 -0
- package/dist/combo.cjs.map +1 -0
- package/dist/combo.d.cts +8 -0
- package/dist/combo.d.ts +8 -0
- package/dist/combo.js +13 -0
- package/dist/combo.js.map +1 -0
- package/dist/custom-type-B6w1n5Ua.d.cts +23 -0
- package/dist/custom-type-XFjuPwCr.d.ts +23 -0
- package/dist/custom.cjs +33 -0
- package/dist/custom.cjs.map +1 -0
- package/dist/custom.d.cts +8 -0
- package/dist/custom.d.ts +8 -0
- package/dist/custom.js +12 -0
- package/dist/custom.js.map +1 -0
- package/dist/donut.cjs +33 -0
- package/dist/donut.cjs.map +1 -0
- package/dist/donut.d.cts +8 -0
- package/dist/donut.d.ts +8 -0
- package/dist/donut.js +12 -0
- package/dist/donut.js.map +1 -0
- package/dist/dumbbell-type-DPSE0OTg.d.ts +12 -0
- package/dist/dumbbell-type-w424KzI2.d.cts +12 -0
- package/dist/dumbbell.cjs +34 -0
- package/dist/dumbbell.cjs.map +1 -0
- package/dist/dumbbell.d.cts +8 -0
- package/dist/dumbbell.d.ts +8 -0
- package/dist/dumbbell.js +13 -0
- package/dist/dumbbell.js.map +1 -0
- package/dist/engine-CNukbv7k.d.cts +426 -0
- package/dist/engine-CNukbv7k.d.ts +426 -0
- package/dist/factory-dbngWV4d.d.cts +8 -0
- package/dist/factory-jRzNNxwj.d.ts +8 -0
- package/dist/finance.cjs +92 -0
- package/dist/finance.cjs.map +1 -0
- package/dist/finance.d.cts +192 -0
- package/dist/finance.d.ts +192 -0
- package/dist/finance.js +3 -0
- package/dist/finance.js.map +1 -0
- package/dist/funnel-type-BeVl3ohX.d.cts +9 -0
- package/dist/funnel-type-CMXGQq4T.d.ts +9 -0
- package/dist/funnel.cjs +33 -0
- package/dist/funnel.cjs.map +1 -0
- package/dist/funnel.d.cts +8 -0
- package/dist/funnel.d.ts +8 -0
- package/dist/funnel.js +12 -0
- package/dist/funnel.js.map +1 -0
- package/dist/gauge-type-BpDBwCeD.d.ts +11 -0
- package/dist/gauge-type-DmjDdfsY.d.cts +11 -0
- package/dist/gauge.cjs +33 -0
- package/dist/gauge.cjs.map +1 -0
- package/dist/gauge.d.cts +8 -0
- package/dist/gauge.d.ts +8 -0
- package/dist/gauge.js +12 -0
- package/dist/gauge.js.map +1 -0
- package/dist/geo.cjs +41 -0
- package/dist/geo.cjs.map +1 -0
- package/dist/geo.d.cts +8 -0
- package/dist/geo.d.ts +8 -0
- package/dist/geo.js +12 -0
- package/dist/geo.js.map +1 -0
- package/dist/graph-type-DkdAB6Vc.d.cts +5 -0
- package/dist/graph-type-ul9xwdf5.d.ts +5 -0
- package/dist/graph.cjs +33 -0
- package/dist/graph.cjs.map +1 -0
- package/dist/graph.d.cts +8 -0
- package/dist/graph.d.ts +8 -0
- package/dist/graph.js +12 -0
- package/dist/graph.js.map +1 -0
- package/dist/heatmap-type-D0shkxK7.d.cts +12 -0
- package/dist/heatmap-type-q6nNhVTr.d.ts +12 -0
- package/dist/heatmap.cjs +33 -0
- package/dist/heatmap.cjs.map +1 -0
- package/dist/heatmap.d.cts +8 -0
- package/dist/heatmap.d.ts +8 -0
- package/dist/heatmap.js +12 -0
- package/dist/heatmap.js.map +1 -0
- package/dist/histogram-type-BWil-Rb7.d.cts +13 -0
- package/dist/histogram-type-CF593WSp.d.ts +13 -0
- package/dist/histogram.cjs +33 -0
- package/dist/histogram.cjs.map +1 -0
- package/dist/histogram.d.cts +8 -0
- package/dist/histogram.d.ts +8 -0
- package/dist/histogram.js +12 -0
- package/dist/histogram.js.map +1 -0
- package/dist/horizontal-bar-type-0mqnyMUR.d.cts +11 -0
- package/dist/horizontal-bar-type-DAlrxY0h.d.ts +11 -0
- package/dist/horizontal-bar.cjs +34 -0
- package/dist/horizontal-bar.cjs.map +1 -0
- package/dist/horizontal-bar.d.cts +8 -0
- package/dist/horizontal-bar.d.ts +8 -0
- package/dist/horizontal-bar.js +13 -0
- package/dist/horizontal-bar.js.map +1 -0
- package/dist/index.cjs +1604 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +594 -0
- package/dist/index.d.ts +594 -0
- package/dist/index.js +1201 -0
- package/dist/index.js.map +1 -0
- package/dist/kagi-type-Y5XUVm3h.d.ts +26 -0
- package/dist/kagi-type-aG-Q1bWk.d.cts +26 -0
- package/dist/kagi.cjs +33 -0
- package/dist/kagi.cjs.map +1 -0
- package/dist/kagi.d.cts +8 -0
- package/dist/kagi.d.ts +8 -0
- package/dist/kagi.js +12 -0
- package/dist/kagi.js.map +1 -0
- package/dist/line-type-B8lgTFjb.d.cts +5 -0
- package/dist/line-type-Diw0nXj7.d.ts +5 -0
- package/dist/line.cjs +33 -0
- package/dist/line.cjs.map +1 -0
- package/dist/line.d.cts +8 -0
- package/dist/line.d.ts +8 -0
- package/dist/line.js +12 -0
- package/dist/line.js.map +1 -0
- package/dist/lines-type-CGrg_mDi.d.cts +31 -0
- package/dist/lines-type-V-seVNZ4.d.ts +31 -0
- package/dist/lines.cjs +33 -0
- package/dist/lines.cjs.map +1 -0
- package/dist/lines.d.cts +8 -0
- package/dist/lines.d.ts +8 -0
- package/dist/lines.js +12 -0
- package/dist/lines.js.map +1 -0
- package/dist/lollipop-type-CoTzKLSu.d.cts +11 -0
- package/dist/lollipop-type-Ygc4rRql.d.ts +11 -0
- package/dist/lollipop.cjs +33 -0
- package/dist/lollipop.cjs.map +1 -0
- package/dist/lollipop.d.cts +8 -0
- package/dist/lollipop.d.ts +8 -0
- package/dist/lollipop.js +12 -0
- package/dist/lollipop.js.map +1 -0
- package/dist/matrix-type-Crb_NwUJ.d.cts +26 -0
- package/dist/matrix-type-Dag1VLCY.d.ts +26 -0
- package/dist/matrix.cjs +33 -0
- package/dist/matrix.cjs.map +1 -0
- package/dist/matrix.d.cts +8 -0
- package/dist/matrix.d.ts +8 -0
- package/dist/matrix.js +12 -0
- package/dist/matrix.js.map +1 -0
- package/dist/ohlc-type-BQBHvVJO.d.cts +28 -0
- package/dist/ohlc-type-CGR-vRGL.d.ts +28 -0
- package/dist/ohlc.cjs +33 -0
- package/dist/ohlc.cjs.map +1 -0
- package/dist/ohlc.d.cts +8 -0
- package/dist/ohlc.d.ts +8 -0
- package/dist/ohlc.js +12 -0
- package/dist/ohlc.js.map +1 -0
- package/dist/parallel-type-6t6xyHMg.d.ts +14 -0
- package/dist/parallel-type-D-S-EqeC.d.cts +14 -0
- package/dist/parallel.cjs +33 -0
- package/dist/parallel.cjs.map +1 -0
- package/dist/parallel.d.cts +8 -0
- package/dist/parallel.d.ts +8 -0
- package/dist/parallel.js +12 -0
- package/dist/parallel.js.map +1 -0
- package/dist/pictorialbar-type-A-8mTX1N.d.ts +5 -0
- package/dist/pictorialbar-type-CnJEH9GZ.d.cts +5 -0
- package/dist/pictorialbar.cjs +33 -0
- package/dist/pictorialbar.cjs.map +1 -0
- package/dist/pictorialbar.d.cts +8 -0
- package/dist/pictorialbar.d.ts +8 -0
- package/dist/pictorialbar.js +12 -0
- package/dist/pictorialbar.js.map +1 -0
- package/dist/pie-type-S7kUKGRS.d.ts +7 -0
- package/dist/pie-type-duX5xkfQ.d.cts +7 -0
- package/dist/pie.cjs +33 -0
- package/dist/pie.cjs.map +1 -0
- package/dist/pie.d.cts +8 -0
- package/dist/pie.d.ts +8 -0
- package/dist/pie.js +12 -0
- package/dist/pie.js.map +1 -0
- package/dist/polar-type-CI6-I8Yg.d.cts +11 -0
- package/dist/polar-type-Dj21GIc9.d.ts +11 -0
- package/dist/polar.cjs +33 -0
- package/dist/polar.cjs.map +1 -0
- package/dist/polar.d.cts +8 -0
- package/dist/polar.d.ts +8 -0
- package/dist/polar.js +12 -0
- package/dist/polar.js.map +1 -0
- package/dist/radar-type-CYjZHuKm.d.ts +9 -0
- package/dist/radar-type-Dgyr13Zd.d.cts +9 -0
- package/dist/radar.cjs +33 -0
- package/dist/radar.cjs.map +1 -0
- package/dist/radar.d.cts +8 -0
- package/dist/radar.d.ts +8 -0
- package/dist/radar.js +12 -0
- package/dist/radar.js.map +1 -0
- package/dist/radialbar-type-CLZ8XgST.d.ts +11 -0
- package/dist/radialbar-type-C_SBXoaa.d.cts +11 -0
- package/dist/radialbar.cjs +33 -0
- package/dist/radialbar.cjs.map +1 -0
- package/dist/radialbar.d.cts +8 -0
- package/dist/radialbar.d.ts +8 -0
- package/dist/radialbar.js +12 -0
- package/dist/radialbar.js.map +1 -0
- package/dist/range-type-CkriEnLm.d.cts +26 -0
- package/dist/range-type-_LbMV4tl.d.ts +26 -0
- package/dist/range.cjs +32 -0
- package/dist/range.cjs.map +1 -0
- package/dist/range.d.cts +8 -0
- package/dist/range.d.ts +8 -0
- package/dist/range.js +11 -0
- package/dist/range.js.map +1 -0
- package/dist/renko-type-43OXCtZ3.d.cts +24 -0
- package/dist/renko-type-ejoXt2ro.d.ts +24 -0
- package/dist/renko.cjs +33 -0
- package/dist/renko.cjs.map +1 -0
- package/dist/renko.d.cts +8 -0
- package/dist/renko.d.ts +8 -0
- package/dist/renko.js +12 -0
- package/dist/renko.js.map +1 -0
- package/dist/sankey-type-CN7PL5MQ.d.ts +5 -0
- package/dist/sankey-type-DfkTUnXB.d.cts +5 -0
- package/dist/sankey.cjs +33 -0
- package/dist/sankey.cjs.map +1 -0
- package/dist/sankey.d.cts +8 -0
- package/dist/sankey.d.ts +8 -0
- package/dist/sankey.js +12 -0
- package/dist/sankey.js.map +1 -0
- package/dist/scatter-type-CD7X1pZb.d.cts +5 -0
- package/dist/scatter-type-D3HdPkZ6.d.ts +5 -0
- package/dist/scatter.cjs +32 -0
- package/dist/scatter.cjs.map +1 -0
- package/dist/scatter.d.cts +8 -0
- package/dist/scatter.d.ts +8 -0
- package/dist/scatter.js +11 -0
- package/dist/scatter.js.map +1 -0
- package/dist/sparkline-type-COW3izgF.d.ts +9 -0
- package/dist/sparkline-type-qt3yoLs7.d.cts +9 -0
- package/dist/sparkline.cjs +33 -0
- package/dist/sparkline.cjs.map +1 -0
- package/dist/sparkline.d.cts +8 -0
- package/dist/sparkline.d.ts +8 -0
- package/dist/sparkline.js +12 -0
- package/dist/sparkline.js.map +1 -0
- package/dist/stacked-bar-type-C-5pmb-D.d.ts +8 -0
- package/dist/stacked-bar-type-Ct6HK2A0.d.cts +8 -0
- package/dist/stacked-bar.cjs +34 -0
- package/dist/stacked-bar.cjs.map +1 -0
- package/dist/stacked-bar.d.cts +8 -0
- package/dist/stacked-bar.d.ts +8 -0
- package/dist/stacked-bar.js +13 -0
- package/dist/stacked-bar.js.map +1 -0
- package/dist/step-type-BSL-CUny.d.cts +11 -0
- package/dist/step-type-Cleoshov.d.ts +11 -0
- package/dist/step.cjs +34 -0
- package/dist/step.cjs.map +1 -0
- package/dist/step.d.cts +8 -0
- package/dist/step.d.ts +8 -0
- package/dist/step.js +13 -0
- package/dist/step.js.map +1 -0
- package/dist/sunburst-type-BOztb_Px.d.cts +5 -0
- package/dist/sunburst-type-ZFw2w6m8.d.ts +5 -0
- package/dist/sunburst.cjs +33 -0
- package/dist/sunburst.cjs.map +1 -0
- package/dist/sunburst.d.cts +8 -0
- package/dist/sunburst.d.ts +8 -0
- package/dist/sunburst.js +12 -0
- package/dist/sunburst.js.map +1 -0
- package/dist/themeriver-type-B5PYChcC.d.ts +15 -0
- package/dist/themeriver-type-BnRSsyal.d.cts +15 -0
- package/dist/themeriver.cjs +33 -0
- package/dist/themeriver.cjs.map +1 -0
- package/dist/themeriver.d.cts +8 -0
- package/dist/themeriver.d.ts +8 -0
- package/dist/themeriver.js +12 -0
- package/dist/themeriver.js.map +1 -0
- package/dist/tree-type-B-bOSg0l.d.ts +5 -0
- package/dist/tree-type-Cz84wHnR.d.cts +5 -0
- package/dist/tree.cjs +33 -0
- package/dist/tree.cjs.map +1 -0
- package/dist/tree.d.cts +8 -0
- package/dist/tree.d.ts +8 -0
- package/dist/tree.js +12 -0
- package/dist/tree.js.map +1 -0
- package/dist/treemap-type-DYDj-rWv.d.ts +11 -0
- package/dist/treemap-type-OBCGexiK.d.cts +11 -0
- package/dist/treemap.cjs +33 -0
- package/dist/treemap.cjs.map +1 -0
- package/dist/treemap.d.cts +8 -0
- package/dist/treemap.d.ts +8 -0
- package/dist/treemap.js +12 -0
- package/dist/treemap.js.map +1 -0
- package/dist/volume-type-C9wRmKR6.d.ts +21 -0
- package/dist/volume-type-CfERBN5g.d.cts +21 -0
- package/dist/volume.cjs +33 -0
- package/dist/volume.cjs.map +1 -0
- package/dist/volume.d.cts +8 -0
- package/dist/volume.d.ts +8 -0
- package/dist/volume.js +12 -0
- package/dist/volume.js.map +1 -0
- package/dist/waterfall-type-CpdVtBi_.d.ts +10 -0
- package/dist/waterfall-type-hm5ylGgW.d.cts +10 -0
- package/dist/waterfall.cjs +33 -0
- package/dist/waterfall.cjs.map +1 -0
- package/dist/waterfall.d.cts +8 -0
- package/dist/waterfall.d.ts +8 -0
- package/dist/waterfall.js +12 -0
- package/dist/waterfall.js.map +1 -0
- package/dist/world-regions-Cfvxpbx0.d.ts +50 -0
- package/dist/world-regions-cMulhqDW.d.cts +50 -0
- package/package.json +262 -0
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var chunkNHGKZMD7_cjs = require('./chunk-NHGKZMD7.cjs');
|
|
4
|
+
var chunkXHQWWR5M_cjs = require('./chunk-XHQWWR5M.cjs');
|
|
5
|
+
|
|
6
|
+
// src/charts/ohlc/ohlc-type.ts
|
|
7
|
+
var ohlcChartType = {
|
|
8
|
+
type: "ohlc",
|
|
9
|
+
getScaleTypes() {
|
|
10
|
+
return { x: "categorical", y: "linear" };
|
|
11
|
+
},
|
|
12
|
+
prepareData(data, options) {
|
|
13
|
+
const opts = options;
|
|
14
|
+
const ohlc = opts.ohlc;
|
|
15
|
+
const prepared = chunkXHQWWR5M_cjs.prepareData(data, options);
|
|
16
|
+
if (ohlc) {
|
|
17
|
+
let yMin = prepared.bounds.yMin;
|
|
18
|
+
let yMax = prepared.bounds.yMax;
|
|
19
|
+
for (let i = 0; i < ohlc.high.length; i++) {
|
|
20
|
+
if (ohlc.high[i] < yMin) yMin = ohlc.high[i];
|
|
21
|
+
if (ohlc.high[i] > yMax) yMax = ohlc.high[i];
|
|
22
|
+
if (ohlc.low[i] < yMin) yMin = ohlc.low[i];
|
|
23
|
+
if (ohlc.low[i] > yMax) yMax = ohlc.low[i];
|
|
24
|
+
}
|
|
25
|
+
prepared.bounds.yMin = yMin;
|
|
26
|
+
prepared.bounds.yMax = yMax;
|
|
27
|
+
}
|
|
28
|
+
return prepared;
|
|
29
|
+
},
|
|
30
|
+
render(ctx) {
|
|
31
|
+
const { data, xScale, yScale, options } = ctx;
|
|
32
|
+
const nodes = [];
|
|
33
|
+
const opts = options;
|
|
34
|
+
const ohlc = opts.ohlc;
|
|
35
|
+
if (!ohlc) return nodes;
|
|
36
|
+
const series = data.series[0];
|
|
37
|
+
if (!series) return nodes;
|
|
38
|
+
const upColor = opts.upColor ?? "var(--color-emerald-500, #10b981)";
|
|
39
|
+
const downColor = opts.downColor ?? "var(--color-red-500, #ef4444)";
|
|
40
|
+
const lw = opts.lineWidth ?? 1.5;
|
|
41
|
+
const bw = chunkNHGKZMD7_cjs.getBandwidth(xScale);
|
|
42
|
+
const tickWidth = bw * 0.3;
|
|
43
|
+
const tickNodes = [];
|
|
44
|
+
for (let i = 0; i < ohlc.open.length; i++) {
|
|
45
|
+
const open = ohlc.open[i];
|
|
46
|
+
const high = ohlc.high[i];
|
|
47
|
+
const low = ohlc.low[i];
|
|
48
|
+
const close = ohlc.close[i];
|
|
49
|
+
const cx = xScale.map(i);
|
|
50
|
+
const isUp = close >= open;
|
|
51
|
+
const color = isUp ? upColor : downColor;
|
|
52
|
+
const yHigh = yScale.map(high);
|
|
53
|
+
const yLow = yScale.map(low);
|
|
54
|
+
const yOpen = yScale.map(open);
|
|
55
|
+
const yClose = yScale.map(close);
|
|
56
|
+
tickNodes.push(chunkXHQWWR5M_cjs.line(cx, yHigh, cx, yLow, {
|
|
57
|
+
class: "chartts-ohlc-stem",
|
|
58
|
+
stroke: color,
|
|
59
|
+
strokeWidth: lw,
|
|
60
|
+
"data-series": 0,
|
|
61
|
+
"data-index": i
|
|
62
|
+
}));
|
|
63
|
+
tickNodes.push(chunkXHQWWR5M_cjs.line(cx - tickWidth, yOpen, cx, yOpen, {
|
|
64
|
+
class: "chartts-ohlc-tick",
|
|
65
|
+
stroke: color,
|
|
66
|
+
strokeWidth: lw,
|
|
67
|
+
"data-series": 0,
|
|
68
|
+
"data-index": i
|
|
69
|
+
}));
|
|
70
|
+
tickNodes.push(chunkXHQWWR5M_cjs.line(cx, yClose, cx + tickWidth, yClose, {
|
|
71
|
+
class: "chartts-ohlc-tick",
|
|
72
|
+
stroke: color,
|
|
73
|
+
strokeWidth: lw,
|
|
74
|
+
"data-series": 0,
|
|
75
|
+
"data-index": i,
|
|
76
|
+
tabindex: 0,
|
|
77
|
+
role: "img",
|
|
78
|
+
ariaLabel: `${data.labels[i] ?? i}: O${open} H${high} L${low} C${close}`
|
|
79
|
+
}));
|
|
80
|
+
}
|
|
81
|
+
nodes.push(chunkXHQWWR5M_cjs.group(tickNodes, {
|
|
82
|
+
class: "chartts-series chartts-series-0",
|
|
83
|
+
"data-series-name": series.name
|
|
84
|
+
}));
|
|
85
|
+
return nodes;
|
|
86
|
+
},
|
|
87
|
+
hitTest(ctx, mx, _my) {
|
|
88
|
+
const { xScale, options } = ctx;
|
|
89
|
+
const opts = options;
|
|
90
|
+
const ohlc = opts.ohlc;
|
|
91
|
+
if (!ohlc) return null;
|
|
92
|
+
const bw = chunkNHGKZMD7_cjs.getBandwidth(xScale);
|
|
93
|
+
const half = bw * 0.35;
|
|
94
|
+
for (let i = 0; i < ohlc.open.length; i++) {
|
|
95
|
+
const cx = xScale.map(i);
|
|
96
|
+
if (mx >= cx - half && mx <= cx + half) {
|
|
97
|
+
return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx) };
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
return null;
|
|
101
|
+
}
|
|
102
|
+
};
|
|
103
|
+
|
|
104
|
+
exports.ohlcChartType = ohlcChartType;
|
|
105
|
+
//# sourceMappingURL=chunk-LEJGLR2P.cjs.map
|
|
106
|
+
//# sourceMappingURL=chunk-LEJGLR2P.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/charts/ohlc/ohlc-type.ts"],"names":["prepareData","getBandwidth","line","group"],"mappings":"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","file":"chunk-LEJGLR2P.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 } from '../../render/tree'\nimport { getBandwidth } from '../../utils/scale'\n\nexport interface OHLCOptions {\n /** OHLC data arrays. */\n ohlc?: {\n open: number[]\n high: number[]\n low: number[]\n close: number[]\n }\n /** Up color (close >= open). Default green. */\n upColor?: string\n /** Down color (close < open). Default red. */\n downColor?: string\n /** Line width for stems and ticks. Default 1.5. */\n lineWidth?: number\n}\n\n/**\n * OHLC (Open-High-Low-Close) chart — tick-mark style.\n *\n * Each bar is a vertical line (high→low) with horizontal ticks:\n * - Left tick = open price\n * - Right tick = close price\n * Color indicates direction (green=up, red=down).\n */\nexport const ohlcChartType: ChartTypePlugin = {\n type: 'ohlc',\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 OHLCOptions\n const ohlc = opts.ohlc\n const prepared = prepareData(data, options)\n\n if (ohlc) {\n let yMin = prepared.bounds.yMin\n let yMax = prepared.bounds.yMax\n for (let i = 0; i < ohlc.high.length; i++) {\n if (ohlc.high[i]! < yMin) yMin = ohlc.high[i]!\n if (ohlc.high[i]! > yMax) yMax = ohlc.high[i]!\n if (ohlc.low[i]! < yMin) yMin = ohlc.low[i]!\n if (ohlc.low[i]! > yMax) yMax = ohlc.low[i]!\n }\n prepared.bounds.yMin = yMin\n prepared.bounds.yMax = yMax\n }\n\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, xScale, yScale, options } = ctx\n const nodes: RenderNode[] = []\n\n const opts = options as unknown as OHLCOptions\n const ohlc = opts.ohlc\n if (!ohlc) return nodes\n\n const series = data.series[0]\n if (!series) return nodes\n\n const upColor = opts.upColor ?? 'var(--color-emerald-500, #10b981)'\n const downColor = opts.downColor ?? 'var(--color-red-500, #ef4444)'\n const lw = opts.lineWidth ?? 1.5\n\n const bw = getBandwidth(xScale)\n const tickWidth = bw * 0.3\n\n const tickNodes: RenderNode[] = []\n\n for (let i = 0; i < ohlc.open.length; i++) {\n const open = ohlc.open[i]!\n const high = ohlc.high[i]!\n const low = ohlc.low[i]!\n const close = ohlc.close[i]!\n\n const cx = xScale.map(i)\n const isUp = close >= open\n const color = isUp ? upColor : downColor\n\n const yHigh = yScale.map(high)\n const yLow = yScale.map(low)\n const yOpen = yScale.map(open)\n const yClose = yScale.map(close)\n\n // Vertical stem (high → low)\n tickNodes.push(line(cx, yHigh, cx, yLow, {\n class: 'chartts-ohlc-stem',\n stroke: color,\n strokeWidth: lw,\n 'data-series': 0,\n 'data-index': i,\n }))\n\n // Left tick (open)\n tickNodes.push(line(cx - tickWidth, yOpen, cx, yOpen, {\n class: 'chartts-ohlc-tick',\n stroke: color,\n strokeWidth: lw,\n 'data-series': 0,\n 'data-index': i,\n }))\n\n // Right tick (close)\n tickNodes.push(line(cx, yClose, cx + tickWidth, yClose, {\n class: 'chartts-ohlc-tick',\n stroke: color,\n strokeWidth: lw,\n 'data-series': 0,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[i] ?? i}: O${open} H${high} L${low} C${close}`,\n }))\n }\n\n nodes.push(group(tickNodes, {\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 { xScale, options } = ctx\n const opts = options as unknown as OHLCOptions\n const ohlc = opts.ohlc\n if (!ohlc) return null\n\n const bw = getBandwidth(xScale)\n const half = bw * 0.35\n\n for (let i = 0; i < ohlc.open.length; i++) {\n const cx = xScale.map(i)\n if (mx >= cx - half && mx <= cx + half) {\n return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx) }\n }\n }\n\n return null\n },\n}\n"]}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
// src/utils/format.ts
|
|
4
|
+
function formatNum(v) {
|
|
5
|
+
return Number.isInteger(v) ? String(v) : v.toFixed(2);
|
|
6
|
+
}
|
|
7
|
+
function formatValue(value) {
|
|
8
|
+
const abs = Math.abs(value);
|
|
9
|
+
if (abs >= 1e12) return trimSuffix(value / 1e12, "T");
|
|
10
|
+
if (abs >= 1e9) return trimSuffix(value / 1e9, "B");
|
|
11
|
+
if (abs >= 1e6) return trimSuffix(value / 1e6, "M");
|
|
12
|
+
if (abs >= 1e3) return trimSuffix(value / 1e3, "K");
|
|
13
|
+
if (Number.isInteger(value)) return String(value);
|
|
14
|
+
return value.toFixed(1);
|
|
15
|
+
}
|
|
16
|
+
function formatPercent(value) {
|
|
17
|
+
const v = Math.abs(value) <= 1 ? value * 100 : value;
|
|
18
|
+
const s = v.toFixed(1);
|
|
19
|
+
return (s.endsWith(".0") ? s.slice(0, -2) : s) + "%";
|
|
20
|
+
}
|
|
21
|
+
function trimSuffix(v, suffix) {
|
|
22
|
+
const s = v.toFixed(1);
|
|
23
|
+
return (s.endsWith(".0") ? s.slice(0, -2) : s) + suffix;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
exports.formatNum = formatNum;
|
|
27
|
+
exports.formatPercent = formatPercent;
|
|
28
|
+
exports.formatValue = formatValue;
|
|
29
|
+
//# sourceMappingURL=chunk-LU35QDPN.cjs.map
|
|
30
|
+
//# sourceMappingURL=chunk-LU35QDPN.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/utils/format.ts"],"names":[],"mappings":";;;AAIO,SAAS,UAAU,CAAA,EAAmB;AAC3C,EAAA,OAAO,MAAA,CAAO,UAAU,CAAC,CAAA,GAAI,OAAO,CAAC,CAAA,GAAI,CAAA,CAAE,OAAA,CAAQ,CAAC,CAAA;AACtD;AAMO,SAAS,YAAY,KAAA,EAAuB;AACjD,EAAA,MAAM,GAAA,GAAM,IAAA,CAAK,GAAA,CAAI,KAAK,CAAA;AAC1B,EAAA,IAAI,OAAO,IAAA,EAAM,OAAO,UAAA,CAAW,KAAA,GAAQ,MAAM,GAAG,CAAA;AACpD,EAAA,IAAI,OAAO,GAAA,EAAK,OAAO,UAAA,CAAW,KAAA,GAAQ,KAAK,GAAG,CAAA;AAClD,EAAA,IAAI,OAAO,GAAA,EAAK,OAAO,UAAA,CAAW,KAAA,GAAQ,KAAK,GAAG,CAAA;AAClD,EAAA,IAAI,OAAO,GAAA,EAAK,OAAO,UAAA,CAAW,KAAA,GAAQ,KAAK,GAAG,CAAA;AAClD,EAAA,IAAI,OAAO,SAAA,CAAU,KAAK,CAAA,EAAG,OAAO,OAAO,KAAK,CAAA;AAChD,EAAA,OAAO,KAAA,CAAM,QAAQ,CAAC,CAAA;AACxB;AAMO,SAAS,cAAc,KAAA,EAAuB;AACnD,EAAA,MAAM,IAAI,IAAA,CAAK,GAAA,CAAI,KAAK,CAAA,IAAK,CAAA,GAAI,QAAQ,GAAA,GAAM,KAAA;AAC/C,EAAA,MAAM,CAAA,GAAI,CAAA,CAAE,OAAA,CAAQ,CAAC,CAAA;AACrB,EAAA,OAAA,CAAQ,CAAA,CAAE,SAAS,IAAI,CAAA,GAAI,EAAE,KAAA,CAAM,CAAA,EAAG,EAAE,CAAA,GAAI,CAAA,IAAK,GAAA;AACnD;AAEA,SAAS,UAAA,CAAW,GAAW,MAAA,EAAwB;AACrD,EAAA,MAAM,CAAA,GAAI,CAAA,CAAE,OAAA,CAAQ,CAAC,CAAA;AACrB,EAAA,OAAA,CAAQ,CAAA,CAAE,SAAS,IAAI,CAAA,GAAI,EAAE,KAAA,CAAM,CAAA,EAAG,EAAE,CAAA,GAAI,CAAA,IAAK,MAAA;AACnD","file":"chunk-LU35QDPN.cjs","sourcesContent":["/**\n * Shared number formatting for SVG path data strings.\n * Outputs integers as-is, decimals with 2 decimal places.\n */\nexport function formatNum(v: number): string {\n return Number.isInteger(v) ? String(v) : v.toFixed(2)\n}\n\n/**\n * Human-readable value formatter with SI suffixes.\n * 1500 → \"1.5K\", 2000000 → \"2M\", 3000000000 → \"3B\"\n */\nexport function formatValue(value: number): string {\n const abs = Math.abs(value)\n if (abs >= 1e12) return trimSuffix(value / 1e12, 'T')\n if (abs >= 1e9) return trimSuffix(value / 1e9, 'B')\n if (abs >= 1e6) return trimSuffix(value / 1e6, 'M')\n if (abs >= 1e3) return trimSuffix(value / 1e3, 'K')\n if (Number.isInteger(value)) return String(value)\n return value.toFixed(1)\n}\n\n/**\n * Percentage formatter: 0.75 → \"75%\", 42 → \"42%\"\n * Values <= 1 are treated as ratios and multiplied by 100.\n */\nexport function formatPercent(value: number): string {\n const v = Math.abs(value) <= 1 ? value * 100 : value\n const s = v.toFixed(1)\n return (s.endsWith('.0') ? s.slice(0, -2) : s) + '%'\n}\n\nfunction trimSuffix(v: number, suffix: string): string {\n const s = v.toFixed(1)\n return (s.endsWith('.0') ? s.slice(0, -2) : s) + suffix\n}\n"]}
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
import { prepareNoAxes } from './chunk-3XVGEBR4.js';
|
|
2
|
+
import { rect, text, group } from './chunk-3BRQGYDX.js';
|
|
3
|
+
|
|
4
|
+
// src/charts/treemap/treemap-type.ts
|
|
5
|
+
var treemapChartType = {
|
|
6
|
+
type: "treemap",
|
|
7
|
+
getScaleTypes() {
|
|
8
|
+
return { x: "categorical", y: "linear" };
|
|
9
|
+
},
|
|
10
|
+
prepareData(data, options) {
|
|
11
|
+
return prepareNoAxes(data, options);
|
|
12
|
+
},
|
|
13
|
+
render(ctx) {
|
|
14
|
+
const { data, area, theme, options } = ctx;
|
|
15
|
+
const nodes = [];
|
|
16
|
+
const series = data.series[0];
|
|
17
|
+
if (!series || series.values.length === 0) return nodes;
|
|
18
|
+
const items = series.values.map((v, i) => ({ value: Math.abs(v), index: i })).filter((d) => d.value > 0).sort((a, b) => b.value - a.value);
|
|
19
|
+
if (items.length === 0) return nodes;
|
|
20
|
+
const total = items.reduce((s, d) => s + d.value, 0);
|
|
21
|
+
const gap = 2;
|
|
22
|
+
const rects = squarify(items.map((d) => d.value / total), area.x, area.y, area.width, area.height);
|
|
23
|
+
for (let k = 0; k < items.length; k++) {
|
|
24
|
+
const item = items[k];
|
|
25
|
+
const r = rects[k];
|
|
26
|
+
const colorIndex = item.index % options.colors.length;
|
|
27
|
+
const color = options.colors[colorIndex];
|
|
28
|
+
const label = String(data.labels[item.index] ?? `Item ${item.index + 1}`);
|
|
29
|
+
const cellNodes = [];
|
|
30
|
+
cellNodes.push(rect(r.x + gap / 2, r.y + gap / 2, r.w - gap, r.h - gap, {
|
|
31
|
+
class: "chartts-treemap-cell",
|
|
32
|
+
fill: color,
|
|
33
|
+
fillOpacity: 0.75,
|
|
34
|
+
rx: 5,
|
|
35
|
+
ry: 5,
|
|
36
|
+
"data-series": 0,
|
|
37
|
+
"data-index": item.index,
|
|
38
|
+
tabindex: 0,
|
|
39
|
+
role: "img",
|
|
40
|
+
ariaLabel: `${label}: ${series.values[item.index]}`
|
|
41
|
+
}));
|
|
42
|
+
if (r.w > 30 && r.h > 20) {
|
|
43
|
+
const fontSize = Math.min(theme.fontSizeSmall, r.w * 0.15, r.h * 0.3);
|
|
44
|
+
cellNodes.push(text(r.x + r.w / 2, r.y + r.h / 2 - fontSize * 0.3, label, {
|
|
45
|
+
class: "chartts-treemap-label",
|
|
46
|
+
fill: "#fff",
|
|
47
|
+
textAnchor: "middle",
|
|
48
|
+
dominantBaseline: "central",
|
|
49
|
+
fontSize,
|
|
50
|
+
fontFamily: theme.fontFamily,
|
|
51
|
+
fontWeight: 600
|
|
52
|
+
}));
|
|
53
|
+
if (r.h > 35) {
|
|
54
|
+
cellNodes.push(text(r.x + r.w / 2, r.y + r.h / 2 + fontSize * 0.8, String(series.values[item.index]), {
|
|
55
|
+
class: "chartts-treemap-value",
|
|
56
|
+
fill: "rgba(255,255,255,0.7)",
|
|
57
|
+
textAnchor: "middle",
|
|
58
|
+
dominantBaseline: "central",
|
|
59
|
+
fontSize: fontSize * 0.85,
|
|
60
|
+
fontFamily: theme.fontFamily
|
|
61
|
+
}));
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
nodes.push(group(cellNodes, {
|
|
65
|
+
class: `chartts-series chartts-series-${item.index}`,
|
|
66
|
+
"data-series-name": label
|
|
67
|
+
}));
|
|
68
|
+
}
|
|
69
|
+
return nodes;
|
|
70
|
+
},
|
|
71
|
+
hitTest(ctx, mx, my) {
|
|
72
|
+
const { data, area } = ctx;
|
|
73
|
+
const series = data.series[0];
|
|
74
|
+
if (!series || series.values.length === 0) return null;
|
|
75
|
+
const items = series.values.map((v, i) => ({ value: Math.abs(v), index: i })).filter((d) => d.value > 0).sort((a, b) => b.value - a.value);
|
|
76
|
+
if (items.length === 0) return null;
|
|
77
|
+
const total = items.reduce((s, d) => s + d.value, 0);
|
|
78
|
+
const rects = squarify(items.map((d) => d.value / total), area.x, area.y, area.width, area.height);
|
|
79
|
+
for (let k = 0; k < items.length; k++) {
|
|
80
|
+
const r = rects[k];
|
|
81
|
+
if (mx >= r.x && mx <= r.x + r.w && my >= r.y && my <= r.y + r.h) {
|
|
82
|
+
return { seriesIndex: 0, pointIndex: items[k].index, distance: 0 };
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
return null;
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
function squarify(values, x, y, w, h) {
|
|
89
|
+
const rects = [];
|
|
90
|
+
layoutRow(values, 0, x, y, w, h, rects);
|
|
91
|
+
return rects;
|
|
92
|
+
}
|
|
93
|
+
function layoutRow(values, start, x, y, w, h, rects) {
|
|
94
|
+
if (start >= values.length) return;
|
|
95
|
+
if (values.length - start === 1) {
|
|
96
|
+
rects.push({ x, y, w, h });
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
const isWide = w >= h;
|
|
100
|
+
let rowSum = 0;
|
|
101
|
+
let bestWorst = Infinity;
|
|
102
|
+
let rowEnd = start;
|
|
103
|
+
for (let i = start; i < values.length; i++) {
|
|
104
|
+
const newSum = rowSum + values[i];
|
|
105
|
+
const rowFraction = newSum;
|
|
106
|
+
const rowThickness2 = isWide ? w * rowFraction : h * rowFraction;
|
|
107
|
+
const count = i - start + 1;
|
|
108
|
+
if (rowThickness2 <= 0) {
|
|
109
|
+
rowSum = newSum;
|
|
110
|
+
rowEnd = i + 1;
|
|
111
|
+
continue;
|
|
112
|
+
}
|
|
113
|
+
let worst = 0;
|
|
114
|
+
for (let j = start; j <= i; j++) {
|
|
115
|
+
const cellFrac = values[j] / newSum;
|
|
116
|
+
const cellLen = isWide ? h * cellFrac : w * cellFrac;
|
|
117
|
+
const ar = Math.max(rowThickness2 / cellLen, cellLen / rowThickness2);
|
|
118
|
+
if (ar > worst) worst = ar;
|
|
119
|
+
}
|
|
120
|
+
if (count === 1 || worst <= bestWorst) {
|
|
121
|
+
bestWorst = worst;
|
|
122
|
+
rowSum = newSum;
|
|
123
|
+
rowEnd = i + 1;
|
|
124
|
+
} else {
|
|
125
|
+
break;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
if (rowEnd === start) rowEnd = start + 1;
|
|
129
|
+
const finalSum = values.slice(start, rowEnd).reduce((a, b) => a + b, 0);
|
|
130
|
+
const rowThickness = isWide ? w * finalSum : h * finalSum;
|
|
131
|
+
let offset = 0;
|
|
132
|
+
for (let i = start; i < rowEnd; i++) {
|
|
133
|
+
const frac = finalSum > 0 ? values[i] / finalSum : 0;
|
|
134
|
+
const cellLen = isWide ? h * frac : w * frac;
|
|
135
|
+
if (isWide) {
|
|
136
|
+
rects.push({ x, y: y + offset, w: rowThickness, h: cellLen });
|
|
137
|
+
} else {
|
|
138
|
+
rects.push({ x: x + offset, y, w: cellLen, h: rowThickness });
|
|
139
|
+
}
|
|
140
|
+
offset += cellLen;
|
|
141
|
+
}
|
|
142
|
+
if (isWide) {
|
|
143
|
+
layoutRow(values, rowEnd, x + rowThickness, y, w - rowThickness, h, rects);
|
|
144
|
+
} else {
|
|
145
|
+
layoutRow(values, rowEnd, x, y + rowThickness, w, h - rowThickness, rects);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
export { treemapChartType };
|
|
150
|
+
//# sourceMappingURL=chunk-LUTU4WW3.js.map
|
|
151
|
+
//# sourceMappingURL=chunk-LUTU4WW3.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/charts/treemap/treemap-type.ts"],"names":["rowThickness"],"mappings":"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","file":"chunk-LUTU4WW3.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 }\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"]}
|
|
@@ -0,0 +1,220 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var chunk5QOQR5FE_cjs = require('./chunk-5QOQR5FE.cjs');
|
|
4
|
+
var chunkXHQWWR5M_cjs = require('./chunk-XHQWWR5M.cjs');
|
|
5
|
+
|
|
6
|
+
// src/charts/chord/chord-type.ts
|
|
7
|
+
var chordChartType = {
|
|
8
|
+
type: "chord",
|
|
9
|
+
getScaleTypes() {
|
|
10
|
+
return { x: "categorical", y: "linear" };
|
|
11
|
+
},
|
|
12
|
+
prepareData(data, options) {
|
|
13
|
+
return chunk5QOQR5FE_cjs.prepareNoAxes(data, options);
|
|
14
|
+
},
|
|
15
|
+
render(ctx) {
|
|
16
|
+
const { data, area, theme, options } = ctx;
|
|
17
|
+
const nodes = [];
|
|
18
|
+
const { arcs, ribbons } = buildChordLayout(data);
|
|
19
|
+
if (arcs.length === 0) return nodes;
|
|
20
|
+
const cx = area.x + area.width / 2;
|
|
21
|
+
const cy = area.y + area.height / 2;
|
|
22
|
+
const outerR = Math.min(area.width, area.height) / 2 - 20;
|
|
23
|
+
const innerR = outerR - 14;
|
|
24
|
+
for (const arc of arcs) {
|
|
25
|
+
if (arc.endAngle - arc.startAngle < 0.01) continue;
|
|
26
|
+
const color = options.colors[arc.index % options.colors.length];
|
|
27
|
+
const pb = new chunkXHQWWR5M_cjs.PathBuilder();
|
|
28
|
+
const x1o = cx + outerR * Math.cos(arc.startAngle);
|
|
29
|
+
const y1o = cy + outerR * Math.sin(arc.startAngle);
|
|
30
|
+
const x2o = cx + outerR * Math.cos(arc.endAngle);
|
|
31
|
+
const y2o = cy + outerR * Math.sin(arc.endAngle);
|
|
32
|
+
const x1i = cx + innerR * Math.cos(arc.endAngle);
|
|
33
|
+
const y1i = cy + innerR * Math.sin(arc.endAngle);
|
|
34
|
+
const x2i = cx + innerR * Math.cos(arc.startAngle);
|
|
35
|
+
const y2i = cy + innerR * Math.sin(arc.startAngle);
|
|
36
|
+
const largeArc = arc.endAngle - arc.startAngle > Math.PI;
|
|
37
|
+
pb.moveTo(x1o, y1o);
|
|
38
|
+
pb.arc(outerR, outerR, 0, largeArc, true, x2o, y2o);
|
|
39
|
+
pb.lineTo(x1i, y1i);
|
|
40
|
+
pb.arc(innerR, innerR, 0, largeArc, false, x2i, y2i);
|
|
41
|
+
pb.close();
|
|
42
|
+
nodes.push(chunkXHQWWR5M_cjs.path(pb.build(), {
|
|
43
|
+
class: "chartts-chord-arc",
|
|
44
|
+
fill: color,
|
|
45
|
+
stroke: color,
|
|
46
|
+
strokeWidth: 0.5,
|
|
47
|
+
"data-series": arc.index,
|
|
48
|
+
"data-index": 0,
|
|
49
|
+
tabindex: 0,
|
|
50
|
+
role: "img",
|
|
51
|
+
ariaLabel: `${arc.name}: ${arc.total}`
|
|
52
|
+
}));
|
|
53
|
+
const midAngle = (arc.startAngle + arc.endAngle) / 2;
|
|
54
|
+
const labelR = outerR + 12;
|
|
55
|
+
const lx = cx + labelR * Math.cos(midAngle);
|
|
56
|
+
const ly = cy + labelR * Math.sin(midAngle);
|
|
57
|
+
const anchor = Math.abs(Math.cos(midAngle)) < 0.01 ? "middle" : Math.cos(midAngle) > 0 ? "start" : "end";
|
|
58
|
+
nodes.push(chunkXHQWWR5M_cjs.text(lx, ly, arc.name, {
|
|
59
|
+
class: "chartts-chord-label",
|
|
60
|
+
fill: theme.textColor,
|
|
61
|
+
textAnchor: anchor,
|
|
62
|
+
dominantBaseline: "central",
|
|
63
|
+
fontSize: theme.fontSizeSmall,
|
|
64
|
+
fontFamily: theme.fontFamily
|
|
65
|
+
}));
|
|
66
|
+
}
|
|
67
|
+
for (let ri = 0; ri < ribbons.length; ri++) {
|
|
68
|
+
const ribbon = ribbons[ri];
|
|
69
|
+
const color = options.colors[ribbon.source % options.colors.length];
|
|
70
|
+
const pb = new chunkXHQWWR5M_cjs.PathBuilder();
|
|
71
|
+
const sx1 = cx + innerR * Math.cos(ribbon.sourceStart);
|
|
72
|
+
const sy1 = cy + innerR * Math.sin(ribbon.sourceStart);
|
|
73
|
+
const sx2 = cx + innerR * Math.cos(ribbon.sourceEnd);
|
|
74
|
+
const sy2 = cy + innerR * Math.sin(ribbon.sourceEnd);
|
|
75
|
+
const tx1 = cx + innerR * Math.cos(ribbon.targetStart);
|
|
76
|
+
const ty1 = cy + innerR * Math.sin(ribbon.targetStart);
|
|
77
|
+
const tx2 = cx + innerR * Math.cos(ribbon.targetEnd);
|
|
78
|
+
const ty2 = cy + innerR * Math.sin(ribbon.targetEnd);
|
|
79
|
+
const srcLarge = ribbon.sourceEnd - ribbon.sourceStart > Math.PI;
|
|
80
|
+
const tgtLarge = ribbon.targetEnd - ribbon.targetStart > Math.PI;
|
|
81
|
+
pb.moveTo(sx1, sy1);
|
|
82
|
+
pb.arc(innerR, innerR, 0, srcLarge, true, sx2, sy2);
|
|
83
|
+
pb.quadTo(cx, cy, tx1, ty1);
|
|
84
|
+
pb.arc(innerR, innerR, 0, tgtLarge, true, tx2, ty2);
|
|
85
|
+
pb.quadTo(cx, cy, sx1, sy1);
|
|
86
|
+
pb.close();
|
|
87
|
+
nodes.push(chunkXHQWWR5M_cjs.path(pb.build(), {
|
|
88
|
+
class: "chartts-chord-ribbon",
|
|
89
|
+
fill: color,
|
|
90
|
+
fillOpacity: 0.35,
|
|
91
|
+
stroke: color,
|
|
92
|
+
strokeWidth: 0.3,
|
|
93
|
+
"data-series": ribbon.source,
|
|
94
|
+
"data-index": ri,
|
|
95
|
+
tabindex: 0,
|
|
96
|
+
role: "img",
|
|
97
|
+
ariaLabel: `${arcs[ribbon.source].name} \u2192 ${arcs[ribbon.target].name}: ${ribbon.value}`
|
|
98
|
+
}));
|
|
99
|
+
}
|
|
100
|
+
return nodes;
|
|
101
|
+
},
|
|
102
|
+
hitTest(ctx, mx, my) {
|
|
103
|
+
const { data, area, options } = ctx;
|
|
104
|
+
const { arcs } = buildChordLayout(data);
|
|
105
|
+
if (arcs.length === 0) return null;
|
|
106
|
+
const cx = area.x + area.width / 2;
|
|
107
|
+
const cy = area.y + area.height / 2;
|
|
108
|
+
const outerR = Math.min(area.width, area.height) / 2 - 20;
|
|
109
|
+
const innerR = outerR - 14;
|
|
110
|
+
const dx = mx - cx;
|
|
111
|
+
const dy = my - cy;
|
|
112
|
+
const dist = Math.sqrt(dx * dx + dy * dy);
|
|
113
|
+
if (dist >= innerR && dist <= outerR) {
|
|
114
|
+
let angle = Math.atan2(dy, dx);
|
|
115
|
+
if (angle < -Math.PI / 2) angle += Math.PI * 2;
|
|
116
|
+
for (const arc of arcs) {
|
|
117
|
+
if (angle >= arc.startAngle && angle <= arc.endAngle) {
|
|
118
|
+
return { seriesIndex: arc.index, pointIndex: 0, distance: 0 };
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
return null;
|
|
123
|
+
}
|
|
124
|
+
};
|
|
125
|
+
function buildChordLayout(data, _options) {
|
|
126
|
+
const arcs = [];
|
|
127
|
+
const ribbons = [];
|
|
128
|
+
const hasArrows = data.series.some((s) => s.name.includes("\u2192") || s.name.includes("->"));
|
|
129
|
+
const nodeNames = [];
|
|
130
|
+
const nodeMap = /* @__PURE__ */ new Map();
|
|
131
|
+
function getOrCreate(name) {
|
|
132
|
+
if (nodeMap.has(name)) return nodeMap.get(name);
|
|
133
|
+
const idx = nodeNames.length;
|
|
134
|
+
nodeMap.set(name, idx);
|
|
135
|
+
nodeNames.push(name);
|
|
136
|
+
return idx;
|
|
137
|
+
}
|
|
138
|
+
if (hasArrows) {
|
|
139
|
+
for (const series of data.series) {
|
|
140
|
+
const parts = series.name.split(/\s*(?:→|->)\s*/);
|
|
141
|
+
if (parts.length < 2) continue;
|
|
142
|
+
getOrCreate(parts[0].trim());
|
|
143
|
+
getOrCreate(parts[1].trim());
|
|
144
|
+
}
|
|
145
|
+
} else {
|
|
146
|
+
for (let i = 0; i < data.labels.length; i++) {
|
|
147
|
+
getOrCreate(String(data.labels[i]));
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
const n = nodeNames.length;
|
|
151
|
+
if (n === 0) return { arcs, ribbons, matrix: [] };
|
|
152
|
+
const matrix = Array.from({ length: n }, () => new Array(n).fill(0));
|
|
153
|
+
if (hasArrows) {
|
|
154
|
+
for (const series of data.series) {
|
|
155
|
+
const parts = series.name.split(/\s*(?:→|->)\s*/);
|
|
156
|
+
if (parts.length < 2) continue;
|
|
157
|
+
const src = getOrCreate(parts[0].trim());
|
|
158
|
+
const tgt = getOrCreate(parts[1].trim());
|
|
159
|
+
const val = series.values[0] ?? 0;
|
|
160
|
+
if (val > 0) matrix[src][tgt] += val;
|
|
161
|
+
}
|
|
162
|
+
} else {
|
|
163
|
+
for (let si = 0; si < data.series.length && si < n; si++) {
|
|
164
|
+
for (let j = 0; j < data.series[si].values.length && j < n; j++) {
|
|
165
|
+
const val = data.series[si].values[j];
|
|
166
|
+
if (val > 0) matrix[si][j] = val;
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
const totals = nodeNames.map((_, i) => {
|
|
171
|
+
let total = 0;
|
|
172
|
+
for (let j = 0; j < n; j++) {
|
|
173
|
+
total += matrix[i][j];
|
|
174
|
+
total += matrix[j][i];
|
|
175
|
+
}
|
|
176
|
+
return total;
|
|
177
|
+
});
|
|
178
|
+
const grandTotal = totals.reduce((s, t) => s + t, 0);
|
|
179
|
+
if (grandTotal === 0) return { arcs, ribbons, matrix };
|
|
180
|
+
const padAngle = 0.04;
|
|
181
|
+
const totalPad = padAngle * n;
|
|
182
|
+
const available = Math.PI * 2 - totalPad;
|
|
183
|
+
let angle = -Math.PI / 2;
|
|
184
|
+
for (let i = 0; i < n; i++) {
|
|
185
|
+
const span = totals[i] / grandTotal * available;
|
|
186
|
+
arcs.push({
|
|
187
|
+
index: i,
|
|
188
|
+
name: nodeNames[i],
|
|
189
|
+
total: totals[i],
|
|
190
|
+
startAngle: angle,
|
|
191
|
+
endAngle: angle + span
|
|
192
|
+
});
|
|
193
|
+
angle += span + padAngle;
|
|
194
|
+
}
|
|
195
|
+
const arcOffsets = arcs.map((a) => a.startAngle);
|
|
196
|
+
for (let i = 0; i < n; i++) {
|
|
197
|
+
for (let j = i; j < n; j++) {
|
|
198
|
+
const val = matrix[i][j] + matrix[j][i];
|
|
199
|
+
if (val <= 0) continue;
|
|
200
|
+
const srcSpan = matrix[i][j] / Math.max(totals[i], 1) * (arcs[i].endAngle - arcs[i].startAngle);
|
|
201
|
+
const tgtSpan = matrix[j][i] / Math.max(totals[j], 1) * (arcs[j].endAngle - arcs[j].startAngle);
|
|
202
|
+
ribbons.push({
|
|
203
|
+
source: i,
|
|
204
|
+
target: j,
|
|
205
|
+
value: val,
|
|
206
|
+
sourceStart: arcOffsets[i],
|
|
207
|
+
sourceEnd: arcOffsets[i] + srcSpan,
|
|
208
|
+
targetStart: arcOffsets[j],
|
|
209
|
+
targetEnd: arcOffsets[j] + tgtSpan
|
|
210
|
+
});
|
|
211
|
+
arcOffsets[i] += srcSpan;
|
|
212
|
+
arcOffsets[j] += tgtSpan;
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
return { arcs, ribbons, matrix };
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
exports.chordChartType = chordChartType;
|
|
219
|
+
//# sourceMappingURL=chunk-M4AQD6WX.cjs.map
|
|
220
|
+
//# sourceMappingURL=chunk-M4AQD6WX.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/charts/chord/chord-type.ts"],"names":["prepareNoAxes","PathBuilder","path","text"],"mappings":"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","file":"chunk-M4AQD6WX.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { path, text } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Chord diagram — shows relationships between entities via ribbons\n * connecting arcs on a circle.\n *\n * Data convention:\n * - labels: entity names (placed around the circle as arcs)\n * - series[i].values[j]: flow from entity i to entity j (adjacency matrix)\n * series.length should equal labels.length for a square matrix.\n *\n * Alternative: arrow notation like Sankey\n * - series names contain \"→\" or \"->\" (e.g., \"A → B\")\n */\n\ninterface ChordArc {\n index: number\n name: string\n total: number\n startAngle: number\n endAngle: number\n}\n\ninterface ChordRibbon {\n source: number\n target: number\n value: number\n sourceStart: number\n sourceEnd: number\n targetStart: number\n targetEnd: number\n}\n\nexport const chordChartType: ChartTypePlugin = {\n type: 'chord',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const { arcs, ribbons } = buildChordLayout(data, options)\n if (arcs.length === 0) return nodes\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR - 14\n\n // Render arcs\n for (const arc of arcs) {\n if (arc.endAngle - arc.startAngle < 0.01) continue\n\n const color = options.colors[arc.index % options.colors.length]!\n const pb = new PathBuilder()\n\n const x1o = cx + outerR * Math.cos(arc.startAngle)\n const y1o = cy + outerR * Math.sin(arc.startAngle)\n const x2o = cx + outerR * Math.cos(arc.endAngle)\n const y2o = cy + outerR * Math.sin(arc.endAngle)\n const x1i = cx + innerR * Math.cos(arc.endAngle)\n const y1i = cy + innerR * Math.sin(arc.endAngle)\n const x2i = cx + innerR * Math.cos(arc.startAngle)\n const y2i = cy + innerR * Math.sin(arc.startAngle)\n const largeArc = (arc.endAngle - arc.startAngle) > Math.PI\n\n pb.moveTo(x1o, y1o)\n pb.arc(outerR, outerR, 0, largeArc, true, x2o, y2o)\n pb.lineTo(x1i, y1i)\n pb.arc(innerR, innerR, 0, largeArc, false, x2i, y2i)\n pb.close()\n\n nodes.push(path(pb.build(), {\n class: 'chartts-chord-arc',\n fill: color,\n stroke: color,\n strokeWidth: 0.5,\n 'data-series': arc.index,\n 'data-index': 0,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${arc.name}: ${arc.total}`,\n }))\n\n // Label\n const midAngle = (arc.startAngle + arc.endAngle) / 2\n const labelR = outerR + 12\n const lx = cx + labelR * Math.cos(midAngle)\n const ly = cy + labelR * Math.sin(midAngle)\n const anchor = Math.abs(Math.cos(midAngle)) < 0.01 ? 'middle' as const\n : Math.cos(midAngle) > 0 ? 'start' as const : 'end' as const\n\n nodes.push(text(lx, ly, arc.name, {\n class: 'chartts-chord-label',\n fill: theme.textColor,\n textAnchor: anchor,\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Render ribbons\n for (let ri = 0; ri < ribbons.length; ri++) {\n const ribbon = ribbons[ri]!\n const color = options.colors[ribbon.source % options.colors.length]!\n\n const pb = new PathBuilder()\n // Source arc on inner ring\n const sx1 = cx + innerR * Math.cos(ribbon.sourceStart)\n const sy1 = cy + innerR * Math.sin(ribbon.sourceStart)\n const sx2 = cx + innerR * Math.cos(ribbon.sourceEnd)\n const sy2 = cy + innerR * Math.sin(ribbon.sourceEnd)\n // Target arc on inner ring\n const tx1 = cx + innerR * Math.cos(ribbon.targetStart)\n const ty1 = cy + innerR * Math.sin(ribbon.targetStart)\n const tx2 = cx + innerR * Math.cos(ribbon.targetEnd)\n const ty2 = cy + innerR * Math.sin(ribbon.targetEnd)\n\n const srcLarge = (ribbon.sourceEnd - ribbon.sourceStart) > Math.PI\n const tgtLarge = (ribbon.targetEnd - ribbon.targetStart) > Math.PI\n\n pb.moveTo(sx1, sy1)\n pb.arc(innerR, innerR, 0, srcLarge, true, sx2, sy2)\n // Bezier to target\n pb.quadTo(cx, cy, tx1, ty1)\n pb.arc(innerR, innerR, 0, tgtLarge, true, tx2, ty2)\n // Bezier back to source\n pb.quadTo(cx, cy, sx1, sy1)\n pb.close()\n\n nodes.push(path(pb.build(), {\n class: 'chartts-chord-ribbon',\n fill: color,\n fillOpacity: 0.35,\n stroke: color,\n strokeWidth: 0.3,\n 'data-series': ribbon.source,\n 'data-index': ri,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${arcs[ribbon.source]!.name} → ${arcs[ribbon.target]!.name}: ${ribbon.value}`,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area, options } = ctx\n const { arcs } = buildChordLayout(data, options)\n if (arcs.length === 0) return null\n\n const cx = area.x + area.width / 2\n const cy = area.y + area.height / 2\n const outerR = Math.min(area.width, area.height) / 2 - 20\n const innerR = outerR - 14\n\n const dx = mx - cx\n const dy = my - cy\n const dist = Math.sqrt(dx * dx + dy * dy)\n\n // Check arc hits\n if (dist >= innerR && dist <= outerR) {\n let angle = Math.atan2(dy, dx)\n if (angle < -Math.PI / 2) angle += Math.PI * 2\n\n for (const arc of arcs) {\n if (angle >= arc.startAngle && angle <= arc.endAngle) {\n return { seriesIndex: arc.index, pointIndex: 0, distance: 0 }\n }\n }\n }\n\n return null\n },\n}\n\n// ---------------------------------------------------------------------------\n// Layout computation\n// ---------------------------------------------------------------------------\n\nfunction buildChordLayout(\n data: PreparedData,\n _options: ResolvedOptions,\n): { arcs: ChordArc[]; ribbons: ChordRibbon[]; matrix: number[][] } {\n const arcs: ChordArc[] = []\n const ribbons: ChordRibbon[] = []\n\n // Check for arrow notation\n const hasArrows = data.series.some(s => s.name.includes('→') || s.name.includes('->'))\n\n // Build adjacency matrix\n const nodeNames: string[] = []\n const nodeMap = new Map<string, number>()\n\n function getOrCreate(name: string): number {\n if (nodeMap.has(name)) return nodeMap.get(name)!\n const idx = nodeNames.length\n nodeMap.set(name, idx)\n nodeNames.push(name)\n return idx\n }\n\n if (hasArrows) {\n // Parse arrow notation\n for (const series of data.series) {\n const parts = series.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length < 2) continue\n getOrCreate(parts[0]!.trim())\n getOrCreate(parts[1]!.trim())\n }\n } else {\n for (let i = 0; i < data.labels.length; i++) {\n getOrCreate(String(data.labels[i]))\n }\n }\n\n const n = nodeNames.length\n if (n === 0) return { arcs, ribbons, matrix: [] }\n\n const matrix: number[][] = Array.from({ length: n }, () => new Array(n).fill(0))\n\n if (hasArrows) {\n for (const series of data.series) {\n const parts = series.name.split(/\\s*(?:→|->)\\s*/)\n if (parts.length < 2) continue\n const src = getOrCreate(parts[0]!.trim())\n const tgt = getOrCreate(parts[1]!.trim())\n const val = series.values[0] ?? 0\n if (val > 0) matrix[src]![tgt]! += val\n }\n } else {\n for (let si = 0; si < data.series.length && si < n; si++) {\n for (let j = 0; j < data.series[si]!.values.length && j < n; j++) {\n const val = data.series[si]!.values[j]!\n if (val > 0) matrix[si]![j]! = val\n }\n }\n }\n\n // Compute totals per node\n const totals = nodeNames.map((_, i) => {\n let total = 0\n for (let j = 0; j < n; j++) {\n total += matrix[i]![j]!\n total += matrix[j]![i]!\n }\n return total\n })\n\n const grandTotal = totals.reduce((s, t) => s + t, 0)\n if (grandTotal === 0) return { arcs, ribbons, matrix }\n\n // Layout arcs\n const padAngle = 0.04\n const totalPad = padAngle * n\n const available = Math.PI * 2 - totalPad\n\n let angle = -Math.PI / 2\n for (let i = 0; i < n; i++) {\n const span = (totals[i]! / grandTotal) * available\n arcs.push({\n index: i,\n name: nodeNames[i]!,\n total: totals[i]!,\n startAngle: angle,\n endAngle: angle + span,\n })\n angle += span + padAngle\n }\n\n // Layout ribbons — track offsets within each arc\n const arcOffsets = arcs.map(a => a.startAngle)\n\n for (let i = 0; i < n; i++) {\n for (let j = i; j < n; j++) {\n const val = matrix[i]![j]! + matrix[j]![i]!\n if (val <= 0) continue\n\n const srcSpan = (matrix[i]![j]! / Math.max(totals[i]!, 1)) * (arcs[i]!.endAngle - arcs[i]!.startAngle)\n const tgtSpan = (matrix[j]![i]! / Math.max(totals[j]!, 1)) * (arcs[j]!.endAngle - arcs[j]!.startAngle)\n\n ribbons.push({\n source: i,\n target: j,\n value: val,\n sourceStart: arcOffsets[i]!,\n sourceEnd: arcOffsets[i]! + srcSpan,\n targetStart: arcOffsets[j]!,\n targetEnd: arcOffsets[j]! + tgtSpan,\n })\n\n arcOffsets[i]! += srcSpan\n arcOffsets[j]! += tgtSpan\n }\n }\n\n return { arcs, ribbons, matrix }\n}\n"]}
|