123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200 |
- import { createNamespace } from '../utils';
- import { sortChildren } from '../utils/vnodes';
- var _createNamespace = createNamespace('form'),
- createComponent = _createNamespace[0],
- bem = _createNamespace[1];
- export default createComponent({
- props: {
- colon: Boolean,
- disabled: Boolean,
- readonly: Boolean,
- labelWidth: [Number, String],
- labelAlign: String,
- inputAlign: String,
- scrollToError: Boolean,
- validateFirst: Boolean,
- errorMessageAlign: String,
- submitOnEnter: {
- type: Boolean,
- default: true
- },
- validateTrigger: {
- type: String,
- default: 'onBlur'
- },
- showError: {
- type: Boolean,
- default: true
- },
- showErrorMessage: {
- type: Boolean,
- default: true
- }
- },
- provide: function provide() {
- return {
- vanForm: this
- };
- },
- data: function data() {
- return {
- fields: []
- };
- },
- methods: {
- getFieldsByNames: function getFieldsByNames(names) {
- if (names) {
- return this.fields.filter(function (field) {
- return names.indexOf(field.name) !== -1;
- });
- }
- return this.fields;
- },
- validateSeq: function validateSeq(names) {
- var _this = this;
- return new Promise(function (resolve, reject) {
- var errors = [];
- var fields = _this.getFieldsByNames(names);
- fields.reduce(function (promise, field) {
- return promise.then(function () {
- if (!errors.length) {
- return field.validate().then(function (error) {
- if (error) {
- errors.push(error);
- }
- });
- }
- });
- }, Promise.resolve()).then(function () {
- if (errors.length) {
- reject(errors);
- } else {
- resolve();
- }
- });
- });
- },
- validateFields: function validateFields(names) {
- var _this2 = this;
- return new Promise(function (resolve, reject) {
- var fields = _this2.getFieldsByNames(names);
- Promise.all(fields.map(function (item) {
- return item.validate();
- })).then(function (errors) {
- errors = errors.filter(function (item) {
- return item;
- });
- if (errors.length) {
- reject(errors);
- } else {
- resolve();
- }
- });
- });
- },
- // @exposed-api
- validate: function validate(name) {
- if (name && !Array.isArray(name)) {
- return this.validateField(name);
- }
- return this.validateFirst ? this.validateSeq(name) : this.validateFields(name);
- },
- validateField: function validateField(name) {
- var matched = this.fields.filter(function (item) {
- return item.name === name;
- });
- if (matched.length) {
- return new Promise(function (resolve, reject) {
- matched[0].validate().then(function (error) {
- if (error) {
- reject(error);
- } else {
- resolve();
- }
- });
- });
- }
- return Promise.reject();
- },
- // @exposed-api
- resetValidation: function resetValidation(name) {
- if (name && !Array.isArray(name)) {
- name = [name];
- }
- var fields = this.getFieldsByNames(name);
- fields.forEach(function (item) {
- item.resetValidation();
- });
- },
- // @exposed-api
- scrollToField: function scrollToField(name, options) {
- this.fields.some(function (item) {
- if (item.name === name) {
- item.$el.scrollIntoView(options);
- return true;
- }
- return false;
- });
- },
- addField: function addField(field) {
- this.fields.push(field);
- sortChildren(this.fields, this);
- },
- removeField: function removeField(field) {
- this.fields = this.fields.filter(function (item) {
- return item !== field;
- });
- },
- getValues: function getValues() {
- return this.fields.reduce(function (form, field) {
- form[field.name] = field.formValue;
- return form;
- }, {});
- },
- onSubmit: function onSubmit(event) {
- event.preventDefault();
- this.submit();
- },
- // @exposed-api
- submit: function submit() {
- var _this3 = this;
- var values = this.getValues();
- this.validate().then(function () {
- _this3.$emit('submit', values);
- }).catch(function (errors) {
- _this3.$emit('failed', {
- values: values,
- errors: errors
- });
- if (_this3.scrollToError) {
- _this3.scrollToField(errors[0].name);
- }
- });
- }
- },
- render: function render() {
- var h = arguments[0];
- return h("form", {
- "class": bem(),
- "on": {
- "submit": this.onSubmit
- }
- }, [this.slots()]);
- }
- });
|