import { use } from '../utils'; import Button from '../button'; import Field from '../field'; import Toast from '../toast'; import Dialog from '../dialog'; import { isMobile } from '../utils/validate/mobile'; const [sfc, bem, t] = use('contact-edit'); const defaultContact = { tel: '', name: '' }; export default sfc({ props: { isEdit: Boolean, isSaving: Boolean, isDeleting: Boolean, contactInfo: { type: Object, default: () => ({ ...defaultContact }) }, telValidator: { type: Function, default: isMobile } }, data() { return { data: { ...defaultContact, ...this.contactInfo }, errorInfo: { name: false, tel: false } }; }, watch: { contactInfo(val) { this.data = { ...defaultContact, ...val }; } }, methods: { onFocus(key) { this.errorInfo[key] = false; }, getErrorMessageByKey(key) { const value = this.data[key].trim(); switch (key) { case 'name': return value ? '' : t('nameEmpty'); case 'tel': return this.telValidator(value) ? '' : t('telInvalid'); } }, onSave() { const isValid = ['name', 'tel'].every(item => { const msg = this.getErrorMessageByKey(item); if (msg) { this.errorInfo[item] = true; Toast(msg); } return !msg; }); if (isValid && !this.isSaving) { this.$emit('save', this.data); } }, onDelete() { Dialog.confirm({ message: t('confirmDelete') }).then(() => { this.$emit('delete', this.data); }); } }, render(h) { const { data, errorInfo } = this; const onFocus = name => () => this.onFocus(name); return (
); } });