2
0
mirror of https://github.com/frappe/books.git synced 2025-01-11 02:36:14 +00:00

fix: Inline errors in TwoColumnForm

This commit is contained in:
Faris Ansari 2020-01-29 16:31:45 +05:30
parent f4fc9703bb
commit 463631d306
2 changed files with 26 additions and 10 deletions

View File

@ -46,8 +46,10 @@
:class="{ 'border-b': !noBorder }"
:style="style"
>
<div class="py-2 pl-4 flex items-center text-gray-600">
{{ df.label }}
<div class="py-2 pl-4 flex text-gray-600">
<div class="py-1">
{{ df.label }}
</div>
</div>
<div class="py-2 pr-4" @click="activateInlineEditing(df)">
<FormControl
@ -66,6 +68,12 @@
@focus="activateInlineEditing(df)"
@new-doc="newdoc => onChange(df, newdoc.name)"
/>
<div
class="text-sm text-red-600 mt-2 pl-2"
v-if="errors[df.fieldname]"
>
{{ errors[df.fieldname] }}
</div>
</div>
</div>
</template>
@ -76,7 +84,7 @@
import frappe from 'frappejs';
import FormControl from '@/components/Controls/FormControl';
import Button from '@/components/Button';
import { handleErrorWithDialog } from '@/utils';
import { getErrorMessage, handleErrorWithDialog } from '@/utils';
let TwoColumnForm = {
name: 'TwoColumnForm',
@ -96,7 +104,8 @@ let TwoColumnForm = {
inlineEditField: null,
inlineEditDoc: null,
inlineEditFields: null,
inlineEditDisplayField: null
inlineEditDisplayField: null,
errors: {}
};
},
provide() {
@ -132,7 +141,13 @@ let TwoColumnForm = {
return this.doc.rename(value);
}
this.doc.set(df.fieldname, value).catch(this.handleError);
// reset error messages
this.$set(this.errors, df.fieldname, null);
this.doc.set(df.fieldname, value).catch(e => {
// set error message for this field
this.$set(this.errors, df.fieldname, getErrorMessage(e, this.doc));
});
if (this.autosave && this.doc._dirty && !this.doc.isNew()) {
if (df.fieldtype === 'Table') {

View File

@ -184,7 +184,7 @@ export function openQuickEdit({ doctype, name, hideFields, defaults = {} }) {
});
}
export function handleErrorWithDialog(e, doc) {
export function getErrorMessage(e, doc) {
let errorMessage = e.message || _('An error occurred');
if (e.type === frappe.errors.LinkValidationError) {
errorMessage = _('{0} {1} is linked with existing records.', [
@ -194,11 +194,12 @@ export function handleErrorWithDialog(e, doc) {
} else if (e.type === frappe.errors.DuplicateEntryError) {
errorMessage = _('{0} {1} already exists.', [doc.doctype, doc.name]);
}
return errorMessage;
}
showMessageDialog({
message: errorMessage
});
export function handleErrorWithDialog(e, doc) {
let errorMessage = getErrorMessage(e, doc);
showMessageDialog({ message: errorMessage });
throw e;
}