Commit 330ea2290542954ba149a9ebe7c8447edefec876
Exists in
master
and in
2 other branches
Merge branch 'develop' into 'master'
Develop See merge request !53
Showing
10 changed files
Show diff stats
gulpfile.js
... | ... | @@ -9,14 +9,20 @@ const pump = require('pump'); |
9 | 9 | const jshint = require('gulp-jshint'); |
10 | 10 | const replace = require('gulp-replace'); |
11 | 11 | const connect = require('gulp-connect'); |
12 | +const header = require('gulp-header'); | |
13 | +const footer = require('gulp-footer'); | |
14 | +const gulpSequence = require('gulp-sequence'); | |
12 | 15 | |
13 | 16 | var paths = { |
14 | 17 | srcJS: 'src/js/*.js', |
15 | 18 | srcViews: 'src/views/*.html', |
19 | + specs: 'spec/*.js', | |
16 | 20 | tmp: 'tmp', |
17 | 21 | dist: 'dist/' |
18 | 22 | }; |
19 | 23 | |
24 | +gulp.task('uglify', gulpSequence('clean', ['templates', 'uglify-spec'], 'uglify-app')); | |
25 | + | |
20 | 26 | gulp.task('templates', ['clean'], function() { |
21 | 27 | return pump( |
22 | 28 | [ |
... | ... | @@ -31,7 +37,7 @@ gulp.task('templates', ['clean'], function() { |
31 | 37 | ); |
32 | 38 | }); |
33 | 39 | |
34 | -gulp.task('uglify', ['templates'], function() { | |
40 | +gulp.task('uglify-app', function() { | |
35 | 41 | return pump( |
36 | 42 | [ |
37 | 43 | gulp.src([ |
... | ... | @@ -48,6 +54,19 @@ gulp.task('uglify', ['templates'], function() { |
48 | 54 | ); |
49 | 55 | }); |
50 | 56 | |
57 | +gulp.task('uglify-spec', function() { | |
58 | + return pump( | |
59 | + [ | |
60 | + gulp.src(paths.specs), | |
61 | + concat('foca-crear-remito.spec.js'), | |
62 | + replace('src/views/', ''), | |
63 | + header("describe('Módulo foca-crear-remito', function() { \n"), | |
64 | + footer("});"), | |
65 | + gulp.dest(paths.dist) | |
66 | + ] | |
67 | + ); | |
68 | +}); | |
69 | + | |
51 | 70 | gulp.task('clean', function() { |
52 | 71 | return gulp.src(['tmp', 'dist'], {read: false}) |
53 | 72 | .pipe(clean()); |
... | ... | @@ -56,7 +75,7 @@ gulp.task('clean', function() { |
56 | 75 | gulp.task('pre-commit', function() { |
57 | 76 | return pump( |
58 | 77 | [ |
59 | - gulp.src(paths.srcJS), | |
78 | + gulp.src([paths.srcJS, paths.specs]), | |
60 | 79 | jshint('.jshintrc'), |
61 | 80 | jshint.reporter('default'), |
62 | 81 | jshint.reporter('fail') |
package.json
... | ... | @@ -4,7 +4,7 @@ |
4 | 4 | "description": "Listado y ABM nota de remitos", |
5 | 5 | "main": "index.js", |
6 | 6 | "scripts": { |
7 | - "test": "echo \"Error: no test specified\" && exit 1", | |
7 | + "test": "test.html", | |
8 | 8 | "compile": "gulp uglify", |
9 | 9 | "gulp-pre-commit": "gulp pre-commit", |
10 | 10 | "postinstall": "npm run compile && gulp clean-post-install", |
... | ... | @@ -31,6 +31,7 @@ |
31 | 31 | "angular": "^1.7.5", |
32 | 32 | "angular-cookies": "^1.7.5", |
33 | 33 | "angular-ladda": "^0.4.3", |
34 | + "angular-mocks": "^1.7.7", | |
34 | 35 | "angular-route": "^1.7.5", |
35 | 36 | "bootstrap": "^4.1.3", |
36 | 37 | "foca-botonera-facturador": "git+http://git.focasoftware.com/npm/foca-botonera-facturador.git", |
... | ... | @@ -42,10 +43,7 @@ |
42 | 43 | "foca-modal-cotizacion": "git+http://git.focasoftware.com/npm/foca-modal-cotizacion.git", |
43 | 44 | "foca-modal-domicilio": "git+http://git.focasoftware.com/npm/foca-modal-domicilio.git", |
44 | 45 | "foca-modal-flete": "git+http://git.focasoftware.com/npm/foca-modal-flete.git", |
45 | - "foca-modal-moneda": "git+http://git.focasoftware.com/npm/foca-modal-moneda.git", | |
46 | 46 | "foca-modal-precio-condiciones": "git+http://git.focasoftware.com/npm/foca-modal-precio-condiciones.git", |
47 | - "foca-modal-proveedor": "git+http://git.focasoftware.com/npm/foca-modal-proveedor.git", | |
48 | - "foca-modal-vendedores": "git+http://git.focasoftware.com/npm/foca-modal-vendedores.git", | |
49 | 47 | "foca-seguimiento": "git+http://git.focasoftware.com/npm/foca-seguimiento.git", |
50 | 48 | "font-awesome": "^4.7.0", |
51 | 49 | "gulp": "^3.9.1", |
spec/controllerSpec.js
... | ... | @@ -0,0 +1,1522 @@ |
1 | +describe('Controlador modulo crear remito', function() { | |
2 | + | |
3 | + var $controller; | |
4 | + | |
5 | + beforeEach(function() { | |
6 | + | |
7 | + module('focaCrearRemito'); | |
8 | + | |
9 | + inject(function(_$controller_) { | |
10 | + $controller = _$controller_; | |
11 | + }); | |
12 | + }); | |
13 | + | |
14 | + describe('Controlador remitoController', function() { | |
15 | + | |
16 | + var timeout; | |
17 | + | |
18 | + beforeEach(function() { | |
19 | + | |
20 | + inject(function($timeout) { | |
21 | + timeout = $timeout; | |
22 | + }); | |
23 | + }); | |
24 | + | |
25 | + it('Existe el controlador remitoController', function() { | |
26 | + | |
27 | + //act | |
28 | + var controlador = $controller('remitoController', { | |
29 | + $scope: { | |
30 | + $broadcast: function() { }, | |
31 | + $watch: function() { } | |
32 | + }, | |
33 | + $uibModal: {}, | |
34 | + $location: {}, | |
35 | + $filter: {}, | |
36 | + crearRemitoService: { | |
37 | + getBotonera: function() { }, | |
38 | + getCotizacionByIdMoneda: function() { | |
39 | + return { | |
40 | + then: function() { } | |
41 | + }; | |
42 | + }, | |
43 | + getNumeroRemito: function() { | |
44 | + return { | |
45 | + then: function() { } | |
46 | + }; | |
47 | + } | |
48 | + }, | |
49 | + $timeout: timeout, | |
50 | + focaModalService: {}, | |
51 | + remitoBusinessService: {}, | |
52 | + $rootScope: { | |
53 | + $on: function() { } | |
54 | + }, | |
55 | + focaBotoneraLateralService: {}, | |
56 | + $localStorage: {} | |
57 | + }); | |
58 | + | |
59 | + //assert | |
60 | + expect(typeof controlador).toEqual('object'); | |
61 | + | |
62 | + }); | |
63 | + | |
64 | + it('seleccionarNotaPedido levanta modal', function() { | |
65 | + | |
66 | + //arrange | |
67 | + var scope = { | |
68 | + $broadcast: function() { }, | |
69 | + $watch: function() { } | |
70 | + }; | |
71 | + var uibModal = { | |
72 | + open: function() { } | |
73 | + }; | |
74 | + | |
75 | + $controller('remitoController', { | |
76 | + $scope: scope, | |
77 | + $uibModal: uibModal, | |
78 | + $location: {}, | |
79 | + $filter: {}, | |
80 | + crearRemitoService: { | |
81 | + getBotonera: function() { }, | |
82 | + getCotizacionByIdMoneda: function() { | |
83 | + return { | |
84 | + then: function() { } | |
85 | + }; | |
86 | + }, | |
87 | + getNumeroRemito: function() { | |
88 | + return { | |
89 | + then: function() { } | |
90 | + }; | |
91 | + } | |
92 | + }, | |
93 | + $timeout: timeout, | |
94 | + focaModalService: {}, | |
95 | + remitoBusinessService: {}, | |
96 | + $rootScope: { | |
97 | + $on: function() { } | |
98 | + }, | |
99 | + focaBotoneraLateralService: {}, | |
100 | + $localStorage: {} | |
101 | + }); | |
102 | + | |
103 | + //act | |
104 | + spyOn(uibModal, 'open').and.returnValue({ result: { then: function() { } } }); | |
105 | + spyOn(scope, 'seleccionarNotaPedido'); | |
106 | + scope.seleccionarNotaPedido(); | |
107 | + | |
108 | + //assert | |
109 | + expect(scope.seleccionarNotaPedido).toHaveBeenCalled(); | |
110 | + | |
111 | + }); | |
112 | + | |
113 | + it('seleccionarRemito levanta modal', function() { | |
114 | + | |
115 | + //arrange | |
116 | + var scope = { | |
117 | + $broadcast: function() { }, | |
118 | + $watch: function() { } | |
119 | + }; | |
120 | + var uibModal = { | |
121 | + open: function() { } | |
122 | + }; | |
123 | + | |
124 | + $controller('remitoController', { | |
125 | + $scope: scope, | |
126 | + $uibModal: uibModal, | |
127 | + $location: {}, | |
128 | + $filter: {}, | |
129 | + crearRemitoService: { | |
130 | + getBotonera: function() { }, | |
131 | + getCotizacionByIdMoneda: function() { | |
132 | + return { | |
133 | + then: function() { } | |
134 | + }; | |
135 | + }, | |
136 | + getNumeroRemito: function() { | |
137 | + return { | |
138 | + then: function() { } | |
139 | + }; | |
140 | + } | |
141 | + }, | |
142 | + $timeout: timeout, | |
143 | + focaModalService: {}, | |
144 | + remitoBusinessService: {}, | |
145 | + $rootScope: { | |
146 | + $on: function() { } | |
147 | + }, | |
148 | + focaBotoneraLateralService: {}, | |
149 | + $localStorage: {} | |
150 | + }); | |
151 | + | |
152 | + //act | |
153 | + spyOn(uibModal, 'open').and.returnValue({ result: { then: function() { } } }); | |
154 | + spyOn(scope, 'seleccionarRemito'); | |
155 | + scope.seleccionarRemito(); | |
156 | + | |
157 | + //assert | |
158 | + expect(scope.seleccionarRemito).toHaveBeenCalled(); | |
159 | + | |
160 | + }); | |
161 | + | |
162 | + it('crearRemito muestra alerta cuando no se eligió vendedor', function() { | |
163 | + | |
164 | + //arrange | |
165 | + var scope = { | |
166 | + $broadcast: function() { }, | |
167 | + $watch: function() { } | |
168 | + }; | |
169 | + var focaModalService = { | |
170 | + alert: function() { } | |
171 | + }; | |
172 | + | |
173 | + $controller('remitoController', { | |
174 | + $scope: scope, | |
175 | + $uibModal: {}, | |
176 | + $location: {}, | |
177 | + $filter: {}, | |
178 | + crearRemitoService: { | |
179 | + getBotonera: function() { }, | |
180 | + getCotizacionByIdMoneda: function() { | |
181 | + return { | |
182 | + then: function() { } | |
183 | + }; | |
184 | + }, | |
185 | + getNumeroRemito: function() { | |
186 | + return { | |
187 | + then: function() { } | |
188 | + }; | |
189 | + } | |
190 | + }, | |
191 | + $timeout: timeout, | |
192 | + focaModalService: focaModalService, | |
193 | + remitoBusinessService: {}, | |
194 | + $rootScope: { | |
195 | + $on: function() { } | |
196 | + }, | |
197 | + focaBotoneraLateralService: {}, | |
198 | + $localStorage: {} | |
199 | + }); | |
200 | + | |
201 | + //act | |
202 | + spyOn(focaModalService, 'alert'); | |
203 | + scope.crearRemito(); | |
204 | + | |
205 | + //assert | |
206 | + expect(focaModalService.alert).toHaveBeenCalledWith('Ingrese Vendedor'); | |
207 | + | |
208 | + }); | |
209 | + | |
210 | + it('crearRemito muestra alerta cuando no se eligió cliente', function() { | |
211 | + | |
212 | + //arrange | |
213 | + var scope = { | |
214 | + $broadcast: function() { }, | |
215 | + $watch: function() { } | |
216 | + }; | |
217 | + var focaModalService = { | |
218 | + alert: function() { } | |
219 | + }; | |
220 | + | |
221 | + $controller('remitoController', { | |
222 | + $scope: scope, | |
223 | + $uibModal: {}, | |
224 | + $location: {}, | |
225 | + $filter: {}, | |
226 | + crearRemitoService: { | |
227 | + getBotonera: function() { }, | |
228 | + getCotizacionByIdMoneda: function() { | |
229 | + return { | |
230 | + then: function() { } | |
231 | + }; | |
232 | + }, | |
233 | + getNumeroRemito: function() { | |
234 | + return { | |
235 | + then: function() { } | |
236 | + }; | |
237 | + } | |
238 | + }, | |
239 | + $timeout: timeout, | |
240 | + focaModalService: focaModalService, | |
241 | + remitoBusinessService: {}, | |
242 | + $rootScope: { | |
243 | + $on: function() { } | |
244 | + }, | |
245 | + focaBotoneraLateralService: {}, | |
246 | + $localStorage: {} | |
247 | + }); | |
248 | + | |
249 | + scope.remito = { | |
250 | + vendedor: { NUM: true }, | |
251 | + cliente: {} | |
252 | + }; | |
253 | + | |
254 | + //act | |
255 | + spyOn(focaModalService, 'alert'); | |
256 | + scope.crearRemito(); | |
257 | + | |
258 | + //assert | |
259 | + expect(focaModalService.alert).toHaveBeenCalledWith('Ingrese Cliente'); | |
260 | + | |
261 | + }); | |
262 | + | |
263 | + it('crearRemito muestra alerta cuando no se eligió Proveedor', function() { | |
264 | + | |
265 | + //arrange | |
266 | + var scope = { | |
267 | + $broadcast: function() { }, | |
268 | + $watch: function() { } | |
269 | + }; | |
270 | + var focaModalService = { | |
271 | + alert: function() { } | |
272 | + }; | |
273 | + | |
274 | + $controller('remitoController', { | |
275 | + $scope: scope, | |
276 | + $uibModal: {}, | |
277 | + $location: {}, | |
278 | + $filter: {}, | |
279 | + crearRemitoService: { | |
280 | + getBotonera: function() { }, | |
281 | + getCotizacionByIdMoneda: function() { | |
282 | + return { | |
283 | + then: function() { } | |
284 | + }; | |
285 | + }, | |
286 | + getNumeroRemito: function() { | |
287 | + return { | |
288 | + then: function() { } | |
289 | + }; | |
290 | + } | |
291 | + }, | |
292 | + $timeout: timeout, | |
293 | + focaModalService: focaModalService, | |
294 | + remitoBusinessService: {}, | |
295 | + $rootScope: { | |
296 | + $on: function() { } | |
297 | + }, | |
298 | + focaBotoneraLateralService: {}, | |
299 | + $localStorage: {} | |
300 | + }); | |
301 | + | |
302 | + scope.remito = { | |
303 | + vendedor: { NUM: true }, | |
304 | + cliente: { COD: true } | |
305 | + }; | |
306 | + | |
307 | + //act | |
308 | + spyOn(focaModalService, 'alert'); | |
309 | + scope.crearRemito(); | |
310 | + | |
311 | + //assert | |
312 | + expect(focaModalService.alert).toHaveBeenCalledWith('Ingrese Proveedor'); | |
313 | + | |
314 | + }); | |
315 | + | |
316 | + it('crearRemito muestra alerta cuando no se eligió moneda', function() { | |
317 | + | |
318 | + //arrange | |
319 | + var scope = { | |
320 | + $broadcast: function() { }, | |
321 | + $watch: function() { } | |
322 | + }; | |
323 | + var focaModalService = { | |
324 | + alert: function() { } | |
325 | + }; | |
326 | + | |
327 | + $controller('remitoController', { | |
328 | + $scope: scope, | |
329 | + $uibModal: {}, | |
330 | + $location: {}, | |
331 | + $filter: {}, | |
332 | + crearRemitoService: { | |
333 | + getBotonera: function() { }, | |
334 | + getCotizacionByIdMoneda: function() { | |
335 | + return { | |
336 | + then: function() { } | |
337 | + }; | |
338 | + }, | |
339 | + getNumeroRemito: function() { | |
340 | + return { | |
341 | + then: function() { } | |
342 | + }; | |
343 | + } | |
344 | + }, | |
345 | + $timeout: timeout, | |
346 | + focaModalService: focaModalService, | |
347 | + remitoBusinessService: {}, | |
348 | + $rootScope: { | |
349 | + $on: function() { } | |
350 | + }, | |
351 | + focaBotoneraLateralService: {}, | |
352 | + $localStorage: {} | |
353 | + }); | |
354 | + | |
355 | + scope.remito = { | |
356 | + vendedor: { NUM: true }, | |
357 | + cliente: { COD: true }, | |
358 | + proveedor: {}, | |
359 | + cotizacion: { moneda: {} } | |
360 | + }; | |
361 | + | |
362 | + //act | |
363 | + spyOn(focaModalService, 'alert'); | |
364 | + scope.crearRemito(); | |
365 | + | |
366 | + //assert | |
367 | + expect(focaModalService.alert).toHaveBeenCalledWith('Ingrese Moneda'); | |
368 | + | |
369 | + }); | |
370 | + | |
371 | + it('crearRemito muestra alerta cuando no se eligió Cotización', function() { | |
372 | + | |
373 | + //arrange | |
374 | + var scope = { | |
375 | + $broadcast: function() { }, | |
376 | + $watch: function() { } | |
377 | + }; | |
378 | + var focaModalService = { | |
379 | + alert: function() { } | |
380 | + }; | |
381 | + | |
382 | + $controller('remitoController', { | |
383 | + $scope: scope, | |
384 | + $uibModal: {}, | |
385 | + $location: {}, | |
386 | + $filter: {}, | |
387 | + crearRemitoService: { | |
388 | + getBotonera: function() { }, | |
389 | + getCotizacionByIdMoneda: function() { | |
390 | + return { | |
391 | + then: function() { } | |
392 | + }; | |
393 | + }, | |
394 | + getNumeroRemito: function() { | |
395 | + return { | |
396 | + then: function() { } | |
397 | + }; | |
398 | + } | |
399 | + }, | |
400 | + $timeout: timeout, | |
401 | + focaModalService: focaModalService, | |
402 | + remitoBusinessService: {}, | |
403 | + $rootScope: { | |
404 | + $on: function() { } | |
405 | + }, | |
406 | + focaBotoneraLateralService: {}, | |
407 | + $localStorage: {} | |
408 | + }); | |
409 | + | |
410 | + scope.remito = { | |
411 | + vendedor: { NUM: true }, | |
412 | + cliente: { COD: true }, | |
413 | + proveedor: {}, | |
414 | + cotizacion: { moneda: { id: true } } | |
415 | + }; | |
416 | + | |
417 | + //act | |
418 | + spyOn(focaModalService, 'alert'); | |
419 | + scope.crearRemito(); | |
420 | + | |
421 | + //assert | |
422 | + expect(focaModalService.alert).toHaveBeenCalledWith('Ingrese Cotización'); | |
423 | + | |
424 | + }); | |
425 | + | |
426 | + it('crearRemito muestra alerta cuando no se eligió flete', function() { | |
427 | + | |
428 | + //arrange | |
429 | + var scope = { | |
430 | + $broadcast: function() { }, | |
431 | + $watch: function() { } | |
432 | + }; | |
433 | + var focaModalService = { | |
434 | + alert: function() { } | |
435 | + }; | |
436 | + | |
437 | + $controller('remitoController', { | |
438 | + $scope: scope, | |
439 | + $uibModal: {}, | |
440 | + $location: {}, | |
441 | + $filter: {}, | |
442 | + crearRemitoService: { | |
443 | + getBotonera: function() { }, | |
444 | + getCotizacionByIdMoneda: function() { | |
445 | + return { | |
446 | + then: function() { } | |
447 | + }; | |
448 | + }, | |
449 | + getNumeroRemito: function() { | |
450 | + return { | |
451 | + then: function() { } | |
452 | + }; | |
453 | + } | |
454 | + }, | |
455 | + $timeout: timeout, | |
456 | + focaModalService: focaModalService, | |
457 | + remitoBusinessService: {}, | |
458 | + $rootScope: { | |
459 | + $on: function() { } | |
460 | + }, | |
461 | + focaBotoneraLateralService: {}, | |
462 | + $localStorage: {} | |
463 | + }); | |
464 | + | |
465 | + scope.remito = { | |
466 | + vendedor: { NUM: true }, | |
467 | + cliente: { COD: true }, | |
468 | + proveedor: {}, | |
469 | + cotizacion: { | |
470 | + moneda: { id: true }, | |
471 | + ID: true | |
472 | + } | |
473 | + }; | |
474 | + | |
475 | + //act | |
476 | + spyOn(focaModalService, 'alert'); | |
477 | + scope.crearRemito(); | |
478 | + | |
479 | + //assert | |
480 | + expect(focaModalService.alert).toHaveBeenCalledWith('Ingrese Flete'); | |
481 | + | |
482 | + }); | |
483 | + | |
484 | + it('crearRemito muestra alerta cuando no se eligió articulos', function() { | |
485 | + | |
486 | + //arrange | |
487 | + var scope = { | |
488 | + $broadcast: function() { }, | |
489 | + $watch: function() { } | |
490 | + }; | |
491 | + var focaModalService = { | |
492 | + alert: function() { } | |
493 | + }; | |
494 | + | |
495 | + $controller('remitoController', { | |
496 | + $scope: scope, | |
497 | + $uibModal: {}, | |
498 | + $location: {}, | |
499 | + $filter: {}, | |
500 | + crearRemitoService: { | |
501 | + getBotonera: function() { }, | |
502 | + getCotizacionByIdMoneda: function() { | |
503 | + return { | |
504 | + then: function() { } | |
505 | + }; | |
506 | + }, | |
507 | + getNumeroRemito: function() { | |
508 | + return { | |
509 | + then: function() { } | |
510 | + }; | |
511 | + } | |
512 | + }, | |
513 | + $timeout: timeout, | |
514 | + focaModalService: focaModalService, | |
515 | + remitoBusinessService: {}, | |
516 | + $rootScope: { | |
517 | + $on: function() { } | |
518 | + }, | |
519 | + focaBotoneraLateralService: {}, | |
520 | + $localStorage: {} | |
521 | + }); | |
522 | + | |
523 | + scope.remito = { | |
524 | + vendedor: { NUM: true }, | |
525 | + cliente: { COD: true }, | |
526 | + proveedor: {}, | |
527 | + cotizacion: { | |
528 | + moneda: { id: true }, | |
529 | + ID: true | |
530 | + }, | |
531 | + flete: true, | |
532 | + articulosRemito: [] | |
533 | + }; | |
534 | + | |
535 | + //act | |
536 | + spyOn(focaModalService, 'alert'); | |
537 | + scope.crearRemito(); | |
538 | + | |
539 | + //assert | |
540 | + expect(focaModalService.alert).toHaveBeenCalledWith('Debe cargar al menos un articulo'); | |
541 | + | |
542 | + }); | |
543 | + | |
544 | + it('crearRemito llama a startGuardar', function() { | |
545 | + | |
546 | + //arrange | |
547 | + var scope = { | |
548 | + $broadcast: function() { }, | |
549 | + $watch: function() { } | |
550 | + }; | |
551 | + var focaBotoneraLateralService = { | |
552 | + startGuardar: function() { } | |
553 | + }; | |
554 | + | |
555 | + $controller('remitoController', { | |
556 | + $scope: scope, | |
557 | + $uibModal: {}, | |
558 | + $location: {}, | |
559 | + $filter: {}, | |
560 | + crearRemitoService: { | |
561 | + getBotonera: function() { }, | |
562 | + getCotizacionByIdMoneda: function() { | |
563 | + return { | |
564 | + then: function() { } | |
565 | + }; | |
566 | + }, | |
567 | + getNumeroRemito: function() { | |
568 | + return { | |
569 | + then: function() { } | |
570 | + }; | |
571 | + }, | |
572 | + crearRemito: function() { | |
573 | + return { | |
574 | + then: function() { } | |
575 | + }; | |
576 | + } | |
577 | + }, | |
578 | + $timeout: timeout, | |
579 | + focaModalService: {}, | |
580 | + remitoBusinessService: {}, | |
581 | + $rootScope: { | |
582 | + $on: function() { } | |
583 | + }, | |
584 | + focaBotoneraLateralService: focaBotoneraLateralService, | |
585 | + $localStorage: {} | |
586 | + }); | |
587 | + | |
588 | + scope.remito = { | |
589 | + vendedor: { NUM: true }, | |
590 | + cliente: { COD: true }, | |
591 | + proveedor: {}, | |
592 | + cotizacion: { | |
593 | + moneda: { id: true }, | |
594 | + ID: true | |
595 | + }, | |
596 | + flete: true, | |
597 | + articulosRemito: [ 1 ] | |
598 | + }; | |
599 | + | |
600 | + //act | |
601 | + spyOn(focaBotoneraLateralService, 'startGuardar'); | |
602 | + scope.crearRemito(); | |
603 | + | |
604 | + //assert | |
605 | + expect(focaBotoneraLateralService.startGuardar).toHaveBeenCalled(); | |
606 | + | |
607 | + }); | |
608 | + | |
609 | + it('crearRemito llama a endGuardar y abre modal', function(done) { | |
610 | + | |
611 | + //arrange | |
612 | + var scope = { | |
613 | + $broadcast: function() { }, | |
614 | + $watch: function() { } | |
615 | + }; | |
616 | + var focaBotoneraLateralService = { | |
617 | + startGuardar: function() { }, | |
618 | + endGuardar: function() { } | |
619 | + }; | |
620 | + var uibModal = { | |
621 | + open: function() { } | |
622 | + }; | |
623 | + var crearRemitoService = { | |
624 | + getBotonera: function() { }, | |
625 | + getCotizacionByIdMoneda: function() { | |
626 | + return { | |
627 | + then: function() { } | |
628 | + }; | |
629 | + }, | |
630 | + getNumeroRemito: function() { | |
631 | + return { | |
632 | + then: function() { } | |
633 | + }; | |
634 | + }, | |
635 | + crearRemito: function() { } | |
636 | + }; | |
637 | + | |
638 | + $controller('remitoController', { | |
639 | + $scope: scope, | |
640 | + $uibModal: uibModal, | |
641 | + $location: {}, | |
642 | + $filter: {}, | |
643 | + crearRemitoService: crearRemitoService, | |
644 | + $timeout: timeout, | |
645 | + focaModalService: {}, | |
646 | + remitoBusinessService: { | |
647 | + addArticulos: function() { } | |
648 | + }, | |
649 | + $rootScope: { | |
650 | + $on: function() { } | |
651 | + }, | |
652 | + focaBotoneraLateralService: focaBotoneraLateralService, | |
653 | + $localStorage: {} | |
654 | + }); | |
655 | + | |
656 | + scope.remito = { | |
657 | + vendedor: { NUM: true }, | |
658 | + cliente: { COD: true }, | |
659 | + proveedor: {}, | |
660 | + cotizacion: { | |
661 | + moneda: { id: true }, | |
662 | + ID: true | |
663 | + }, | |
664 | + flete: true, | |
665 | + articulosRemito: [1] | |
666 | + }; | |
667 | + var promiseRespond = Promise.resolve({ data: {} }); | |
668 | + | |
669 | + //act | |
670 | + spyOn(crearRemitoService, 'crearRemito').and.returnValue(promiseRespond); | |
671 | + spyOn(focaBotoneraLateralService, 'endGuardar'); | |
672 | + spyOn(uibModal, 'open'); | |
673 | + scope.crearRemito(); | |
674 | + | |
675 | + //assert | |
676 | + promiseRespond.then(function() { | |
677 | + | |
678 | + expect(focaBotoneraLateralService.endGuardar).toHaveBeenCalled(); | |
679 | + done(); | |
680 | + }); | |
681 | + }); | |
682 | + | |
683 | + it('seleccionarProductos abre modal', function() { | |
684 | + | |
685 | + //arrange | |
686 | + var scope = { | |
687 | + $broadcast: function() { }, | |
688 | + $watch: function() { } | |
689 | + }; | |
690 | + var uibModal = { | |
691 | + open: function() { } | |
692 | + }; | |
693 | + | |
694 | + $controller('remitoController', { | |
695 | + $scope: scope, | |
696 | + $uibModal: uibModal, | |
697 | + $location: {}, | |
698 | + $filter: {}, | |
699 | + crearRemitoService: { | |
700 | + getBotonera: function() {}, | |
701 | + getCotizacionByIdMoneda: function() { | |
702 | + return { | |
703 | + then: function() {} | |
704 | + }; | |
705 | + }, | |
706 | + getNumeroRemito: function() { | |
707 | + return { | |
708 | + then: function() {} | |
709 | + }; | |
710 | + } | |
711 | + }, | |
712 | + $timeout: timeout, | |
713 | + focaModalService: {}, | |
714 | + remitoBusinessService: { | |
715 | + addArticulos: function() { } | |
716 | + }, | |
717 | + $rootScope: { | |
718 | + $on: function() { } | |
719 | + }, | |
720 | + focaBotoneraLateralService: {}, | |
721 | + $localStorage: {} | |
722 | + }); | |
723 | + | |
724 | + scope.remito = { | |
725 | + cotizacion: { | |
726 | + moneda: { }, | |
727 | + }, | |
728 | + }; | |
729 | + scope.idLista = true; | |
730 | + | |
731 | + //act | |
732 | + spyOn(uibModal, 'open').and.returnValue({ result: { then: function() {} } }); | |
733 | + scope.seleccionarProductos(); | |
734 | + | |
735 | + //assert | |
736 | + expect(uibModal.open).toHaveBeenCalled(); | |
737 | + }); | |
738 | + | |
739 | + it('seleccionarProductos abre alerta si no se eligió lista', function() { | |
740 | + | |
741 | + //arrange | |
742 | + var scope = { | |
743 | + $broadcast: function() { }, | |
744 | + $watch: function() { } | |
745 | + }; | |
746 | + var focaModalService = { | |
747 | + alert: function() { } | |
748 | + }; | |
749 | + | |
750 | + $controller('remitoController', { | |
751 | + $scope: scope, | |
752 | + $uibModal: {}, | |
753 | + $location: {}, | |
754 | + $filter: {}, | |
755 | + crearRemitoService: { | |
756 | + getBotonera: function() {}, | |
757 | + getCotizacionByIdMoneda: function() { | |
758 | + return { | |
759 | + then: function() {} | |
760 | + }; | |
761 | + }, | |
762 | + getNumeroRemito: function() { | |
763 | + return { | |
764 | + then: function() {} | |
765 | + }; | |
766 | + } | |
767 | + }, | |
768 | + $timeout: timeout, | |
769 | + focaModalService: focaModalService, | |
770 | + remitoBusinessService: { | |
771 | + addArticulos: function() { } | |
772 | + }, | |
773 | + $rootScope: { | |
774 | + $on: function() { } | |
775 | + }, | |
776 | + focaBotoneraLateralService: {}, | |
777 | + $localStorage: {} | |
778 | + }); | |
779 | + | |
780 | + //act | |
781 | + spyOn(focaModalService, 'alert'); | |
782 | + scope.seleccionarProductos(); | |
783 | + | |
784 | + //assert | |
785 | + expect(focaModalService.alert) | |
786 | + .toHaveBeenCalledWith('Primero seleccione una lista de precio y condicion'); | |
787 | + }); | |
788 | + | |
789 | + it('seleccionarPuntosDeDescarga abre modal', function() { | |
790 | + | |
791 | + //arrange | |
792 | + var scope = { | |
793 | + $broadcast: function() { }, | |
794 | + $watch: function() { } | |
795 | + }; | |
796 | + var uibModal = { | |
797 | + open: function() { } | |
798 | + }; | |
799 | + | |
800 | + $controller('remitoController', { | |
801 | + $scope: scope, | |
802 | + $uibModal: uibModal, | |
803 | + $location: {}, | |
804 | + $filter: {}, | |
805 | + crearRemitoService: { | |
806 | + getBotonera: function() {}, | |
807 | + getCotizacionByIdMoneda: function() { | |
808 | + return { | |
809 | + then: function() {} | |
810 | + }; | |
811 | + }, | |
812 | + getNumeroRemito: function() { | |
813 | + return { | |
814 | + then: function() {} | |
815 | + }; | |
816 | + } | |
817 | + }, | |
818 | + $timeout: timeout, | |
819 | + focaModalService: {}, | |
820 | + remitoBusinessService: { | |
821 | + addArticulos: function() { } | |
822 | + }, | |
823 | + $rootScope: { | |
824 | + $on: function() { } | |
825 | + }, | |
826 | + focaBotoneraLateralService: {}, | |
827 | + $localStorage: {} | |
828 | + }); | |
829 | + scope.remito = { | |
830 | + cliente: { COD: true }, | |
831 | + domicilio: { id: true } | |
832 | + }; | |
833 | + | |
834 | + //act | |
835 | + spyOn(uibModal, 'open').and.returnValue({ result: { then: function() { } } }); | |
836 | + scope.seleccionarPuntosDeDescarga(); | |
837 | + | |
838 | + //assert | |
839 | + expect(uibModal.open).toHaveBeenCalled(); | |
840 | + }); | |
841 | + | |
842 | + it('seleccionarVendedor abre modal', function() { | |
843 | + | |
844 | + //arrange | |
845 | + var scope = { | |
846 | + $broadcast: function() { }, | |
847 | + $watch: function() { } | |
848 | + }; | |
849 | + var focaModalService = { | |
850 | + modal: function() { } | |
851 | + }; | |
852 | + | |
853 | + $controller('remitoController', { | |
854 | + $scope: scope, | |
855 | + $uibModal: {}, | |
856 | + $location: {}, | |
857 | + $filter: {}, | |
858 | + crearRemitoService: { | |
859 | + getBotonera: function() {}, | |
860 | + getCotizacionByIdMoneda: function() { | |
861 | + return { | |
862 | + then: function() {} | |
863 | + }; | |
864 | + }, | |
865 | + getNumeroRemito: function() { | |
866 | + return { | |
867 | + then: function() {} | |
868 | + }; | |
869 | + } | |
870 | + }, | |
871 | + $timeout: timeout, | |
872 | + focaModalService: focaModalService, | |
873 | + remitoBusinessService: { | |
874 | + addArticulos: function() { } | |
875 | + }, | |
876 | + $rootScope: { | |
877 | + $on: function() { } | |
878 | + }, | |
879 | + focaBotoneraLateralService: {}, | |
880 | + $localStorage: {} | |
881 | + }); | |
882 | + | |
883 | + //act | |
884 | + spyOn(focaModalService, 'modal').and.returnValue({ then: function() { } }); | |
885 | + scope.seleccionarVendedor(); | |
886 | + | |
887 | + //assert | |
888 | + expect(focaModalService.modal).toHaveBeenCalled(); | |
889 | + }); | |
890 | + | |
891 | + it('seleccionarCliente abre modal', function() { | |
892 | + | |
893 | + //arrange | |
894 | + var scope = { | |
895 | + $broadcast: function() { }, | |
896 | + $watch: function() { } | |
897 | + }; | |
898 | + var uibModal = { | |
899 | + open: function() { } | |
900 | + }; | |
901 | + | |
902 | + $controller('remitoController', { | |
903 | + $scope: scope, | |
904 | + $uibModal: uibModal, | |
905 | + $location: {}, | |
906 | + $filter: {}, | |
907 | + crearRemitoService: { | |
908 | + getBotonera: function() {}, | |
909 | + getCotizacionByIdMoneda: function() { | |
910 | + return { | |
911 | + then: function() {} | |
912 | + }; | |
913 | + }, | |
914 | + getNumeroRemito: function() { | |
915 | + return { | |
916 | + then: function() {} | |
917 | + }; | |
918 | + } | |
919 | + }, | |
920 | + $timeout: timeout, | |
921 | + focaModalService: {}, | |
922 | + remitoBusinessService: { | |
923 | + addArticulos: function() { } | |
924 | + }, | |
925 | + $rootScope: { | |
926 | + $on: function() { } | |
927 | + }, | |
928 | + focaBotoneraLateralService: {}, | |
929 | + $localStorage: {} | |
930 | + }); | |
931 | + | |
932 | + //act | |
933 | + spyOn(uibModal, 'open').and.returnValue({ result: { then: function() { } } }); | |
934 | + scope.seleccionarCliente(true); | |
935 | + | |
936 | + //assert | |
937 | + expect(uibModal.open).toHaveBeenCalled(); | |
938 | + }); | |
939 | + | |
940 | + it('seleccionarCliente setea cliente y llama a abrirModalDomicilios', function(done) { | |
941 | + | |
942 | + //arrange | |
943 | + var scope = { | |
944 | + $broadcast: function() { }, | |
945 | + $watch: function() { } | |
946 | + }; | |
947 | + var uibModal = { | |
948 | + open: function() { } | |
949 | + }; | |
950 | + | |
951 | + $controller('remitoController', { | |
952 | + $scope: scope, | |
953 | + $uibModal: uibModal, | |
954 | + $location: {}, | |
955 | + $filter: {}, | |
956 | + crearRemitoService: { | |
957 | + getBotonera: function() {}, | |
958 | + getCotizacionByIdMoneda: function() { | |
959 | + return { | |
960 | + then: function() {} | |
961 | + }; | |
962 | + }, | |
963 | + getNumeroRemito: function() { | |
964 | + return { | |
965 | + then: function() {} | |
966 | + }; | |
967 | + } | |
968 | + }, | |
969 | + $timeout: timeout, | |
970 | + focaModalService: {}, | |
971 | + remitoBusinessService: { | |
972 | + addArticulos: function() { } | |
973 | + }, | |
974 | + $rootScope: { | |
975 | + $on: function() { } | |
976 | + }, | |
977 | + focaBotoneraLateralService: {}, | |
978 | + $localStorage: {} | |
979 | + }); | |
980 | + var response = 'test'; | |
981 | + var promesa = { result: Promise.resolve(response) }; | |
982 | + | |
983 | + //act | |
984 | + spyOn(uibModal, 'open').and.returnValue(promesa); | |
985 | + spyOn(scope, 'abrirModalDomicilios'); | |
986 | + scope.seleccionarCliente(true); | |
987 | + | |
988 | + //assert | |
989 | + promesa.result.then(function() { | |
990 | + expect(scope.abrirModalDomicilios).toHaveBeenCalledWith(response); | |
991 | + expect(scope.cliente).toEqual(response); | |
992 | + done(); | |
993 | + }); | |
994 | + }); | |
995 | + | |
996 | + it('seleccionarProveedor abre modal', function() { | |
997 | + | |
998 | + //arrange | |
999 | + var scope = { | |
1000 | + $broadcast: function() { }, | |
1001 | + $watch: function() { } | |
1002 | + }; | |
1003 | + var focaModalService = { | |
1004 | + modal: function() { } | |
1005 | + }; | |
1006 | + | |
1007 | + $controller('remitoController', { | |
1008 | + $scope: scope, | |
1009 | + $uibModal: {}, | |
1010 | + $location: {}, | |
1011 | + $filter: {}, | |
1012 | + crearRemitoService: { | |
1013 | + getBotonera: function() {}, | |
1014 | + getCotizacionByIdMoneda: function() { | |
1015 | + return { | |
1016 | + then: function() {} | |
1017 | + }; | |
1018 | + }, | |
1019 | + getNumeroRemito: function() { | |
1020 | + return { | |
1021 | + then: function() {} | |
1022 | + }; | |
1023 | + } | |
1024 | + }, | |
1025 | + $timeout: timeout, | |
1026 | + focaModalService: focaModalService, | |
1027 | + remitoBusinessService: { | |
1028 | + addArticulos: function() { } | |
1029 | + }, | |
1030 | + $rootScope: { | |
1031 | + $on: function() { } | |
1032 | + }, | |
1033 | + focaBotoneraLateralService: {}, | |
1034 | + $localStorage: {} | |
1035 | + }); | |
1036 | + | |
1037 | + //act | |
1038 | + spyOn(focaModalService, 'modal').and.returnValue({ then: function() { } }); | |
1039 | + scope.seleccionarProveedor(); | |
1040 | + | |
1041 | + //assert | |
1042 | + expect(focaModalService.modal).toHaveBeenCalled(); | |
1043 | + }); | |
1044 | + | |
1045 | + it('seleccionarProveedor setea provedor y llama a callback', function(done) { | |
1046 | + | |
1047 | + //arrange | |
1048 | + var scope = { | |
1049 | + $broadcast: function() { }, | |
1050 | + $watch: function() { } | |
1051 | + }; | |
1052 | + var focaModalService = { | |
1053 | + modal: function() { } | |
1054 | + }; | |
1055 | + | |
1056 | + $controller('remitoController', { | |
1057 | + $scope: scope, | |
1058 | + $uibModal: {}, | |
1059 | + $location: {}, | |
1060 | + $filter: function() { | |
1061 | + return function() { }; | |
1062 | + }, | |
1063 | + crearRemitoService: { | |
1064 | + getBotonera: function() {}, | |
1065 | + getCotizacionByIdMoneda: function() { | |
1066 | + return { | |
1067 | + then: function() {} | |
1068 | + }; | |
1069 | + }, | |
1070 | + getNumeroRemito: function() { | |
1071 | + return { | |
1072 | + then: function() {} | |
1073 | + }; | |
1074 | + } | |
1075 | + }, | |
1076 | + $timeout: timeout, | |
1077 | + focaModalService: focaModalService, | |
1078 | + remitoBusinessService: { | |
1079 | + addArticulos: function() { } | |
1080 | + }, | |
1081 | + $rootScope: { | |
1082 | + $on: function() { } | |
1083 | + }, | |
1084 | + focaBotoneraLateralService: {}, | |
1085 | + $localStorage: {} | |
1086 | + }); | |
1087 | + var response = { COD: 1 }; | |
1088 | + var promesa = Promise.resolve(response); | |
1089 | + window.callback = function() { }; | |
1090 | + | |
1091 | + //act | |
1092 | + spyOn(focaModalService, 'modal').and.returnValue(promesa); | |
1093 | + spyOn(window, 'callback'); | |
1094 | + scope.seleccionarProveedor(window.callback); | |
1095 | + | |
1096 | + //assert | |
1097 | + promesa.then(function() { | |
1098 | + expect(window.callback).toHaveBeenCalled(); | |
1099 | + expect(scope.remito.proveedor).toBe(response); | |
1100 | + expect(scope.remito.idProveedor).toBe(response.COD); | |
1101 | + done(); | |
1102 | + }); | |
1103 | + }); | |
1104 | + | |
1105 | + it('abrirModalDomicilios abre modal', function() { | |
1106 | + | |
1107 | + //arrange | |
1108 | + var scope = { | |
1109 | + $broadcast: function() { }, | |
1110 | + $watch: function() { } | |
1111 | + }; | |
1112 | + var uibModal = { | |
1113 | + open: function() { } | |
1114 | + }; | |
1115 | + | |
1116 | + $controller('remitoController', { | |
1117 | + $scope: scope, | |
1118 | + $uibModal: uibModal, | |
1119 | + $location: {}, | |
1120 | + $filter: {}, | |
1121 | + crearRemitoService: { | |
1122 | + getBotonera: function() {}, | |
1123 | + getCotizacionByIdMoneda: function() { | |
1124 | + return { | |
1125 | + then: function() {} | |
1126 | + }; | |
1127 | + }, | |
1128 | + getNumeroRemito: function() { | |
1129 | + return { | |
1130 | + then: function() {} | |
1131 | + }; | |
1132 | + } | |
1133 | + }, | |
1134 | + $timeout: timeout, | |
1135 | + focaModalService: {}, | |
1136 | + remitoBusinessService: { | |
1137 | + addArticulos: function() { } | |
1138 | + }, | |
1139 | + $rootScope: { | |
1140 | + $on: function() { } | |
1141 | + }, | |
1142 | + focaBotoneraLateralService: {}, | |
1143 | + $localStorage: {} | |
1144 | + }); | |
1145 | + | |
1146 | + //act | |
1147 | + spyOn(uibModal, 'open').and.returnValue({ result: { then: function() { } } }); | |
1148 | + scope.abrirModalDomicilios(); | |
1149 | + | |
1150 | + //assert | |
1151 | + expect(uibModal.open).toHaveBeenCalled(); | |
1152 | + | |
1153 | + }); | |
1154 | + | |
1155 | + it('getTotal devuelve correctamente', function() { | |
1156 | + | |
1157 | + //arrange | |
1158 | + var scope = { | |
1159 | + $broadcast: function() { }, | |
1160 | + $watch: function() { } | |
1161 | + }; | |
1162 | + | |
1163 | + $controller('remitoController', { | |
1164 | + $scope: scope, | |
1165 | + $uibModal: {}, | |
1166 | + $location: {}, | |
1167 | + $filter: {}, | |
1168 | + crearRemitoService: { | |
1169 | + getBotonera: function() {}, | |
1170 | + getCotizacionByIdMoneda: function() { | |
1171 | + return { | |
1172 | + then: function() {} | |
1173 | + }; | |
1174 | + }, | |
1175 | + getNumeroRemito: function() { | |
1176 | + return { | |
1177 | + then: function() {} | |
1178 | + }; | |
1179 | + } | |
1180 | + }, | |
1181 | + $timeout: timeout, | |
1182 | + focaModalService: {}, | |
1183 | + remitoBusinessService: { | |
1184 | + addArticulos: function() { } | |
1185 | + }, | |
1186 | + $rootScope: { | |
1187 | + $on: function() { } | |
1188 | + }, | |
1189 | + focaBotoneraLateralService: {}, | |
1190 | + $localStorage: {} | |
1191 | + }); | |
1192 | + scope.remito = { | |
1193 | + articulosRemito: [ | |
1194 | + { | |
1195 | + precio: 100, | |
1196 | + cantidad: 3 | |
1197 | + } | |
1198 | + ] | |
1199 | + }; | |
1200 | + | |
1201 | + //act | |
1202 | + var result = scope.getTotal(); | |
1203 | + | |
1204 | + //assert | |
1205 | + expect(result).toEqual(300); | |
1206 | + | |
1207 | + }); | |
1208 | + | |
1209 | + it('getSubTotal devuelve correctamente', function() { | |
1210 | + | |
1211 | + //arrange | |
1212 | + var scope = { | |
1213 | + $broadcast: function() { }, | |
1214 | + $watch: function() { } | |
1215 | + }; | |
1216 | + | |
1217 | + $controller('remitoController', { | |
1218 | + $scope: scope, | |
1219 | + $uibModal: {}, | |
1220 | + $location: {}, | |
1221 | + $filter: {}, | |
1222 | + crearRemitoService: { | |
1223 | + getBotonera: function() {}, | |
1224 | + getCotizacionByIdMoneda: function() { | |
1225 | + return { | |
1226 | + then: function() {} | |
1227 | + }; | |
1228 | + }, | |
1229 | + getNumeroRemito: function() { | |
1230 | + return { | |
1231 | + then: function() {} | |
1232 | + }; | |
1233 | + } | |
1234 | + }, | |
1235 | + $timeout: timeout, | |
1236 | + focaModalService: {}, | |
1237 | + remitoBusinessService: { | |
1238 | + addArticulos: function() { } | |
1239 | + }, | |
1240 | + $rootScope: { | |
1241 | + $on: function() { } | |
1242 | + }, | |
1243 | + focaBotoneraLateralService: {}, | |
1244 | + $localStorage: {} | |
1245 | + }); | |
1246 | + scope.articuloACargar = { | |
1247 | + precio: 200, | |
1248 | + cantidad: 4 | |
1249 | + }; | |
1250 | + | |
1251 | + //act | |
1252 | + var result = scope.getSubTotal(); | |
1253 | + | |
1254 | + //assert | |
1255 | + expect(result).toEqual(800); | |
1256 | + | |
1257 | + }); | |
1258 | + | |
1259 | + it('seleccionarPreciosYCondiciones muestra alerta sino se eligió cliente', function() { | |
1260 | + | |
1261 | + //arrange | |
1262 | + var scope = { | |
1263 | + $broadcast: function() { }, | |
1264 | + $watch: function() { } | |
1265 | + }; | |
1266 | + var focaModalService = { | |
1267 | + alert: function() {} | |
1268 | + }; | |
1269 | + | |
1270 | + $controller('remitoController', { | |
1271 | + $scope: scope, | |
1272 | + $uibModal: {}, | |
1273 | + $location: {}, | |
1274 | + $filter: {}, | |
1275 | + crearRemitoService: { | |
1276 | + getBotonera: function() {}, | |
1277 | + getCotizacionByIdMoneda: function() { | |
1278 | + return { | |
1279 | + then: function() {} | |
1280 | + }; | |
1281 | + }, | |
1282 | + getNumeroRemito: function() { | |
1283 | + return { | |
1284 | + then: function() {} | |
1285 | + }; | |
1286 | + } | |
1287 | + }, | |
1288 | + $timeout: timeout, | |
1289 | + focaModalService: focaModalService, | |
1290 | + remitoBusinessService: { | |
1291 | + addArticulos: function() { } | |
1292 | + }, | |
1293 | + $rootScope: { | |
1294 | + $on: function() { } | |
1295 | + }, | |
1296 | + focaBotoneraLateralService: {}, | |
1297 | + $localStorage: {} | |
1298 | + }); | |
1299 | + | |
1300 | + //act | |
1301 | + spyOn(focaModalService, 'alert'); | |
1302 | + scope.seleccionarPreciosYCondiciones(); | |
1303 | + | |
1304 | + //assert | |
1305 | + expect(focaModalService.alert).toHaveBeenCalledWith('Primero seleccione un cliente'); | |
1306 | + | |
1307 | + }); | |
1308 | + | |
1309 | + it('seleccionarPreciosYCondiciones abre modal', function() { | |
1310 | + | |
1311 | + //arrange | |
1312 | + var scope = { | |
1313 | + $broadcast: function() { }, | |
1314 | + $watch: function() { } | |
1315 | + }; | |
1316 | + var uibModal = { | |
1317 | + open: function() {} | |
1318 | + }; | |
1319 | + | |
1320 | + $controller('remitoController', { | |
1321 | + $scope: scope, | |
1322 | + $uibModal: uibModal, | |
1323 | + $location: {}, | |
1324 | + $filter: {}, | |
1325 | + crearRemitoService: { | |
1326 | + getBotonera: function() {}, | |
1327 | + getCotizacionByIdMoneda: function() { | |
1328 | + return { | |
1329 | + then: function() {} | |
1330 | + }; | |
1331 | + }, | |
1332 | + getNumeroRemito: function() { | |
1333 | + return { | |
1334 | + then: function() {} | |
1335 | + }; | |
1336 | + } | |
1337 | + }, | |
1338 | + $timeout: timeout, | |
1339 | + focaModalService: {}, | |
1340 | + remitoBusinessService: { | |
1341 | + addArticulos: function() { } | |
1342 | + }, | |
1343 | + $rootScope: { | |
1344 | + $on: function() { } | |
1345 | + }, | |
1346 | + focaBotoneraLateralService: {}, | |
1347 | + $localStorage: {} | |
1348 | + }); | |
1349 | + scope.remito = { | |
1350 | + cliente: { COD: true } | |
1351 | + }; | |
1352 | + | |
1353 | + //act | |
1354 | + spyOn(uibModal, 'open').and.returnValue({ result: { then: function() { } } }); | |
1355 | + scope.seleccionarPreciosYCondiciones(); | |
1356 | + | |
1357 | + //assert | |
1358 | + expect(uibModal.open).toHaveBeenCalled(); | |
1359 | + | |
1360 | + }); | |
1361 | + | |
1362 | + it('seleccionarMoneda abre modal y llama a cotizacion', function(done) { | |
1363 | + | |
1364 | + //arrange | |
1365 | + var scope = { | |
1366 | + $broadcast: function() { }, | |
1367 | + $watch: function() { } | |
1368 | + }; | |
1369 | + var focaModalService = { | |
1370 | + modal: function() {} | |
1371 | + }; | |
1372 | + var uibModal = { | |
1373 | + open: function() { | |
1374 | + return { | |
1375 | + result: { | |
1376 | + then: function() {} | |
1377 | + } | |
1378 | + }; | |
1379 | + } | |
1380 | + }; | |
1381 | + | |
1382 | + $controller('remitoController', { | |
1383 | + $scope: scope, | |
1384 | + $uibModal: uibModal, | |
1385 | + $location: {}, | |
1386 | + $filter: {}, | |
1387 | + crearRemitoService: { | |
1388 | + getBotonera: function() {}, | |
1389 | + getCotizacionByIdMoneda: function() { | |
1390 | + return { | |
1391 | + then: function() {} | |
1392 | + }; | |
1393 | + }, | |
1394 | + getNumeroRemito: function() { | |
1395 | + return { | |
1396 | + then: function() {} | |
1397 | + }; | |
1398 | + } | |
1399 | + }, | |
1400 | + $timeout: timeout, | |
1401 | + focaModalService: focaModalService, | |
1402 | + remitoBusinessService: { | |
1403 | + addArticulos: function() { } | |
1404 | + }, | |
1405 | + $rootScope: { | |
1406 | + $on: function() { } | |
1407 | + }, | |
1408 | + focaBotoneraLateralService: {}, | |
1409 | + $localStorage: {} | |
1410 | + }); | |
1411 | + var promesa = Promise.resolve('test'); | |
1412 | + | |
1413 | + //act | |
1414 | + spyOn(focaModalService, 'modal').and.returnValue(promesa); | |
1415 | + scope.seleccionarMoneda(); | |
1416 | + | |
1417 | + //assert | |
1418 | + promesa.then(function() { | |
1419 | + expect(focaModalService.modal).toHaveBeenCalled(); | |
1420 | + done(); | |
1421 | + }); | |
1422 | + }); | |
1423 | + | |
1424 | + it('seleccionarObservaciones levanta prompt', function() { | |
1425 | + | |
1426 | + //arrange | |
1427 | + var scope = { | |
1428 | + $broadcast: function() { }, | |
1429 | + $watch: function() { } | |
1430 | + }; | |
1431 | + var focaModalService = { | |
1432 | + prompt: function() {} | |
1433 | + }; | |
1434 | + | |
1435 | + $controller('remitoController', { | |
1436 | + $scope: scope, | |
1437 | + $uibModal: {}, | |
1438 | + $location: {}, | |
1439 | + $filter: {}, | |
1440 | + crearRemitoService: { | |
1441 | + getBotonera: function() {}, | |
1442 | + getCotizacionByIdMoneda: function() { | |
1443 | + return { | |
1444 | + then: function() {} | |
1445 | + }; | |
1446 | + }, | |
1447 | + getNumeroRemito: function() { | |
1448 | + return { | |
1449 | + then: function() {} | |
1450 | + }; | |
1451 | + } | |
1452 | + }, | |
1453 | + $timeout: timeout, | |
1454 | + focaModalService: focaModalService, | |
1455 | + remitoBusinessService: { | |
1456 | + addArticulos: function() { } | |
1457 | + }, | |
1458 | + $rootScope: { | |
1459 | + $on: function() { } | |
1460 | + }, | |
1461 | + focaBotoneraLateralService: {}, | |
1462 | + $localStorage: {} | |
1463 | + }); | |
1464 | + | |
1465 | + //act | |
1466 | + spyOn(focaModalService, 'prompt').and.returnValue({ then: function() { } }); | |
1467 | + scope.seleccionarObservaciones(); | |
1468 | + | |
1469 | + //assert | |
1470 | + expect(focaModalService.prompt).toHaveBeenCalled(); | |
1471 | + }); | |
1472 | + | |
1473 | + it('abrirModalCotizacion abre modal', function() { | |
1474 | + | |
1475 | + //arrange | |
1476 | + var scope = { | |
1477 | + $broadcast: function() { }, | |
1478 | + $watch: function() { } | |
1479 | + }; | |
1480 | + var uibModal = { | |
1481 | + open: function() {} | |
1482 | + }; | |
1483 | + | |
1484 | + $controller('remitoController', { | |
1485 | + $scope: scope, | |
1486 | + $uibModal: uibModal, | |
1487 | + $location: {}, | |
1488 | + $filter: {}, | |
1489 | + crearRemitoService: { | |
1490 | + getBotonera: function() {}, | |
1491 | + getCotizacionByIdMoneda: function() { | |
1492 | + return { | |
1493 | + then: function() {} | |
1494 | + }; | |
1495 | + }, | |
1496 | + getNumeroRemito: function() { | |
1497 | + return { | |
1498 | + then: function() {} | |
1499 | + }; | |
1500 | + } | |
1501 | + }, | |
1502 | + $timeout: timeout, | |
1503 | + focaModalService: {}, | |
1504 | + remitoBusinessService: { | |
1505 | + addArticulos: function() { } | |
1506 | + }, | |
1507 | + $rootScope: { | |
1508 | + $on: function() { } | |
1509 | + }, | |
1510 | + focaBotoneraLateralService: {}, | |
1511 | + $localStorage: {} | |
1512 | + }); | |
1513 | + | |
1514 | + //act | |
1515 | + spyOn(uibModal, 'open').and.returnValue({ result: { then: function() { } } }); | |
1516 | + scope.abrirModalCotizacion(); | |
1517 | + | |
1518 | + //assert | |
1519 | + expect(uibModal.open).toHaveBeenCalled(); | |
1520 | + }); | |
1521 | + }); | |
1522 | +}); |
spec/routeSpec.js
... | ... | @@ -0,0 +1,21 @@ |
1 | +describe('Rutas de módulo crear remito', function() { | |
2 | + | |
3 | + var route; | |
4 | + | |
5 | + beforeEach(function() { | |
6 | + | |
7 | + module('focaCrearRemito'); | |
8 | + inject(function($route) { | |
9 | + route = $route; | |
10 | + }); | |
11 | + }); | |
12 | + | |
13 | + it('la ruta /venta-remito/crear lleva a la ruta correcta', function() { | |
14 | + | |
15 | + //assert | |
16 | + expect(route.routes['/venta-remito/crear'].controller) | |
17 | + .toEqual('remitoController'); | |
18 | + expect(route.routes['/venta-remito/crear'].templateUrl) | |
19 | + .toEqual('src/views/remito.html'); | |
20 | + }); | |
21 | +}); |
spec/serviceSpec.js
... | ... | @@ -0,0 +1,392 @@ |
1 | +describe('Servicios modulo crear remito', function() { | |
2 | + | |
3 | + beforeEach(function(){ | |
4 | + module('focaCrearRemito'); | |
5 | + inject(module(function($provide) { | |
6 | + $provide.value('API_ENDPOINT', { | |
7 | + URL: 'localhost' | |
8 | + }); | |
9 | + })); | |
10 | + }); | |
11 | + | |
12 | + describe('servicio crearRemitoService', function() { | |
13 | + | |
14 | + var servicio, httpBackend; | |
15 | + | |
16 | + beforeEach(function() { | |
17 | + inject(function($httpBackend, _crearRemitoService_) { | |
18 | + servicio = _crearRemitoService_; | |
19 | + httpBackend = $httpBackend; | |
20 | + }); | |
21 | + }); | |
22 | + | |
23 | + it('existe el servicio crearRemitoService', function() { | |
24 | + | |
25 | + //assert | |
26 | + expect(typeof servicio).toEqual('object'); | |
27 | + }); | |
28 | + | |
29 | + it('función crearRemito llama a ruta correcta', function() { | |
30 | + | |
31 | + //arrange | |
32 | + var result; | |
33 | + var fakeParam = 1; | |
34 | + var respond = 'test'; | |
35 | + httpBackend.expectPOST('localhost/remito', fakeParam).respond(respond); | |
36 | + | |
37 | + //act | |
38 | + servicio.crearRemito(fakeParam).then(function(res) { | |
39 | + result = res.data; | |
40 | + }); | |
41 | + httpBackend.flush(); | |
42 | + | |
43 | + //assert | |
44 | + expect(result).toEqual(respond); | |
45 | + }); | |
46 | + | |
47 | + it('función getRemitoById llama a ruta correcta', function() { | |
48 | + | |
49 | + //arrange | |
50 | + var result; | |
51 | + var fakeParam = 1; | |
52 | + var respond = 'test'; | |
53 | + httpBackend.expectGET('localhost/remito/obtener/' + fakeParam).respond(respond); | |
54 | + | |
55 | + //act | |
56 | + servicio.getRemitoById(fakeParam).then(function(res) { | |
57 | + result = res.data; | |
58 | + }); | |
59 | + httpBackend.flush(); | |
60 | + | |
61 | + //assert | |
62 | + expect(result).toEqual(respond); | |
63 | + }); | |
64 | + | |
65 | + it('función obtenerRemito llama a ruta correcta', function() { | |
66 | + | |
67 | + //arrange | |
68 | + var result; | |
69 | + var fakeParam = 1; | |
70 | + var respond = 'test'; | |
71 | + httpBackend.expectGET('localhost/nota-pedido').respond(respond); | |
72 | + | |
73 | + //act | |
74 | + servicio.obtenerRemito(fakeParam).then(function(res) { | |
75 | + result = res.data; | |
76 | + }); | |
77 | + httpBackend.flush(); | |
78 | + | |
79 | + //assert | |
80 | + expect(result).toEqual(respond); | |
81 | + }); | |
82 | + | |
83 | + it('función setRemito setea correctamente', function() { | |
84 | + | |
85 | + //arrange | |
86 | + var fakeParam = 1; | |
87 | + | |
88 | + //act | |
89 | + servicio.setRemito(fakeParam); | |
90 | + | |
91 | + //assert | |
92 | + expect(servicio.remito).toEqual(fakeParam); | |
93 | + }); | |
94 | + | |
95 | + it('función clearRemito setea correctamente', function() { | |
96 | + | |
97 | + //act | |
98 | + servicio.clearRemito(); | |
99 | + | |
100 | + //assert | |
101 | + expect(servicio.remito).toEqual(undefined); | |
102 | + }); | |
103 | + | |
104 | + it('función getRemito trae correctamente', function() { | |
105 | + | |
106 | + //arrange | |
107 | + var fakeParam = 1; | |
108 | + | |
109 | + //act | |
110 | + servicio.remito = fakeParam; | |
111 | + var result = servicio.getRemito(); | |
112 | + | |
113 | + //assert | |
114 | + expect(result).toEqual(fakeParam); | |
115 | + }); | |
116 | + | |
117 | + it('función getArticulosByIdRemito llama a ruta correcta', function() { | |
118 | + | |
119 | + //arrange | |
120 | + var result; | |
121 | + var fakeParam = 1; | |
122 | + var respond = 'test'; | |
123 | + httpBackend.expectGET('localhost/articulos/nota-pedido/' + fakeParam).respond(respond); | |
124 | + | |
125 | + //act | |
126 | + servicio.getArticulosByIdRemito(fakeParam).then(function(res) { | |
127 | + result = res.data; | |
128 | + }); | |
129 | + httpBackend.flush(); | |
130 | + | |
131 | + //assert | |
132 | + expect(result).toEqual(respond); | |
133 | + }); | |
134 | + | |
135 | + it('función crearArticulosParaRemito llama a ruta correcta', function() { | |
136 | + | |
137 | + //arrange | |
138 | + var result; | |
139 | + var fakeParam = 1; | |
140 | + var respond = 'test'; | |
141 | + httpBackend.expectPOST('localhost/articulos/remito', {articuloRemito: fakeParam}) | |
142 | + .respond(respond); | |
143 | + | |
144 | + //act | |
145 | + servicio.crearArticulosParaRemito(fakeParam).then(function(res) { | |
146 | + result = res.data; | |
147 | + }); | |
148 | + httpBackend.flush(); | |
149 | + | |
150 | + //assert | |
151 | + expect(result).toEqual(respond); | |
152 | + }); | |
153 | + | |
154 | + it('función getDomiciliosByIdRemito llama a ruta correcta', function() { | |
155 | + | |
156 | + //arrange | |
157 | + var result; | |
158 | + var fakeParam = 1; | |
159 | + var respond = 'test'; | |
160 | + httpBackend.expectGET('localhost/nota-pedido/' + fakeParam + '/domicilios') | |
161 | + .respond(respond); | |
162 | + | |
163 | + //act | |
164 | + servicio.getDomiciliosByIdRemito(fakeParam).then(function(res) { | |
165 | + result = res.data; | |
166 | + }); | |
167 | + httpBackend.flush(); | |
168 | + | |
169 | + //assert | |
170 | + expect(result).toEqual(respond); | |
171 | + }); | |
172 | + | |
173 | + it('función getDomiciliosByIdCliente llama a ruta correcta', function() { | |
174 | + | |
175 | + //arrange | |
176 | + var result; | |
177 | + var fakeParam = 1; | |
178 | + var respond = 'test'; | |
179 | + httpBackend.expectGET('localhost/domicilio/tipo/2/cliente/' + fakeParam) | |
180 | + .respond(respond); | |
181 | + | |
182 | + //act | |
183 | + servicio.getDomiciliosByIdCliente(fakeParam).then(function(res) { | |
184 | + result = res.data; | |
185 | + }); | |
186 | + httpBackend.flush(); | |
187 | + | |
188 | + //assert | |
189 | + expect(result).toEqual(respond); | |
190 | + }); | |
191 | + | |
192 | + it('función getPrecioCondicion llama a ruta correcta', function() { | |
193 | + | |
194 | + //arrange | |
195 | + var result; | |
196 | + var respond = 'test'; | |
197 | + httpBackend.expectGET('localhost/precio-condicion').respond(respond); | |
198 | + | |
199 | + //act | |
200 | + servicio.getPrecioCondicion().then(function(res) { | |
201 | + result = res.data; | |
202 | + }); | |
203 | + httpBackend.flush(); | |
204 | + | |
205 | + //assert | |
206 | + expect(result).toEqual(respond); | |
207 | + }); | |
208 | + | |
209 | + it('función getPrecioCondicionById llama a ruta correcta', function() { | |
210 | + | |
211 | + //arrange | |
212 | + var result; | |
213 | + var fakeParam = 1; | |
214 | + var respond = 'test'; | |
215 | + httpBackend.expectGET('localhost/precio-condicion/' + fakeParam).respond(respond); | |
216 | + | |
217 | + //act | |
218 | + servicio.getPrecioCondicionById(fakeParam).then(function(res) { | |
219 | + result = res.data; | |
220 | + }); | |
221 | + httpBackend.flush(); | |
222 | + | |
223 | + //assert | |
224 | + expect(result).toEqual(respond); | |
225 | + }); | |
226 | + | |
227 | + it('función getPlazoPagoByPrecioCondicion llama a ruta correcta', function() { | |
228 | + | |
229 | + //arrange | |
230 | + var result; | |
231 | + var fakeParam = 1; | |
232 | + var respond = 'test'; | |
233 | + httpBackend.expectGET('localhost/plazo-pago/precio-condicion/' + fakeParam) | |
234 | + .respond(respond); | |
235 | + | |
236 | + //act | |
237 | + servicio.getPlazoPagoByPrecioCondicion(fakeParam).then(function(res) { | |
238 | + result = res.data; | |
239 | + }); | |
240 | + httpBackend.flush(); | |
241 | + | |
242 | + //assert | |
243 | + expect(result).toEqual(respond); | |
244 | + }); | |
245 | + | |
246 | + it('función crearFlete llama a ruta correcta', function() { | |
247 | + | |
248 | + //arrange | |
249 | + var result; | |
250 | + var fakeParam = 1; | |
251 | + var respond = 'test'; | |
252 | + httpBackend.expectPOST('localhost/flete', {flete: fakeParam}).respond(respond); | |
253 | + | |
254 | + //act | |
255 | + servicio.crearFlete(fakeParam).then(function(res) { | |
256 | + result = res.data; | |
257 | + }); | |
258 | + httpBackend.flush(); | |
259 | + | |
260 | + //assert | |
261 | + expect(result).toEqual(respond); | |
262 | + }); | |
263 | + | |
264 | + it('función crearPlazosParaRemito llama a ruta correcta', function() { | |
265 | + | |
266 | + //arrange | |
267 | + var result; | |
268 | + var fakeParam = 1; | |
269 | + var respond = 'test'; | |
270 | + httpBackend.expectPOST('localhost/plazo-pago/remito', fakeParam).respond(respond); | |
271 | + | |
272 | + //act | |
273 | + servicio.crearPlazosParaRemito(fakeParam).then(function(res) { | |
274 | + result = res.data; | |
275 | + }); | |
276 | + httpBackend.flush(); | |
277 | + | |
278 | + //assert | |
279 | + expect(result).toEqual(respond); | |
280 | + }); | |
281 | + | |
282 | + it('función getCotizacionByIdMoneda llama a ruta correcta', function() { | |
283 | + | |
284 | + //arrange | |
285 | + var result; | |
286 | + var fakeParam = 1; | |
287 | + var respond = 'test'; | |
288 | + httpBackend.expectGET('localhost/moneda/' + fakeParam).respond(respond); | |
289 | + | |
290 | + //act | |
291 | + servicio.getCotizacionByIdMoneda(fakeParam).then(function(res) { | |
292 | + result = res.data; | |
293 | + }); | |
294 | + httpBackend.flush(); | |
295 | + | |
296 | + //assert | |
297 | + expect(result).toEqual(respond); | |
298 | + }); | |
299 | + | |
300 | + it('función crearEstadoParaRemito llama a ruta correcta', function() { | |
301 | + | |
302 | + //arrange | |
303 | + var result; | |
304 | + var fakeParam = 1; | |
305 | + var respond = 'test'; | |
306 | + httpBackend.expectPOST('localhost/estado', { estado: fakeParam }).respond(respond); | |
307 | + | |
308 | + //act | |
309 | + servicio.crearEstadoParaRemito(fakeParam).then(function(res) { | |
310 | + result = res.data; | |
311 | + }); | |
312 | + httpBackend.flush(); | |
313 | + | |
314 | + //assert | |
315 | + expect(result).toEqual(respond); | |
316 | + }); | |
317 | + | |
318 | + it('función getNumeroRemito llama a ruta correcta', function() { | |
319 | + | |
320 | + //arrange | |
321 | + var result; | |
322 | + var respond = 'test'; | |
323 | + httpBackend.expectGET('localhost/remito/numero-siguiente').respond(respond); | |
324 | + | |
325 | + //act | |
326 | + servicio.getNumeroRemito().then(function(res) { | |
327 | + result = res.data; | |
328 | + }); | |
329 | + httpBackend.flush(); | |
330 | + | |
331 | + //assert | |
332 | + expect(result).toEqual(respond); | |
333 | + }); | |
334 | + | |
335 | + it('función imprimirRemitoByIdRemito llama a ruta correcta', function() { | |
336 | + | |
337 | + //arrange | |
338 | + var result; | |
339 | + var fakeParam = 1; | |
340 | + var respond = new Blob(['test']); | |
341 | + httpBackend.expectGET('localhost/remito/comprobante/' + fakeParam) | |
342 | + .respond(respond); | |
343 | + | |
344 | + //act | |
345 | + servicio.imprimirRemitoByIdRemito(fakeParam).then(function(res) { | |
346 | + result = res.data; | |
347 | + }); | |
348 | + httpBackend.flush(); | |
349 | + | |
350 | + //assert | |
351 | + expect(result).toEqual(respond); | |
352 | + }); | |
353 | + | |
354 | + it('función getPuntosDescargaByClienDom llama a ruta correcta', function() { | |
355 | + | |
356 | + //arrange | |
357 | + var result; | |
358 | + var fakeParam = 1; | |
359 | + var respond = 'test'; | |
360 | + httpBackend.expectGET('localhost/punto-descarga/' + fakeParam + '/' + fakeParam) | |
361 | + .respond(respond); | |
362 | + | |
363 | + //act | |
364 | + servicio.getPuntosDescargaByClienDom(fakeParam, fakeParam).then(function(res) { | |
365 | + result = res.data; | |
366 | + }); | |
367 | + httpBackend.flush(); | |
368 | + | |
369 | + //assert | |
370 | + expect(result).toEqual(respond); | |
371 | + }); | |
372 | + | |
373 | + it('función enviarCorreo llama a ruta correcta', function() { | |
374 | + | |
375 | + //arrange | |
376 | + var result; | |
377 | + var fakeParam = 1; | |
378 | + var respond = 'test'; | |
379 | + httpBackend.expectPOST('localhost/remito/mail', fakeParam) | |
380 | + .respond(respond); | |
381 | + | |
382 | + //act | |
383 | + servicio.enviarCorreo(fakeParam).then(function(res) { | |
384 | + result = res.data; | |
385 | + }); | |
386 | + httpBackend.flush(); | |
387 | + | |
388 | + //assert | |
389 | + expect(result).toEqual(respond); | |
390 | + }); | |
391 | + }); | |
392 | +}); |
src/js/app.js
src/js/controller.js
... | ... | @@ -83,7 +83,7 @@ angular.module('focaCrearRemito') .controller('remitoController', |
83 | 83 | $scope.inicial = angular.copy($scope.remito); |
84 | 84 | } |
85 | 85 | |
86 | - $scope.$watch('remito', function(newValue, oldValue) { | |
86 | + $scope.$watch('remito', function(newValue) { | |
87 | 87 | focaBotoneraLateralService.setPausarData({ |
88 | 88 | label: 'remito', |
89 | 89 | val: newValue |
... | ... | @@ -159,20 +159,27 @@ angular.module('focaCrearRemito') .controller('remitoController', |
159 | 159 | } |
160 | 160 | ]; |
161 | 161 | |
162 | + if (notaPedido.observaciones) { | |
163 | + cabeceras.push({ | |
164 | + label: 'Observaciones:', | |
165 | + valor: notaPedido.observaciones | |
166 | + }); | |
167 | + } | |
168 | + | |
162 | 169 | function valorPrecioCondicion() { |
163 | - if(notaPedido.idPrecioCondicion > 0) { | |
170 | + if (notaPedido.idPrecioCondicion > 0) { | |
164 | 171 | return notaPedido.precioCondicion.nombre; |
165 | - }else { | |
172 | + } else { | |
166 | 173 | return 'Ingreso Manual'; |
167 | 174 | } |
168 | 175 | } |
169 | 176 | |
170 | - if(notaPedido.flete === 1) { | |
177 | + if (notaPedido.flete === 1) { | |
171 | 178 | var cabeceraBomba = { |
172 | 179 | label: 'Bomba:', |
173 | 180 | valor: notaPedido.bomba === 1 ? 'Si' : 'No' |
174 | 181 | }; |
175 | - if(notaPedido.kilometros) { | |
182 | + if (notaPedido.kilometros) { | |
176 | 183 | var cabeceraKilometros = { |
177 | 184 | label: 'Kilometros:', |
178 | 185 | valor: notaPedido.kilometros |
... | ... | @@ -239,7 +246,9 @@ angular.module('focaCrearRemito') .controller('remitoController', |
239 | 246 | } else if (!$scope.remito.proveedor) { |
240 | 247 | focaModalService.alert('Ingrese Proveedor'); |
241 | 248 | return; |
242 | - } else if (!$scope.remito.cotizacion.moneda.id && !$scope.remito.cotizacion.moneda.ID) { | |
249 | + } else if (!$scope.remito.cotizacion.moneda.id && | |
250 | + !$scope.remito.cotizacion.moneda.ID) | |
251 | + { | |
243 | 252 | focaModalService.alert('Ingrese Moneda'); |
244 | 253 | return; |
245 | 254 | } else if (!$scope.remito.cotizacion.ID) { |
... | ... | @@ -442,7 +451,12 @@ angular.module('focaCrearRemito') .controller('remitoController', |
442 | 451 | } |
443 | 452 | }; |
444 | 453 | |
445 | - $scope.seleccionarVendedor = function() { | |
454 | + $scope.seleccionarVendedor = function(callback, ocultarVendedor) { | |
455 | + if (ocultarVendedor) { | |
456 | + callback(); | |
457 | + return; | |
458 | + } | |
459 | + | |
446 | 460 | if(varlidarRemitoFacturado()) { |
447 | 461 | var parametrosModal = { |
448 | 462 | titulo: 'Búsqueda vendedores', |
... | ... | @@ -472,6 +486,8 @@ angular.module('focaCrearRemito') .controller('remitoController', |
472 | 486 | }); |
473 | 487 | $scope.remito.idVendedor = vendedor.id; |
474 | 488 | $scope.remito.vendedor = vendedor; |
489 | + deleteCliente(); | |
490 | + callback(); | |
475 | 491 | }, function() { |
476 | 492 | |
477 | 493 | } |
... | ... | @@ -479,7 +495,35 @@ angular.module('focaCrearRemito') .controller('remitoController', |
479 | 495 | } |
480 | 496 | }; |
481 | 497 | |
482 | - $scope.seleccionarProveedor = function() { | |
498 | + $scope.seleccionarCliente = function(ocultarVendedor) { | |
499 | + | |
500 | + $scope.seleccionarVendedor(function() { | |
501 | + if (varlidarRemitoFacturado()) { | |
502 | + var modalInstance = $uibModal.open( | |
503 | + { | |
504 | + ariaLabelledBy: 'Busqueda de Cliente', | |
505 | + templateUrl: 'foca-busqueda-cliente-modal.html', | |
506 | + controller: 'focaBusquedaClienteModalController', | |
507 | + resolve: { | |
508 | + vendedor: function() { return $scope.remito.vendedor; }, | |
509 | + cobrador: function() { return null; } | |
510 | + }, | |
511 | + size: 'lg' | |
512 | + } | |
513 | + ); | |
514 | + modalInstance.result.then( | |
515 | + function(cliente) { | |
516 | + $scope.abrirModalDomicilios(cliente); | |
517 | + $scope.cliente = cliente; | |
518 | + }, function() { | |
519 | + $scope.seleccionarCliente(); | |
520 | + } | |
521 | + ); | |
522 | + } | |
523 | + }, ocultarVendedor); | |
524 | + }; | |
525 | + | |
526 | + $scope.seleccionarProveedor = function(callback) { | |
483 | 527 | if(varlidarRemitoFacturado()) { |
484 | 528 | var parametrosModal = { |
485 | 529 | titulo: 'Búsqueda de Proveedor', |
... | ... | @@ -515,38 +559,8 @@ angular.module('focaCrearRemito') .controller('remitoController', |
515 | 559 | valor: $filter('rellenarDigitos')(proveedor.COD, 5) + ' - ' + |
516 | 560 | proveedor.NOM |
517 | 561 | }); |
518 | - }, function() { | |
519 | - | |
520 | - } | |
521 | - ); | |
522 | - } | |
523 | - }; | |
524 | - | |
525 | - $scope.seleccionarCliente = function() { | |
526 | - if (!$scope.remito.vendedor) { | |
527 | - focaModalService.alert('Primero seleccione un vendedor'); | |
528 | - return; | |
529 | - } | |
530 | - | |
531 | - if (varlidarRemitoFacturado()) { | |
532 | - var modalInstance = $uibModal.open( | |
533 | - { | |
534 | - ariaLabelledBy: 'Busqueda de Cliente', | |
535 | - templateUrl: 'foca-busqueda-cliente-modal.html', | |
536 | - controller: 'focaBusquedaClienteModalController', | |
537 | - resolve: { | |
538 | - vendedor: function() { return $scope.remito.vendedor; } | |
539 | - }, | |
540 | - size: 'lg' | |
541 | - } | |
542 | - ); | |
543 | - modalInstance.result.then( | |
544 | - function(cliente) { | |
545 | - $scope.abrirModalDomicilios(cliente); | |
546 | - $scope.cliente = cliente; | |
547 | - }, function() { | |
548 | - | |
549 | - } | |
562 | + callback(); | |
563 | + }, function() { } | |
550 | 564 | ); |
551 | 565 | } |
552 | 566 | }; |
... | ... | @@ -571,7 +585,8 @@ angular.module('focaCrearRemito') .controller('remitoController', |
571 | 585 | COD: cliente.cod, |
572 | 586 | CUIT: cliente.cuit, |
573 | 587 | NOM: cliente.nom, |
574 | - MAIL: cliente.mail | |
588 | + MAIL: cliente.mail, | |
589 | + MOD: cliente.mod | |
575 | 590 | }; |
576 | 591 | |
577 | 592 | |
... | ... | @@ -600,23 +615,12 @@ angular.module('focaCrearRemito') .controller('remitoController', |
600 | 615 | }); |
601 | 616 | } |
602 | 617 | }, function() { |
603 | - $scope.seleccionarCliente(); | |
618 | + $scope.seleccionarCliente(true); | |
604 | 619 | return; |
605 | 620 | } |
606 | 621 | ); |
607 | 622 | }; |
608 | 623 | |
609 | - $scope.mostrarFichaCliente = function() { | |
610 | - $uibModal.open( | |
611 | - { | |
612 | - ariaLabelledBy: 'Datos del Cliente', | |
613 | - templateUrl: 'foca-crear-remito-ficha-cliente.html', | |
614 | - controller: 'focaCrearRemitoFichaClienteController', | |
615 | - size: 'lg' | |
616 | - } | |
617 | - ); | |
618 | - }; | |
619 | - | |
620 | 624 | $scope.getTotal = function() { |
621 | 625 | var total = 0; |
622 | 626 | var arrayTempArticulos = $scope.remito.articulosRemito; |
... | ... | @@ -633,13 +637,22 @@ angular.module('focaCrearRemito') .controller('remitoController', |
633 | 637 | }; |
634 | 638 | |
635 | 639 | $scope.seleccionarPreciosYCondiciones = function() { |
640 | + if (!$scope.remito.cliente.COD) { | |
641 | + focaModalService.alert('Primero seleccione un cliente'); | |
642 | + return; | |
643 | + } | |
636 | 644 | if(varlidarRemitoFacturado()) { |
637 | 645 | var modalInstance = $uibModal.open( |
638 | 646 | { |
639 | 647 | ariaLabelledBy: 'Busqueda de Precio Condición', |
640 | 648 | templateUrl: 'modal-precio-condicion.html', |
641 | 649 | controller: 'focaModalPrecioCondicionController', |
642 | - size: 'lg' | |
650 | + size: 'lg', | |
651 | + resolve: { | |
652 | + idListaPrecio: function() { | |
653 | + return $scope.remito.cliente.MOD || null; | |
654 | + } | |
655 | + } | |
643 | 656 | } |
644 | 657 | ); |
645 | 658 | modalInstance.result.then( |
... | ... | @@ -679,61 +692,65 @@ angular.module('focaCrearRemito') .controller('remitoController', |
679 | 692 | } |
680 | 693 | }; |
681 | 694 | |
682 | - $scope.seleccionarFlete = function() { | |
683 | - if(varlidarRemitoFacturado()) { | |
684 | - var modalInstance = $uibModal.open( | |
685 | - { | |
686 | - ariaLabelledBy: 'Busqueda de Flete', | |
687 | - templateUrl: 'modal-flete.html', | |
688 | - controller: 'focaModalFleteController', | |
689 | - size: 'lg', | |
690 | - resolve: { | |
691 | - parametrosFlete: | |
692 | - function() { | |
693 | - return { | |
694 | - flete: $scope.remito.flete ? '1' : | |
695 | - ($scope.remito.fob ? 'FOB' : | |
696 | - ($scope.remito.flete === undefined ? null : '0')), | |
697 | - bomba: $scope.remito.bomba ? '1' : | |
698 | - ($scope.remito.bomba === undefined ? null : '0'), | |
699 | - kilometros: $scope.remito.kilometros | |
700 | - }; | |
701 | - } | |
695 | + $scope.seleccionarTransportista = function() { | |
696 | + $scope.seleccionarProveedor(function() { | |
697 | + if (varlidarRemitoFacturado()) { | |
698 | + var modalInstance = $uibModal.open( | |
699 | + { | |
700 | + ariaLabelledBy: 'Busqueda de Flete', | |
701 | + templateUrl: 'modal-flete.html', | |
702 | + controller: 'focaModalFleteController', | |
703 | + size: 'lg', | |
704 | + resolve: { | |
705 | + parametrosFlete: | |
706 | + function() { | |
707 | + return { | |
708 | + flete: $scope.remito.flete ? '1' : | |
709 | + ($scope.remito.fob ? 'FOB' : | |
710 | + ($scope.remito.flete === undefined ? | |
711 | + null : '0')), | |
712 | + bomba: $scope.remito.bomba ? '1' : | |
713 | + ($scope.remito.bomba === undefined ? | |
714 | + null : '0'), | |
715 | + kilometros: $scope.remito.kilometros | |
716 | + }; | |
717 | + } | |
718 | + } | |
702 | 719 | } |
703 | - } | |
704 | - ); | |
705 | - modalInstance.result.then( | |
706 | - function(datos) { | |
707 | - $scope.remito.flete = datos.flete; | |
708 | - $scope.remito.fob = datos.FOB; | |
709 | - $scope.remito.bomba = datos.bomba; | |
710 | - $scope.remito.kilometros = datos.kilometros; | |
711 | - | |
712 | - $scope.$broadcast('addCabecera',{ | |
713 | - label: 'Flete:', | |
714 | - valor: datos.flete ? 'Si' : ($scope.remito.fob ? 'FOB' : 'No') | |
715 | - }); | |
716 | - if(datos.flete) { | |
720 | + ); | |
721 | + modalInstance.result.then( | |
722 | + function(datos) { | |
723 | + $scope.remito.flete = datos.flete; | |
724 | + $scope.remito.fob = datos.FOB; | |
725 | + $scope.remito.bomba = datos.bomba; | |
726 | + $scope.remito.kilometros = datos.kilometros; | |
727 | + | |
717 | 728 | $scope.$broadcast('addCabecera',{ |
718 | - label: 'Bomba:', | |
719 | - valor: datos.bomba ? 'Si' : 'No' | |
720 | - }); | |
721 | - $scope.$broadcast('addCabecera',{ | |
722 | - label: 'Kilometros:', | |
723 | - valor: datos.kilometros | |
729 | + label: 'Flete:', | |
730 | + valor: datos.flete ? 'Si' : ($scope.remito.fob ? 'FOB' : 'No') | |
724 | 731 | }); |
725 | - }else { | |
726 | - $scope.$broadcast('removeCabecera', 'Bomba:'); | |
727 | - $scope.$broadcast('removeCabecera', 'Kilometros:'); | |
728 | - $scope.remito.fob = false; | |
729 | - $scope.remito.bomba = false; | |
730 | - $scope.remito.kilometros = null; | |
732 | + if (datos.flete) { | |
733 | + $scope.$broadcast('addCabecera',{ | |
734 | + label: 'Bomba:', | |
735 | + valor: datos.bomba ? 'Si' : 'No' | |
736 | + }); | |
737 | + $scope.$broadcast('addCabecera',{ | |
738 | + label: 'Kilometros:', | |
739 | + valor: datos.kilometros | |
740 | + }); | |
741 | + } else { | |
742 | + $scope.$broadcast('removeCabecera', 'Bomba:'); | |
743 | + $scope.$broadcast('removeCabecera', 'Kilometros:'); | |
744 | + $scope.remito.fob = false; | |
745 | + $scope.remito.bomba = false; | |
746 | + $scope.remito.kilometros = null; | |
747 | + } | |
748 | + }, function() { | |
749 | + $scope.seleccionarTransportista(); | |
731 | 750 | } |
732 | - }, function() { | |
733 | - | |
734 | - } | |
735 | - ); | |
736 | - } | |
751 | + ); | |
752 | + } | |
753 | + }); | |
737 | 754 | }; |
738 | 755 | |
739 | 756 | $scope.seleccionarMoneda = function() { |
... | ... | @@ -765,7 +782,12 @@ angular.module('focaCrearRemito') .controller('remitoController', |
765 | 782 | |
766 | 783 | $scope.seleccionarObservaciones = function() { |
767 | 784 | focaModalService |
768 | - .prompt('Observaciones', $scope.remito.observaciones, true, true) | |
785 | + .prompt({ | |
786 | + titulo: 'Observaciones', | |
787 | + value: $scope.remito.observaciones, | |
788 | + textarea: true, | |
789 | + readonly: true | |
790 | + }) | |
769 | 791 | .then(function(observaciones) { |
770 | 792 | $scope.remito.observaciones = observaciones; |
771 | 793 | }); |
... | ... | @@ -836,14 +858,15 @@ angular.module('focaCrearRemito') .controller('remitoController', |
836 | 858 | }; |
837 | 859 | |
838 | 860 | $scope.editarArticulo = function(key, articulo) { |
839 | - if(key === 13) { | |
840 | - if(articulo.cantidad === null || articulo.cantidad === 0 || | |
841 | - articulo.cantidad === undefined) { | |
842 | - focaModalService.alert('El valor debe ser al menos 1'); | |
861 | + if (key === 13) { | |
862 | + if (!articulo.cantidad || !articulo.precio) { | |
863 | + focaModalService.alert('Los valores deben ser al menos 1'); | |
864 | + return; | |
865 | + } else if (articulo.cantidad < 0 || articulo.precio < 0) { | |
866 | + focaModalService.alert('Los valores no pueden ser negativos'); | |
843 | 867 | return; |
844 | 868 | } |
845 | - articulo.editCantidad = false; | |
846 | - articulo.editPrecio = false; | |
869 | + articulo.editCantidad = articulo.editPrecio = false; | |
847 | 870 | } |
848 | 871 | }; |
849 | 872 | |
... | ... | @@ -855,28 +878,6 @@ angular.module('focaCrearRemito') .controller('remitoController', |
855 | 878 | } |
856 | 879 | }; |
857 | 880 | |
858 | - $scope.limpiarFlete = function() { | |
859 | - $scope.remito.fleteNombre = ''; | |
860 | - $scope.remito.chofer = ''; | |
861 | - $scope.remito.vehiculo = ''; | |
862 | - $scope.remito.kilometros = ''; | |
863 | - $scope.remito.costoUnitarioKmFlete = ''; | |
864 | - $scope.choferes = ''; | |
865 | - $scope.vehiculos = ''; | |
866 | - }; | |
867 | - | |
868 | - $scope.limpiarPantalla = function() { | |
869 | - $scope.limpiarFlete(); | |
870 | - $scope.remito.flete = '0'; | |
871 | - $scope.remito.bomba = '0'; | |
872 | - $scope.remito.precioCondicion = ''; | |
873 | - $scope.remito.articulosRemito = []; | |
874 | - $scope.remito.vendedor.nombre = ''; | |
875 | - $scope.remito.cliente = {nombre: ''}; | |
876 | - $scope.remito.domicilio = {dom: ''}; | |
877 | - $scope.domiciliosCliente = []; | |
878 | - }; | |
879 | - | |
880 | 881 | $scope.resetFilter = function() { |
881 | 882 | $scope.articuloACargar = {}; |
882 | 883 | $scope.cargando = true; |
... | ... | @@ -1056,10 +1057,19 @@ angular.module('focaCrearRemito') .controller('remitoController', |
1056 | 1057 | function getLSRemito() { |
1057 | 1058 | var remito = JSON.parse($localStorage.remito || null); |
1058 | 1059 | if (remito) { |
1059 | - console.log('remito', remito); | |
1060 | 1060 | setearRemito(remito); |
1061 | 1061 | delete $localStorage.remito; |
1062 | 1062 | } |
1063 | 1063 | } |
1064 | + | |
1065 | + function deleteCliente() { | |
1066 | + delete $scope.remito.domicilioStamp; | |
1067 | + delete $scope.remito.puntosDescarga; | |
1068 | + $scope.remito.domicilio = {dom: ''}; | |
1069 | + $scope.remito.cliente = {}; | |
1070 | + $scope.$broadcast('removeCabecera', 'Cliente:'); | |
1071 | + $scope.$broadcast('removeCabecera', 'Domicilio:'); | |
1072 | + $scope.$broadcast('removeCabecera', 'Puntos de descarga:'); | |
1073 | + } | |
1064 | 1074 | } |
1065 | 1075 | ]); |
src/js/service.js
... | ... | @@ -80,15 +80,11 @@ angular.module('focaCrearRemito') |
80 | 80 | image: 'notaDePedido.png' |
81 | 81 | }, |
82 | 82 | { |
83 | - label: 'Vendedor', | |
84 | - image: 'vendedor.png' | |
85 | - }, | |
86 | - { | |
87 | 83 | label: 'Cliente', |
88 | 84 | image: 'cliente.png' |
89 | 85 | }, |
90 | 86 | { |
91 | - label: 'Proveedor', | |
87 | + label: 'Transportista', | |
92 | 88 | image: 'proveedor.png' |
93 | 89 | }, |
94 | 90 | { |
... | ... | @@ -100,16 +96,12 @@ angular.module('focaCrearRemito') |
100 | 96 | image: 'precios-condiciones.png' |
101 | 97 | }, |
102 | 98 | { |
103 | - label: 'Flete', | |
104 | - image: 'flete.png' | |
105 | - }, | |
106 | - { | |
107 | 99 | label: 'Productos', |
108 | 100 | image: 'productos.png' |
109 | 101 | }, |
110 | 102 | { |
111 | 103 | label: 'Observaciones', |
112 | - image: 'productos.png', | |
104 | + image: 'botonObservaciones.png', | |
113 | 105 | disable: true |
114 | 106 | } |
115 | 107 | ]; |
src/views/remito.html
... | ... | @@ -94,7 +94,7 @@ |
94 | 94 | > |
95 | 95 | <i |
96 | 96 | class="selectable" |
97 | - ng-click="idLista == -1 && cambioEdit(articulo, 'precio')" | |
97 | + ng-click="cambioEdit(articulo, 'precio')" | |
98 | 98 | ng-hide="articulo.editPrecio" |
99 | 99 | ng-bind="articulo.precio | number: 4"> |
100 | 100 | </i> |
... | ... | @@ -110,6 +110,13 @@ |
110 | 110 | > |
111 | 111 | <i class="fa fa-trash"></i> |
112 | 112 | </button> |
113 | + <button | |
114 | + class="btn btn-outline-light" | |
115 | + ng-click="editarArticulo(13, articulo)" | |
116 | + ng-show="articulo.editCantidad || articulo.editPrecio" | |
117 | + > | |
118 | + <i class="fa fa-save"></i> | |
119 | + </button> | |
113 | 120 | </td> |
114 | 121 | </tr> |
115 | 122 | </tbody> |
... | ... | @@ -148,9 +155,9 @@ |
148 | 155 | <td class="col text-right"> |
149 | 156 | <input |
150 | 157 | class="form-control" |
151 | - ng-value="articuloACargar.precio | number: 4" | |
158 | + ng-model="articuloACargar.precio" | |
152 | 159 | ng-show="idLista != -1" |
153 | - readonly | |
160 | + ng-keypress="agregarATabla($event.keyCode)" | |
154 | 161 | > |
155 | 162 | <input |
156 | 163 | class="form-control" |
test.html
... | ... | @@ -0,0 +1,22 @@ |
1 | +<html> | |
2 | + <head> | |
3 | + <link rel="stylesheet" type="text/css" href="node_modules/jasmine-core/lib/jasmine-core/jasmine.css"> | |
4 | + <meta charset="UTF-8" /> | |
5 | + </head> | |
6 | + <body> | |
7 | + <script type="text/javascript" src="node_modules/jasmine-core/lib/jasmine-core/jasmine.js"></script> | |
8 | + <script type="text/javascript" src="node_modules/jasmine-core/lib/jasmine-core/jasmine-html.js"></script> | |
9 | + <script type="text/javascript" src="node_modules/jasmine-core/lib/jasmine-core/boot.js"></script> | |
10 | + <script type="text/javascript" src="node_modules/angular/angular.min.js"></script> | |
11 | + <script type="text/javascript" src="node_modules/angular-route/angular-route.min.js"></script> | |
12 | + <script type="text/javascript" src="node_modules/angular-mocks/angular-mocks.js"></script> | |
13 | + <script type="text/javascript" src="src/js/app.js"></script> | |
14 | + <script type="text/javascript" src="src/js/controller.js"></script> | |
15 | + <script type="text/javascript" src="src/js/service.js"></script> | |
16 | + <script type="text/javascript" src="src/js/route.js"></script> | |
17 | + | |
18 | + <script type="text/javascript" src="spec/controllerSpec.js"></script> | |
19 | + <script type="text/javascript" src="spec/serviceSpec.js"></script> | |
20 | + <script type="text/javascript" src="spec/routeSpec.js"></script> | |
21 | + </body> | |
22 | +</html> |