mirror of
https://github.com/ClusterCockpit/cc-backend
synced 2025-03-14 18:05:56 +01:00
feat: add subCluster level frontend keys for metric selections
- applies to jobView and nodeList
This commit is contained in:
parent
2b56b40e6d
commit
d0af933b35
@ -128,15 +128,24 @@
|
|||||||
if (!job) return;
|
if (!job) return;
|
||||||
|
|
||||||
const pendingMetrics = [
|
const pendingMetrics = [
|
||||||
...(ccconfig[`job_view_selectedMetrics:${job.cluster}`] ||
|
...(
|
||||||
$initq.data.globalMetrics.reduce((names, gm) => {
|
(
|
||||||
if (gm.availability.find((av) => av.cluster === job.cluster && av.subClusters.includes(job.subCluster))) {
|
ccconfig[`job_view_selectedMetrics:${job.cluster}:${job.subCluster}`] ||
|
||||||
names.push(gm.name);
|
ccconfig[`job_view_selectedMetrics:${job.cluster}`]
|
||||||
}
|
) ||
|
||||||
return names;
|
$initq.data.globalMetrics
|
||||||
}, [])
|
.reduce((names, gm) => {
|
||||||
|
if (gm.availability.find((av) => av.cluster === job.cluster && av.subClusters.includes(job.subCluster))) {
|
||||||
|
names.push(gm.name);
|
||||||
|
}
|
||||||
|
return names;
|
||||||
|
}, [])
|
||||||
),
|
),
|
||||||
...(ccconfig[`job_view_nodestats_selectedMetrics:${job.cluster}`] ||
|
...(
|
||||||
|
(
|
||||||
|
ccconfig[`job_view_nodestats_selectedMetrics:${job.cluster}:${job.subCluster}`] ||
|
||||||
|
ccconfig[`job_view_nodestats_selectedMetrics:${job.cluster}`]
|
||||||
|
) ||
|
||||||
ccconfig[`job_view_nodestats_selectedMetrics`]
|
ccconfig[`job_view_nodestats_selectedMetrics`]
|
||||||
),
|
),
|
||||||
];
|
];
|
||||||
|
@ -137,5 +137,5 @@
|
|||||||
bind:metrics
|
bind:metrics
|
||||||
bind:isOpen={isMetricsSelectionOpen}
|
bind:isOpen={isMetricsSelectionOpen}
|
||||||
bind:showFootprint
|
bind:showFootprint
|
||||||
footprintSelect={true}
|
footprintSelect
|
||||||
/>
|
/>
|
||||||
|
@ -29,8 +29,8 @@
|
|||||||
import Refresher from "./generic/helper/Refresher.svelte";
|
import Refresher from "./generic/helper/Refresher.svelte";
|
||||||
|
|
||||||
export let displayType;
|
export let displayType;
|
||||||
export let cluster;
|
export let cluster = null;
|
||||||
export let subCluster = "";
|
export let subCluster = null;
|
||||||
export let from = null;
|
export let from = null;
|
||||||
export let to = null;
|
export let to = null;
|
||||||
|
|
||||||
@ -60,7 +60,10 @@
|
|||||||
let hostnameFilter = "";
|
let hostnameFilter = "";
|
||||||
let pendingHostnameFilter = "";
|
let pendingHostnameFilter = "";
|
||||||
let selectedMetric = ccconfig.system_view_selectedMetric || "";
|
let selectedMetric = ccconfig.system_view_selectedMetric || "";
|
||||||
let selectedMetrics = ccconfig[`node_list_selectedMetrics:${cluster}`] || [ccconfig.system_view_selectedMetric];
|
let selectedMetrics = (
|
||||||
|
ccconfig[`node_list_selectedMetrics:${cluster}:${subCluster}`] ||
|
||||||
|
ccconfig[`node_list_selectedMetrics:${cluster}`]
|
||||||
|
) || [ccconfig.system_view_selectedMetric];
|
||||||
let isMetricsSelectionOpen = false;
|
let isMetricsSelectionOpen = false;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -191,6 +194,7 @@
|
|||||||
|
|
||||||
<MetricSelection
|
<MetricSelection
|
||||||
{cluster}
|
{cluster}
|
||||||
|
{subCluster}
|
||||||
configName="node_list_selectedMetrics"
|
configName="node_list_selectedMetrics"
|
||||||
metrics={selectedMetrics}
|
metrics={selectedMetrics}
|
||||||
bind:isOpen={isMetricsSelectionOpen}
|
bind:isOpen={isMetricsSelectionOpen}
|
||||||
|
@ -352,7 +352,7 @@
|
|||||||
bind:metrics
|
bind:metrics
|
||||||
bind:isOpen={isMetricsSelectionOpen}
|
bind:isOpen={isMetricsSelectionOpen}
|
||||||
bind:showFootprint
|
bind:showFootprint
|
||||||
footprintSelect={true}
|
footprintSelect
|
||||||
/>
|
/>
|
||||||
|
|
||||||
<HistogramSelection
|
<HistogramSelection
|
||||||
|
@ -47,12 +47,12 @@
|
|||||||
|
|
||||||
$: {
|
$: {
|
||||||
if (allMetrics != null) {
|
if (allMetrics != null) {
|
||||||
if (cluster == null) {
|
if (!cluster) {
|
||||||
for (let metric of globalMetrics) allMetrics.add(metric.name);
|
for (let metric of globalMetrics) allMetrics.add(metric.name);
|
||||||
} else {
|
} else {
|
||||||
allMetrics.clear();
|
allMetrics.clear();
|
||||||
for (let gm of globalMetrics) {
|
for (let gm of globalMetrics) {
|
||||||
if (subCluster == null) {
|
if (!subCluster) {
|
||||||
if (gm.availability.find((av) => av.cluster === cluster)) allMetrics.add(gm.name);
|
if (gm.availability.find((av) => av.cluster === cluster)) allMetrics.add(gm.name);
|
||||||
} else {
|
} else {
|
||||||
if (gm.availability.find((av) => av.cluster === cluster && av.subClusters.includes(subCluster))) allMetrics.add(gm.name);
|
if (gm.availability.find((av) => av.cluster === cluster && av.subClusters.includes(subCluster))) allMetrics.add(gm.name);
|
||||||
@ -67,7 +67,7 @@
|
|||||||
|
|
||||||
function printAvailability(metric, cluster) {
|
function printAvailability(metric, cluster) {
|
||||||
const avail = globalMetrics.find((gm) => gm.name === metric)?.availability
|
const avail = globalMetrics.find((gm) => gm.name === metric)?.availability
|
||||||
if (cluster == null) {
|
if (!cluster) {
|
||||||
return avail.map((av) => av.cluster).join(',')
|
return avail.map((av) => av.cluster).join(',')
|
||||||
} else {
|
} else {
|
||||||
return avail.find((av) => av.cluster === cluster).subClusters.join(',')
|
return avail.find((av) => av.cluster === cluster).subClusters.join(',')
|
||||||
@ -112,10 +112,17 @@
|
|||||||
metrics = newMetricsOrder.filter((m) => unorderedMetrics.includes(m));
|
metrics = newMetricsOrder.filter((m) => unorderedMetrics.includes(m));
|
||||||
isOpen = false;
|
isOpen = false;
|
||||||
|
|
||||||
showFootprint = !!pendingShowFootprint;
|
let configKey;
|
||||||
|
if (cluster && subCluster) {
|
||||||
|
configKey = `${configName}:${cluster}:${subCluster}`;
|
||||||
|
} else if (cluster && !subCluster) {
|
||||||
|
configKey = `${configName}:${cluster}`;
|
||||||
|
} else {
|
||||||
|
configKey = `${configName}`;
|
||||||
|
}
|
||||||
|
|
||||||
updateConfigurationMutation({
|
updateConfigurationMutation({
|
||||||
name: cluster == null ? configName : `${configName}:${cluster}`,
|
name: configKey,
|
||||||
value: JSON.stringify(metrics),
|
value: JSON.stringify(metrics),
|
||||||
}).subscribe((res) => {
|
}).subscribe((res) => {
|
||||||
if (res.fetching === false && res.error) {
|
if (res.fetching === false && res.error) {
|
||||||
@ -123,17 +130,20 @@
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
updateConfigurationMutation({
|
if (footprintSelect) {
|
||||||
name:
|
showFootprint = !!pendingShowFootprint;
|
||||||
cluster == null
|
updateConfigurationMutation({
|
||||||
? "plot_list_showFootprint"
|
name:
|
||||||
: `plot_list_showFootprint:${cluster}`,
|
!cluster
|
||||||
value: JSON.stringify(showFootprint),
|
? "plot_list_showFootprint"
|
||||||
}).subscribe((res) => {
|
: `plot_list_showFootprint:${cluster}`,
|
||||||
if (res.fetching === false && res.error) {
|
value: JSON.stringify(showFootprint),
|
||||||
throw res.error;
|
}).subscribe((res) => {
|
||||||
}
|
if (res.fetching === false && res.error) {
|
||||||
});
|
throw res.error;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
dispatch('update-metrics', metrics);
|
dispatch('update-metrics', metrics);
|
||||||
}
|
}
|
||||||
|
@ -37,9 +37,10 @@
|
|||||||
sorting = {},
|
sorting = {},
|
||||||
isMetricSelectionOpen = false,
|
isMetricSelectionOpen = false,
|
||||||
availableMetrics = new Set(),
|
availableMetrics = new Set(),
|
||||||
selectedMetrics =
|
selectedMetrics = (
|
||||||
getContext("cc-config")[`job_view_nodestats_selectedMetrics:${job.cluster}`] ||
|
getContext("cc-config")[`job_view_nodestats_selectedMetrics:${job.cluster}:${job.subCluster}`] ||
|
||||||
getContext("cc-config")["job_view_nodestats_selectedMetrics"];
|
getContext("cc-config")[`job_view_nodestats_selectedMetrics:${job.cluster}`]
|
||||||
|
) || getContext("cc-config")["job_view_nodestats_selectedMetrics"];
|
||||||
|
|
||||||
for (let metric of sortedJobMetrics) {
|
for (let metric of sortedJobMetrics) {
|
||||||
// Not Exclusive or Multi-Node: get maxScope directly (mostly: node)
|
// Not Exclusive or Multi-Node: get maxScope directly (mostly: node)
|
||||||
|
@ -217,13 +217,15 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td colspan={selectedMetrics.length + 1}>
|
<td colspan={selectedMetrics.length + 1}>
|
||||||
<div style="text-align:center;">
|
<div style="text-align:center;">
|
||||||
<p><b>
|
{#if !usePaging}
|
||||||
Loading nodes {nodes.length + 1} to
|
<p><b>
|
||||||
{ matchedNodes
|
Loading nodes {nodes.length + 1} to
|
||||||
? `${(nodes.length + paging.itemsPerPage) > matchedNodes ? matchedNodes : (nodes.length + paging.itemsPerPage)} of ${matchedNodes} total`
|
{ matchedNodes
|
||||||
: (nodes.length + paging.itemsPerPage)
|
? `${(nodes.length + paging.itemsPerPage) > matchedNodes ? matchedNodes : (nodes.length + paging.itemsPerPage)} of ${matchedNodes} total`
|
||||||
}
|
: (nodes.length + paging.itemsPerPage)
|
||||||
</b></p>
|
}
|
||||||
|
</b></p>
|
||||||
|
{/if}
|
||||||
<Spinner secondary />
|
<Spinner secondary />
|
||||||
</div>
|
</div>
|
||||||
</td>
|
</td>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user