🐛 Fix rendering for node titles

This commit is contained in:
Iván Ovejero 2021-11-29 09:34:59 +01:00
parent c478276f35
commit 393723af39
2 changed files with 61 additions and 6 deletions

View file

@ -50,13 +50,9 @@
<div :class="{'disabled-linethrough': true, success: workflowDataItems > 0}" v-if="showDisabledLinethrough"></div> <div :class="{'disabled-linethrough': true, success: workflowDataItems > 0}" v-if="showDisabledLinethrough"></div>
</div> </div>
<div class="node-description"> <div class="node-description">
<div class="node-name" :title="data.name"> <div class="node-name" :title="nodeTitle">
<p> <p>
{{ this.$headerText({ {{ nodeTitle }}
key: `headers.${shortNodeType}.displayName`,
fallback: data.name,
})
}}
</p> </p>
<p v-if="data.disabled">({{ $baseText('node.disabled') }}}</p> <p v-if="data.disabled">({{ $baseText('node.disabled') }}}</p>
</div> </div>
@ -164,6 +160,23 @@ export default mixins(externalHooks, nodeBase, nodeHelpers, renderText, workflow
shortNodeType (): string { shortNodeType (): string {
return this.$shortNodeType(this.data.type); return this.$shortNodeType(this.data.type);
}, },
nodeTitle (): string {
const node = this.data;
const nodeName = this.$headerText({
key: `headers.${this.$shortNodeType(node.type)}.displayName`,
fallback: node.name,
});
if (!/\d$/.test(node.name)) return nodeName;
const nativeDuplicateSuffix = this.getDuplicateSuffix(node, { fromNative: true });
if (nativeDuplicateSuffix) return nodeName + nativeDuplicateSuffix;
return nodeName + this.getDuplicateSuffix(node, { fromStandard: true });
},
waiting (): string | undefined { waiting (): string | undefined {
const workflowExecution = this.$store.getters.getWorkflowExecution; const workflowExecution = this.$store.getters.getWorkflowExecution;
@ -272,6 +285,35 @@ export default mixins(externalHooks, nodeBase, nodeHelpers, renderText, workflow
this.$emit('duplicateNode', this.data.name); this.$emit('duplicateNode', this.data.name);
}); });
}, },
/**
* Extract the duplicate number suffix from a node name:
* - from a node name natively ending in a number, e.g. `'S31'` `'1'`
* - from a standard node name, e.g. `'GitHub1'` `'1'`
*/
getDuplicateSuffix(
node: INodeUi,
{ fromNative, fromStandard }: { fromNative?: true; fromStandard?: true; },
) {
if (fromNative) {
const { nativelyNumberSuffixedNodeNames: natives } = this.$store.getters;
const found = natives.find((native: string) => node.name.includes(native));
if (!found) return null;
return node.name.split(found).pop()!;
}
if (fromStandard) {
const match = node.name.match(/(.*)(?<duplicateSuffix>\d)$/);
if (!match || !match.groups || !match.groups.duplicateSuffix) return null;
return match.groups.duplicateSuffix;
}
throw new Error('Either "fromNative" or "fromStandard" must be specified');
},
setNodeActive () { setNodeActive () {
this.$store.commit('setActiveNode', this.data.name); this.$store.commit('setActiveNode', this.data.name);
}, },

View file

@ -818,6 +818,19 @@ export const store = new Vuex.Store({
allNodeTypes: (state): INodeTypeDescription[] => { allNodeTypes: (state): INodeTypeDescription[] => {
return state.nodeTypes; return state.nodeTypes;
}, },
/**
* Getter for node display names ending with a number: `'S3'`, `'MSG91'`, etc.
*/
nativelyNumberSuffixedNodeNames: (_, getters): string[] => {
const allNodeTypes: INodeTypeDescription[] = getters.allNodeTypes;
return allNodeTypes.reduce<string[]>((acc, cur) => {
if (/\d$/.test(cur.displayName)) acc.push(cur.displayName);
return acc;
}, []);
},
nodeType: (state, getters) => (nodeType: string, typeVersion?: number): INodeTypeDescription | null => { nodeType: (state, getters) => (nodeType: string, typeVersion?: number): INodeTypeDescription | null => {
const foundType = state.nodeTypes.find(typeData => { const foundType = state.nodeTypes.find(typeData => {
return typeData.name === nodeType && typeData.version === (typeVersion || typeData.defaultVersion || DEFAULT_NODETYPE_VERSION); return typeData.name === nodeType && typeData.version === (typeVersion || typeData.defaultVersion || DEFAULT_NODETYPE_VERSION);