import _extends from "@babel/runtime/helpers/esm/extends"; // Utils import { createNamespace } from '../utils'; import { isMobile } from '../utils/validate/mobile'; // Components import Cell from '../cell'; import Field from '../field'; import Button from '../button'; import Dialog from '../dialog'; import Switch from '../switch'; var _createNamespace = createNamespace('contact-edit'), createComponent = _createNamespace[0], bem = _createNamespace[1], t = _createNamespace[2]; var defaultContact = { tel: '', name: '' }; export default createComponent({ props: { isEdit: Boolean, isSaving: Boolean, isDeleting: Boolean, showSetDefault: Boolean, setDefaultLabel: String, contactInfo: { type: Object, default: function _default() { return _extends({}, defaultContact); } }, telValidator: { type: Function, default: isMobile } }, data: function data() { return { data: _extends({}, defaultContact, this.contactInfo), errorInfo: { name: '', tel: '' } }; }, watch: { contactInfo: function contactInfo(val) { this.data = _extends({}, defaultContact, val); } }, methods: { onFocus: function onFocus(key) { this.errorInfo[key] = ''; }, getErrorMessageByKey: function getErrorMessageByKey(key) { var value = this.data[key].trim(); switch (key) { case 'name': return value ? '' : t('nameInvalid'); case 'tel': return this.telValidator(value) ? '' : t('telInvalid'); } }, onSave: function onSave() { var _this = this; var isValid = ['name', 'tel'].every(function (item) { var msg = _this.getErrorMessageByKey(item); if (msg) { _this.errorInfo[item] = msg; } return !msg; }); if (isValid && !this.isSaving) { this.$emit('save', this.data); } }, onDelete: function onDelete() { var _this2 = this; Dialog.confirm({ title: t('confirmDelete') }).then(function () { _this2.$emit('delete', _this2.data); }); } }, render: function render() { var _this3 = this; var h = arguments[0]; var data = this.data, errorInfo = this.errorInfo; var onFocus = function onFocus(name) { return function () { return _this3.onFocus(name); }; }; return h("div", { "class": bem() }, [h("div", { "class": bem('fields') }, [h(Field, { "attrs": { "clearable": true, "maxlength": "30", "label": t('name'), "placeholder": t('nameEmpty'), "errorMessage": errorInfo.name }, "on": { "focus": onFocus('name') }, "model": { value: data.name, callback: function callback($$v) { _this3.$set(data, "name", $$v); } } }), h(Field, { "attrs": { "clearable": true, "type": "tel", "label": t('tel'), "placeholder": t('telEmpty'), "errorMessage": errorInfo.tel }, "on": { "focus": onFocus('tel') }, "model": { value: data.tel, callback: function callback($$v) { _this3.$set(data, "tel", $$v); } } })]), this.showSetDefault && h(Cell, { "attrs": { "title": this.setDefaultLabel, "border": false }, "class": bem('switch-cell') }, [h(Switch, { "attrs": { "size": 24 }, "slot": "right-icon", "on": { "change": function change(event) { _this3.$emit('change-default', event); } }, "model": { value: data.isDefault, callback: function callback($$v) { _this3.$set(data, "isDefault", $$v); } } })]), h("div", { "class": bem('buttons') }, [h(Button, { "attrs": { "block": true, "round": true, "type": "danger", "text": t('save'), "loading": this.isSaving }, "on": { "click": this.onSave } }), this.isEdit && h(Button, { "attrs": { "block": true, "round": true, "text": t('delete'), "loading": this.isDeleting }, "on": { "click": this.onDelete } })])]); } });