X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/e7af6c00434d5eb34c72ac714cfd450052185762..717210dfd80d0831c83c08086a3c27cace13ed18:/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 49ce98c0..52c0f451 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; - } -};