salix/modules/claim/back/models/claim-beginning.js

52 lines
1.6 KiB
JavaScript
Raw Normal View History

2020-06-16 05:47:46 +00:00
const UserError = require('vn-loopback/util/user-error');
const LoopBackContext = require('loopback-context');
2018-08-30 07:19:09 +00:00
module.exports = Self => {
require('../methods/claim-beginning/importToNewRefundTicket')(Self);
2018-08-30 07:19:09 +00:00
Self.validatesUniquenessOf('saleFk', {
message: `A claim with that sale already exists`
});
2020-06-16 10:00:38 +00:00
2020-06-16 05:47:46 +00:00
Self.observe('before save', async ctx => {
if (ctx.isNewInstance) return;
2023-03-08 06:45:22 +00:00
//await claimIsEditable(ctx);
2020-06-16 05:47:46 +00:00
});
2020-06-16 10:00:38 +00:00
2020-06-16 05:47:46 +00:00
Self.observe('before delete', async ctx => {
if (ctx.isNewInstance) return;
await claimIsEditable(ctx);
});
async function claimIsEditable(ctx) {
const loopBackContext = LoopBackContext.getCurrentContext();
const httpCtx = {req: loopBackContext.active};
2023-02-07 14:40:03 +00:00
const models = Self.app.models;
const myOptions = {};
if (ctx.options && ctx.options.transaction)
myOptions.transaction = ctx.options.transaction;
2020-07-09 11:24:56 +00:00
const claimBeginning = await Self.findById(ctx.where.id);
2023-03-07 09:20:10 +00:00
2023-02-07 14:40:03 +00:00
const filter = {
2023-03-07 09:20:10 +00:00
where: {id: claimBeginning.claimFk},
include: [
{
relation: 'claimState',
scope: {
fields: ['id', 'code', 'description']
}
}
]
};
2023-02-07 14:40:03 +00:00
const [claim] = await models.Claim.find(filter, myOptions);
2023-03-08 06:45:22 +00:00
const isEditable = await models.ClaimState.isEditable(httpCtx, claim.claimState().id);
2020-06-16 05:47:46 +00:00
if (!isEditable)
throw new UserError(`The current claim can't be modified`);
}
2018-08-30 07:19:09 +00:00
};