diff --git a/loopback/locale/es.json b/loopback/locale/es.json index f01da55ac..769ccc1bd 100644 --- a/loopback/locale/es.json +++ b/loopback/locale/es.json @@ -161,5 +161,6 @@ "The nif cannot be empty": "El NIF no puede quedar en blanco", "You need to fill sage information before you check verified data": "Debes rellenar la información de sage antes de marcar datos comprobados", "ASSIGN_ZONE_FIRST": "Asigna una zona primero", - "You can not select this payment method without a registered bankery account": "No se puede utilizar este método de pago si no has registrado una cuenta bancaria" + "You can not select this payment method without a registered bankery account": "No se puede utilizar este método de pago si no has registrado una cuenta bancaria", + "Sorts whole route": "Reordena ruta entera" } \ No newline at end of file diff --git a/modules/route/back/methods/route/guessPriority.js b/modules/route/back/methods/route/guessPriority.js index bb5b34ca3..eab9f3473 100644 --- a/modules/route/back/methods/route/guessPriority.js +++ b/modules/route/back/methods/route/guessPriority.js @@ -1,5 +1,5 @@ module.exports = Self => { - Self.remoteMethod('guessPriority', { + Self.remoteMethodCtx('guessPriority', { description: 'Changes automatically the priority of the tickets in a route', accessType: 'READ', accepts: [{ @@ -19,10 +19,32 @@ module.exports = Self => { } }); - Self.guessPriority = async id => { - let query = `CALL vn.routeGuessPriority(?)`; + Self.guessPriority = async(ctx, id) => { + const userId = ctx.req.accessToken.userId; + const $t = ctx.req.__; // $translate + const query = `CALL vn.routeGuessPriority(?)`; + const tx = await Self.beginTransaction({}); - let options = [id]; - return await Self.rawSql(query, options); + try { + let options = {transaction: tx}; + + const priority = await Self.rawSql(query, [id], options); + + let logRecord = { + originFk: id, + userFk: userId, + action: 'update', + changedModel: 'Route', + description: $t('Sorts whole route') + }; + + await Self.app.models.RouteLog.create(logRecord, options); + + await tx.commit(); + return priority; + } catch (e) { + await tx.rollback(); + throw e; + } }; }; diff --git a/modules/route/back/methods/route/specs/guessPriority.spec.js b/modules/route/back/methods/route/specs/guessPriority.spec.js index 448501e67..4e70d727e 100644 --- a/modules/route/back/methods/route/specs/guessPriority.spec.js +++ b/modules/route/back/methods/route/specs/guessPriority.spec.js @@ -15,9 +15,15 @@ describe('route guessPriority()', () => { }); it('should call guessPriority() and then check the tickets in the target route now have their priorities defined', async() => { + const ctx = { + req: { + accessToken: {userId: 9}, + __: () => {} + }, + }; routeTicketsToRestore = await app.models.Ticket.find({where: {routeFk: targetRouteId}}); - await app.models.Route.guessPriority(targetRouteId); + await app.models.Route.guessPriority(ctx, targetRouteId); let routeTickets = await app.models.Ticket.find({where: {routeFk: targetRouteId}, fields: ['id', 'priority']}); expect(routeTickets.length).toEqual(2); diff --git a/modules/route/front/tickets/index.html b/modules/route/front/tickets/index.html index 1f91dd3f1..7e03a3981 100644 --- a/modules/route/front/tickets/index.html +++ b/modules/route/front/tickets/index.html @@ -31,13 +31,13 @@ model="model"> - Order + Order Ticket Client Packages - + Warehouse - Postcode + PC Street @@ -50,7 +50,7 @@ ng-model="ticket.checked"> - + {{ticket.packages}} - {{::ticket.volume | number:1}} + {{::ticket.volume | number:1}} {{ticket.warehouse.name}} - {{ticket.address.postalCode}} + {{ticket.address.postalCode}} {{ticket.address.street}}