cc-backend/web/frontend/src/Jobs.root.svelte

122 lines
3.2 KiB
Svelte
Raw Normal View History

2022-06-22 11:20:57 +02:00
<script>
import { onMount, getContext } from "svelte";
import { init } from "./utils.js";
import {
Row,
Col,
Button,
Icon,
Card,
Spinner,
} from "@sveltestrap/sveltestrap";
import Filters from "./filters/Filters.svelte";
import JobList from "./joblist/JobList.svelte";
import Refresher from "./joblist/Refresher.svelte";
import Sorting from "./joblist/SortSelection.svelte";
import MetricSelection from "./MetricSelection.svelte";
import TextFilter from "./filters/TextFilter.svelte";
2022-06-22 11:20:57 +02:00
const { query: initq } = init();
2022-06-22 11:20:57 +02:00
const ccconfig = getContext("cc-config");
2022-06-22 11:20:57 +02:00
export let filterPresets = {};
export let authlevel;
export let roles;
2022-06-22 11:20:57 +02:00
let filterComponent; // see why here: https://stackoverflow.com/questions/58287729/how-can-i-export-a-function-from-a-svelte-component-that-changes-a-value-in-the
let jobList,
matchedJobs = null;
let sorting = { field: "startTime", order: "DESC" },
isSortingOpen = false,
isMetricsSelectionOpen = false;
let metrics = filterPresets.cluster
? ccconfig[`plot_list_selectedMetrics:${filterPresets.cluster}`] ||
ccconfig.plot_list_selectedMetrics
: ccconfig.plot_list_selectedMetrics;
let showFootprint = filterPresets.cluster
? !!ccconfig[`plot_list_showFootprint:${filterPresets.cluster}`]
: !!ccconfig.plot_list_showFootprint;
let selectedCluster = filterPresets?.cluster ? filterPresets.cluster : null;
// The filterPresets are handled by the Filters component,
// so we need to wait for it to be ready before we can start a query.
// This is also why JobList component starts out with a paused query.
onMount(() => filterComponent.update());
2022-06-22 11:20:57 +02:00
</script>
<Row>
{#if $initq.fetching}
2022-06-22 11:20:57 +02:00
<Col xs="auto">
<Spinner />
2022-06-22 11:20:57 +02:00
</Col>
{:else if $initq.error}
2022-06-22 11:20:57 +02:00
<Col xs="auto">
<Card body color="danger">{$initq.error.message}</Card>
2022-06-22 11:20:57 +02:00
</Col>
{/if}
</Row>
<Row>
<Col xs="auto">
<Button outline color="primary" on:click={() => (isSortingOpen = true)}>
<Icon name="sort-up" /> Sorting
</Button>
<Button
outline
color="primary"
on:click={() => (isMetricsSelectionOpen = true)}
>
<Icon name="graph-up" /> Metrics
</Button>
<Button disabled outline
>{matchedJobs == null ? "Loading..." : `${matchedJobs} jobs`}</Button
>
</Col>
<Col xs="auto">
<Filters
{filterPresets}
bind:this={filterComponent}
on:update={({ detail }) => {
selectedCluster = detail.filters[0]?.cluster
? detail.filters[0].cluster.eq
: null;
jobList.update(detail.filters);
}}
/>
</Col>
2022-06-22 11:20:57 +02:00
<Col xs="3" style="margin-left: auto;">
<TextFilter
bind:authlevel
bind:roles
on:update={({ detail }) => filterComponent.update(detail)}
/>
</Col>
<Col xs="2">
<Refresher on:reload={() => jobList.refresh()} />
</Col>
2022-06-22 11:20:57 +02:00
</Row>
<br />
2022-06-22 11:20:57 +02:00
<Row>
<Col>
<JobList
bind:metrics
bind:sorting
bind:matchedJobs
bind:this={jobList}
bind:showFootprint
/>
</Col>
2022-06-22 11:20:57 +02:00
</Row>
<Sorting bind:sorting bind:isOpen={isSortingOpen} />
2022-06-22 11:20:57 +02:00
<MetricSelection
bind:cluster={selectedCluster}
configName="plot_list_selectedMetrics"
bind:metrics
bind:isOpen={isMetricsSelectionOpen}
bind:showFootprint
view="list"
/>