X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/97de0bf90660e72220f350483981e35d53a5998f..95563e85e95cae6a4ef6d2c2137fe1a3533ef8db:/src/views/process-panel/process-panel-root.tsx diff --git a/src/views/process-panel/process-panel-root.tsx b/src/views/process-panel/process-panel-root.tsx index 49ce98c03e..df0f7a64bf 100644 --- a/src/views/process-panel/process-panel-root.tsx +++ b/src/views/process-panel/process-panel-root.tsx @@ -9,83 +9,52 @@ import { DefaultView } from '~/components/default-view/default-view'; import { ProcessIcon } from '~/components/icon/icon'; import { Process } from '~/store/processes/process'; import { SubprocessesCard } from './subprocesses-card'; -import { ProcessSubprocesses } from '~/views-components/process-subprocesses/process-subprocesses'; -import { SubprocessesStatus } from '~/views/process-panel/process-subprocesses'; - -type CssRules = 'headerActive' | 'headerCompleted' | 'headerQueued' | 'headerFailed' | 'headerCanceled'; +import { ProcessSubprocesses } from '~/views/process-panel/process-subprocesses'; +import { SubprocessFilterDataProps } from '~/components/subprocess-filter/subprocess-filter'; export interface ProcessPanelRootDataProps { process?: Process; + subprocesses: Array; + filters: Array; + totalSubprocessesLength: number; } export interface ProcessPanelRootActionProps { - onContextMenu: (event: React.MouseEvent) => void; + onContextMenu: (event: React.MouseEvent, process: Process) => void; + onToggle: (status: string) => void; + openProcessInputDialog: (uuid: string) => void; } export type ProcessPanelRootProps = ProcessPanelRootDataProps & ProcessPanelRootActionProps; -export const ProcessPanelRoot = (props: ProcessPanelRootProps) => - props.process - ? - +export const ProcessPanelRoot = ({process, ...props}: ProcessPanelRootProps) => + process + ? + + process={process} + onContextMenu={event => props.onContextMenu(event, process)} + openProcessInputDialog={props.openProcessInputDialog} /> - + { return; }} + subprocessesAmount={props.totalSubprocessesLength} + filters={props.filters} + onToggle={props.onToggle} /> - + + + : + justify='center' + style={{ minHeight: '100%' }}> ; -export const getBackgroundColorStatus = (status: string, classes: Record) => { - switch (status) { - case SubprocessesStatus.COMPLETED: - return classes.headerCompleted; - case SubprocessesStatus.CANCELED: - return classes.headerCanceled; - case SubprocessesStatus.QUEUED: - return classes.headerQueued; - case SubprocessesStatus.FAILED: - return classes.headerFailed; - case SubprocessesStatus.ACTIVE: - return classes.headerActive; - default: - return classes.headerQueued; - } -};