import { Model, mixin } from 'objection'; import TenantModel from 'models/TenantModel'; import ModelSetting from './ModelSetting'; import CustomViewBaseModel from './CustomViewBaseModel'; import ModelSearchable from './ModelSearchable'; export default class RefundCreditNote extends mixin(TenantModel, [ ModelSetting, CustomViewBaseModel, ModelSearchable, ]) { /** * Table name. */ static get tableName() { return 'refund_credit_note_transactions'; } /** * Timestamps columns. */ get timestamps() { return ['created_at', 'updated_at']; } /* * Relationship mapping. */ static get relationMappings() { const Account = require('models/Account'); const CreditNote = require('models/CreditNote'); return { fromAccount: { relation: Model.BelongsToOneRelation, modelClass: Account.default, join: { from: 'refund_credit_note_transactions.fromAccountId', to: 'accounts.id', }, }, creditNote: { relation: Model.BelongsToOneRelation, modelClass: CreditNote.default, join: { from: 'refund_credit_note_transactions.creditNoteId', to: 'credit_notes.id', }, }, }; } }