2022-04-19 11:29:36 +05:30
|
|
|
import { Fyo } from 'fyo';
|
2022-04-24 12:18:44 +05:30
|
|
|
import { Doc } from 'fyo/model/doc';
|
2022-04-14 10:54:11 +05:30
|
|
|
import {
|
|
|
|
Action,
|
|
|
|
FiltersMap,
|
|
|
|
FormulaMap,
|
|
|
|
ListViewSettings,
|
2022-04-22 16:32:03 +05:30
|
|
|
ValidationMap,
|
2022-04-19 11:29:36 +05:30
|
|
|
} from 'fyo/model/types';
|
2022-04-22 16:32:03 +05:30
|
|
|
import {
|
|
|
|
validateEmail,
|
|
|
|
validatePhoneNumber,
|
|
|
|
} from 'fyo/model/validationFunction';
|
2022-05-23 11:00:54 +05:30
|
|
|
import { Money } from 'pesa';
|
2022-04-14 10:54:11 +05:30
|
|
|
import { PartyRole } from './types';
|
|
|
|
|
|
|
|
export class Party extends Doc {
|
2022-10-08 00:11:50 +05:30
|
|
|
role?: PartyRole;
|
|
|
|
defaultAccount?: string;
|
2022-05-04 18:17:45 +05:30
|
|
|
outstandingAmount?: Money;
|
2022-04-14 12:13:58 +05:30
|
|
|
async updateOutstandingAmount() {
|
2022-05-03 18:43:47 +05:30
|
|
|
/**
|
|
|
|
* If Role === "Both" then outstanding Amount
|
|
|
|
* will be the amount to be paid to the party.
|
|
|
|
*/
|
|
|
|
|
2022-04-14 10:54:11 +05:30
|
|
|
const role = this.role as PartyRole;
|
2022-05-03 18:43:47 +05:30
|
|
|
let outstandingAmount = this.fyo.pesa(0);
|
|
|
|
|
|
|
|
if (role === 'Customer' || role === 'Both') {
|
|
|
|
const outstandingReceive = await this._getTotalOutstandingAmount(
|
|
|
|
'SalesInvoice'
|
|
|
|
);
|
|
|
|
outstandingAmount = outstandingAmount.add(outstandingReceive);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (role === 'Supplier') {
|
|
|
|
const outstandingPay = await this._getTotalOutstandingAmount(
|
|
|
|
'PurchaseInvoice'
|
|
|
|
);
|
|
|
|
outstandingAmount = outstandingAmount.add(outstandingPay);
|
2022-04-14 10:54:11 +05:30
|
|
|
}
|
2022-05-03 18:43:47 +05:30
|
|
|
|
|
|
|
if (role === 'Both') {
|
|
|
|
const outstandingPay = await this._getTotalOutstandingAmount(
|
|
|
|
'PurchaseInvoice'
|
|
|
|
);
|
|
|
|
outstandingAmount = outstandingAmount.sub(outstandingPay);
|
|
|
|
}
|
|
|
|
|
|
|
|
await this.setAndSync({ outstandingAmount });
|
2022-04-14 10:54:11 +05:30
|
|
|
}
|
|
|
|
|
2022-05-03 18:43:47 +05:30
|
|
|
async _getTotalOutstandingAmount(
|
2022-04-14 10:54:11 +05:30
|
|
|
schemaName: 'SalesInvoice' | 'PurchaseInvoice'
|
|
|
|
) {
|
2022-05-03 18:43:47 +05:30
|
|
|
const outstandingAmounts = await this.fyo.db.getAllRaw(schemaName, {
|
|
|
|
fields: ['outstandingAmount'],
|
|
|
|
filters: {
|
|
|
|
submitted: true,
|
|
|
|
cancelled: false,
|
|
|
|
party: this.name as string,
|
|
|
|
},
|
|
|
|
});
|
2022-04-14 10:54:11 +05:30
|
|
|
|
2022-05-03 18:43:47 +05:30
|
|
|
return outstandingAmounts
|
2022-04-18 16:59:20 +05:30
|
|
|
.map(({ outstandingAmount }) =>
|
2022-04-19 11:29:36 +05:30
|
|
|
this.fyo.pesa(outstandingAmount as number)
|
2022-04-18 16:59:20 +05:30
|
|
|
)
|
2022-04-19 11:29:36 +05:30
|
|
|
.reduce((a, b) => a.add(b), this.fyo.pesa(0));
|
2022-04-14 10:54:11 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
formulas: FormulaMap = {
|
2022-04-29 18:30:24 +05:30
|
|
|
defaultAccount: {
|
|
|
|
formula: async () => {
|
|
|
|
const role = this.role as PartyRole;
|
|
|
|
if (role === 'Both') {
|
|
|
|
return '';
|
|
|
|
}
|
2022-04-14 10:54:11 +05:30
|
|
|
|
2022-04-29 18:30:24 +05:30
|
|
|
let accountName = 'Debtors';
|
|
|
|
if (role === 'Supplier') {
|
|
|
|
accountName = 'Creditors';
|
|
|
|
}
|
2022-04-14 10:54:11 +05:30
|
|
|
|
2022-04-29 18:30:24 +05:30
|
|
|
const accountExists = await this.fyo.db.exists('Account', accountName);
|
|
|
|
return accountExists ? accountName : '';
|
|
|
|
},
|
|
|
|
dependsOn: ['role'],
|
2022-04-14 10:54:11 +05:30
|
|
|
},
|
2022-04-29 18:30:24 +05:30
|
|
|
currency: {
|
2022-09-29 15:11:05 +05:30
|
|
|
formula: async () => {
|
|
|
|
if (!this.currency) {
|
|
|
|
return this.fyo.singles.SystemSettings!.currency as string;
|
|
|
|
}
|
|
|
|
},
|
2022-04-29 18:30:24 +05:30
|
|
|
},
|
2022-04-14 10:54:11 +05:30
|
|
|
};
|
|
|
|
|
2022-04-22 16:32:03 +05:30
|
|
|
validations: ValidationMap = {
|
|
|
|
email: validateEmail,
|
|
|
|
phone: validatePhoneNumber,
|
|
|
|
};
|
|
|
|
|
2022-04-14 10:54:11 +05:30
|
|
|
static filters: FiltersMap = {
|
|
|
|
defaultAccount: (doc: Doc) => {
|
|
|
|
const role = doc.role as PartyRole;
|
|
|
|
if (role === 'Both') {
|
2022-04-14 12:13:58 +05:30
|
|
|
return {
|
|
|
|
isGroup: false,
|
|
|
|
accountType: ['in', ['Payable', 'Receivable']],
|
|
|
|
};
|
2022-04-14 10:54:11 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
|
|
|
isGroup: false,
|
|
|
|
accountType: role === 'Customer' ? 'Receivable' : 'Payable',
|
|
|
|
};
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
2022-04-18 16:59:20 +05:30
|
|
|
static getListViewSettings(): ListViewSettings {
|
|
|
|
return {
|
2022-05-02 16:26:47 +05:30
|
|
|
columns: ['name', 'email', 'phone', 'outstandingAmount'],
|
2022-04-18 16:59:20 +05:30
|
|
|
};
|
|
|
|
}
|
2022-04-14 10:54:11 +05:30
|
|
|
|
2022-04-19 11:29:36 +05:30
|
|
|
static getActions(fyo: Fyo): Action[] {
|
2022-04-18 16:59:20 +05:30
|
|
|
return [
|
|
|
|
{
|
2022-04-29 00:27:10 +05:30
|
|
|
label: fyo.t`Create Purchase`,
|
2022-04-18 16:59:20 +05:30
|
|
|
condition: (doc: Doc) =>
|
2022-04-26 15:42:33 +05:30
|
|
|
!doc.notInserted && (doc.role as PartyRole) !== 'Customer',
|
2022-04-18 16:59:20 +05:30
|
|
|
action: async (partyDoc, router) => {
|
2022-05-02 11:01:11 +05:30
|
|
|
const doc = await fyo.doc.getNewDoc('PurchaseInvoice', {
|
|
|
|
party: partyDoc.name,
|
|
|
|
account: partyDoc.defaultAccount as string,
|
|
|
|
});
|
2022-04-18 16:59:20 +05:30
|
|
|
router.push({
|
|
|
|
path: `/edit/PurchaseInvoice/${doc.name}`,
|
|
|
|
query: {
|
2022-05-01 10:15:47 +05:30
|
|
|
schemaName: 'PurchaseInvoice',
|
2022-04-18 16:59:20 +05:30
|
|
|
values: {
|
|
|
|
// @ts-ignore
|
|
|
|
party: partyDoc.name!,
|
|
|
|
},
|
2022-04-14 10:54:11 +05:30
|
|
|
},
|
2022-04-18 16:59:20 +05:30
|
|
|
});
|
|
|
|
},
|
2022-04-14 10:54:11 +05:30
|
|
|
},
|
2022-04-18 16:59:20 +05:30
|
|
|
{
|
2022-04-29 00:27:10 +05:30
|
|
|
label: fyo.t`View Purchases`,
|
2022-04-18 16:59:20 +05:30
|
|
|
condition: (doc: Doc) =>
|
2022-04-26 15:42:33 +05:30
|
|
|
!doc.notInserted && (doc.role as PartyRole) !== 'Customer',
|
2022-04-18 16:59:20 +05:30
|
|
|
action: async (partyDoc, router) => {
|
2022-05-02 11:01:11 +05:30
|
|
|
router.push(`/list/PurchaseInvoice/party/${partyDoc.name}`);
|
2022-04-18 16:59:20 +05:30
|
|
|
},
|
2022-04-14 10:54:11 +05:30
|
|
|
},
|
2022-04-18 16:59:20 +05:30
|
|
|
{
|
2022-04-29 00:27:10 +05:30
|
|
|
label: fyo.t`Create Sale`,
|
2022-04-18 16:59:20 +05:30
|
|
|
condition: (doc: Doc) =>
|
2022-04-26 15:42:33 +05:30
|
|
|
!doc.notInserted && (doc.role as PartyRole) !== 'Supplier',
|
2022-04-18 16:59:20 +05:30
|
|
|
action: async (partyDoc, router) => {
|
2022-05-02 11:01:11 +05:30
|
|
|
const doc = await fyo.doc.getNewDoc('SalesInvoice', {
|
|
|
|
party: partyDoc.name,
|
|
|
|
account: partyDoc.defaultAccount as string,
|
|
|
|
});
|
2022-04-18 16:59:20 +05:30
|
|
|
router.push({
|
|
|
|
path: `/edit/SalesInvoice/${doc.name}`,
|
|
|
|
query: {
|
2022-05-01 10:15:47 +05:30
|
|
|
schemaName: 'SalesInvoice',
|
2022-04-18 16:59:20 +05:30
|
|
|
values: {
|
|
|
|
// @ts-ignore
|
|
|
|
party: partyDoc.name!,
|
|
|
|
},
|
2022-04-14 10:54:11 +05:30
|
|
|
},
|
2022-04-18 16:59:20 +05:30
|
|
|
});
|
|
|
|
},
|
2022-04-14 10:54:11 +05:30
|
|
|
},
|
2022-04-18 16:59:20 +05:30
|
|
|
{
|
2022-04-29 00:27:10 +05:30
|
|
|
label: fyo.t`View Sales`,
|
2022-04-18 16:59:20 +05:30
|
|
|
condition: (doc: Doc) =>
|
2022-04-26 15:42:33 +05:30
|
|
|
!doc.notInserted && (doc.role as PartyRole) !== 'Supplier',
|
2022-04-18 16:59:20 +05:30
|
|
|
action: async (partyDoc, router) => {
|
2022-05-02 11:01:11 +05:30
|
|
|
router.push(`/list/SalesInvoice/party/${partyDoc.name}`);
|
2022-04-18 16:59:20 +05:30
|
|
|
},
|
2022-04-14 10:54:11 +05:30
|
|
|
},
|
2022-04-18 16:59:20 +05:30
|
|
|
];
|
|
|
|
}
|
2022-04-14 10:54:11 +05:30
|
|
|
}
|