Commit 8aac173c17f19c7cbb829cc985984a184bf2f50b
1 parent
fd679a711e
Exists in
master
refactor seguimiento
Showing
2 changed files
with
161 additions
and
111 deletions
Show diff stats
src/js/controller.js
1 | angular.module('focaAdminSeguimiento') .controller('focaAdminSeguimientoController', [ | 1 | angular.module('focaAdminSeguimiento') .controller('focaAdminSeguimientoController', [ |
2 | '$scope', '$timeout', 'focaAdminSeguimientoService', | 2 | '$scope', '$timeout', 'focaAdminSeguimientoService', |
3 | 'focaBotoneraLateralService','$location', '$routeParams', | 3 | 'focaBotoneraLateralService','$location', '$routeParams', |
4 | function($scope, $timeout, focaAdminSeguimientoService, | 4 | function($scope, $timeout, focaAdminSeguimientoService, |
5 | focaBotoneraLateralService, $location, $routeParams) { | 5 | focaBotoneraLateralService, $location, $routeParams) { |
6 | 6 | ||
7 | $scope.actividad = ''; | 7 | $scope.actividad = ''; |
8 | $scope.titulo = ''; | 8 | $scope.titulo = ''; |
9 | var cabecera = ''; | 9 | var cabecera = ''; |
10 | 10 | ||
11 | $scope.now = new Date(); | 11 | $scope.now = new Date(); |
12 | 12 | ||
13 | if ($routeParams.parametro === 'nota-pedido') { | 13 | if ($routeParams.parametro === 'nota-pedido') { |
14 | $scope.actividad = 'Nota de pedido'; | 14 | $scope.actividad = 'Nota de pedido'; |
15 | $scope.titulo = 'Seguimiento de nota de pedido'; | 15 | $scope.titulo = 'Seguimiento de nota de pedido'; |
16 | cabecera = 'Vendedor:'; | 16 | cabecera = 'Vendedor:'; |
17 | } | 17 | } |
18 | 18 | ||
19 | if ($routeParams.parametro === 'hoja-ruta') { | 19 | if ($routeParams.parametro === 'hoja-ruta') { |
20 | $scope.actividad = 'Entrega de producto'; | 20 | $scope.actividad = 'Entrega de producto'; |
21 | $scope.titulo = 'Seguimiento de hoja de ruta'; | 21 | $scope.titulo = 'Seguimiento de hoja de ruta'; |
22 | cabecera = 'Vehiculo:'; | 22 | cabecera = 'Vehiculo:'; |
23 | } | 23 | } |
24 | 24 | ||
25 | if ($routeParams.parametro === 'cobranza') { | 25 | if ($routeParams.parametro === 'cobranza') { |
26 | $scope.actividad = 'Cobranza'; | 26 | $scope.actividad = 'Cobranza'; |
27 | $scope.titulo = 'Seguimiento de cobranza'; | 27 | $scope.titulo = 'Seguimiento de cobranza'; |
28 | cabecera = 'Cobrador:'; | 28 | cabecera = 'Cobrador:'; |
29 | } | 29 | } |
30 | 30 | ||
31 | $scope.idUsuario = 0; | 31 | $scope.idUsuario = 0; |
32 | $scope.marcadores = []; | 32 | $scope.marcadores = []; |
33 | getSeguimiento(); | 33 | getSeguimiento(); |
34 | 34 | ||
35 | $timeout(function() { | 35 | $timeout(function() { |
36 | $scope.$broadcast('addCabecera',{ | 36 | $scope.$broadcast('addCabecera',{ |
37 | label: 'General', | 37 | label: 'General', |
38 | valor: '' | 38 | valor: '' |
39 | }); | 39 | }); |
40 | }) | 40 | }); |
41 | 41 | ||
42 | //SETEO BOTONERA LATERAL | 42 | //SETEO BOTONERA LATERAL |
43 | focaBotoneraLateralService.showSalir(true); | 43 | focaBotoneraLateralService.showSalir(true); |
44 | focaBotoneraLateralService.showPausar(false); | 44 | focaBotoneraLateralService.showPausar(false); |
45 | focaBotoneraLateralService.showGuardar(false); | 45 | focaBotoneraLateralService.showGuardar(false); |
46 | 46 | ||
47 | $scope.general = function() { | 47 | $scope.general = function() { |
48 | $scope.idUsuario = 0; | 48 | $scope.idUsuario = 0; |
49 | getSeguimiento(); | 49 | getSeguimiento(); |
50 | $scope.$broadcast('removeCabecera', cabecera); | 50 | $scope.$broadcast('removeCabecera', cabecera); |
51 | $scope.$broadcast('addCabecera',{ | 51 | $scope.$broadcast('addCabecera',{ |
52 | label: 'General', | 52 | label: 'General', |
53 | valor: '' | 53 | valor: '' |
54 | }); | 54 | }); |
55 | }; | 55 | }; |
56 | 56 | ||
57 | $scope.individual = function() { | 57 | $scope.individual = function() { |
58 | $scope.idUsuario = -1; | 58 | $scope.idUsuario = -1; |
59 | }; | 59 | }; |
60 | 60 | ||
61 | $scope.salir = function() { | 61 | $scope.salir = function() { |
62 | $location.path('/'); | 62 | $location.path('/'); |
63 | }; | 63 | }; |
64 | 64 | ||
65 | $scope.search = function(key) { | 65 | $scope.search = function(key) { |
66 | if (key === 13) { | 66 | if (key === 13) { |
67 | $scope.idUsuario = $scope.idUsuarioInput; | 67 | $scope.idUsuario = $scope.idUsuarioInput; |
68 | getSeguimiento(); | 68 | getSeguimiento(); |
69 | $scope.$broadcast('removeCabecera', 'General'); | 69 | $scope.$broadcast('removeCabecera', 'General'); |
70 | $scope.$broadcast('addCabecera', { | 70 | $scope.$broadcast('addCabecera', { |
71 | label: cabecera, | 71 | label: cabecera, |
72 | valor: $scope.idUsuarioInput | 72 | valor: $scope.idUsuarioInput |
73 | }); | 73 | }); |
74 | } | 74 | } |
75 | }; | 75 | }; |
76 | 76 | ||
77 | $scope.fecha = function() { | 77 | $scope.fecha = function() { |
78 | getSeguimiento(); | 78 | getSeguimiento(); |
79 | }; | 79 | }; |
80 | 80 | ||
81 | function getSeguimiento() { | 81 | function getSeguimiento() { |
82 | var now = $scope.now; | 82 | var now = $scope.now; |
83 | var desde = new Date(new Date(now.setHours(0)).setMinutes(0)); | 83 | var desde = new Date(new Date(now.setHours(0)).setMinutes(0)); |
84 | desde = desde.setDate(desde.getDate() - 1); | 84 | desde = desde.setDate(desde.getDate() - 1); |
85 | desde = new Date(desde); | 85 | desde = new Date(desde); |
86 | var datos = { | 86 | var datos = { |
87 | actividad: $scope.actividad, | 87 | actividad: $scope.actividad, |
88 | idUsuario: $scope.idUsuario, | 88 | idUsuario: $scope.idUsuario, |
89 | fechaDesde: desde, | 89 | fechaDesde: desde, |
90 | fechaHasta: new Date(new Date(now.setHours(23)).setMinutes(59)) | 90 | fechaHasta: new Date(new Date(now.setHours(23)).setMinutes(59)) |
91 | }; | 91 | }; |
92 | 92 | ||
93 | $scope.datosBuscados = { | 93 | $scope.datosBuscados = { |
94 | actividad: $scope.actividad, | 94 | actividad: $scope.actividad, |
95 | individual: $scope.idUsuario !== 0 ? true : false | 95 | individual: $scope.idUsuario !== 0 ? true : false |
96 | }; | 96 | }; |
97 | 97 | ||
98 | focaAdminSeguimientoService.obtenerActividad(datos).then(function(datos) { | 98 | focaAdminSeguimientoService.obtenerActividad(datos).then(function(datos) { |
99 | 99 | ||
100 | $scope.marcadores = datos.data; | 100 | $scope.marcadores = datos.data; |
101 | }); | 101 | }); |
102 | } | 102 | } |
103 | } | 103 | } |
104 | ]); | 104 | ]); |
105 | 105 |
src/js/osm-directive.js
1 | angular.module('focaAdminSeguimiento').directive('osm', function() { | 1 | angular.module('focaAdminSeguimiento').directive('osm', function() { |
2 | return { | 2 | return { |
3 | restrict: 'E', | 3 | restrict: 'E', |
4 | link: function(scope, el, attrs) { | 4 | link: function(scope, el, attrs) { |
5 | var contenedor = document.createElement('div'); | 5 | var contenedor = document.createElement('div'); |
6 | el.append(contenedor); | 6 | el.append(contenedor); |
7 | scope.map = L.map(contenedor).setView([attrs.latitud, attrs.longitud], attrs.zoom); | 7 | scope.map = L.map(contenedor).setView([attrs.latitud, attrs.longitud], attrs.zoom); |
8 | L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png').addTo(scope.map); | 8 | L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png').addTo(scope.map); |
9 | }, | 9 | }, |
10 | controller: ['$scope', '$filter', function($scope, $filter) { | 10 | controller: ['$scope', '$filter', function($scope, $filter) { |
11 | $scope.markers = []; | 11 | $scope.markers = []; |
12 | $scope.$watch('marcadores', function() { | 12 | $scope.$watch('marcadores', function() { |
13 | for(var i in $scope.markers) { | 13 | for(var i in $scope.markers) { |
14 | $scope.map.removeLayer($scope.markers[i]); | 14 | $scope.map.removeLayer($scope.markers[i]); |
15 | } | 15 | } |
16 | 16 | ||
17 | $scope.markers = []; | 17 | $scope.markers = []; |
18 | var observacion = ''; | ||
19 | |||
18 | angular.forEach($scope.marcadores, function(marcador) { | 20 | angular.forEach($scope.marcadores, function(marcador) { |
19 | var observacion = ''; | ||
20 | |||
21 | if ($scope.parametros.actividad === 'Nota de pedido') { | 21 | if ($scope.parametros.actividad === 'Nota de pedido') { |
22 | observacion += | 22 | observacion = generarObservacion(getNotaPedido(marcador)); |
23 | 'Vendedor: ' + marcador.notaPedido.idVendedor + ' - ' + | ||
24 | ( | ||
25 | marcador.notaPedido.vendedor ? | ||
26 | marcador.notaPedido.vendedor.NomVen : | ||
27 | '' | ||
28 | ) + '<br/>'; | ||
29 | |||
30 | if (!$scope.parametros.individual) { | ||
31 | observacion += '<b>Ultima Nota de Pedido</b><br/>'; | ||
32 | } | ||
33 | observacion += 'Fecha: ' + | ||
34 | $filter('date')(marcador.fecha.slice(0,10), 'dd/MM/yyyy') + ' ' + | ||
35 | marcador.fecha.slice(11,19) + '<br/>'; | ||
36 | observacion += 'Nº: ' + $filter('comprobante')([ | ||
37 | marcador.notaPedido.sucursal, | ||
38 | marcador.notaPedido.numeroNotaPedido | ||
39 | ]) + '<br/>'; | ||
40 | observacion += 'Cliente: ' + | ||
41 | marcador.notaPedido.cliente.NOM + '<br/>'; | ||
42 | |||
43 | if ($scope.parametros.individual) { | ||
44 | observacion += | ||
45 | 'Total: ' + $filter('currency')(marcador.notaPedido.total, '$'); | ||
46 | observacion = 'Orden: ' + marcador.orden + '<br/>' + observacion; | ||
47 | |||
48 | if (marcador.distancia) { | ||
49 | observacion += '<br/>Distancia a casa central: ' + | ||
50 | marcador.distancia + 'km'; | ||
51 | } | ||
52 | } else { | ||
53 | observacion += 'Cantidad de nota de pedido: ' + | ||
54 | marcador.cantidad + '<br/>'; | ||
55 | observacion += 'Total Vendido: ' + | ||
56 | $filter('currency')(marcador.total, '$'); | ||
57 | } | ||
58 | } | 23 | } |
59 | 24 | ||
60 | if ($scope.parametros.actividad === 'Cobranza') { | 25 | if ($scope.parametros.actividad === 'Cobranza') { |
61 | observacion += 'Cobrador: ' + marcador.recibo.cobrador.id + ' - ' + | 26 | observacion = getCobranza(marcador); |
62 | marcador.recibo.CFE + '<br/>'; | 27 | } |
28 | |||
29 | if ($scope.parametros.actividad === 'Entrega de producto') { | ||
30 | observacion = getEntrega(marcador); | ||
31 | } | ||
32 | |||
33 | if (observacion) { | ||
34 | $scope.markers.push( | ||
35 | L.marker([marcador.latitud, marcador.longitud]).addTo($scope.map) | ||
36 | .bindPopup(observacion) | ||
37 | ); | ||
38 | |||
39 | $scope.markers[0].openPopup(); | ||
40 | } | ||
41 | }); | ||
63 | 42 | ||
64 | if (!$scope.parametros.individual) { | 43 | function getNotaPedido(marcador) { |
65 | observacion += '<b>Ultima Cobranza</b><br/>'; | 44 | var observacion = []; |
45 | |||
46 | if (!marcador.notaPedido.id) { | ||
47 | return false; | ||
48 | } | ||
49 | |||
50 | var notaPedido = marcador.notaPedido; | ||
51 | var textVendedor = notaPedido.idVendedor + ' - '; | ||
52 | |||
53 | if (notaPedido.vendedor) { | ||
54 | textVendedor += notaPedido.vendedor.NomVen; | ||
55 | } | ||
56 | |||
57 | observacion.push(['Vendedor', textVendedor]); | ||
58 | |||
59 | if (!$scope.parametros.individual) { | ||
60 | observacion.push(['Ultima Nota de Pedido', '']); | ||
61 | } | ||
62 | |||
63 | var textFecha = $filter('date')(marcador.fecha.slice(0,10), 'dd/MM/yyyy') + | ||
64 | ' ' + marcador.fecha.slice(11,19); | ||
65 | observacion.push(['Fecha', textFecha]); | ||
66 | |||
67 | observacion.push(['Nº', | ||
68 | $filter('comprobante')([notaPedido.sucursal, notaPedido.numeroNotaPedido ]) | ||
69 | ]); | ||
70 | |||
71 | if (notaPedido.cliente) { | ||
72 | observacion.push(['Cliente', notaPedido.cliente.NOM]); | ||
73 | } | ||
74 | |||
75 | if ($scope.parametros.individual) { | ||
76 | observacion.push(['Total', $filter('currency')(notaPedido.total, '$')]); | ||
77 | observacion.unshift(['Orden', marcador.orden]); | ||
78 | |||
79 | if (marcador.distancia) { | ||
80 | observacion.push(['Distancia a casa central', | ||
81 | marcador.distancia + 'km' | ||
82 | ]); | ||
66 | } | 83 | } |
84 | } else { | ||
85 | observacion.push(['Cantidad de nota de pedido', | ||
86 | marcador.cantidad | ||
87 | ]); | ||
88 | |||
89 | observacion.push(['Total Vendido', | ||
90 | $filter('currency')(marcador.total, '$') | ||
91 | ]); | ||
92 | } | ||
93 | |||
94 | console.info(marcador, observacion); | ||
95 | return observacion; | ||
96 | } | ||
97 | |||
98 | function getCobranza(marcador) { | ||
99 | observacion += 'Cobrador: ' + marcador.recibo.cobrador.id + ' - ' + | ||
100 | marcador.recibo.CFE + '<br/>'; | ||
101 | |||
102 | if (!$scope.parametros.individual) { | ||
103 | observacion += '<b>Ultima Cobranza</b><br/>'; | ||
104 | } | ||
67 | 105 | ||
68 | observacion += 'Fecha: ' + | 106 | observacion += 'Fecha: ' + |
69 | $filter('date')(marcador.fecha.slice(0,10), 'dd/MM/yyyy') + ' ' + | 107 | $filter('date')(marcador.fecha.slice(0,10), 'dd/MM/yyyy') + ' ' + |
70 | marcador.fecha.slice(11,19) + '<br/>'; | 108 | marcador.fecha.slice(11,19) + '<br/>'; |
71 | observacion += 'Nº: ' + $filter('comprobante')([ | 109 | observacion += 'Nº: ' + $filter('comprobante')([ |
72 | marcador.sucursal, marcador.idUsuario]) + '<br/>'; | 110 | marcador.sucursal, marcador.idUsuario]) + '<br/>'; |
73 | observacion += 'Cliente: ' + marcador.recibo.cliente.NOM + '<br/>'; | 111 | observacion += 'Cliente: ' + marcador.recibo.cliente.NOM + '<br/>'; |
74 | 112 | ||
75 | if ($scope.parametros.individual) { | 113 | if ($scope.parametros.individual) { |
76 | if (marcador.distancia) { | 114 | if (marcador.distancia) { |
77 | observacion += 'Distancia a casa central: ' + | 115 | observacion += 'Distancia a casa central: ' + |
78 | marcador.distancia + 'km' + '<br/>'; | 116 | marcador.distancia + 'km' + '<br/>'; |
79 | observacion += 'Total Cobrado: ' + | ||
80 | $filter('currency')(marcador.factura.IPA, '$'); | ||
81 | } | ||
82 | } else { | ||
83 | observacion += 'Cantidad de cobranzas: ' + | ||
84 | marcador.cantidad + '<br/>'; | ||
85 | observacion += 'Total Cobrado: ' + | 117 | observacion += 'Total Cobrado: ' + |
86 | $filter('currency')(marcador.factura.IPA, '$'); | 118 | $filter('currency')(marcador.factura.IPA, '$'); |
87 | } | 119 | } |
88 | } | 120 | } else { |
121 | observacion += 'Cantidad de cobranzas: ' + | ||
122 | marcador.cantidad + '<br/>'; | ||
123 | observacion += 'Total Cobrado: ' + | ||
124 | $filter('currency')(marcador.factura.IPA, '$'); | ||
125 | } | ||
89 | 126 | ||
90 | if ($scope.parametros.actividad === 'Entrega de producto') { | 127 | return observacion; |
91 | var remito = marcador.hojaRutaMovimiento.remito; | 128 | } |
92 | observacion += 'Vehiculo: ' + | 129 | |
93 | remito.hojaRuta.idVehiculo + ' - ' + | 130 | function getEntrega(marcador) { |
94 | remito.hojaRuta.vehiculo.tractor + '<br/>'; | 131 | var observacion = ''; |
95 | observacion += 'Transportista: ' + | 132 | var remito = marcador.hojaRutaMovimiento.remito; |
96 | remito.hojaRuta.transportista.NOM + '<br/>'; | 133 | observacion += 'Vehiculo: ' + |
97 | observacion += 'Chofer: ' + | 134 | remito.hojaRuta.idVehiculo + ' - ' + |
98 | remito.hojaRuta.chofer.nombre + '<br/>'; | 135 | remito.hojaRuta.vehiculo.tractor + '<br/>'; |
99 | observacion += 'Hoja de ruta: ' + $filter('comprobante')([ | 136 | observacion += 'Transportista: ' + |
100 | remito.hojaRuta.sucursal, | 137 | remito.hojaRuta.transportista.NOM + '<br/>'; |
101 | remito.hojaRuta.numeroHojaRuta | 138 | observacion += 'Chofer: ' + |
102 | ]) + '<br/>'; | 139 | remito.hojaRuta.chofer.nombre + '<br/>'; |
103 | 140 | observacion += 'Hoja de ruta: ' + $filter('comprobante')([ | |
104 | if (!$scope.parametros.individual) { | 141 | remito.hojaRuta.sucursal, |
105 | observacion += '<b>Ultimo Remito</b><br/>'; | 142 | remito.hojaRuta.numeroHojaRuta |
143 | ]) + '<br/>'; | ||
144 | |||
145 | if (!$scope.parametros.individual) { | ||
146 | observacion += '<b>Ultimo Remito</b><br/>'; | ||
147 | } | ||
148 | |||
149 | observacion += 'Fecha: ' + | ||
150 | $filter('date')(marcador.fecha.slice(0,10), 'dd/MM/yyyy') + ' ' + | ||
151 | marcador.fecha.slice(11,19) + '<br/>'; | ||
152 | |||
153 | observacion += 'Nº: ' + $filter('comprobante')([ | ||
154 | remito.sucursal, | ||
155 | remito.numeroRemito | ||
156 | ]) + '<br/>'; | ||
157 | observacion += 'Cliente: ' + | ||
158 | remito.cliente.NOM + '<br/>'; | ||
159 | |||
160 | if ($scope.parametros.individual) { | ||
161 | observacion += 'Producto: ' + | ||
162 | remito.articulosRemito[0].descripcion + '<br/>'; | ||
163 | observacion += 'Cantidad entregada: ' + | ||
164 | remito.carga + '<br/>'; |