2022-11-21 12:05:05 +05:30
|
|
|
import { Fyo } from 'fyo';
|
2022-10-06 14:20:13 +05:30
|
|
|
import {
|
2022-11-21 12:05:05 +05:30
|
|
|
Action,
|
2022-10-06 14:20:13 +05:30
|
|
|
DefaultMap,
|
|
|
|
FiltersMap,
|
|
|
|
FormulaMap,
|
2022-11-30 20:16:20 +05:30
|
|
|
ListViewSettings,
|
2022-10-06 14:20:13 +05:30
|
|
|
} from 'fyo/model/types';
|
2022-11-21 12:05:05 +05:30
|
|
|
import { getDocStatusListColumn, getLedgerLinkAction } from 'models/helpers';
|
2022-11-18 23:01:50 +05:30
|
|
|
import { LedgerPosting } from 'models/Transactional/LedgerPosting';
|
2022-10-05 20:07:17 +05:30
|
|
|
import { ModelNameEnum } from 'models/types';
|
|
|
|
import { Money } from 'pesa';
|
|
|
|
import { StockMovementItem } from './StockMovementItem';
|
2022-11-18 23:01:50 +05:30
|
|
|
import { Transfer } from './Transfer';
|
2022-10-05 20:07:17 +05:30
|
|
|
import { MovementType } from './types';
|
|
|
|
|
2022-11-18 23:01:50 +05:30
|
|
|
export class StockMovement extends Transfer {
|
2022-10-05 20:07:17 +05:30
|
|
|
name?: string;
|
|
|
|
date?: Date;
|
|
|
|
numberSeries?: string;
|
|
|
|
movementType?: MovementType;
|
2022-10-06 14:20:13 +05:30
|
|
|
items?: StockMovementItem[];
|
2022-10-05 20:07:17 +05:30
|
|
|
amount?: Money;
|
|
|
|
|
2022-11-18 23:01:50 +05:30
|
|
|
override get isTransactional(): boolean {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
override async getPosting(): Promise<LedgerPosting | null> {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2022-10-06 14:20:13 +05:30
|
|
|
formulas: FormulaMap = {
|
|
|
|
amount: {
|
|
|
|
formula: () => {
|
|
|
|
return this.items?.reduce(
|
|
|
|
(acc, item) => acc.add(item.amount ?? 0),
|
|
|
|
this.fyo.pesa(0)
|
|
|
|
);
|
|
|
|
},
|
|
|
|
dependsOn: ['items'],
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
2022-10-05 20:07:17 +05:30
|
|
|
static filters: FiltersMap = {
|
|
|
|
numberSeries: () => ({ referenceType: ModelNameEnum.StockMovement }),
|
|
|
|
};
|
|
|
|
|
|
|
|
static defaults: DefaultMap = {
|
|
|
|
date: () => new Date(),
|
|
|
|
};
|
|
|
|
|
2022-11-30 20:16:20 +05:30
|
|
|
static getListViewSettings(fyo: Fyo): ListViewSettings {
|
2022-11-16 14:05:38 +05:30
|
|
|
return {
|
2022-11-30 20:16:20 +05:30
|
|
|
columns: [
|
|
|
|
'name',
|
|
|
|
getDocStatusListColumn(),
|
|
|
|
'date',
|
|
|
|
{
|
|
|
|
label: fyo.t`Movement Type`,
|
|
|
|
fieldname: 'movementType',
|
|
|
|
fieldtype: 'Select',
|
|
|
|
size: 'small',
|
|
|
|
render(doc) {
|
|
|
|
const movementType = doc.movementType as MovementType;
|
|
|
|
const label =
|
|
|
|
{
|
|
|
|
[MovementType.MaterialIssue]: fyo.t`Material Issue`,
|
|
|
|
[MovementType.MaterialReceipt]: fyo.t`Material Receipt`,
|
|
|
|
[MovementType.MaterialTransfer]: fyo.t`Material Transfer`,
|
|
|
|
}[movementType] ?? '';
|
|
|
|
|
|
|
|
return {
|
|
|
|
template: `<span>${label}</span>`,
|
|
|
|
};
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
2022-11-16 14:05:38 +05:30
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2022-11-02 20:26:37 +05:30
|
|
|
_getTransferDetails() {
|
|
|
|
return (this.items ?? []).map((row) => ({
|
|
|
|
item: row.item!,
|
|
|
|
rate: row.rate!,
|
|
|
|
quantity: row.quantity!,
|
|
|
|
fromLocation: row.fromLocation,
|
|
|
|
toLocation: row.toLocation,
|
|
|
|
}));
|
2022-10-29 11:45:23 +05:30
|
|
|
}
|
2022-11-21 12:05:05 +05:30
|
|
|
|
|
|
|
static getActions(fyo: Fyo): Action[] {
|
|
|
|
return [getLedgerLinkAction(fyo, true)];
|
|
|
|
}
|
2022-10-05 20:07:17 +05:30
|
|
|
}
|