@panoboard/core 1.3.0 → 1.9.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/annotations/executor.d.ts +32 -0
- package/dist/annotations/executor.d.ts.map +1 -0
- package/dist/annotations/executor.js +74 -0
- package/dist/annotations/executor.js.map +1 -0
- package/dist/annotations/index.d.ts +2 -0
- package/dist/annotations/index.d.ts.map +1 -0
- package/dist/annotations/index.js +15 -0
- package/dist/annotations/index.js.map +1 -0
- package/dist/cache/keys.d.ts.map +1 -1
- package/dist/cache/keys.js +4 -4
- package/dist/cache/keys.js.map +1 -1
- package/dist/components/ConfigErrorBanner.d.ts.map +1 -1
- package/dist/components/ConfigErrorBanner.js +38 -10
- package/dist/components/ConfigErrorBanner.js.map +1 -1
- package/dist/components/CrosshairContext.d.ts +13 -0
- package/dist/components/CrosshairContext.d.ts.map +1 -0
- package/dist/components/CrosshairContext.js +37 -0
- package/dist/components/CrosshairContext.js.map +1 -0
- package/dist/components/DashboardCard.d.ts +3 -1
- package/dist/components/DashboardCard.d.ts.map +1 -1
- package/dist/components/DashboardCard.js +65 -12
- package/dist/components/DashboardCard.js.map +1 -1
- package/dist/components/DashboardDescription.d.ts +19 -0
- package/dist/components/DashboardDescription.d.ts.map +1 -0
- package/dist/components/DashboardDescription.js +61 -0
- package/dist/components/DashboardDescription.js.map +1 -0
- package/dist/components/DashboardLinks.d.ts +8 -0
- package/dist/components/DashboardLinks.d.ts.map +1 -0
- package/dist/components/DashboardLinks.js +53 -0
- package/dist/components/DashboardLinks.js.map +1 -0
- package/dist/components/DashboardShell.d.ts +5 -1
- package/dist/components/DashboardShell.d.ts.map +1 -1
- package/dist/components/DashboardShell.js +42 -25
- package/dist/components/DashboardShell.js.map +1 -1
- package/dist/components/EmptyState.d.ts.map +1 -1
- package/dist/components/EmptyState.js +7 -1
- package/dist/components/EmptyState.js.map +1 -1
- package/dist/components/ErrorPage.d.ts.map +1 -1
- package/dist/components/ErrorPage.js +22 -33
- package/dist/components/ErrorPage.js.map +1 -1
- package/dist/components/FilterBar.d.ts.map +1 -1
- package/dist/components/FilterBar.js +21 -5
- package/dist/components/FilterBar.js.map +1 -1
- package/dist/components/NotificationCenter.d.ts +6 -0
- package/dist/components/NotificationCenter.d.ts.map +1 -0
- package/dist/components/NotificationCenter.js +83 -0
- package/dist/components/NotificationCenter.js.map +1 -0
- package/dist/components/NotificationIndicator.d.ts +6 -0
- package/dist/components/NotificationIndicator.d.ts.map +1 -0
- package/dist/components/NotificationIndicator.js +24 -0
- package/dist/components/NotificationIndicator.js.map +1 -0
- package/dist/components/PanelGrid.js +2 -2
- package/dist/components/PanelGrid.js.map +1 -1
- package/dist/components/PanelWrapper.d.ts +2 -1
- package/dist/components/PanelWrapper.d.ts.map +1 -1
- package/dist/components/PanelWrapper.js +101 -16
- package/dist/components/PanelWrapper.js.map +1 -1
- package/dist/components/RefreshContext.d.ts +3 -0
- package/dist/components/RefreshContext.d.ts.map +1 -0
- package/dist/components/RefreshContext.js +7 -0
- package/dist/components/RefreshContext.js.map +1 -0
- package/dist/components/RefreshControl.d.ts +17 -0
- package/dist/components/RefreshControl.d.ts.map +1 -0
- package/dist/components/RefreshControl.js +72 -0
- package/dist/components/RefreshControl.js.map +1 -0
- package/dist/components/SectionGrid.d.ts +9 -0
- package/dist/components/SectionGrid.d.ts.map +1 -0
- package/dist/components/SectionGrid.js +76 -0
- package/dist/components/SectionGrid.js.map +1 -0
- package/dist/components/SectionHeader.d.ts +8 -0
- package/dist/components/SectionHeader.d.ts.map +1 -0
- package/dist/components/SectionHeader.js +21 -0
- package/dist/components/SectionHeader.js.map +1 -0
- package/dist/components/TagPills.d.ts +7 -0
- package/dist/components/TagPills.d.ts.map +1 -0
- package/dist/components/TagPills.js +41 -0
- package/dist/components/TagPills.js.map +1 -0
- package/dist/components/filters/BooleanFilter.d.ts.map +1 -1
- package/dist/components/filters/BooleanFilter.js +1 -3
- package/dist/components/filters/BooleanFilter.js.map +1 -1
- package/dist/components/filters/CalendarGrid.d.ts.map +1 -1
- package/dist/components/filters/CalendarGrid.js +1 -1
- package/dist/components/filters/CalendarGrid.js.map +1 -1
- package/dist/components/filters/DateRangeFilter.d.ts.map +1 -1
- package/dist/components/filters/DateRangeFilter.js +4 -6
- package/dist/components/filters/DateRangeFilter.js.map +1 -1
- package/dist/components/filters/FilterChips.d.ts.map +1 -1
- package/dist/components/filters/FilterChips.js +71 -10
- package/dist/components/filters/FilterChips.js.map +1 -1
- package/dist/components/filters/IntervalFilter.d.ts +9 -0
- package/dist/components/filters/IntervalFilter.d.ts.map +1 -0
- package/dist/components/filters/IntervalFilter.js +32 -0
- package/dist/components/filters/IntervalFilter.js.map +1 -0
- package/dist/components/filters/MultiSelectFilter.d.ts.map +1 -1
- package/dist/components/filters/MultiSelectFilter.js +1 -3
- package/dist/components/filters/MultiSelectFilter.js.map +1 -1
- package/dist/components/filters/NumberFilter.d.ts.map +1 -1
- package/dist/components/filters/NumberFilter.js +5 -1
- package/dist/components/filters/NumberFilter.js.map +1 -1
- package/dist/components/filters/SelectFilter.d.ts +2 -1
- package/dist/components/filters/SelectFilter.d.ts.map +1 -1
- package/dist/components/filters/SelectFilter.js +9 -10
- package/dist/components/filters/SelectFilter.js.map +1 -1
- package/dist/components/filters/TextFilter.d.ts.map +1 -1
- package/dist/components/filters/TextFilter.js +5 -1
- package/dist/components/filters/TextFilter.js.map +1 -1
- package/dist/components/index.d.ts +11 -1
- package/dist/components/index.d.ts.map +1 -1
- package/dist/components/index.js +14 -1
- package/dist/components/index.js.map +1 -1
- package/dist/components/panels/AnnotationLayer.d.ts +28 -0
- package/dist/components/panels/AnnotationLayer.d.ts.map +1 -0
- package/dist/components/panels/AnnotationLayer.js +102 -0
- package/dist/components/panels/AnnotationLayer.js.map +1 -0
- package/dist/components/panels/AreaChart.d.ts +3 -1
- package/dist/components/panels/AreaChart.d.ts.map +1 -1
- package/dist/components/panels/AreaChart.js +87 -5
- package/dist/components/panels/AreaChart.js.map +1 -1
- package/dist/components/panels/BarChart.d.ts.map +1 -1
- package/dist/components/panels/BarChart.js +61 -7
- package/dist/components/panels/BarChart.js.map +1 -1
- package/dist/components/panels/BulletChart.js +1 -1
- package/dist/components/panels/BulletChart.js.map +1 -1
- package/dist/components/panels/CalendarHeatmap.d.ts.map +1 -1
- package/dist/components/panels/CalendarHeatmap.js +7 -4
- package/dist/components/panels/CalendarHeatmap.js.map +1 -1
- package/dist/components/panels/ChartTooltip.d.ts.map +1 -1
- package/dist/components/panels/ChartTooltip.js +9 -48
- package/dist/components/panels/ChartTooltip.js.map +1 -1
- package/dist/components/panels/DataLinks.d.ts +35 -0
- package/dist/components/panels/DataLinks.d.ts.map +1 -0
- package/dist/components/panels/DataLinks.js +67 -0
- package/dist/components/panels/DataLinks.js.map +1 -0
- package/dist/components/panels/GaugePanel.d.ts +7 -0
- package/dist/components/panels/GaugePanel.d.ts.map +1 -0
- package/dist/components/panels/GaugePanel.js +116 -0
- package/dist/components/panels/GaugePanel.js.map +1 -0
- package/dist/components/panels/HistogramPanel.d.ts +18 -0
- package/dist/components/panels/HistogramPanel.d.ts.map +1 -0
- package/dist/components/panels/HistogramPanel.js +92 -0
- package/dist/components/panels/HistogramPanel.js.map +1 -0
- package/dist/components/panels/LineChart.d.ts +3 -1
- package/dist/components/panels/LineChart.d.ts.map +1 -1
- package/dist/components/panels/LineChart.js +90 -5
- package/dist/components/panels/LineChart.js.map +1 -1
- package/dist/components/panels/ListPanel.d.ts.map +1 -1
- package/dist/components/panels/ListPanel.js +1 -1
- package/dist/components/panels/ListPanel.js.map +1 -1
- package/dist/components/panels/MarkdownPanel.d.ts +15 -1
- package/dist/components/panels/MarkdownPanel.d.ts.map +1 -1
- package/dist/components/panels/MarkdownPanel.js +70 -7
- package/dist/components/panels/MarkdownPanel.js.map +1 -1
- package/dist/components/panels/MetricPanel.d.ts.map +1 -1
- package/dist/components/panels/MetricPanel.js +1 -1
- package/dist/components/panels/MetricPanel.js.map +1 -1
- package/dist/components/panels/PanelEmpty.d.ts.map +1 -1
- package/dist/components/panels/PanelEmpty.js +1 -1
- package/dist/components/panels/PanelEmpty.js.map +1 -1
- package/dist/components/panels/PanelError.d.ts.map +1 -1
- package/dist/components/panels/PanelError.js +4 -1
- package/dist/components/panels/PanelError.js.map +1 -1
- package/dist/components/panels/PanelSkeleton.js +2 -2
- package/dist/components/panels/PanelSkeleton.js.map +1 -1
- package/dist/components/panels/RadialBarChart.js +1 -1
- package/dist/components/panels/RadialBarChart.js.map +1 -1
- package/dist/components/panels/ScatterChart.d.ts +15 -1
- package/dist/components/panels/ScatterChart.d.ts.map +1 -1
- package/dist/components/panels/ScatterChart.js +96 -26
- package/dist/components/panels/ScatterChart.js.map +1 -1
- package/dist/components/panels/Sparkline.d.ts +21 -0
- package/dist/components/panels/Sparkline.d.ts.map +1 -0
- package/dist/components/panels/Sparkline.js +53 -0
- package/dist/components/panels/Sparkline.js.map +1 -0
- package/dist/components/panels/StatPanel.d.ts +3 -1
- package/dist/components/panels/StatPanel.d.ts.map +1 -1
- package/dist/components/panels/StatPanel.js +33 -4
- package/dist/components/panels/StatPanel.js.map +1 -1
- package/dist/components/panels/TablePanel.d.ts +2 -1
- package/dist/components/panels/TablePanel.d.ts.map +1 -1
- package/dist/components/panels/TablePanel.js +96 -6
- package/dist/components/panels/TablePanel.js.map +1 -1
- package/dist/components/panels/VideoPanel.d.ts.map +1 -1
- package/dist/components/panels/VideoPanel.js +1 -1
- package/dist/components/panels/VideoPanel.js.map +1 -1
- package/dist/components/panels/nivo-theme.d.ts +1 -44
- package/dist/components/panels/nivo-theme.d.ts.map +1 -1
- package/dist/components/panels/nivo-theme.js +9 -104
- package/dist/components/panels/nivo-theme.js.map +1 -1
- package/dist/components/panels/semantic-colors.d.ts.map +1 -1
- package/dist/components/panels/semantic-colors.js +2 -39
- package/dist/components/panels/semantic-colors.js.map +1 -1
- package/dist/components/ui/Button.d.ts +1 -1
- package/dist/components/ui/Button.d.ts.map +1 -1
- package/dist/components/ui/Button.js +6 -9
- package/dist/components/ui/Button.js.map +1 -1
- package/dist/components/ui/Tabs.d.ts.map +1 -1
- package/dist/components/ui/Tabs.js +1 -1
- package/dist/components/ui/Tabs.js.map +1 -1
- package/dist/connectors/bigquery.d.ts.map +1 -1
- package/dist/connectors/bigquery.js +6 -1
- package/dist/connectors/bigquery.js.map +1 -1
- package/dist/connectors/postgres.d.ts.map +1 -1
- package/dist/connectors/postgres.js +3 -0
- package/dist/connectors/postgres.js.map +1 -1
- package/dist/connectors/redshift.d.ts.map +1 -1
- package/dist/connectors/redshift.js +3 -0
- package/dist/connectors/redshift.js.map +1 -1
- package/dist/contexts/NotificationContext.d.ts +10 -0
- package/dist/contexts/NotificationContext.d.ts.map +1 -0
- package/dist/contexts/NotificationContext.js +24 -0
- package/dist/contexts/NotificationContext.js.map +1 -0
- package/dist/filters/daterange.d.ts +1 -1
- package/dist/filters/daterange.d.ts.map +1 -1
- package/dist/filters/daterange.js +54 -9
- package/dist/filters/daterange.js.map +1 -1
- package/dist/filters/index.d.ts +2 -0
- package/dist/filters/index.d.ts.map +1 -1
- package/dist/filters/index.js +2 -0
- package/dist/filters/index.js.map +1 -1
- package/dist/filters/interval.d.ts +13 -0
- package/dist/filters/interval.d.ts.map +1 -0
- package/dist/filters/interval.js +40 -0
- package/dist/filters/interval.js.map +1 -0
- package/dist/filters/resolver.d.ts +1 -1
- package/dist/filters/resolver.d.ts.map +1 -1
- package/dist/filters/resolver.js +28 -2
- package/dist/filters/resolver.js.map +1 -1
- package/dist/flattenTabs.d.ts +8 -0
- package/dist/flattenTabs.d.ts.map +1 -0
- package/dist/flattenTabs.js +24 -0
- package/dist/flattenTabs.js.map +1 -0
- package/dist/formats.d.ts +1 -1
- package/dist/formats.d.ts.map +1 -1
- package/dist/formats.js +19 -9
- package/dist/formats.js.map +1 -1
- package/dist/hooks/useNotifications.d.ts +5 -0
- package/dist/hooks/useNotifications.d.ts.map +1 -0
- package/dist/hooks/useNotifications.js +48 -0
- package/dist/hooks/useNotifications.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -1
- package/dist/interpolation.d.ts +10 -0
- package/dist/interpolation.d.ts.map +1 -0
- package/dist/interpolation.js +64 -0
- package/dist/interpolation.js.map +1 -0
- package/dist/panels/conditional.d.ts +12 -0
- package/dist/panels/conditional.d.ts.map +1 -0
- package/dist/panels/conditional.js +90 -0
- package/dist/panels/conditional.js.map +1 -0
- package/dist/panels/index.d.ts +11 -0
- package/dist/panels/index.d.ts.map +1 -0
- package/dist/panels/index.js +19 -0
- package/dist/panels/index.js.map +1 -0
- package/dist/panels/mappings.d.ts +40 -0
- package/dist/panels/mappings.d.ts.map +1 -0
- package/dist/panels/mappings.js +83 -0
- package/dist/panels/mappings.js.map +1 -0
- package/dist/panels/overrides.d.ts +37 -0
- package/dist/panels/overrides.d.ts.map +1 -0
- package/dist/panels/overrides.js +57 -0
- package/dist/panels/overrides.js.map +1 -0
- package/dist/panels/threshold-layers.d.ts +18 -0
- package/dist/panels/threshold-layers.d.ts.map +1 -0
- package/dist/panels/threshold-layers.js +35 -0
- package/dist/panels/threshold-layers.js.map +1 -0
- package/dist/panels/thresholds.d.ts +36 -0
- package/dist/panels/thresholds.d.ts.map +1 -0
- package/dist/panels/thresholds.js +81 -0
- package/dist/panels/thresholds.js.map +1 -0
- package/dist/schemas/annotations.d.ts +34 -0
- package/dist/schemas/annotations.d.ts.map +1 -0
- package/dist/schemas/annotations.js +19 -0
- package/dist/schemas/annotations.js.map +1 -0
- package/dist/schemas/config.d.ts +1 -0
- package/dist/schemas/config.d.ts.map +1 -1
- package/dist/schemas/config.js +1 -0
- package/dist/schemas/config.js.map +1 -1
- package/dist/schemas/dashboard.d.ts +5861 -235
- package/dist/schemas/dashboard.d.ts.map +1 -1
- package/dist/schemas/dashboard.js +173 -10
- package/dist/schemas/dashboard.js.map +1 -1
- package/dist/schemas/index.d.ts +6 -1
- package/dist/schemas/index.d.ts.map +1 -1
- package/dist/schemas/index.js +6 -1
- package/dist/schemas/index.js.map +1 -1
- package/dist/schemas/mappings.d.ts +46 -0
- package/dist/schemas/mappings.d.ts.map +1 -0
- package/dist/schemas/mappings.js +46 -0
- package/dist/schemas/mappings.js.map +1 -0
- package/dist/schemas/overrides.d.ts +77 -0
- package/dist/schemas/overrides.d.ts.map +1 -0
- package/dist/schemas/overrides.js +38 -0
- package/dist/schemas/overrides.js.map +1 -0
- package/dist/schemas/theme.d.ts +89 -7
- package/dist/schemas/theme.d.ts.map +1 -1
- package/dist/schemas/theme.js +40 -24
- package/dist/schemas/theme.js.map +1 -1
- package/dist/schemas/thresholds.d.ts +19 -0
- package/dist/schemas/thresholds.d.ts.map +1 -0
- package/dist/schemas/thresholds.js +31 -0
- package/dist/schemas/thresholds.js.map +1 -0
- package/dist/schemas/transforms.d.ts +54 -0
- package/dist/schemas/transforms.d.ts.map +1 -0
- package/dist/schemas/transforms.js +51 -0
- package/dist/schemas/transforms.js.map +1 -0
- package/dist/startup/sql-lint.d.ts.map +1 -1
- package/dist/startup/sql-lint.js +3 -2
- package/dist/startup/sql-lint.js.map +1 -1
- package/dist/theme/builtin.d.ts.map +1 -1
- package/dist/theme/builtin.js +56 -62
- package/dist/theme/builtin.js.map +1 -1
- package/dist/theme/colors.d.ts +11 -0
- package/dist/theme/colors.d.ts.map +1 -0
- package/dist/theme/colors.js +71 -0
- package/dist/theme/colors.js.map +1 -0
- package/dist/theme/context.d.ts.map +1 -1
- package/dist/theme/context.js +16 -3
- package/dist/theme/context.js.map +1 -1
- package/dist/theme/loader-export.d.ts +1 -1
- package/dist/theme/loader-export.d.ts.map +1 -1
- package/dist/theme/loader-export.js +1 -1
- package/dist/theme/loader-export.js.map +1 -1
- package/dist/theme/loader.d.ts +8 -3
- package/dist/theme/loader.d.ts.map +1 -1
- package/dist/theme/loader.js +24 -13
- package/dist/theme/loader.js.map +1 -1
- package/dist/transforms/computed.d.ts +11 -0
- package/dist/transforms/computed.d.ts.map +1 -0
- package/dist/transforms/computed.js +24 -0
- package/dist/transforms/computed.js.map +1 -0
- package/dist/transforms/engine.d.ts +17 -0
- package/dist/transforms/engine.d.ts.map +1 -0
- package/dist/transforms/engine.js +65 -0
- package/dist/transforms/engine.js.map +1 -0
- package/dist/transforms/expression.d.ts +9 -0
- package/dist/transforms/expression.d.ts.map +1 -0
- package/dist/transforms/expression.js +306 -0
- package/dist/transforms/expression.js.map +1 -0
- package/dist/transforms/filter.d.ts +11 -0
- package/dist/transforms/filter.d.ts.map +1 -0
- package/dist/transforms/filter.js +10 -0
- package/dist/transforms/filter.js.map +1 -0
- package/dist/transforms/index.d.ts +10 -0
- package/dist/transforms/index.d.ts.map +1 -0
- package/dist/transforms/index.js +9 -0
- package/dist/transforms/index.js.map +1 -0
- package/dist/transforms/limit.d.ts +11 -0
- package/dist/transforms/limit.d.ts.map +1 -0
- package/dist/transforms/limit.js +4 -0
- package/dist/transforms/limit.js.map +1 -0
- package/dist/transforms/percentage.d.ts +11 -0
- package/dist/transforms/percentage.d.ts.map +1 -0
- package/dist/transforms/percentage.js +25 -0
- package/dist/transforms/percentage.js.map +1 -0
- package/dist/transforms/rename.d.ts +11 -0
- package/dist/transforms/rename.d.ts.map +1 -0
- package/dist/transforms/rename.js +17 -0
- package/dist/transforms/rename.js.map +1 -0
- package/dist/transforms/sort.d.ts +11 -0
- package/dist/transforms/sort.d.ts.map +1 -0
- package/dist/transforms/sort.js +21 -0
- package/dist/transforms/sort.js.map +1 -0
- package/dist/types/config-error.d.ts +1 -1
- package/dist/types/config-error.d.ts.map +1 -1
- package/dist/types/notification.d.ts +19 -0
- package/dist/types/notification.d.ts.map +1 -0
- package/dist/types/notification.js +15 -0
- package/dist/types/notification.js.map +1 -0
- package/package.json +12 -2
|
@@ -12,12 +12,27 @@ import { jsx as _jsx } from "react/jsx-runtime";
|
|
|
12
12
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
13
|
// See the License for the specific language governing permissions and
|
|
14
14
|
// limitations under the License.
|
|
15
|
+
import { useCallback } from "react";
|
|
15
16
|
import { ResponsiveLine } from "@nivo/line";
|
|
16
17
|
import { buildNivoTheme, getChartPalette } from "./nivo-theme";
|
|
17
18
|
import { useTheme } from "../../theme/context";
|
|
18
19
|
import { ChartTooltip } from "./ChartTooltip";
|
|
19
20
|
import { formatValue, formatValueShort } from "../../formats";
|
|
20
21
|
import { useLocale } from "../../locale/context";
|
|
22
|
+
import { buildThresholdBands } from "../../panels/threshold-layers";
|
|
23
|
+
import { resolveSemanticHex } from "../../panels/thresholds";
|
|
24
|
+
import { applyMappings } from "../../panels/mappings";
|
|
25
|
+
import { createAnnotationLayer } from "./AnnotationLayer";
|
|
26
|
+
import { useCrosshair } from "../CrosshairContext";
|
|
27
|
+
/** Format an x-axis value — converts epoch ms to short date, passes strings through. */
|
|
28
|
+
function formatXLabel(v) {
|
|
29
|
+
const n = Number(v);
|
|
30
|
+
if (!isNaN(n) && n > 1e9) {
|
|
31
|
+
const d = new Date(n);
|
|
32
|
+
return `${d.getMonth() + 1}/${d.getDate()}`;
|
|
33
|
+
}
|
|
34
|
+
return String(v);
|
|
35
|
+
}
|
|
21
36
|
function buildLineData(data, xKey, yKey, seriesKey) {
|
|
22
37
|
if (seriesKey) {
|
|
23
38
|
const seriesMap = new Map();
|
|
@@ -44,33 +59,100 @@ function buildLineData(data, xKey, yKey, seriesKey) {
|
|
|
44
59
|
},
|
|
45
60
|
];
|
|
46
61
|
}
|
|
47
|
-
|
|
62
|
+
function createThresholdLayer(thresholds, theme) {
|
|
63
|
+
if (!thresholds)
|
|
64
|
+
return undefined;
|
|
65
|
+
return function ThresholdBandLayer({ yScale, innerWidth }) {
|
|
66
|
+
const scale = yScale;
|
|
67
|
+
const domain = yScale.domain();
|
|
68
|
+
const yMin = domain[0];
|
|
69
|
+
const yMax = domain[1];
|
|
70
|
+
const bands = buildThresholdBands(thresholds, { yMin, yMax });
|
|
71
|
+
return (_jsx("g", { children: bands.map((band, i) => {
|
|
72
|
+
const hex = resolveSemanticHex(band.color, theme);
|
|
73
|
+
const top = scale(band.y1);
|
|
74
|
+
const bottom = scale(band.y0);
|
|
75
|
+
const height = Math.abs(bottom - top);
|
|
76
|
+
return (_jsx("rect", { x: 0, y: Math.min(top, bottom), width: innerWidth, height: height, fill: hex, fillOpacity: 0.08 }, i));
|
|
77
|
+
}) }));
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Nivo custom layer that renders a shared crosshair line.
|
|
82
|
+
* Reads the timestamp directly from CrosshairContext so it updates
|
|
83
|
+
* without needing Nivo to rebuild the layers array.
|
|
84
|
+
*/
|
|
85
|
+
function SharedCrosshairLayer({ points, innerHeight }) {
|
|
86
|
+
const { timestamp } = useCrosshair();
|
|
87
|
+
const theme = useTheme();
|
|
88
|
+
if (timestamp == null)
|
|
89
|
+
return null;
|
|
90
|
+
const match = points.find((p) => Number(p.data.x) === timestamp);
|
|
91
|
+
if (!match)
|
|
92
|
+
return null;
|
|
93
|
+
return (_jsx("line", { x1: match.x, x2: match.x, y1: 0, y2: innerHeight, stroke: theme.primary, strokeWidth: 2, strokeDasharray: "6 3", opacity: 0.8, style: { pointerEvents: "none" } }));
|
|
94
|
+
}
|
|
95
|
+
export function AreaChart({ data, config, annotations = [] }) {
|
|
48
96
|
const theme = useTheme();
|
|
49
97
|
const nivoTheme = buildNivoTheme(theme);
|
|
50
98
|
const palette = getChartPalette(theme);
|
|
99
|
+
const { timestamp: _timestamp, setTimestamp } = useCrosshair();
|
|
51
100
|
const xKey = config.x ?? "x";
|
|
52
101
|
const yKey = config.y ?? "y";
|
|
53
102
|
const yFormat = config.y_format;
|
|
54
103
|
const stacked = config.stacked ?? false;
|
|
55
104
|
const chartData = buildLineData(data, xKey, yKey, config.series);
|
|
105
|
+
const thresholds = config.thresholds;
|
|
106
|
+
const thresholdLayer = createThresholdLayer(thresholds, theme);
|
|
107
|
+
const chartMappings = config.mappings;
|
|
56
108
|
const locale = useLocale();
|
|
57
109
|
const fmt = (v) => yFormat
|
|
58
110
|
? formatValue(v, yFormat, locale)
|
|
59
111
|
: v.toLocaleString(locale, { maximumFractionDigits: 2 });
|
|
112
|
+
const handleMouseMove = useCallback((point) => {
|
|
113
|
+
const xVal = Number(point.data.x);
|
|
114
|
+
if (!Number.isNaN(xVal))
|
|
115
|
+
setTimestamp(xVal);
|
|
116
|
+
}, [setTimestamp]);
|
|
117
|
+
const handleMouseLeave = useCallback(() => {
|
|
118
|
+
setTimestamp(null);
|
|
119
|
+
}, [setTimestamp]);
|
|
120
|
+
const layers = [
|
|
121
|
+
"grid",
|
|
122
|
+
"markers",
|
|
123
|
+
"axes",
|
|
124
|
+
];
|
|
125
|
+
if (thresholdLayer) {
|
|
126
|
+
layers.push(thresholdLayer);
|
|
127
|
+
}
|
|
128
|
+
const annotationLayer = createAnnotationLayer(annotations);
|
|
129
|
+
layers.push(SharedCrosshairLayer);
|
|
130
|
+
layers.push("areas", "crosshair", "lines", "points", "slices", "mesh", "legends");
|
|
131
|
+
// Annotation layer renders AFTER mesh so its hover zones sit on top
|
|
132
|
+
if (annotationLayer) {
|
|
133
|
+
layers.push(annotationLayer);
|
|
134
|
+
}
|
|
60
135
|
return (_jsx("div", { style: { height: "100%" }, children: _jsx(ResponsiveLine, { data: chartData, colors: config.color ? [config.color] : palette, theme: nivoTheme, margin: {
|
|
61
136
|
top: 16,
|
|
62
137
|
right: 16,
|
|
63
138
|
bottom: chartData.length > 1 ? 72 : 48,
|
|
64
139
|
left: 56,
|
|
65
|
-
}, xScale: { type: "point" }, yScale: { type: "linear", stacked }, enableArea: true, areaOpacity: 0.2, axisBottom: {
|
|
140
|
+
}, xScale: { type: "point" }, yScale: { type: "linear", stacked }, enableArea: true, areaOpacity: 0.2, axisBottom: {
|
|
141
|
+
tickSize: 4,
|
|
142
|
+
tickPadding: 4,
|
|
143
|
+
tickRotation: -30,
|
|
144
|
+
format: formatXLabel,
|
|
145
|
+
}, axisLeft: {
|
|
66
146
|
tickSize: 4,
|
|
67
147
|
tickPadding: 4,
|
|
68
148
|
format: (v) => yFormat
|
|
69
149
|
? formatValueShort(v, yFormat, locale)
|
|
70
150
|
: Number(v).toLocaleString(locale),
|
|
71
|
-
}, pointSize: 4, useMesh: true, enableCrosshair: true, tooltip: ({ point }) => {
|
|
72
|
-
const
|
|
73
|
-
|
|
151
|
+
}, pointSize: 4, useMesh: true, enableCrosshair: true, layers: layers, onMouseMove: handleMouseMove, onMouseLeave: handleMouseLeave, tooltip: ({ point }) => {
|
|
152
|
+
const rawY = Number(point.data.y);
|
|
153
|
+
const mapped = applyMappings(rawY, chartMappings);
|
|
154
|
+
const formatted = mapped?.text ?? fmt(rawY);
|
|
155
|
+
return (_jsx(ChartTooltip, { label: formatXLabel(point.data.x), value: `${point.seriesId}: ${formatted}`, color: point.color }));
|
|
74
156
|
}, legends: chartData.length > 1
|
|
75
157
|
? [
|
|
76
158
|
{
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AreaChart.js","sourceRoot":"","sources":["../../../src/components/panels/AreaChart.tsx"],"names":[],"mappings":";AAAA,iCAAiC;AACjC,EAAE;AACF,kEAAkE;AAClE,mEAAmE;AACnE,0CAA0C;AAC1C,EAAE;AACF,+DAA+D;AAC/D,EAAE;AACF,sEAAsE;AACtE,oEAAoE;AACpE,2EAA2E;AAC3E,sEAAsE;AACtE,iCAAiC;AAEjC,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAE5C,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/D,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAC9D,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"AreaChart.js","sourceRoot":"","sources":["../../../src/components/panels/AreaChart.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BarChart.d.ts","sourceRoot":"","sources":["../../../src/components/panels/BarChart.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"BarChart.d.ts","sourceRoot":"","sources":["../../../src/components/panels/BarChart.tsx"],"names":[],"mappings":"AA6BA,UAAU,eAAe;IACvB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;IAChC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACjC;AA8BD,wBAAgB,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,eAAe,2CAiKzD"}
|
|
@@ -12,6 +12,7 @@ import { jsx as _jsx } from "react/jsx-runtime";
|
|
|
12
12
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
13
|
// See the License for the specific language governing permissions and
|
|
14
14
|
// limitations under the License.
|
|
15
|
+
import { useCallback } from "react";
|
|
15
16
|
import { ResponsiveBar } from "@nivo/bar";
|
|
16
17
|
import { buildNivoTheme, getChartPalette } from "./nivo-theme";
|
|
17
18
|
import { useTheme } from "../../theme/context";
|
|
@@ -19,15 +20,36 @@ import { ChartTooltip } from "./ChartTooltip";
|
|
|
19
20
|
import { formatValue, formatValueShort } from "../../formats";
|
|
20
21
|
import { useLocale } from "../../locale/context";
|
|
21
22
|
import { extractSemanticColor } from "./semantic-colors";
|
|
23
|
+
import { resolveThresholdColor, resolveSemanticHex } from "../../panels/thresholds";
|
|
24
|
+
import { applyMappings } from "../../panels/mappings";
|
|
25
|
+
import { useCrosshair } from "../CrosshairContext";
|
|
26
|
+
/**
|
|
27
|
+
* Creates a Nivo custom layer that renders a shared crosshair line
|
|
28
|
+
* driven by the CrosshairContext timestamp.
|
|
29
|
+
*/
|
|
30
|
+
function createSharedCrosshairLayer(timestamp) {
|
|
31
|
+
if (timestamp == null)
|
|
32
|
+
return undefined;
|
|
33
|
+
return function SharedCrosshairLayer({ bars, innerHeight }) {
|
|
34
|
+
const match = bars.find((b) => Number(b.data.indexValue) === timestamp);
|
|
35
|
+
if (!match)
|
|
36
|
+
return null;
|
|
37
|
+
const cx = match.x + match.width / 2;
|
|
38
|
+
return (_jsx("line", { x1: cx, x2: cx, y1: 0, y2: innerHeight, stroke: "currentColor", strokeWidth: 1, strokeDasharray: "6 4", opacity: 0.5, style: { pointerEvents: "none" } }));
|
|
39
|
+
};
|
|
40
|
+
}
|
|
22
41
|
export function BarChart({ data, config }) {
|
|
23
42
|
const theme = useTheme();
|
|
24
43
|
const nivoTheme = buildNivoTheme(theme);
|
|
25
44
|
const palette = getChartPalette(theme);
|
|
45
|
+
const { timestamp, setTimestamp } = useCrosshair();
|
|
26
46
|
const xKey = config.x ?? "x";
|
|
27
47
|
const yKey = config.y ?? "y";
|
|
28
48
|
const yFormat = config.y_format;
|
|
29
49
|
const seriesKey = config.series;
|
|
30
50
|
const stacked = config.stacked ?? false;
|
|
51
|
+
const thresholds = config.thresholds;
|
|
52
|
+
const chartMappings = config.mappings;
|
|
31
53
|
// Build color map: explicit series_colors > semantic theme colors > palette
|
|
32
54
|
const seriesColorMap = {};
|
|
33
55
|
if (config.series_colors) {
|
|
@@ -63,14 +85,46 @@ export function BarChart({ data, config }) {
|
|
|
63
85
|
keys = [yKey];
|
|
64
86
|
chartData = data.map((row) => ({ ...row }));
|
|
65
87
|
}
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
88
|
+
// Build threshold color function for single-series bars
|
|
89
|
+
const thresholdColorFn = thresholds && !seriesKey
|
|
90
|
+
? (datum) => {
|
|
91
|
+
const value = datum[yKey];
|
|
92
|
+
const colorName = resolveThresholdColor(value, thresholds);
|
|
93
|
+
if (colorName)
|
|
94
|
+
return resolveSemanticHex(colorName, theme);
|
|
95
|
+
return palette[0];
|
|
96
|
+
}
|
|
97
|
+
: undefined;
|
|
98
|
+
const handleMouseEnter = useCallback((datum) => {
|
|
99
|
+
const xVal = Number(datum.indexValue);
|
|
100
|
+
if (!Number.isNaN(xVal))
|
|
101
|
+
setTimestamp(xVal);
|
|
102
|
+
}, [setTimestamp]);
|
|
103
|
+
const handleMouseLeave = useCallback(() => {
|
|
104
|
+
setTimestamp(null);
|
|
105
|
+
}, [setTimestamp]);
|
|
106
|
+
const sharedCrosshairLayer = createSharedCrosshairLayer(timestamp);
|
|
107
|
+
const barLayers = [
|
|
108
|
+
"grid",
|
|
109
|
+
"axes",
|
|
110
|
+
"bars",
|
|
111
|
+
];
|
|
112
|
+
if (sharedCrosshairLayer) {
|
|
113
|
+
barLayers.push(sharedCrosshairLayer);
|
|
114
|
+
}
|
|
115
|
+
barLayers.push("markers", "legends", "annotations", "totals");
|
|
116
|
+
return (_jsx("div", { style: { height: "100%" }, children: _jsx(ResponsiveBar, { data: chartData, keys: keys, indexBy: xKey, groupMode: stacked ? "stacked" : "grouped", colors: thresholdColorFn
|
|
117
|
+
? (bar) => thresholdColorFn(bar.data)
|
|
118
|
+
: Object.keys(seriesColorMap).length > 0
|
|
119
|
+
? ({ id }) => seriesColorMap[String(id)] ??
|
|
120
|
+
palette[keys.indexOf(String(id)) % palette.length]
|
|
121
|
+
: config.color
|
|
122
|
+
? [config.color]
|
|
123
|
+
: palette, theme: nivoTheme, margin: { top: 16, right: 16, bottom: 48, left: 56 }, padding: 0.3, layers: barLayers, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, tooltip: ({ id, value, indexValue }) => {
|
|
72
124
|
const hasMultipleSeries = keys.length > 1;
|
|
73
|
-
const
|
|
125
|
+
const numVal = typeof value === "number" ? value : Number(value);
|
|
126
|
+
const mapped = applyMappings(numVal, chartMappings);
|
|
127
|
+
const formatted = mapped?.text ?? fmt(numVal);
|
|
74
128
|
return (_jsx(ChartTooltip, { label: String(indexValue), value: hasMultipleSeries ? `${id}: ${formatted}` : formatted }));
|
|
75
129
|
}, axisBottom: {
|
|
76
130
|
tickSize: 4,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BarChart.js","sourceRoot":"","sources":["../../../src/components/panels/BarChart.tsx"],"names":[],"mappings":";AAAA,iCAAiC;AACjC,EAAE;AACF,kEAAkE;AAClE,mEAAmE;AACnE,0CAA0C;AAC1C,EAAE;AACF,+DAA+D;AAC/D,EAAE;AACF,sEAAsE;AACtE,oEAAoE;AACpE,2EAA2E;AAC3E,sEAAsE;AACtE,iCAAiC;AAEjC,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"BarChart.js","sourceRoot":"","sources":["../../../src/components/panels/BarChart.tsx"],"names":[],"mappings":"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"}
|
|
@@ -41,6 +41,6 @@ export function BulletChart({ data, config }) {
|
|
|
41
41
|
markers: parseList(row[markersKey]),
|
|
42
42
|
};
|
|
43
43
|
});
|
|
44
|
-
return (_jsx("div", { style: { height: "100%" }, children: _jsx(ResponsiveBullet, { data: chartData, theme: nivoTheme, margin: { top: 40, right: 32, bottom: 40, left: 120 }, spacing: 32, titleAlign: "start", titleOffsetX: -100, measureSize: 0.4, markerSize: 0.6, rangeColors: [
|
|
44
|
+
return (_jsx("div", { style: { height: "100%" }, children: _jsx(ResponsiveBullet, { data: chartData, theme: nivoTheme, margin: { top: 40, right: 32, bottom: 40, left: 120 }, spacing: 32, titleAlign: "start", titleOffsetX: -100, measureSize: 0.4, markerSize: 0.6, rangeColors: [theme.panel.surface, theme.panel.border, theme.panel.header], measureColors: palette, markerColors: [theme.status.negative] }) }));
|
|
45
45
|
}
|
|
46
46
|
//# sourceMappingURL=BulletChart.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BulletChart.js","sourceRoot":"","sources":["../../../src/components/panels/BulletChart.tsx"],"names":[],"mappings":";AAAA,iCAAiC;AACjC,EAAE;AACF,kEAAkE;AAClE,mEAAmE;AACnE,0CAA0C;AAC1C,EAAE;AACF,+DAA+D;AAC/D,EAAE;AACF,sEAAsE;AACtE,oEAAoE;AACpE,2EAA2E;AAC3E,sEAAsE;AACtE,iCAAiC;AAEjC,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/D,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAO/C,MAAM,UAAU,WAAW,CAAC,EAAE,IAAI,EAAE,MAAM,EAAmB;IAC3D,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,SAAS,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC;IACxC,MAAM,OAAO,GAAG,eAAe,CAAC,KAAK,CAAC,CAAC;IAEvC,MAAM,KAAK,GAAW,MAAM,CAAC,EAAE,IAAI,IAAI,CAAC;IACxC,MAAM,SAAS,GAAW,MAAM,CAAC,MAAM,IAAI,QAAQ,CAAC;IACpD,MAAM,WAAW,GAAW,MAAM,CAAC,QAAQ,IAAI,UAAU,CAAC;IAC1D,MAAM,UAAU,GAAW,MAAM,CAAC,OAAO,IAAI,SAAS,CAAC;IAEvD,sEAAsE;IACtE,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;QACjC,MAAM,SAAS,GAAG,CAAC,GAAY,EAAY,EAAE;YAC3C,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC;gBAAE,OAAO,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YAC/C,IAAI,OAAO,GAAG,KAAK,QAAQ;gBACzB,OAAO,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;YACrD,IAAI,OAAO,GAAG,KAAK,QAAQ;gBAAE,OAAO,CAAC,GAAG,CAAC,CAAC;YAC1C,OAAO,EAAE,CAAC;QACZ,CAAC,CAAC;QAEF,OAAO;YACL,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YACtB,MAAM,EAAE,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YACjC,QAAQ,EAAE,SAAS,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;YACrC,OAAO,EAAE,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;SACpC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,OAAO,CACL,cAAK,KAAK,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,YAC5B,KAAC,gBAAgB,IACf,IAAI,EAAE,SAAS,EACf,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,EACrD,OAAO,EAAE,EAAE,EACX,UAAU,EAAC,OAAO,EAClB,YAAY,EAAE,CAAC,GAAG,EAClB,WAAW,EAAE,GAAG,EAChB,UAAU,EAAE,GAAG,EACf,WAAW,EAAE,CAAC,
|
|
1
|
+
{"version":3,"file":"BulletChart.js","sourceRoot":"","sources":["../../../src/components/panels/BulletChart.tsx"],"names":[],"mappings":";AAAA,iCAAiC;AACjC,EAAE;AACF,kEAAkE;AAClE,mEAAmE;AACnE,0CAA0C;AAC1C,EAAE;AACF,+DAA+D;AAC/D,EAAE;AACF,sEAAsE;AACtE,oEAAoE;AACpE,2EAA2E;AAC3E,sEAAsE;AACtE,iCAAiC;AAEjC,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/D,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAO/C,MAAM,UAAU,WAAW,CAAC,EAAE,IAAI,EAAE,MAAM,EAAmB;IAC3D,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,SAAS,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC;IACxC,MAAM,OAAO,GAAG,eAAe,CAAC,KAAK,CAAC,CAAC;IAEvC,MAAM,KAAK,GAAW,MAAM,CAAC,EAAE,IAAI,IAAI,CAAC;IACxC,MAAM,SAAS,GAAW,MAAM,CAAC,MAAM,IAAI,QAAQ,CAAC;IACpD,MAAM,WAAW,GAAW,MAAM,CAAC,QAAQ,IAAI,UAAU,CAAC;IAC1D,MAAM,UAAU,GAAW,MAAM,CAAC,OAAO,IAAI,SAAS,CAAC;IAEvD,sEAAsE;IACtE,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;QACjC,MAAM,SAAS,GAAG,CAAC,GAAY,EAAY,EAAE;YAC3C,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC;gBAAE,OAAO,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YAC/C,IAAI,OAAO,GAAG,KAAK,QAAQ;gBACzB,OAAO,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;YACrD,IAAI,OAAO,GAAG,KAAK,QAAQ;gBAAE,OAAO,CAAC,GAAG,CAAC,CAAC;YAC1C,OAAO,EAAE,CAAC;QACZ,CAAC,CAAC;QAEF,OAAO;YACL,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YACtB,MAAM,EAAE,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YACjC,QAAQ,EAAE,SAAS,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;YACrC,OAAO,EAAE,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;SACpC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,OAAO,CACL,cAAK,KAAK,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,YAC5B,KAAC,gBAAgB,IACf,IAAI,EAAE,SAAS,EACf,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,EACrD,OAAO,EAAE,EAAE,EACX,UAAU,EAAC,OAAO,EAClB,YAAY,EAAE,CAAC,GAAG,EAClB,WAAW,EAAE,GAAG,EAChB,UAAU,EAAE,GAAG,EACf,WAAW,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,EAC1E,aAAa,EAAE,OAAO,EACtB,YAAY,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,GACrC,GACE,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CalendarHeatmap.d.ts","sourceRoot":"","sources":["../../../src/components/panels/CalendarHeatmap.tsx"],"names":[],"mappings":"AAkBA,UAAU,eAAe;IACvB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;IAChC,MAAM,EAAE,GAAG,CAAC;CACb;AAED,wBAAgB,eAAe,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,eAAe,
|
|
1
|
+
{"version":3,"file":"CalendarHeatmap.d.ts","sourceRoot":"","sources":["../../../src/components/panels/CalendarHeatmap.tsx"],"names":[],"mappings":"AAkBA,UAAU,eAAe;IACvB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;IAChC,MAAM,EAAE,GAAG,CAAC;CACb;AAED,wBAAgB,eAAe,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,eAAe,2CAiDhE"}
|
|
@@ -29,10 +29,13 @@ export function CalendarHeatmap({ data, config }) {
|
|
|
29
29
|
const days = chartData.map((d) => d.day).sort();
|
|
30
30
|
const from = config.from ?? days[0] ?? new Date().getFullYear() + "-01-01";
|
|
31
31
|
const to = config.to ?? days[days.length - 1] ?? new Date().getFullYear() + "-12-31";
|
|
32
|
-
// Use first 4 palette colors for the calendar gradient,
|
|
33
|
-
const calendarColors =
|
|
34
|
-
|
|
35
|
-
|
|
32
|
+
// Use first 4 palette colors for the calendar gradient, padded with theme.primary
|
|
33
|
+
const calendarColors = [
|
|
34
|
+
palette[0] ?? theme.primary,
|
|
35
|
+
palette[1] ?? theme.primary,
|
|
36
|
+
palette[2] ?? theme.primary,
|
|
37
|
+
palette[3] ?? theme.primary,
|
|
38
|
+
];
|
|
36
39
|
// Extract background-like colors from theme for empty/border
|
|
37
40
|
const emptyColor = nivoTheme.grid.line.stroke;
|
|
38
41
|
const borderColor = nivoTheme.grid.line.stroke;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CalendarHeatmap.js","sourceRoot":"","sources":["../../../src/components/panels/CalendarHeatmap.tsx"],"names":[],"mappings":";AAAA,iCAAiC;AACjC,EAAE;AACF,kEAAkE;AAClE,mEAAmE;AACnE,0CAA0C;AAC1C,EAAE;AACF,+DAA+D;AAC/D,EAAE;AACF,sEAAsE;AACtE,oEAAoE;AACpE,2EAA2E;AAC3E,sEAAsE;AACtE,iCAAiC;AAEjC,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/D,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAO/C,MAAM,UAAU,eAAe,CAAC,EAAE,IAAI,EAAE,MAAM,EAAmB;IAC/D,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,SAAS,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC;IACxC,MAAM,OAAO,GAAG,eAAe,CAAC,KAAK,CAAC,CAAC;IAEvC,MAAM,MAAM,GAAW,MAAM,CAAC,GAAG,IAAI,KAAK,CAAC;IAC3C,MAAM,QAAQ,GAAW,MAAM,CAAC,KAAK,IAAI,OAAO,CAAC;IAEjD,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;QACnC,GAAG,EAAE,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACxB,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC;KAClC,CAAC,CAAC,CAAC;IAEJ,8BAA8B;IAC9B,MAAM,IAAI,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;IAChD,MAAM,IAAI,GACR,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,GAAG,QAAQ,CAAC;IAChE,MAAM,EAAE,GACN,MAAM,CAAC,EAAE,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,IAAI,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,GAAG,QAAQ,CAAC;IAE5E,
|
|
1
|
+
{"version":3,"file":"CalendarHeatmap.js","sourceRoot":"","sources":["../../../src/components/panels/CalendarHeatmap.tsx"],"names":[],"mappings":";AAAA,iCAAiC;AACjC,EAAE;AACF,kEAAkE;AAClE,mEAAmE;AACnE,0CAA0C;AAC1C,EAAE;AACF,+DAA+D;AAC/D,EAAE;AACF,sEAAsE;AACtE,oEAAoE;AACpE,2EAA2E;AAC3E,sEAAsE;AACtE,iCAAiC;AAEjC,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/D,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAO/C,MAAM,UAAU,eAAe,CAAC,EAAE,IAAI,EAAE,MAAM,EAAmB;IAC/D,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,SAAS,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC;IACxC,MAAM,OAAO,GAAG,eAAe,CAAC,KAAK,CAAC,CAAC;IAEvC,MAAM,MAAM,GAAW,MAAM,CAAC,GAAG,IAAI,KAAK,CAAC;IAC3C,MAAM,QAAQ,GAAW,MAAM,CAAC,KAAK,IAAI,OAAO,CAAC;IAEjD,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;QACnC,GAAG,EAAE,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACxB,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC;KAClC,CAAC,CAAC,CAAC;IAEJ,8BAA8B;IAC9B,MAAM,IAAI,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;IAChD,MAAM,IAAI,GACR,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,GAAG,QAAQ,CAAC;IAChE,MAAM,EAAE,GACN,MAAM,CAAC,EAAE,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,IAAI,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,GAAG,QAAQ,CAAC;IAE5E,kFAAkF;IAClF,MAAM,cAAc,GAAG;QACrB,OAAO,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,OAAO;QAC3B,OAAO,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,OAAO;QAC3B,OAAO,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,OAAO;QAC3B,OAAO,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,OAAO;KAC5B,CAAC;IAEF,6DAA6D;IAC7D,MAAM,UAAU,GAAG,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;IAC9C,MAAM,WAAW,GAAG,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;IAE/C,OAAO,CACL,cAAK,KAAK,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,YAC5B,KAAC,kBAAkB,IACjB,IAAI,EAAE,SAAS,EACf,IAAI,EAAE,IAAI,EACV,EAAE,EAAE,EAAE,EACN,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EACnD,UAAU,EAAE,UAAU,EACtB,MAAM,EAAE,cAAc,EACtB,WAAW,EAAE,EAAE,EACf,gBAAgB,EAAE,WAAW,EAC7B,cAAc,EAAE,CAAC,EACjB,cAAc,EAAE,WAAW,GAC3B,GACE,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChartTooltip.d.ts","sourceRoot":"","sources":["../../../src/components/panels/ChartTooltip.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"ChartTooltip.d.ts","sourceRoot":"","sources":["../../../src/components/panels/ChartTooltip.tsx"],"names":[],"mappings":"AAkBA,MAAM,WAAW,iBAAiB;IAChC,qEAAqE;IACrE,KAAK,EAAE,MAAM,CAAC;IACd,6BAA6B;IAC7B,KAAK,EAAE,MAAM,CAAC;IACd,gCAAgC;IAChC,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED;;;GAGG;AACH,wBAAgB,YAAY,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,iBAAiB,2CA4CtE;AAID,MAAM,WAAW,gBAAgB;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,4BAA4B;IAC3C,iDAAiD;IACjD,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,gBAAgB,EAAE,CAAC;CAC5B;AAED,wBAAgB,uBAAuB,CAAC,EACtC,KAAK,EACL,MAAM,GACP,EAAE,4BAA4B,2CA6D9B;AAID;;;GAGG;AACH,wBAAgB,aAAa,KACnB,4BAIL;IACD,EAAE,EAAE,MAAM,GAAG,MAAM,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,MAAM,GAAG,MAAM,CAAC;CAC7B,6CACF;AAED;;;GAGG;AACH,wBAAgB,cAAc,KACpB,YAEL;IACD,KAAK,EAAE;QACL,QAAQ,EAAE,MAAM,GAAG,MAAM,CAAC;QAC1B,IAAI,EAAE;YAAE,UAAU,EAAE,MAAM,GAAG,MAAM,CAAC;YAAC,UAAU,EAAE,MAAM,GAAG,MAAM,CAAA;SAAE,CAAC;QACnE,KAAK,EAAE,MAAM,CAAC;KACf,CAAC;CACH,6CAOF"}
|
|
@@ -13,55 +13,16 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
13
13
|
// See the License for the specific language governing permissions and
|
|
14
14
|
// limitations under the License.
|
|
15
15
|
import { useTheme } from "../../theme/context";
|
|
16
|
-
/**
|
|
17
|
-
* Extracts a hex color from a Tailwind class string (same logic as nivo-theme).
|
|
18
|
-
* Duplicated here to keep this file self-contained and avoid circular deps.
|
|
19
|
-
*/
|
|
20
|
-
function extractHex(twClass, fallback) {
|
|
21
|
-
const match = twClass.match(/#[0-9a-fA-F]{3,8}/);
|
|
22
|
-
if (match)
|
|
23
|
-
return match[0];
|
|
24
|
-
const namedColors = {
|
|
25
|
-
"slate-50": "#f8fafc",
|
|
26
|
-
"slate-100": "#f1f5f9",
|
|
27
|
-
"slate-200": "#e2e8f0",
|
|
28
|
-
"slate-300": "#cbd5e1",
|
|
29
|
-
"slate-400": "#94a3b8",
|
|
30
|
-
"slate-500": "#64748b",
|
|
31
|
-
"slate-600": "#475569",
|
|
32
|
-
"slate-700": "#334155",
|
|
33
|
-
"slate-800": "#1e293b",
|
|
34
|
-
"slate-900": "#0f172a",
|
|
35
|
-
"slate-950": "#020617",
|
|
36
|
-
"gray-800": "#1f2937",
|
|
37
|
-
"gray-900": "#111827",
|
|
38
|
-
"zinc-800": "#27272a",
|
|
39
|
-
"zinc-900": "#18181b",
|
|
40
|
-
white: "#ffffff",
|
|
41
|
-
black: "#000000",
|
|
42
|
-
"indigo-300": "#a5b4fc",
|
|
43
|
-
"indigo-400": "#818cf8",
|
|
44
|
-
"indigo-500": "#6366f1",
|
|
45
|
-
"emerald-400": "#34d399",
|
|
46
|
-
"red-400": "#f87171",
|
|
47
|
-
"amber-400": "#fbbf24",
|
|
48
|
-
};
|
|
49
|
-
for (const [name, hex] of Object.entries(namedColors)) {
|
|
50
|
-
if (twClass.includes(name))
|
|
51
|
-
return hex;
|
|
52
|
-
}
|
|
53
|
-
return fallback;
|
|
54
|
-
}
|
|
55
16
|
/**
|
|
56
17
|
* Themed tooltip for single-series Nivo charts.
|
|
57
18
|
* Uses inline styles because it renders inside an SVG foreign-object context.
|
|
58
19
|
*/
|
|
59
20
|
export function ChartTooltip({ label, value, color }) {
|
|
60
21
|
const theme = useTheme();
|
|
61
|
-
const bg =
|
|
62
|
-
const border =
|
|
63
|
-
const textMain =
|
|
64
|
-
const textMuted =
|
|
22
|
+
const bg = theme.panel.surface;
|
|
23
|
+
const border = theme.panel.border;
|
|
24
|
+
const textMain = theme.panel.title;
|
|
25
|
+
const textMuted = theme.typography.muted;
|
|
65
26
|
return (_jsxs("div", { style: {
|
|
66
27
|
background: bg,
|
|
67
28
|
border: `1px solid ${border}`,
|
|
@@ -83,11 +44,11 @@ export function ChartTooltip({ label, value, color }) {
|
|
|
83
44
|
}
|
|
84
45
|
export function MultiSeriesChartTooltip({ label, points, }) {
|
|
85
46
|
const theme = useTheme();
|
|
86
|
-
const bg =
|
|
87
|
-
const border =
|
|
88
|
-
const textMain =
|
|
89
|
-
const textMuted =
|
|
90
|
-
const divider =
|
|
47
|
+
const bg = theme.panel.surface;
|
|
48
|
+
const border = theme.panel.border;
|
|
49
|
+
const textMain = theme.panel.title;
|
|
50
|
+
const textMuted = theme.typography.muted;
|
|
51
|
+
const divider = theme.panel.border;
|
|
91
52
|
return (_jsxs("div", { style: {
|
|
92
53
|
background: bg,
|
|
93
54
|
border: `1px solid ${border}`,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChartTooltip.js","sourceRoot":"","sources":["../../../src/components/panels/ChartTooltip.tsx"],"names":[],"mappings":";AAAA,iCAAiC;AACjC,EAAE;AACF,kEAAkE;AAClE,mEAAmE;AACnE,0CAA0C;AAC1C,EAAE;AACF,+DAA+D;AAC/D,EAAE;AACF,sEAAsE;AACtE,oEAAoE;AACpE,2EAA2E;AAC3E,sEAAsE;AACtE,iCAAiC;AAEjC,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"ChartTooltip.js","sourceRoot":"","sources":["../../../src/components/panels/ChartTooltip.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
export interface DataLink {
|
|
2
|
+
title: string;
|
|
3
|
+
url: string;
|
|
4
|
+
target: "_self" | "_blank";
|
|
5
|
+
}
|
|
6
|
+
export interface ResolvedDataLink {
|
|
7
|
+
title: string;
|
|
8
|
+
url: string;
|
|
9
|
+
target: "_self" | "_blank";
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Interpolate a data link URL template.
|
|
13
|
+
* - ${row.field} resolves to row[field], URL-encoded
|
|
14
|
+
* - ${filter_name} resolves to filterValues[filter_name], URL-encoded
|
|
15
|
+
* Exported for testing.
|
|
16
|
+
*/
|
|
17
|
+
export declare function interpolateDataLinkUrl(urlTemplate: string, row: Record<string, unknown>, filterValues: Record<string, string>): string;
|
|
18
|
+
/**
|
|
19
|
+
* Resolve an array of data link templates against a specific row and filter context.
|
|
20
|
+
* Exported for testing.
|
|
21
|
+
*/
|
|
22
|
+
export declare function resolveDataLinks(links: DataLink[], row: Record<string, unknown>, filterValues: Record<string, string>): ResolvedDataLink[];
|
|
23
|
+
/** Link icon overlay for table rows -- shows on hover */
|
|
24
|
+
export declare function DataLinkIcon({ links }: {
|
|
25
|
+
links: ResolvedDataLink[];
|
|
26
|
+
}): import("react/jsx-runtime").JSX.Element | null;
|
|
27
|
+
/**
|
|
28
|
+
* Wrap a stat panel to make the entire panel clickable when it has data links.
|
|
29
|
+
* Uses the first data link as the primary click target.
|
|
30
|
+
*/
|
|
31
|
+
export declare function ClickableStatWrapper({ links, children, }: {
|
|
32
|
+
links: ResolvedDataLink[];
|
|
33
|
+
children: React.ReactNode;
|
|
34
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
35
|
+
//# sourceMappingURL=DataLinks.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DataLinks.d.ts","sourceRoot":"","sources":["../../../src/components/panels/DataLinks.tsx"],"names":[],"mappings":"AAgBA,MAAM,WAAW,QAAQ;IACvB,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,OAAO,GAAG,QAAQ,CAAC;CAC5B;AAED,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,OAAO,GAAG,QAAQ,CAAC;CAC5B;AAED;;;;;GAKG;AACH,wBAAgB,sBAAsB,CACpC,WAAW,EAAE,MAAM,EACnB,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC5B,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GACnC,MAAM,CAiBR;AAED;;;GAGG;AACH,wBAAgB,gBAAgB,CAC9B,KAAK,EAAE,QAAQ,EAAE,EACjB,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC5B,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GACnC,gBAAgB,EAAE,CAMpB;AAID,yDAAyD;AACzD,wBAAgB,YAAY,CAAC,EAAE,KAAK,EAAE,EAAE;IAAE,KAAK,EAAE,gBAAgB,EAAE,CAAA;CAAE,kDA8CpE;AAED;;;GAGG;AACH,wBAAgB,oBAAoB,CAAC,EACnC,KAAK,EACL,QAAQ,GACT,EAAE;IACD,KAAK,EAAE,gBAAgB,EAAE,CAAC;IAC1B,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B,2CAeA"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
// Copyright 2026 Mataki Labs LLC
|
|
3
|
+
//
|
|
4
|
+
// Licensed under the Business Source License 1.1 (the "License");
|
|
5
|
+
// you may not use this file except in compliance with the License.
|
|
6
|
+
// You may obtain a copy of the License at
|
|
7
|
+
//
|
|
8
|
+
// https://github.com/panoboard/panoboard/blob/main/LICENSE
|
|
9
|
+
//
|
|
10
|
+
// Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
+
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
// See the License for the specific language governing permissions and
|
|
14
|
+
// limitations under the License.
|
|
15
|
+
import { ExternalLink } from "lucide-react";
|
|
16
|
+
/**
|
|
17
|
+
* Interpolate a data link URL template.
|
|
18
|
+
* - ${row.field} resolves to row[field], URL-encoded
|
|
19
|
+
* - ${filter_name} resolves to filterValues[filter_name], URL-encoded
|
|
20
|
+
* Exported for testing.
|
|
21
|
+
*/
|
|
22
|
+
export function interpolateDataLinkUrl(urlTemplate, row, filterValues) {
|
|
23
|
+
// Replace ${row.field} patterns
|
|
24
|
+
let url = urlTemplate.replace(/\$\{row\.([^}]+)\}/g, (_match, field) => {
|
|
25
|
+
const value = row[field.trim()];
|
|
26
|
+
return value != null ? encodeURIComponent(String(value)) : "";
|
|
27
|
+
});
|
|
28
|
+
// Replace ${filter_name} patterns (that are NOT ${row.*})
|
|
29
|
+
url = url.replace(/\$\{([^}]+)\}/g, (_match, name) => {
|
|
30
|
+
const value = filterValues[name.trim()];
|
|
31
|
+
return value != null ? encodeURIComponent(value) : "";
|
|
32
|
+
});
|
|
33
|
+
return url;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Resolve an array of data link templates against a specific row and filter context.
|
|
37
|
+
* Exported for testing.
|
|
38
|
+
*/
|
|
39
|
+
export function resolveDataLinks(links, row, filterValues) {
|
|
40
|
+
return links.map((link) => ({
|
|
41
|
+
title: link.title,
|
|
42
|
+
url: interpolateDataLinkUrl(link.url, row, filterValues),
|
|
43
|
+
target: link.target ?? "_self",
|
|
44
|
+
}));
|
|
45
|
+
}
|
|
46
|
+
// --- UI Components ---
|
|
47
|
+
/** Link icon overlay for table rows -- shows on hover */
|
|
48
|
+
export function DataLinkIcon({ links }) {
|
|
49
|
+
if (links.length === 0)
|
|
50
|
+
return null;
|
|
51
|
+
if (links.length === 1) {
|
|
52
|
+
return (_jsx("a", { href: links[0].url, target: links[0].target, rel: links[0].target === "_blank" ? "noopener noreferrer" : undefined, className: "inline-flex items-center transition-colors", style: { color: "var(--text-link)" }, title: links[0].title, children: _jsx(ExternalLink, { className: "w-3.5 h-3.5" }) }));
|
|
53
|
+
}
|
|
54
|
+
// Multiple links: render a dropdown-like popover on hover
|
|
55
|
+
return (_jsxs("div", { className: "relative group inline-flex", children: [_jsx("button", { className: "inline-flex items-center transition-colors", style: { color: "var(--text-link)" }, title: "Data links", children: _jsx(ExternalLink, { className: "w-3.5 h-3.5" }) }), _jsx("div", { className: "hidden group-hover:flex flex-col absolute right-0 top-full mt-1 z-50 glass-overlay rounded-lg shadow-xl py-1 min-w-40", children: links.map((link, i) => (_jsx("a", { href: link.url, target: link.target, rel: link.target === "_blank" ? "noopener noreferrer" : undefined, className: "px-3 py-1.5 text-xs transition-colors hover:opacity-80", style: { color: "var(--text-label)" }, children: link.title }, i))) })] }));
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Wrap a stat panel to make the entire panel clickable when it has data links.
|
|
59
|
+
* Uses the first data link as the primary click target.
|
|
60
|
+
*/
|
|
61
|
+
export function ClickableStatWrapper({ links, children, }) {
|
|
62
|
+
if (links.length === 0)
|
|
63
|
+
return _jsx(_Fragment, { children: children });
|
|
64
|
+
const primary = links[0];
|
|
65
|
+
return (_jsx("a", { href: primary.url, target: primary.target, rel: primary.target === "_blank" ? "noopener noreferrer" : undefined, className: "block h-full cursor-pointer hover:opacity-80 transition-opacity", title: primary.title, children: children }));
|
|
66
|
+
}
|
|
67
|
+
//# sourceMappingURL=DataLinks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DataLinks.js","sourceRoot":"","sources":["../../../src/components/panels/DataLinks.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GaugePanel.d.ts","sourceRoot":"","sources":["../../../src/components/panels/GaugePanel.tsx"],"names":[],"mappings":"AAkBA,UAAU,eAAe;IACvB,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAC/B;AA8DD,wBAAgB,UAAU,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,eAAe,2CA+I1D"}
|