From 92a645f395579014cd675e8f0235f137e738954e Mon Sep 17 00:00:00 2001 From: Carlos Jimenez Ruiz Date: Fri, 15 Feb 2019 12:39:21 +0100 Subject: [PATCH] #1122 + worker descriptor popover + small refactors for worker.nickname --- .../claim/back/methods/claim/getSummary.js | 33 +++++-- modules/claim/front/index/index.html | 16 +++- modules/claim/front/index/index.js | 16 +++- modules/claim/front/routes.json | 2 +- modules/claim/front/summary/index.html | 20 +++-- modules/claim/front/summary/index.js | 21 +++-- modules/item/back/methods/item/filter.js | 1 + modules/item/front/diary/index.html | 2 +- modules/item/front/diary/locale/es.yml | 3 +- modules/item/front/index/index.html | 24 ++++- modules/item/front/index/index.js | 27 ++++-- modules/item/front/routes.json | 2 +- modules/order/front/index/index.html | 16 +++- modules/order/front/index/index.js | 22 +++-- modules/order/front/routes.json | 2 +- .../ticket/back/methods/expedition/filter.js | 5 +- .../methods/sale-tracking/listSaleTracking.js | 1 + modules/ticket/back/methods/ticket/filter.js | 3 +- modules/ticket/front/expedition/index.html | 18 +++- modules/ticket/front/expedition/index.js | 24 +++-- modules/ticket/front/index/index.html | 18 +++- modules/ticket/front/index/index.js | 16 +++- modules/ticket/front/index/index.spec.js | 13 +-- modules/ticket/front/request/index/index.html | 24 ++++- modules/ticket/front/request/index/index.js | 34 +++++--- modules/ticket/front/routes.json | 2 +- modules/ticket/front/sale-tracking/index.html | 19 ++-- modules/ticket/front/sale-tracking/index.js | 20 +++-- .../ticket/front/tracking/index/index.html | 15 +++- modules/ticket/front/tracking/index/index.js | 21 ++++- .../front/descriptor-popover/index.html | 12 +++ .../worker/front/descriptor-popover/index.js | 73 ++++++++++++++++ .../front/descriptor-popover/index.spec.js | 87 +++++++++++++++++++ .../front/descriptor-popover/style.scss | 11 +++ modules/worker/front/index.js | 1 + services/db/install/dump/fixtures.sql | 4 +- 36 files changed, 513 insertions(+), 115 deletions(-) create mode 100644 modules/worker/front/descriptor-popover/index.html create mode 100644 modules/worker/front/descriptor-popover/index.js create mode 100644 modules/worker/front/descriptor-popover/index.spec.js create mode 100644 modules/worker/front/descriptor-popover/style.scss diff --git a/modules/claim/back/methods/claim/getSummary.js b/modules/claim/back/methods/claim/getSummary.js index ac57447b6..bdf5faf63 100644 --- a/modules/claim/back/methods/claim/getSummary.js +++ b/modules/claim/back/methods/claim/getSummary.js @@ -89,12 +89,33 @@ module.exports = Self => { filter = { where: {claimFk: id}, include: [ - {relation: 'claimResponsible'}, - {relation: 'worker'}, - {relation: 'claimDestination'}, - {relation: 'claimReason'}, - {relation: 'claimResult'}, - {relation: 'claimRedelivery'} + { + relation: 'claimResponsible' + }, + { + relation: 'worker', + scope: { + fields: ['userFk'], + include: { + relation: 'user', + scope: { + fields: ['nickname'] + } + } + } + }, + { + relation: 'claimDestination' + }, + { + relation: 'claimReason' + }, + { + relation: 'claimResult' + }, + { + relation: 'claimRedelivery' + } ] }; promises.push(Self.app.models.ClaimDevelopment.find(filter)); diff --git a/modules/claim/front/index/index.html b/modules/claim/front/index/index.html index 69b191ad0..535fbc214 100644 --- a/modules/claim/front/index/index.html +++ b/modules/claim/front/index/index.html @@ -37,12 +37,18 @@ ui-sref="claim.card.summary({id: claim.id})"> {{::claim.id}} - + {{::claim.client.name}} {{::claim.created | date:'dd/MM/yyyy'}} - {{::claim.worker.user.nickname}} + + + {{::claim.worker.user.nickname}} + + {{::claim.claimState.description}} @@ -67,7 +73,11 @@ - + + + diff --git a/modules/claim/front/index/index.js b/modules/claim/front/index/index.js index 3b493ef37..ec9624845 100644 --- a/modules/claim/front/index/index.js +++ b/modules/claim/front/index/index.js @@ -65,14 +65,22 @@ export default class Controller { } } - showDescriptor(event, clientFk) { - this.$.descriptor.clientFk = clientFk; - this.$.descriptor.parent = event.target; - this.$.descriptor.show(); + showClientDescriptor(event, clientFk) { + this.$.clientDescriptor.clientFk = clientFk; + this.$.clientDescriptor.parent = event.target; + this.$.clientDescriptor.show(); event.preventDefault(); event.stopImmediatePropagation(); } + showWorkerDescriptor(event, userId) { + event.preventDefault(); + event.stopImmediatePropagation(); + this.selectedWorker = userId; + this.$.workerDescriptor.parent = event.target; + this.$.workerDescriptor.show(); + } + preview(event, claim) { this.claimSelected = claim; this.$.dialogSummaryClaim.show(); diff --git a/modules/claim/front/routes.json b/modules/claim/front/routes.json index eca447b90..a382df098 100644 --- a/modules/claim/front/routes.json +++ b/modules/claim/front/routes.json @@ -3,7 +3,7 @@ "name": "Claims", "icon": "icon-claims", "validations": true, - "dependencies": ["item", "client"], + "dependencies": ["worker", "item", "client"], "menu": [ {"state": "claim.card.basicData", "icon": "settings"}, {"state": "claim.card.detail", "icon": "icon-details"}, diff --git a/modules/claim/front/summary/index.html b/modules/claim/front/summary/index.html index f24db068c..4a04ae4e2 100644 --- a/modules/claim/front/summary/index.html +++ b/modules/claim/front/summary/index.html @@ -54,7 +54,7 @@ {{saleClaimed.sale.itemFk | zeroFill:6}} @@ -90,7 +90,13 @@ {{development.claimReason.description}} {{development.claimResult.description}} {{development.claimResponsible.description}} - {{development.worker.firstName}} + + + {{::development.worker.user.nickname}} + + {{development.claimRedelivery.description}} @@ -115,7 +121,7 @@ {{action.sale.itemFk | zeroFill:6}} @@ -138,6 +144,10 @@ - \ No newline at end of file + + + \ No newline at end of file diff --git a/modules/claim/front/summary/index.js b/modules/claim/front/summary/index.js index 7ef46baf2..67af420fe 100644 --- a/modules/claim/front/summary/index.js +++ b/modules/claim/front/summary/index.js @@ -1,7 +1,7 @@ import ngModule from '../module'; class Controller { - constructor($http, $scope) { + constructor($scope, $http) { this.$http = $http; this.$ = $scope; } @@ -17,8 +17,7 @@ class Controller { this.getSummary(); } - // Item Descriptor - showDescriptor(event, itemFk) { + showItemDescriptor(event, itemFk) { this.quicklinks = { btnThree: { icon: 'icon-transaction', @@ -28,13 +27,21 @@ class Controller { tooltip: 'Item diary' } }; - this.$.descriptor.itemFk = itemFk; - this.$.descriptor.parent = event.target; - this.$.descriptor.show(); + this.$.itemDescriptor.itemFk = itemFk; + this.$.itemDescriptor.parent = event.target; + this.$.itemDescriptor.show(); + } + + showWorkerDescriptor(event, userId) { + event.preventDefault(); + event.stopImmediatePropagation(); + this.selectedWorker = userId; + this.$.workerDescriptor.parent = event.target; + this.$.workerDescriptor.show(); } } -Controller.$inject = ['$http', '$scope']; +Controller.$inject = ['$scope', '$http']; ngModule.component('vnClaimSummary', { template: require('./index.html'), diff --git a/modules/item/back/methods/item/filter.js b/modules/item/back/methods/item/filter.js index cc047c608..fd14357b8 100644 --- a/modules/item/back/methods/item/filter.js +++ b/modules/item/back/methods/item/filter.js @@ -34,6 +34,7 @@ module.exports = Self => { i.size, i.tag5, i.value5, i.tag6, i.value6, i.tag7, i.value7, i.tag8, i.value8, i.isActive, t.name type, u.nickname userNickname, + t.name type, u.id userId, intr.description AS intrastat, i.stems, ori.code AS origin, t.name AS type, ic.name AS category diff --git a/modules/item/front/diary/index.html b/modules/item/front/diary/index.html index 94878c8c5..0e1accd05 100644 --- a/modules/item/front/diary/index.html +++ b/modules/item/front/diary/index.html @@ -23,7 +23,7 @@ Date - Id + Ticket/Entry State Reference Client diff --git a/modules/item/front/diary/locale/es.yml b/modules/item/front/diary/locale/es.yml index c2d7c4683..e00816d78 100644 --- a/modules/item/front/diary/locale/es.yml +++ b/modules/item/front/diary/locale/es.yml @@ -1,3 +1,4 @@ In: Entrada Out: Salida -Visible quantity: Cantidad visible \ No newline at end of file +Visible quantity: Cantidad visible +Ticket/Entry: Ticket/Entrada \ No newline at end of file diff --git a/modules/item/front/index/index.html b/modules/item/front/index/index.html index d4def30a2..6330d6bf8 100644 --- a/modules/item/front/index/index.html +++ b/modules/item/front/index/index.html @@ -45,7 +45,13 @@ zoom-image="{{::$ctrl.imagesPath}}/1600x900/{{::item.image}}" on-error-src/> - {{::item.id | zeroFill:6}} + + + {{::item.id | zeroFill:6}} + + {{::item.category}} {{::item.intrastat}} {{::item.origin}} - {{::item.userNickname}} + + + {{::item.userNickname}} + + - \ No newline at end of file + + + + + \ No newline at end of file diff --git a/modules/item/front/index/index.js b/modules/item/front/index/index.js index e2decd07b..979bce0fd 100644 --- a/modules/item/front/index/index.js +++ b/modules/item/front/index/index.js @@ -31,21 +31,36 @@ class Controller { } } - showDescriptor(event, itemFk) { + showItemDescriptor(event, itemFk) { + if (event.defaultPrevented) return; + + event.preventDefault(); + event.stopPropagation(); + this.quicklinks = { btnThree: { icon: 'icon-transaction', state: `item.card.diary({ id: ${itemFk}, - warehouseFk: ${this.ticket.warehouseFk}, - ticketFk: ${this.ticket.id} })`, tooltip: 'Item diary' } }; - this.$scope.descriptor.itemFk = itemFk; - this.$scope.descriptor.parent = event.target; - this.$scope.descriptor.show(); + this.$.itemDescriptor.itemFk = itemFk; + this.$.itemDescriptor.parent = event.target; + this.$.itemDescriptor.show(); + } + + + showWorkerDescriptor(event, userId) { + if (event.defaultPrevented) return; + + event.preventDefault(); + event.stopPropagation(); + + this.selectedWorker = userId; + this.$.workerDescriptor.parent = event.target; + this.$.workerDescriptor.show(); } paramBuilder(param, value) { diff --git a/modules/item/front/routes.json b/modules/item/front/routes.json index 35651ef5b..c7180b3df 100644 --- a/modules/item/front/routes.json +++ b/modules/item/front/routes.json @@ -3,7 +3,7 @@ "name": "Items", "icon": "inbox", "validations" : true, - "dependencies": ["client", "ticket"], + "dependencies": ["worker", "client", "ticket"], "menu": [ {"state": "item.card.data", "icon": "settings"}, {"state": "item.card.tags", "icon": "icon-tags"}, diff --git a/modules/order/front/index/index.html b/modules/order/front/index/index.html index e3680cd4b..a4b04ca63 100644 --- a/modules/order/front/index/index.html +++ b/modules/order/front/index/index.html @@ -36,11 +36,17 @@ ui-sref="order.card.summary({id: {{::order.id}}})"> {{::order.id}} - + {{::order.client.name}} - {{::order.client.salesPerson.user.nickname}} + + + {{::order.client.salesPerson.user.nickname | dashIfEmpty}} + + + vn-id="clientDescriptor"> + + diff --git a/modules/order/front/index/index.js b/modules/order/front/index/index.js index 3c1400c44..678809ee5 100644 --- a/modules/order/front/index/index.js +++ b/modules/order/front/index/index.js @@ -2,7 +2,7 @@ import ngModule from '../module'; export default class Controller { constructor($scope) { - this.$scope = $scope; + this.$ = $scope; this.ticketSelected = null; this.filter = { include: [ @@ -51,23 +51,31 @@ export default class Controller { } } - showDescriptor(event, clientFk) { - this.$scope.descriptor.clientFk = clientFk; - this.$scope.descriptor.parent = event.target; - this.$scope.descriptor.show(); + showClientDescriptor(event, clientFk) { + this.$.clientDescriptor.clientFk = clientFk; + this.$.clientDescriptor.parent = event.target; + this.$.clientDescriptor.show(); event.preventDefault(); event.stopImmediatePropagation(); } + showWorkerDescriptor(event, userId) { + event.preventDefault(); + event.stopImmediatePropagation(); + this.selectedWorker = userId; + this.$.workerDescriptor.parent = event.target; + this.$.workerDescriptor.show(); + } + onDescriptorLoad() { - this.$scope.popover.relocate(); + this.$.popover.relocate(); } preview(event, order) { event.preventDefault(); event.stopImmediatePropagation(); this.selectedOrder = order; - this.$scope.summary.show(); + this.$.summary.show(); } } diff --git a/modules/order/front/routes.json b/modules/order/front/routes.json index dda5ed646..709d75b67 100644 --- a/modules/order/front/routes.json +++ b/modules/order/front/routes.json @@ -3,7 +3,7 @@ "name": "Orders", "icon": "shopping_cart", "validations": true, - "dependencies": ["item", "ticket"], + "dependencies": ["worker", "item", "ticket"], "menu": [ {"state": "order.card.basicData", "icon": "settings"}, {"state": "order.card.catalog", "icon": "shopping_cart"}, diff --git a/modules/ticket/back/methods/expedition/filter.js b/modules/ticket/back/methods/expedition/filter.js index ce1c62928..b8c634553 100644 --- a/modules/ticket/back/methods/expedition/filter.js +++ b/modules/ticket/back/methods/expedition/filter.js @@ -33,14 +33,15 @@ module.exports = Self => { e.checked, i2.name nameBox, e.itemFk, - w.name nameWorker, - w.firstName, + u.nickname userNickname, + u.id userId, e.created FROM vn.expedition e LEFT JOIN vn.item i2 ON i2.id = e.itemFk INNER JOIN vn.item i1 ON i1.id = e.isBox LEFT JOIN vn.worker w ON w.id = e.workerFk + JOIN account.user u ON u.id = w.id `); stmt.merge(Self.buildSuffix(filter, 'e')); diff --git a/modules/ticket/back/methods/sale-tracking/listSaleTracking.js b/modules/ticket/back/methods/sale-tracking/listSaleTracking.js index 8d3e0c248..7ee037161 100644 --- a/modules/ticket/back/methods/sale-tracking/listSaleTracking.js +++ b/modules/ticket/back/methods/sale-tracking/listSaleTracking.js @@ -32,6 +32,7 @@ module.exports = Self => { st.created, st.workerFk, u.nickname userNickname, + u.id userId, ste.name AS state FROM saleTracking st JOIN sale s ON s.id = st.saleFk diff --git a/modules/ticket/back/methods/ticket/filter.js b/modules/ticket/back/methods/ticket/filter.js index 59754d706..557c75d9e 100644 --- a/modules/ticket/back/methods/ticket/filter.js +++ b/modules/ticket/back/methods/ticket/filter.js @@ -183,7 +183,8 @@ module.exports = Self => { ts.stateFk as stateFk, ts.alertLevel as alertLevel, ts.code as alertLevelCode, - u.nickname userNickname + u.nickname userNickname, + u.id userId FROM ticket t LEFT JOIN address a ON a.id = t.addressFk LEFT JOIN province p ON p.id = a.provinceFk diff --git a/modules/ticket/front/expedition/index.html b/modules/ticket/front/expedition/index.html index 1adb2ae04..be34e1c24 100644 --- a/modules/ticket/front/expedition/index.html +++ b/modules/ticket/front/expedition/index.html @@ -33,7 +33,7 @@ + ng-click="$ctrl.showItemDescriptor($event, expedition.itemFk)"> {{expedition.itemFk | zeroFill:6}} @@ -41,7 +41,14 @@ {{::expedition.nameBox}} {{::expedition.counter}} {{::expedition.checked}} - {{::expedition.firstName}} {{::expedition.nameWorker}} + {{::expedition.userNickname}} + + + {{::expedition.userNickname | dashIfEmpty}} + + {{::expedition.created | date:'dd/MM/yyyy HH:mm'}} @@ -51,9 +58,14 @@ - + + this.$scope.model.refresh() + () => this.$.model.refresh() ); } } - showDescriptor(event, itemFk) { + showItemDescriptor(event, itemFk) { if (!itemFk) return; this.quicklinks = { btnThree: { @@ -33,13 +33,21 @@ class Controller { tooltip: 'Item diary', }, }; - this.$scope.descriptor.itemFk = itemFk; - this.$scope.descriptor.parent = event.target; - this.$scope.descriptor.show(); + this.$.itemDescriptor.itemFk = itemFk; + this.$.itemDescriptor.parent = event.target; + this.$.itemDescriptor.show(); + } + + showWorkerDescriptor(event, userId) { + event.preventDefault(); + event.stopImmediatePropagation(); + this.selectedWorker = userId; + this.$.workerDescriptor.parent = event.target; + this.$.workerDescriptor.show(); } onDescriptorLoad() { - this.$scope.popover.relocate(); + this.$.popover.relocate(); } } diff --git a/modules/ticket/front/index/index.html b/modules/ticket/front/index/index.html index 6e2038ea6..02dad3337 100644 --- a/modules/ticket/front/index/index.html +++ b/modules/ticket/front/index/index.html @@ -59,7 +59,13 @@ {{::ticket.id}} - {{::ticket.userNickname | dashIfEmpty}} + + + {{::ticket.userNickname | dashIfEmpty}} + + {{::ticket.shipped | dateTime: 'dd/MM/yyyy'}} @@ -69,7 +75,7 @@ + ng-click="$ctrl.showClientDescriptor($event, ticket.clientFk)"> {{::ticket.nickname}} @@ -110,5 +116,9 @@ - - \ No newline at end of file + + + + \ No newline at end of file diff --git a/modules/ticket/front/index/index.js b/modules/ticket/front/index/index.js index ab65c702d..809c77d71 100644 --- a/modules/ticket/front/index/index.js +++ b/modules/ticket/front/index/index.js @@ -88,12 +88,20 @@ export default class Controller { return 'alert'; } - showDescriptor(event, clientFk) { + showClientDescriptor(event, clientFk) { event.preventDefault(); event.stopImmediatePropagation(); - this.$.descriptor.clientFk = clientFk; - this.$.descriptor.parent = event.target; - this.$.descriptor.show(); + this.$.clientDescriptor.clientFk = clientFk; + this.$.clientDescriptor.parent = event.target; + this.$.clientDescriptor.show(); + } + + showWorkerDescriptor(event, userId) { + event.preventDefault(); + event.stopImmediatePropagation(); + this.selectedWorker = userId; + this.$.workerDescriptor.parent = event.target; + this.$.workerDescriptor.show(); } preview(event, ticket) { diff --git a/modules/ticket/front/index/index.spec.js b/modules/ticket/front/index/index.spec.js index e202de3d7..e529f552f 100644 --- a/modules/ticket/front/index/index.spec.js +++ b/modules/ticket/front/index/index.spec.js @@ -14,12 +14,13 @@ describe('Component vnTicketIndex', () => { }]; beforeEach(() => { + ngModule('worker'); ngModule('client'); ngModule('item'); ngModule('ticket'); }); - beforeEach(inject(($compile, $rootScope, $httpBackend, _$window_) => { + beforeEach(inject(($compile, $rootScope, _$window_) => { $window = _$window_; $element = $compile('')($rootScope); controller = $element.controller('vnTicketIndex'); @@ -54,18 +55,18 @@ describe('Component vnTicketIndex', () => { }); }); - describe('showDescriptor()', () => { - it('should show the descriptor popover', () => { - spyOn(controller.$.descriptor, 'show'); + describe('showClientDescriptor()', () => { + it('should show the client descriptor popover', () => { + spyOn(controller.$.clientDescriptor, 'show'); let event = new MouseEvent('click', { view: $window, bubbles: true, cancelable: true }); - controller.showDescriptor(event, tickets[0].clientFk); + controller.showClientDescriptor(event, tickets[0].clientFk); - expect(controller.$.descriptor.show).toHaveBeenCalledWith(); + expect(controller.$.clientDescriptor.show).toHaveBeenCalledWith(); }); }); diff --git a/modules/ticket/front/request/index/index.html b/modules/ticket/front/request/index/index.html index 9b7cdfe68..f15c4e55e 100644 --- a/modules/ticket/front/request/index/index.html +++ b/modules/ticket/front/request/index/index.html @@ -35,14 +35,26 @@ {{::request.id}} {{::request.description}} {{::request.created | dateTime: 'dd/MM/yyyy'}} - {{::request.requester.user.nickname}} - {{::request.atender.user.nickname}} + + + {{::request.requester.user.nickname | dashIfEmpty}} + + + + + {{::request.atender.user.nickname | dashIfEmpty}} + + {{::request.quantity}} {{::request.price | currency: 'EUR': 2}} {{request.saleFk | zeroFill:6}} @@ -69,9 +81,13 @@ + + { - this.$scope.watcher.notifySaved(); - this.$scope.watcher.updateOriginalData(); + this.$.model.remove(index); + this.$.watcher.check(); + this.$.model.save().then(() => { + this.$.watcher.notifySaved(); + this.$.watcher.updateOriginalData(); }); } - // Item Descriptor - showDescriptor(event, sale) { + + showItemDescriptor(event, sale) { this.quicklinks = { btnThree: { icon: 'icon-transaction', @@ -55,13 +55,21 @@ class Controller { tooltip: 'Item diary' } }; - this.$scope.descriptor.itemFk = sale.itemFk; - this.$scope.descriptor.parent = event.target; - this.$scope.descriptor.show(); + this.$.itemDescriptor.itemFk = sale.itemFk; + this.$.itemDescriptor.parent = event.target; + this.$.itemDescriptor.show(); + } + + showWorkerDescriptor(event, userId) { + event.preventDefault(); + event.stopImmediatePropagation(); + this.selectedWorker = userId; + this.$.workerDescriptor.parent = event.target; + this.$.workerDescriptor.show(); } } -Controller.$inject = ['$stateParams', '$scope']; +Controller.$inject = ['$scope', '$stateParams']; ngModule.component('vnTicketRequestIndex', { template: require('./index.html'), diff --git a/modules/ticket/front/routes.json b/modules/ticket/front/routes.json index 091b84b2e..de8b916d3 100644 --- a/modules/ticket/front/routes.json +++ b/modules/ticket/front/routes.json @@ -3,7 +3,7 @@ "name": "Tickets", "icon": "icon-ticket", "validations": true, - "dependencies": ["item", "client"], + "dependencies": ["worker", "item", "client"], "menu": [ {"state": "ticket.card.data.stepOne", "icon": "settings"}, {"state": "ticket.card.sale", "icon": "icon-lines"}, diff --git a/modules/ticket/front/sale-tracking/index.html b/modules/ticket/front/sale-tracking/index.html index 182cf0793..4b169817e 100644 --- a/modules/ticket/front/sale-tracking/index.html +++ b/modules/ticket/front/sale-tracking/index.html @@ -32,7 +32,7 @@ {{sale.itemFk | zeroFill:6}} @@ -40,9 +40,12 @@ {{::sale.quantity}} {{::sale.originalQuantity}} - - {{::sale.userNickname}} + + + {{::sale.userNickname | dashIfEmpty}} + {{::sale.state}} {{::sale.created | date: 'dd/MM/yyyy HH:mm'}} @@ -56,6 +59,10 @@ - - \ No newline at end of file + + + \ No newline at end of file diff --git a/modules/ticket/front/sale-tracking/index.js b/modules/ticket/front/sale-tracking/index.js index 63298eca3..b0f7e8041 100644 --- a/modules/ticket/front/sale-tracking/index.js +++ b/modules/ticket/front/sale-tracking/index.js @@ -2,11 +2,11 @@ import ngModule from '../module'; class Controller { constructor($scope, $stateParams) { - this.$scope = $scope; + this.$ = $scope; this.$stateParams = $stateParams; } - showDescriptor(event, itemFk) { + showItemDescriptor(event, itemFk) { this.quicklinks = { btnThree: { icon: 'icon-transaction', @@ -18,13 +18,21 @@ class Controller { tooltip: 'Item diary', }, }; - this.$scope.descriptor.itemFk = itemFk; - this.$scope.descriptor.parent = event.target; - this.$scope.descriptor.show(); + this.$.itemDescriptor.itemFk = itemFk; + this.$.itemDescriptor.parent = event.target; + this.$.itemDescriptor.show(); + } + + showWorkerDescriptor(event, userId) { + event.preventDefault(); + event.stopImmediatePropagation(); + this.selectedWorker = userId; + this.$.workerDescriptor.parent = event.target; + this.$.workerDescriptor.show(); } onDescriptorLoad() { - this.$scope.popover.relocate(); + this.$.popover.relocate(); } } diff --git a/modules/ticket/front/tracking/index/index.html b/modules/ticket/front/tracking/index/index.html index c5a8c993b..a5d354004 100644 --- a/modules/ticket/front/tracking/index/index.html +++ b/modules/ticket/front/tracking/index/index.html @@ -6,7 +6,6 @@ limit="20" data="trackings"> - @@ -22,7 +21,13 @@ {{::tracking.state.name}} - {{::tracking.worker.firstName}} {{ticket.worker.name}} + + + {{::tracking.worker.user.nickname | dashIfEmpty}} + + {{::tracking.created | date:'dd/MM/yyyy HH:mm'}} @@ -36,4 +41,8 @@ - \ No newline at end of file + + + \ No newline at end of file diff --git a/modules/ticket/front/tracking/index/index.js b/modules/ticket/front/tracking/index/index.js index 54b21f76c..58db5f774 100644 --- a/modules/ticket/front/tracking/index/index.js +++ b/modules/ticket/front/tracking/index/index.js @@ -1,14 +1,21 @@ import ngModule from '../../module'; class Controller { - constructor($stateParams) { + constructor($scope, $stateParams) { + this.$ = $scope; this.$stateParams = $stateParams; this.filter = { include: [ { relation: 'worker', scope: { - fields: ['firstName', 'name'] + fields: ['userFk'], + include: { + relation: 'user', + scope: { + fields: ['nickname'] + } + } } }, { @@ -20,9 +27,17 @@ class Controller { ] }; } + + showWorkerDescriptor(event, userId) { + event.preventDefault(); + event.stopImmediatePropagation(); + this.selectedWorker = userId; + this.$.workerDescriptor.parent = event.target; + this.$.workerDescriptor.show(); + } } -Controller.$inject = ['$stateParams']; +Controller.$inject = ['$scope', '$stateParams']; ngModule.component('vnTicketTrackingIndex', { template: require('./index.html'), diff --git a/modules/worker/front/descriptor-popover/index.html b/modules/worker/front/descriptor-popover/index.html new file mode 100644 index 000000000..21f32f0c2 --- /dev/null +++ b/modules/worker/front/descriptor-popover/index.html @@ -0,0 +1,12 @@ + + + + + + \ No newline at end of file diff --git a/modules/worker/front/descriptor-popover/index.js b/modules/worker/front/descriptor-popover/index.js new file mode 100644 index 000000000..637bfe50c --- /dev/null +++ b/modules/worker/front/descriptor-popover/index.js @@ -0,0 +1,73 @@ +import ngModule from '../module'; +import Component from 'core/lib/component'; +import './style.scss'; + +class Controller extends Component { + constructor($element, $scope, $http, $timeout, $q) { + super($element, $scope); + this.$timeout = $timeout; + this.$http = $http; + this.$q = $q; + this.worker = null; + } + + set workerFk(id) { + if (id == this._workerFk) return; + + this._workerFk = id; + this.worker = null; + this.loadData(); + } + + get workerFk() { + return this._workerFk; + } + + set quicklinks(value = {}) { + this._quicklinks = Object.assign(value, this._quicklinks); + } + + get quicklinks() { + return this._quicklinks; + } + + show() { + this.$.popover.parent = this.parent; + this.$.popover.show(); + } + + loadData() { + let query = `api/Workers/${this._workerFk}`; + let filter = { + include: [ + { + relation: 'user', + scope: {fields: ['name', 'email']} + }, { + relation: 'client', + scope: {fields: ['fi']} + }, { + relation: 'sip', + scope: {fields: ['extension']} + } + ] + }; + + this.$http.get(query, {params: {filter}}).then(res => { + this.worker = res.data; + this.$.$applyAsync(() => { + this.$.popover.relocate(); + }); + }); + } +} +Controller.$inject = ['$element', '$scope', '$http', '$timeout', '$q']; + +ngModule.component('vnWorkerDescriptorPopover', { + template: require('./index.html'), + controller: Controller, + bindings: { + workerFk: '<', + quicklinks: '<' + } +}); diff --git a/modules/worker/front/descriptor-popover/index.spec.js b/modules/worker/front/descriptor-popover/index.spec.js new file mode 100644 index 000000000..246fb9b37 --- /dev/null +++ b/modules/worker/front/descriptor-popover/index.spec.js @@ -0,0 +1,87 @@ +import './index.js'; + +describe('worker Component vnWorkerDescriptorPopover', () => { + let $httpBackend; + let $httpParamSerializer; + let $scope; + let controller; + let $element; + + beforeEach(ngModule('worker')); + + beforeEach(angular.mock.inject(($componentController, $rootScope, _$httpBackend_, _$httpParamSerializer_) => { + $httpBackend = _$httpBackend_; + $httpParamSerializer = _$httpParamSerializer_; + $element = angular.element(`
`); + $scope = $rootScope.$new(); + $scope.popover = {relocate: () => {}, show: () => {}}; + controller = $componentController('vnWorkerDescriptorPopover', {$scope, $element}); + })); + + describe('workerFk()', () => { + it(`should not apply any changes if the received id is the same stored in _workerFk`, () => { + controller.worker = 'I exist!'; + controller._workerFk = 1; + spyOn(controller, 'loadData'); + controller.workerFk = 1; + + expect(controller.worker).toEqual('I exist!'); + expect(controller._workerFk).toEqual(1); + expect(controller.loadData).not.toHaveBeenCalled(); + }); + + it(`should set the received id into _workerFk, set the worker to null and then call loadData()`, () => { + controller.worker = `Please don't`; + controller._workerFk = 1; + spyOn(controller, 'loadData'); + controller.workerFk = 999; + + expect(controller.worker).toBeNull(); + expect(controller._workerFk).toEqual(999); + expect(controller.loadData).toHaveBeenCalledWith(); + }); + }); + + describe('show()', () => { + it(`should call the show()`, () => { + spyOn(controller.$.popover, 'show'); + controller.show(); + + expect(controller.$.popover.show).toHaveBeenCalledWith(); + }); + }); + + describe('loadData()', () => { + it(`should perform a get query to store the worker data into the controller`, () => { + controller.workerFk = 1; + controller.canceler = null; + let response = {}; + + let config = { + filter: { + include: [ + { + relation: 'user', + scope: {fields: ['name', 'email']} + }, { + relation: 'client', + scope: {fields: ['fi']} + }, { + relation: 'sip', + scope: {fields: ['extension']} + } + ] + } + }; + + let json = $httpParamSerializer(config); + + $httpBackend.whenGET(`api/Workers/${controller._workerFk}?${json}`).respond(response); + $httpBackend.expectGET(`api/Workers/${controller._workerFk}?${json}`); + controller.loadData(); + $httpBackend.flush(); + + expect(controller.worker).toEqual(response); + }); + }); +}); diff --git a/modules/worker/front/descriptor-popover/style.scss b/modules/worker/front/descriptor-popover/style.scss new file mode 100644 index 000000000..58e65d320 --- /dev/null +++ b/modules/worker/front/descriptor-popover/style.scss @@ -0,0 +1,11 @@ +vn-ticket-descriptor-popover { + vn-ticket-descriptor { + display: block; + width: 16em; + max-height: 28em; + + & > vn-card { + margin: 0!important; + } + } +} \ No newline at end of file diff --git a/modules/worker/front/index.js b/modules/worker/front/index.js index 8b0bf8c6d..79f374f30 100644 --- a/modules/worker/front/index.js +++ b/modules/worker/front/index.js @@ -4,5 +4,6 @@ import './index/'; import './summary'; import './card'; import './descriptor'; +import './descriptor-popover'; import './search-panel'; import './basic-data'; diff --git a/services/db/install/dump/fixtures.sql b/services/db/install/dump/fixtures.sql index a88d19e2e..a95d5db47 100644 --- a/services/db/install/dump/fixtures.sql +++ b/services/db/install/dump/fixtures.sql @@ -657,8 +657,8 @@ INSERT INTO `vn`.`saleComponent`(`saleFk`, `componentFk`, `value`) INSERT INTO `vn`.`saleTracking`(`saleFk`, `isChecked`, `created`, `originalQuantity`, `workerFk`, `actionFk`, `id`, `stateFk`) VALUES - ( 1, 0, CURDATE(), 5, 40, 3, 1, 14), - ( 1, 1, CURDATE(), 5, 40, 3, 2, 8), + ( 1, 0, CURDATE(), 5, 55, 3, 1, 14), + ( 1, 1, CURDATE(), 5, 54, 3, 2, 8), ( 2, 1, CURDATE(), 10, 40, 4, 3, 8), ( 3, 1, CURDATE(), 2, 40, 4, 4, 8);