mirror of
https://github.com/frappe/books.git
synced 2025-01-22 14:48:25 +00:00
incr: add default location
This commit is contained in:
parent
5d732844fb
commit
8ae6ae0cca
@ -1,8 +1,34 @@
|
||||
import { ModelNameEnum } from '../../models/types';
|
||||
import { defaultUOMs } from '../../utils/defaults';
|
||||
import { DatabaseManager } from '../database/manager';
|
||||
import { getDefaultMetaFieldValueMap } from '../helpers';
|
||||
|
||||
const defaultUOMs = [
|
||||
{
|
||||
name: `Unit`,
|
||||
isWhole: true,
|
||||
},
|
||||
{
|
||||
name: `Kg`,
|
||||
isWhole: false,
|
||||
},
|
||||
{
|
||||
name: `Gram`,
|
||||
isWhole: false,
|
||||
},
|
||||
{
|
||||
name: `Meter`,
|
||||
isWhole: false,
|
||||
},
|
||||
{
|
||||
name: `Hour`,
|
||||
isWhole: false,
|
||||
},
|
||||
{
|
||||
name: `Day`,
|
||||
isWhole: false,
|
||||
},
|
||||
];
|
||||
|
||||
async function execute(dm: DatabaseManager) {
|
||||
for (const uom of defaultUOMs) {
|
||||
const defaults = getDefaultMetaFieldValueMap();
|
||||
|
@ -4,6 +4,7 @@ import { AccountTypeEnum } from 'models/baseModels/Account/types';
|
||||
import { ValuationMethod } from './types';
|
||||
|
||||
export class InventorySettings extends Doc {
|
||||
defaultLocation?: string;
|
||||
stockInHand?: string;
|
||||
valuationMethod?: ValuationMethod;
|
||||
stockReceivedButNotBilled?: string;
|
||||
|
@ -3,11 +3,10 @@ import {
|
||||
FiltersMap,
|
||||
FormulaMap,
|
||||
ReadOnlyMap,
|
||||
RequiredMap
|
||||
RequiredMap,
|
||||
} from 'fyo/model/types';
|
||||
import { ModelNameEnum } from 'models/types';
|
||||
import { Money } from 'pesa';
|
||||
import { locationFilter } from './helpers';
|
||||
import { StockMovement } from './StockMovement';
|
||||
import { MovementType } from './types';
|
||||
|
||||
@ -21,10 +20,20 @@ export class StockMovementItem extends Doc {
|
||||
amount?: Money;
|
||||
parentdoc?: StockMovement;
|
||||
|
||||
get isIssue() {
|
||||
return this.parentdoc?.movementType === MovementType.MaterialIssue;
|
||||
}
|
||||
|
||||
get isReceipt() {
|
||||
return this.parentdoc?.movementType === MovementType.MaterialReceipt;
|
||||
}
|
||||
|
||||
get isTransfer() {
|
||||
return this.parentdoc?.movementType === MovementType.MaterialTransfer;
|
||||
}
|
||||
|
||||
static filters: FiltersMap = {
|
||||
item: () => ({ trackItem: true }),
|
||||
toLocation: locationFilter,
|
||||
fromLocation: locationFilter,
|
||||
};
|
||||
|
||||
formulas: FormulaMap = {
|
||||
@ -43,40 +52,50 @@ export class StockMovementItem extends Doc {
|
||||
dependsOn: ['item', 'rate', 'quantity'],
|
||||
},
|
||||
fromLocation: {
|
||||
formula: () => {
|
||||
if (this.parentdoc?.movementType === MovementType.MaterialReceipt) {
|
||||
formula: (fn) => {
|
||||
if (this.isReceipt || this.isTransfer) {
|
||||
return null;
|
||||
}
|
||||
|
||||
const defaultLocation = this.fyo.singles.InventorySettings
|
||||
?.defaultLocation as string | undefined;
|
||||
if (defaultLocation && !this.location && this.isIssue) {
|
||||
return defaultLocation;
|
||||
}
|
||||
|
||||
return this.toLocation;
|
||||
},
|
||||
dependsOn: ['movementType'],
|
||||
},
|
||||
toLocation: {
|
||||
formula: () => {
|
||||
if (this.parentdoc?.movementType === MovementType.MaterialIssue) {
|
||||
formula: (fn) => {
|
||||
if (this.isIssue || this.isTransfer) {
|
||||
return null;
|
||||
}
|
||||
|
||||
const defaultLocation = this.fyo.singles.InventorySettings
|
||||
?.defaultLocation as string | undefined;
|
||||
if (defaultLocation && !this.location && this.isReceipt) {
|
||||
return defaultLocation;
|
||||
}
|
||||
|
||||
return this.toLocation;
|
||||
},
|
||||
dependsOn: ['movementType'],
|
||||
},
|
||||
};
|
||||
|
||||
required: RequiredMap = {
|
||||
fromLocation: () =>
|
||||
this.parentdoc?.movementType === 'MaterialIssue' ||
|
||||
this.parentdoc?.movementType === 'MaterialTransfer',
|
||||
toLocation: () =>
|
||||
this.parentdoc?.movementType === 'MaterialReceipt' ||
|
||||
this.parentdoc?.movementType === 'MaterialTransfer',
|
||||
fromLocation: () => this.isIssue || this.isTransfer,
|
||||
toLocation: () => this.isReceipt || this.isTransfer,
|
||||
};
|
||||
|
||||
readOnly: ReadOnlyMap = {
|
||||
fromLocation: () =>
|
||||
this.parentdoc?.movementType === MovementType.MaterialReceipt,
|
||||
toLocation: () =>
|
||||
this.parentdoc?.movementType === MovementType.MaterialIssue,
|
||||
fromLocation: () => this.isReceipt,
|
||||
toLocation: () => this.isIssue,
|
||||
};
|
||||
|
||||
static createFilters: FiltersMap = {
|
||||
item: () => ({ trackItem: true, itemType: 'Product' }),
|
||||
fromLocation: (doc: Doc) => ({ item: (doc.item ?? '') as string }),
|
||||
toLocation: (doc: Doc) => ({ item: (doc.item ?? '') as string }),
|
||||
};
|
||||
}
|
||||
|
@ -2,7 +2,6 @@ import { Doc } from 'fyo/model/doc';
|
||||
import { FiltersMap, FormulaMap } from 'fyo/model/types';
|
||||
import { ModelNameEnum } from 'models/types';
|
||||
import { Money } from 'pesa';
|
||||
import { locationFilter } from './helpers';
|
||||
|
||||
export class StockTransferItem extends Doc {
|
||||
item?: string;
|
||||
@ -94,6 +93,20 @@ export class StockTransferItem extends Doc {
|
||||
},
|
||||
dependsOn: ['item'],
|
||||
},
|
||||
location: {
|
||||
formula: () => {
|
||||
if (this.location) {
|
||||
return;
|
||||
}
|
||||
|
||||
const defaultLocation = this.fyo.singles.InventorySettings
|
||||
?.defaultLocation as string | undefined;
|
||||
|
||||
if (defaultLocation && !this.location) {
|
||||
return defaultLocation;
|
||||
}
|
||||
},
|
||||
},
|
||||
};
|
||||
|
||||
static filters: FiltersMap = {
|
||||
@ -105,6 +118,5 @@ export class StockTransferItem extends Doc {
|
||||
|
||||
return { for: ['not in', [itemNotFor]], trackItem: true };
|
||||
},
|
||||
location: locationFilter,
|
||||
};
|
||||
}
|
||||
|
@ -1,12 +1 @@
|
||||
import { Doc } from "fyo/model/doc";
|
||||
import { FilterFunction } from "fyo/model/types";
|
||||
import { QueryFilter } from "utils/db/types";
|
||||
|
||||
export const locationFilter: FilterFunction = (doc: Doc) => {
|
||||
const item = doc.item;
|
||||
if (!doc.item) {
|
||||
return { item: null };
|
||||
}
|
||||
|
||||
return { item: ['in', [null, item]] } as QueryFilter;
|
||||
};
|
||||
|
@ -21,6 +21,13 @@
|
||||
"default": "FIFO",
|
||||
"required": true
|
||||
},
|
||||
{
|
||||
"fieldname": "defaultLocation",
|
||||
"label": "Default Location",
|
||||
"fieldtype": "Link",
|
||||
"target": "Location",
|
||||
"create": true
|
||||
},
|
||||
{
|
||||
"fieldname": "stockInHand",
|
||||
"label": "Stock In Hand Acc.",
|
||||
|
@ -12,11 +12,13 @@
|
||||
"required": true
|
||||
},
|
||||
{
|
||||
"fieldname": "item",
|
||||
"label": "Item",
|
||||
"fieldname": "address",
|
||||
"label": "Address",
|
||||
"fieldtype": "Link",
|
||||
"target": "Item"
|
||||
"target": "Address",
|
||||
"placeholder": "Click to create",
|
||||
"inline": true
|
||||
}
|
||||
],
|
||||
"quickEditFields": ["item"]
|
||||
"quickEditFields": ["item", "address"]
|
||||
}
|
||||
|
@ -7,7 +7,6 @@ import {
|
||||
DEFAULT_LOCALE,
|
||||
DEFAULT_SERIES_START,
|
||||
} from 'fyo/utils/consts';
|
||||
import { ValueError } from 'fyo/utils/errors';
|
||||
import {
|
||||
AccountRootTypeEnum,
|
||||
AccountTypeEnum,
|
||||
@ -23,7 +22,7 @@ import {
|
||||
setCurrencySymbols,
|
||||
} from 'src/utils/initialization';
|
||||
import { getRandomString } from 'utils';
|
||||
import { defaultUOMs } from 'utils/defaults';
|
||||
import { getDefaultLocations, getDefaultUOMs } from 'utils/defaults';
|
||||
import { getCountryCodeFromCountry, getCountryInfo } from 'utils/misc';
|
||||
import { CountryInfo } from 'utils/types';
|
||||
import { CreateCOA } from './createCOA';
|
||||
@ -62,9 +61,13 @@ async function createDefaultEntries(fyo: Fyo) {
|
||||
/**
|
||||
* Create default UOM entries
|
||||
*/
|
||||
for (const uom of defaultUOMs) {
|
||||
for (const uom of getDefaultUOMs(fyo)) {
|
||||
await checkAndCreateDoc(ModelNameEnum.UOM, uom, fyo);
|
||||
}
|
||||
|
||||
for (const loc of getDefaultLocations(fyo)) {
|
||||
await checkAndCreateDoc(ModelNameEnum.Location, loc, fyo);
|
||||
}
|
||||
}
|
||||
|
||||
async function initializeDatabase(dbPath: string, country: string, fyo: Fyo) {
|
||||
@ -368,5 +371,10 @@ async function updateInventorySettings(fyo: Fyo) {
|
||||
inventorySettings.set(settingName, accounts[0].name);
|
||||
}
|
||||
|
||||
const location = fyo.t`Stores`;
|
||||
if (await fyo.db.exists(ModelNameEnum.Location, location)) {
|
||||
inventorySettings.set('defaultLocation', location);
|
||||
}
|
||||
|
||||
await inventorySettings.sync();
|
||||
}
|
||||
|
@ -1,26 +1,34 @@
|
||||
export const defaultUOMs = [
|
||||
{
|
||||
name: 'Unit',
|
||||
isWhole: true,
|
||||
},
|
||||
{
|
||||
name: 'Kg',
|
||||
isWhole: false,
|
||||
},
|
||||
{
|
||||
name: 'Gram',
|
||||
isWhole: false,
|
||||
},
|
||||
{
|
||||
name: 'Meter',
|
||||
isWhole: false,
|
||||
},
|
||||
{
|
||||
name: 'Hour',
|
||||
isWhole: false,
|
||||
},
|
||||
{
|
||||
name: 'Day',
|
||||
isWhole: false,
|
||||
},
|
||||
];
|
||||
import { Fyo } from 'fyo';
|
||||
|
||||
export function getDefaultUOMs(fyo: Fyo) {
|
||||
return [
|
||||
{
|
||||
name: fyo.t`Unit`,
|
||||
isWhole: true,
|
||||
},
|
||||
{
|
||||
name: fyo.t`Kg`,
|
||||
isWhole: false,
|
||||
},
|
||||
{
|
||||
name: fyo.t`Gram`,
|
||||
isWhole: false,
|
||||
},
|
||||
{
|
||||
name: fyo.t`Meter`,
|
||||
isWhole: false,
|
||||
},
|
||||
{
|
||||
name: fyo.t`Hour`,
|
||||
isWhole: false,
|
||||
},
|
||||
{
|
||||
name: fyo.t`Day`,
|
||||
isWhole: false,
|
||||
},
|
||||
];
|
||||
}
|
||||
|
||||
export function getDefaultLocations(fyo: Fyo) {
|
||||
return [{ name: fyo.t`Stores` }];
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user