2
0
mirror of https://github.com/frappe/books.git synced 2025-01-07 00:53:58 +00:00
books/backend/patches/createPaymentMethods.ts

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

58 lines
1.5 KiB
TypeScript
Raw Normal View History

2024-12-26 09:50:32 +00:00
import { ModelNameEnum } from 'models/types';
import { DatabaseManager } from '../database/manager';
import { AccountTypeEnum } from 'models/baseModels/Account/types';
import { getDefaultMetaFieldValueMap } from 'backend/helpers';
type AccountTypeMap = Record<AccountTypeEnum, string[] | undefined>;
async function execute(dm: DatabaseManager) {
const accounts = (await dm.db?.getAll(ModelNameEnum.Account, {
fields: ['name', 'accountType'],
filters: {
accountType: [
'in',
[
AccountTypeEnum.Bank,
AccountTypeEnum.Cash,
AccountTypeEnum.Payable,
AccountTypeEnum.Receivable,
],
],
},
})) as { name: string; accountType: AccountTypeEnum }[];
const accountsMap = accounts.reduce((acc, ac) => {
acc[ac.accountType] ??= [];
acc[ac.accountType]!.push(ac.name);
return acc;
}, {} as AccountTypeMap);
const defaults = getDefaultMetaFieldValueMap();
const paymentMethods = [
{
name: 'Cash',
2024-12-27 11:01:23 +00:00
type: 'Cash',
2024-12-26 09:50:32 +00:00
account: accountsMap[AccountTypeEnum.Cash]?.[0],
...defaults,
},
{
name: 'Bank',
2024-12-27 11:01:23 +00:00
type: 'Bank',
2024-12-26 09:50:32 +00:00
account: accountsMap[AccountTypeEnum.Bank]?.[0],
...defaults,
},
{
name: 'Transfer',
2024-12-27 11:01:23 +00:00
type: 'Bank',
2024-12-26 09:50:32 +00:00
account: accountsMap[AccountTypeEnum.Bank]?.[0],
...defaults,
},
];
for (const paymentMethod of paymentMethods) {
await dm.db?.insert(ModelNameEnum.PaymentMethod, paymentMethod);
}
}
export default { execute };