mirror of
https://github.com/n8n-io/n8n.git
synced 2025-03-05 20:50:17 -08:00
feat: Add workflow data reset action (#4618)
* feat: add workflow data reset action * fix: remove console.log * chore: fix linting issues
This commit is contained in:
parent
f7a9ef9116
commit
0daa36c197
|
@ -9,8 +9,6 @@ import {useSettingsStore} from "@/stores/settings";
|
|||
import {defineStore} from "pinia";
|
||||
import {useWorkflowsStore} from "@/stores/workflows";
|
||||
|
||||
// @TODO Move to workflows store as part of workflows store refactoring
|
||||
//
|
||||
export const useWorkflowsEEStore = defineStore(STORES.WORKFLOWS_EE, {
|
||||
state() { return {}; },
|
||||
actions: {
|
||||
|
|
|
@ -1,4 +1,11 @@
|
|||
import { DEFAULT_NEW_WORKFLOW_NAME, DUPLICATE_POSTFFIX, MAX_WORKFLOW_NAME_LENGTH, PLACEHOLDER_EMPTY_WORKFLOW_ID, STORES } from "@/constants";
|
||||
import {
|
||||
DEFAULT_NEW_WORKFLOW_NAME,
|
||||
DUPLICATE_POSTFFIX,
|
||||
EnterpriseEditionFeature,
|
||||
MAX_WORKFLOW_NAME_LENGTH,
|
||||
PLACEHOLDER_EMPTY_WORKFLOW_ID,
|
||||
STORES,
|
||||
} from "@/constants";
|
||||
import {
|
||||
IExecutionResponse,
|
||||
IExecutionsCurrentSummaryExtended,
|
||||
|
@ -13,22 +20,43 @@ import {
|
|||
IWorkflowsMap,
|
||||
WorkflowsState,
|
||||
} from "@/Interface";
|
||||
import { defineStore } from "pinia";
|
||||
import { IConnection, IConnections, IDataObject, INode, INodeConnections, INodeCredentials, INodeCredentialsDetails, INodeExecutionData, INodeIssueData, IPinData, IRunData, ITaskData, IWorkflowSettings } from 'n8n-workflow';
|
||||
import {defineStore} from "pinia";
|
||||
import {
|
||||
IConnection,
|
||||
IConnections,
|
||||
IDataObject,
|
||||
INode,
|
||||
INodeConnections,
|
||||
INodeCredentials,
|
||||
INodeCredentialsDetails,
|
||||
INodeExecutionData,
|
||||
INodeIssueData,
|
||||
IPinData,
|
||||
IRunData,
|
||||
ITaskData,
|
||||
IWorkflowSettings,
|
||||
} from 'n8n-workflow';
|
||||
import Vue from "vue";
|
||||
import { useRootStore } from "./n8nRootStore";
|
||||
import { getActiveWorkflows, getCurrentExecutions, getFinishedExecutions, getNewWorkflow, getWorkflows } from "@/api/workflows";
|
||||
import { useUIStore } from "./ui";
|
||||
import { getPairedItemsMapping } from "@/pairedItemUtils";
|
||||
import { dataPinningEventBus } from "@/event-bus/data-pinning-event-bus";
|
||||
import { isJsonKeyObject } from "@/utils";
|
||||
import { stringSizeInBytes } from "@/components/helpers";
|
||||
import { useNDVStore } from "./ndv";
|
||||
import { useNodeTypesStore } from "./nodeTypes";
|
||||
import {useRootStore} from "./n8nRootStore";
|
||||
import {
|
||||
getActiveWorkflows,
|
||||
getCurrentExecutions,
|
||||
getFinishedExecutions,
|
||||
getNewWorkflow,
|
||||
getWorkflows,
|
||||
} from "@/api/workflows";
|
||||
import {useUIStore} from "./ui";
|
||||
import {getPairedItemsMapping} from "@/pairedItemUtils";
|
||||
import {dataPinningEventBus} from "@/event-bus/data-pinning-event-bus";
|
||||
import {isJsonKeyObject} from "@/utils";
|
||||
import {stringSizeInBytes} from "@/components/helpers";
|
||||
import {useNDVStore} from "./ndv";
|
||||
import {useNodeTypesStore} from "./nodeTypes";
|
||||
import {useWorkflowsEEStore} from "@/stores/workflows.ee";
|
||||
import {useUsersStore} from "@/stores/users";
|
||||
import {useSettingsStore} from "@/stores/settings";
|
||||
|
||||
export const useWorkflowsStore = defineStore(STORES.WORKFLOWS, {
|
||||
state: (): WorkflowsState => ({
|
||||
workflow: {
|
||||
const createEmptyWorkflow = (): IWorkflowDb => ({
|
||||
id: PLACEHOLDER_EMPTY_WORKFLOW_ID,
|
||||
name: '',
|
||||
active: false,
|
||||
|
@ -40,7 +68,11 @@ export const useWorkflowsStore = defineStore(STORES.WORKFLOWS, {
|
|||
tags: [],
|
||||
pinData: {},
|
||||
hash: '',
|
||||
},
|
||||
});
|
||||
|
||||
export const useWorkflowsStore = defineStore(STORES.WORKFLOWS, {
|
||||
state: (): WorkflowsState => ({
|
||||
workflow: createEmptyWorkflow(),
|
||||
activeWorkflows: [],
|
||||
activeExecutions: [],
|
||||
currentWorkflowExecutions: [],
|
||||
|
@ -199,6 +231,8 @@ export const useWorkflowsStore = defineStore(STORES.WORKFLOWS, {
|
|||
},
|
||||
|
||||
async getNewWorkflowData(name?: string): Promise<INewWorkflowData> {
|
||||
const workflowsEEStore = useWorkflowsEEStore();
|
||||
|
||||
let workflowData = {
|
||||
name: '',
|
||||
onboardingFlowEnabled: false,
|
||||
|
@ -213,9 +247,21 @@ export const useWorkflowsStore = defineStore(STORES.WORKFLOWS, {
|
|||
}
|
||||
|
||||
this.setWorkflowName({ newName: workflowData.name, setStateDirty: false });
|
||||
|
||||
return workflowData;
|
||||
},
|
||||
|
||||
resetWorkflow() {
|
||||
const usersStore = useUsersStore();
|
||||
const settingsStore = useSettingsStore();
|
||||
|
||||
this.workflow = createEmptyWorkflow();
|
||||
|
||||
if (settingsStore.isEnterpriseFeatureEnabled(EnterpriseEditionFeature.WorkflowSharing)) {
|
||||
Vue.set(this.workflow, 'ownedBy', usersStore.currentUser);
|
||||
}
|
||||
},
|
||||
|
||||
setWorkflowId (id: string): void {
|
||||
this.workflow.id = id === 'new' ? PLACEHOLDER_EMPTY_WORKFLOW_ID : id;
|
||||
},
|
||||
|
|
|
@ -841,7 +841,6 @@ export default mixins(
|
|||
this.workflowsStore.setWorkflowPinData(data.pinData || {});
|
||||
this.workflowsStore.setWorkflowHash(data.hash);
|
||||
|
||||
// @TODO
|
||||
this.workflowsStore.addWorkflow({
|
||||
id: data.id,
|
||||
name: data.name,
|
||||
|
@ -853,15 +852,22 @@ export default mixins(
|
|||
updatedAt: data.updatedAt,
|
||||
nodes: data.nodes,
|
||||
connections: data.connections,
|
||||
hash: '',
|
||||
});
|
||||
|
||||
if (data.ownedBy) {
|
||||
this.workflowsEEStore.setWorkflowOwnedBy({
|
||||
workflowId: data.id,
|
||||
ownedBy: data.ownedBy,
|
||||
});
|
||||
}
|
||||
|
||||
if (data.sharedWith) {
|
||||
this.workflowsEEStore.setWorkflowSharedWith({
|
||||
workflowId: data.id,
|
||||
sharedWith: data.sharedWith,
|
||||
});
|
||||
}
|
||||
|
||||
if (data.usedCredentials) {
|
||||
this.credentialsStore.addCredentials(data.usedCredentials);
|
||||
|
@ -3084,6 +3090,8 @@ export default mixins(
|
|||
return Promise.resolve(data);
|
||||
},
|
||||
resetWorkspace() {
|
||||
this.workflowsStore.resetWorkflow();
|
||||
|
||||
// Reset nodes
|
||||
this.deleteEveryEndpoint();
|
||||
|
||||
|
@ -3104,7 +3112,6 @@ export default mixins(
|
|||
this.workflowsStore.resetAllNodesIssues();
|
||||
// vm.$forceUpdate();
|
||||
|
||||
this.workflowsStore.$patch({ workflow: {} });
|
||||
this.workflowsStore.setActive(false);
|
||||
this.workflowsStore.setWorkflowId(PLACEHOLDER_EMPTY_WORKFLOW_ID);
|
||||
this.workflowsStore.setWorkflowName({ newName: '', setStateDirty: false });
|
||||
|
|
Loading…
Reference in a new issue