import { DataColumns } from '~/components/data-table/data-table';
import { ProcessStatusFilter } from '../resource-type-filters/resource-type-filters';
import { ContainerRequestResource } from '~/models/container-request';
+import { progressIndicatorActions } from '../progress-indicator/progress-indicator-actions';
export class SubprocessMiddlewareService extends DataExplorerMiddlewareService {
constructor(private services: ServiceRepository, id: string) {
const dataExplorer = getDataExplorer(state.dataExplorer, this.getId());
try {
+ api.dispatch(progressIndicatorActions.START_WORKING(this.getId()));
const parentContainerRequestUuid = state.processPanel.containerRequestUuid;
- if (parentContainerRequestUuid === "") {
- api.dispatch(subprocessPanelActions.CLEAR());
- return;
- }
const parentContainerRequest = await this.services.containerRequestService.get(parentContainerRequestUuid);
- if (!parentContainerRequest.containerUuid) {
- api.dispatch(subprocessPanelActions.CLEAR());
- return;
- }
const containerRequests = await this.services.containerRequestService.list(
{ ...getParams(dataExplorer, parentContainerRequest) });
- if (containerRequests.items.length === 0) {
- api.dispatch(subprocessPanelActions.CLEAR());
- return;
- }
const containerUuids: string[] = containerRequests.items.reduce(
(uuids, { containerUuid }) =>
containerUuid
filters: new FilterBuilder().addIn('uuid', containerUuids).getFilters()
});
- // Populate the actual user view
+ api.dispatch(progressIndicatorActions.PERSIST_STOP_WORKING(this.getId()));
api.dispatch(updateResources(containerRequests.items));
api.dispatch(updateResources(containers.items));
+ // Populate the actual user view
api.dispatch(setItems(containerRequests));
} catch {
+ api.dispatch(progressIndicatorActions.PERSIST_STOP_WORKING(this.getId()));
api.dispatch(couldNotFetchSubprocesses());
}
}
export const PROJECT_PANEL_ID = "projectPanel";
-const DEFAUL_VIEW_MESSAGES = [
+const DEFAULT_VIEW_MESSAGES = [
'Your project is empty.',
'Please create a project or create a collection and upload a data.',
];
dataTableDefaultView={
<DataTableDefaultView
icon={ProjectIcon}
- messages={DEFAUL_VIEW_MESSAGES} />
+ messages={DEFAULT_VIEW_MESSAGES} />
} />
</div>;
}
type SubprocessPanelProps = SubprocessPanelActionProps & SubprocessPanelDataProps;
+const DEFAULT_VIEW_MESSAGES = [
+ 'No subprocesses available for listing.',
+ 'The current process may not have any or none matches current filtering.'
+];
+
export const SubprocessPanelRoot = (props: SubprocessPanelProps) => {
return <DataExplorer
id={SUBPROCESS_PANEL_ID}
dataTableDefaultView={
<DataTableDefaultView
icon={ProcessIcon}
- messages={['This process has no subprocesses.']} />
+ messages={DEFAULT_VIEW_MESSAGES} />
} />;
};
\ No newline at end of file
import { RootState } from "~/store/store";
import { navigateTo } from "~/store/navigation/navigation-action";
import { loadDetailsPanel } from "~/store/details-panel/details-panel-action";
+import { getProcess } from "~/store/processes/process";
const mapDispatchToProps = (dispatch: Dispatch): SubprocessPanelActionProps => ({
onContextMenu: (event, resourceUuid, isAdmin) => {
- const kind = resourceKindToContextMenuKind(resourceUuid);
- if (kind) {
+ const menuKind = resourceKindToContextMenuKind(resourceUuid, isAdmin);
+ const resource = getProcess(resourceUuid);
+ if (menuKind && resource) {
dispatch<any>(openContextMenu(event, {
- name: '',
+ name: resource.name,
uuid: resourceUuid,
ownerUuid: '',
kind: ResourceKind.PROCESS,
- menuKind: kind
+ menuKind
}));
}
},