2022-02-16 11:49:16 +05:30
|
|
|
import { t } from 'frappe';
|
2021-11-04 16:01:26 +05:30
|
|
|
export default {
|
2019-08-01 17:22:58 +05:30
|
|
|
name: 'PurchaseInvoiceItem',
|
2019-07-19 18:54:31 +05:30
|
|
|
doctype: 'DocType',
|
|
|
|
isChild: 1,
|
|
|
|
keywordFields: [],
|
2019-12-04 22:51:31 +05:30
|
|
|
tableFields: ['item', 'tax', 'quantity', 'rate', 'amount'],
|
2019-07-19 18:54:31 +05:30
|
|
|
fields: [
|
|
|
|
{
|
|
|
|
fieldname: 'item',
|
2022-02-16 11:49:16 +05:30
|
|
|
label: t`Item`,
|
2019-07-19 18:54:31 +05:30
|
|
|
fieldtype: 'Link',
|
|
|
|
target: 'Item',
|
2020-02-03 23:25:02 +05:30
|
|
|
required: 1,
|
|
|
|
getFilters(_, doc) {
|
2021-12-11 00:47:28 +05:30
|
|
|
let items = doc.parentdoc.items.map((d) => d.item).filter(Boolean);
|
2022-03-10 12:23:28 +05:30
|
|
|
|
|
|
|
const baseFilter = { for: ['not in', ['sales']] };
|
|
|
|
if (items.length <= 0) {
|
|
|
|
return baseFilter;
|
2020-02-03 23:25:02 +05:30
|
|
|
}
|
2022-03-10 12:23:28 +05:30
|
|
|
|
|
|
|
return {
|
|
|
|
name: ['not in', items],
|
|
|
|
...baseFilter,
|
|
|
|
};
|
2021-12-11 00:47:28 +05:30
|
|
|
},
|
2019-07-19 18:54:31 +05:30
|
|
|
},
|
|
|
|
{
|
|
|
|
fieldname: 'description',
|
2022-02-16 11:49:16 +05:30
|
|
|
label: t`Description`,
|
2019-07-19 18:54:31 +05:30
|
|
|
fieldtype: 'Text',
|
|
|
|
formula: (row, doc) => doc.getFrom('Item', row.item, 'description'),
|
2021-12-11 00:47:28 +05:30
|
|
|
hidden: 1,
|
2019-07-19 18:54:31 +05:30
|
|
|
},
|
|
|
|
{
|
|
|
|
fieldname: 'quantity',
|
2022-02-16 11:49:16 +05:30
|
|
|
label: t`Quantity`,
|
2019-07-19 18:54:31 +05:30
|
|
|
fieldtype: 'Float',
|
2019-12-13 01:04:37 +05:30
|
|
|
required: 1,
|
2021-12-27 17:04:34 +05:30
|
|
|
default: 1,
|
2019-07-19 18:54:31 +05:30
|
|
|
},
|
|
|
|
{
|
|
|
|
fieldname: 'rate',
|
2022-02-16 11:49:16 +05:30
|
|
|
label: t`Rate`,
|
2019-07-19 18:54:31 +05:30
|
|
|
fieldtype: 'Currency',
|
|
|
|
required: 1,
|
2019-12-04 22:51:31 +05:30
|
|
|
formula: async (row, doc) => {
|
2021-12-27 17:04:34 +05:30
|
|
|
const baseRate =
|
|
|
|
(await doc.getFrom('Item', row.item, 'rate')) || frappe.pesa(0);
|
|
|
|
return baseRate.div(doc.exchangeRate);
|
2019-12-04 22:51:31 +05:30
|
|
|
},
|
2021-12-11 00:47:28 +05:30
|
|
|
getCurrency: (row, doc) => doc.currency,
|
2022-02-28 12:46:33 +05:30
|
|
|
validate(value) {
|
|
|
|
if (value.gte(0)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
throw new frappe.errors.ValidationError(
|
|
|
|
frappe.t`Rate (${frappe.format(
|
|
|
|
value,
|
|
|
|
'Currency'
|
|
|
|
)}) cannot be less zero.`
|
|
|
|
);
|
|
|
|
},
|
2019-12-04 22:51:31 +05:30
|
|
|
},
|
|
|
|
{
|
|
|
|
fieldname: 'baseRate',
|
2022-02-16 11:49:16 +05:30
|
|
|
label: t`Rate (Company Currency)`,
|
2019-12-04 22:51:31 +05:30
|
|
|
fieldtype: 'Currency',
|
2021-12-27 17:04:34 +05:30
|
|
|
formula: (row, doc) => row.rate.mul(doc.exchangeRate),
|
2021-12-11 00:47:28 +05:30
|
|
|
readOnly: 1,
|
2019-07-19 18:54:31 +05:30
|
|
|
},
|
|
|
|
{
|
|
|
|
fieldname: 'account',
|
2022-02-16 11:49:16 +05:30
|
|
|
label: t`Account`,
|
2019-07-19 18:54:31 +05:30
|
|
|
fieldtype: 'Link',
|
|
|
|
target: 'Account',
|
|
|
|
required: 1,
|
2022-02-28 17:36:41 +05:30
|
|
|
readOnly: 1,
|
2021-12-11 00:47:28 +05:30
|
|
|
formula: (row, doc) => doc.getFrom('Item', row.item, 'expenseAccount'),
|
2019-07-19 18:54:31 +05:30
|
|
|
},
|
|
|
|
{
|
|
|
|
fieldname: 'tax',
|
2022-02-16 11:49:16 +05:30
|
|
|
label: t`Tax`,
|
2019-07-19 18:54:31 +05:30
|
|
|
fieldtype: 'Link',
|
|
|
|
target: 'Tax',
|
|
|
|
formula: (row, doc) => {
|
|
|
|
if (row.tax) return row.tax;
|
|
|
|
return doc.getFrom('Item', row.item, 'tax');
|
2021-12-11 00:47:28 +05:30
|
|
|
},
|
2019-07-19 18:54:31 +05:30
|
|
|
},
|
|
|
|
{
|
|
|
|
fieldname: 'amount',
|
2022-02-16 11:49:16 +05:30
|
|
|
label: t`Amount`,
|
2019-07-19 18:54:31 +05:30
|
|
|
fieldtype: 'Currency',
|
|
|
|
readOnly: 1,
|
2021-12-27 17:04:34 +05:30
|
|
|
formula: (row) => row.rate.mul(row.quantity),
|
2021-12-11 00:47:28 +05:30
|
|
|
getCurrency: (row, doc) => doc.currency,
|
2019-07-19 18:54:31 +05:30
|
|
|
},
|
|
|
|
{
|
2019-12-04 22:51:31 +05:30
|
|
|
fieldname: 'baseAmount',
|
2022-02-16 11:49:16 +05:30
|
|
|
label: t`Amount (Company Currency)`,
|
2019-12-04 22:51:31 +05:30
|
|
|
fieldtype: 'Currency',
|
2019-07-19 18:54:31 +05:30
|
|
|
readOnly: 1,
|
2021-12-27 17:04:34 +05:30
|
|
|
formula: (row, doc) => row.amount.mul(doc.exchangeRate),
|
2021-12-11 00:47:28 +05:30
|
|
|
},
|
|
|
|
],
|
2019-07-19 18:54:31 +05:30
|
|
|
};
|