@validationcloud/fractal-ui 1.77.0 → 1.79.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/README.md +20 -0
- package/dist/charts.d.ts +2 -0
- package/dist/charts.js +29 -20
- package/dist/components/dropdown-menu/dropdown-menu.js +34 -26
- package/dist/components/echarts-renderer/geo/africa-countries.json.d.ts +2463 -0
- package/dist/components/echarts-renderer/geo/africa-countries.json.js +9 -0
- package/dist/components/echarts-renderer/geo/americas-countries.json.d.ts +4160 -0
- package/dist/components/echarts-renderer/geo/americas-countries.json.js +9 -0
- package/dist/components/echarts-renderer/geo/asia-countries.json.d.ts +4297 -0
- package/dist/components/echarts-renderer/geo/asia-countries.json.js +9 -0
- package/dist/components/echarts-renderer/geo/europe-countries.json.d.ts +2486 -0
- package/dist/components/echarts-renderer/geo/europe-countries.json.js +9 -0
- package/dist/components/echarts-renderer/geo/us-states.json.d.ts +1338 -0
- package/dist/components/echarts-renderer/geo/us-states.json.js +9 -0
- package/dist/components/echarts-renderer/geo/world-continents.json.d.ts +10639 -0
- package/dist/components/echarts-renderer/geo/world-continents.json.js +9 -0
- package/dist/components/echarts-renderer/geo/world-countries.json.d.ts +14549 -0
- package/dist/components/echarts-renderer/geo/world-countries.json.js +9 -0
- package/dist/components/echarts-renderer/geo/world-regions.json.d.ts +10621 -0
- package/dist/components/echarts-renderer/geo/world-regions.json.js +9 -0
- package/dist/components/echarts-renderer/map-centers.d.ts +1 -0
- package/dist/components/echarts-renderer/map-centers.js +13 -0
- package/dist/components/echarts-renderer/map-style.d.ts +12 -0
- package/dist/components/echarts-renderer/map-style.js +12 -0
- package/dist/components/echarts-renderer/mavrik-theme-horizontal.json.d.ts +36 -0
- package/dist/components/echarts-renderer/mavrik-theme-horizontal.json.js +26 -22
- package/dist/components/echarts-renderer/mavrik-theme.json.d.ts +36 -0
- package/dist/components/echarts-renderer/mavrik-theme.json.js +26 -22
- package/dist/components/echarts-renderer/natural-earth-projection.d.ts +29 -0
- package/dist/components/echarts-renderer/natural-earth-projection.js +64 -0
- package/dist/components/echarts-renderer/register-map.d.ts +24 -0
- package/dist/components/echarts-renderer/register-map.js +62 -0
- package/dist/components/echarts-renderer/sanitize-chart-options.d.ts +2 -2
- package/dist/components/echarts-renderer/sanitize-chart-options.js +28 -5
- package/dist/components/echarts-renderer/use-chart-instance.js +38 -36
- package/dist/hooks/use-scroll-to-bottom.d.ts +4 -3
- package/dist/lib/render-chart-to-image.js +72 -43
- package/dist/maps.json +438 -0
- package/package.json +22 -4
|
@@ -1,39 +1,43 @@
|
|
|
1
|
-
const M = [{ type: "linear", x: 0, y: 0, x2: 0, y2: 1, colorStops: [{ offset: 0, color: "#C14E64" }, { offset: 1, color: "#DE7385" }] }, "#00BBFA", "#0072B2", "#E69F00", "#D66119", "#56B4E9", "#45B26B", "#F0E442", "#FF99BF", "#8277D8"], L = "#1A1D1F", N = { fontFamily: "Poppins, sans-serif", fontWeight: 500 }, j = { top: 32, left: 32, textStyle: { color: "#FFFFFF", fontSize: 16, fontWeight: 600 }, subtextStyle: { color: "#A7A9AD" } }, A = { itemStyle: { borderWidth: 1 }, lineStyle: { width: 2 }, areaStyle: { opacity: 0.15 }, showSymbol: !1, symbolSize: 5, symbol: "circle", smooth: !1, sampling: "lttb" }, D = { barGap: "25%", barCategoryGap: "25%" }, g = { axisLine: { show: !0, lineStyle: { color: "#3A3D46", type: "dashed" } }, axisTick: { show: !1 }, axisLabel: { show: !0, color: "#A7A9AD", hideOverlap: !0 }, nameLocation: "middle", nameTextStyle: { color: "#A7A9AD", fontSize: 11, fontWeight: 400 }, splitLine: { show: !1 } }, u = { axisLine: { show: !1 }, axisTick: { show: !1 }, axisLabel: { show: !0, color: "#A7A9AD", hideOverlap: !0 }, nameLocation: "middle", nameTextStyle: { color: "#A7A9AD", fontSize: 11, fontWeight: 400 }, splitLine: { show: !0, lineStyle: { color: ["#3A3D46"], type: "dashed" } } }, I = { axisLine: { show: !1 }, axisTick: { show: !1 }, axisLabel: { show: !0, color: "#A7A9AD", hideOverlap: !0 }, nameLocation: "middle", nameTextStyle: { color: "#A7A9AD", fontSize: 11, fontWeight: 400 }, splitLine: { show: !0, lineStyle: { color: ["#3A3D46"], type: "dashed" } } }, t = { axisLine: { show: !0, lineStyle: { color: "#3A3D46" } }, axisTick: { show: !1 }, axisLabel: { show: !0, color: "#A7A9AD", hideOverlap: !0 }, nameLocation: "middle", nameTextStyle: { color: "#A7A9AD", fontSize: 11, fontWeight: 400 }, splitLine: { show: !1 } }, y = { top: 82, left: "auto", right: 32, icon: "circle", itemGap: 22, itemWidth: 12, itemHeight: 12, textStyle: { color: "#A7A9AD", fontSize: 11 } }, T = { top: 132, left: 32, right: 32, bottom: 32, outerBoundsMode: "same", outerBoundsContain: "axisLabel" }, S = { backgroundColor: "rgba(26, 29, 31, 0)", borderColor: "#3A3D46", borderRadius: 4, dataBackground: { lineStyle: { color: "#606060", width: 1 }, areaStyle: { color: "rgba(96, 96, 96, 0.3)" } }, selectedDataBackground: { lineStyle: { color: "#b36674", width: 1 }, areaStyle: { color: "rgba(164, 91, 105, 0.5)" } }, fillerColor: "rgba(82, 45, 52, 0.35)", handleStyle: { color: "#C14E64", borderColor: "#C14E64" }, moveHandleStyle: { color: "#b36674" }, brushStyle: { color: "rgba(95, 58, 65, 0.2)" }, emphasis: { handleStyle: { color: "rgb(209, 123, 140)", borderColor: "rgb(209, 123, 140)" } }, handleSize: "100%", textStyle: { color: "#A7A9AD" } }, i = { color: ["#C14E64", "#00BBFA", "#0072B2", "#E69F00", "#D66119", "#56B4E9", "#45B26B", "#F0E442", "#FF99BF", "#8277D8"], left: 140, right: 140, top: 82, bottom: 32, nodeWidth: 20, nodeGap: 40, layoutIterations: 32, draggable: !1, emphasis: { focus: "adjacency" }, label: { show: !0, formatter: "{b}", color: "#FCFCFC", fontSize: 11, width: 100, overflow: "truncate", ellipsis: "..." }, edgeLabel: { show: !1, fontSize: 9, color: "#A7A9AD", backgroundColor: "rgba(26, 29, 31, 0.85)", padding: [2, 6], borderRadius: 3 }, lineStyle: { color: "gradient", opacity: 0.4, curveness: 0.5 }, itemStyle: { borderWidth: 0 }, levels: [{ depth: 0, itemStyle: { color: "#C14E64" }, lineStyle: { color: "gradient", opacity: 0.4 } }, { depth: 1, itemStyle: { color: "#56B4E9" }, lineStyle: { color: "gradient", opacity: 0.4 } }, { depth: 2, itemStyle: { color: "#0072B2" }, lineStyle: { color: "gradient", opacity: 0.4 } }] }, z = { label: { color: "#A7A9AD" }, emphasis: { label: { color: "#FFFFFF" } } }, o = { confine: !0, backgroundColor: "transparent", padding: 10, borderRadius: 8, borderColor: "#50525A", borderWidth: 1, textStyle: { color: "#FCFCFC", fontFamily: "Poppins, sans-serif", fontSize: 11, fontStyle: "normal", fontWeight: 500 }, extraCssText: "letter-spacing: 0.22px; box-shadow: 0 14px 11px -4px rgba(0, 0, 0, 0.30), 0 -4px 4px 0 rgba(0, 0, 0, 0.04) inset; background: radial-gradient(ellipse at 25% 0%, rgba(217, 217, 217, 0.12) 0%, transparent 60%), #1A1D1F;" }, e = { type: "image", id: "fractal-watermark", left: "center", top: "middle", style: { image: "data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" width="210" height="24" fill="none" viewBox="0 0 210 24">
  <g fill="#a7a9ad" fill-opacity="0.3">
    <path fill-rule="evenodd" d="M33.733 1.868h-21.67C6.438 1.868 1.878 6.404 1.878 12s4.56 10.132 10.185 10.132h21.67c5.625 0 10.185-4.536 10.185-10.132S39.358 1.868 33.733 1.868M0 12c0 6.627 5.4 12 12.063 12h21.67c6.662 0 12.063-5.373 12.063-12s-5.4-12-12.063-12h-21.67C5.401 0 0 5.373 0 12" clip-rule="evenodd"/>
    <path fill-rule="evenodd" d="M33.734 5.174h-21.67C8.273 5.174 5.2 8.23 5.2 12s3.073 6.826 6.863 6.826h21.67c3.79 0 6.862-3.056 6.862-6.826s-3.072-6.826-6.862-6.826M3.323 12c0 4.802 3.912 8.695 8.74 8.695h21.67c4.827 0 8.74-3.893 8.74-8.695s-3.913-8.695-8.74-8.695h-21.67c-4.828 0-8.74 3.893-8.74 8.695" clip-rule="evenodd"/>
    <path fill-rule="evenodd" d="M33.733 8.48h-21.67A3.53 3.53 0 0 0 8.523 12a3.53 3.53 0 0 0 3.54 3.521h21.67a3.53 3.53 0 0 0 3.54-3.52 3.53 3.53 0 0 0-3.54-3.522M6.646 12c0 2.976 2.425 5.39 5.417 5.39h21.67c2.992 0 5.418-2.414 5.418-5.39s-2.426-5.39-5.418-5.39h-21.67c-2.992 0-5.417 2.414-5.417 5.39" clip-rule="evenodd"/>
    <path d="M58.45 20.695h-2.77L48.592 3.327h2.7l5.773 14.542 5.773-14.542h2.7zM73.986 20.695h-2.06l-.14-1.482q-.64.81-1.617 1.262-.978.45-2.165.451-1.246 0-2.223-.486a3.86 3.86 0 0 1-1.537-1.332 3.4 3.4 0 0 1-.559-1.922q0-1.134.606-1.991.605-.868 1.653-1.355 1.047-.498 2.386-.498.838 0 1.699.197a6.6 6.6 0 0 1 1.571.556v-.429q0-.844-.442-1.447a2.7 2.7 0 0 0-1.187-.938 4.1 4.1 0 0 0-1.653-.324q-.802 0-1.641.278-.826.277-1.56.857l-.721-1.934a9.3 9.3 0 0 1 2.2-.95 8.3 8.3 0 0 1 2.257-.323q1.583 0 2.724.625a4.35 4.35 0 0 1 1.78 1.783q.63 1.146.63 2.71zm-5.517-1.783q.827 0 1.525-.336a2.93 2.93 0 0 0 1.129-.973q.442-.636.477-1.482v-.162a4.7 4.7 0 0 0-1.338-.683 4.6 4.6 0 0 0-1.502-.255q-1.176 0-1.955.556-.78.555-.78 1.424 0 .544.314.984.326.43.873.683.56.244 1.257.244M77.988 20.695h-2.54V2.864h2.54zM80.666 5.758q-.548 0-.92-.382a1.28 1.28 0 0 1-.373-.926q0-.545.373-.915.372-.382.92-.382.56 0 .932.382.385.37.385.915t-.385.926q-.373.382-.932.382m1.188 14.937h-2.388V9.116h2.388zM95.628 20.695H93.52l-.128-1.656a5.7 5.7 0 0 1-1.909 1.39q-1.106.497-2.432.497-1.677 0-3.003-.787a5.7 5.7 0 0 1-2.095-2.154q-.757-1.365-.757-3.08 0-1.724.757-3.08a5.7 5.7 0 0 1 2.095-2.153q1.326-.787 3.003-.787 1.257 0 2.328.451a5.5 5.5 0 0 1 1.862 1.262V3.327h2.386zm-6.18-1.9q1.059 0 1.908-.486a3.75 3.75 0 0 0 1.374-1.32q.512-.833.512-1.898v-.394q0-1.065-.512-1.899a3.66 3.66 0 0 0-1.374-1.308q-.85-.475-1.908-.475-1.083 0-1.944.51a3.7 3.7 0 0 0-1.362 1.389q-.5.869-.5 1.98t.5 1.991a3.8 3.8 0 0 0 1.362 1.401q.861.51 1.944.51M107.269 20.695h-2.061l-.139-1.482q-.64.81-1.618 1.262-.978.45-2.165.451-1.245 0-2.223-.486a3.86 3.86 0 0 1-1.536-1.332 3.4 3.4 0 0 1-.56-1.922q0-1.134.606-1.991.605-.868 1.653-1.355 1.047-.498 2.386-.498a7.6 7.6 0 0 1 1.699.197 6.6 6.6 0 0 1 1.571.556v-.429q0-.844-.442-1.447a2.7 2.7 0 0 0-1.187-.938 4.1 4.1 0 0 0-1.653-.324 5.166 5.166 0 0 0-3.2 1.135l-.722-1.934a9.3 9.3 0 0 1 2.2-.95 8.3 8.3 0 0 1 2.258-.323q1.583 0 2.723.625a4.35 4.35 0 0 1 1.781 1.783q.629 1.146.629 2.71zm-5.517-1.783q.826 0 1.524-.336a2.9 2.9 0 0 0 1.129-.973q.442-.636.477-1.482v-.162a4.6 4.6 0 0 0-1.338-.683 4.6 4.6 0 0 0-1.502-.255q-1.175 0-1.955.556-.78.555-.78 1.424 0 .544.314.984.327.43.873.683.56.244 1.258.244M116.424 20.405q-1.221.521-2.362.521t-2.002-.486a3.5 3.5 0 0 1-1.339-1.366q-.477-.892-.477-2.05v-5.789h-2.037V9.116h2.153V6.222h2.27v2.894h3.399v2.119h-3.399v5.35q0 1.018.547 1.62.558.59 1.432.59.734 0 1.455-.44zM118.58 5.758q-.548 0-.92-.382a1.28 1.28 0 0 1-.373-.926q0-.545.373-.915.372-.382.92-.382.56 0 .932.382.385.37.385.915t-.385.926a1.25 1.25 0 0 1-.932.382m1.188 14.937h-2.388V9.116h2.388zM127.257 20.926q-1.746 0-3.143-.787a5.85 5.85 0 0 1-2.2-2.142q-.803-1.366-.803-3.092 0-1.713.803-3.068a5.8 5.8 0 0 1 2.2-2.153q1.397-.8 3.143-.8 1.757 0 3.142.8a5.76 5.76 0 0 1 2.177 2.153q.803 1.355.803 3.068 0 1.725-.803 3.092a5.8 5.8 0 0 1-2.177 2.142q-1.385.787-3.142.787m-.012-2.13q1.06 0 1.886-.51a3.7 3.7 0 0 0 1.315-1.39q.489-.88.489-2.002 0-1.1-.489-1.969a3.6 3.6 0 0 0-1.315-1.389q-.827-.52-1.886-.52-1.047 0-1.885.52a3.7 3.7 0 0 0-1.327 1.39q-.477.868-.477 1.968 0 1.123.477 2.003a3.8 3.8 0 0 0 1.327 1.39q.837.509 1.885.509M145.816 20.695h-2.386v-6.287q0-1.54-.849-2.455-.839-.915-2.258-.915-1.466 0-2.363.973-.896.972-.896 2.582v6.102h-2.386V9.116h2.013l.082 1.864a4.25 4.25 0 0 1 1.676-1.551q1.035-.544 2.432-.544 2.294 0 3.609 1.377 1.326 1.379 1.326 3.798zM166.178 18.483a8.7 8.7 0 0 1-2.888 1.887q-1.664.672-3.631.672t-3.632-.672a8.7 8.7 0 0 1-2.898-1.887 8.9 8.9 0 0 1-1.908-2.871q-.676-1.656-.676-3.601 0-1.957.676-3.601a8.7 8.7 0 0 1 1.908-2.872 8.7 8.7 0 0 1 2.898-1.887q1.665-.671 3.632-.671 1.955 0 3.619.683 1.677.671 2.875 1.864l-1.78 1.806a6.2 6.2 0 0 0-2.094-1.54q-1.212-.567-2.654-.567-1.397 0-2.573.51a6 6 0 0 0-2.049 1.423 6.6 6.6 0 0 0-1.361 2.154q-.478 1.239-.478 2.698t.478 2.698a6.7 6.7 0 0 0 1.361 2.165 6.2 6.2 0 0 0 2.049 1.424q1.175.498 2.573.498 1.442 0 2.654-.556a6.2 6.2 0 0 0 2.083-1.552zM170.092 20.695h-2.54V2.864h2.54zM177.534 20.926q-1.745 0-3.143-.787a5.84 5.84 0 0 1-2.199-2.142q-.803-1.366-.803-3.092 0-1.713.803-3.068a5.8 5.8 0 0 1 2.199-2.153q1.398-.8 3.143-.8 1.758 0 3.142.8a5.75 5.75 0 0 1 2.176 2.153q.804 1.355.803 3.068 0 1.725-.803 3.092a5.8 5.8 0 0 1-2.176 2.142q-1.384.787-3.142.787m-.013-2.13q1.06 0 1.887-.51a3.7 3.7 0 0 0 1.315-1.39q.488-.88.488-2.002 0-1.1-.488-1.969a3.6 3.6 0 0 0-1.315-1.389q-.827-.52-1.887-.52a3.5 3.5 0 0 0-1.885.52 3.7 3.7 0 0 0-1.326 1.39q-.477.868-.477 1.968 0 1.123.477 2.003a3.8 3.8 0 0 0 1.326 1.39 3.56 3.56 0 0 0 1.885.509M196.1 20.695h-2.026l-.082-1.864q-.64 1.018-1.676 1.563-1.025.532-2.433.532-2.28 0-3.607-1.378-1.316-1.39-1.316-3.797V9.116h2.387v6.287q0 1.54.837 2.455.84.915 2.258.915 1.468 0 2.364-.973.907-.984.907-2.582V9.116h2.387zM209.84 20.695h-2.106l-.129-1.656a5.7 5.7 0 0 1-1.908 1.39q-1.105.497-2.433.497-1.676 0-3.002-.787a5.7 5.7 0 0 1-2.096-2.154q-.756-1.365-.756-3.08 0-1.724.756-3.08a5.7 5.7 0 0 1 2.096-2.153q1.326-.787 3.002-.787 1.257 0 2.329.451a5.5 5.5 0 0 1 1.862 1.262V3.327h2.385zm-6.18-1.9q1.059 0 1.908-.486a3.74 3.74 0 0 0 1.374-1.32q.512-.833.513-1.898v-.394q0-1.065-.513-1.899a3.65 3.65 0 0 0-1.374-1.308q-.849-.475-1.908-.475-1.082 0-1.943.51a3.7 3.7 0 0 0-1.363 1.389q-.5.869-.499 1.98 0 1.111.499 1.991a3.8 3.8 0 0 0 1.363 1.401q.86.51 1.943.51"/>
  </g>
</svg>", width: 210, height: 24 }, z: 100, silent: !0 }, x = {
|
|
1
|
+
const M = [{ type: "linear", x: 0, y: 0, x2: 0, y2: 1, colorStops: [{ offset: 0, color: "#C14E64" }, { offset: 1, color: "#DE7385" }] }, "#00BBFA", "#0072B2", "#E69F00", "#D66119", "#56B4E9", "#45B26B", "#F0E442", "#FF99BF", "#8277D8"], L = "#1A1D1F", N = { fontFamily: "Poppins, sans-serif", fontWeight: 500 }, j = { top: 32, left: 32, textStyle: { color: "#FFFFFF", fontSize: 16, fontWeight: 600 }, subtextStyle: { color: "#A7A9AD" } }, D = { itemStyle: { borderWidth: 1 }, lineStyle: { width: 2 }, areaStyle: { opacity: 0.15 }, showSymbol: !1, symbolSize: 5, symbol: "circle", smooth: !1, sampling: "lttb" }, A = { barGap: "25%", barCategoryGap: "25%" }, g = { axisLine: { show: !0, lineStyle: { color: "#3A3D46", type: "dashed" } }, axisTick: { show: !1 }, axisLabel: { show: !0, color: "#A7A9AD", hideOverlap: !0 }, nameLocation: "middle", nameTextStyle: { color: "#A7A9AD", fontSize: 11, fontWeight: 400 }, splitLine: { show: !1 } }, t = { axisLine: { show: !1 }, axisTick: { show: !1 }, axisLabel: { show: !0, color: "#A7A9AD", hideOverlap: !0 }, nameLocation: "middle", nameTextStyle: { color: "#A7A9AD", fontSize: 11, fontWeight: 400 }, splitLine: { show: !0, lineStyle: { color: ["#3A3D46"], type: "dashed" } } }, u = { axisLine: { show: !1 }, axisTick: { show: !1 }, axisLabel: { show: !0, color: "#A7A9AD", hideOverlap: !0 }, nameLocation: "middle", nameTextStyle: { color: "#A7A9AD", fontSize: 11, fontWeight: 400 }, splitLine: { show: !0, lineStyle: { color: ["#3A3D46"], type: "dashed" } } }, I = { axisLine: { show: !0, lineStyle: { color: "#3A3D46" } }, axisTick: { show: !1 }, axisLabel: { show: !0, color: "#A7A9AD", hideOverlap: !0 }, nameLocation: "middle", nameTextStyle: { color: "#A7A9AD", fontSize: 11, fontWeight: 400 }, splitLine: { show: !1 } }, y = { top: 82, left: "auto", right: 32, icon: "circle", itemGap: 22, itemWidth: 12, itemHeight: 12, textStyle: { color: "#A7A9AD", fontSize: 11 } }, T = { top: 132, left: 32, right: 32, bottom: 32, outerBoundsMode: "same", outerBoundsContain: "axisLabel" }, i = { backgroundColor: "rgba(26, 29, 31, 0)", borderColor: "#3A3D46", borderRadius: 4, dataBackground: { lineStyle: { color: "#606060", width: 1 }, areaStyle: { color: "rgba(96, 96, 96, 0.3)" } }, selectedDataBackground: { lineStyle: { color: "#b36674", width: 1 }, areaStyle: { color: "rgba(164, 91, 105, 0.5)" } }, fillerColor: "rgba(82, 45, 52, 0.35)", handleStyle: { color: "#C14E64", borderColor: "#C14E64" }, moveHandleStyle: { color: "#b36674" }, brushStyle: { color: "rgba(95, 58, 65, 0.2)" }, emphasis: { handleStyle: { color: "rgb(209, 123, 140)", borderColor: "rgb(209, 123, 140)" } }, handleSize: "100%", textStyle: { color: "#A7A9AD" } }, S = { color: ["#C14E64", "#00BBFA", "#0072B2", "#E69F00", "#D66119", "#56B4E9", "#45B26B", "#F0E442", "#FF99BF", "#8277D8"], left: 140, right: 140, top: 82, bottom: 32, nodeWidth: 20, nodeGap: 40, layoutIterations: 32, draggable: !1, emphasis: { focus: "adjacency" }, label: { show: !0, formatter: "{b}", color: "#FCFCFC", fontSize: 11, width: 100, overflow: "truncate", ellipsis: "..." }, edgeLabel: { show: !1, fontSize: 9, color: "#A7A9AD", backgroundColor: "rgba(26, 29, 31, 0.85)", padding: [2, 6], borderRadius: 3 }, lineStyle: { color: "gradient", opacity: 0.4, curveness: 0.5 }, itemStyle: { borderWidth: 0 }, levels: [{ depth: 0, itemStyle: { color: "#C14E64" }, lineStyle: { color: "gradient", opacity: 0.4 } }, { depth: 1, itemStyle: { color: "#56B4E9" }, lineStyle: { color: "gradient", opacity: 0.4 } }, { depth: 2, itemStyle: { color: "#0072B2" }, lineStyle: { color: "gradient", opacity: 0.4 } }] }, z = { itemStyle: { areaColor: "#413E3D", borderColor: "#2A2726", borderWidth: 0.5 }, label: { show: !1 }, emphasis: { label: { show: !1 }, itemStyle: { areaColor: "#524E4D" } } }, e = { itemStyle: { areaColor: "#413E3D", borderColor: "#2A2726", borderWidth: 0.5 }, label: { show: !1 }, emphasis: { label: { show: !1 }, itemStyle: { areaColor: "#524E4D" } } }, o = { label: { color: "#A7A9AD" }, emphasis: { label: { color: "#FFFFFF" } } }, x = { confine: !0, backgroundColor: "transparent", padding: 10, borderRadius: 8, borderColor: "#50525A", borderWidth: 1, textStyle: { color: "#FCFCFC", fontFamily: "Poppins, sans-serif", fontSize: 11, fontStyle: "normal", fontWeight: 500 }, extraCssText: "letter-spacing: 0.22px; box-shadow: 0 14px 11px -4px rgba(0, 0, 0, 0.30), 0 -4px 4px 0 rgba(0, 0, 0, 0.04) inset; background: radial-gradient(ellipse at 25% 0%, rgba(217, 217, 217, 0.12) 0%, transparent 60%), #1A1D1F;" }, C = { type: "image", id: "fractal-watermark", left: "center", top: "middle", style: { image: "data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" width="210" height="24" fill="none" viewBox="0 0 210 24">
  <g fill="#a7a9ad" fill-opacity="0.3">
    <path fill-rule="evenodd" d="M33.733 1.868h-21.67C6.438 1.868 1.878 6.404 1.878 12s4.56 10.132 10.185 10.132h21.67c5.625 0 10.185-4.536 10.185-10.132S39.358 1.868 33.733 1.868M0 12c0 6.627 5.4 12 12.063 12h21.67c6.662 0 12.063-5.373 12.063-12s-5.4-12-12.063-12h-21.67C5.401 0 0 5.373 0 12" clip-rule="evenodd"/>
    <path fill-rule="evenodd" d="M33.734 5.174h-21.67C8.273 5.174 5.2 8.23 5.2 12s3.073 6.826 6.863 6.826h21.67c3.79 0 6.862-3.056 6.862-6.826s-3.072-6.826-6.862-6.826M3.323 12c0 4.802 3.912 8.695 8.74 8.695h21.67c4.827 0 8.74-3.893 8.74-8.695s-3.913-8.695-8.74-8.695h-21.67c-4.828 0-8.74 3.893-8.74 8.695" clip-rule="evenodd"/>
    <path fill-rule="evenodd" d="M33.733 8.48h-21.67A3.53 3.53 0 0 0 8.523 12a3.53 3.53 0 0 0 3.54 3.521h21.67a3.53 3.53 0 0 0 3.54-3.52 3.53 3.53 0 0 0-3.54-3.522M6.646 12c0 2.976 2.425 5.39 5.417 5.39h21.67c2.992 0 5.418-2.414 5.418-5.39s-2.426-5.39-5.418-5.39h-21.67c-2.992 0-5.417 2.414-5.417 5.39" clip-rule="evenodd"/>
    <path d="M58.45 20.695h-2.77L48.592 3.327h2.7l5.773 14.542 5.773-14.542h2.7zM73.986 20.695h-2.06l-.14-1.482q-.64.81-1.617 1.262-.978.45-2.165.451-1.246 0-2.223-.486a3.86 3.86 0 0 1-1.537-1.332 3.4 3.4 0 0 1-.559-1.922q0-1.134.606-1.991.605-.868 1.653-1.355 1.047-.498 2.386-.498.838 0 1.699.197a6.6 6.6 0 0 1 1.571.556v-.429q0-.844-.442-1.447a2.7 2.7 0 0 0-1.187-.938 4.1 4.1 0 0 0-1.653-.324q-.802 0-1.641.278-.826.277-1.56.857l-.721-1.934a9.3 9.3 0 0 1 2.2-.95 8.3 8.3 0 0 1 2.257-.323q1.583 0 2.724.625a4.35 4.35 0 0 1 1.78 1.783q.63 1.146.63 2.71zm-5.517-1.783q.827 0 1.525-.336a2.93 2.93 0 0 0 1.129-.973q.442-.636.477-1.482v-.162a4.7 4.7 0 0 0-1.338-.683 4.6 4.6 0 0 0-1.502-.255q-1.176 0-1.955.556-.78.555-.78 1.424 0 .544.314.984.326.43.873.683.56.244 1.257.244M77.988 20.695h-2.54V2.864h2.54zM80.666 5.758q-.548 0-.92-.382a1.28 1.28 0 0 1-.373-.926q0-.545.373-.915.372-.382.92-.382.56 0 .932.382.385.37.385.915t-.385.926q-.373.382-.932.382m1.188 14.937h-2.388V9.116h2.388zM95.628 20.695H93.52l-.128-1.656a5.7 5.7 0 0 1-1.909 1.39q-1.106.497-2.432.497-1.677 0-3.003-.787a5.7 5.7 0 0 1-2.095-2.154q-.757-1.365-.757-3.08 0-1.724.757-3.08a5.7 5.7 0 0 1 2.095-2.153q1.326-.787 3.003-.787 1.257 0 2.328.451a5.5 5.5 0 0 1 1.862 1.262V3.327h2.386zm-6.18-1.9q1.059 0 1.908-.486a3.75 3.75 0 0 0 1.374-1.32q.512-.833.512-1.898v-.394q0-1.065-.512-1.899a3.66 3.66 0 0 0-1.374-1.308q-.85-.475-1.908-.475-1.083 0-1.944.51a3.7 3.7 0 0 0-1.362 1.389q-.5.869-.5 1.98t.5 1.991a3.8 3.8 0 0 0 1.362 1.401q.861.51 1.944.51M107.269 20.695h-2.061l-.139-1.482q-.64.81-1.618 1.262-.978.45-2.165.451-1.245 0-2.223-.486a3.86 3.86 0 0 1-1.536-1.332 3.4 3.4 0 0 1-.56-1.922q0-1.134.606-1.991.605-.868 1.653-1.355 1.047-.498 2.386-.498a7.6 7.6 0 0 1 1.699.197 6.6 6.6 0 0 1 1.571.556v-.429q0-.844-.442-1.447a2.7 2.7 0 0 0-1.187-.938 4.1 4.1 0 0 0-1.653-.324 5.166 5.166 0 0 0-3.2 1.135l-.722-1.934a9.3 9.3 0 0 1 2.2-.95 8.3 8.3 0 0 1 2.258-.323q1.583 0 2.723.625a4.35 4.35 0 0 1 1.781 1.783q.629 1.146.629 2.71zm-5.517-1.783q.826 0 1.524-.336a2.9 2.9 0 0 0 1.129-.973q.442-.636.477-1.482v-.162a4.6 4.6 0 0 0-1.338-.683 4.6 4.6 0 0 0-1.502-.255q-1.175 0-1.955.556-.78.555-.78 1.424 0 .544.314.984.327.43.873.683.56.244 1.258.244M116.424 20.405q-1.221.521-2.362.521t-2.002-.486a3.5 3.5 0 0 1-1.339-1.366q-.477-.892-.477-2.05v-5.789h-2.037V9.116h2.153V6.222h2.27v2.894h3.399v2.119h-3.399v5.35q0 1.018.547 1.62.558.59 1.432.59.734 0 1.455-.44zM118.58 5.758q-.548 0-.92-.382a1.28 1.28 0 0 1-.373-.926q0-.545.373-.915.372-.382.92-.382.56 0 .932.382.385.37.385.915t-.385.926a1.25 1.25 0 0 1-.932.382m1.188 14.937h-2.388V9.116h2.388zM127.257 20.926q-1.746 0-3.143-.787a5.85 5.85 0 0 1-2.2-2.142q-.803-1.366-.803-3.092 0-1.713.803-3.068a5.8 5.8 0 0 1 2.2-2.153q1.397-.8 3.143-.8 1.757 0 3.142.8a5.76 5.76 0 0 1 2.177 2.153q.803 1.355.803 3.068 0 1.725-.803 3.092a5.8 5.8 0 0 1-2.177 2.142q-1.385.787-3.142.787m-.012-2.13q1.06 0 1.886-.51a3.7 3.7 0 0 0 1.315-1.39q.489-.88.489-2.002 0-1.1-.489-1.969a3.6 3.6 0 0 0-1.315-1.389q-.827-.52-1.886-.52-1.047 0-1.885.52a3.7 3.7 0 0 0-1.327 1.39q-.477.868-.477 1.968 0 1.123.477 2.003a3.8 3.8 0 0 0 1.327 1.39q.837.509 1.885.509M145.816 20.695h-2.386v-6.287q0-1.54-.849-2.455-.839-.915-2.258-.915-1.466 0-2.363.973-.896.972-.896 2.582v6.102h-2.386V9.116h2.013l.082 1.864a4.25 4.25 0 0 1 1.676-1.551q1.035-.544 2.432-.544 2.294 0 3.609 1.377 1.326 1.379 1.326 3.798zM166.178 18.483a8.7 8.7 0 0 1-2.888 1.887q-1.664.672-3.631.672t-3.632-.672a8.7 8.7 0 0 1-2.898-1.887 8.9 8.9 0 0 1-1.908-2.871q-.676-1.656-.676-3.601 0-1.957.676-3.601a8.7 8.7 0 0 1 1.908-2.872 8.7 8.7 0 0 1 2.898-1.887q1.665-.671 3.632-.671 1.955 0 3.619.683 1.677.671 2.875 1.864l-1.78 1.806a6.2 6.2 0 0 0-2.094-1.54q-1.212-.567-2.654-.567-1.397 0-2.573.51a6 6 0 0 0-2.049 1.423 6.6 6.6 0 0 0-1.361 2.154q-.478 1.239-.478 2.698t.478 2.698a6.7 6.7 0 0 0 1.361 2.165 6.2 6.2 0 0 0 2.049 1.424q1.175.498 2.573.498 1.442 0 2.654-.556a6.2 6.2 0 0 0 2.083-1.552zM170.092 20.695h-2.54V2.864h2.54zM177.534 20.926q-1.745 0-3.143-.787a5.84 5.84 0 0 1-2.199-2.142q-.803-1.366-.803-3.092 0-1.713.803-3.068a5.8 5.8 0 0 1 2.199-2.153q1.398-.8 3.143-.8 1.758 0 3.142.8a5.75 5.75 0 0 1 2.176 2.153q.804 1.355.803 3.068 0 1.725-.803 3.092a5.8 5.8 0 0 1-2.176 2.142q-1.384.787-3.142.787m-.013-2.13q1.06 0 1.887-.51a3.7 3.7 0 0 0 1.315-1.39q.488-.88.488-2.002 0-1.1-.488-1.969a3.6 3.6 0 0 0-1.315-1.389q-.827-.52-1.887-.52a3.5 3.5 0 0 0-1.885.52 3.7 3.7 0 0 0-1.326 1.39q-.477.868-.477 1.968 0 1.123.477 2.003a3.8 3.8 0 0 0 1.326 1.39 3.56 3.56 0 0 0 1.885.509M196.1 20.695h-2.026l-.082-1.864q-.64 1.018-1.676 1.563-1.025.532-2.433.532-2.28 0-3.607-1.378-1.316-1.39-1.316-3.797V9.116h2.387v6.287q0 1.54.837 2.455.84.915 2.258.915 1.468 0 2.364-.973.907-.984.907-2.582V9.116h2.387zM209.84 20.695h-2.106l-.129-1.656a5.7 5.7 0 0 1-1.908 1.39q-1.105.497-2.433.497-1.676 0-3.002-.787a5.7 5.7 0 0 1-2.096-2.154q-.756-1.365-.756-3.08 0-1.724.756-3.08a5.7 5.7 0 0 1 2.096-2.153q1.326-.787 3.002-.787 1.257 0 2.329.451a5.5 5.5 0 0 1 1.862 1.262V3.327h2.385zm-6.18-1.9q1.059 0 1.908-.486a3.74 3.74 0 0 0 1.374-1.32q.512-.833.513-1.898v-.394q0-1.065-.513-1.899a3.65 3.65 0 0 0-1.374-1.308q-.849-.475-1.908-.475-1.082 0-1.943.51a3.7 3.7 0 0 0-1.363 1.389q-.5.869-.499 1.98 0 1.111.499 1.991a3.8 3.8 0 0 0 1.363 1.401q.86.51 1.943.51"/>
  </g>
</svg>", width: 210, height: 24 }, z: 100, silent: !0 }, l = {
|
|
2
2
|
color: M,
|
|
3
3
|
backgroundColor: L,
|
|
4
4
|
textStyle: N,
|
|
5
5
|
title: j,
|
|
6
|
-
line:
|
|
7
|
-
bar:
|
|
6
|
+
line: D,
|
|
7
|
+
bar: A,
|
|
8
8
|
categoryAxis: g,
|
|
9
|
-
valueAxis:
|
|
10
|
-
logAxis:
|
|
11
|
-
timeAxis:
|
|
9
|
+
valueAxis: t,
|
|
10
|
+
logAxis: u,
|
|
11
|
+
timeAxis: I,
|
|
12
12
|
legend: y,
|
|
13
13
|
grid: T,
|
|
14
|
-
dataZoom:
|
|
15
|
-
sankey:
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
14
|
+
dataZoom: i,
|
|
15
|
+
sankey: S,
|
|
16
|
+
map: z,
|
|
17
|
+
geo: e,
|
|
18
|
+
markPoint: o,
|
|
19
|
+
tooltip: x,
|
|
20
|
+
graphic: C
|
|
19
21
|
};
|
|
20
22
|
export {
|
|
21
23
|
L as backgroundColor,
|
|
22
|
-
|
|
24
|
+
A as bar,
|
|
23
25
|
g as categoryAxis,
|
|
24
26
|
M as color,
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
e as
|
|
27
|
+
i as dataZoom,
|
|
28
|
+
l as default,
|
|
29
|
+
e as geo,
|
|
30
|
+
C as graphic,
|
|
28
31
|
T as grid,
|
|
29
32
|
y as legend,
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
z as
|
|
33
|
-
|
|
33
|
+
D as line,
|
|
34
|
+
u as logAxis,
|
|
35
|
+
z as map,
|
|
36
|
+
o as markPoint,
|
|
37
|
+
S as sankey,
|
|
34
38
|
N as textStyle,
|
|
35
|
-
|
|
39
|
+
I as timeAxis,
|
|
36
40
|
j as title,
|
|
37
|
-
|
|
38
|
-
|
|
41
|
+
x as tooltip,
|
|
42
|
+
t as valueAxis
|
|
39
43
|
};
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { MapName } from './register-map';
|
|
2
|
+
type Projection = {
|
|
3
|
+
project(point: number[]): number[];
|
|
4
|
+
unproject(point: number[]): number[];
|
|
5
|
+
};
|
|
6
|
+
/**
|
|
7
|
+
* Creates a Natural Earth I projection centered on the given longitude.
|
|
8
|
+
* Polynomial coefficients from Savric et al. (2011).
|
|
9
|
+
*/
|
|
10
|
+
export declare function createNaturalEarthProjection(centerLon?: number): Projection;
|
|
11
|
+
type LambertParams = {
|
|
12
|
+
centerLon: number;
|
|
13
|
+
centerLat: number;
|
|
14
|
+
standardParallel1: number;
|
|
15
|
+
standardParallel2: number;
|
|
16
|
+
};
|
|
17
|
+
/**
|
|
18
|
+
* Creates a Lambert Conformal Conic projection.
|
|
19
|
+
* Conformal — preserves local shapes. Well suited for mid-latitude regions.
|
|
20
|
+
*/
|
|
21
|
+
export declare function createLambertProjection({ centerLon, centerLat, standardParallel1, standardParallel2, }: LambertParams): Projection;
|
|
22
|
+
/**
|
|
23
|
+
* Creates the appropriate projection for a named map.
|
|
24
|
+
* World maps use Natural Earth I; regional maps use Lambert Conformal Conic.
|
|
25
|
+
*/
|
|
26
|
+
export declare function createMapProjection(mapName: MapName): Projection;
|
|
27
|
+
/** Default Natural Earth I projection centered at longitude 0 (for world maps). */
|
|
28
|
+
export declare const naturalEarthProjection: Projection;
|
|
29
|
+
export {};
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { MAP_CENTERS as w } from "./map-centers.js";
|
|
2
|
+
const n = Math.PI / 180, b = 180 / Math.PI;
|
|
3
|
+
function f(l = 0) {
|
|
4
|
+
const M = l * n;
|
|
5
|
+
return {
|
|
6
|
+
project(e) {
|
|
7
|
+
const u = (e[0] ?? 0) * n - M, o = (e[1] ?? 0) * n, a = o * o, t = a * a;
|
|
8
|
+
return [
|
|
9
|
+
u * (0.8707 - 0.131979 * a + t * (-0.013791 + t * (3971e-6 * a - 1529e-6 * t))),
|
|
10
|
+
-(o * (1.007226 + a * (0.015085 + t * (-0.044475 + 0.028874 * a - 5916e-6 * t))))
|
|
11
|
+
];
|
|
12
|
+
},
|
|
13
|
+
unproject(e) {
|
|
14
|
+
const u = e[0] ?? 0, o = -(e[1] ?? 0);
|
|
15
|
+
let a = o;
|
|
16
|
+
for (let i = 25; i > 0; i--) {
|
|
17
|
+
const s = a * a, r = s * s, h = (a * (1.007226 + s * (0.015085 + r * (-0.044475 + 0.028874 * s - 5916e-6 * r))) - o) / (1.007226 + s * (3 * 0.015085 + r * (7 * -0.044475 + 9 * 0.028874 * s - 11 * 5916e-6 * r)));
|
|
18
|
+
if (a -= h, Math.abs(h) < 1e-12) break;
|
|
19
|
+
}
|
|
20
|
+
const t = a * a, d = t * t;
|
|
21
|
+
return [(u / (0.8707 + t * (-0.131979 + d * (-0.013791 + d * (3971e-6 * t - 1529e-6 * d)))) + M) * b, a * b];
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
function m({
|
|
26
|
+
centerLon: l,
|
|
27
|
+
centerLat: M,
|
|
28
|
+
standardParallel1: e,
|
|
29
|
+
standardParallel2: u
|
|
30
|
+
}) {
|
|
31
|
+
const o = l * n, a = M * n, t = e * n, d = u * n, c = Math.abs(t - d) < 1e-10 ? Math.sin(t) : Math.log(Math.cos(t) / Math.cos(d)) / Math.log(Math.tan(Math.PI / 4 + d / 2) / Math.tan(Math.PI / 4 + t / 2)), i = Math.cos(t) * Math.pow(Math.tan(Math.PI / 4 + t / 2), c) / c, s = i / Math.pow(Math.tan(Math.PI / 4 + a / 2), c);
|
|
32
|
+
return {
|
|
33
|
+
project(r) {
|
|
34
|
+
const h = (r[0] ?? 0) * n, P = Math.max(-89.5 * n, Math.min(89.5 * n, (r[1] ?? 0) * n)), p = i / Math.pow(Math.tan(Math.PI / 4 + P / 2), c), L = c * (h - o);
|
|
35
|
+
return [p * Math.sin(L), -(s - p * Math.cos(L))];
|
|
36
|
+
},
|
|
37
|
+
unproject(r) {
|
|
38
|
+
const h = r[0] ?? 0, P = s + (r[1] ?? 0), p = Math.sign(c) * Math.sqrt(h * h + P * P), L = Math.atan2(h, Math.abs(P)) * Math.sign(P), j = 2 * Math.atan(Math.pow(i / p, 1 / c)) - Math.PI / 2;
|
|
39
|
+
return [(L / c + o) * b, j * b];
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
const I = {
|
|
44
|
+
"us-states": { centerLon: -96, centerLat: 37, standardParallel1: 33, standardParallel2: 45 },
|
|
45
|
+
"europe-countries": { centerLon: 15, centerLat: 52, standardParallel1: 43, standardParallel2: 62 },
|
|
46
|
+
"americas-countries": { centerLon: -80, centerLat: 10, standardParallel1: -20, standardParallel2: 40 },
|
|
47
|
+
"asia-countries": { centerLon: 90, centerLat: 35, standardParallel1: 20, standardParallel2: 50 },
|
|
48
|
+
"africa-countries": { centerLon: 20, centerLat: 0, standardParallel1: -10, standardParallel2: 20 }
|
|
49
|
+
}, A = /* @__PURE__ */ new Set(["world-countries", "world-continents", "world-regions"]);
|
|
50
|
+
function R(l) {
|
|
51
|
+
if (A.has(l)) {
|
|
52
|
+
const e = w[l] ?? [0, 0];
|
|
53
|
+
return f(e[0]);
|
|
54
|
+
}
|
|
55
|
+
const M = I[l];
|
|
56
|
+
return m(M || { centerLon: 0, centerLat: 0, standardParallel1: -15, standardParallel2: 15 });
|
|
57
|
+
}
|
|
58
|
+
const g = f();
|
|
59
|
+
export {
|
|
60
|
+
m as createLambertProjection,
|
|
61
|
+
R as createMapProjection,
|
|
62
|
+
f as createNaturalEarthProjection,
|
|
63
|
+
g as naturalEarthProjection
|
|
64
|
+
};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { registerMap } from 'echarts';
|
|
2
|
+
type EChartsModule = {
|
|
3
|
+
registerMap: typeof registerMap;
|
|
4
|
+
};
|
|
5
|
+
/** All available map names. This is the single source of truth for map registration. */
|
|
6
|
+
export declare const MAP_NAMES: readonly ["world-countries", "world-continents", "world-regions", "us-states", "europe-countries", "americas-countries", "asia-countries", "africa-countries"];
|
|
7
|
+
export type MapName = (typeof MAP_NAMES)[number];
|
|
8
|
+
export declare function isMapName(value: string): value is MapName;
|
|
9
|
+
/**
|
|
10
|
+
* Extracts the map name required by chart options, if any.
|
|
11
|
+
* Looks at `series[].map` and `geo[].map` properties.
|
|
12
|
+
*/
|
|
13
|
+
export declare function getRequiredMapName(option: unknown): string | undefined;
|
|
14
|
+
/**
|
|
15
|
+
* Registers a named map GeoJSON with ECharts (async, for client-side use).
|
|
16
|
+
* Uses dynamic import so each map's GeoJSON is code-split into its own chunk.
|
|
17
|
+
*/
|
|
18
|
+
export declare function registerMapAsync(echarts: EChartsModule, mapName: string): Promise<void>;
|
|
19
|
+
/**
|
|
20
|
+
* Registers a named map GeoJSON with ECharts (sync, for server-side use).
|
|
21
|
+
* Accepts pre-loaded GeoJSON to avoid async in synchronous render paths.
|
|
22
|
+
*/
|
|
23
|
+
export declare function registerMapSync(echarts: EChartsModule, mapName: string, geoJSON: unknown): void;
|
|
24
|
+
export {};
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
const s = /* @__PURE__ */ new Set(), a = [
|
|
2
|
+
"world-countries",
|
|
3
|
+
"world-continents",
|
|
4
|
+
"world-regions",
|
|
5
|
+
"us-states",
|
|
6
|
+
"europe-countries",
|
|
7
|
+
"americas-countries",
|
|
8
|
+
"asia-countries",
|
|
9
|
+
"africa-countries"
|
|
10
|
+
], u = new Set(a);
|
|
11
|
+
function f(t) {
|
|
12
|
+
return u.has(t);
|
|
13
|
+
}
|
|
14
|
+
const p = {
|
|
15
|
+
"world-countries": () => import("./geo/world-countries.json.js").then((t) => t.default),
|
|
16
|
+
"world-continents": () => import("./geo/world-continents.json.js").then((t) => t.default),
|
|
17
|
+
"world-regions": () => import("./geo/world-regions.json.js").then((t) => t.default),
|
|
18
|
+
"us-states": () => import("./geo/us-states.json.js").then((t) => t.default),
|
|
19
|
+
"europe-countries": () => import("./geo/europe-countries.json.js").then((t) => t.default),
|
|
20
|
+
"americas-countries": () => import("./geo/americas-countries.json.js").then((t) => t.default),
|
|
21
|
+
"asia-countries": () => import("./geo/asia-countries.json.js").then((t) => t.default),
|
|
22
|
+
"africa-countries": () => import("./geo/africa-countries.json.js").then((t) => t.default)
|
|
23
|
+
};
|
|
24
|
+
function d(t) {
|
|
25
|
+
if (!t || typeof t != "object") return;
|
|
26
|
+
const e = t;
|
|
27
|
+
if (e.geo) {
|
|
28
|
+
const o = Array.isArray(e.geo) ? e.geo : [e.geo];
|
|
29
|
+
for (const n of o)
|
|
30
|
+
if (n && typeof n == "object") {
|
|
31
|
+
const i = n.map;
|
|
32
|
+
if (typeof i == "string") return i;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
const r = e.series;
|
|
36
|
+
if (!r) return;
|
|
37
|
+
const c = Array.isArray(r) ? r : [r];
|
|
38
|
+
for (const o of c)
|
|
39
|
+
if (o && typeof o == "object" && o.type === "map") {
|
|
40
|
+
const n = o.map;
|
|
41
|
+
if (typeof n == "string") return n;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
async function g(t, e) {
|
|
45
|
+
if (s.has(e)) return;
|
|
46
|
+
if (!f(e)) {
|
|
47
|
+
console.warn(`Unknown map name: "${e}". Available maps: ${a.join(", ")}`);
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
const r = await p[e]();
|
|
51
|
+
t.registerMap(e, r), s.add(e);
|
|
52
|
+
}
|
|
53
|
+
function l(t, e, r) {
|
|
54
|
+
s.has(e) || (t.registerMap(e, r), s.add(e));
|
|
55
|
+
}
|
|
56
|
+
export {
|
|
57
|
+
a as MAP_NAMES,
|
|
58
|
+
d as getRequiredMapName,
|
|
59
|
+
f as isMapName,
|
|
60
|
+
g as registerMapAsync,
|
|
61
|
+
l as registerMapSync
|
|
62
|
+
};
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { EChartsOption } from 'echarts';
|
|
2
2
|
/**
|
|
3
|
-
* Removes problematic interactive components from chart options
|
|
4
|
-
*
|
|
3
|
+
* Removes problematic interactive components from chart options
|
|
4
|
+
* and applies sensible defaults for map charts.
|
|
5
5
|
*/
|
|
6
6
|
export declare function sanitizeChartOptions(option: EChartsOption): EChartsOption;
|
|
@@ -1,9 +1,32 @@
|
|
|
1
|
-
const
|
|
2
|
-
function
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
const i = /* @__PURE__ */ new Set(["axisPointer"]);
|
|
2
|
+
function o(t) {
|
|
3
|
+
const e = t.series;
|
|
4
|
+
return e ? (Array.isArray(e) ? e : [e]).some((n) => typeof n == "object" && "type" in n && n.type === "map") : !1;
|
|
5
|
+
}
|
|
6
|
+
function a(t) {
|
|
7
|
+
const e = t.name ?? "", r = t.value;
|
|
8
|
+
if (r == null || typeof r == "number" && isNaN(r))
|
|
9
|
+
return e;
|
|
10
|
+
const n = typeof r == "number" ? r.toLocaleString(void 0, { maximumFractionDigits: 2 }) : r;
|
|
11
|
+
return `${e}: ${n}`;
|
|
12
|
+
}
|
|
13
|
+
function s(t) {
|
|
14
|
+
if (!o(t)) return t;
|
|
15
|
+
const e = t.tooltip ?? {};
|
|
16
|
+
return e.formatter ? t : {
|
|
17
|
+
...t,
|
|
18
|
+
tooltip: {
|
|
19
|
+
...e,
|
|
20
|
+
formatter: a
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
function f(t) {
|
|
25
|
+
const e = Object.fromEntries(
|
|
26
|
+
Object.entries(t).filter(([r]) => !i.has(r))
|
|
5
27
|
);
|
|
28
|
+
return s(e);
|
|
6
29
|
}
|
|
7
30
|
export {
|
|
8
|
-
|
|
31
|
+
f as sanitizeChartOptions
|
|
9
32
|
};
|
|
@@ -1,56 +1,58 @@
|
|
|
1
1
|
"use client";
|
|
2
|
-
import { useRef as
|
|
2
|
+
import { useRef as f, useState as T, useEffect as I, useCallback as S } from "react";
|
|
3
3
|
import { calculateTitleLayout as m } from "./calculate-title-layout.js";
|
|
4
4
|
import { replaceFormatterTokens as O } from "./formatters/replace-formatter-tokens.js";
|
|
5
5
|
import { mergeThemeGraphicIntoOptions as R } from "./merge-theme-graphic-into-options.js";
|
|
6
|
+
import { getRequiredMapName as j, registerMapAsync as x } from "./register-map.js";
|
|
6
7
|
import { sanitizeChartOptions as w } from "./sanitize-chart-options.js";
|
|
7
8
|
const W = /* @__PURE__ */ new Set();
|
|
8
|
-
function
|
|
9
|
-
const
|
|
10
|
-
y.current =
|
|
11
|
-
const s =
|
|
9
|
+
function B({ options: i, theme: t }) {
|
|
10
|
+
const e = f(null), o = f(null), y = f(i), C = f(t?.config), z = f(t?.config.graphic), [b, v] = T(!1);
|
|
11
|
+
y.current = i, C.current = t?.config, z.current = t?.config.graphic, I(() => {
|
|
12
|
+
const s = e.current;
|
|
12
13
|
if (!s) return;
|
|
13
|
-
let r = !0,
|
|
14
|
-
const
|
|
15
|
-
const
|
|
16
|
-
if (!
|
|
17
|
-
const p =
|
|
18
|
-
|
|
14
|
+
let r = !0, n;
|
|
15
|
+
const d = new ResizeObserver((c) => {
|
|
16
|
+
const u = c[0], a = o.current;
|
|
17
|
+
if (!u || !a) return;
|
|
18
|
+
const p = u.contentRect.width, g = w(y.current), l = O(g), h = m(l, p, C.current);
|
|
19
|
+
a.setOption(R(h, z.current), {
|
|
19
20
|
replaceMerge: ["graphic"]
|
|
20
|
-
}),
|
|
21
|
+
}), a.resize();
|
|
21
22
|
});
|
|
22
|
-
return
|
|
23
|
+
return d.observe(s), (async () => {
|
|
23
24
|
try {
|
|
24
|
-
const
|
|
25
|
-
if (!r || !
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
25
|
+
const c = await import("echarts");
|
|
26
|
+
if (!r || !e.current) return;
|
|
27
|
+
const u = j(i);
|
|
28
|
+
if (u && await x(c, u), t && !W.has(t.name)) {
|
|
29
|
+
const { graphic: F, ...M } = t.config;
|
|
30
|
+
c.registerTheme(t.name, M), W.add(t.name);
|
|
29
31
|
}
|
|
30
|
-
const a =
|
|
31
|
-
a && a.dispose(),
|
|
32
|
+
const a = c.getInstanceByDom(e.current);
|
|
33
|
+
a && a.dispose(), n = c.init(e.current, t?.name, {
|
|
32
34
|
renderer: "svg"
|
|
33
|
-
}),
|
|
34
|
-
const
|
|
35
|
-
|
|
35
|
+
}), o.current = n;
|
|
36
|
+
const p = e.current.clientWidth, g = w(i), l = O(g), h = m(l, p, t?.config);
|
|
37
|
+
n.setOption(R(h, t?.config.graphic), {
|
|
36
38
|
replaceMerge: ["graphic"]
|
|
37
|
-
}),
|
|
38
|
-
} catch (
|
|
39
|
-
console.error("Failed to load echarts",
|
|
39
|
+
}), n.resize(), v(!0);
|
|
40
|
+
} catch (c) {
|
|
41
|
+
console.error("Failed to load echarts", c);
|
|
40
42
|
}
|
|
41
43
|
})(), () => {
|
|
42
|
-
r = !1,
|
|
44
|
+
r = !1, d.disconnect(), n && n.dispose(), o.current = null, v(!1);
|
|
43
45
|
};
|
|
44
|
-
}, [t,
|
|
45
|
-
if (!b || !
|
|
46
|
-
const s =
|
|
47
|
-
|
|
46
|
+
}, [t, i]), I(() => {
|
|
47
|
+
if (!b || !o.current || !e.current) return;
|
|
48
|
+
const s = e.current.clientWidth, r = w(i), n = O(r), d = m(n, s, t?.config);
|
|
49
|
+
o.current.setOption(R(d, t?.config.graphic), {
|
|
48
50
|
replaceMerge: ["graphic"]
|
|
49
51
|
});
|
|
50
|
-
}, [b,
|
|
52
|
+
}, [b, i, t?.config, t?.config.graphic]);
|
|
51
53
|
const k = S(async () => {
|
|
52
|
-
if (!
|
|
53
|
-
const s =
|
|
54
|
+
if (!o.current) return;
|
|
55
|
+
const s = o.current.getDataURL({
|
|
54
56
|
type: "png",
|
|
55
57
|
pixelRatio: 2,
|
|
56
58
|
backgroundColor: "#fff"
|
|
@@ -58,10 +60,10 @@ function L({ options: o, theme: t }) {
|
|
|
58
60
|
r.download = `chart-${(/* @__PURE__ */ new Date()).toISOString()}.png`, r.href = s, document.body.appendChild(r), r.click(), document.body.removeChild(r);
|
|
59
61
|
}, []);
|
|
60
62
|
return {
|
|
61
|
-
containerRef:
|
|
63
|
+
containerRef: e,
|
|
62
64
|
downloadChart: k
|
|
63
65
|
};
|
|
64
66
|
}
|
|
65
67
|
export {
|
|
66
|
-
|
|
68
|
+
B as useChartInstance
|
|
67
69
|
};
|
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
type UseScrollToBottomOptions = {
|
|
2
2
|
readonly threshold?: number;
|
|
3
3
|
};
|
|
4
|
-
|
|
5
|
-
containerRef:
|
|
6
|
-
endRef:
|
|
4
|
+
type UseScrollToBottomReturn = {
|
|
5
|
+
containerRef: React.RefObject<HTMLDivElement | null>;
|
|
6
|
+
endRef: React.RefObject<HTMLDivElement | null>;
|
|
7
7
|
isAtBottom: boolean;
|
|
8
8
|
scrollToBottom: (behavior?: ScrollBehavior) => void;
|
|
9
9
|
onViewportEnter: () => void;
|
|
10
10
|
onViewportLeave: () => void;
|
|
11
11
|
};
|
|
12
|
+
export declare function useScrollToBottom({ threshold }?: UseScrollToBottomOptions): UseScrollToBottomReturn;
|
|
12
13
|
export {};
|
|
@@ -1,33 +1,51 @@
|
|
|
1
|
-
import * as
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import
|
|
5
|
-
import
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
9
|
-
import
|
|
10
|
-
import
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
1
|
+
import * as d from "echarts";
|
|
2
|
+
import { writeFileSync as w, mkdtempSync as N } from "node:fs";
|
|
3
|
+
import { tmpdir as T } from "node:os";
|
|
4
|
+
import y from "node:path";
|
|
5
|
+
import { Image as C, Canvas as S, FontLibrary as G } from "skia-canvas";
|
|
6
|
+
import { calculateTitleLayout as F } from "../components/echarts-renderer/calculate-title-layout.js";
|
|
7
|
+
import { isChartTheme as b } from "../components/echarts-renderer/chart-theme.js";
|
|
8
|
+
import { replaceFormatterTokens as J } from "../components/echarts-renderer/formatters/replace-formatter-tokens.js";
|
|
9
|
+
import A from "../components/echarts-renderer/geo/africa-countries.json.js";
|
|
10
|
+
import I from "../components/echarts-renderer/geo/americas-countries.json.js";
|
|
11
|
+
import j from "../components/echarts-renderer/geo/asia-countries.json.js";
|
|
12
|
+
import E from "../components/echarts-renderer/geo/europe-countries.json.js";
|
|
13
|
+
import M from "../components/echarts-renderer/geo/us-states.json.js";
|
|
14
|
+
import R from "../components/echarts-renderer/geo/world-continents.json.js";
|
|
15
|
+
import P from "../components/echarts-renderer/geo/world-countries.json.js";
|
|
16
|
+
import k from "../components/echarts-renderer/geo/world-regions.json.js";
|
|
17
|
+
import { mergeThemeGraphicIntoOptions as v } from "../components/echarts-renderer/merge-theme-graphic-into-options.js";
|
|
18
|
+
import { getRequiredMapName as x, isMapName as D, registerMapSync as _ } from "../components/echarts-renderer/register-map.js";
|
|
19
|
+
const $ = {
|
|
20
|
+
"world-countries": P,
|
|
21
|
+
"world-continents": R,
|
|
22
|
+
"world-regions": k,
|
|
23
|
+
"us-states": M,
|
|
24
|
+
"europe-countries": E,
|
|
25
|
+
"americas-countries": I,
|
|
26
|
+
"asia-countries": j,
|
|
27
|
+
"africa-countries": A
|
|
28
|
+
};
|
|
29
|
+
globalThis.Image = C;
|
|
30
|
+
const g = /* @__PURE__ */ new Set();
|
|
31
|
+
let f;
|
|
32
|
+
function z() {
|
|
33
|
+
return f || (f = N(y.join(T(), "chart-fonts-"))), f;
|
|
16
34
|
}
|
|
17
|
-
function
|
|
35
|
+
function L(r) {
|
|
18
36
|
for (const t of r)
|
|
19
|
-
if (!
|
|
37
|
+
if (!g.has(t.family))
|
|
20
38
|
try {
|
|
21
|
-
const e =
|
|
22
|
-
const
|
|
23
|
-
return
|
|
39
|
+
const e = z(), o = t.data.map((a, m) => {
|
|
40
|
+
const n = y.join(e, `${t.family}-${String(m)}.ttf`);
|
|
41
|
+
return w(n, a), n;
|
|
24
42
|
});
|
|
25
|
-
|
|
43
|
+
G.use(t.family, o), g.add(t.family);
|
|
26
44
|
} catch (e) {
|
|
27
45
|
console.warn(`Failed to register ${t.family} fonts, charts will use fallback font:`, e);
|
|
28
46
|
}
|
|
29
47
|
}
|
|
30
|
-
const
|
|
48
|
+
const V = /* @__PURE__ */ new Set([
|
|
31
49
|
"aria",
|
|
32
50
|
// Tries to set DOM attributes which node-canvas doesn't implement
|
|
33
51
|
"toolbox",
|
|
@@ -39,41 +57,52 @@ const P = /* @__PURE__ */ new Set([
|
|
|
39
57
|
"axisPointer"
|
|
40
58
|
// Crosshair on hover
|
|
41
59
|
]);
|
|
42
|
-
function
|
|
60
|
+
function q(r) {
|
|
43
61
|
if (!r || typeof r != "object" || Array.isArray(r))
|
|
44
62
|
return { animation: !1 };
|
|
45
63
|
const t = Object.fromEntries(
|
|
46
|
-
Object.entries(r).filter(([e]) => !
|
|
64
|
+
Object.entries(r).filter(([e]) => !V.has(e))
|
|
47
65
|
);
|
|
48
66
|
return t.animation = !1, t;
|
|
49
67
|
}
|
|
50
|
-
function
|
|
68
|
+
function B(r) {
|
|
69
|
+
const t = new S(r.width, r.height);
|
|
70
|
+
return t.getContext("2d").drawImage(r, 0, 0), t;
|
|
71
|
+
}
|
|
72
|
+
function U({
|
|
51
73
|
option: r,
|
|
52
74
|
theme: t,
|
|
53
75
|
fonts: e,
|
|
54
|
-
width:
|
|
55
|
-
height:
|
|
56
|
-
devicePixelRatio:
|
|
76
|
+
width: o = 800,
|
|
77
|
+
height: a = 600,
|
|
78
|
+
devicePixelRatio: m = 2
|
|
57
79
|
}) {
|
|
58
|
-
e?.length &&
|
|
59
|
-
let
|
|
80
|
+
e?.length && L(e);
|
|
81
|
+
let n, s, p;
|
|
60
82
|
if (t) {
|
|
61
|
-
|
|
62
|
-
const { graphic:
|
|
63
|
-
|
|
83
|
+
s = b(t) ? t.config : t, p = s.graphic;
|
|
84
|
+
const { graphic: h, ...c } = s;
|
|
85
|
+
n = c;
|
|
64
86
|
}
|
|
65
|
-
const
|
|
87
|
+
const i = x(r);
|
|
88
|
+
i && (D(i) ? _(d, i, $[i]) : console.warn(`Unknown map name for server-side rendering: "${i}"`));
|
|
89
|
+
const l = new S(o, a), u = d.init(l, n, {
|
|
66
90
|
renderer: "canvas",
|
|
67
|
-
devicePixelRatio:
|
|
68
|
-
width:
|
|
69
|
-
height:
|
|
70
|
-
})
|
|
71
|
-
|
|
91
|
+
devicePixelRatio: m,
|
|
92
|
+
width: o,
|
|
93
|
+
height: a
|
|
94
|
+
});
|
|
95
|
+
try {
|
|
96
|
+
const h = q(r), c = J(h), O = F(c, o, s);
|
|
97
|
+
return u.setOption(v(O, p), { replaceMerge: ["graphic"] }), B(l);
|
|
98
|
+
} finally {
|
|
99
|
+
u.dispose();
|
|
100
|
+
}
|
|
72
101
|
}
|
|
73
|
-
function
|
|
74
|
-
return
|
|
102
|
+
function ft(r) {
|
|
103
|
+
return U(r).toBufferSync("png");
|
|
75
104
|
}
|
|
76
105
|
export {
|
|
77
|
-
|
|
78
|
-
|
|
106
|
+
U as renderChartToCanvas,
|
|
107
|
+
ft as renderChartToImage
|
|
79
108
|
};
|