mirror of
				https://github.com/ClusterCockpit/cc-backend
				synced 2025-10-26 14:25:06 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			99 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Svelte
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Svelte
		
	
	
	
	
	
| <!--
 | |
|     @component Selector component for (footprint) metrics to be displayed as histogram
 | |
| 
 | |
|     Properties:
 | |
|     - `cluster String`: Currently selected cluster
 | |
|     - `selectedHistograms [String]`: The currently selected metrics to display as histogram
 | |
|     - ìsOpen Bool`: Is selection opened
 | |
|  -->
 | |
| 
 | |
| <script>
 | |
|   import { getContext } from "svelte";
 | |
|   import {
 | |
|     Modal,
 | |
|     ModalBody,
 | |
|     ModalHeader,
 | |
|     ModalFooter,
 | |
|     Button,
 | |
|     ListGroup,
 | |
|     ListGroupItem,
 | |
|   } from "@sveltestrap/sveltestrap";
 | |
|   import { gql, getContextClient, mutationStore } from "@urql/svelte";
 | |
| 
 | |
|   export let cluster;
 | |
|   export let selectedHistograms;
 | |
|   export let isOpen;
 | |
| 
 | |
|   const client = getContextClient();
 | |
|   const initialized = getContext("initialized");
 | |
| 
 | |
|   function loadHistoMetrics(isInitialized, thisCluster) {
 | |
|     if (!isInitialized) return [];
 | |
| 
 | |
|     if (!thisCluster) {
 | |
|       return getContext("globalMetrics")
 | |
|       .filter((gm) => gm?.footprint)
 | |
|       .map((fgm) => { return fgm.name })
 | |
|     } else {
 | |
|       return getContext("globalMetrics")
 | |
|       .filter((gm) => gm?.availability.find((av) => av.cluster == thisCluster))
 | |
|       .filter((agm) => agm?.footprint)
 | |
|       .map((afgm) => { return afgm.name })
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   const updateConfigurationMutation = ({ name, value }) => {
 | |
|     return mutationStore({
 | |
|       client: client,
 | |
|       query: gql`
 | |
|         mutation ($name: String!, $value: String!) {
 | |
|           updateConfiguration(name: $name, value: $value)
 | |
|         }
 | |
|       `,
 | |
|       variables: { name, value },
 | |
|     });
 | |
|   };
 | |
| 
 | |
|   function updateConfiguration(data) {
 | |
|     updateConfigurationMutation({
 | |
|       name: data.name,
 | |
|       value: JSON.stringify(data.value),
 | |
|     }).subscribe((res) => {
 | |
|       if (res.fetching === false && res.error) {
 | |
|         throw res.error;
 | |
|       }
 | |
|     });
 | |
|   }
 | |
| 
 | |
|   function closeAndApply() {
 | |
|     isOpen = !isOpen;
 | |
|     updateConfiguration({
 | |
|       name: cluster
 | |
|         ? `user_view_histogramMetrics:${cluster}`
 | |
|         : "user_view_histogramMetrics",
 | |
|       value: selectedHistograms,
 | |
|     });
 | |
|   }
 | |
| 
 | |
|   $: availableMetrics = loadHistoMetrics($initialized, cluster);
 | |
| 
 | |
| </script>
 | |
| 
 | |
| <Modal {isOpen} toggle={() => (isOpen = !isOpen)}>
 | |
|   <ModalHeader>Select metrics presented in histograms</ModalHeader>
 | |
|   <ModalBody>
 | |
|     <ListGroup>
 | |
|       {#each availableMetrics as metric (metric)}
 | |
|         <ListGroupItem>
 | |
|           <input type="checkbox" bind:group={selectedHistograms} value={metric} />
 | |
|           {metric}
 | |
|         </ListGroupItem>
 | |
|       {/each}
 | |
|     </ListGroup>
 | |
|   </ModalBody>
 | |
|   <ModalFooter>
 | |
|     <Button color="primary" on:click={closeAndApply}>Close & Apply</Button>
 | |
|     <Button color="secondary" on:click={() => (isOpen = !isOpen)}>Close</Button>
 | |
|   </ModalFooter>
 | |
| </Modal>
 |