mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-18 18:41:14 +00:00
refactor(editor): Apply Prettier (no-changelog) (#4920)
* ⚡ Adjust `format` script * 🔥 Remove exemption for `editor-ui` * 🎨 Prettify * 👕 Fix lint
This commit is contained in:
@@ -6,13 +6,14 @@
|
||||
</div>
|
||||
<details>
|
||||
<summary class="error-details__summary">
|
||||
<font-awesome-icon class="error-details__icon" icon="angle-right" /> {{ $locale.baseText('nodeErrorView.details') }}
|
||||
<font-awesome-icon class="error-details__icon" icon="angle-right" />
|
||||
{{ $locale.baseText('nodeErrorView.details') }}
|
||||
</summary>
|
||||
<div class="error-details__content">
|
||||
<div v-if="error.context && error.context.causeDetailed">
|
||||
<el-card class="box-card" shadow="never">
|
||||
<div>
|
||||
{{error.context.causeDetailed}}
|
||||
{{ error.context.causeDetailed }}
|
||||
</div>
|
||||
</el-card>
|
||||
</div>
|
||||
@@ -24,22 +25,33 @@
|
||||
</div>
|
||||
</template>
|
||||
<div>
|
||||
{{new Date(error.timestamp).toLocaleString()}}
|
||||
{{ new Date(error.timestamp).toLocaleString() }}
|
||||
</div>
|
||||
</el-card>
|
||||
</div>
|
||||
<div v-if="error.context && error.context.itemIndex !== undefined" class="el-card box-card is-never-shadow el-card__body">
|
||||
<span class="error-details__summary">{{ $locale.baseText('nodeErrorView.itemIndex') }}:</span>
|
||||
{{error.context.itemIndex}}
|
||||
<span v-if="error.context.runIndex">
|
||||
| <span class="error-details__summary">{{ $locale.baseText('nodeErrorView.itemIndex') }}:</span>
|
||||
{{error.context.runIndex}}
|
||||
</span>
|
||||
<span v-if="error.context.parameter">
|
||||
| <span class="error-details__summary">{{ $locale.baseText('nodeErrorView.inParameter') }}:</span>
|
||||
{{ parameterDisplayName(error.context.parameter) }}
|
||||
</span>
|
||||
</div>
|
||||
<div
|
||||
v-if="error.context && error.context.itemIndex !== undefined"
|
||||
class="el-card box-card is-never-shadow el-card__body"
|
||||
>
|
||||
<span class="error-details__summary"
|
||||
>{{ $locale.baseText('nodeErrorView.itemIndex') }}:</span
|
||||
>
|
||||
{{ error.context.itemIndex }}
|
||||
<span v-if="error.context.runIndex">
|
||||
|
|
||||
<span class="error-details__summary"
|
||||
>{{ $locale.baseText('nodeErrorView.itemIndex') }}:</span
|
||||
>
|
||||
{{ error.context.runIndex }}
|
||||
</span>
|
||||
<span v-if="error.context.parameter">
|
||||
|
|
||||
<span class="error-details__summary"
|
||||
>{{ $locale.baseText('nodeErrorView.inParameter') }}:</span
|
||||
>
|
||||
{{ parameterDisplayName(error.context.parameter) }}
|
||||
</span>
|
||||
</div>
|
||||
<div v-if="error.httpCode">
|
||||
<el-card class="box-card" shadow="never">
|
||||
<template #header>
|
||||
@@ -48,7 +60,7 @@
|
||||
</div>
|
||||
</template>
|
||||
<div>
|
||||
{{error.httpCode}}
|
||||
{{ error.httpCode }}
|
||||
</div>
|
||||
</el-card>
|
||||
</div>
|
||||
@@ -57,13 +69,19 @@
|
||||
<template #header>
|
||||
<div class="clearfix box-card__title">
|
||||
<span>{{ $locale.baseText('nodeErrorView.cause') }}</span>
|
||||
<br>
|
||||
<span class="box-card__subtitle">{{ $locale.baseText('nodeErrorView.dataBelowMayContain') }}</span>
|
||||
<br />
|
||||
<span class="box-card__subtitle">{{
|
||||
$locale.baseText('nodeErrorView.dataBelowMayContain')
|
||||
}}</span>
|
||||
</div>
|
||||
</template>
|
||||
</template>
|
||||
<div>
|
||||
<div class="copy-button" v-if="displayCause">
|
||||
<n8n-icon-button @click="copyCause" :title="$locale.baseText('nodeErrorView.copyToClipboard')" icon="copy" />
|
||||
<n8n-icon-button
|
||||
@click="copyCause"
|
||||
:title="$locale.baseText('nodeErrorView.copyToClipboard')"
|
||||
icon="copy"
|
||||
/>
|
||||
</div>
|
||||
<vue-json-pretty
|
||||
v-if="displayCause"
|
||||
@@ -75,7 +93,9 @@
|
||||
class="json-data"
|
||||
/>
|
||||
<span v-else>
|
||||
<font-awesome-icon icon="info-circle" />{{ $locale.baseText('nodeErrorView.theErrorCauseIsTooLargeToBeDisplayed') }}
|
||||
<font-awesome-icon icon="info-circle" />{{
|
||||
$locale.baseText('nodeErrorView.theErrorCauseIsTooLargeToBeDisplayed')
|
||||
}}
|
||||
</span>
|
||||
</div>
|
||||
</el-card>
|
||||
@@ -103,43 +123,27 @@ import VueJsonPretty from 'vue-json-pretty';
|
||||
import { copyPaste } from '@/mixins/copyPaste';
|
||||
import { showMessage } from '@/mixins/showMessage';
|
||||
import mixins from 'vue-typed-mixins';
|
||||
import {
|
||||
MAX_DISPLAY_DATA_SIZE,
|
||||
} from '@/constants';
|
||||
import {
|
||||
INodeUi,
|
||||
} from '@/Interface';
|
||||
import { MAX_DISPLAY_DATA_SIZE } from '@/constants';
|
||||
import { INodeUi } from '@/Interface';
|
||||
|
||||
import {
|
||||
INodeProperties,
|
||||
INodePropertyCollection,
|
||||
INodePropertyOptions,
|
||||
} from 'n8n-workflow';
|
||||
import { INodeProperties, INodePropertyCollection, INodePropertyOptions } from 'n8n-workflow';
|
||||
import { sanitizeHtml } from '@/utils';
|
||||
import { mapStores } from 'pinia';
|
||||
import { useNDVStore } from '@/stores/ndv';
|
||||
import { useNodeTypesStore } from '@/stores/nodeTypes';
|
||||
|
||||
export default mixins(
|
||||
copyPaste,
|
||||
showMessage,
|
||||
).extend({
|
||||
export default mixins(copyPaste, showMessage).extend({
|
||||
name: 'NodeErrorView',
|
||||
props: [
|
||||
'error',
|
||||
],
|
||||
props: ['error'],
|
||||
components: {
|
||||
VueJsonPretty,
|
||||
},
|
||||
computed: {
|
||||
...mapStores(
|
||||
useNodeTypesStore,
|
||||
useNDVStore,
|
||||
),
|
||||
...mapStores(useNodeTypesStore, useNDVStore),
|
||||
displayCause(): boolean {
|
||||
return JSON.stringify(this.error.cause).length < MAX_DISPLAY_DATA_SIZE;
|
||||
},
|
||||
parameters (): INodeProperties[] {
|
||||
parameters(): INodeProperties[] {
|
||||
const node = this.ndvStore.activeNode;
|
||||
if (!node) {
|
||||
return [];
|
||||
@@ -154,20 +158,24 @@ export default mixins(
|
||||
},
|
||||
},
|
||||
methods: {
|
||||
replacePlaceholders (parameter: string, message: string): string {
|
||||
replacePlaceholders(parameter: string, message: string): string {
|
||||
const parameterName = this.parameterDisplayName(parameter, false);
|
||||
const parameterFullName = this.parameterDisplayName(parameter, true);
|
||||
return message.replace(/%%PARAMETER%%/g, parameterName).replace(/%%PARAMETER_FULL%%/g, parameterFullName);
|
||||
return message
|
||||
.replace(/%%PARAMETER%%/g, parameterName)
|
||||
.replace(/%%PARAMETER_FULL%%/g, parameterFullName);
|
||||
},
|
||||
getErrorDescription (): string {
|
||||
getErrorDescription(): string {
|
||||
if (!this.error.context || !this.error.context.descriptionTemplate) {
|
||||
return sanitizeHtml(this.error.description);
|
||||
}
|
||||
|
||||
const parameterName = this.parameterDisplayName(this.error.context.parameter);
|
||||
return sanitizeHtml(this.error.context.descriptionTemplate.replace(/%%PARAMETER%%/g, parameterName));
|
||||
return sanitizeHtml(
|
||||
this.error.context.descriptionTemplate.replace(/%%PARAMETER%%/g, parameterName),
|
||||
);
|
||||
},
|
||||
getErrorMessage (): string {
|
||||
getErrorMessage(): string {
|
||||
const baseErrorMessage = this.$locale.baseText('nodeErrorView.error') + ': ';
|
||||
|
||||
if (!this.error.context || !this.error.context.messageTemplate) {
|
||||
@@ -176,7 +184,10 @@ export default mixins(
|
||||
|
||||
const parameterName = this.parameterDisplayName(this.error.context.parameter);
|
||||
|
||||
return baseErrorMessage + this.error.context.messageTemplate.replace(/%%PARAMETER%%/g, parameterName);
|
||||
return (
|
||||
baseErrorMessage +
|
||||
this.error.context.messageTemplate.replace(/%%PARAMETER%%/g, parameterName)
|
||||
);
|
||||
},
|
||||
parameterDisplayName(path: string, fullPath = true) {
|
||||
try {
|
||||
@@ -188,12 +199,15 @@ export default mixins(
|
||||
if (fullPath === false) {
|
||||
return parameters.pop()!.displayName;
|
||||
}
|
||||
return parameters.map(parameter => parameter.displayName).join(' > ');
|
||||
return parameters.map((parameter) => parameter.displayName).join(' > ');
|
||||
} catch (error) {
|
||||
return `Could not find parameter "${path}"`;
|
||||
}
|
||||
},
|
||||
parameterName(parameters: Array<(INodePropertyOptions | INodeProperties | INodePropertyCollection)>, pathParts: string[]): Array<(INodeProperties | INodePropertyCollection)> {
|
||||
parameterName(
|
||||
parameters: Array<INodePropertyOptions | INodeProperties | INodePropertyCollection>,
|
||||
pathParts: string[],
|
||||
): Array<INodeProperties | INodePropertyCollection> {
|
||||
let currentParameterName = pathParts.shift();
|
||||
|
||||
if (currentParameterName === undefined) {
|
||||
@@ -204,7 +218,9 @@ export default mixins(
|
||||
if (arrayMatch !== null && arrayMatch.length > 0) {
|
||||
currentParameterName = arrayMatch[1];
|
||||
}
|
||||
const currentParameter = parameters.find(parameter => parameter.name === currentParameterName) as unknown as INodeProperties | INodePropertyCollection;
|
||||
const currentParameter = parameters.find(
|
||||
(parameter) => parameter.name === currentParameterName,
|
||||
) as unknown as INodeProperties | INodePropertyCollection;
|
||||
|
||||
if (currentParameter === undefined) {
|
||||
throw new Error(`Could not find parameter "${currentParameterName}"`);
|
||||
@@ -215,11 +231,17 @@ export default mixins(
|
||||
}
|
||||
|
||||
if (currentParameter.hasOwnProperty('options')) {
|
||||
return [currentParameter, ...this.parameterName((currentParameter as INodeProperties).options!, pathParts)];
|
||||
return [
|
||||
currentParameter,
|
||||
...this.parameterName((currentParameter as INodeProperties).options!, pathParts),
|
||||
];
|
||||
}
|
||||
|
||||
if (currentParameter.hasOwnProperty('values')) {
|
||||
return [currentParameter, ...this.parameterName((currentParameter as INodePropertyCollection).values, pathParts)];
|
||||
return [
|
||||
currentParameter,
|
||||
...this.parameterName((currentParameter as INodePropertyCollection).values, pathParts),
|
||||
];
|
||||
}
|
||||
|
||||
// We can not resolve any deeper so lets stop here and at least return hopefully something useful
|
||||
@@ -240,7 +262,6 @@ export default mixins(
|
||||
</script>
|
||||
|
||||
<style lang="scss">
|
||||
|
||||
.error-header {
|
||||
margin-bottom: 10px;
|
||||
}
|
||||
@@ -260,7 +281,7 @@ export default mixins(
|
||||
font-weight: 600;
|
||||
font-size: 16px;
|
||||
cursor: pointer;
|
||||
outline:none;
|
||||
outline: none;
|
||||
}
|
||||
|
||||
.error-details__icon {
|
||||
@@ -268,15 +289,15 @@ export default mixins(
|
||||
}
|
||||
|
||||
details > summary {
|
||||
list-style-type: none;
|
||||
list-style-type: none;
|
||||
}
|
||||
|
||||
details > summary::-webkit-details-marker {
|
||||
display: none;
|
||||
display: none;
|
||||
}
|
||||
|
||||
details[open] {
|
||||
.error-details__icon {
|
||||
.error-details__icon {
|
||||
transform: rotate(90deg);
|
||||
}
|
||||
}
|
||||
@@ -309,5 +330,4 @@ details[open] {
|
||||
right: 50px;
|
||||
z-index: 1000;
|
||||
}
|
||||
|
||||
</style>
|
||||
|
||||
Reference in New Issue
Block a user