Skip to content

Commit

Permalink
ui: add option to delete all workflow runs
Browse files Browse the repository at this point in the history
  • Loading branch information
mdonadoni committed Oct 20, 2023
1 parent 7d581f5 commit 8326409
Show file tree
Hide file tree
Showing 4 changed files with 58 additions and 13 deletions.
1 change: 1 addition & 0 deletions CHANGES.rst
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ Changes
Version 0.9.2 (UNRELEASED)
--------------------------

- Adds option to delete all the runs of a workflow.
- Changes Docker image Node version from 16 to 18.

Version 0.9.1 (2023-09-27)
Expand Down
4 changes: 2 additions & 2 deletions reana-ui/src/actions.js
Original file line number Diff line number Diff line change
Expand Up @@ -411,11 +411,11 @@ export function fetchWorkflowRetentionRules(id) {
};
}

export function deleteWorkflow(id, workspace = true) {
export function deleteWorkflow(id, { workspace = true, allRuns = false } = {}) {
return async (dispatch) => {
dispatch({ type: WORKFLOW_DELETE_INIT });
return await client
.deleteWorkflow(id, { workspace })
.deleteWorkflow(id, { workspace, allRuns })
.then((resp) => {
dispatch({ type: WORKFLOW_DELETED, ...resp.data });
dispatch({ type: WORKFLOW_LIST_REFRESH });
Expand Down
4 changes: 2 additions & 2 deletions reana-ui/src/client.js
Original file line number Diff line number Diff line change
Expand Up @@ -151,9 +151,9 @@ class Client {
return this._request(WORKFLOW_RETENTION_RULES_URL(id));
}

deleteWorkflow(id, data) {
deleteWorkflow(id, { workspace, allRuns }) {
return this._request(WORKFLOW_SET_STATUS_URL(id, { status: "deleted" }), {
data,
data: { workspace, all_runs: allRuns },
method: "put",
});
}
Expand Down
62 changes: 53 additions & 9 deletions reana-ui/src/components/WorkflowDeleteModal.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,27 +8,64 @@
under the terms of the MIT License; see LICENSE file for more details.
*/

import { useEffect, useState } from "react";
import { useDispatch, useSelector } from "react-redux";
import { Button, Modal, Message, Icon } from "semantic-ui-react";
import { Button, Checkbox, Icon, Message, Modal } from "semantic-ui-react";

import { deleteWorkflow, closeDeleteWorkflowModal } from "~/actions";
import { closeDeleteWorkflowModal, deleteWorkflow } from "~/actions";
import client from "~/client";
import { NON_DELETED_STATUSES } from "~/config";
import {
getWorkflowDeleteModalOpen,
getWorkflowDeleteModalItem,
getWorkflowDeleteModalOpen,
} from "~/selectors";

export default function WorkflowDeleteModal() {
const dispatch = useDispatch();
const open = useSelector(getWorkflowDeleteModalOpen);
const workflow = useSelector(getWorkflowDeleteModalItem);
const [allRuns, setAllRuns] = useState(false);
const [allRunsTotal, setAllRunsTotal] = useState();

const { id, name, run, size } = workflow ?? {};

useEffect(() => {
// reset local state on workflow change
setAllRuns(false);
setAllRunsTotal(null);
}, [id]);

useEffect(() => {
if (!name) {
return;
}

client
.getWorkflows({
workflowIdOrName: name,
status: NON_DELETED_STATUSES,
// request minimum number of workflows as we are only interested in `total`
pagination: { size: 1, page: 1 },
})
.then((resp) => setAllRunsTotal(resp.data.total))
.catch((err) =>
console.log(
`Error while fetching number of workflows with name ${name}`,
err
)
);
}, [name]);

if (!workflow) return null;

const onCloseModal = () => {
dispatch(closeDeleteWorkflowModal());
};

const { id, name, run, size } = workflow;
const deleteButtonLabel = allRuns
? `Delete ${allRunsTotal ?? "all"} workflows named "${name}"`
: `Delete workflow "${name}#${run}"`;

return (
<Modal open={open} onClose={onCloseModal} closeIcon size="small">
<Modal.Header>Delete workflow</Modal.Header>
Expand All @@ -45,20 +82,27 @@ export default function WorkflowDeleteModal() {
download all the files you want to keep before proceeding.
</Message.Content>
</Message>
<p>
Are you sure you want to delete workflow "{name} #{run}"?
</p>
<Checkbox
label={
<label>
Delete all the runs of the workflow{" "}
{allRunsTotal ? `(${allRunsTotal})` : ""}
</label>
}
onChange={(e, data) => setAllRuns(data.checked)}
checked={allRuns}
/>
</Modal.Content>
<Modal.Actions>
<Button
negative
onClick={() => {
dispatch(deleteWorkflow(id)).then(() => {
dispatch(deleteWorkflow(id, { allRuns })).then(() => {
onCloseModal();
});
}}
>
Delete
{deleteButtonLabel}
</Button>
<Button onClick={onCloseModal}>Cancel</Button>
</Modal.Actions>
Expand Down

0 comments on commit 8326409

Please sign in to comment.