var template = `

{{title}}

{{content}}

`; export default { template: template, props: { title: String, loading: Boolean, visible: Boolean, content: { type: String, default: '' }, fields: { type: Array, default () { return [] } }, showLabel: { type: Boolean, default: false }, mainText: { type: String, default: 'OK' }, secondText: String, mainClick: { type: Function, default () { this.visible = false; } }, secondClick: { type: Function, default () { this.visible = false; } } }, data() { return { formFields: [] }; }, computed: { btnTabIndex() { return this.fields.length + 1; } }, watch: { fields: { immediate: true, handler() { this.formFields = this.fields.map(field => { if (typeof field === 'string') return { name: field, label: field, value: '', type: 'text', } if (typeof field === 'object') return { name: field.name || '', label: field.label || '', value: field.value || '', type: field.type || 'text', } }); } }, 'fields.length'() { this.focus(); }, visible: { immediate: true, handler() { this.focus() } } }, methods: { fieldType(f) { var type = f.type || 'text'; if (type !== 'text' && type !== 'password') return 'text'; else return type; }, handleMainClick() { var data = {}; this.formFields.forEach(field => { var value = field.value; if (field.type === 'number') value = parseInt(value, 10) || 0; else if (field.type === 'float') value = parseFloat(value) || 0.0; data[field.name] = value; }) this.mainClick(data); }, handleSecondClick() { this.secondClick(); }, focus() { this.$nextTick(() => { if (!this.visible) return; var fields = this.$refs.input, otherInput = this.$el.querySelectorAll('input'), button = this.$refs.mainButton; if (fields && fields.length > 0) { this.$refs.input[0].focus(); this.$refs.input[0].select(); } else if (otherInput && otherInput.length > 0) { otherInput[0].focus(); otherInput[0].select(); } else if (button) { button.focus(); } }) } } }