@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,104 @@
|
|
|
1
|
+
import { getBandwidth } from './chunk-E6PR75X7.js';
|
|
2
|
+
import { line, group, prepareData } from './chunk-3BRQGYDX.js';
|
|
3
|
+
|
|
4
|
+
// src/charts/ohlc/ohlc-type.ts
|
|
5
|
+
var ohlcChartType = {
|
|
6
|
+
type: "ohlc",
|
|
7
|
+
getScaleTypes() {
|
|
8
|
+
return { x: "categorical", y: "linear" };
|
|
9
|
+
},
|
|
10
|
+
prepareData(data, options) {
|
|
11
|
+
const opts = options;
|
|
12
|
+
const ohlc = opts.ohlc;
|
|
13
|
+
const prepared = prepareData(data, options);
|
|
14
|
+
if (ohlc) {
|
|
15
|
+
let yMin = prepared.bounds.yMin;
|
|
16
|
+
let yMax = prepared.bounds.yMax;
|
|
17
|
+
for (let i = 0; i < ohlc.high.length; i++) {
|
|
18
|
+
if (ohlc.high[i] < yMin) yMin = ohlc.high[i];
|
|
19
|
+
if (ohlc.high[i] > yMax) yMax = ohlc.high[i];
|
|
20
|
+
if (ohlc.low[i] < yMin) yMin = ohlc.low[i];
|
|
21
|
+
if (ohlc.low[i] > yMax) yMax = ohlc.low[i];
|
|
22
|
+
}
|
|
23
|
+
prepared.bounds.yMin = yMin;
|
|
24
|
+
prepared.bounds.yMax = yMax;
|
|
25
|
+
}
|
|
26
|
+
return prepared;
|
|
27
|
+
},
|
|
28
|
+
render(ctx) {
|
|
29
|
+
const { data, xScale, yScale, options } = ctx;
|
|
30
|
+
const nodes = [];
|
|
31
|
+
const opts = options;
|
|
32
|
+
const ohlc = opts.ohlc;
|
|
33
|
+
if (!ohlc) return nodes;
|
|
34
|
+
const series = data.series[0];
|
|
35
|
+
if (!series) return nodes;
|
|
36
|
+
const upColor = opts.upColor ?? "var(--color-emerald-500, #10b981)";
|
|
37
|
+
const downColor = opts.downColor ?? "var(--color-red-500, #ef4444)";
|
|
38
|
+
const lw = opts.lineWidth ?? 1.5;
|
|
39
|
+
const bw = getBandwidth(xScale);
|
|
40
|
+
const tickWidth = bw * 0.3;
|
|
41
|
+
const tickNodes = [];
|
|
42
|
+
for (let i = 0; i < ohlc.open.length; i++) {
|
|
43
|
+
const open = ohlc.open[i];
|
|
44
|
+
const high = ohlc.high[i];
|
|
45
|
+
const low = ohlc.low[i];
|
|
46
|
+
const close = ohlc.close[i];
|
|
47
|
+
const cx = xScale.map(i);
|
|
48
|
+
const isUp = close >= open;
|
|
49
|
+
const color = isUp ? upColor : downColor;
|
|
50
|
+
const yHigh = yScale.map(high);
|
|
51
|
+
const yLow = yScale.map(low);
|
|
52
|
+
const yOpen = yScale.map(open);
|
|
53
|
+
const yClose = yScale.map(close);
|
|
54
|
+
tickNodes.push(line(cx, yHigh, cx, yLow, {
|
|
55
|
+
class: "chartts-ohlc-stem",
|
|
56
|
+
stroke: color,
|
|
57
|
+
strokeWidth: lw,
|
|
58
|
+
"data-series": 0,
|
|
59
|
+
"data-index": i
|
|
60
|
+
}));
|
|
61
|
+
tickNodes.push(line(cx - tickWidth, yOpen, cx, yOpen, {
|
|
62
|
+
class: "chartts-ohlc-tick",
|
|
63
|
+
stroke: color,
|
|
64
|
+
strokeWidth: lw,
|
|
65
|
+
"data-series": 0,
|
|
66
|
+
"data-index": i
|
|
67
|
+
}));
|
|
68
|
+
tickNodes.push(line(cx, yClose, cx + tickWidth, yClose, {
|
|
69
|
+
class: "chartts-ohlc-tick",
|
|
70
|
+
stroke: color,
|
|
71
|
+
strokeWidth: lw,
|
|
72
|
+
"data-series": 0,
|
|
73
|
+
"data-index": i,
|
|
74
|
+
tabindex: 0,
|
|
75
|
+
role: "img",
|
|
76
|
+
ariaLabel: `${data.labels[i] ?? i}: O${open} H${high} L${low} C${close}`
|
|
77
|
+
}));
|
|
78
|
+
}
|
|
79
|
+
nodes.push(group(tickNodes, {
|
|
80
|
+
class: "chartts-series chartts-series-0",
|
|
81
|
+
"data-series-name": series.name
|
|
82
|
+
}));
|
|
83
|
+
return nodes;
|
|
84
|
+
},
|
|
85
|
+
hitTest(ctx, mx, _my) {
|
|
86
|
+
const { xScale, options } = ctx;
|
|
87
|
+
const opts = options;
|
|
88
|
+
const ohlc = opts.ohlc;
|
|
89
|
+
if (!ohlc) return null;
|
|
90
|
+
const bw = getBandwidth(xScale);
|
|
91
|
+
const half = bw * 0.35;
|
|
92
|
+
for (let i = 0; i < ohlc.open.length; i++) {
|
|
93
|
+
const cx = xScale.map(i);
|
|
94
|
+
if (mx >= cx - half && mx <= cx + half) {
|
|
95
|
+
return { seriesIndex: 0, pointIndex: i, distance: Math.abs(mx - cx) };
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
return null;
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
|
|
102
|
+
export { ohlcChartType };
|
|
103
|
+
//# sourceMappingURL=chunk-FUZFNUCJ.js.map
|
|
104
|
+
//# sourceMappingURL=chunk-FUZFNUCJ.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/charts/ohlc/ohlc-type.ts"],"names":[],"mappings":"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","file":"chunk-FUZFNUCJ.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, line } 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,13 @@
|
|
|
1
|
+
import { createChart } from './chunk-3BRQGYDX.js';
|
|
2
|
+
|
|
3
|
+
// src/api/factory.ts
|
|
4
|
+
function createConvenience(chartType) {
|
|
5
|
+
return function(target, config) {
|
|
6
|
+
const { data, ...options } = config;
|
|
7
|
+
return createChart(target, chartType, data, options);
|
|
8
|
+
};
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export { createConvenience };
|
|
12
|
+
//# sourceMappingURL=chunk-GM3ZO5WV.js.map
|
|
13
|
+
//# sourceMappingURL=chunk-GM3ZO5WV.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/api/factory.ts"],"names":[],"mappings":";;;AAQO,SAAS,kBAAkB,SAAA,EAA4B;AAC5D,EAAA,OAAO,SAAU,QAA8B,MAAA,EAAoC;AACjF,IAAA,MAAM,EAAE,IAAA,EAAM,GAAG,OAAA,EAAQ,GAAI,MAAA;AAC7B,IAAA,OAAO,WAAA,CAAY,MAAA,EAAQ,SAAA,EAAW,IAAA,EAAM,OAAO,CAAA;AAAA,EACrD,CAAA;AACF","file":"chunk-GM3ZO5WV.js","sourcesContent":["import { createChart } from './create'\nimport type { ChartData, ChartOptions, ChartInstance, ChartTypePlugin } from '../types'\n\nexport interface ChartConfig extends ChartOptions {\n data: ChartData\n debug?: boolean\n}\n\nexport function createConvenience(chartType: ChartTypePlugin) {\n return function (target: string | HTMLElement, config: ChartConfig): ChartInstance {\n const { data, ...options } = config\n return createChart(target, chartType, data, options)\n }\n}\n"]}
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var chunk5QOQR5FE_cjs = require('./chunk-5QOQR5FE.cjs');
|
|
4
|
+
var chunkXHQWWR5M_cjs = require('./chunk-XHQWWR5M.cjs');
|
|
5
|
+
|
|
6
|
+
// src/charts/parallel/parallel-type.ts
|
|
7
|
+
var parallelChartType = {
|
|
8
|
+
type: "parallel",
|
|
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 dimCount = data.labels.length;
|
|
19
|
+
if (dimCount < 2 || data.series.length === 0) return nodes;
|
|
20
|
+
const padding = 24;
|
|
21
|
+
const axisSpacing = (area.width - padding * 2) / Math.max(dimCount - 1, 1);
|
|
22
|
+
const axisTop = area.y + padding;
|
|
23
|
+
const axisBottom = area.y + area.height - padding;
|
|
24
|
+
const mins = new Array(dimCount).fill(Infinity);
|
|
25
|
+
const maxs = new Array(dimCount).fill(-Infinity);
|
|
26
|
+
for (const series of data.series) {
|
|
27
|
+
for (let d = 0; d < dimCount; d++) {
|
|
28
|
+
const v = series.values[d] ?? 0;
|
|
29
|
+
if (v < mins[d]) mins[d] = v;
|
|
30
|
+
if (v > maxs[d]) maxs[d] = v;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
for (let d = 0; d < dimCount; d++) {
|
|
34
|
+
if (mins[d] === maxs[d]) {
|
|
35
|
+
mins[d] = mins[d] - 1;
|
|
36
|
+
maxs[d] = maxs[d] + 1;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
const axisX = (dim) => area.x + padding + dim * axisSpacing;
|
|
40
|
+
const valueToY = (dim, value) => {
|
|
41
|
+
const frac = (value - mins[dim]) / (maxs[dim] - mins[dim]);
|
|
42
|
+
return axisBottom - frac * (axisBottom - axisTop);
|
|
43
|
+
};
|
|
44
|
+
for (let d = 0; d < dimCount; d++) {
|
|
45
|
+
const x = axisX(d);
|
|
46
|
+
nodes.push(chunkXHQWWR5M_cjs.line(x, axisTop, x, axisBottom, {
|
|
47
|
+
class: "chartts-parallel-axis",
|
|
48
|
+
stroke: theme.axisColor,
|
|
49
|
+
strokeWidth: theme.axisWidth
|
|
50
|
+
}));
|
|
51
|
+
nodes.push(chunkXHQWWR5M_cjs.text(x, axisBottom + 14, String(data.labels[d]), {
|
|
52
|
+
class: "chartts-parallel-label",
|
|
53
|
+
fill: theme.textMuted,
|
|
54
|
+
textAnchor: "middle",
|
|
55
|
+
dominantBaseline: "auto",
|
|
56
|
+
fontSize: theme.fontSizeSmall,
|
|
57
|
+
fontFamily: theme.fontFamily
|
|
58
|
+
}));
|
|
59
|
+
nodes.push(chunkXHQWWR5M_cjs.text(x - 6, axisTop, String(Math.round(maxs[d])), {
|
|
60
|
+
class: "chartts-parallel-tick",
|
|
61
|
+
fill: theme.textMuted,
|
|
62
|
+
textAnchor: "end",
|
|
63
|
+
dominantBaseline: "central",
|
|
64
|
+
fontSize: theme.fontSizeSmall * 0.85,
|
|
65
|
+
fontFamily: theme.fontFamily
|
|
66
|
+
}));
|
|
67
|
+
nodes.push(chunkXHQWWR5M_cjs.text(x - 6, axisBottom, String(Math.round(mins[d])), {
|
|
68
|
+
class: "chartts-parallel-tick",
|
|
69
|
+
fill: theme.textMuted,
|
|
70
|
+
textAnchor: "end",
|
|
71
|
+
dominantBaseline: "central",
|
|
72
|
+
fontSize: theme.fontSizeSmall * 0.85,
|
|
73
|
+
fontFamily: theme.fontFamily
|
|
74
|
+
}));
|
|
75
|
+
}
|
|
76
|
+
for (let si = 0; si < data.series.length; si++) {
|
|
77
|
+
const series = data.series[si];
|
|
78
|
+
const color = series.color ?? options.colors[si % options.colors.length];
|
|
79
|
+
const pb = new chunkXHQWWR5M_cjs.PathBuilder();
|
|
80
|
+
for (let d = 0; d < dimCount; d++) {
|
|
81
|
+
const x = axisX(d);
|
|
82
|
+
const y = valueToY(d, series.values[d] ?? 0);
|
|
83
|
+
if (d === 0) pb.moveTo(x, y);
|
|
84
|
+
else pb.lineTo(x, y);
|
|
85
|
+
}
|
|
86
|
+
nodes.push(chunkXHQWWR5M_cjs.path(pb.build(), {
|
|
87
|
+
class: "chartts-parallel-line",
|
|
88
|
+
stroke: color,
|
|
89
|
+
strokeWidth: theme.lineWidth,
|
|
90
|
+
fill: "none",
|
|
91
|
+
fillOpacity: 0,
|
|
92
|
+
opacity: Math.max(0.3, 1 - data.series.length * 0.03),
|
|
93
|
+
"data-series": si,
|
|
94
|
+
tabindex: 0,
|
|
95
|
+
role: "img",
|
|
96
|
+
ariaLabel: `${series.name}: ${series.values.join(", ")}`
|
|
97
|
+
}));
|
|
98
|
+
}
|
|
99
|
+
return nodes;
|
|
100
|
+
},
|
|
101
|
+
hitTest(ctx, mx, my) {
|
|
102
|
+
const { data, area } = ctx;
|
|
103
|
+
const dimCount = data.labels.length;
|
|
104
|
+
if (dimCount < 2 || data.series.length === 0) return null;
|
|
105
|
+
const padding = 24;
|
|
106
|
+
const axisSpacing = (area.width - padding * 2) / Math.max(dimCount - 1, 1);
|
|
107
|
+
const axisTop = area.y + padding;
|
|
108
|
+
const axisBottom = area.y + area.height - padding;
|
|
109
|
+
const mins = new Array(dimCount).fill(Infinity);
|
|
110
|
+
const maxs = new Array(dimCount).fill(-Infinity);
|
|
111
|
+
for (const series of data.series) {
|
|
112
|
+
for (let d = 0; d < dimCount; d++) {
|
|
113
|
+
const v = series.values[d] ?? 0;
|
|
114
|
+
if (v < mins[d]) mins[d] = v;
|
|
115
|
+
if (v > maxs[d]) maxs[d] = v;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
for (let d = 0; d < dimCount; d++) {
|
|
119
|
+
if (mins[d] === maxs[d]) {
|
|
120
|
+
mins[d] = mins[d] - 1;
|
|
121
|
+
maxs[d] = maxs[d] + 1;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
const axisX = (dim) => area.x + padding + dim * axisSpacing;
|
|
125
|
+
const valueToY = (dim, value) => {
|
|
126
|
+
const frac = (value - mins[dim]) / (maxs[dim] - mins[dim]);
|
|
127
|
+
return axisBottom - frac * (axisBottom - axisTop);
|
|
128
|
+
};
|
|
129
|
+
let best = null;
|
|
130
|
+
let bestDist = 20;
|
|
131
|
+
for (let si = 0; si < data.series.length; si++) {
|
|
132
|
+
const series = data.series[si];
|
|
133
|
+
for (let d = 0; d < dimCount; d++) {
|
|
134
|
+
const x = axisX(d);
|
|
135
|
+
const y = valueToY(d, series.values[d] ?? 0);
|
|
136
|
+
const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2);
|
|
137
|
+
if (dist < bestDist) {
|
|
138
|
+
bestDist = dist;
|
|
139
|
+
best = { seriesIndex: si, pointIndex: d, distance: dist };
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
return best;
|
|
144
|
+
}
|
|
145
|
+
};
|
|
146
|
+
|
|
147
|
+
exports.parallelChartType = parallelChartType;
|
|
148
|
+
//# sourceMappingURL=chunk-GNRRK7TZ.cjs.map
|
|
149
|
+
//# sourceMappingURL=chunk-GNRRK7TZ.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/charts/parallel/parallel-type.ts"],"names":["prepareNoAxes","line","text","PathBuilder","path"],"mappings":"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","file":"chunk-GNRRK7TZ.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { path, text, line } from '../../render/tree'\nimport { PathBuilder } from '../../render/tree'\n\n/**\n * Parallel coordinates chart — multi-dimensional data on parallel vertical axes.\n *\n * Data convention:\n * - labels: axis names (dimensions), one per axis\n * - series[i]: one data record. series[i].values[j] = value for dimension j\n *\n * Each series becomes a polyline crossing all axes.\n */\n\nexport const parallelChartType: ChartTypePlugin = {\n type: 'parallel',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const dimCount = data.labels.length\n if (dimCount < 2 || data.series.length === 0) return nodes\n\n const padding = 24\n const axisSpacing = (area.width - padding * 2) / Math.max(dimCount - 1, 1)\n const axisTop = area.y + padding\n const axisBottom = area.y + area.height - padding\n\n // Compute min/max per dimension\n const mins: number[] = new Array(dimCount).fill(Infinity)\n const maxs: number[] = new Array(dimCount).fill(-Infinity)\n for (const series of data.series) {\n for (let d = 0; d < dimCount; d++) {\n const v = series.values[d] ?? 0\n if (v < mins[d]!) mins[d] = v\n if (v > maxs[d]!) maxs[d] = v\n }\n }\n\n // Ensure min !== max\n for (let d = 0; d < dimCount; d++) {\n if (mins[d] === maxs[d]) {\n mins[d] = mins[d]! - 1\n maxs[d] = maxs[d]! + 1\n }\n }\n\n const axisX = (dim: number) => area.x + padding + dim * axisSpacing\n const valueToY = (dim: number, value: number) => {\n const frac = (value - mins[dim]!) / (maxs[dim]! - mins[dim]!)\n return axisBottom - frac * (axisBottom - axisTop) // invert: higher values = higher on axis\n }\n\n // Draw axes\n for (let d = 0; d < dimCount; d++) {\n const x = axisX(d)\n\n // Axis line\n nodes.push(line(x, axisTop, x, axisBottom, {\n class: 'chartts-parallel-axis',\n stroke: theme.axisColor,\n strokeWidth: theme.axisWidth,\n }))\n\n // Axis label at bottom\n nodes.push(text(x, axisBottom + 14, String(data.labels[d]!), {\n class: 'chartts-parallel-label',\n fill: theme.textMuted,\n textAnchor: 'middle',\n dominantBaseline: 'auto',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n\n // Min/max ticks\n nodes.push(text(x - 6, axisTop, String(Math.round(maxs[d]!)), {\n class: 'chartts-parallel-tick',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall * 0.85,\n fontFamily: theme.fontFamily,\n }))\n nodes.push(text(x - 6, axisBottom, String(Math.round(mins[d]!)), {\n class: 'chartts-parallel-tick',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall * 0.85,\n fontFamily: theme.fontFamily,\n }))\n }\n\n // Draw series lines\n for (let si = 0; si < data.series.length; si++) {\n const series = data.series[si]!\n const color = series.color ?? options.colors[si % options.colors.length]!\n\n const pb = new PathBuilder()\n for (let d = 0; d < dimCount; d++) {\n const x = axisX(d)\n const y = valueToY(d, series.values[d] ?? 0)\n if (d === 0) pb.moveTo(x, y)\n else pb.lineTo(x, y)\n }\n\n nodes.push(path(pb.build(), {\n class: 'chartts-parallel-line',\n stroke: color,\n strokeWidth: theme.lineWidth,\n fill: 'none',\n fillOpacity: 0,\n opacity: Math.max(0.3, 1 - data.series.length * 0.03),\n 'data-series': si,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values.join(', ')}`,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area } = ctx\n const dimCount = data.labels.length\n if (dimCount < 2 || data.series.length === 0) return null\n\n const padding = 24\n const axisSpacing = (area.width - padding * 2) / Math.max(dimCount - 1, 1)\n const axisTop = area.y + padding\n const axisBottom = area.y + area.height - padding\n\n const mins: number[] = new Array(dimCount).fill(Infinity)\n const maxs: number[] = new Array(dimCount).fill(-Infinity)\n for (const series of data.series) {\n for (let d = 0; d < dimCount; d++) {\n const v = series.values[d] ?? 0\n if (v < mins[d]!) mins[d] = v\n if (v > maxs[d]!) maxs[d] = v\n }\n }\n for (let d = 0; d < dimCount; d++) {\n if (mins[d] === maxs[d]) { mins[d] = mins[d]! - 1; maxs[d] = maxs[d]! + 1 }\n }\n\n const axisX = (dim: number) => area.x + padding + dim * axisSpacing\n const valueToY = (dim: number, value: number) => {\n const frac = (value - mins[dim]!) / (maxs[dim]! - mins[dim]!)\n return axisBottom - frac * (axisBottom - axisTop)\n }\n\n // Find closest series line\n let best: HitResult | null = null\n let bestDist = 20 // max hit distance\n\n for (let si = 0; si < data.series.length; si++) {\n const series = data.series[si]!\n for (let d = 0; d < dimCount; d++) {\n const x = axisX(d)\n const y = valueToY(d, series.values[d] ?? 0)\n const dist = Math.sqrt((mx - x) ** 2 + (my - y) ** 2)\n if (dist < bestDist) {\n bestDist = dist\n best = { seriesIndex: si, pointIndex: d, distance: dist }\n }\n }\n }\n\n return best\n },\n}\n"]}
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import { createHorizontalMapper } from './chunk-E6PR75X7.js';
|
|
2
|
+
import { formatNum } from './chunk-OGSZO22B.js';
|
|
3
|
+
import { text, path, rect, group, prepareData } from './chunk-3BRQGYDX.js';
|
|
4
|
+
|
|
5
|
+
// src/charts/bar/horizontal-bar-type.ts
|
|
6
|
+
var horizontalBarChartType = {
|
|
7
|
+
type: "horizontal-bar",
|
|
8
|
+
getScaleTypes() {
|
|
9
|
+
return { x: "categorical", y: "linear" };
|
|
10
|
+
},
|
|
11
|
+
prepareData(data, options) {
|
|
12
|
+
const prepared = prepareData(data, {
|
|
13
|
+
...options,
|
|
14
|
+
xAxis: false,
|
|
15
|
+
yAxis: false,
|
|
16
|
+
xGrid: false,
|
|
17
|
+
yGrid: false,
|
|
18
|
+
legend: false
|
|
19
|
+
});
|
|
20
|
+
if (options.yMin === void 0 && prepared.bounds.yMin > 0) {
|
|
21
|
+
prepared.bounds.yMin = 0;
|
|
22
|
+
}
|
|
23
|
+
if (options.yMax === void 0 && prepared.bounds.yMax < 0) {
|
|
24
|
+
prepared.bounds.yMax = 0;
|
|
25
|
+
}
|
|
26
|
+
return prepared;
|
|
27
|
+
},
|
|
28
|
+
render(ctx) {
|
|
29
|
+
const { data, area, options, yScale, theme } = ctx;
|
|
30
|
+
const nodes = [];
|
|
31
|
+
const seriesCount = data.series.length;
|
|
32
|
+
const pointCount = data.series[0]?.values.length ?? 0;
|
|
33
|
+
if (pointCount === 0) return nodes;
|
|
34
|
+
const labelWidth = Math.min(70, area.width * 0.2);
|
|
35
|
+
const chartX = area.x + labelWidth;
|
|
36
|
+
const chartW = area.width - labelWidth;
|
|
37
|
+
const categoryHeight = area.height / pointCount;
|
|
38
|
+
const barGap = options.barGap;
|
|
39
|
+
const groupHeight = categoryHeight * (1 - barGap);
|
|
40
|
+
const barHeight = groupHeight / seriesCount;
|
|
41
|
+
const groupOffset = -groupHeight / 2;
|
|
42
|
+
const valueToX = createHorizontalMapper(yScale, area, chartX, chartW);
|
|
43
|
+
const zeroX = valueToX(0);
|
|
44
|
+
for (let i = 0; i < pointCount; i++) {
|
|
45
|
+
const catCenter = area.y + categoryHeight * (i + 0.5);
|
|
46
|
+
nodes.push(text(area.x + labelWidth - 6, catCenter, String(data.labels[i] ?? ""), {
|
|
47
|
+
class: "chartts-hbar-label",
|
|
48
|
+
fill: theme.textMuted,
|
|
49
|
+
textAnchor: "end",
|
|
50
|
+
dominantBaseline: "central",
|
|
51
|
+
fontSize: theme.fontSizeSmall,
|
|
52
|
+
fontFamily: theme.fontFamily
|
|
53
|
+
}));
|
|
54
|
+
}
|
|
55
|
+
for (const series of data.series) {
|
|
56
|
+
const barNodes = [];
|
|
57
|
+
for (let i = 0; i < series.values.length; i++) {
|
|
58
|
+
const catCenter = area.y + categoryHeight * (i + 0.5);
|
|
59
|
+
const barY = catCenter + groupOffset + series.index * barHeight;
|
|
60
|
+
const vx = valueToX(series.values[i]);
|
|
61
|
+
const x = Math.min(vx, zeroX);
|
|
62
|
+
const w = Math.abs(vx - zeroX);
|
|
63
|
+
const isPositive = series.values[i] >= 0;
|
|
64
|
+
const barFill = `url(#chartts-bar-${series.index})`;
|
|
65
|
+
const r = Math.min(options.barRadius, barHeight / 2, w / 2);
|
|
66
|
+
if (r > 0 && w > r * 2) {
|
|
67
|
+
const d = isPositive ? `M${formatNum(x)},${formatNum(barY)}H${formatNum(x + w - r)}Q${formatNum(x + w)},${formatNum(barY)},${formatNum(x + w)},${formatNum(barY + r)}V${formatNum(barY + barHeight - r)}Q${formatNum(x + w)},${formatNum(barY + barHeight)},${formatNum(x + w - r)},${formatNum(barY + barHeight)}H${formatNum(x)}Z` : `M${formatNum(x + w)},${formatNum(barY)}H${formatNum(x + r)}Q${formatNum(x)},${formatNum(barY)},${formatNum(x)},${formatNum(barY + r)}V${formatNum(barY + barHeight - r)}Q${formatNum(x)},${formatNum(barY + barHeight)},${formatNum(x + r)},${formatNum(barY + barHeight)}H${formatNum(x + w)}Z`;
|
|
68
|
+
barNodes.push(path(d, {
|
|
69
|
+
class: "chartts-bar chartts-bar-horizontal",
|
|
70
|
+
fill: barFill,
|
|
71
|
+
"data-series": series.index,
|
|
72
|
+
"data-index": i,
|
|
73
|
+
tabindex: 0,
|
|
74
|
+
role: "img",
|
|
75
|
+
ariaLabel: `${series.name}: ${series.values[i]}`
|
|
76
|
+
}));
|
|
77
|
+
} else {
|
|
78
|
+
barNodes.push(rect(x, barY, w, barHeight, {
|
|
79
|
+
class: "chartts-bar chartts-bar-horizontal",
|
|
80
|
+
fill: barFill,
|
|
81
|
+
"data-series": series.index,
|
|
82
|
+
"data-index": i,
|
|
83
|
+
tabindex: 0,
|
|
84
|
+
role: "img",
|
|
85
|
+
ariaLabel: `${series.name}: ${series.values[i]}`
|
|
86
|
+
}));
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
nodes.push(group(barNodes, {
|
|
90
|
+
class: `chartts-series chartts-series-${series.index}`,
|
|
91
|
+
"data-series-name": series.name
|
|
92
|
+
}));
|
|
93
|
+
}
|
|
94
|
+
return nodes;
|
|
95
|
+
},
|
|
96
|
+
hitTest(ctx, mx, my) {
|
|
97
|
+
const { data, area, options, yScale } = ctx;
|
|
98
|
+
const seriesCount = data.series.length;
|
|
99
|
+
const pointCount = data.series[0]?.values.length ?? 0;
|
|
100
|
+
if (pointCount === 0) return null;
|
|
101
|
+
const labelWidth = Math.min(70, area.width * 0.2);
|
|
102
|
+
const chartX = area.x + labelWidth;
|
|
103
|
+
const chartW = area.width - labelWidth;
|
|
104
|
+
const categoryHeight = area.height / pointCount;
|
|
105
|
+
const groupHeight = categoryHeight * (1 - options.barGap);
|
|
106
|
+
const barHeight = groupHeight / seriesCount;
|
|
107
|
+
const groupOffset = -groupHeight / 2;
|
|
108
|
+
const valueToX = createHorizontalMapper(yScale, area, chartX, chartW);
|
|
109
|
+
const zeroX = valueToX(0);
|
|
110
|
+
for (const series of data.series) {
|
|
111
|
+
for (let i = 0; i < series.values.length; i++) {
|
|
112
|
+
const catCenter = area.y + categoryHeight * (i + 0.5);
|
|
113
|
+
const barY = catCenter + groupOffset + series.index * barHeight;
|
|
114
|
+
const vx = valueToX(series.values[i]);
|
|
115
|
+
const x = Math.min(vx, zeroX);
|
|
116
|
+
const w = Math.abs(vx - zeroX);
|
|
117
|
+
if (mx >= x - 2 && mx <= x + w + 2 && my >= barY - 2 && my <= barY + barHeight + 2) {
|
|
118
|
+
return { seriesIndex: series.index, pointIndex: i, distance: 0 };
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
return null;
|
|
123
|
+
}
|
|
124
|
+
};
|
|
125
|
+
|
|
126
|
+
export { horizontalBarChartType };
|
|
127
|
+
//# sourceMappingURL=chunk-H2AE7JMU.js.map
|
|
128
|
+
//# sourceMappingURL=chunk-H2AE7JMU.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/charts/bar/horizontal-bar-type.ts"],"names":[],"mappings":";;;;;AAeO,IAAM,sBAAA,GAA0C;AAAA,EACrD,IAAA,EAAM,gBAAA;AAAA,EAEN,aAAA,GAAgD;AAC9C,IAAA,OAAO,EAAE,CAAA,EAAG,aAAA,EAAe,CAAA,EAAG,QAAA,EAAS;AAAA,EACzC,CAAA;AAAA,EAEA,WAAA,CAAY,MAAiB,OAAA,EAAwC;AACnE,IAAA,MAAM,QAAA,GAAW,YAAY,IAAA,EAAM;AAAA,MACjC,GAAG,OAAA;AAAA,MACH,KAAA,EAAO,KAAA;AAAA,MACP,KAAA,EAAO,KAAA;AAAA,MACP,KAAA,EAAO,KAAA;AAAA,MACP,KAAA,EAAO,KAAA;AAAA,MACP,MAAA,EAAQ;AAAA,KACT,CAAA;AACD,IAAA,IAAI,QAAQ,IAAA,KAAS,MAAA,IAAa,QAAA,CAAS,MAAA,CAAO,OAAO,CAAA,EAAG;AAC1D,MAAA,QAAA,CAAS,OAAO,IAAA,GAAO,CAAA;AAAA,IACzB;AACA,IAAA,IAAI,QAAQ,IAAA,KAAS,MAAA,IAAa,QAAA,CAAS,MAAA,CAAO,OAAO,CAAA,EAAG;AAC1D,MAAA,QAAA,CAAS,OAAO,IAAA,GAAO,CAAA;AAAA,IACzB;AACA,IAAA,OAAO,QAAA;AAAA,EACT,CAAA;AAAA,EAEA,OAAO,GAAA,EAAkC;AACvC,IAAA,MAAM,EAAE,IAAA,EAAM,IAAA,EAAM,OAAA,EAAS,MAAA,EAAQ,OAAM,GAAI,GAAA;AAC/C,IAAA,MAAM,QAAsB,EAAC;AAE7B,IAAA,MAAM,WAAA,GAAc,KAAK,MAAA,CAAO,MAAA;AAChC,IAAA,MAAM,aAAa,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA,EAAG,OAAO,MAAA,IAAU,CAAA;AACpD,IAAA,IAAI,UAAA,KAAe,GAAG,OAAO,KAAA;AAG7B,IAAA,MAAM,aAAa,IAAA,CAAK,GAAA,CAAI,EAAA,EAAI,IAAA,CAAK,QAAQ,GAAG,CAAA;AAChD,IAAA,MAAM,MAAA,GAAS,KAAK,CAAA,GAAI,UAAA;AACxB,IAAA,MAAM,MAAA,GAAS,KAAK,KAAA,GAAQ,UAAA;AAK5B,IAAA,MAAM,cAAA,GAAiB,KAAK,MAAA,GAAS,UAAA;AACrC,IAAA,MAAM,SAAS,OAAA,CAAQ,MAAA;AACvB,IAAA,MAAM,WAAA,GAAc,kBAAkB,CAAA,GAAI,MAAA,CAAA;AAC1C,IAAA,MAAM,YAAY,WAAA,GAAc,WAAA;AAChC,IAAA,MAAM,WAAA,GAAc,CAAC,WAAA,GAAc,CAAA;AAEnC,IAAA,MAAM,QAAA,GAAW,sBAAA,CAAuB,MAAA,EAAQ,IAAA,EAAM,QAAQ,MAAM,CAAA;AACpE,IAAA,MAAM,KAAA,GAAQ,SAAS,CAAC,CAAA;AAGxB,IAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,UAAA,EAAY,CAAA,EAAA,EAAK;AACnC,MAAA,MAAM,SAAA,GAAY,IAAA,CAAK,CAAA,GAAI,cAAA,IAAkB,CAAA,GAAI,GAAA,CAAA;AACjD,MAAA,KAAA,CAAM,IAAA,CAAK,IAAA,CAAK,IAAA,CAAK,CAAA,GAAI,UAAA,GAAa,CAAA,EAAG,SAAA,EAAW,MAAA,CAAO,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA,IAAK,EAAE,CAAA,EAAG;AAAA,QAChF,KAAA,EAAO,oBAAA;AAAA,QACP,MAAM,KAAA,CAAM,SAAA;AAAA,QACZ,UAAA,EAAY,KAAA;AAAA,QACZ,gBAAA,EAAkB,SAAA;AAAA,QAClB,UAAU,KAAA,CAAM,aAAA;AAAA,QAChB,YAAY,KAAA,CAAM;AAAA,OACnB,CAAC,CAAA;AAAA,IACJ;AAEA,IAAA,KAAA,MAAW,MAAA,IAAU,KAAK,MAAA,EAAQ;AAChC,MAAA,MAAM,WAAyB,EAAC;AAEhC,MAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AAC7C,QAAA,MAAM,SAAA,GAAY,IAAA,CAAK,CAAA,GAAI,cAAA,IAAkB,CAAA,GAAI,GAAA,CAAA;AACjD,QAAA,MAAM,IAAA,GAAO,SAAA,GAAY,WAAA,GAAc,MAAA,CAAO,KAAA,GAAQ,SAAA;AACtD,QAAA,MAAM,EAAA,GAAK,QAAA,CAAS,MAAA,CAAO,MAAA,CAAO,CAAC,CAAE,CAAA;AAErC,QAAA,MAAM,CAAA,GAAI,IAAA,CAAK,GAAA,CAAI,EAAA,EAAI,KAAK,CAAA;AAC5B,QAAA,MAAM,CAAA,GAAI,IAAA,CAAK,GAAA,CAAI,EAAA,GAAK,KAAK,CAAA;AAC7B,QAAA,MAAM,UAAA,GAAa,MAAA,CAAO,MAAA,CAAO,CAAC,CAAA,IAAM,CAAA;AAExC,QAAA,MAAM,OAAA,GAAU,CAAA,iBAAA,EAAoB,MAAA,CAAO,KAAK,CAAA,CAAA,CAAA;AAChD,QAAA,MAAM,CAAA,GAAI,KAAK,GAAA,CAAI,OAAA,CAAQ,WAAW,SAAA,GAAY,CAAA,EAAG,IAAI,CAAC,CAAA;AAE1D,QAAA,IAAI,CAAA,GAAI,CAAA,IAAK,CAAA,GAAI,CAAA,GAAI,CAAA,EAAG;AAEtB,UAAA,MAAM,CAAA,GAAI,UAAA,GACN,CAAA,CAAA,EAAI,SAAA,CAAU,CAAC,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,IAAI,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,CAAA,GAAI,CAAA,GAAI,CAAC,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,CAAA,GAAI,CAAC,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,IAAI,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,CAAA,GAAI,CAAC,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,IAAA,GAAO,CAAC,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,IAAA,GAAO,SAAA,GAAY,CAAC,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,CAAA,GAAI,CAAC,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,IAAA,GAAO,SAAS,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,CAAA,GAAI,CAAA,GAAI,CAAC,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,IAAA,GAAO,SAAS,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,CAAC,CAAC,CAAA,CAAA,CAAA,GAC1S,CAAA,CAAA,EAAI,SAAA,CAAU,CAAA,GAAI,CAAC,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,IAAI,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,CAAA,GAAI,CAAC,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,CAAC,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,IAAI,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,CAAC,CAAC,IAAI,SAAA,CAAU,IAAA,GAAO,CAAC,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,IAAA,GAAO,SAAA,GAAY,CAAC,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,CAAC,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,IAAA,GAAO,SAAS,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,CAAA,GAAI,CAAC,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,IAAA,GAAO,SAAS,CAAC,CAAA,CAAA,EAAI,SAAA,CAAU,CAAA,GAAI,CAAC,CAAC,CAAA,CAAA,CAAA;AAElS,UAAA,QAAA,CAAS,IAAA,CAAK,KAAK,CAAA,EAAG;AAAA,YACpB,KAAA,EAAO,oCAAA;AAAA,YACP,IAAA,EAAM,OAAA;AAAA,YACN,eAAe,MAAA,CAAO,KAAA;AAAA,YACtB,YAAA,EAAc,CAAA;AAAA,YACd,QAAA,EAAU,CAAA;AAAA,YACV,IAAA,EAAM,KAAA;AAAA,YACN,SAAA,EAAW,GAAG,MAAA,CAAO,IAAI,KAAK,MAAA,CAAO,MAAA,CAAO,CAAC,CAAC,CAAA;AAAA,WAC/C,CAAC,CAAA;AAAA,QACJ,CAAA,MAAO;AACL,UAAA,QAAA,CAAS,IAAA,CAAK,IAAA,CAAK,CAAA,EAAG,IAAA,EAAM,GAAG,SAAA,EAAW;AAAA,YACxC,KAAA,EAAO,oCAAA;AAAA,YACP,IAAA,EAAM,OAAA;AAAA,YACN,eAAe,MAAA,CAAO,KAAA;AAAA,YACtB,YAAA,EAAc,CAAA;AAAA,YACd,QAAA,EAAU,CAAA;AAAA,YACV,IAAA,EAAM,KAAA;AAAA,YACN,SAAA,EAAW,GAAG,MAAA,CAAO,IAAI,KAAK,MAAA,CAAO,MAAA,CAAO,CAAC,CAAC,CAAA;AAAA,WAC/C,CAAC,CAAA;AAAA,QACJ;AAAA,MACF;AAEA,MAAA,KAAA,CAAM,IAAA,CAAK,MAAM,QAAA,EAAU;AAAA,QACzB,KAAA,EAAO,CAAA,8BAAA,EAAiC,MAAA,CAAO,KAAK,CAAA,CAAA;AAAA,QACpD,oBAAoB,MAAA,CAAO;AAAA,OAC5B,CAAC,CAAA;AAAA,IACJ;AAEA,IAAA,OAAO,KAAA;AAAA,EACT,CAAA;AAAA,EAEA,OAAA,CAAQ,GAAA,EAAoB,EAAA,EAAY,EAAA,EAA8B;AACpE,IAAA,MAAM,EAAE,IAAA,EAAM,IAAA,EAAM,OAAA,EAAS,QAAO,GAAI,GAAA;AACxC,IAAA,MAAM,WAAA,GAAc,KAAK,MAAA,CAAO,MAAA;AAChC,IAAA,MAAM,aAAa,IAAA,CAAK,MAAA,CAAO,CAAC,CAAA,EAAG,OAAO,MAAA,IAAU,CAAA;AACpD,IAAA,IAAI,UAAA,KAAe,GAAG,OAAO,IAAA;AAE7B,IAAA,MAAM,aAAa,IAAA,CAAK,GAAA,CAAI,EAAA,EAAI,IAAA,CAAK,QAAQ,GAAG,CAAA;AAChD,IAAA,MAAM,MAAA,GAAS,KAAK,CAAA,GAAI,UAAA;AACxB,IAAA,MAAM,MAAA,GAAS,KAAK,KAAA,GAAQ,UAAA;AAC5B,IAAA,MAAM,cAAA,GAAiB,KAAK,MAAA,GAAS,UAAA;AACrC,IAAA,MAAM,WAAA,GAAc,cAAA,IAAkB,CAAA,GAAI,OAAA,CAAQ,MAAA,CAAA;AAClD,IAAA,MAAM,YAAY,WAAA,GAAc,WAAA;AAChC,IAAA,MAAM,WAAA,GAAc,CAAC,WAAA,GAAc,CAAA;AAEnC,IAAA,MAAM,QAAA,GAAW,sBAAA,CAAuB,MAAA,EAAQ,IAAA,EAAM,QAAQ,MAAM,CAAA;AACpE,IAAA,MAAM,KAAA,GAAQ,SAAS,CAAC,CAAA;AAExB,IAAA,KAAA,MAAW,MAAA,IAAU,KAAK,MAAA,EAAQ;AAChC,MAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,MAAA,CAAO,MAAA,CAAO,QAAQ,CAAA,EAAA,EAAK;AAC7C,QAAA,MAAM,SAAA,GAAY,IAAA,CAAK,CAAA,GAAI,cAAA,IAAkB,CAAA,GAAI,GAAA,CAAA;AACjD,QAAA,MAAM,IAAA,GAAO,SAAA,GAAY,WAAA,GAAc,MAAA,CAAO,KAAA,GAAQ,SAAA;AACtD,QAAA,MAAM,EAAA,GAAK,QAAA,CAAS,MAAA,CAAO,MAAA,CAAO,CAAC,CAAE,CAAA;AACrC,QAAA,MAAM,CAAA,GAAI,IAAA,CAAK,GAAA,CAAI,EAAA,EAAI,KAAK,CAAA;AAC5B,QAAA,MAAM,CAAA,GAAI,IAAA,CAAK,GAAA,CAAI,EAAA,GAAK,KAAK,CAAA;AAE7B,QAAA,IAAI,EAAA,IAAM,CAAA,GAAI,CAAA,IAAK,EAAA,IAAM,CAAA,GAAI,CAAA,GAAI,CAAA,IAAK,EAAA,IAAM,IAAA,GAAO,CAAA,IAAK,EAAA,IAAM,IAAA,GAAO,YAAY,CAAA,EAAG;AAClF,UAAA,OAAO,EAAE,WAAA,EAAa,MAAA,CAAO,OAAO,UAAA,EAAY,CAAA,EAAG,UAAU,CAAA,EAAE;AAAA,QACjE;AAAA,MACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AACF","file":"chunk-H2AE7JMU.js","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareData } from '../../data/prepare'\nimport { group, rect, path, text } from '../../render/tree'\nimport { formatNum } from '../../utils/format'\nimport { createHorizontalMapper } from '../../utils/scale'\n\n/**\n * Horizontal bar chart — bars grow left-to-right.\n *\n * Uses the xScale for categories (mapped to y positions) and yScale for values\n * (mapped to x positions), but transposes the rendering.\n */\nexport const horizontalBarChartType: ChartTypePlugin = {\n type: 'horizontal-bar',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n const prepared = prepareData(data, {\n ...options,\n xAxis: false,\n yAxis: false,\n xGrid: false,\n yGrid: false,\n legend: false,\n })\n if (options.yMin === undefined && prepared.bounds.yMin > 0) {\n prepared.bounds.yMin = 0\n }\n if (options.yMax === undefined && prepared.bounds.yMax < 0) {\n prepared.bounds.yMax = 0\n }\n return prepared\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, options, yScale, theme } = ctx\n const nodes: RenderNode[] = []\n\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return nodes\n\n // Reserve space for category labels on the left\n const labelWidth = Math.min(70, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n\n // In horizontal mode:\n // - Y axis becomes categories\n // - X axis becomes value axis (use yScale for values mapped to x positions)\n const categoryHeight = area.height / pointCount\n const barGap = options.barGap\n const groupHeight = categoryHeight * (1 - barGap)\n const barHeight = groupHeight / seriesCount\n const groupOffset = -groupHeight / 2\n\n const valueToX = createHorizontalMapper(yScale, area, chartX, chartW)\n const zeroX = valueToX(0)\n\n // Category labels on the left\n for (let i = 0; i < pointCount; i++) {\n const catCenter = area.y + categoryHeight * (i + 0.5)\n nodes.push(text(area.x + labelWidth - 6, catCenter, String(data.labels[i] ?? ''), {\n class: 'chartts-hbar-label',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: theme.fontSizeSmall,\n fontFamily: theme.fontFamily,\n }))\n }\n\n for (const series of data.series) {\n const barNodes: RenderNode[] = []\n\n for (let i = 0; i < series.values.length; i++) {\n const catCenter = area.y + categoryHeight * (i + 0.5)\n const barY = catCenter + groupOffset + series.index * barHeight\n const vx = valueToX(series.values[i]!)\n\n const x = Math.min(vx, zeroX)\n const w = Math.abs(vx - zeroX)\n const isPositive = series.values[i]! >= 0\n\n const barFill = `url(#chartts-bar-${series.index})`\n const r = Math.min(options.barRadius, barHeight / 2, w / 2)\n\n if (r > 0 && w > r * 2) {\n // Rounded right end for positive, left end for negative\n const d = isPositive\n ? `M${formatNum(x)},${formatNum(barY)}H${formatNum(x + w - r)}Q${formatNum(x + w)},${formatNum(barY)},${formatNum(x + w)},${formatNum(barY + r)}V${formatNum(barY + barHeight - r)}Q${formatNum(x + w)},${formatNum(barY + barHeight)},${formatNum(x + w - r)},${formatNum(barY + barHeight)}H${formatNum(x)}Z`\n : `M${formatNum(x + w)},${formatNum(barY)}H${formatNum(x + r)}Q${formatNum(x)},${formatNum(barY)},${formatNum(x)},${formatNum(barY + r)}V${formatNum(barY + barHeight - r)}Q${formatNum(x)},${formatNum(barY + barHeight)},${formatNum(x + r)},${formatNum(barY + barHeight)}H${formatNum(x + w)}Z`\n\n barNodes.push(path(d, {\n class: 'chartts-bar chartts-bar-horizontal',\n fill: barFill,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\n } else {\n barNodes.push(rect(x, barY, w, barHeight, {\n class: 'chartts-bar chartts-bar-horizontal',\n fill: barFill,\n 'data-series': series.index,\n 'data-index': i,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${series.name}: ${series.values[i]}`,\n }))\n }\n }\n\n nodes.push(group(barNodes, {\n class: `chartts-series chartts-series-${series.index}`,\n 'data-series-name': series.name,\n }))\n }\n\n return nodes\n },\n\n hitTest(ctx: RenderContext, mx: number, my: number): HitResult | null {\n const { data, area, options, yScale } = ctx\n const seriesCount = data.series.length\n const pointCount = data.series[0]?.values.length ?? 0\n if (pointCount === 0) return null\n\n const labelWidth = Math.min(70, area.width * 0.2)\n const chartX = area.x + labelWidth\n const chartW = area.width - labelWidth\n const categoryHeight = area.height / pointCount\n const groupHeight = categoryHeight * (1 - options.barGap)\n const barHeight = groupHeight / seriesCount\n const groupOffset = -groupHeight / 2\n\n const valueToX = createHorizontalMapper(yScale, area, chartX, chartW)\n const zeroX = valueToX(0)\n\n for (const series of data.series) {\n for (let i = 0; i < series.values.length; i++) {\n const catCenter = area.y + categoryHeight * (i + 0.5)\n const barY = catCenter + groupOffset + series.index * barHeight\n const vx = valueToX(series.values[i]!)\n const x = Math.min(vx, zeroX)\n const w = Math.abs(vx - zeroX)\n\n if (mx >= x - 2 && mx <= x + w + 2 && my >= barY - 2 && my <= barY + barHeight + 2) {\n return { seriesIndex: series.index, pointIndex: i, distance: 0 }\n }\n }\n }\n\n return null\n },\n}\n"]}
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var chunk5QOQR5FE_cjs = require('./chunk-5QOQR5FE.cjs');
|
|
4
|
+
var chunkXHQWWR5M_cjs = require('./chunk-XHQWWR5M.cjs');
|
|
5
|
+
|
|
6
|
+
// src/charts/calendar/calendar-type.ts
|
|
7
|
+
var calendarChartType = {
|
|
8
|
+
type: "calendar",
|
|
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 series = data.series[0];
|
|
19
|
+
if (!series || series.values.length === 0) return nodes;
|
|
20
|
+
const values = series.values;
|
|
21
|
+
const count = values.length;
|
|
22
|
+
const rows = 7;
|
|
23
|
+
const cols = Math.ceil(count / rows);
|
|
24
|
+
let maxVal = 0;
|
|
25
|
+
for (const v of values) {
|
|
26
|
+
if (Math.abs(v) > maxVal) maxVal = Math.abs(v);
|
|
27
|
+
}
|
|
28
|
+
if (maxVal === 0) maxVal = 1;
|
|
29
|
+
const dayLabels = ["Mon", "Tue", "Wed", "Thu", "Fri", "Sat", "Sun"];
|
|
30
|
+
const labelW = 30;
|
|
31
|
+
const gridX = area.x + labelW;
|
|
32
|
+
const gridW = area.width - labelW;
|
|
33
|
+
const gridH = area.height;
|
|
34
|
+
const cellW = Math.min(gridW / cols, gridH / rows) - 1;
|
|
35
|
+
const cellH = cellW;
|
|
36
|
+
const gap = Math.max(1, cellW * 0.12);
|
|
37
|
+
const color = options.colors[0] ?? "#10b981";
|
|
38
|
+
for (let r = 0; r < rows; r++) {
|
|
39
|
+
if (r % 2 === 0) {
|
|
40
|
+
nodes.push(chunkXHQWWR5M_cjs.text(area.x + labelW - 4, area.y + r * (cellH + gap) + cellH / 2, dayLabels[r], {
|
|
41
|
+
class: "chartts-calendar-daylabel",
|
|
42
|
+
fill: theme.textMuted,
|
|
43
|
+
textAnchor: "end",
|
|
44
|
+
dominantBaseline: "central",
|
|
45
|
+
fontSize: Math.min(theme.fontSizeSmall * 0.8, cellH * 0.6),
|
|
46
|
+
fontFamily: theme.fontFamily
|
|
47
|
+
}));
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
for (let idx = 0; idx < count; idx++) {
|
|
51
|
+
const col = Math.floor(idx / rows);
|
|
52
|
+
const row = idx % rows;
|
|
53
|
+
const val = Math.abs(values[idx]);
|
|
54
|
+
const intensity = val / maxVal;
|
|
55
|
+
const x = gridX + col * (cellW + gap);
|
|
56
|
+
const y = area.y + row * (cellH + gap);
|
|
57
|
+
const cellColor = intensity === 0 ? theme.gridColor ?? "#e5e7eb" : interpolateOpacity(color, intensity);
|
|
58
|
+
const cellNodes = [
|
|
59
|
+
chunkXHQWWR5M_cjs.rect(x, y, cellW, cellH, {
|
|
60
|
+
class: "chartts-calendar-cell",
|
|
61
|
+
fill: cellColor,
|
|
62
|
+
rx: 3,
|
|
63
|
+
ry: 3,
|
|
64
|
+
"data-series": 0,
|
|
65
|
+
"data-index": idx,
|
|
66
|
+
tabindex: 0,
|
|
67
|
+
role: "img",
|
|
68
|
+
ariaLabel: `${data.labels[idx] ?? `Day ${idx + 1}`}: ${values[idx]}`
|
|
69
|
+
})
|
|
70
|
+
];
|
|
71
|
+
nodes.push(chunkXHQWWR5M_cjs.group(cellNodes, {
|
|
72
|
+
class: `chartts-series chartts-series-${idx}`
|
|
73
|
+
}));
|
|
74
|
+
}
|
|
75
|
+
return nodes;
|
|
76
|
+
},
|
|
77
|
+
hitTest(ctx, mx, my) {
|
|
78
|
+
const { data, area } = ctx;
|
|
79
|
+
const series = data.series[0];
|
|
80
|
+
if (!series || series.values.length === 0) return null;
|
|
81
|
+
const count = series.values.length;
|
|
82
|
+
const rows = 7;
|
|
83
|
+
const cols = Math.ceil(count / rows);
|
|
84
|
+
const labelW = 30;
|
|
85
|
+
const gridX = area.x + labelW;
|
|
86
|
+
const gridW = area.width - labelW;
|
|
87
|
+
const gridH = area.height;
|
|
88
|
+
const cellW = Math.min(gridW / cols, gridH / rows) - 1;
|
|
89
|
+
const cellH = cellW;
|
|
90
|
+
const gap = Math.max(1, cellW * 0.12);
|
|
91
|
+
const col = Math.floor((mx - gridX) / (cellW + gap));
|
|
92
|
+
const row = Math.floor((my - area.y) / (cellH + gap));
|
|
93
|
+
if (col < 0 || col >= cols || row < 0 || row >= rows) return null;
|
|
94
|
+
const idx = col * rows + row;
|
|
95
|
+
if (idx >= count) return null;
|
|
96
|
+
const cellX = gridX + col * (cellW + gap);
|
|
97
|
+
const cellY = area.y + row * (cellH + gap);
|
|
98
|
+
if (mx >= cellX && mx <= cellX + cellW && my >= cellY && my <= cellY + cellH) {
|
|
99
|
+
return { seriesIndex: 0, pointIndex: idx, distance: 0 };
|
|
100
|
+
}
|
|
101
|
+
return null;
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
function interpolateOpacity(hexColor, t) {
|
|
105
|
+
const hex = hexColor.replace("#", "");
|
|
106
|
+
const r = parseInt(hex.substring(0, 2), 16);
|
|
107
|
+
const g = parseInt(hex.substring(2, 4), 16);
|
|
108
|
+
const b = parseInt(hex.substring(4, 6), 16);
|
|
109
|
+
const alpha = 0.15 + t * 0.85;
|
|
110
|
+
return `rgba(${r},${g},${b},${alpha})`;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
exports.calendarChartType = calendarChartType;
|
|
114
|
+
//# sourceMappingURL=chunk-H4RNJ7FK.cjs.map
|
|
115
|
+
//# sourceMappingURL=chunk-H4RNJ7FK.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/charts/calendar/calendar-type.ts"],"names":["prepareNoAxes","text","rect","group"],"mappings":"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","file":"chunk-H4RNJ7FK.cjs","sourcesContent":["import type {\n ChartTypePlugin, ChartData, ResolvedOptions, PreparedData,\n RenderContext, RenderNode, HitResult, ScaleType,\n} from '../../types'\nimport { prepareNoAxes } from '../../utils/prepare'\nimport { group, rect, text } from '../../render/tree'\n\n/**\n * Calendar heatmap — GitHub-style contribution grid.\n *\n * Data format:\n * - labels: dates as strings (YYYY-MM-DD) or numbers (day index)\n * - series[0]: values for each day (intensity)\n *\n * Renders a 7-row (days of week) x N-column (weeks) grid.\n * If labels aren't dates, treats data as a flat grid: 7 rows.\n */\nexport const calendarChartType: ChartTypePlugin = {\n type: 'calendar',\n\n getScaleTypes(): { x: ScaleType; y: ScaleType } {\n return { x: 'categorical', y: 'linear' }\n },\n\n prepareData(data: ChartData, options: ResolvedOptions): PreparedData {\n return prepareNoAxes(data, options)\n },\n\n render(ctx: RenderContext): RenderNode[] {\n const { data, area, theme, options } = ctx\n const nodes: RenderNode[] = []\n\n const series = data.series[0]\n if (!series || series.values.length === 0) return nodes\n\n const values = series.values\n const count = values.length\n const rows = 7 // days of week\n const cols = Math.ceil(count / rows)\n\n let maxVal = 0\n for (const v of values) {\n if (Math.abs(v) > maxVal) maxVal = Math.abs(v)\n }\n if (maxVal === 0) maxVal = 1\n\n // Day labels\n const dayLabels = ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']\n const labelW = 30\n const gridX = area.x + labelW\n const gridW = area.width - labelW\n const gridH = area.height\n\n const cellW = Math.min(gridW / cols, gridH / rows) - 1\n const cellH = cellW // square cells\n const gap = Math.max(1, cellW * 0.12)\n\n const color = options.colors[0] ?? '#10b981'\n\n // Day-of-week labels\n for (let r = 0; r < rows; r++) {\n if (r % 2 === 0) { // show Mon, Wed, Fri, Sun\n nodes.push(text(area.x + labelW - 4, area.y + r * (cellH + gap) + cellH / 2, dayLabels[r]!, {\n class: 'chartts-calendar-daylabel',\n fill: theme.textMuted,\n textAnchor: 'end',\n dominantBaseline: 'central',\n fontSize: Math.min(theme.fontSizeSmall * 0.8, cellH * 0.6),\n fontFamily: theme.fontFamily,\n }))\n }\n }\n\n // Cells\n for (let idx = 0; idx < count; idx++) {\n const col = Math.floor(idx / rows)\n const row = idx % rows\n const val = Math.abs(values[idx]!)\n const intensity = val / maxVal\n\n const x = gridX + col * (cellW + gap)\n const y = area.y + row * (cellH + gap)\n\n const cellColor = intensity === 0\n ? (theme.gridColor ?? '#e5e7eb')\n : interpolateOpacity(color, intensity)\n\n const cellNodes: RenderNode[] = [\n rect(x, y, cellW, cellH, {\n class: 'chartts-calendar-cell',\n fill: cellColor,\n rx: 3,\n ry: 3,\n 'data-series': 0,\n 'data-index': idx,\n tabindex: 0,\n role: 'img',\n ariaLabel: `${data.labels[idx] ?? `Day ${idx + 1}`}: ${values[idx]}`,\n }),\n ]\n\n nodes.push(group(cellNodes, {\n class: `chartts-series chartts-series-${idx}`,\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 count = series.values.length\n const rows = 7\n const cols = Math.ceil(count / rows)\n const labelW = 30\n const gridX = area.x + labelW\n const gridW = area.width - labelW\n const gridH = area.height\n\n const cellW = Math.min(gridW / cols, gridH / rows) - 1\n const cellH = cellW\n const gap = Math.max(1, cellW * 0.12)\n\n const col = Math.floor((mx - gridX) / (cellW + gap))\n const row = Math.floor((my - area.y) / (cellH + gap))\n\n if (col < 0 || col >= cols || row < 0 || row >= rows) return null\n\n const idx = col * rows + row\n if (idx >= count) return null\n\n // Check if actually within the cell bounds\n const cellX = gridX + col * (cellW + gap)\n const cellY = area.y + row * (cellH + gap)\n if (mx >= cellX && mx <= cellX + cellW && my >= cellY && my <= cellY + cellH) {\n return { seriesIndex: 0, pointIndex: idx, distance: 0 }\n }\n\n return null\n },\n}\n\nfunction interpolateOpacity(hexColor: string, t: number): string {\n // Parse hex\n const hex = hexColor.replace('#', '')\n const r = parseInt(hex.substring(0, 2), 16)\n const g = parseInt(hex.substring(2, 4), 16)\n const b = parseInt(hex.substring(4, 6), 16)\n\n // Blend with a minimum opacity of 0.15 up to 1.0\n const alpha = 0.15 + t * 0.85\n return `rgba(${r},${g},${b},${alpha})`\n}\n"]}
|