mirror of
https://github.com/frappe/books.git
synced 2024-11-10 07:40:55 +00:00
33 lines
1.6 KiB
Markdown
33 lines
1.6 KiB
Markdown
|
# Models
|
||
|
|
||
|
The `models` root folder contains all the model files, i.e. files containing all the models. **Models** here, refers to the classes that handle the data, its validation and updation and a bunch of other stuff.
|
||
|
|
||
|
Each model directly or indirectly extends the `Doc` class from `frappe/model/doc.ts` so for more info check that file and the associated types in `frappe/model/types.ts`.
|
||
|
|
||
|
A model class can used even if the class body has no content, for example `PurchaseInvoiceItem`. Else the model used will default to using `Doc`. The class can also be used to provide type information for the field types else they default to the catch all `DocValue` example:
|
||
|
|
||
|
```typescript
|
||
|
class Todo extends Doc {
|
||
|
title?: string;
|
||
|
date?: Date;
|
||
|
completed?: boolean;
|
||
|
}
|
||
|
```
|
||
|
|
||
|
While this has obvious advantages, the drawback is if the underlying fieldtype changes this too will have to be changed.
|
||
|
|
||
|
## Adding Stuff
|
||
|
|
||
|
When adding stuff to `models/**` make sure that it isn't importing any Vue code or other frontend specific code globally. This is cause model file tests will directly use the the `Frappe` class and will be run using `mocha` on `node`.
|
||
|
|
||
|
Importing frontend code will break all the tests. This also implies that one should be wary about transitive dependencies.
|
||
|
|
||
|
_Note: Frontend specific code can be imported but they should be done so, only using dynamic imports i.e. `await import('...')`._
|
||
|
|
||
|
## Regional Models
|
||
|
|
||
|
Regional models should as far as possible extend the base model and override what's required.
|
||
|
|
||
|
They should then be imported dynamicall and returned from `getRegionalModels` in `models/index.ts` on the basis of `countryCode`.
|
||
|
|