mirror of
https://github.com/frappe/books.git
synced 2025-01-25 16:18:33 +00:00
Merge pull request #236 from 18alantom/minor-fixes-payments
fix: minor changes and fixes to Payments
This commit is contained in:
commit
ab97812239
@ -24,48 +24,48 @@ export default {
|
|||||||
'Excise Entry',
|
'Excise Entry',
|
||||||
'Write Off Entry',
|
'Write Off Entry',
|
||||||
'Opening Entry',
|
'Opening Entry',
|
||||||
'Depreciation Entry'
|
'Depreciation Entry',
|
||||||
],
|
],
|
||||||
required: 1
|
required: 1,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'date',
|
fieldname: 'date',
|
||||||
label: 'Date',
|
label: 'Date',
|
||||||
fieldtype: 'Date',
|
fieldtype: 'Date',
|
||||||
default: DateTime.local().toISODate()
|
default: () => DateTime.local().toISODate(),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'accounts',
|
fieldname: 'accounts',
|
||||||
label: 'Account Entries',
|
label: 'Account Entries',
|
||||||
fieldtype: 'Table',
|
fieldtype: 'Table',
|
||||||
childtype: 'JournalEntryAccount',
|
childtype: 'JournalEntryAccount',
|
||||||
required: true
|
required: true,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'referenceNumber',
|
fieldname: 'referenceNumber',
|
||||||
label: 'Reference Number',
|
label: 'Reference Number',
|
||||||
fieldtype: 'Data'
|
fieldtype: 'Data',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'referenceDate',
|
fieldname: 'referenceDate',
|
||||||
label: 'Reference Date',
|
label: 'Reference Date',
|
||||||
fieldtype: 'Date'
|
fieldtype: 'Date',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'userRemark',
|
fieldname: 'userRemark',
|
||||||
label: 'User Remark',
|
label: 'User Remark',
|
||||||
fieldtype: 'Text',
|
fieldtype: 'Text',
|
||||||
placeholder: 'User Remark'
|
placeholder: 'User Remark',
|
||||||
}
|
},
|
||||||
],
|
],
|
||||||
actions: [
|
actions: [
|
||||||
{
|
{
|
||||||
label: 'Revert',
|
label: 'Revert',
|
||||||
condition: doc => doc.submitted,
|
condition: (doc) => doc.submitted,
|
||||||
action(doc) {
|
action(doc) {
|
||||||
doc.revert();
|
doc.revert();
|
||||||
}
|
},
|
||||||
},
|
},
|
||||||
ledgerLink
|
ledgerLink,
|
||||||
]
|
],
|
||||||
};
|
};
|
||||||
|
@ -15,13 +15,13 @@ export default {
|
|||||||
label: 'Party',
|
label: 'Party',
|
||||||
fieldtype: 'Link',
|
fieldtype: 'Link',
|
||||||
target: 'Party',
|
target: 'Party',
|
||||||
required: 1
|
required: 1,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'date',
|
fieldname: 'date',
|
||||||
label: 'Posting Date',
|
label: 'Posting Date',
|
||||||
fieldtype: 'Date',
|
fieldtype: 'Date',
|
||||||
default: new Date().toISOString()
|
default: () => new Date().toISOString(),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'account',
|
fieldname: 'account',
|
||||||
@ -37,14 +37,14 @@ export default {
|
|||||||
return { accountType: ['in', ['Bank', 'Cash']], isGroup: 0 };
|
return { accountType: ['in', ['Bank', 'Cash']], isGroup: 0 };
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'paymentType',
|
fieldname: 'paymentType',
|
||||||
label: 'Payment Type',
|
label: 'Payment Type',
|
||||||
fieldtype: 'Select',
|
fieldtype: 'Select',
|
||||||
options: ['', 'Receive', 'Pay'],
|
options: ['', 'Receive', 'Pay'],
|
||||||
required: 1
|
required: 1,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'paymentAccount',
|
fieldname: 'paymentAccount',
|
||||||
@ -62,11 +62,11 @@ export default {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
formula: doc => {
|
formula: (doc) => {
|
||||||
if (doc.paymentMethod === 'Cash') {
|
if (doc.paymentMethod === 'Cash') {
|
||||||
return 'Cash';
|
return 'Cash';
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'paymentMethod',
|
fieldname: 'paymentMethod',
|
||||||
@ -74,37 +74,36 @@ export default {
|
|||||||
placeholder: 'Payment Method',
|
placeholder: 'Payment Method',
|
||||||
fieldtype: 'Select',
|
fieldtype: 'Select',
|
||||||
options: ['', 'Cash', 'Cheque', 'Transfer'],
|
options: ['', 'Cash', 'Cheque', 'Transfer'],
|
||||||
required: 1
|
required: 1,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'referenceId',
|
fieldname: 'referenceId',
|
||||||
label: 'Ref. / Cheque No.',
|
label: 'Ref. / Cheque No.',
|
||||||
placeholder: 'Ref. / Cheque No.',
|
placeholder: 'Ref. / Cheque No.',
|
||||||
fieldtype: 'Data',
|
fieldtype: 'Data',
|
||||||
required: 1 // TODO: UNIQUE
|
required: (doc) => doc.paymentMethod !== 'Cash', // TODO: UNIQUE
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'referenceDate',
|
fieldname: 'referenceDate',
|
||||||
label: 'Ref. Date',
|
label: 'Ref. Date',
|
||||||
placeholder: 'Ref. Date',
|
placeholder: 'Ref. Date',
|
||||||
fieldtype: 'Date'
|
fieldtype: 'Date',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'clearanceDate',
|
fieldname: 'clearanceDate',
|
||||||
label: 'Clearance Date',
|
label: 'Clearance Date',
|
||||||
placeholder: 'Clearance Date',
|
placeholder: 'Clearance Date',
|
||||||
fieldtype: 'Date',
|
fieldtype: 'Date',
|
||||||
hidden: doc => {
|
hidden: (doc) => doc.paymentMethod === 'Cash',
|
||||||
return doc.paymentMethod === 'Cash' ? 1 : 0;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'amount',
|
fieldname: 'amount',
|
||||||
label: 'Amount',
|
label: 'Amount',
|
||||||
fieldtype: 'Currency',
|
fieldtype: 'Currency',
|
||||||
required: 1,
|
required: 1,
|
||||||
formula: doc => doc.getSum('for', 'amount'),
|
formula: (doc) => doc.getSum('for', 'amount'),
|
||||||
validate(value, doc) {
|
validate(value, doc) {
|
||||||
|
if (doc.for.length === 0) return;
|
||||||
const amount = doc.getSum('for', 'amount');
|
const amount = doc.getSum('for', 'amount');
|
||||||
|
|
||||||
if (value > amount) {
|
if (value > amount) {
|
||||||
@ -119,24 +118,27 @@ export default {
|
|||||||
} else if (value === 0) {
|
} else if (value === 0) {
|
||||||
throw new frappe.errors.ValidationError(
|
throw new frappe.errors.ValidationError(
|
||||||
frappe._(
|
frappe._(
|
||||||
`Payment amount cannot be ${frappe.format(value, 'Currency')}. Amount has been reset to max viable amount.`
|
`Payment amount cannot be ${frappe.format(
|
||||||
|
value,
|
||||||
|
'Currency'
|
||||||
|
)}. Amount has been reset to max viable amount.`
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'writeoff',
|
fieldname: 'writeoff',
|
||||||
label: 'Write Off / Refund',
|
label: 'Write Off / Refund',
|
||||||
fieldtype: 'Currency'
|
fieldtype: 'Currency',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'for',
|
fieldname: 'for',
|
||||||
label: 'Payment For',
|
label: 'Payment Reference',
|
||||||
fieldtype: 'Table',
|
fieldtype: 'Table',
|
||||||
childtype: 'PaymentFor',
|
childtype: 'PaymentFor',
|
||||||
required: 1
|
required: 0,
|
||||||
}
|
},
|
||||||
],
|
],
|
||||||
|
|
||||||
quickEditFields: [
|
quickEditFields: [
|
||||||
@ -151,58 +153,68 @@ export default {
|
|||||||
'clearanceDate',
|
'clearanceDate',
|
||||||
'amount',
|
'amount',
|
||||||
'writeoff',
|
'writeoff',
|
||||||
'for'
|
'for',
|
||||||
],
|
],
|
||||||
|
|
||||||
layout: [
|
layout: [
|
||||||
{
|
{
|
||||||
columns: [
|
columns: [
|
||||||
{
|
{
|
||||||
fields: ['party', 'account']
|
fields: ['party', 'account'],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fields: ['date', 'paymentAccount']
|
fields: ['date', 'paymentAccount'],
|
||||||
}
|
},
|
||||||
]
|
],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
columns: [
|
columns: [
|
||||||
{
|
{
|
||||||
fields: ['paymentMethod']
|
fields: ['paymentMethod'],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fields: ['paymentType']
|
fields: ['paymentType'],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fields: ['referenceId']
|
fields: ['referenceId'],
|
||||||
}
|
},
|
||||||
]
|
],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
columns: [
|
columns: [
|
||||||
{
|
{
|
||||||
fields: ['referenceDate']
|
fields: ['referenceDate'],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fields: ['clearanceDate']
|
fields: ['clearanceDate'],
|
||||||
}
|
},
|
||||||
]
|
],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
columns: [
|
columns: [
|
||||||
{
|
{
|
||||||
fields: ['for']
|
fields: ['for'],
|
||||||
}
|
},
|
||||||
]
|
],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
columns: [
|
columns: [
|
||||||
{
|
{
|
||||||
fields: ['amount', 'writeoff']
|
fields: ['amount', 'writeoff'],
|
||||||
}
|
},
|
||||||
]
|
],
|
||||||
}
|
},
|
||||||
|
],
|
||||||
|
actions: [
|
||||||
|
{
|
||||||
|
label: 'Revert',
|
||||||
|
condition: (doc) => doc.submitted,
|
||||||
|
action(doc) {
|
||||||
|
doc.revert();
|
||||||
|
},
|
||||||
|
},
|
||||||
|
utils.ledgerLink,
|
||||||
],
|
],
|
||||||
|
|
||||||
links: [utils.ledgerLink]
|
links: [utils.ledgerLink],
|
||||||
};
|
};
|
||||||
|
@ -20,8 +20,8 @@ export default class PaymentServer extends BaseDocument {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async beforeSubmit() {
|
async beforeSubmit() {
|
||||||
if (!this.for.length) {
|
if (!this.for || !this.for.length) {
|
||||||
throw new Error(`No reference for the payment.`);
|
return;
|
||||||
}
|
}
|
||||||
for (let row of this.for) {
|
for (let row of this.for) {
|
||||||
if (!['SalesInvoice', 'PurchaseInvoice'].includes(row.referenceType)) {
|
if (!['SalesInvoice', 'PurchaseInvoice'].includes(row.referenceType)) {
|
||||||
@ -36,9 +36,14 @@ export default class PaymentServer extends BaseDocument {
|
|||||||
outstandingAmount = baseGrandTotal;
|
outstandingAmount = baseGrandTotal;
|
||||||
}
|
}
|
||||||
if (this.amount <= 0 || this.amount > outstandingAmount) {
|
if (this.amount <= 0 || this.amount > outstandingAmount) {
|
||||||
throw new Error(
|
let message = frappe._(
|
||||||
`Payment amount (${this.amount}) should be greater than 0 and less than Outstanding amount (${outstandingAmount})`
|
`Payment amount (${this.amount}) should be less than Outstanding amount (${outstandingAmount}).`
|
||||||
);
|
);
|
||||||
|
if (this.amount <= 0) {
|
||||||
|
const amt = this.amount < 0 ? ` (${this.amount})` : '';
|
||||||
|
message = frappe._(`Payment amount${amt} should be greater than 0.`);
|
||||||
|
}
|
||||||
|
throw new frappe.errors.ValidationError(message);
|
||||||
} else {
|
} else {
|
||||||
// update outstanding amounts in invoice and party
|
// update outstanding amounts in invoice and party
|
||||||
let newOutstanding = outstandingAmount - this.amount;
|
let newOutstanding = outstandingAmount - this.amount;
|
||||||
@ -61,4 +66,4 @@ export default class PaymentServer extends BaseDocument {
|
|||||||
|
|
||||||
// Maybe revert outstanding amount of invoice too?
|
// Maybe revert outstanding amount of invoice too?
|
||||||
}
|
}
|
||||||
};
|
}
|
||||||
|
@ -26,7 +26,7 @@ export default {
|
|||||||
fieldname: 'date',
|
fieldname: 'date',
|
||||||
label: 'Date',
|
label: 'Date',
|
||||||
fieldtype: 'Date',
|
fieldtype: 'Date',
|
||||||
default: new Date().toISOString().slice(0, 10)
|
default: () => new Date().toISOString().slice(0, 10)
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'supplier',
|
fieldname: 'supplier',
|
||||||
|
@ -19,20 +19,20 @@ export default {
|
|||||||
fieldname: 'name',
|
fieldname: 'name',
|
||||||
fieldtype: 'Data',
|
fieldtype: 'Data',
|
||||||
required: 1,
|
required: 1,
|
||||||
readOnly: 1
|
readOnly: 1,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'date',
|
fieldname: 'date',
|
||||||
label: 'Date',
|
label: 'Date',
|
||||||
fieldtype: 'Date',
|
fieldtype: 'Date',
|
||||||
default: new Date().toISOString().slice(0, 10)
|
default: () => new Date().toISOString().slice(0, 10),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'customer',
|
fieldname: 'customer',
|
||||||
label: 'Customer',
|
label: 'Customer',
|
||||||
fieldtype: 'Link',
|
fieldtype: 'Link',
|
||||||
target: 'Customer',
|
target: 'Customer',
|
||||||
required: 1
|
required: 1,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'account',
|
fieldname: 'account',
|
||||||
@ -40,90 +40,90 @@ export default {
|
|||||||
fieldtype: 'Link',
|
fieldtype: 'Link',
|
||||||
target: 'Account',
|
target: 'Account',
|
||||||
disableCreation: true,
|
disableCreation: true,
|
||||||
formula: doc => doc.getFrom('Party', doc.customer, 'defaultAccount'),
|
formula: (doc) => doc.getFrom('Party', doc.customer, 'defaultAccount'),
|
||||||
getFilters: () => {
|
getFilters: () => {
|
||||||
return {
|
return {
|
||||||
isGroup: 0,
|
isGroup: 0,
|
||||||
accountType: 'Receivable'
|
accountType: 'Receivable',
|
||||||
};
|
};
|
||||||
}
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'currency',
|
fieldname: 'currency',
|
||||||
label: 'Customer Currency',
|
label: 'Customer Currency',
|
||||||
fieldtype: 'Link',
|
fieldtype: 'Link',
|
||||||
target: 'Currency',
|
target: 'Currency',
|
||||||
formula: doc => doc.getFrom('Party', doc.customer, 'currency'),
|
formula: (doc) => doc.getFrom('Party', doc.customer, 'currency'),
|
||||||
formulaDependsOn: ['customer']
|
formulaDependsOn: ['customer'],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'exchangeRate',
|
fieldname: 'exchangeRate',
|
||||||
label: 'Exchange Rate',
|
label: 'Exchange Rate',
|
||||||
fieldtype: 'Float',
|
fieldtype: 'Float',
|
||||||
formula: doc => doc.getExchangeRate(),
|
formula: (doc) => doc.getExchangeRate(),
|
||||||
readOnly: true
|
readOnly: true,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'items',
|
fieldname: 'items',
|
||||||
label: 'Items',
|
label: 'Items',
|
||||||
fieldtype: 'Table',
|
fieldtype: 'Table',
|
||||||
childtype: 'SalesInvoiceItem',
|
childtype: 'SalesInvoiceItem',
|
||||||
required: true
|
required: true,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'netTotal',
|
fieldname: 'netTotal',
|
||||||
label: 'Net Total',
|
label: 'Net Total',
|
||||||
fieldtype: 'Currency',
|
fieldtype: 'Currency',
|
||||||
formula: doc => doc.getSum('items', 'amount'),
|
formula: (doc) => doc.getSum('items', 'amount'),
|
||||||
readOnly: 1,
|
readOnly: 1,
|
||||||
getCurrency: doc => doc.currency
|
getCurrency: (doc) => doc.currency,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'baseNetTotal',
|
fieldname: 'baseNetTotal',
|
||||||
label: 'Net Total (Company Currency)',
|
label: 'Net Total (Company Currency)',
|
||||||
fieldtype: 'Currency',
|
fieldtype: 'Currency',
|
||||||
formula: doc => doc.netTotal * doc.exchangeRate,
|
formula: (doc) => doc.netTotal * doc.exchangeRate,
|
||||||
readOnly: 1
|
readOnly: 1,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'taxes',
|
fieldname: 'taxes',
|
||||||
label: 'Taxes',
|
label: 'Taxes',
|
||||||
fieldtype: 'Table',
|
fieldtype: 'Table',
|
||||||
childtype: 'TaxSummary',
|
childtype: 'TaxSummary',
|
||||||
formula: doc => doc.getTaxSummary(),
|
formula: (doc) => doc.getTaxSummary(),
|
||||||
readOnly: 1
|
readOnly: 1,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'grandTotal',
|
fieldname: 'grandTotal',
|
||||||
label: 'Grand Total',
|
label: 'Grand Total',
|
||||||
fieldtype: 'Currency',
|
fieldtype: 'Currency',
|
||||||
formula: doc => doc.getGrandTotal(),
|
formula: (doc) => doc.getGrandTotal(),
|
||||||
readOnly: 1,
|
readOnly: 1,
|
||||||
getCurrency: doc => doc.currency
|
getCurrency: (doc) => doc.currency,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'baseGrandTotal',
|
fieldname: 'baseGrandTotal',
|
||||||
label: 'Grand Total (Company Currency)',
|
label: 'Grand Total (Company Currency)',
|
||||||
fieldtype: 'Currency',
|
fieldtype: 'Currency',
|
||||||
formula: doc => doc.grandTotal * doc.exchangeRate,
|
formula: (doc) => doc.grandTotal * doc.exchangeRate,
|
||||||
readOnly: 1
|
readOnly: 1,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'outstandingAmount',
|
fieldname: 'outstandingAmount',
|
||||||
label: 'Outstanding Amount',
|
label: 'Outstanding Amount',
|
||||||
fieldtype: 'Currency',
|
fieldtype: 'Currency',
|
||||||
formula: doc => {
|
formula: (doc) => {
|
||||||
if (doc.submitted) return;
|
if (doc.submitted) return;
|
||||||
return doc.baseGrandTotal;
|
return doc.baseGrandTotal;
|
||||||
},
|
},
|
||||||
readOnly: 1
|
readOnly: 1,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
fieldname: 'terms',
|
fieldname: 'terms',
|
||||||
label: 'Notes',
|
label: 'Notes',
|
||||||
fieldtype: 'Text'
|
fieldtype: 'Text',
|
||||||
}
|
},
|
||||||
],
|
],
|
||||||
|
|
||||||
actions: getActions('SalesInvoice')
|
actions: getActions('SalesInvoice'),
|
||||||
};
|
};
|
||||||
|
@ -0,0 +1 @@
|
|||||||
|
v0_0_3/makePaymentRefIdNullable
|
28
patches/v0_0_3/makePaymentRefIdNullable.js
Normal file
28
patches/v0_0_3/makePaymentRefIdNullable.js
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
import frappe from 'frappejs';
|
||||||
|
|
||||||
|
export default async function execute() {
|
||||||
|
// Since sqlite has no ALTER TABLE to change column meta
|
||||||
|
// the table has to be _Prestiged_.
|
||||||
|
const tableInfo = await frappe.db.sql('pragma table_info("Payment")');
|
||||||
|
const referenceId = tableInfo.find(({ name }) => name === 'referenceId');
|
||||||
|
if (!referenceId || !referenceId.notnull) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
await frappe.db.createTable('Payment', '__Payment');
|
||||||
|
await frappe.db.sql('insert into __Payment select * from Payment');
|
||||||
|
|
||||||
|
const mainCount = await frappe.db.knex
|
||||||
|
.table('Payment')
|
||||||
|
.count('name as count');
|
||||||
|
const replCount = await frappe.db.knex
|
||||||
|
.table('__Payment')
|
||||||
|
.count('name as count');
|
||||||
|
|
||||||
|
if (mainCount[0].count === replCount[0].count) {
|
||||||
|
await frappe.db.knex.schema.dropTable('Payment');
|
||||||
|
await frappe.db.knex.schema.renameTable('__Payment', 'Payment');
|
||||||
|
} else {
|
||||||
|
await frappe.db.knex.schema.dropTable('__Payment');
|
||||||
|
}
|
||||||
|
}
|
@ -8,7 +8,8 @@
|
|||||||
size="small"
|
size="small"
|
||||||
:df="df"
|
:df="df"
|
||||||
:value="doc[df.fieldname]"
|
:value="doc[df.fieldname]"
|
||||||
@change="value => onChange(df, value)"
|
:read-only="submitted"
|
||||||
|
@change="(value) => onChange(df, value)"
|
||||||
/>
|
/>
|
||||||
<template v-else>
|
<template v-else>
|
||||||
<template v-if="inlineEditField === df && inlineEditDoc">
|
<template v-if="inlineEditField === df && inlineEditDoc">
|
||||||
@ -20,7 +21,7 @@
|
|||||||
:column-ratio="columnRatio"
|
:column-ratio="columnRatio"
|
||||||
:no-border="true"
|
:no-border="true"
|
||||||
:focus-first-input="true"
|
:focus-first-input="true"
|
||||||
@error="msg => $emit('error', msg)"
|
@error="(msg) => $emit('error', msg)"
|
||||||
/>
|
/>
|
||||||
<div class="flex px-4 pb-2">
|
<div class="flex px-4 pb-2">
|
||||||
<Button
|
<Button
|
||||||
@ -55,7 +56,7 @@
|
|||||||
class="py-2 pr-4"
|
class="py-2 pr-4"
|
||||||
@click="activateInlineEditing(df)"
|
@click="activateInlineEditing(df)"
|
||||||
:class="{
|
:class="{
|
||||||
'pl-2': df.fieldtype === 'AttachImage'
|
'pl-2': df.fieldtype === 'AttachImage',
|
||||||
}"
|
}"
|
||||||
>
|
>
|
||||||
<FormControl
|
<FormControl
|
||||||
@ -71,9 +72,10 @@
|
|||||||
: doc[df.fieldname]
|
: doc[df.fieldname]
|
||||||
"
|
"
|
||||||
:class="{ 'p-2': df.fieldtype === 'Check' }"
|
:class="{ 'p-2': df.fieldtype === 'Check' }"
|
||||||
@change="value => onChange(df, value)"
|
:read-only="submitted"
|
||||||
|
@change="(value) => onChange(df, value)"
|
||||||
@focus="activateInlineEditing(df)"
|
@focus="activateInlineEditing(df)"
|
||||||
@new-doc="newdoc => onChange(df, newdoc.name)"
|
@new-doc="(newdoc) => onChange(df, newdoc.name)"
|
||||||
/>
|
/>
|
||||||
<div
|
<div
|
||||||
class="text-sm text-red-600 mt-2 pl-2"
|
class="text-sm text-red-600 mt-2 pl-2"
|
||||||
@ -101,10 +103,10 @@ let TwoColumnForm = {
|
|||||||
autosave: Boolean,
|
autosave: Boolean,
|
||||||
columnRatio: {
|
columnRatio: {
|
||||||
type: Array,
|
type: Array,
|
||||||
default: () => [1, 1]
|
default: () => [1, 1],
|
||||||
},
|
},
|
||||||
noBorder: Boolean,
|
noBorder: Boolean,
|
||||||
focusFirstInput: Boolean
|
focusFirstInput: Boolean,
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
@ -112,20 +114,20 @@ let TwoColumnForm = {
|
|||||||
inlineEditDoc: null,
|
inlineEditDoc: null,
|
||||||
inlineEditFields: null,
|
inlineEditFields: null,
|
||||||
inlineEditDisplayField: null,
|
inlineEditDisplayField: null,
|
||||||
errors: {}
|
errors: {},
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
provide() {
|
provide() {
|
||||||
return {
|
return {
|
||||||
doctype: this.doc.doctype,
|
doctype: this.doc.doctype,
|
||||||
name: this.doc.name,
|
name: this.doc.name,
|
||||||
doc: this.doc
|
doc: this.doc,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
components: {
|
components: {
|
||||||
FormControl,
|
FormControl,
|
||||||
Button,
|
Button,
|
||||||
TwoColumnForm: () => TwoColumnForm
|
TwoColumnForm: () => TwoColumnForm,
|
||||||
},
|
},
|
||||||
mounted() {
|
mounted() {
|
||||||
if (this.focusFirstInput) {
|
if (this.focusFirstInput) {
|
||||||
@ -135,8 +137,9 @@ let TwoColumnForm = {
|
|||||||
methods: {
|
methods: {
|
||||||
onChange(df, value) {
|
onChange(df, value) {
|
||||||
if (value == null) {
|
if (value == null) {
|
||||||
return;
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
let oldValue = this.doc.get(df.fieldname);
|
let oldValue = this.doc.get(df.fieldname);
|
||||||
|
|
||||||
if (oldValue === value) {
|
if (oldValue === value) {
|
||||||
@ -151,7 +154,7 @@ let TwoColumnForm = {
|
|||||||
// reset error messages
|
// reset error messages
|
||||||
this.$set(this.errors, df.fieldname, null);
|
this.$set(this.errors, df.fieldname, null);
|
||||||
|
|
||||||
this.doc.set(df.fieldname, value).catch(e => {
|
this.doc.set(df.fieldname, value).catch((e) => {
|
||||||
// set error message for this field
|
// set error message for this field
|
||||||
this.$set(this.errors, df.fieldname, getErrorMessage(e, this.doc));
|
this.$set(this.errors, df.fieldname, getErrorMessage(e, this.doc));
|
||||||
});
|
});
|
||||||
@ -197,7 +200,7 @@ let TwoColumnForm = {
|
|||||||
await this.doc.loadLinks();
|
await this.doc.loadLinks();
|
||||||
this.inlineEditField = null;
|
this.inlineEditField = null;
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
formFields() {
|
formFields() {
|
||||||
@ -205,13 +208,16 @@ let TwoColumnForm = {
|
|||||||
},
|
},
|
||||||
style() {
|
style() {
|
||||||
let templateColumns = (this.columnRatio || [1, 1])
|
let templateColumns = (this.columnRatio || [1, 1])
|
||||||
.map(r => `${r}fr`)
|
.map((r) => `${r}fr`)
|
||||||
.join(' ');
|
.join(' ');
|
||||||
return {
|
return {
|
||||||
'grid-template-columns': templateColumns
|
'grid-template-columns': templateColumns,
|
||||||
};
|
};
|
||||||
}
|
},
|
||||||
}
|
submitted() {
|
||||||
|
return Boolean(this.doc.meta.isSubmittable && this.doc.submitted);
|
||||||
|
},
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
export default TwoColumnForm;
|
export default TwoColumnForm;
|
||||||
|
@ -6,11 +6,11 @@ const requirePatch = require.context('../patches', true, /\w+\.(js)$/);
|
|||||||
export default async function runMigrate() {
|
export default async function runMigrate() {
|
||||||
let patchOrder = patchesTxt.split('\n');
|
let patchOrder = patchesTxt.split('\n');
|
||||||
let allPatches = {};
|
let allPatches = {};
|
||||||
requirePatch.keys().forEach(fileName => {
|
requirePatch.keys().forEach((fileName) => {
|
||||||
if (fileName === './index.js') return;
|
if (fileName === './index.js') return;
|
||||||
let method;
|
let method;
|
||||||
try {
|
try {
|
||||||
method = requirePatch(fileName);
|
method = requirePatch(fileName).default;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error(error);
|
console.error(error);
|
||||||
method = null;
|
method = null;
|
||||||
|
@ -26,10 +26,10 @@
|
|||||||
type="primary"
|
type="primary"
|
||||||
v-if="
|
v-if="
|
||||||
meta &&
|
meta &&
|
||||||
meta.isSubmittable &&
|
meta.isSubmittable &&
|
||||||
doc &&
|
doc &&
|
||||||
!doc.submitted &&
|
!doc.submitted &&
|
||||||
!doc._notInserted
|
!doc._notInserted
|
||||||
"
|
"
|
||||||
class="ml-2 text-white text-xs"
|
class="ml-2 text-white text-xs"
|
||||||
>
|
>
|
||||||
@ -43,7 +43,7 @@
|
|||||||
v-if="imageField"
|
v-if="imageField"
|
||||||
:df="imageField"
|
:df="imageField"
|
||||||
:value="doc[imageField.fieldname]"
|
:value="doc[imageField.fieldname]"
|
||||||
@change="value => valueChange(imageField, value)"
|
@change="(value) => valueChange(imageField, value)"
|
||||||
size="small"
|
size="small"
|
||||||
class="mb-1"
|
class="mb-1"
|
||||||
:letter-placeholder="
|
:letter-placeholder="
|
||||||
@ -57,7 +57,7 @@
|
|||||||
v-if="titleField"
|
v-if="titleField"
|
||||||
:df="titleField"
|
:df="titleField"
|
||||||
:value="doc[titleField.fieldname]"
|
:value="doc[titleField.fieldname]"
|
||||||
@change="value => valueChange(titleField, value)"
|
@change="(value) => valueChange(titleField, value)"
|
||||||
@input="setTitleSize"
|
@input="setTitleSize"
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
@ -81,7 +81,11 @@ import Button from '@/components/Button';
|
|||||||
import FormControl from '@/components/Controls/FormControl';
|
import FormControl from '@/components/Controls/FormControl';
|
||||||
import TwoColumnForm from '@/components/TwoColumnForm';
|
import TwoColumnForm from '@/components/TwoColumnForm';
|
||||||
import DropdownWithActions from '@/components/DropdownWithActions';
|
import DropdownWithActions from '@/components/DropdownWithActions';
|
||||||
import { openQuickEdit, getActionsForDocument } from '@/utils';
|
import {
|
||||||
|
openQuickEdit,
|
||||||
|
getActionsForDocument,
|
||||||
|
handleErrorWithDialog,
|
||||||
|
} from '@/utils';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'QuickEditForm',
|
name: 'QuickEditForm',
|
||||||
@ -90,7 +94,7 @@ export default {
|
|||||||
Button,
|
Button,
|
||||||
FormControl,
|
FormControl,
|
||||||
TwoColumnForm,
|
TwoColumnForm,
|
||||||
DropdownWithActions
|
DropdownWithActions,
|
||||||
},
|
},
|
||||||
provide() {
|
provide() {
|
||||||
let vm = this;
|
let vm = this;
|
||||||
@ -99,7 +103,7 @@ export default {
|
|||||||
name: this.name,
|
name: this.name,
|
||||||
get doc() {
|
get doc() {
|
||||||
return vm.doc;
|
return vm.doc;
|
||||||
}
|
},
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
@ -107,7 +111,7 @@ export default {
|
|||||||
doc: null,
|
doc: null,
|
||||||
titleField: null,
|
titleField: null,
|
||||||
imageField: null,
|
imageField: null,
|
||||||
statusText: null
|
statusText: null,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
async created() {
|
async created() {
|
||||||
@ -120,7 +124,7 @@ export default {
|
|||||||
fields() {
|
fields() {
|
||||||
return this.meta
|
return this.meta
|
||||||
.getQuickEditFields()
|
.getQuickEditFields()
|
||||||
.filter(df => !(this.hideFields || []).includes(df.fieldname));
|
.filter((df) => !(this.hideFields || []).includes(df.fieldname));
|
||||||
},
|
},
|
||||||
actions() {
|
actions() {
|
||||||
return getActionsForDocument(this.doc);
|
return getActionsForDocument(this.doc);
|
||||||
@ -130,7 +134,7 @@ export default {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return this.meta.quickEditWidget(this.doc);
|
return this.meta.quickEditWidget(this.doc);
|
||||||
}
|
},
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
async fetchMetaAndDoc() {
|
async fetchMetaAndDoc() {
|
||||||
@ -165,7 +169,7 @@ export default {
|
|||||||
this.doc.once('afterRename', () => {
|
this.doc.once('afterRename', () => {
|
||||||
openQuickEdit({
|
openQuickEdit({
|
||||||
doctype: this.doctype,
|
doctype: this.doctype,
|
||||||
name: this.doc.name
|
name: this.doc.name,
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
this.doc.on('beforeUpdate', () => {
|
this.doc.on('beforeUpdate', () => {
|
||||||
@ -186,8 +190,14 @@ export default {
|
|||||||
insertDoc() {
|
insertDoc() {
|
||||||
this.$refs.form.insert();
|
this.$refs.form.insert();
|
||||||
},
|
},
|
||||||
submitDoc() {
|
async submitDoc() {
|
||||||
this.$refs.form.submit();
|
console.log(this.meta)
|
||||||
|
console.log(this.doc)
|
||||||
|
try {
|
||||||
|
await this.$refs.form.submit();
|
||||||
|
} catch (e) {
|
||||||
|
this.statusText = null;
|
||||||
|
}
|
||||||
},
|
},
|
||||||
routeToPrevious() {
|
routeToPrevious() {
|
||||||
this.$router.back();
|
this.$router.back();
|
||||||
@ -202,7 +212,7 @@ export default {
|
|||||||
}
|
}
|
||||||
input.size = valueLength;
|
input.size = valueLength;
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
}
|
},
|
||||||
};
|
};
|
||||||
</script>
|
</script>
|
||||||
|
@ -33,7 +33,7 @@ function getInitializedPrintWindow() {
|
|||||||
const printWindow = new BrowserWindow({
|
const printWindow = new BrowserWindow({
|
||||||
width: 595,
|
width: 595,
|
||||||
height: 842,
|
height: 842,
|
||||||
show: true,
|
show: false,
|
||||||
webPreferences: {
|
webPreferences: {
|
||||||
contextIsolation: false,
|
contextIsolation: false,
|
||||||
nodeIntegration: process.env.ELECTRON_NODE_INTEGRATION,
|
nodeIntegration: process.env.ELECTRON_NODE_INTEGRATION,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user