mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-03 17:07:29 -08:00
push nodes out 200 on insert
This commit is contained in:
parent
edc5390089
commit
db66ad8f54
|
@ -316,7 +316,7 @@ export default mixins(
|
||||||
// Update the values on the node
|
// Update the values on the node
|
||||||
this.$store.commit('updateNodeProperties', updateInformation);
|
this.$store.commit('updateNodeProperties', updateInformation);
|
||||||
|
|
||||||
const node = this.$store.getters.nodeByName(updateInformation.name);
|
const node = this.$store.getters.getNodeByName(updateInformation.name);
|
||||||
|
|
||||||
// Update the issues
|
// Update the issues
|
||||||
this.updateNodeCredentialIssues(node);
|
this.updateNodeCredentialIssues(node);
|
||||||
|
@ -336,7 +336,7 @@ export default mixins(
|
||||||
// Save the node name before we commit the change because
|
// Save the node name before we commit the change because
|
||||||
// we need the old name to rename the node properly
|
// we need the old name to rename the node properly
|
||||||
const nodeNameBefore = parameterData.node || this.node.name;
|
const nodeNameBefore = parameterData.node || this.node.name;
|
||||||
const node = this.$store.getters.nodeByName(nodeNameBefore);
|
const node = this.$store.getters.getNodeByName(nodeNameBefore);
|
||||||
if (parameterData.name === 'name') {
|
if (parameterData.name === 'name') {
|
||||||
// Name of node changed so we have to set also the new node name as active
|
// Name of node changed so we have to set also the new node name as active
|
||||||
|
|
||||||
|
|
|
@ -18,7 +18,7 @@ export const nodeBase = mixins(
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
data (): INodeUi {
|
data (): INodeUi {
|
||||||
return this.$store.getters.nodeByName(this.name);
|
return this.$store.getters.getNodeByName(this.name);
|
||||||
},
|
},
|
||||||
hasIssues (): boolean {
|
hasIssues (): boolean {
|
||||||
if (this.data.issues !== undefined && Object.keys(this.data.issues).length) {
|
if (this.data.issues !== undefined && Object.keys(this.data.issues).length) {
|
||||||
|
@ -33,11 +33,13 @@ export const nodeBase = mixins(
|
||||||
return this.$store.getters.getNodeIndex(this.data.name).toString();
|
return this.$store.getters.getNodeIndex(this.data.name).toString();
|
||||||
},
|
},
|
||||||
nodePosition (): object {
|
nodePosition (): object {
|
||||||
|
const node = this.$store.getters.nodesByName[this.name];
|
||||||
|
console.log(node);
|
||||||
const returnStyles: {
|
const returnStyles: {
|
||||||
[key: string]: string;
|
[key: string]: string;
|
||||||
} = {
|
} = {
|
||||||
left: this.data.position[0] + 'px',
|
left: node.position[0] + 'px',
|
||||||
top: this.data.position[1] + 'px',
|
top: node.position[1] + 'px',
|
||||||
};
|
};
|
||||||
|
|
||||||
return returnStyles;
|
return returnStyles;
|
||||||
|
|
|
@ -763,7 +763,13 @@ export const store = new Vuex.Store({
|
||||||
allNodes: (state): INodeUi[] => {
|
allNodes: (state): INodeUi[] => {
|
||||||
return state.workflow.nodes;
|
return state.workflow.nodes;
|
||||||
},
|
},
|
||||||
nodeByName: (state) => (nodeName: string): INodeUi | null => {
|
nodesByName: (state: IRootState): {[name: string]: INodeUi} => {
|
||||||
|
return state.workflow.nodes.reduce((accu: {[name: string]: INodeUi}, node) => {
|
||||||
|
accu[node.name] = node;
|
||||||
|
return accu;
|
||||||
|
}, {});
|
||||||
|
},
|
||||||
|
getNodeByName: (state) => (nodeName: string): INodeUi | null => {
|
||||||
const foundNode = state.workflow.nodes.find(node => {
|
const foundNode = state.workflow.nodes.find(node => {
|
||||||
return node.name === nodeName;
|
return node.name === nodeName;
|
||||||
});
|
});
|
||||||
|
@ -796,10 +802,10 @@ export const store = new Vuex.Store({
|
||||||
return foundType;
|
return foundType;
|
||||||
},
|
},
|
||||||
activeNode: (state, getters): INodeUi | null => {
|
activeNode: (state, getters): INodeUi | null => {
|
||||||
return getters.nodeByName(state.activeNode);
|
return getters.getNodeByName(state.activeNode);
|
||||||
},
|
},
|
||||||
lastSelectedNode: (state, getters): INodeUi | null => {
|
lastSelectedNode: (state, getters): INodeUi | null => {
|
||||||
return getters.nodeByName(state.lastSelectedNode);
|
return getters.getNodeByName(state.lastSelectedNode);
|
||||||
},
|
},
|
||||||
lastSelectedNodeOutputIndex: (state, getters): number | null => {
|
lastSelectedNodeOutputIndex: (state, getters): number | null => {
|
||||||
return state.lastSelectedNodeOutputIndex;
|
return state.lastSelectedNodeOutputIndex;
|
||||||
|
|
|
@ -745,7 +745,7 @@ export default mixins(
|
||||||
// Ignore current node
|
// Ignore current node
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
siblingNode = this.$store.getters.nodeByName(ouputConnection.node);
|
siblingNode = this.$store.getters.getNodeByName(ouputConnection.node);
|
||||||
|
|
||||||
if (e.key === 'ArrowUp') {
|
if (e.key === 'ArrowUp') {
|
||||||
// Get the next node on the left
|
// Get the next node on the left
|
||||||
|
@ -829,6 +829,25 @@ export default mixins(
|
||||||
this.nodeSelectedByName(lastSelectedNode.name);
|
this.nodeSelectedByName(lastSelectedNode.name);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
pushDownstreamNodes (margin: number) {
|
||||||
|
const lastSelectedNode = this.lastSelectedNode;
|
||||||
|
if (lastSelectedNode === null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const workflow = this.getWorkflow();
|
||||||
|
for (const nodeName of workflow.getChildNodes(lastSelectedNode.name)) {
|
||||||
|
const node = this.$store.getters.nodesByName[nodeName] as INodeUi;
|
||||||
|
const updateInformation = {
|
||||||
|
name: nodeName,
|
||||||
|
properties: {
|
||||||
|
position: [node.position[0] + margin, node.position[1]],
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
this.$store.commit('updateNodeProperties', updateInformation);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
cutSelectedNodes () {
|
cutSelectedNodes () {
|
||||||
this.copySelectedNodes();
|
this.copySelectedNodes();
|
||||||
this.deleteSelectedNodes();
|
this.deleteSelectedNodes();
|
||||||
|
@ -1074,7 +1093,7 @@ export default mixins(
|
||||||
},
|
},
|
||||||
|
|
||||||
nodeDeselectedByName (nodeName: string) {
|
nodeDeselectedByName (nodeName: string) {
|
||||||
const node = this.$store.getters.nodeByName(nodeName);
|
const node = this.$store.getters.getNodeByName(nodeName);
|
||||||
if (node) {
|
if (node) {
|
||||||
this.nodeDeselected(node);
|
this.nodeDeselected(node);
|
||||||
}
|
}
|
||||||
|
@ -1085,7 +1104,7 @@ export default mixins(
|
||||||
this.deselectAllNodes();
|
this.deselectAllNodes();
|
||||||
}
|
}
|
||||||
|
|
||||||
const node = this.$store.getters.nodeByName(nodeName);
|
const node = this.$store.getters.getNodeByName(nodeName);
|
||||||
if (node) {
|
if (node) {
|
||||||
this.nodeSelected(node);
|
this.nodeSelected(node);
|
||||||
}
|
}
|
||||||
|
@ -1180,6 +1199,7 @@ export default mixins(
|
||||||
const lastSelectedNode = this.lastSelectedNode;
|
const lastSelectedNode = this.lastSelectedNode;
|
||||||
const lastSelectedNodeOutputIndex = this.$store.getters.lastSelectedNodeOutputIndex;
|
const lastSelectedNodeOutputIndex = this.$store.getters.lastSelectedNodeOutputIndex;
|
||||||
if (lastSelectedNode) {
|
if (lastSelectedNode) {
|
||||||
|
this.pushDownstreamNodes(200);
|
||||||
// If a node is active then add the new node directly after the current one
|
// If a node is active then add the new node directly after the current one
|
||||||
// newNodeData.position = [activeNode.position[0], activeNode.position[1] + 60];
|
// newNodeData.position = [activeNode.position[0], activeNode.position[1] + 60];
|
||||||
newNodeData.position = getNewNodePosition(
|
newNodeData.position = getNewNodePosition(
|
||||||
|
@ -1319,8 +1339,8 @@ export default mixins(
|
||||||
const sourceNodeName = this.$store.getters.getNodeNameByIndex(sourceInfo.nodeIndex);
|
const sourceNodeName = this.$store.getters.getNodeNameByIndex(sourceInfo.nodeIndex);
|
||||||
const targetNodeName = this.$store.getters.getNodeNameByIndex(targetInfo.nodeIndex);
|
const targetNodeName = this.$store.getters.getNodeNameByIndex(targetInfo.nodeIndex);
|
||||||
|
|
||||||
const sourceNode = this.$store.getters.nodeByName(sourceNodeName);
|
const sourceNode = this.$store.getters.getNodeByName(sourceNodeName);
|
||||||
const targetNode = this.$store.getters.nodeByName(targetNodeName);
|
const targetNode = this.$store.getters.getNodeByName(targetNodeName);
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
info.connection.removeOverlay('drop-add-node');
|
info.connection.removeOverlay('drop-add-node');
|
||||||
|
@ -1652,7 +1672,7 @@ export default mixins(
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const node = this.$store.getters.nodeByName(nodeName);
|
const node = this.$store.getters.getNodeByName(nodeName);
|
||||||
|
|
||||||
const nodeTypeData: INodeTypeDescription = this.$store.getters.nodeType(node.type);
|
const nodeTypeData: INodeTypeDescription = this.$store.getters.nodeType(node.type);
|
||||||
if (nodeTypeData.maxNodes !== undefined && this.getNodeTypeCount(node.type) >= nodeTypeData.maxNodes) {
|
if (nodeTypeData.maxNodes !== undefined && this.getNodeTypeCount(node.type) >= nodeTypeData.maxNodes) {
|
||||||
|
@ -1710,7 +1730,7 @@ export default mixins(
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const node = this.$store.getters.nodeByName(nodeName);
|
const node = this.$store.getters.getNodeByName(nodeName);
|
||||||
|
|
||||||
// "requiredNodeTypes" are also defined in cli/commands/run.ts
|
// "requiredNodeTypes" are also defined in cli/commands/run.ts
|
||||||
const requiredNodeTypes = [ 'n8n-nodes-base.start' ];
|
const requiredNodeTypes = [ 'n8n-nodes-base.start' ];
|
||||||
|
|
Loading…
Reference in a new issue