2
0
mirror of https://github.com/frappe/books.git synced 2025-01-27 00:58:35 +00:00
books/ui/components/Form/FormLayout.vue
2018-06-27 20:08:27 +05:30

88 lines
2.1 KiB
Vue

<template>
<form :class="['frappe-form-layout', { 'was-validated': invalid }]">
<div class="row" v-if="layoutConfig"
v-for="(section, i) in layoutConfig.sections" :key="i"
v-show="showSection(i)"
>
<div class="col" v-for="(column, j) in section.columns" :key="j">
<frappe-control
v-for="fieldname in column.fields"
:key="fieldname"
:docfield="getDocField(fieldname)"
:value="$data[fieldname]"
@change="value => updateDoc(fieldname, value)"
/>
</div>
</div>
<div v-if="!layout">
<frappe-control
v-for="docfield in fields"
:key="docfield.fieldname"
:docfield="docfield"
:value="$data[docfield.fieldname]"
@change="value => updateDoc(docfield.fieldname, value)"
/>
</div>
</form>
</template>
<script>
export default {
name: 'FormLayout',
props: ['doc', 'fields', 'layout', 'invalid', 'currentSection'],
data() {
const dataObj = {};
for (let df of this.fields) {
dataObj[df.fieldname] = this.doc[df.fieldname];
if (df.fieldtype === 'Table' && !dataObj[df.fieldname]) {
dataObj[df.fieldname] = [];
}
}
return dataObj;
},
created() {
this.doc.on('change', ({ doc, fieldname }) => {
if (fieldname) {
// update value
this[fieldname] = doc[fieldname];
} else {
// update all values
this.fields.forEach(df => {
this[df.fieldname] = doc[df.fieldname];
});
}
});
},
methods: {
getDocField(fieldname) {
return this.fields.find(df => df.fieldname === fieldname);
},
updateDoc(fieldname, value) {
this.doc.set(fieldname, value);
},
showSection(i) {
if (this.layoutConfig.paginated) {
return this.currentSection === i;
}
return true;
}
},
computed: {
layoutConfig() {
if (!this.layout) return false;
let config = this.layout;
if (Array.isArray(config)) {
config = {
sections: config
}
}
return config;
}
}
};
</script>