2
0
mirror of https://github.com/frappe/books.git synced 2024-12-22 02:49:03 +00:00
books/models
Akshay a05d2aa703
Merge pull request #1047 from AbleKSaju/fix-sinv-validation
fix: change date fieldtype to Datetime in invoice
2024-12-11 12:38:33 +05:30
..
baseModels Merge pull request #1047 from AbleKSaju/fix-sinv-validation 2024-12-11 12:38:33 +05:30
inventory feat: register schema for Modern POS ui 2024-11-14 12:41:59 +05:30
regionalModels/in feat: hide loyaltyProgram and loyaltyPoints in party when not enabled 2024-09-04 09:08:30 +05:30
Transactional fixing reports/ledger issues 2024-02-06 16:29:44 -08:00
exchangeRate.ts refactor: move ledgerPosting to models 2022-05-23 16:18:22 +05:30
helpers.ts feat: alert when available quantity is exceeded in POS 2024-12-07 14:20:59 +05:30
index.ts feat: Applied Coupon Codes 2024-09-30 14:57:25 +05:30
README.md refactor: rename 'frappe' to 'fyo' outside src 2022-05-23 16:18:22 +05:30
types.ts feat: Applied Coupon Codes 2024-09-30 14:57:25 +05:30

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 fyo/model/doc.ts so for more info check that file and the associated types in fyo/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:

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.

The data stored by the models is decided by the schema passed to it's constructor. Check schemas/README.md for info on this.

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 Fyo 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.

It should also not import the Fyo object (singleton) from src, where ever fyo is required in models it should be passed to it.

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.