prometheus/web/ui/mantine-ui/src/pages/query/urlStateEncoding.ts
Julius Volz 4efd47741e
Some checks failed
CI / Go tests (push) Has been cancelled
CI / More Go tests (push) Has been cancelled
CI / Go tests with previous Go version (push) Has been cancelled
CI / UI tests (push) Has been cancelled
CI / Go tests on Windows (push) Has been cancelled
CI / Mixins tests (push) Has been cancelled
CI / Build Prometheus for common architectures (0) (push) Has been cancelled
CI / Build Prometheus for common architectures (1) (push) Has been cancelled
CI / Build Prometheus for common architectures (2) (push) Has been cancelled
CI / Build Prometheus for all architectures (0) (push) Has been cancelled
CI / Build Prometheus for all architectures (1) (push) Has been cancelled
CI / Build Prometheus for all architectures (10) (push) Has been cancelled
CI / Build Prometheus for all architectures (11) (push) Has been cancelled
CI / Build Prometheus for all architectures (2) (push) Has been cancelled
CI / Build Prometheus for all architectures (3) (push) Has been cancelled
CI / Build Prometheus for all architectures (4) (push) Has been cancelled
CI / Build Prometheus for all architectures (5) (push) Has been cancelled
CI / Build Prometheus for all architectures (6) (push) Has been cancelled
CI / Build Prometheus for all architectures (7) (push) Has been cancelled
CI / Build Prometheus for all architectures (8) (push) Has been cancelled
CI / Build Prometheus for all architectures (9) (push) Has been cancelled
CI / Check generated parser (push) Has been cancelled
CI / golangci-lint (push) Has been cancelled
CI / fuzzing (push) Has been cancelled
CI / codeql (push) Has been cancelled
CI / Report status of build Prometheus for all architectures (push) Has been cancelled
CI / Publish main branch artifacts (push) Has been cancelled
CI / Publish release artefacts (push) Has been cancelled
CI / Publish UI on npm Registry (push) Has been cancelled
Correctly encode/decode new resolution states in URL
Signed-off-by: Julius Volz <julius.volz@gmail.com>
2024-08-21 18:06:38 +02:00

160 lines
4.6 KiB
TypeScript

import {
GraphDisplayMode,
Panel,
newDefaultPanel,
} from "../../state/queryPageSlice";
import dayjs from "dayjs";
import {
formatPrometheusDuration,
parsePrometheusDuration,
} from "../../lib/formatTime";
export function parseTime(timeText: string): number {
return dayjs.utc(timeText).valueOf();
}
export const decodePanelOptionsFromURLParams = (query: string): Panel[] => {
const urlParams = new URLSearchParams(query);
const panels = [];
for (let i = 0; ; i++) {
if (!urlParams.has(`g${i}.expr`)) {
// Every panel should have an expr, so if we don't find one, we're done.
break;
}
const panel = newDefaultPanel();
const decodeSetting = (setting: string, fn: (_value: string) => void) => {
const param = `g${i}.${setting}`;
if (urlParams.has(param)) {
fn(urlParams.get(param) as string);
}
};
decodeSetting("expr", (value) => {
panel.expr = value;
});
decodeSetting("tab", (value) => {
panel.visualizer.activeTab = value === "0" ? "graph" : "table";
});
decodeSetting("display_mode", (value) => {
panel.visualizer.displayMode = value as GraphDisplayMode;
});
decodeSetting("stacked", (value) => {
panel.visualizer.displayMode =
value === "1" ? GraphDisplayMode.Stacked : GraphDisplayMode.Lines;
});
decodeSetting("show_exemplars", (value) => {
panel.visualizer.showExemplars = value === "1";
});
decodeSetting("range_input", (value) => {
panel.visualizer.range =
parsePrometheusDuration(value) || panel.visualizer.range;
});
decodeSetting("end_input", (value) => {
panel.visualizer.endTime = parseTime(value);
});
// Legacy "step_input" parameter, overriden below by
// "res_type" / "res_density" / "res_step" if present.
decodeSetting("step_input", (value) => {
if (parseInt(value) > 0) {
panel.visualizer.resolution = {
type: "custom",
step: parseInt(value) * 1000,
};
}
});
decodeSetting("res_type", (value) => {
switch (value) {
case "auto":
decodeSetting("res_density", (density) => {
if (["low", "medium", "high"].includes(density)) {
panel.visualizer.resolution = {
type: "auto",
density: density as "low" | "medium" | "high",
};
}
});
break;
case "fixed":
decodeSetting("res_step", (step) => {
panel.visualizer.resolution = {
type: "fixed",
step: parseFloat(step) * 1000,
};
});
break;
case "custom":
decodeSetting("res_step", (step) => {
panel.visualizer.resolution = {
type: "custom",
step: parseFloat(step) * 1000,
};
});
break;
default:
console.log("Unknown resolution type", value);
}
});
decodeSetting("moment_input", (value) => {
panel.visualizer.endTime = parseTime(value);
});
panels.push(panel);
}
return panels;
};
export function formatTime(time: number): string {
return dayjs.utc(time).format("YYYY-MM-DD HH:mm:ss");
}
export const encodePanelOptionsToURLParams = (
panels: Panel[]
): URLSearchParams => {
const params = new URLSearchParams();
const addParam = (idx: number, param: string, value: string) =>
params.append(`g${idx}.${param}`, value);
panels.forEach((p, idx) => {
addParam(idx, "expr", p.expr);
addParam(idx, "tab", p.visualizer.activeTab === "graph" ? "0" : "1");
if (p.visualizer.endTime !== null) {
addParam(idx, "end_input", formatTime(p.visualizer.endTime));
addParam(idx, "moment_input", formatTime(p.visualizer.endTime));
}
addParam(idx, "range_input", formatPrometheusDuration(p.visualizer.range));
switch (p.visualizer.resolution.type) {
case "auto":
addParam(idx, "res_type", "auto");
addParam(idx, "res_density", p.visualizer.resolution.density);
break;
case "fixed":
addParam(idx, "res_type", "fixed");
addParam(
idx,
"res_step",
(p.visualizer.resolution.step / 1000).toString()
);
break;
case "custom":
addParam(idx, "res_type", "custom");
addParam(
idx,
"res_step",
(p.visualizer.resolution.step / 1000).toString()
);
break;
}
addParam(idx, "display_mode", p.visualizer.displayMode);
addParam(idx, "show_exemplars", p.visualizer.showExemplars ? "1" : "0");
});
return params;
};