mirror of
https://github.com/n8n-io/n8n.git
synced 2025-03-05 20:50:17 -08:00
* feat: Added vite.js dependencies. * chore: Removed tests folder to follow same structure as design-system * chore: Removed unused testing config. * chore: Created vite.js index.html * refactor: Updated scss structure and imports. * refactor: Updated workflow building. * fix: Cleared up all workflow dependency cycles. Added proper package.json imports config. * feat: Got a working build using Vite. Need to fix issues next. * fix: Progress! Getting process.env error. * fix: Changed process.env to import.meta.env. * fix: Fixed circular imports that used require(). Fixed monaco editor. * chore: Removed commented code. * chore: Cleaned up package.json * feat: Made necessary changes to replace base path in css files. * feat: Serve CSS files for `editor-ui` Vite migration (#4069) ⚡ Serve CSS files for Vite migration * chore: Fixed package-lock.json. * fix: Fixed build after centralized tsconfig update. * fix: Removed lodash-es replacement. * fix: Commented out vitest test command. * style: Fixed linting issues. * fix: Added lodash-es hotfix back. * chore: Updated package-lock.json * refactor: Renamed all n8n scss variables to no longer be defined as private. * feat(editor): add application-wide el-button replacement. * fix(editor): Fix import in page alert after merge. * chore(editor): update package-lock.json. * fix: Case sensitive lodash-es replacement for vue-agile. * fix: add alias for lodash-es camelcase import. * fix: add patch-package support for fixing quill * feat: add patch-package on postinstall * fix: update quill patch path. * refactor: rename quill patch * fix: update quill version. * fix: update quill patch * fix: fix linting rules after installing eslint in design-system * fix: update date picker button to have primary color * test: update callout component snapshots * fix(editor): fix linting issues in editor after enabling eslint * fix(cli): add /assets/* to auth ignore endpoints in server * chore: update package-lock.json * chore: update package-lock.json * fix(editor): fix linting issues * feat: add vite-legacy support * fix: update workflow package interface imports to type imports. * chore: update package-lock.json * fix(editor) fix importing translations other than english * fix(editor): remove test command until vitest is added * fix: increase memory allocation for vite build * fix: add patch-package patches to n8n-custom docker build * fix: add performance and load time improvements * fix: add proper typing to setNodeType * chore: update package-lock.json * style: use generic type for reduce in setNodeType Co-authored-by: Iván Ovejero <ivov.src@gmail.com>
269 lines
5.4 KiB
Vue
269 lines
5.4 KiB
Vue
<template>
|
|
<n8n-checkbox
|
|
v-if="type === 'checkbox'"
|
|
v-bind="$props"
|
|
@input="onInput"
|
|
@focus="onFocus"
|
|
ref="input"
|
|
></n8n-checkbox>
|
|
<n8n-input-label v-else :label="label" :tooltipText="tooltipText" :required="required && showRequiredAsterisk">
|
|
<div :class="showErrors ? $style.errorInput : ''" @keydown.stop @keydown.enter="onEnter">
|
|
<slot v-if="hasDefaultSlot"></slot>
|
|
<n8n-select
|
|
v-else-if="type === 'select' || type === 'multi-select'"
|
|
:value="value"
|
|
:placeholder="placeholder"
|
|
:multiple="type === 'multi-select'"
|
|
@change="onInput"
|
|
@focus="onFocus"
|
|
@blur="onBlur"
|
|
ref="input"
|
|
>
|
|
<n8n-option
|
|
v-for="option in (options || [])"
|
|
:key="option.value"
|
|
:value="option.value"
|
|
:label="option.label"
|
|
/>
|
|
</n8n-select>
|
|
<n8n-input
|
|
v-else
|
|
:type="type"
|
|
:placeholder="placeholder"
|
|
:value="value"
|
|
:maxlength="maxlength"
|
|
:autocomplete="autocomplete"
|
|
@input="onInput"
|
|
@blur="onBlur"
|
|
@focus="onFocus"
|
|
ref="input"
|
|
/>
|
|
</div>
|
|
<div :class="$style.errors" v-if="showErrors">
|
|
<span>{{ validationError }}</span>
|
|
<n8n-link
|
|
v-if="documentationUrl && documentationText"
|
|
:to="documentationUrl"
|
|
:newWindow="true"
|
|
size="small"
|
|
theme="danger"
|
|
>
|
|
{{ documentationText }}
|
|
</n8n-link>
|
|
</div>
|
|
<div :class="$style.infoText" v-else-if="infoText">
|
|
<span size="small">{{ infoText }}</span>
|
|
</div>
|
|
</n8n-input-label>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import Vue from 'vue';
|
|
import N8nInput from '../N8nInput';
|
|
import N8nSelect from '../N8nSelect';
|
|
import N8nOption from '../N8nOption';
|
|
import N8nInputLabel from '../N8nInputLabel';
|
|
import N8nCheckbox from '../N8nCheckbox';
|
|
|
|
import { getValidationError, VALIDATORS } from './validators';
|
|
import { Rule, RuleGroup, IValidator } from "../../types";
|
|
|
|
import Locale from '../../mixins/locale';
|
|
import mixins from 'vue-typed-mixins';
|
|
|
|
export default mixins(Locale).extend({
|
|
name: 'n8n-form-input',
|
|
components: {
|
|
N8nInput,
|
|
N8nInputLabel,
|
|
N8nOption,
|
|
N8nSelect,
|
|
N8nCheckbox,
|
|
},
|
|
data() {
|
|
return {
|
|
hasBlurred: false,
|
|
isTyping: false,
|
|
};
|
|
},
|
|
props: {
|
|
value: {
|
|
},
|
|
label: {
|
|
type: String,
|
|
},
|
|
infoText: {
|
|
type: String,
|
|
},
|
|
required: {
|
|
type: Boolean,
|
|
},
|
|
showRequiredAsterisk: {
|
|
type: Boolean,
|
|
default: true,
|
|
},
|
|
type: {
|
|
type: String,
|
|
default: 'text',
|
|
},
|
|
placeholder: {
|
|
type: String,
|
|
},
|
|
tooltipText: {
|
|
type: String,
|
|
},
|
|
showValidationWarnings: {
|
|
type: Boolean,
|
|
},
|
|
validateOnBlur: {
|
|
type: Boolean,
|
|
default: true,
|
|
},
|
|
documentationUrl: {
|
|
type: String,
|
|
},
|
|
documentationText: {
|
|
type: String,
|
|
default: 'Open docs',
|
|
},
|
|
validationRules: {
|
|
type: Array,
|
|
},
|
|
validators: {
|
|
type: Object,
|
|
},
|
|
maxlength: {
|
|
type: Number,
|
|
},
|
|
options: {
|
|
type: Array,
|
|
},
|
|
autocomplete: {
|
|
type: String,
|
|
},
|
|
focusInitially: {
|
|
type: Boolean,
|
|
},
|
|
labelSize: {
|
|
type: String,
|
|
default: 'medium',
|
|
validator: (value: string): boolean =>
|
|
['small', 'medium'].includes(value),
|
|
},
|
|
},
|
|
mounted() {
|
|
this.$emit('validate', !this.validationError);
|
|
|
|
if (this.focusInitially && this.$refs.input) {
|
|
(this.$refs.input as HTMLTextAreaElement).focus();
|
|
}
|
|
},
|
|
computed: {
|
|
validationError(): string | null {
|
|
const error = this.getValidationError();
|
|
if (error) {
|
|
return this.t(error.messageKey, error.options);
|
|
}
|
|
|
|
return null;
|
|
},
|
|
hasDefaultSlot(): boolean {
|
|
return !!this.$slots.default;
|
|
},
|
|
showErrors(): boolean {
|
|
return (
|
|
!!this.validationError &&
|
|
((this.validateOnBlur && this.hasBlurred && !this.isTyping) || this.showValidationWarnings)
|
|
);
|
|
},
|
|
},
|
|
methods: {
|
|
getValidationError(): ReturnType<IValidator['validate']> {
|
|
const rules = (this.validationRules || []) as Array<Rule | RuleGroup>;
|
|
const validators = {
|
|
...VALIDATORS,
|
|
...(this.validators || {}),
|
|
} as { [key: string]: IValidator | RuleGroup };
|
|
|
|
if (this.required) {
|
|
const error = getValidationError(this.value, validators, validators.REQUIRED as IValidator);
|
|
if (error) {
|
|
return error;
|
|
}
|
|
}
|
|
|
|
for (let i = 0; i < rules.length; i++) {
|
|
if (rules[i].hasOwnProperty('name')) {
|
|
const rule = rules[i] as Rule;
|
|
if (validators[rule.name]) {
|
|
const error = getValidationError(
|
|
this.value,
|
|
validators,
|
|
validators[rule.name] as IValidator,
|
|
rule.config,
|
|
);
|
|
if (error) {
|
|
return error;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (rules[i].hasOwnProperty('rules')) {
|
|
const rule = rules[i] as RuleGroup;
|
|
const error = getValidationError(
|
|
this.value,
|
|
validators,
|
|
rule,
|
|
);
|
|
if (error) {
|
|
return error;
|
|
}
|
|
}
|
|
}
|
|
|
|
return null;
|
|
},
|
|
onBlur() {
|
|
this.hasBlurred = true;
|
|
this.isTyping = false;
|
|
this.$emit('blur');
|
|
},
|
|
onInput(value: any) {
|
|
this.isTyping = true;
|
|
this.$emit('input', value);
|
|
},
|
|
onFocus() {
|
|
this.$emit('focus');
|
|
},
|
|
onEnter(event: Event) {
|
|
event.stopPropagation();
|
|
event.preventDefault();
|
|
this.$emit('enter');
|
|
},
|
|
},
|
|
watch: {
|
|
validationError(newValue: string | null, oldValue: string | null) {
|
|
this.$emit('validate', !newValue);
|
|
},
|
|
},
|
|
});
|
|
</script>
|
|
|
|
<style lang="scss" module>
|
|
.infoText {
|
|
margin-top: var(--spacing-2xs);
|
|
font-size: var(--font-size-2xs);
|
|
font-weight: var(--font-weight-regular);
|
|
color: var(--color-text-base);
|
|
}
|
|
|
|
.errors {
|
|
composes: infoText;
|
|
color: var(--color-danger);
|
|
}
|
|
|
|
.errorInput {
|
|
--input-border-color: var(--color-danger);
|
|
}
|
|
</style>
|