Commit 570d9fce9b555939a331e6de6755408db322c373
Exists in
master
Merge remote-tracking branch 'upstream/develop'
Showing
3 changed files
Show diff stats
spec/controllerSpec.js
... | ... | @@ -25,6 +25,7 @@ describe('Controladores abm precios condiciones', function() { |
25 | 25 | focaAbmPreciosCondicionesService: {}, |
26 | 26 | $location: {}, |
27 | 27 | focaModalService: {}, |
28 | + $localStorage: {}, | |
28 | 29 | focaBotoneraLateralService: {}, |
29 | 30 | $timeout: timeout |
30 | 31 | }); |
... | ... | @@ -42,6 +43,7 @@ describe('Controladores abm precios condiciones', function() { |
42 | 43 | $scope: scope, |
43 | 44 | focaAbmPreciosCondicionesService: {}, |
44 | 45 | $location: $location, |
46 | + $localStorage: {}, | |
45 | 47 | focaModalService: {}, |
46 | 48 | focaBotoneraLateralService: {}, |
47 | 49 | $timeout: timeout |
... | ... | @@ -67,6 +69,7 @@ describe('Controladores abm precios condiciones', function() { |
67 | 69 | $scope: scope, |
68 | 70 | focaAbmPreciosCondicionesService: {}, |
69 | 71 | $location: {}, |
72 | + $localStorage: {}, | |
70 | 73 | focaModalService: focaModalService, |
71 | 74 | focaBotoneraLateralService: {}, |
72 | 75 | $timeout: timeout |
... | ... | @@ -94,6 +97,7 @@ describe('Controladores abm precios condiciones', function() { |
94 | 97 | $scope: scope, |
95 | 98 | focaAbmPreciosCondicionesService: focaAbmPreciosCondicionesService, |
96 | 99 | $location: {}, |
100 | + $localStorage: {}, | |
97 | 101 | focaModalService: focaModalService, |
98 | 102 | focaBotoneraLateralService: {}, |
99 | 103 | $timeout: timeout |
... | ... | @@ -123,6 +127,7 @@ describe('Controladores abm precios condiciones', function() { |
123 | 127 | $scope: scope, |
124 | 128 | focaAbmPreciosCondicionesService: focaAbmPreciosCondicionesService, |
125 | 129 | $location: {}, |
130 | + $localStorage: {}, | |
126 | 131 | focaModalService: {}, |
127 | 132 | focaBotoneraLateralService: {}, |
128 | 133 | $timeout: timeout |
... | ... | @@ -143,7 +148,9 @@ describe('Controladores abm precios condiciones', function() { |
143 | 148 | it('Existe el controlador focaAbmPrecioCondicionController', function() { |
144 | 149 | //act |
145 | 150 | var controlador = $controller('focaAbmPrecioCondicionController', { |
146 | - $scope: {}, | |
151 | + $scope: { | |
152 | + $watch: function(){} | |
153 | + }, | |
147 | 154 | focaAbmPreciosCondicionesService: { |
148 | 155 | obtenerPrecioCondicion: function() { |
149 | 156 | return { |
... | ... | @@ -157,6 +164,7 @@ describe('Controladores abm precios condiciones', function() { |
157 | 164 | focaModalService: {}, |
158 | 165 | $timeout: timeout, |
159 | 166 | $uibModal: {}, |
167 | + $localStorage: {}, | |
160 | 168 | $window: {} |
161 | 169 | }); |
162 | 170 | |
... | ... | @@ -167,7 +175,11 @@ describe('Controladores abm precios condiciones', function() { |
167 | 175 | it('La funcion $scope.cancelar lleva a la ruta correcta', function() { |
168 | 176 | inject(function($location) { |
169 | 177 | //arrange |
170 | - var scope = {}; | |
178 | + var scope = { | |
179 | + $watch: function() {}, | |
180 | + salir: function() {}, | |
181 | + formPrecioCondicion: '' | |
182 | + }; | |
171 | 183 | $controller('focaAbmPrecioCondicionController', { |
172 | 184 | $scope: scope, |
173 | 185 | focaAbmPreciosCondicionesService: { |
... | ... | @@ -180,6 +192,7 @@ describe('Controladores abm precios condiciones', function() { |
180 | 192 | focaBotoneraLateralService: {}, |
181 | 193 | $routeParams: {}, |
182 | 194 | $location: $location, |
195 | + $localStorage: {}, | |
183 | 196 | focaModalService: {}, |
184 | 197 | $timeout: timeout, |
185 | 198 | $uibModal: {}, |
... | ... | @@ -187,7 +200,7 @@ describe('Controladores abm precios condiciones', function() { |
187 | 200 | }); |
188 | 201 | |
189 | 202 | //act |
190 | - scope.cancelar(); | |
203 | + scope.salir(); | |
191 | 204 | |
192 | 205 | //assert |
193 | 206 | expect($location.url()).toEqual('/precio-condicion'); |
... | ... | @@ -197,7 +210,9 @@ describe('Controladores abm precios condiciones', function() { |
197 | 210 | it('La funcion $scope.guardar llama a servicio.guardarPrecioCondicion', function() { |
198 | 211 | inject(function($location) { |
199 | 212 | //arrange |
200 | - var scope = {}; | |
213 | + var scope = { | |
214 | + $watch: function() { } | |
215 | + }; | |
201 | 216 | var focaAbmPreciosCondicionesService = { |
202 | 217 | obtenerPrecioCondicion: function() { |
203 | 218 | return { |
... | ... | @@ -217,13 +232,21 @@ describe('Controladores abm precios condiciones', function() { |
217 | 232 | focaBotoneraLateralService: {}, |
218 | 233 | $routeParams: {}, |
219 | 234 | $location: $location, |
220 | - focaModalService: {}, | |
235 | + focaModalService: { | |
236 | + alert: function() {} | |
237 | + }, | |
221 | 238 | $timeout: timeout, |
222 | 239 | $uibModal: {}, |
240 | + $localStorage: {}, | |
223 | 241 | $window: window |
224 | 242 | }); |
225 | 243 | var promesaGuardarPrecioCondicion = Promise.resolve(true); |
226 | - scope.precioCondicion = { listaPrecio: {} }; | |
244 | + scope.precioCondicion = { | |
245 | + listaPrecio: {}, | |
246 | + nombre: true, | |
247 | + descripcion: true, | |
248 | + idListaPrecio: true | |
249 | + }; | |
227 | 250 | |
228 | 251 | //act |
229 | 252 | //spyOn(window, 'location').and.returnValue({ assign: function() {} }); |
... | ... | @@ -238,7 +261,9 @@ describe('Controladores abm precios condiciones', function() { |
238 | 261 | |
239 | 262 | it('La funcion $scope.solicitarConfirmacionPlazoPago levanta modal confirm', function() { |
240 | 263 | //act |
241 | - var scope = {}; | |
264 | + var scope = { | |
265 | + $watch: function() {} | |
266 | + }; | |
242 | 267 | var focaModalService = { |
243 | 268 | confirm: function() { } |
244 | 269 | }; |
... | ... | @@ -257,6 +282,7 @@ describe('Controladores abm precios condiciones', function() { |
257 | 282 | focaModalService: focaModalService, |
258 | 283 | $timeout: timeout, |
259 | 284 | $uibModal: {}, |
285 | + $localStorage: {}, | |
260 | 286 | $window: {} |
261 | 287 | }); |
262 | 288 | |
... | ... | @@ -271,7 +297,9 @@ describe('Controladores abm precios condiciones', function() { |
271 | 297 | |
272 | 298 | it('La funcion $scope.solicitarConfirmacionPlazoPago borra al dar ok', function(done) { |
273 | 299 | //act |
274 | - var scope = {}; | |
300 | + var scope = { | |
301 | + $watch: function() { } | |
302 | + }; | |
275 | 303 | var focaModalService = { |
276 | 304 | confirm: function() { } |
277 | 305 | }; |
... | ... | @@ -291,6 +319,7 @@ describe('Controladores abm precios condiciones', function() { |
291 | 319 | $location: {}, |
292 | 320 | focaModalService: focaModalService, |
293 | 321 | $timeout: timeout, |
322 | + $localStorage: {}, | |
294 | 323 | $uibModal: {}, |
295 | 324 | $window: {} |
296 | 325 | }); |
... | ... | @@ -313,7 +342,9 @@ describe('Controladores abm precios condiciones', function() { |
313 | 342 | |
314 | 343 | it('La funcion $scope.seleccionarListaPrecio levanta modal', function() { |
315 | 344 | //arrange |
316 | - var scope = {}; | |
345 | + var scope = { | |
346 | + $watch: function() {} | |
347 | + }; | |
317 | 348 | var uibModal = { |
318 | 349 | open: function() { } |
319 | 350 | }; |
... | ... | @@ -333,6 +364,7 @@ describe('Controladores abm precios condiciones', function() { |
333 | 364 | focaModalService: {}, |
334 | 365 | $timeout: timeout, |
335 | 366 | $uibModal: uibModal, |
367 | + $localStorage: {}, | |
336 | 368 | $window: {} |
337 | 369 | }); |
338 | 370 | |
... | ... | @@ -346,7 +378,9 @@ describe('Controladores abm precios condiciones', function() { |
346 | 378 | |
347 | 379 | it('La funcion $scope.verProductosListaPrecio levanta modal', function() { |
348 | 380 | //arrange |
349 | - var scope = {}; | |
381 | + var scope = { | |
382 | + $watch: function() {} | |
383 | + }; | |
350 | 384 | var uibModal = { |
351 | 385 | open: function() { } |
352 | 386 | }; |
... | ... | @@ -366,6 +400,7 @@ describe('Controladores abm precios condiciones', function() { |
366 | 400 | focaModalService: {}, |
367 | 401 | $timeout: timeout, |
368 | 402 | $uibModal: uibModal, |
403 | + $localStorage: {}, | |
369 | 404 | $window: {} |
370 | 405 | }); |
371 | 406 | scope.precioCondicion = { |
... | ... | @@ -381,7 +416,9 @@ describe('Controladores abm precios condiciones', function() { |
381 | 416 | |
382 | 417 | it('la función next suma uno a $scope.focused', function() { |
383 | 418 | //arrange |
384 | - var scope = {}; | |
419 | + var scope = { | |
420 | + $watch: function() {} | |
421 | + }; | |
385 | 422 | var focaAbmPreciosCondicionesService = { |
386 | 423 | obtenerPrecioCondicion: function() { |
387 | 424 | return { |
... | ... | @@ -398,6 +435,7 @@ describe('Controladores abm precios condiciones', function() { |
398 | 435 | focaModalService: {}, |
399 | 436 | $timeout: timeout, |
400 | 437 | $uibModal: {}, |
438 | + $localStorage: {}, | |
401 | 439 | $window: {} |
402 | 440 | }); |
403 | 441 |
src/js/controller.js
1 | 1 | angular.module('focaAbmPreciosCondiciones') |
2 | 2 | .controller('focaAbmPreciosCondicionesController', [ |
3 | 3 | '$scope', 'focaAbmPreciosCondicionesService', '$location', |
4 | - 'focaModalService', 'focaBotoneraLateralService', '$timeout', | |
4 | + 'focaModalService', 'focaBotoneraLateralService', '$timeout', '$localStorage', | |
5 | 5 | function($scope, focaAbmPreciosCondicionesService, $location, |
6 | - focaModalService, focaBotoneraLateralService, $timeout) { | |
6 | + focaModalService, focaBotoneraLateralService, $timeout, $localStorage) { | |
7 | 7 | |
8 | 8 | $timeout(function() { |
9 | 9 | focaBotoneraLateralService.showSalir(true); |
... | ... | @@ -11,6 +11,7 @@ angular.module('focaAbmPreciosCondiciones') |
11 | 11 | focaBotoneraLateralService.showCancelar(false); |
12 | 12 | focaBotoneraLateralService.showGuardar(false); |
13 | 13 | }); |
14 | + | |
14 | 15 | $scope.filters = ''; |
15 | 16 | $scope.now = new Date(); |
16 | 17 | $scope.editar = function(id) { |
... | ... | @@ -45,15 +46,20 @@ angular.module('focaAbmPreciosCondiciones') |
45 | 46 | }); |
46 | 47 | } |
47 | 48 | }; |
49 | + | |
50 | + if ($localStorage.precioCondicion) { | |
51 | + var precioCondicion = JSON.parse($localStorage.precioCondicion); | |
52 | + if (!precioCondicion.id) { precioCondicion.id = 0; } | |
53 | + $location.path('/precio-condicion/' + precioCondicion.id); | |
54 | + } | |
48 | 55 | } |
49 | 56 | ]) |
50 | 57 | .controller('focaAbmPrecioCondicionController', [ |
51 | 58 | '$scope', 'focaAbmPreciosCondicionesService', 'focaBotoneraLateralService', |
52 | - '$routeParams', '$location', 'focaModalService', '$timeout', '$uibModal', '$window', | |
59 | + '$routeParams', '$location', 'focaModalService', '$timeout', '$uibModal', '$window', '$localStorage', '$filter', | |
53 | 60 | function( |
54 | 61 | $scope, focaAbmPreciosCondicionesService, focaBotoneraLateralService, |
55 | - $routeParams, $location, focaModalService, $timeout, $uibModal, $window | |
56 | - ) { | |
62 | + $routeParams, $location, focaModalService, $timeout, $uibModal, $window, $localStorage, $filter) { | |
57 | 63 | $scope.focused = 1; |
58 | 64 | $scope.plazosAEliminar = []; |
59 | 65 | $scope.mostrarPlazos = $routeParams.id > 0; |
... | ... | @@ -69,7 +75,7 @@ angular.module('focaAbmPreciosCondiciones') |
69 | 75 | idListaPrecio: 0, |
70 | 76 | vigencia: new Date() |
71 | 77 | }; |
72 | - if(datos.data.id) { | |
78 | + if (datos.data.id) { | |
73 | 79 | $scope.precioCondicion = datos.data; |
74 | 80 | $scope.listaPrecioLabel = datos.data.listaPrecio.ID.trim() + |
75 | 81 | ' - ' + datos.data.listaPrecio.DES; |
... | ... | @@ -91,22 +97,48 @@ angular.module('focaAbmPreciosCondiciones') |
91 | 97 | } |
92 | 98 | }); |
93 | 99 | |
100 | + $timeout(function() {getLSPrecioC();}); | |
101 | + | |
94 | 102 | $timeout(function() { |
95 | 103 | focaBotoneraLateralService.showSalir(false); |
96 | 104 | focaBotoneraLateralService.showPausar(true); |
97 | - focaBotoneraLateralService.showCancelar(true); | |
105 | + focaBotoneraLateralService.showCancelar(false); | |
98 | 106 | focaBotoneraLateralService.showGuardar(true, $scope.guardar); |
107 | + focaBotoneraLateralService.addCustomButton('Salir', $scope.salir); | |
99 | 108 | }); |
100 | 109 | |
101 | - $scope.cancelar = function() { | |
102 | - $location.path('/precio-condicion'); | |
110 | + $scope.salir = function() { | |
111 | + | |
112 | + if ($scope.formPrecioCondicion.$pristine == false) { | |
113 | + focaModalService.confirm( | |
114 | + '¿Está seguro de que desea salir? Se perderán todos los datos cargados.' | |
115 | + ).then(function(data) { | |
116 | + if (data) { | |
117 | + $location.path('/precio-condicion'); | |
118 | + } | |
119 | + }); | |
120 | + } else { | |
121 | + $location.path('/precio-condicion'); | |
122 | + } | |
103 | 123 | }; |
104 | 124 | $scope.guardar = function() { |
125 | + | |
126 | + if (!$scope.precioCondicion.nombre) { | |
127 | + focaModalService.alert('Ingrese nombre'); | |
128 | + return; | |
129 | + } else if (!$scope.precioCondicion.descripcion) { | |
130 | + focaModalService.alert('Ingrese descripcion'); | |
131 | + return; | |
132 | + } else if (!$scope.precioCondicion.idListaPrecio) { | |
133 | + focaModalService.alert('Seleccione precio'); | |
134 | + return; | |
135 | + } | |
136 | + | |
105 | 137 | var promises = []; |
106 | 138 | var precioCondicion = $scope.precioCondicion; |
107 | 139 | precioCondicion.idListaPrecio = precioCondicion.listaPrecio.ID; |
108 | 140 | delete precioCondicion.listaPrecio; |
109 | - if($scope.mostrarPlazos) { | |
141 | + if ($scope.mostrarPlazos) { | |
110 | 142 | promises.push( |
111 | 143 | focaAbmPreciosCondicionesService |
112 | 144 | .guardarPlazosPago($scope.precioCondicion.plazos) |
... | ... | @@ -133,15 +165,15 @@ angular.module('focaAbmPreciosCondiciones') |
133 | 165 | }; |
134 | 166 | |
135 | 167 | $scope.agregarPlazo = function(key) { |
136 | - if(key === 13) { | |
137 | - if(!$scope.plazoACargar.dias && $scope.plazoACargar.dias !== 0) { | |
168 | + if (key === 13) { | |
169 | + if (!$scope.plazoACargar.dias && $scope.plazoACargar.dias !== 0) { | |
138 | 170 | focaModalService.alert('Ingrese cantidad de días'); |
139 | 171 | return; |
140 | 172 | } |
141 | 173 | var tieneEseDia = $scope.precioCondicion.plazos.filter(function(a) { |
142 | 174 | return a.dias === $scope.plazoACargar.dias; |
143 | 175 | }); |
144 | - if(tieneEseDia.length > 0) { | |
176 | + if (tieneEseDia.length > 0) { | |
145 | 177 | focaModalService.alert('Ya ha ingresado un plazo con esos días'); |
146 | 178 | return; |
147 | 179 | } |
... | ... | @@ -155,7 +187,7 @@ angular.module('focaAbmPreciosCondiciones') |
155 | 187 | } |
156 | 188 | }; |
157 | 189 | $scope.quitarPlazo = function(key) { |
158 | - if($scope.precioCondicion.plazos[key].id) | |
190 | + if ($scope.precioCondicion.plazos[key].id) | |
159 | 191 | $scope.plazosAEliminar.push($scope.precioCondicion.plazos[key].id); |
160 | 192 | |
161 | 193 | $scope.precioCondicion.plazos.splice(key, 1); |
... | ... | @@ -179,7 +211,7 @@ angular.module('focaAbmPreciosCondiciones') |
179 | 211 | }; |
180 | 212 | |
181 | 213 | $scope.seleccionarListaPrecio = function(key) { |
182 | - if(key === 13){ | |
214 | + if (key === 13){ | |
183 | 215 | var modalInstance = $uibModal.open( |
184 | 216 | { |
185 | 217 | ariaLabelledBy: 'Busqueda de Listas de precio', |
... | ... | @@ -188,7 +220,8 @@ angular.module('focaAbmPreciosCondiciones') |
188 | 220 | size: 'lg' |
189 | 221 | } |
190 | 222 | ); |
191 | - modalInstance.result.then(function(listaPrecio) { | |
223 | + modalInstance.result.then(function(listaPrecio) { | |
224 | + $scope.precioCondicion.idListaPrecio = listaPrecio.ID; | |
192 | 225 | $scope.precioCondicion.listaPrecio = listaPrecio; |
193 | 226 | $scope.listaPrecioLabel = listaPrecio.ID + ' - ' + listaPrecio.DES; |
194 | 227 | $scope.focused = 4; |
... | ... | @@ -216,7 +249,32 @@ angular.module('focaAbmPreciosCondiciones') |
216 | 249 | }; |
217 | 250 | |
218 | 251 | $scope.next = function(key) { |
219 | - if(key === 13) $scope.focused++; | |
252 | + if (key === 13) $scope.focused++; | |
220 | 253 | }; |
254 | + | |
255 | + //watch | |
256 | + $scope.$watch('precioCondicion', function(newValue) { | |
257 | + focaBotoneraLateralService.setPausarData({ | |
258 | + label: 'precioCondicion', | |
259 | + val: newValue | |
260 | + }); | |
261 | + }, true); | |
262 | + | |
263 | + function setearPrecioCondicion(precioCondicion) { | |
264 | + $scope.precioCondicion = precioCondicion; | |
265 | + $scope.$broadcast('addCabecera', { | |
266 | + label: 'Precio y Condicion:', | |
267 | + valor: $filter('rellenarDigitos')(precioCondicion.id) | |
268 | + }); | |
269 | + } | |
270 | + | |
271 | + function getLSPrecioC() { | |
272 | + var precioCondicion = JSON.parse($localStorage.precioCondicion || null); | |
273 | + | |
274 | + if (precioCondicion) { | |
275 | + setearPrecioCondicion(precioCondicion); | |
276 | + delete $localStorage.precioCondicion; | |
277 | + } | |
278 | + } | |
221 | 279 | } |
222 | 280 | ]); |
src/views/foca-abm-precios-condiciones-item.html
... | ... | @@ -6,7 +6,7 @@ |
6 | 6 | ></foca-cabecera-facturador> |
7 | 7 | </div> |
8 | 8 | <div class="row"> |
9 | - <form class="col-md-10"> | |
9 | + <form class= "col-md-10" name="formPrecioCondicion"> | |
10 | 10 | <input type="hidden" name="id" ng-model="precioCondicion.id" /> |
11 | 11 | <div class="row mb-3"> |
12 | 12 | <label class="col-sm-2 col-form-label">Código</label> |