module.exports = Self => { Self.remoteMethodCtx('importToNewRefundTicket', { description: 'Imports lines from claimBeginning to a new ticket with specific shipped, landed dates, agency and company', accessType: 'WRITE', accepts: [{ arg: 'id', type: 'number', required: true, description: 'the claim id', http: {source: 'path'} }], returns: { type: 'string', root: true }, http: { path: `/:id/importToNewRefundTicket`, verb: 'POST' } }); async function addSalesToTicket(salesToRefund, ticketFk, options) { let formatedSales = []; salesToRefund.forEach(sale => { let formatedSale = { itemFk: sale.sale().itemFk, ticketFk: ticketFk, concept: sale.sale().concept, quantity: -Math.abs(sale.quantity), price: sale.sale().price, discount: sale.sale().discount, reserved: sale.sale().reserved, isPicked: sale.sale().isPicked, created: sale.sale().created }; formatedSales.push(formatedSale); }); return await Self.app.models.Sale.create(formatedSales, options); } async function insertIntoClaimEnd(createdSales, claimId, workerId, options) { let formatedSales = []; createdSales.forEach(sale => { let formatedSale = { saleFk: sale.id, claimFk: claimId, workerFk: workerId }; formatedSales.push(formatedSale); }); return await Self.app.models.ClaimEnd.create(formatedSales, options); } async function saveObservation(observation, options) { let query = `INSERT INTO vn.ticketObservation(ticketFk, observationTypeFk, description) VALUES(?, ?, ?) ON DUPLICATE KEY UPDATE description = CONCAT(vn.ticketObservation.description, VALUES(description),' ')`; await Self.rawSql(query, [ observation.ticketFk, observation.observationTypeFk, observation.description ], options); } Self.importToNewRefundTicket = async(ctx, id) => { let models = Self.app.models; let token = ctx.req.accessToken; let userId = token.userId; let worker = await models.Worker.findOne({where: {userFk: userId}}); let obsevationType = await models.ObservationType.findOne({where: {description: 'comercial'}}); let agency = await models.AgencyMode.findOne({where: {code: 'refund'}}); let state = await models.State.findOne({where: {code: 'DELIVERED'}}); let filter = { where: {id: id}, include: [ { relation: 'ticket', scope: { fields: ['id', 'clientFk', 'warehouseFk', 'companyFk', 'addressFk'] } } ] }; let claim = await models.Claim.findOne(filter); let today = new Date(); let params = { clientFk: claim.ticket().clientFk, shipped: today, landed: today, warehouseFk: claim.ticket().warehouseFk, companyFk: claim.ticket().companyFk, addressFk: claim.ticket().addressFk, agencyModeFk: agency.id, userId: userId }; let salesFilter = { where: {claimFk: id}, include: [ { relation: 'sale', scope: { fields: ['id', 'itemFk', 'concept', 'price', 'discount', 'reserved', 'isPicked', 'created', 'priceFixed', 'isPriceFixed'] } } ] }; let tx = await Self.beginTransaction({}); try { let options = {transaction: tx}; let newRefundTicket = await models.Ticket.new(ctx, params, options); let observation = { description: `Reclama ticket: ${claim.ticketFk}`, ticketFk: newRefundTicket.id, observationTypeFk: obsevationType.id }; await saveObservation(observation, options); await models.TicketTracking.create({ ticketFk: newRefundTicket.id, stateFk: state.id, workerFk: worker.id }, options); let salesToRefund = await models.ClaimBeginning.find(salesFilter); let createdSales = await addSalesToTicket(salesToRefund, newRefundTicket.id, options); insertIntoClaimEnd(createdSales, id, worker.id, options); await Self.rawSql('CALL vn.ticketCalculateClon(?, ?)', [ newRefundTicket.id, claim.ticketFk ], options); await tx.commit(); return newRefundTicket; } catch (e) { await tx.rollback(); throw e; } }; };