diff --git a/db/changes/10150-entry/00-ticketUpdateAction.sql b/db/changes/10150-entry/00-ticketUpdateAction.sql new file mode 100644 index 000000000..a05c65d7a --- /dev/null +++ b/db/changes/10150-entry/00-ticketUpdateAction.sql @@ -0,0 +1,5 @@ +ALTER TABLE `vn`.`ticketUpdateAction` +ADD COLUMN `code` VARCHAR(45) NOT NULL AFTER `description`; + +UPDATE `vn`.`ticketUpdateAction` SET `code`='changePrice' WHERE `id`='1'; +UPDATE `vn`.`ticketUpdateAction` SET `code`='turnInMana' WHERE `id`='3'; diff --git a/e2e/helpers/selectors.js b/e2e/helpers/selectors.js index d7e20018b..63e5ddf2f 100644 --- a/e2e/helpers/selectors.js +++ b/e2e/helpers/selectors.js @@ -471,7 +471,7 @@ export default { nextStepButton: 'vn-step-control .buttons > section:last-child vn-button', finalizeButton: 'vn-step-control .buttons > section:last-child button[type=submit]', stepTwoTotalPriceDif: 'vn-ticket-basic-data-step-two vn-tfoot > vn-tr > :nth-child(6)', - chargesReason: 'vn-autocomplete[ng-model="$ctrl.ticket.option"]', + chargesReason: 'vn-ticket-basic-data-step-two div:nth-child(3) > vn-radio', }, ticketComponents: { base: 'vn-ticket-components [name="base-sum"]' diff --git a/e2e/paths/05-ticket-module/06_basic_data_steps.spec.js b/e2e/paths/05-ticket-module/06_basic_data_steps.spec.js index f677625cd..de78b9fa7 100644 --- a/e2e/paths/05-ticket-module/06_basic_data_steps.spec.js +++ b/e2e/paths/05-ticket-module/06_basic_data_steps.spec.js @@ -80,15 +80,8 @@ describe('Ticket Edit basic data path', () => { expect(result).toContain('-€248.00'); }); - it(`should then click next to move on to step three`, async() => { - await page.waitToClick(selectors.ticketBasicData.nextStepButton); - let url = await page.expectURL('data/step-three'); - - expect(url).toBe(true); - }); - it(`should select a new reason for the changes made then click on finalize`, async() => { - await page.autocompleteSearch(selectors.ticketBasicData.chargesReason, 'Cambiar los precios en el ticket'); + await page.waitToClick(selectors.ticketBasicData.chargesReason); await page.waitToClick(selectors.ticketBasicData.finalizeButton); let url = await page.expectURL('summary'); diff --git a/modules/ticket/back/models/ticket-update-action.json b/modules/ticket/back/models/ticket-update-action.json index c4a4ce8df..3072c2172 100644 --- a/modules/ticket/back/models/ticket-update-action.json +++ b/modules/ticket/back/models/ticket-update-action.json @@ -1,28 +1,31 @@ { - "name": "TicketUpdateAction", - "base": "VnModel", - "options": { - "mysql": { - "table": "ticketUpdateAction" - } - }, - "properties": { - "id": { - "id": true, - "type": "Number", - "description": "Identifier" - }, - "description": { - "type": "String", - "required": true - } -}, -"acls": [ - { - "accessType": "READ", - "principalType": "ROLE", - "principalId": "$everyone", - "permission": "ALLOW" - } -] -} + "name": "TicketUpdateAction", + "base": "VnModel", + "options": { + "mysql": { + "table": "ticketUpdateAction" + } + }, + "properties": { + "id": { + "id": true, + "type": "Number", + "description": "Identifier" + }, + "description": { + "type": "String", + "required": true + }, + "code": { + "type": "String" + } + }, + "acls": [ + { + "accessType": "READ", + "principalType": "ROLE", + "principalId": "$everyone", + "permission": "ALLOW" + } + ] +} \ No newline at end of file diff --git a/modules/ticket/front/basic-data/index.html b/modules/ticket/front/basic-data/index.html index f313110b3..34db1e246 100644 --- a/modules/ticket/front/basic-data/index.html +++ b/modules/ticket/front/basic-data/index.html @@ -3,9 +3,8 @@ step-count="10" steps="[ {name: 'Basic data', state: 'ticket.card.basicData.stepOne'}, - {name: 'Price difference', state: 'ticket.card.basicData.stepTwo'}, - {name: 'Charge', state: 'ticket.card.basicData.stepThree'}]" - on-step-change="$ctrl.onStepChange(state)" + {name: 'Price difference', state: 'ticket.card.basicData.stepTwo'}]" + on-step-change="$ctrl.onStepChange()" on-step-end="$ctrl.onSubmit()"> diff --git a/modules/ticket/front/basic-data/index.js b/modules/ticket/front/basic-data/index.js index 1afe6f9aa..4965ee61e 100644 --- a/modules/ticket/front/basic-data/index.js +++ b/modules/ticket/front/basic-data/index.js @@ -16,8 +16,8 @@ class Controller { this.child = child; } - onStepChange(state) { - return this.child.onStepChange(state); + onStepChange() { + return this.child.onStepChange(); } onSubmit() { diff --git a/modules/ticket/front/basic-data/step-three/index.html b/modules/ticket/front/basic-data/step-three/index.html deleted file mode 100644 index 300b8f6d3..000000000 --- a/modules/ticket/front/basic-data/step-three/index.html +++ /dev/null @@ -1,14 +0,0 @@ -
diff --git a/modules/ticket/front/basic-data/step-three/index.js b/modules/ticket/front/basic-data/step-three/index.js deleted file mode 100644 index 1cd643dd2..000000000 --- a/modules/ticket/front/basic-data/step-three/index.js +++ /dev/null @@ -1,73 +0,0 @@ -import ngModule from '../../module'; - -class Controller { - constructor($http, $scope, $state, $translate, vnApp) { - this.$http = $http; - this.$scope = $scope; - this.$state = $state; - this.$translate = $translate; - this.vnApp = vnApp; - } - - $onInit() { - this.data.registerChild(this); - } - - get ticket() { - return this._ticket; - } - - set ticket(value) { - this._ticket = value; - - if (value) this.ticket.option = 1; - } - - onStepChange(state) { - return true; - } - - onSubmit() { - if (!this.ticket.option) { - return this.vnApp.showError( - this.$translate.instant('Choose an option') - ); - } - - let query = `tickets/${this.ticket.id}/componentUpdate`; - let params = { - clientId: this.ticket.clientFk, - agencyModeId: this.ticket.agencyModeFk, - addressId: this.ticket.addressFk, - zoneId: this.ticket.zoneFk, - warehouseId: this.ticket.warehouseFk, - companyId: this.ticket.companyFk, - shipped: this.ticket.shipped, - landed: this.ticket.landed, - isDeleted: this.ticket.isDeleted, - option: this.ticket.option - }; - - this.$http.post(query, params).then(res => { - this.vnApp.showMessage( - this.$translate.instant(`The ticket has been unrouted`) - ); - this.card.reload(); - this.$state.go('ticket.card.summary', {id: this.$state.params.id}); - }); - } -} - -Controller.$inject = ['$http', '$scope', '$state', '$translate', 'vnApp']; - -ngModule.component('vnTicketBasicDataStepThree', { - template: require('./index.html'), - controller: Controller, - bindings: { - ticket: '<' - }, - require: { - card: '^vnTicketCard', - data: '^vnTicketBasicData' - } -}); diff --git a/modules/ticket/front/basic-data/step-three/index.spec.js b/modules/ticket/front/basic-data/step-three/index.spec.js deleted file mode 100644 index 6843caec1..000000000 --- a/modules/ticket/front/basic-data/step-three/index.spec.js +++ /dev/null @@ -1,67 +0,0 @@ -import './index.js'; - -describe('ticket', () => { - describe('Component vnTicketBasicDataStepThree', () => { - let now = Date.now(); - let $state; - let controller; - let $httpBackend; - let vnApp; - - beforeEach(ngModule('ticket')); - - beforeEach(angular.mock.inject(($componentController, _$state_, _$httpBackend_, _vnApp_) => { - $state = _$state_; - spyOn($state, 'go'); - vnApp = _vnApp_; - spyOn(vnApp, 'showError'); - $httpBackend = _$httpBackend_; - controller = $componentController('vnTicketBasicDataStepThree', {$state}); - })); - - describe('onSubmit()', () => { - it(`should return an error if the item doesn't have option property in the controller`, () => { - controller._ticket = {id: 1}; - controller.onSubmit(); - - expect(vnApp.showError).toHaveBeenCalledWith('Choose an option'); - }); - - it('should perform a post query correctly then call two functions()', () => { - spyOn(controller.vnApp, 'showMessage'); - controller.card = {reload: () => {}}; - spyOn(controller.card, 'reload'); - - controller.ticket = { - id: 1, - agencyModeFk: 1, - addressFk: 121, - zoneFk: 3, - warehouseFk: 1, - shipped: now, - landed: now, - option: 1 - }; - - let data = { - agencyModeId: 1, - addressId: 121, - zoneId: 3, - warehouseId: 1, - shipped: now, - landed: now, - option: 1 - }; - - $httpBackend.whenPOST(`tickets/1/componentUpdate`, data).respond('ok'); - $httpBackend.expectPOST(`tickets/1/componentUpdate`, data); - controller.onSubmit(); - $httpBackend.flush(); - - expect(controller.vnApp.showMessage).toHaveBeenCalledWith('The ticket has been unrouted'); - expect(controller.card.reload).toHaveBeenCalledWith(); - expect(controller.$state.go).toHaveBeenCalledWith('ticket.card.summary', jasmine.any(Object)); - }); - }); - }); -}); diff --git a/modules/ticket/front/basic-data/step-three/locale/es.yml b/modules/ticket/front/basic-data/step-three/locale/es.yml deleted file mode 100644 index 185534c34..000000000 --- a/modules/ticket/front/basic-data/step-three/locale/es.yml +++ /dev/null @@ -1,4 +0,0 @@ -Charge: Cargo -Choose an option: Selecciona una opción -Charge difference to: Diferencia a cargo de -The ticket has been unrouted: El ticket ha sido desenrutado \ No newline at end of file diff --git a/modules/ticket/front/basic-data/step-two/index.html b/modules/ticket/front/basic-data/step-two/index.html index 04cb7f212..0154b3caa 100644 --- a/modules/ticket/front/basic-data/step-two/index.html +++ b/modules/ticket/front/basic-data/step-two/index.html @@ -1,3 +1,23 @@ +