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 };
|