mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-16 04:40:32 +00:00
feat: remove Webpack and depend on nodemon. feat: refactoring expenses. feat: optimize system users with caching. feat: architecture tenant optimize.
73 lines
1.8 KiB
JavaScript
73 lines
1.8 KiB
JavaScript
import { Model, mixin } from 'objection';
|
|
import TenantModel from 'models/TenantModel';
|
|
|
|
export default class SaleReceipt extends TenantModel {
|
|
/**
|
|
* Table name
|
|
*/
|
|
static get tableName() {
|
|
return 'sales_receipts';
|
|
}
|
|
|
|
/**
|
|
* Timestamps columns.
|
|
*/
|
|
get timestamps() {
|
|
return ['created_at', 'updated_at'];
|
|
}
|
|
|
|
/**
|
|
* Relationship mapping.
|
|
*/
|
|
static get relationMappings() {
|
|
const Customer = require('models/Customer');
|
|
const Account = require('models/Account');
|
|
const AccountTransaction = require('models/AccountTransaction');
|
|
const ItemEntry = require('models/ItemEntry');
|
|
|
|
return {
|
|
customer: {
|
|
relation: Model.BelongsToOneRelation,
|
|
modelClass: this.relationBindKnex(Customer.default),
|
|
join: {
|
|
from: 'sales_receipts.customerId',
|
|
to: 'customers.id',
|
|
},
|
|
},
|
|
|
|
depositAccount: {
|
|
relation: Model.BelongsToOneRelation,
|
|
modelClass: this.relationBindKnex(Account.default),
|
|
join: {
|
|
from: 'sales_receipts.depositAccountId',
|
|
to: 'accounts.id',
|
|
},
|
|
},
|
|
|
|
entries: {
|
|
relation: Model.HasManyRelation,
|
|
modelClass: this.relationBindKnex(ItemEntry.default),
|
|
join: {
|
|
from: 'sales_receipts.id',
|
|
to: 'items_entries.referenceId',
|
|
},
|
|
filter(builder) {
|
|
builder.where('reference_type', 'SaleReceipt');
|
|
},
|
|
},
|
|
|
|
transactions: {
|
|
relation: Model.HasManyRelation,
|
|
modelClass: this.relationBindKnex(AccountTransaction.default),
|
|
join: {
|
|
from: 'sales_receipts.id',
|
|
to: 'accounts_transactions.referenceId'
|
|
},
|
|
filter(builder) {
|
|
builder.where('reference_type', 'SaleReceipt');
|
|
},
|
|
}
|
|
};
|
|
}
|
|
}
|