2
0
mirror of https://github.com/frappe/books.git synced 2024-11-15 01:44:04 +00:00
books/fyo/model/types.ts

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

114 lines
3.9 KiB
TypeScript
Raw Normal View History

import { Fyo } from 'fyo';
import { DocValue, DocValueMap } from 'fyo/core/types';
2023-06-06 07:44:26 +00:00
import type SystemSettings from 'fyo/models/SystemSettings';
2022-06-14 09:10:46 +00:00
import { FieldType, Schema, SelectOption } from 'schemas/types';
import { QueryFilter } from 'utils/db/types';
import { RouteLocationRaw, Router } from 'vue-router';
import { Doc } from './doc';
2023-06-06 07:44:26 +00:00
import type { AccountingSettings } from 'models/baseModels/AccountingSettings/AccountingSettings';
import type { Defaults } from 'models/baseModels/Defaults/Defaults';
import type { PrintSettings } from 'models/baseModels/PrintSettings/PrintSettings';
import type { InventorySettings } from 'models/inventory/InventorySettings';
/**
* The functions below are used for dynamic evaluation
* and setting of field types.
*
* Since they are set directly on the doc, they can
* access the doc by using `this`.
*
* - `Formula`: Async function used for obtaining a computed value such as amount (rate * qty).
* - `Default`: Regular function used to dynamically set the default value, example new Date().
* - `Validation`: Async function that throw an error if the value is invalid.
* - `Required`: Regular function used to decide if a value is mandatory (there are !notnul in the db).
*/
export type FormulaReturn = DocValue | DocValueMap[] | undefined | Doc[];
export type Formula = (fieldname?: string) => Promise<FormulaReturn> | FormulaReturn;
export type FormulaConfig = { dependsOn?: string[]; formula: Formula };
2022-10-12 09:29:43 +00:00
export type Default = (doc: Doc) => DocValue;
2022-04-22 11:02:03 +00:00
export type Validation = (value: DocValue) => Promise<void> | void;
export type Required = () => boolean;
export type Hidden = () => boolean;
2022-04-22 11:02:03 +00:00
export type ReadOnly = () => boolean;
2022-04-18 08:01:41 +00:00
export type GetCurrency = () => string;
export type FormulaMap = Record<string, FormulaConfig | undefined>;
export type DefaultMap = Record<string, Default | undefined>;
export type ValidationMap = Record<string, Validation | undefined>;
export type RequiredMap = Record<string, Required | undefined>;
2022-04-22 12:01:04 +00:00
export type CurrenciesMap = Record<string, GetCurrency | undefined>;
export type HiddenMap = Record<string, Hidden | undefined>;
export type ReadOnlyMap = Record<string, ReadOnly | undefined>;
export type ChangeArg = { doc: Doc; changed: string };
/**
* Should add this for hidden too
*/
export type ModelMap = Record<string, typeof Doc | undefined>;
export type DocMap = Record<string, Doc | undefined>;
2022-04-18 08:01:41 +00:00
export interface SinglesMap {
SystemSettings?: SystemSettings;
2023-06-06 07:44:26 +00:00
AccountingSettings?: AccountingSettings;
InventorySettings?: InventorySettings;
PrintSettings?: PrintSettings;
Defaults?: Defaults;
[key: string]: Doc | undefined;
2022-04-18 08:01:41 +00:00
}
// Static Config properties
export type FilterFunction = (doc: Doc) => QueryFilter | Promise<QueryFilter>;
export type FiltersMap = Record<string, FilterFunction>;
export type EmptyMessageFunction = (doc: Doc) => string;
export type EmptyMessageMap = Record<string, EmptyMessageFunction>;
export type ListFunction = (doc?: Doc) => string[] | SelectOption[];
2022-04-22 12:01:04 +00:00
export type ListsMap = Record<string, ListFunction | undefined>;
export interface Action {
label: string;
action: (doc: Doc, router: Router) => Promise<void> | void | unknown;
2022-04-20 06:38:47 +00:00
condition?: (doc: Doc) => boolean;
2022-11-30 06:59:52 +00:00
group?: string;
type?: 'primary' | 'secondary';
2022-04-20 06:38:47 +00:00
component?: {
template: string;
2022-04-20 06:38:47 +00:00
};
}
2022-06-14 09:10:46 +00:00
export interface RenderData {
schema: Schema,
[key: string]: DocValue | Schema
}
export type ColumnConfig = {
label: string;
fieldtype: FieldType;
fieldname: string;
2022-06-14 09:10:46 +00:00
render?: (doc: RenderData) => { template: string };
display?: (value: unknown, fyo: Fyo) => string;
}
export type ListViewColumn = string | ColumnConfig;
export interface ListViewSettings {
formRoute?: (name: string) => RouteLocationRaw;
columns?: ListViewColumn[];
}
export interface TreeViewSettings {
parentField: string;
getRootLabel: () => Promise<string>;
}
2022-06-14 09:10:46 +00:00
export type DocStatus =
| ''
| 'Draft'
| 'Saved'
| 'NotSaved'
| 'Submitted'
| 'Cancelled';