mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-16 04:40:32 +00:00
134 lines
2.9 KiB
JavaScript
134 lines
2.9 KiB
JavaScript
import { Model } from 'objection';
|
|
import TenantModel from 'models/TenantModel';
|
|
|
|
export default class Contact extends TenantModel {
|
|
/**
|
|
* Table name
|
|
*/
|
|
static get tableName() {
|
|
return 'contacts';
|
|
}
|
|
|
|
/**
|
|
* Model timestamps.
|
|
*/
|
|
get timestamps() {
|
|
return ['createdAt', 'updatedAt'];
|
|
}
|
|
|
|
/**
|
|
* Model modifiers.
|
|
*/
|
|
static get modifiers() {
|
|
return {
|
|
filterContactIds(query, customerIds) {
|
|
query.whereIn('id', customerIds);
|
|
},
|
|
|
|
customer(query) {
|
|
query.where('contact_service', 'customer');
|
|
},
|
|
|
|
vendor(query){
|
|
query.where('contact_service', 'vendor');
|
|
}
|
|
};
|
|
}
|
|
|
|
/**
|
|
* Relationship mapping.
|
|
*/
|
|
static get relationMappings() {
|
|
const SaleInvoice = require('models/SaleInvoice');
|
|
const Bill = require('models/Bill');
|
|
|
|
return {
|
|
salesInvoices: {
|
|
relation: Model.HasManyRelation,
|
|
modelClass: SaleInvoice.default,
|
|
join: {
|
|
from: 'contacts.id',
|
|
to: 'sales_invoices.customerId',
|
|
},
|
|
},
|
|
|
|
bills: {
|
|
relation: Model.HasManyRelation,
|
|
modelClass: Bill.default,
|
|
join: {
|
|
from: 'contacts.id',
|
|
to: 'bills.vendorId',
|
|
},
|
|
}
|
|
};
|
|
}
|
|
|
|
/**
|
|
* Change vendor balance.
|
|
* @param {Integer} customerId
|
|
* @param {Numeric} amount
|
|
*/
|
|
static async changeBalance(customerId, amount) {
|
|
const changeMethod = (amount > 0) ? 'increment' : 'decrement';
|
|
|
|
return this.query()
|
|
.where('id', customerId)
|
|
[changeMethod]('balance', Math.abs(amount));
|
|
}
|
|
|
|
/**
|
|
* Increment the given customer balance.
|
|
* @param {Integer} customerId
|
|
* @param {Integer} amount
|
|
*/
|
|
static async incrementBalance(customerId, amount) {
|
|
return this.query()
|
|
.where('id', customerId)
|
|
.increment('balance', amount);
|
|
}
|
|
|
|
/**
|
|
* Decrement the given customer balance.
|
|
* @param {integer} customerId -
|
|
* @param {integer} amount -
|
|
*/
|
|
static async decrementBalance(customerId, amount) {
|
|
await this.query()
|
|
.where('id', customerId)
|
|
.decrement('balance', amount);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param {number} customerId
|
|
* @param {number} oldCustomerId
|
|
* @param {number} amount
|
|
* @param {number} oldAmount
|
|
*/
|
|
static changeDiffBalance(customerId, oldCustomerId, amount, oldAmount) {
|
|
const diffAmount = amount - oldAmount;
|
|
const asyncOpers = [];
|
|
|
|
if (customerId != oldCustomerId) {
|
|
const oldCustomerOper = this.changeBalance(oldCustomerId, (oldAmount * -1));
|
|
const customerOper = this.changeBalance(customerId, amount);
|
|
|
|
asyncOpers.push(customerOper);
|
|
asyncOpers.push(oldCustomerOper);
|
|
} else {
|
|
const balanceChangeOper = this.changeBalance(customerId, diffAmount);
|
|
asyncOpers.push(balanceChangeOper);
|
|
}
|
|
return Promise.all(asyncOpers);
|
|
}
|
|
|
|
|
|
static get fields() {
|
|
return {
|
|
created_at: {
|
|
column: 'created_at',
|
|
}
|
|
};
|
|
}
|
|
}
|