X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/f159c2bb8e32579651942e8ba7a53c4d90a9b890..2c2b5e935152a258e2f7b01a15d3fda78c349c88:/src/websocket/websocket.ts diff --git a/src/websocket/websocket.ts b/src/websocket/websocket.ts index e7ea3016c9..506b92c801 100644 --- a/src/websocket/websocket.ts +++ b/src/websocket/websocket.ts @@ -9,11 +9,12 @@ import { WebSocketService } from './websocket-service'; import { ResourceEventMessage } from './resource-event-message'; import { ResourceKind } from '~/models/resource'; import { loadProcess } from '~/store/processes/processes-actions'; -import { loadContainers } from '~/store/processes/processes-actions'; import { LogEventType } from '~/models/log'; import { addProcessLogsPanelItem } from '../store/process-logs-panel/process-logs-panel-actions'; -import { FilterBuilder } from "~/services/api/filter-builder"; -import { snackbarActions, SnackbarKind } from "~/store/snackbar/snackbar-actions"; +import { subprocessPanelActions } from "~/store/subprocess-panel/subprocess-panel-actions"; +import { projectPanelActions } from "~/store/project-panel/project-panel-action"; +import { getProjectPanelCurrentUuid } from '~/store/project-panel/project-panel-action'; +import { allProcessesPanelActions } from '~/store/all-processes-panel/all-processes-panel-action'; export const initWebSocket = (config: Config, authService: AuthService, store: RootStore) => { if (config.websocketUrl) { @@ -21,8 +22,7 @@ export const initWebSocket = (config: Config, authService: AuthService, store: R webSocketService.setMessageListener(messageListener(store)); webSocketService.connect(); } else { - console.warn("WARNING: Websocket ExternalURL is not set on the API Server"); - store.dispatch(snackbarActions.OPEN_SNACKBAR({ message: "Websocket URL missing on cluster config", kind: SnackbarKind.WARNING })); + console.warn("WARNING: Websocket ExternalURL is not set on the cluster config."); } }; @@ -30,15 +30,21 @@ const messageListener = (store: RootStore) => (message: ResourceEventMessage) => if (message.eventType === LogEventType.CREATE || message.eventType === LogEventType.UPDATE) { switch (message.objectKind) { case ResourceKind.CONTAINER_REQUEST: - return store.dispatch(loadProcess(message.objectUuid)); + if (store.getState().processPanel.containerRequestUuid === message.objectUuid) { + store.dispatch(loadProcess(message.objectUuid)); + } + // fall through, this will happen for container requests as well. case ResourceKind.CONTAINER: - return store.dispatch(loadContainers( - new FilterBuilder().addIn('uuid', [message.objectUuid]).getFilters() - )); + store.dispatch(subprocessPanelActions.REQUEST_ITEMS()); + store.dispatch(allProcessesPanelActions.REQUEST_ITEMS()); + if (message.objectOwnerUuid === getProjectPanelCurrentUuid(store.getState())) { + store.dispatch(projectPanelActions.REQUEST_ITEMS()); + } + return; default: return; } } else { - return store.dispatch(addProcessLogsPanelItem(message as ResourceEventMessage<{text: string}>)); + return store.dispatch(addProcessLogsPanelItem(message as ResourceEventMessage<{ text: string }>)); } };