@panoboard/core 1.10.0 → 1.11.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.map +1 -1
- package/dist/annotations/executor.js +13 -0
- package/dist/annotations/executor.js.map +1 -1
- package/dist/components/ConfigErrorBanner.d.ts.map +1 -1
- package/dist/components/ConfigErrorBanner.js +13 -0
- package/dist/components/ConfigErrorBanner.js.map +1 -1
- package/dist/components/DashboardLinks.d.ts.map +1 -1
- package/dist/components/DashboardLinks.js +9 -4
- package/dist/components/DashboardLinks.js.map +1 -1
- package/dist/components/DashboardShell.d.ts.map +1 -1
- package/dist/components/DashboardShell.js +43 -7
- package/dist/components/DashboardShell.js.map +1 -1
- package/dist/components/NotificationIndicator.d.ts.map +1 -1
- package/dist/components/NotificationIndicator.js +4 -3
- package/dist/components/NotificationIndicator.js.map +1 -1
- package/dist/components/PanelExpansionContext.d.ts +22 -0
- package/dist/components/PanelExpansionContext.d.ts.map +1 -0
- package/dist/components/PanelExpansionContext.js +26 -0
- package/dist/components/PanelExpansionContext.js.map +1 -0
- package/dist/components/PanelFullscreenOverlay.d.ts +8 -0
- package/dist/components/PanelFullscreenOverlay.d.ts.map +1 -0
- package/dist/components/PanelFullscreenOverlay.js +45 -0
- package/dist/components/PanelFullscreenOverlay.js.map +1 -0
- package/dist/components/PanelWrapper.d.ts +3 -1
- package/dist/components/PanelWrapper.d.ts.map +1 -1
- package/dist/components/PanelWrapper.js +30 -12
- package/dist/components/PanelWrapper.js.map +1 -1
- package/dist/components/RefreshContext.d.ts.map +1 -1
- package/dist/components/RefreshContext.js +13 -0
- package/dist/components/RefreshContext.js.map +1 -1
- package/dist/components/RefreshControl.js +2 -2
- package/dist/components/RefreshControl.js.map +1 -1
- package/dist/components/index.d.ts +3 -0
- package/dist/components/index.d.ts.map +1 -1
- package/dist/components/index.js +2 -0
- package/dist/components/index.js.map +1 -1
- package/dist/components/panels/StatPanel.d.ts +2 -1
- package/dist/components/panels/StatPanel.d.ts.map +1 -1
- package/dist/components/panels/StatPanel.js +5 -2
- package/dist/components/panels/StatPanel.js.map +1 -1
- package/dist/components/panels/TablePanel.d.ts +3 -2
- package/dist/components/panels/TablePanel.d.ts.map +1 -1
- package/dist/components/panels/TablePanel.js +14 -15
- package/dist/components/panels/TablePanel.js.map +1 -1
- package/dist/components/panels/index.d.ts +1 -1
- package/dist/components/panels/index.d.ts.map +1 -1
- package/dist/components/panels/index.js +26 -44
- package/dist/components/panels/index.js.map +1 -1
- package/dist/config/index.d.ts.map +1 -1
- package/dist/config/index.js +13 -0
- package/dist/config/index.js.map +1 -1
- package/dist/config/resolve.d.ts.map +1 -1
- package/dist/config/resolve.js +13 -0
- package/dist/config/resolve.js.map +1 -1
- package/dist/query/template.d.ts.map +1 -1
- package/dist/query/template.js +7 -0
- package/dist/query/template.js.map +1 -1
- package/dist/schemas/annotations.d.ts.map +1 -1
- package/dist/schemas/annotations.js +13 -0
- package/dist/schemas/annotations.js.map +1 -1
- package/dist/schemas/dashboard.d.ts +735 -0
- package/dist/schemas/dashboard.d.ts.map +1 -1
- package/dist/schemas/index.d.ts +1 -1
- package/dist/schemas/index.d.ts.map +1 -1
- package/dist/schemas/index.js.map +1 -1
- package/dist/startup/index.d.ts +2 -0
- package/dist/startup/index.d.ts.map +1 -1
- package/dist/startup/index.js +1 -0
- package/dist/startup/index.js.map +1 -1
- package/dist/startup/sentinel-check.d.ts +12 -0
- package/dist/startup/sentinel-check.d.ts.map +1 -0
- package/dist/startup/sentinel-check.js +142 -0
- package/dist/startup/sentinel-check.js.map +1 -0
- package/dist/transforms/computed.d.ts.map +1 -1
- package/dist/transforms/computed.js +13 -0
- package/dist/transforms/computed.js.map +1 -1
- package/dist/transforms/engine.d.ts.map +1 -1
- package/dist/transforms/engine.js +13 -0
- package/dist/transforms/engine.js.map +1 -1
- package/dist/transforms/expression.d.ts.map +1 -1
- package/dist/transforms/expression.js +13 -13
- package/dist/transforms/expression.js.map +1 -1
- package/dist/transforms/filter.d.ts.map +1 -1
- package/dist/transforms/filter.js +13 -0
- package/dist/transforms/filter.js.map +1 -1
- package/dist/transforms/index.d.ts.map +1 -1
- package/dist/transforms/index.js +13 -0
- package/dist/transforms/index.js.map +1 -1
- package/dist/transforms/limit.d.ts.map +1 -1
- package/dist/transforms/limit.js +13 -0
- package/dist/transforms/limit.js.map +1 -1
- package/dist/transforms/percentage.d.ts.map +1 -1
- package/dist/transforms/percentage.js +13 -0
- package/dist/transforms/percentage.js.map +1 -1
- package/dist/transforms/rename.d.ts.map +1 -1
- package/dist/transforms/rename.js +13 -0
- package/dist/transforms/rename.js.map +1 -1
- package/dist/transforms/sort.d.ts.map +1 -1
- package/dist/transforms/sort.js +13 -0
- package/dist/transforms/sort.js.map +1 -1
- package/dist/types/config-error.d.ts.map +1 -1
- package/dist/types/config-error.js +13 -0
- package/dist/types/config-error.js.map +1 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"executor.d.ts","sourceRoot":"","sources":["../../src/annotations/executor.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"executor.d.ts","sourceRoot":"","sources":["../../src/annotations/executor.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAEzD,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC7B;AAED,MAAM,WAAW,kBAAkB;IACjC,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,eAAe,EAAE,CAAC;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED;;;;;;GAMG;AACH,wBAAsB,wBAAwB,CAC5C,WAAW,EAAE,UAAU,EAAE,EACzB,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACvC,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EACpC,YAAY,EAAE,CAAC,UAAU,EAAE,MAAM,KAAK;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,OAAO,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;QAAC,OAAO,EAAE;YAAE,IAAI,EAAE,MAAM,CAAC;YAAC,IAAI,EAAE,MAAM,CAAA;SAAE,EAAE,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE,CAAC,CAAA;CAAE,GAAG,IAAI,EACnN,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAC3B,OAAO,CAAC,kBAAkB,EAAE,CAAC,CA0E/B"}
|
|
@@ -1,3 +1,16 @@
|
|
|
1
|
+
// Copyright 2026 Mataki Labs LLC
|
|
2
|
+
//
|
|
3
|
+
// Licensed under the Business Source License 1.1 (the "License");
|
|
4
|
+
// you may not use this file except in compliance with the License.
|
|
5
|
+
// You may obtain a copy of the License at
|
|
6
|
+
//
|
|
7
|
+
// https://github.com/panoboard/panoboard/blob/main/LICENSE
|
|
8
|
+
//
|
|
9
|
+
// Unless required by applicable law or agreed to in writing, software
|
|
10
|
+
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
11
|
+
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
|
+
// See the License for the specific language governing permissions and
|
|
13
|
+
// limitations under the License.
|
|
1
14
|
/**
|
|
2
15
|
* Executes annotation queries for all enabled annotations.
|
|
3
16
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"executor.js","sourceRoot":"","sources":["../../src/annotations/executor.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"executor.js","sourceRoot":"","sources":["../../src/annotations/executor.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ConfigErrorBanner.d.ts","sourceRoot":"","sources":["../../src/components/ConfigErrorBanner.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"ConfigErrorBanner.d.ts","sourceRoot":"","sources":["../../src/components/ConfigErrorBanner.tsx"],"names":[],"mappings":"AAkBA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAEzD,UAAU,sBAAsB;IAC9B,MAAM,EAAE,WAAW,EAAE,CAAC;CACvB;AAgID,wBAAgB,iBAAiB,CAAC,EAAE,MAAM,EAAE,EAAE,sBAAsB,kDA4DnE"}
|
|
@@ -1,4 +1,17 @@
|
|
|
1
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.
|
|
2
15
|
import { useState } from "react";
|
|
3
16
|
import { AlertTriangle, ChevronDown, ChevronUp, X } from "lucide-react";
|
|
4
17
|
import { useTheme } from "../theme/context";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ConfigErrorBanner.js","sourceRoot":"","sources":["../../src/components/ConfigErrorBanner.tsx"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ConfigErrorBanner.js","sourceRoot":"","sources":["../../src/components/ConfigErrorBanner.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DashboardLinks.d.ts","sourceRoot":"","sources":["../../src/components/DashboardLinks.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"DashboardLinks.d.ts","sourceRoot":"","sources":["../../src/components/DashboardLinks.tsx"],"names":[],"mappings":"AAkBA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAE1D,UAAU,mBAAmB;IAC3B,KAAK,CAAC,EAAE,aAAa,EAAE,CAAC;IACxB,YAAY,EAAE,MAAM,CAAC;CACtB;AAgCD,wBAAgB,cAAc,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,EAAE,mBAAmB,kDAyC1E"}
|
|
@@ -15,6 +15,7 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
15
15
|
import { Link } from "react-router";
|
|
16
16
|
import { ExternalLink } from "lucide-react";
|
|
17
17
|
import { useTheme } from "../theme/context";
|
|
18
|
+
import { interpolate } from "../interpolation";
|
|
18
19
|
function buildInternalHref(link, filterParams) {
|
|
19
20
|
const base = `/dashboards/${link.dashboard}`;
|
|
20
21
|
if (!link.forward_filters || link.forward_filters.length === 0) {
|
|
@@ -32,9 +33,13 @@ function buildInternalHref(link, filterParams) {
|
|
|
32
33
|
const qs = target.toString();
|
|
33
34
|
return qs ? `${base}?${qs}` : base;
|
|
34
35
|
}
|
|
35
|
-
function interpolateUrl(url) {
|
|
36
|
-
|
|
37
|
-
|
|
36
|
+
function interpolateUrl(url, filterParams) {
|
|
37
|
+
const params = new URLSearchParams(filterParams);
|
|
38
|
+
const values = {};
|
|
39
|
+
for (const [key, value] of params.entries()) {
|
|
40
|
+
values[key] = encodeURIComponent(value);
|
|
41
|
+
}
|
|
42
|
+
return interpolate(url, values);
|
|
38
43
|
}
|
|
39
44
|
export function DashboardLinks({ links, filterParams }) {
|
|
40
45
|
const theme = useTheme();
|
|
@@ -45,7 +50,7 @@ export function DashboardLinks({ links, filterParams }) {
|
|
|
45
50
|
return (_jsx(Link, { to: buildInternalHref(link, filterParams), className: "inline-flex items-center gap-1.5 rounded-md px-3 py-1.5 text-sm font-medium hover:opacity-80 transition-colors", style: { color: theme.typography.muted }, children: link.title }, `${link.dashboard}-${idx}`));
|
|
46
51
|
}
|
|
47
52
|
if (link.url) {
|
|
48
|
-
return (_jsxs("a", { href: interpolateUrl(link.url), target: "_blank", rel: "noopener noreferrer", className: "inline-flex items-center gap-1.5 rounded-md px-3 py-1.5 text-sm font-medium hover:opacity-80 transition-colors", style: { color: theme.typography.muted }, children: [link.title, _jsx(ExternalLink, { className: "w-3 h-3" })] }, `${link.url}-${idx}`));
|
|
53
|
+
return (_jsxs("a", { href: interpolateUrl(link.url, filterParams), target: "_blank", rel: "noopener noreferrer", className: "inline-flex items-center gap-1.5 rounded-md px-3 py-1.5 text-sm font-medium hover:opacity-80 transition-colors", style: { color: theme.typography.muted }, children: [link.title, _jsx(ExternalLink, { className: "w-3 h-3" })] }, `${link.url}-${idx}`));
|
|
49
54
|
}
|
|
50
55
|
return null;
|
|
51
56
|
}) }));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DashboardLinks.js","sourceRoot":"","sources":["../../src/components/DashboardLinks.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,IAAI,EAAE,MAAM,cAAc,CAAC;AACpC,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAC5C,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"DashboardLinks.js","sourceRoot":"","sources":["../../src/components/DashboardLinks.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DashboardShell.d.ts","sourceRoot":"","sources":["../../src/components/DashboardShell.tsx"],"names":[],"mappings":"AAcA,OAAO,EAAE,KAAK,SAAS,EAA4C,MAAM,OAAO,CAAC;AAMjF,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"DashboardShell.d.ts","sourceRoot":"","sources":["../../src/components/DashboardShell.tsx"],"names":[],"mappings":"AAcA,OAAO,EAAE,KAAK,SAAS,EAA4C,MAAM,OAAO,CAAC;AAMjF,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAM1D,UAAU,mBAAmB;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,KAAK,CAAC,EAAE,aAAa,EAAE,CAAC;IACxB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,SAAS,CAAC;IACpB,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED,wBAAgB,cAAc,CAAC,EAC7B,KAAK,EACL,WAAW,EACX,IAAI,EACJ,KAAK,EACL,YAAY,EACZ,OAAO,EACP,OAAO,EACP,QAAQ,GACT,EAAE,mBAAmB,2CA+PrB"}
|
|
@@ -20,6 +20,8 @@ import { TagPills } from "./TagPills";
|
|
|
20
20
|
import { DashboardLinks } from "./DashboardLinks";
|
|
21
21
|
import { RefreshControl, parseRefreshParam } from "./RefreshControl";
|
|
22
22
|
import { RefreshProvider } from "./RefreshContext";
|
|
23
|
+
import { PanelExpansionContext } from "./PanelExpansionContext";
|
|
24
|
+
import { PanelFullscreenOverlay } from "./PanelFullscreenOverlay";
|
|
23
25
|
export function DashboardShell({ title, description, tags, links, filterParams, refresh, filters, children, }) {
|
|
24
26
|
const revalidator = useRevalidator();
|
|
25
27
|
const [searchParams, setSearchParams] = useSearchParams();
|
|
@@ -33,6 +35,43 @@ export function DashboardShell({ title, description, tags, links, filterParams,
|
|
|
33
35
|
const isFullscreen = searchParams.get("fullscreen") === "1";
|
|
34
36
|
const [hintHidden, setHintHidden] = useState(false);
|
|
35
37
|
const hintVisible = !isFullscreen || !hintHidden;
|
|
38
|
+
// ── Panel fullscreen state ──────────────────────────────────────────────────
|
|
39
|
+
const [expandedPanelInfo, setExpandedPanelInfo] = useState(null);
|
|
40
|
+
const focusedPanelId = searchParams.get("panel");
|
|
41
|
+
// If the page is loaded/refreshed with ?panel= already in the URL but no
|
|
42
|
+
// stored panel info (we can't reconstruct it from the URL alone), clean up
|
|
43
|
+
// the stale param on mount.
|
|
44
|
+
const didMountRef = useRef(false);
|
|
45
|
+
useEffect(() => {
|
|
46
|
+
if (!didMountRef.current) {
|
|
47
|
+
didMountRef.current = true;
|
|
48
|
+
if (focusedPanelId && !expandedPanelInfo) {
|
|
49
|
+
setSearchParams((prev) => {
|
|
50
|
+
const next = new URLSearchParams(prev);
|
|
51
|
+
next.delete("panel");
|
|
52
|
+
return next;
|
|
53
|
+
}, { preventScrollReset: true });
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
57
|
+
}, []);
|
|
58
|
+
const handlePanelExpand = useCallback((info) => {
|
|
59
|
+
setExpandedPanelInfo(info);
|
|
60
|
+
setSearchParams((prev) => {
|
|
61
|
+
const next = new URLSearchParams(prev);
|
|
62
|
+
next.set("panel", info.panelId);
|
|
63
|
+
return next;
|
|
64
|
+
}, { preventScrollReset: true });
|
|
65
|
+
}, [setSearchParams]);
|
|
66
|
+
const handlePanelClose = useCallback(() => {
|
|
67
|
+
setExpandedPanelInfo(null);
|
|
68
|
+
setSearchParams((prev) => {
|
|
69
|
+
const next = new URLSearchParams(prev);
|
|
70
|
+
next.delete("panel");
|
|
71
|
+
return next;
|
|
72
|
+
}, { preventScrollReset: true });
|
|
73
|
+
}, [setSearchParams]);
|
|
74
|
+
// ── Dashboard fullscreen ────────────────────────────────────────────────────
|
|
36
75
|
// Hide the exit hint after a delay when entering fullscreen; reset when leaving
|
|
37
76
|
useEffect(() => {
|
|
38
77
|
if (!isFullscreen) {
|
|
@@ -40,7 +79,7 @@ export function DashboardShell({ title, description, tags, links, filterParams,
|
|
|
40
79
|
}
|
|
41
80
|
const timer = setTimeout(() => setHintHidden(true), 1500);
|
|
42
81
|
const handleKeyDown = (e) => {
|
|
43
|
-
if (e.key === "Escape") {
|
|
82
|
+
if (e.key === "Escape" && !e.defaultPrevented) {
|
|
44
83
|
setSearchParams((prev) => {
|
|
45
84
|
const next = new URLSearchParams(prev);
|
|
46
85
|
next.delete("fullscreen");
|
|
@@ -112,11 +151,8 @@ export function DashboardShell({ title, description, tags, links, filterParams,
|
|
|
112
151
|
return next;
|
|
113
152
|
}, { preventScrollReset: true });
|
|
114
153
|
}, [setSearchParams]);
|
|
115
|
-
return (_jsxs("div", { className: "px-6 py-6 flex-1", children: [_jsxs("div", { className: "flex flex-col xl:flex-row xl:items-start gap-4 mb-6", children: [_jsxs("div", { className: "shrink-0", children: [_jsxs("div", { className: "flex items-baseline gap-2", children: [_jsx("h1", { className: "text-3xl font-extrabold", style: { color: "var(--text-title)", letterSpacing: "-0.03em" }, children: title }), _jsx("button", { onClick: toggleFullscreen, title: isFullscreen ? "Exit full screen" : "Enter full screen", className: "rounded p-0.5 transition opacity-30 hover:opacity-70", style: { color: "var(--text-muted)" }, children: isFullscreen ? _jsx(Minimize2, { className: "w-4 h-4" }) : _jsx(Maximize2, { className: "w-4 h-4" }) })] }), description && _jsx(DashboardDescription, { description: description }), tags && tags.length > 0 && (_jsx("div", { className: "mt-2", children: _jsx(TagPills, { tags: tags, linkBase: "/dashboards" }) })), links && links.length > 0 && (_jsx("div", { className: "mt-2", children: _jsx(DashboardLinks, { links: links, filterParams: filterParams ?? "" }) }))] }), _jsxs("div", { className: "flex items-start gap-3 xl:ml-auto xl:mt-1", children: [filters, _jsxs("div", { className: "shrink-0 flex items-center gap-2", children: [_jsx("div", { className: "hidden xl:block self-stretch", style: { width: 1, backgroundColor: "var(--panel-border)" } }), _jsx(RefreshControl, { currentValue: activeRefreshValue, isRefreshing: isRefreshing, lastRefreshedAt: lastRefreshedAt, onRefresh: doRefresh, onChangeInterval: handleChangeInterval })] })] })] }), _jsx(RefreshProvider, { value: refreshKey, children: children }), isFullscreen && (_jsxs("div", { className: "fixed top-0 inset-x-0 z-50 group", children: [_jsx("div", { className: "h-4 w-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
background: "rgba(10, 12, 20, 0.95)",
|
|
119
|
-
borderColor: "var(--panel-border)",
|
|
120
|
-
}, children: _jsxs("div", { className: "flex items-center justify-between px-6 py-2 gap-4", children: [_jsxs("div", { className: "flex items-baseline gap-2 shrink-0", children: [_jsx("span", { className: "font-semibold text-sm", style: { color: "var(--text-title)" }, children: title }), _jsx("button", { onClick: toggleFullscreen, title: "Exit full screen", className: "rounded p-0.5 transition opacity-50 hover:opacity-90", style: { color: "var(--text-muted)" }, children: _jsx(Minimize2, { className: "w-3.5 h-3.5" }) })] }), _jsxs("div", { className: "flex items-center gap-2 ml-auto", children: [filters, _jsx("div", { className: "self-stretch", style: { width: 1, backgroundColor: "var(--panel-border)" } }), _jsx(RefreshControl, { currentValue: activeRefreshValue, isRefreshing: isRefreshing, lastRefreshedAt: lastRefreshedAt, onRefresh: doRefresh, onChangeInterval: handleChangeInterval })] })] }) })] }))] }));
|
|
154
|
+
return (_jsx(PanelExpansionContext.Provider, { value: { expandedPanelId: focusedPanelId, onExpand: handlePanelExpand }, children: _jsxs("div", { className: "px-6 py-6 flex-1", children: [_jsxs("div", { className: "flex flex-col xl:flex-row xl:items-start gap-4 mb-6", children: [_jsxs("div", { className: "shrink-0", children: [_jsxs("div", { className: "flex items-baseline gap-2", children: [_jsx("h1", { className: "text-3xl font-extrabold", style: { color: "var(--text-title)", letterSpacing: "-0.03em" }, children: title }), _jsx("button", { onClick: toggleFullscreen, title: isFullscreen ? "Exit full screen" : "Enter full screen", className: "rounded p-0.5 transition opacity-30 hover:opacity-70", style: { color: "var(--text-muted)" }, children: isFullscreen ? _jsx(Minimize2, { className: "w-4 h-4" }) : _jsx(Maximize2, { className: "w-4 h-4" }) })] }), description && _jsx(DashboardDescription, { description: description }), tags && tags.length > 0 && (_jsx("div", { className: "mt-2", children: _jsx(TagPills, { tags: tags, linkBase: "/dashboards" }) })), links && links.length > 0 && (_jsx("div", { className: "mt-2", children: _jsx(DashboardLinks, { links: links, filterParams: filterParams ?? "" }) }))] }), _jsxs("div", { className: "flex items-start gap-3 xl:ml-auto xl:mt-1", children: [filters, _jsxs("div", { className: "shrink-0 flex items-center gap-2", children: [_jsx("div", { className: "hidden xl:block self-stretch", style: { width: 1, backgroundColor: "var(--panel-border)" } }), _jsx(RefreshControl, { currentValue: activeRefreshValue, isRefreshing: isRefreshing, lastRefreshedAt: lastRefreshedAt, onRefresh: doRefresh, onChangeInterval: handleChangeInterval })] })] })] }), _jsx(RefreshProvider, { value: refreshKey, children: children }), isFullscreen && (_jsxs("div", { className: "fixed top-0 inset-x-0 z-50 flex justify-center group", children: [_jsx("div", { className: "h-4 w-64" }), _jsxs("button", { onClick: toggleFullscreen, style: { background: "rgba(0, 0, 0, 0.85)" }, className: `absolute top-0 flex items-center gap-2 text-white rounded-b-lg px-4 py-2 text-sm font-medium shadow-lg backdrop-blur-sm transition-transform duration-300 ease-in-out ${hintVisible
|
|
155
|
+
? "translate-y-0"
|
|
156
|
+
: "-translate-y-full group-hover:translate-y-0"}`, children: [_jsx(Minimize2, { className: "w-4 h-4" }), "Exit Full Screen"] })] })), expandedPanelInfo && (_jsx(PanelFullscreenOverlay, { info: expandedPanelInfo, onClose: handlePanelClose }))] }) }));
|
|
121
157
|
}
|
|
122
158
|
//# sourceMappingURL=DashboardShell.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DashboardShell.js","sourceRoot":"","sources":["../../src/components/DashboardShell.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,EAAkB,SAAS,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AACjF,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/D,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACpD,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,OAAO,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrE,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"DashboardShell.js","sourceRoot":"","sources":["../../src/components/DashboardShell.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NotificationIndicator.d.ts","sourceRoot":"","sources":["../../src/components/NotificationIndicator.tsx"],"names":[],"mappings":"AAgBA,UAAU,0BAA0B;IAClC,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB;AAED,wBAAgB,qBAAqB,CAAC,EAAE,OAAO,EAAE,EAAE,0BAA0B,
|
|
1
|
+
{"version":3,"file":"NotificationIndicator.d.ts","sourceRoot":"","sources":["../../src/components/NotificationIndicator.tsx"],"names":[],"mappings":"AAgBA,UAAU,0BAA0B;IAClC,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB;AAED,wBAAgB,qBAAqB,CAAC,EAAE,OAAO,EAAE,EAAE,0BAA0B,kDAyB5E"}
|
|
@@ -17,8 +17,9 @@ export function NotificationIndicator({ onClick }) {
|
|
|
17
17
|
const { status, count } = useNotificationContext();
|
|
18
18
|
if (status === "healthy")
|
|
19
19
|
return null;
|
|
20
|
-
const
|
|
21
|
-
const
|
|
22
|
-
|
|
20
|
+
const isError = status === "error";
|
|
21
|
+
const dotClass = isError ? "bg-red-500" : "bg-amber-500";
|
|
22
|
+
const textClass = isError ? "text-red-400" : "text-amber-400";
|
|
23
|
+
return (_jsxs("button", { type: "button", onClick: onClick, className: "flex items-center gap-1.5 text-sm hover:opacity-80 transition", "aria-label": `${count} system notification${count !== 1 ? "s" : ""}`, children: [_jsx("span", { "data-testid": "status-dot", className: `w-2 h-2 rounded-full ${dotClass}` }), _jsx("span", { className: textClass, children: count })] }));
|
|
23
24
|
}
|
|
24
25
|
//# sourceMappingURL=NotificationIndicator.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NotificationIndicator.js","sourceRoot":"","sources":["../../src/components/NotificationIndicator.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,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AAMzE,MAAM,UAAU,qBAAqB,CAAC,EAAE,OAAO,EAA8B;IAC3E,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,sBAAsB,EAAE,CAAC;IAEnD,IAAI,MAAM,KAAK,SAAS;QAAE,OAAO,IAAI,CAAC;IAEtC,MAAM,
|
|
1
|
+
{"version":3,"file":"NotificationIndicator.js","sourceRoot":"","sources":["../../src/components/NotificationIndicator.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,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AAMzE,MAAM,UAAU,qBAAqB,CAAC,EAAE,OAAO,EAA8B;IAC3E,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,sBAAsB,EAAE,CAAC;IAEnD,IAAI,MAAM,KAAK,SAAS;QAAE,OAAO,IAAI,CAAC;IAEtC,MAAM,OAAO,GAAG,MAAM,KAAK,OAAO,CAAC;IACnC,MAAM,QAAQ,GAAG,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,cAAc,CAAC;IACzD,MAAM,SAAS,GAAG,OAAO,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,gBAAgB,CAAC;IAE9D,OAAO,CACL,kBACE,IAAI,EAAC,QAAQ,EACb,OAAO,EAAE,OAAO,EAChB,SAAS,EAAC,+DAA+D,gBAC7D,GAAG,KAAK,uBAAuB,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,aAEnE,8BACc,YAAY,EACxB,SAAS,EAAE,wBAAwB,QAAQ,EAAE,GAC7C,EACF,eAAM,SAAS,EAAE,SAAS,YACvB,KAAK,GACD,IACA,CACV,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
export interface ExpandOrigin {
|
|
2
|
+
x: number;
|
|
3
|
+
y: number;
|
|
4
|
+
}
|
|
5
|
+
export interface ExpandInfo {
|
|
6
|
+
panelId: string;
|
|
7
|
+
panel: Record<string, unknown>;
|
|
8
|
+
slug: string;
|
|
9
|
+
origin: ExpandOrigin;
|
|
10
|
+
}
|
|
11
|
+
export interface PanelExpansionContextValue {
|
|
12
|
+
expandedPanelId: string | null;
|
|
13
|
+
onExpand: (info: ExpandInfo) => void;
|
|
14
|
+
}
|
|
15
|
+
export declare const PanelExpansionContext: import("react").Context<PanelExpansionContextValue>;
|
|
16
|
+
export declare function usePanelExpansion(): PanelExpansionContextValue;
|
|
17
|
+
/**
|
|
18
|
+
* Converts an absolute DOMRect position to viewport-relative fractions (0–1).
|
|
19
|
+
* Exported for testing.
|
|
20
|
+
*/
|
|
21
|
+
export declare function computeExpandOrigin(rect: Pick<DOMRect, "left" | "top">, viewportWidth: number, viewportHeight: number): ExpandOrigin;
|
|
22
|
+
//# sourceMappingURL=PanelExpansionContext.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PanelExpansionContext.d.ts","sourceRoot":"","sources":["../../src/components/PanelExpansionContext.tsx"],"names":[],"mappings":"AAUA,MAAM,WAAW,YAAY;IAC3B,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;CACX;AAED,MAAM,WAAW,UAAU;IACzB,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,YAAY,CAAC;CACtB;AAED,MAAM,WAAW,0BAA0B;IACzC,eAAe,EAAE,MAAM,GAAG,IAAI,CAAC;IAC/B,QAAQ,EAAE,CAAC,IAAI,EAAE,UAAU,KAAK,IAAI,CAAC;CACtC;AAED,eAAO,MAAM,qBAAqB,qDAGhC,CAAC;AAEH,wBAAgB,iBAAiB,IAAI,0BAA0B,CAE9D;AAED;;;GAGG;AACH,wBAAgB,mBAAmB,CACjC,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,KAAK,CAAC,EACnC,aAAa,EAAE,MAAM,EACrB,cAAc,EAAE,MAAM,GACrB,YAAY,CAKd"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
// Copyright 2026 Mataki Labs LLC
|
|
2
|
+
//
|
|
3
|
+
// Licensed under the Business Source License 1.1 (the "License");
|
|
4
|
+
// you may not use this file except in compliance with the License.
|
|
5
|
+
// You may obtain a copy of the License at
|
|
6
|
+
//
|
|
7
|
+
// https://github.com/panoboard/panoboard/blob/main/LICENSE
|
|
8
|
+
import { createContext, useContext } from "react";
|
|
9
|
+
export const PanelExpansionContext = createContext({
|
|
10
|
+
expandedPanelId: null,
|
|
11
|
+
onExpand: () => { },
|
|
12
|
+
});
|
|
13
|
+
export function usePanelExpansion() {
|
|
14
|
+
return useContext(PanelExpansionContext);
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Converts an absolute DOMRect position to viewport-relative fractions (0–1).
|
|
18
|
+
* Exported for testing.
|
|
19
|
+
*/
|
|
20
|
+
export function computeExpandOrigin(rect, viewportWidth, viewportHeight) {
|
|
21
|
+
return {
|
|
22
|
+
x: Math.min(1, Math.max(0, rect.left / viewportWidth)),
|
|
23
|
+
y: Math.min(1, Math.max(0, rect.top / viewportHeight)),
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=PanelExpansionContext.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PanelExpansionContext.js","sourceRoot":"","sources":["../../src/components/PanelExpansionContext.tsx"],"names":[],"mappings":"AAAA,iCAAiC;AACjC,EAAE;AACF,kEAAkE;AAClE,mEAAmE;AACnE,0CAA0C;AAC1C,EAAE;AACF,+DAA+D;AAE/D,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAmBlD,MAAM,CAAC,MAAM,qBAAqB,GAAG,aAAa,CAA6B;IAC7E,eAAe,EAAE,IAAI;IACrB,QAAQ,EAAE,GAAG,EAAE,GAAE,CAAC;CACnB,CAAC,CAAC;AAEH,MAAM,UAAU,iBAAiB;IAC/B,OAAO,UAAU,CAAC,qBAAqB,CAAC,CAAC;AAC3C,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,mBAAmB,CACjC,IAAmC,EACnC,aAAqB,EACrB,cAAsB;IAEtB,OAAO;QACL,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,IAAI,GAAG,aAAa,CAAC,CAAC;QACtD,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,GAAG,cAAc,CAAC,CAAC;KACvD,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { ExpandInfo } from "./PanelExpansionContext";
|
|
2
|
+
interface PanelFullscreenOverlayProps {
|
|
3
|
+
info: ExpandInfo;
|
|
4
|
+
onClose: () => void;
|
|
5
|
+
}
|
|
6
|
+
export declare function PanelFullscreenOverlay({ info, onClose }: PanelFullscreenOverlayProps): import("react").ReactPortal;
|
|
7
|
+
export {};
|
|
8
|
+
//# sourceMappingURL=PanelFullscreenOverlay.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PanelFullscreenOverlay.d.ts","sourceRoot":"","sources":["../../src/components/PanelFullscreenOverlay.tsx"],"names":[],"mappings":"AAYA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAE1D,UAAU,2BAA2B;IACnC,IAAI,EAAE,UAAU,CAAC;IACjB,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB;AAED,wBAAgB,sBAAsB,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,2BAA2B,+BA8EpF"}
|
|
@@ -0,0 +1,45 @@
|
|
|
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
|
+
import { useState, useEffect } from "react";
|
|
10
|
+
import { createPortal } from "react-dom";
|
|
11
|
+
import { Minimize2 } from "lucide-react";
|
|
12
|
+
import { PanelWrapper } from "./PanelWrapper";
|
|
13
|
+
export function PanelFullscreenOverlay({ info, onClose }) {
|
|
14
|
+
const [isClosing, setIsClosing] = useState(false);
|
|
15
|
+
// Escape key closes the panel fullscreen
|
|
16
|
+
useEffect(() => {
|
|
17
|
+
function handleKeyDown(e) {
|
|
18
|
+
if (e.key === "Escape") {
|
|
19
|
+
e.preventDefault();
|
|
20
|
+
handleClose();
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
window.addEventListener("keydown", handleKeyDown);
|
|
24
|
+
return () => window.removeEventListener("keydown", handleKeyDown);
|
|
25
|
+
// Re-subscribe when isClosing changes so handleClose sees the latest value
|
|
26
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
27
|
+
}, [isClosing]);
|
|
28
|
+
function handleClose() {
|
|
29
|
+
if (!isClosing)
|
|
30
|
+
setIsClosing(true);
|
|
31
|
+
}
|
|
32
|
+
function handleAnimationEnd(e) {
|
|
33
|
+
// Only fire on the overlay element's own animation, not children
|
|
34
|
+
if (isClosing && e.currentTarget === e.target && e.animationName === "panel-contract") {
|
|
35
|
+
onClose();
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
const originX = `${info.origin.x * 100}%`;
|
|
39
|
+
const originY = `${info.origin.y * 100}%`;
|
|
40
|
+
return createPortal(_jsxs(_Fragment, { children: [_jsx("div", { className: `fixed inset-0 z-9998 bg-black ${isClosing ? "backdrop-out" : "backdrop-in"}`, onClick: handleClose, "aria-hidden": "true" }), _jsxs("div", { className: `fixed inset-4 z-9999 flex flex-col glass-overlay overflow-hidden ${isClosing ? "panel-fullscreen-contract" : "panel-fullscreen-expand"}`, style: {
|
|
41
|
+
"--expand-origin-x": originX,
|
|
42
|
+
"--expand-origin-y": originY,
|
|
43
|
+
}, onAnimationEnd: handleAnimationEnd, role: "dialog", "aria-modal": "true", "aria-label": `${String(info.panel.title ?? "Panel")} - fullscreen`, children: [_jsxs("div", { className: "fixed top-0 inset-x-0 z-10000 flex justify-center group", children: [_jsx("div", { className: "h-4 w-64" }), _jsxs("button", { onClick: handleClose, style: { background: "rgba(0, 0, 0, 0.85)" }, className: "-translate-y-full group-hover:translate-y-0 absolute top-0 flex items-center gap-2 text-white rounded-b-lg px-4 py-2 text-sm font-medium shadow-lg backdrop-blur-sm transition-transform duration-300 ease-in-out", children: [_jsx(Minimize2, { className: "w-4 h-4" }), "Exit Full Screen"] })] }), _jsx("div", { className: "flex-1 min-h-0", children: _jsx(PanelWrapper, { slug: info.slug, panel: info.panel, isExpanded: true, onCollapse: handleClose }) })] })] }), document.body);
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=PanelFullscreenOverlay.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PanelFullscreenOverlay.js","sourceRoot":"","sources":["../../src/components/PanelFullscreenOverlay.tsx"],"names":[],"mappings":";AAAA,iCAAiC;AACjC,EAAE;AACF,kEAAkE;AAClE,mEAAmE;AACnE,0CAA0C;AAC1C,EAAE;AACF,+DAA+D;AAE/D,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAQ9C,MAAM,UAAU,sBAAsB,CAAC,EAAE,IAAI,EAAE,OAAO,EAA+B;IACnF,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAElD,yCAAyC;IACzC,SAAS,CAAC,GAAG,EAAE;QACb,SAAS,aAAa,CAAC,CAAgB;YACrC,IAAI,CAAC,CAAC,GAAG,KAAK,QAAQ,EAAE,CAAC;gBACvB,CAAC,CAAC,cAAc,EAAE,CAAC;gBACnB,WAAW,EAAE,CAAC;YAChB,CAAC;QACH,CAAC;QACD,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;QAClD,OAAO,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,aAAa,CAAC,CAAC;QAClE,2EAA2E;QAC3E,uDAAuD;IACzD,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;IAEhB,SAAS,WAAW;QAClB,IAAI,CAAC,SAAS;YAAE,YAAY,CAAC,IAAI,CAAC,CAAC;IACrC,CAAC;IAED,SAAS,kBAAkB,CAAC,CAAuC;QACjE,iEAAiE;QACjE,IAAI,SAAS,IAAI,CAAC,CAAC,aAAa,KAAK,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,aAAa,KAAK,gBAAgB,EAAE,CAAC;YACtF,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC;IAED,MAAM,OAAO,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;IAC1C,MAAM,OAAO,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;IAE1C,OAAO,YAAY,CACjB,8BAEE,cACE,SAAS,EAAE,iCAAiC,SAAS,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,aAAa,EAAE,EACxF,OAAO,EAAE,WAAW,iBACR,MAAM,GAClB,EAEF,eACE,SAAS,EAAE,oEAAoE,SAAS,CAAC,CAAC,CAAC,2BAA2B,CAAC,CAAC,CAAC,yBAAyB,EAAE,EACpJ,KAAK,EACH;oBACE,mBAAmB,EAAE,OAAO;oBAC5B,mBAAmB,EAAE,OAAO;iBACN,EAE1B,cAAc,EAAE,kBAAkB,EAClC,IAAI,EAAC,QAAQ,gBACF,MAAM,gBACL,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,OAAO,CAAC,eAAe,aAGjE,eAAK,SAAS,EAAC,yDAAyD,aACtE,cAAK,SAAS,EAAC,UAAU,GAAG,EAC5B,kBACE,OAAO,EAAE,WAAW,EACpB,KAAK,EAAE,EAAE,UAAU,EAAE,qBAAqB,EAAE,EAC5C,SAAS,EAAC,mNAAmN,aAE7N,KAAC,SAAS,IAAC,SAAS,EAAC,SAAS,GAAG,wBAE1B,IACL,EAEN,cAAK,SAAS,EAAC,gBAAgB,YAC7B,KAAC,YAAY,IACX,IAAI,EAAE,IAAI,CAAC,IAAI,EACf,KAAK,EAAE,IAAI,CAAC,KAAK,EACjB,UAAU,QACV,UAAU,EAAE,WAAW,GACvB,GACE,IACF,IACL,EACH,QAAQ,CAAC,IAAI,CACd,CAAC;AACJ,CAAC"}
|
|
@@ -3,7 +3,9 @@ interface PanelWrapperProps {
|
|
|
3
3
|
panel: Record<string, unknown>;
|
|
4
4
|
filterParams?: string;
|
|
5
5
|
index?: number;
|
|
6
|
+
isExpanded?: boolean;
|
|
7
|
+
onCollapse?: () => void;
|
|
6
8
|
}
|
|
7
|
-
export declare function PanelWrapper({ slug, panel, index }: PanelWrapperProps): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
export declare function PanelWrapper({ slug, panel, index, isExpanded, onCollapse }: PanelWrapperProps): import("react/jsx-runtime").JSX.Element;
|
|
8
10
|
export {};
|
|
9
11
|
//# sourceMappingURL=PanelWrapper.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PanelWrapper.d.ts","sourceRoot":"","sources":["../../src/components/PanelWrapper.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"PanelWrapper.d.ts","sourceRoot":"","sources":["../../src/components/PanelWrapper.tsx"],"names":[],"mappings":"AAqCA,UAAU,iBAAiB;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,IAAI,CAAC;CACzB;AAED,wBAAgB,YAAY,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,UAAU,EAAE,EAAE,iBAAiB,2CAuB7F"}
|
|
@@ -14,7 +14,7 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
14
14
|
// limitations under the License.
|
|
15
15
|
import { Suspense, useEffect, useRef, useState } from "react";
|
|
16
16
|
import { createPortal } from "react-dom";
|
|
17
|
-
import { Info } from "lucide-react";
|
|
17
|
+
import { Info, Maximize2, Minimize2 } from "lucide-react";
|
|
18
18
|
import { useLoaderData, useFetcher, useSearchParams } from "react-router";
|
|
19
19
|
import { ThemeProvider } from "../theme/context";
|
|
20
20
|
import { PanelSkeleton } from "./panels/PanelSkeleton";
|
|
@@ -31,28 +31,46 @@ import { GaugePanel } from "./panels/GaugePanel";
|
|
|
31
31
|
import { HistogramPanel } from "./panels/HistogramPanel";
|
|
32
32
|
import { panelRegistry } from "./panels/index";
|
|
33
33
|
import { useRefreshKey } from "./RefreshContext";
|
|
34
|
-
|
|
34
|
+
import { usePanelExpansion, computeExpandOrigin } from "./PanelExpansionContext";
|
|
35
|
+
export function PanelWrapper({ slug, panel, index, isExpanded, onCollapse }) {
|
|
35
36
|
// Read panelThemes from the dashboard route loader
|
|
36
37
|
const loaderData = useLoaderData();
|
|
37
38
|
const panelThemes = loaderData?.panelThemes;
|
|
38
39
|
const panelTheme = panelThemes?.[panel.id];
|
|
39
|
-
const inner = _jsx(PanelWrapperInner, { slug: slug, panel: panel, index: index });
|
|
40
|
+
const inner = (_jsx(PanelWrapperInner, { slug: slug, panel: panel, index: index, isExpanded: isExpanded, onCollapse: onCollapse }));
|
|
40
41
|
if (panelTheme) {
|
|
41
42
|
return _jsx(ThemeProvider, { theme: panelTheme, children: inner });
|
|
42
43
|
}
|
|
43
44
|
return inner;
|
|
44
45
|
}
|
|
45
|
-
function PanelWrapperInner({ slug, panel, index }) {
|
|
46
|
+
function PanelWrapperInner({ slug, panel, index, isExpanded, onCollapse }) {
|
|
46
47
|
const description = panel.description;
|
|
47
48
|
const transparent = panel.transparent;
|
|
48
49
|
const animDelay = Math.min((index ?? 0) * 50, 500);
|
|
49
|
-
|
|
50
|
+
const panelId = panel.id;
|
|
51
|
+
const expandButtonRef = useRef(null);
|
|
52
|
+
const { onExpand } = usePanelExpansion();
|
|
53
|
+
function handleExpandClick() {
|
|
54
|
+
if (isExpanded) {
|
|
55
|
+
onCollapse?.();
|
|
56
|
+
}
|
|
57
|
+
else if (expandButtonRef.current) {
|
|
58
|
+
const rect = expandButtonRef.current.getBoundingClientRect();
|
|
59
|
+
onExpand({
|
|
60
|
+
panelId,
|
|
61
|
+
panel,
|
|
62
|
+
slug,
|
|
63
|
+
origin: computeExpandOrigin(rect, window.innerWidth, window.innerHeight),
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
return (_jsxs("div", { className: `${transparent || isExpanded ? "" : "glass-panel panel-animate z-0"} h-full flex flex-col relative group`, style: transparent || isExpanded ? undefined : { animationDelay: `${animDelay}ms` }, children: [_jsxs("div", { className: "px-5 pt-3.5 pb-2 flex items-center gap-2", style: { borderBottom: "1px solid rgba(255,255,255,0.04)" }, children: [_jsx("h3", { className: "uppercase truncate flex-1", style: {
|
|
50
68
|
fontSize: "10px",
|
|
51
69
|
letterSpacing: "0.15em",
|
|
52
70
|
fontWeight: 600,
|
|
53
71
|
color: "var(--panel-title)",
|
|
54
72
|
opacity: 0.45,
|
|
55
|
-
}, children: panel.title }), description && _jsx(DescriptionTooltip, { description: description })] }), _jsx("div", { className: "flex-1 px-5 pb-5 min-h-0", children: _jsx(Suspense, { fallback: _jsx(PanelSkeleton, { type: panel.type }), children: _jsx(PanelContent, { slug: slug, panel: panel }) }) })] }));
|
|
73
|
+
}, children: panel.title }), description && _jsx(DescriptionTooltip, { description: description }), _jsx("button", { ref: expandButtonRef, type: "button", onClick: handleExpandClick, className: `${isExpanded ? "opacity-40" : "opacity-0 group-hover:opacity-40"} hover:opacity-70! transition cursor-pointer`, style: { color: "var(--text-muted)" }, "aria-label": isExpanded ? "Restore panel" : "Expand panel", children: isExpanded ? (_jsx(Minimize2, { className: "w-3.5 h-3.5" })) : (_jsx(Maximize2, { className: "w-3.5 h-3.5" })) })] }), _jsx("div", { className: "flex-1 px-5 pb-5 min-h-0", children: _jsx(Suspense, { fallback: _jsx(PanelSkeleton, { type: panel.type }), children: _jsx(PanelContent, { slug: slug, panel: panel, isExpanded: isExpanded }) }) })] }));
|
|
56
74
|
}
|
|
57
75
|
function DescriptionTooltip({ description }) {
|
|
58
76
|
const [show, setShow] = useState(false);
|
|
@@ -66,7 +84,7 @@ function DescriptionTooltip({ description }) {
|
|
|
66
84
|
};
|
|
67
85
|
return (_jsxs("div", { className: "flex items-center", children: [_jsx("button", { ref: buttonRef, type: "button", className: "opacity-40 hover:opacity-70 transition cursor-help", style: { color: "var(--text-muted)" }, onMouseEnter: () => { updatePos(); setShow(true); }, onMouseLeave: () => setShow(false), onFocus: () => { updatePos(); setShow(true); }, onBlur: () => setShow(false), "aria-label": "Panel description", children: _jsx(Info, { className: "w-3.5 h-3.5" }) }), show && createPortal(_jsx("div", { className: "fixed z-9999 max-w-xs p-3 rounded-lg shadow-lg glass-overlay text-xs leading-relaxed", style: { color: "var(--text-muted)", top: pos.top, right: pos.right }, role: "tooltip", children: description }), document.body)] }));
|
|
68
86
|
}
|
|
69
|
-
function PanelContent({ slug, panel }) {
|
|
87
|
+
function PanelContent({ slug, panel, isExpanded }) {
|
|
70
88
|
const [searchParams] = useSearchParams();
|
|
71
89
|
// Markdown and iframe panels have no datasource/query — render directly.
|
|
72
90
|
// Wrap in a client-only guard to avoid hydration mismatch (MarkdownPanel
|
|
@@ -86,9 +104,9 @@ function PanelContent({ slug, panel }) {
|
|
|
86
104
|
if (panel.type === "iframe") {
|
|
87
105
|
return _jsx(IframePanel, { panel: panel });
|
|
88
106
|
}
|
|
89
|
-
return _jsx(FetchedPanelContent, { slug: slug, panel: panel });
|
|
107
|
+
return _jsx(FetchedPanelContent, { slug: slug, panel: panel, isExpanded: isExpanded });
|
|
90
108
|
}
|
|
91
|
-
function FetchedPanelContent({ slug, panel }) {
|
|
109
|
+
function FetchedPanelContent({ slug, panel, isExpanded }) {
|
|
92
110
|
const fetcher = useFetcher();
|
|
93
111
|
const [searchParams] = useSearchParams();
|
|
94
112
|
const qString = searchParams.toString();
|
|
@@ -156,12 +174,12 @@ function FetchedPanelContent({ slug, panel }) {
|
|
|
156
174
|
if (!key.startsWith("_"))
|
|
157
175
|
filterValues[key] = value;
|
|
158
176
|
});
|
|
159
|
-
return renderPanel(panel, data, comparisonData, sparklineData, filterValues, flatAnnotations);
|
|
177
|
+
return renderPanel(panel, data, comparisonData, sparklineData, filterValues, flatAnnotations, isExpanded);
|
|
160
178
|
}
|
|
161
|
-
function renderPanel(panel, data, comparisonData, sparklineData, filterValues, annotations) {
|
|
179
|
+
function renderPanel(panel, data, comparisonData, sparklineData, filterValues, annotations, isExpanded) {
|
|
162
180
|
switch (panel.type) {
|
|
163
181
|
case "stat":
|
|
164
|
-
return (_jsx(StatPanel, { panel: panel, data: data, comparisonData: comparisonData, sparklineData: sparklineData, filterValues: filterValues }));
|
|
182
|
+
return (_jsx(StatPanel, { panel: panel, data: data, comparisonData: comparisonData, sparklineData: sparklineData, filterValues: filterValues, isExpanded: isExpanded }));
|
|
165
183
|
case "table":
|
|
166
184
|
return _jsx(TablePanel, { panel: panel, data: data, filterValues: filterValues });
|
|
167
185
|
case "metric":
|