mirror of
				https://github.com/ClusterCockpit/cc-backend
				synced 2025-10-24 22:35:06 +02:00 
			
		
		
		
	Skip render of disabled metrics in job view
-Add function to check if metric is disabled -Relates to #119
This commit is contained in:
		| @@ -1,5 +1,5 @@ | |||||||
| <script> | <script> | ||||||
|     import { init, groupByScope, fetchMetricsStore } from './utils.js' |     import { init, groupByScope, fetchMetricsStore, checkMetricDisabled } from './utils.js' | ||||||
|     import { Row, Col, Card, Spinner, TabContent, TabPane, |     import { Row, Col, Card, Spinner, TabContent, TabPane, | ||||||
|              CardBody, CardHeader, CardTitle, Button, Icon } from 'sveltestrap' |              CardBody, CardHeader, CardTitle, Button, Icon } from 'sveltestrap' | ||||||
|     import PlotTable from './PlotTable.svelte' |     import PlotTable from './PlotTable.svelte' | ||||||
| @@ -95,7 +95,14 @@ | |||||||
|         somethingMissing = missingMetrics.length > 0 || missingHosts.length > 0 |         somethingMissing = missingMetrics.length > 0 || missingHosts.length > 0 | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     const orderAndMap = (grouped, selectedMetrics) => selectedMetrics.map(metric => ({ metric: metric, data: grouped.find((group) => group[0].name == metric) })) |     const orderAndMap = (grouped, selectedMetrics) =>  | ||||||
|  |         selectedMetrics.map(metric => ({  | ||||||
|  |             metric: metric, | ||||||
|  |             data: grouped.find((group) =>  | ||||||
|  |                 group[0].name == metric | ||||||
|  |             ), | ||||||
|  |             disabled: checkMetricDisabled(metric, $initq.data.job.cluster, $initq.data.job.subCluster)  | ||||||
|  |         })) | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <div class="row" bind:clientWidth={fullWidth}></div> | <div class="row" bind:clientWidth={fullWidth}></div> | ||||||
|   | |||||||
| @@ -24,14 +24,13 @@ | |||||||
|                 else |                 else | ||||||
|                     row.push({ _is_placeholder: true, ri, ci }) |                     row.push({ _is_placeholder: true, ri, ci }) | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             rows.push(row) |             rows.push(row) | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         return rows |         return rows | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     $: rows = tile(items, itemsPerRow) |     $: rows = tile(items.filter(item => item.disabled === false), itemsPerRow) | ||||||
|     $: plotWidth = (tableWidth / itemsPerRow) - (padding * itemsPerRow) |     $: plotWidth = (tableWidth / itemsPerRow) - (padding * itemsPerRow) | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -296,3 +296,20 @@ export function stickyHeader(datatableHeaderSelector, updatePading) { | |||||||
|     document.addEventListener("scroll", onscroll); |     document.addEventListener("scroll", onscroll); | ||||||
|     onDestroy(() => document.removeEventListener("scroll", onscroll)); |     onDestroy(() => document.removeEventListener("scroll", onscroll)); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | export function checkMetricDisabled(m, c, s) { //[m]etric, [c]luster, [s]ubcluster | ||||||
|  |     const mc = getContext("metrics"); | ||||||
|  |     const thisConfig = mc(c, m); | ||||||
|  |     let thisSCIndex = -1; | ||||||
|  |     if (thisConfig) { | ||||||
|  |         thisSCIndex = thisConfig.subClusters.findIndex( | ||||||
|  |             (subcluster) => subcluster.name == s | ||||||
|  |         ); | ||||||
|  |     }; | ||||||
|  |     if (thisSCIndex >= 0) { | ||||||
|  |         if (thisConfig.subClusters[thisSCIndex].remove == true) { | ||||||
|  |             return true; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     return false; | ||||||
|  | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user