Commit c649a3237e5de4dfeac664bc6495fd380e10dae9

Authored by Eric Fernandez
Exists in master

Merge branch 'master' into 'master'

Master

See merge request !8
src/js/controller.js
1 angular.module('focaModalPuntoDescarga') 1 angular.module('focaModalPuntoDescarga')
2 .controller('focaModalPuntoDescargaController', [ 2 .controller('focaModalPuntoDescargaController', [
3 '$timeout', 3 '$timeout',
4 '$filter', 4 '$filter',
5 '$scope', 5 '$scope',
6 '$uibModalInstance', 6 '$uibModalInstance',
7 'focaModalPuntoDescargaService', 7 'focaModalPuntoDescargaService',
8 'filters', 8 'filters',
9 'focaModalService', 9 'focaModalService',
10 function($timeout, $filter, $scope, $uibModalInstance, 10 function($timeout, $filter, $scope, $uibModalInstance,
11 focaModalPuntoDescargaService, filters, focaModalService) { 11 focaModalPuntoDescargaService, filters, focaModalService) {
12 12
13 $scope.cantidadArticulo = 0; 13 $scope.cantidadArticulo = 0;
14 $scope.articuloSeleccionado = 0; 14 $scope.articuloSeleccionado = 0;
15 $scope.ivas = []; 15 $scope.ivas = [];
16 $scope.puntosSeleccionados = []; 16 $scope.puntosSeleccionados = [];
17 $scope.puntoDescarga = { 17 $scope.puntoDescarga = {
18 id: 0, 18 id: 0,
19 id_cliente: filters.idCliente, 19 id_cliente: filters.idCliente,
20 id_da_config_0: filters.idDomicilio, 20 id_da_config_0: filters.idDomicilio,
21 latitud: -32.89214159952345, 21 latitud: -32.89214159952345,
22 longitud: -68.84572999101856 22 longitud: -68.84572999101856
23 }; 23 };
24 $scope.articulos = angular.copy(filters.articulos); 24 $scope.articulos = angular.copy(filters.articulos);
25 $scope.articulos.map(function(articulo) { 25 $scope.articulos.map(function(articulo) {
26 articulo.restante = articulo.cantidad; 26 articulo.restante = articulo.cantidad;
27 }); 27 });
28 actualizarTabla(); 28 actualizarTabla();
29 cargarPuntos(filters.puntosDescarga); 29 cargarPuntos(filters.puntosDescarga);
30 30
31 $scope.cancel = function() { 31 $scope.cancel = function() {
32 if($scope.ingreso) { 32 if($scope.ingreso) {
33 $scope.ingreso = false; 33 $scope.ingreso = false;
34 }else { 34 }else {
35 $uibModalInstance.dismiss('cancel'); 35 $uibModalInstance.dismiss('cancel');
36 } 36 }
37 }; 37 };
38 38
39 $scope.aceptar = function() { 39 $scope.aceptar = function() {
40 if($scope.cargaArticulos) { 40 if($scope.cargaArticulos) {
41 cargarArticulos(); 41 cargarArticulos();
42 }else { 42 }else {
43 verCargaArticulos(); 43 verCargaArticulos();
44 } 44 }
45 }; 45 };
46 46
47 $scope.guardar = function() { 47 $scope.guardar = function() {
48 focaModalPuntoDescargaService 48 focaModalPuntoDescargaService
49 .guardarPuntoDescarga($scope.puntoDescarga) 49 .guardarPuntoDescarga($scope.puntoDescarga)
50 .then(function() { 50 .then(function() {
51 actualizarTabla(); 51 actualizarTabla();
52 $scope.ingreso = false; 52 $scope.ingreso = false;
53 $scope.puntoDescarga = { 53 $scope.puntoDescarga = {
54 id: 0, 54 id: 0,
55 id_cliente: filters.idCliente, 55 id_cliente: filters.idCliente,
56 id_da_config_0: filters.idDomicilio, 56 id_da_config_0: filters.idDomicilio,
57 latitud: -32.89214159952345, 57 latitud: -32.89214159952345,
58 longitud: -68.84572999101856 58 longitud: -68.84572999101856
59 }; 59 };
60 }); 60 });
61 }; 61 };
62 62
63 $scope.editar = function(id) { 63 $scope.editar = function(id) {
64 focaModalPuntoDescargaService.getPuntoDescargaById(id).then(function(res) { 64 focaModalPuntoDescargaService.getPuntoDescargaById(id).then(function(res) {
65 $scope.puntoDescarga = res.data; 65 $scope.puntoDescarga = res.data;
66 $scope.ingreso = true; 66 $scope.ingreso = true;
67 }); 67 });
68 }; 68 };
69 69
70 $scope.eliminar = function(idx, id) { 70 $scope.eliminar = function(idx, puntoDescarga) {
71 focaModalPuntoDescargaService.eliminarPuntoDescarga(id).then(function() { 71 focaModalService.confirm('¿Está seguro que desea borrar el punto de descarga '+
72 $scope.puntosDescarga.splice(idx, 1); 72 puntoDescarga.descripcion + '?').then(function(data) {
73 }); 73 if(data) {
74 focaModalPuntoDescargaService
75 .eliminarPuntoDescarga(puntoDescarga.id)
76 .then(function() {
77 $scope.puntosDescarga.splice(idx, 1);
78 });
79 }
80 });
74 }; 81 };
75 82
76 $scope.seleccionarPunto = function(idx) { 83 $scope.seleccionarPunto = function(idx, esCheckbox) {
77 var indexPunto = $scope.puntosSeleccionados.indexOf(idx); 84 var indexPunto = $scope.puntosSeleccionados.indexOf(idx);
78 if(indexPunto !== -1) { 85 if(indexPunto !== -1) {
86 if(!esCheckbox){
87 $scope.puntosDescarga[idx].seleccionado = false;
88 }
79 $scope.puntosSeleccionados.splice(indexPunto, 1); 89 $scope.puntosSeleccionados.splice(indexPunto, 1);
80 }else { 90 }else {
91 if(!esCheckbox){
92 $scope.puntosDescarga[idx].seleccionado = true;
93 }
81 $scope.puntosSeleccionados.push(idx); 94 $scope.puntosSeleccionados.push(idx);
82 } 95 }
83 }; 96 };
84 97
85 $scope.agregarArticulo = function(punto, key) { 98 $scope.agregarArticulo = function(punto, key) {
86 key = (typeof key === 'undefined') ? 13 : key; 99 key = (typeof key === 'undefined') ? 13 : key;
87 100
88 if(key === 13){ 101 if(key === 13){
89 var articulo = $scope.articulos[$scope.articuloSeleccionado], 102 var articulo = $scope.articulos[$scope.articuloSeleccionado],
90 cantidadRestante = articulo.restante - punto.cantidadACargar; 103 cantidadRestante = articulo.restante - punto.cantidadACargar;
91 104
92 if(cantidadRestante < 0) { 105 if(cantidadRestante < 0) {
93 focaModalService.alert('La cantidad a cargar debe ser menor o igual al restante'); 106 focaModalService
107 .alert('La cantidad a cargar debe ser menor o igual al restante');
94 }else if(punto.cantidadACargar <= 0) { 108 }else if(punto.cantidadACargar <= 0) {
95 focaModalService.alert('La cantidad a cargar debe ser mayor que cero'); 109 focaModalService
110 .alert('La cantidad a cargar debe ser mayor que cero');
96 }else { 111 }else {
97 punto.cargado += parseInt(punto.cantidadACargar); 112 punto.cargado += parseInt(punto.cantidadACargar);
98 articulo.restante = cantidadRestante; 113 articulo.restante = cantidadRestante;
99 var existeArticulo = punto.articulosAgregados.filter( 114 var existeArticulo = punto.articulosAgregados.filter(
100 function (articuloAAgregar) { 115 function (articuloAAgregar) {
101 return articuloAAgregar.id === articulo.idArticulo; 116 return articuloAAgregar.id === articulo.idArticulo;
102 }); 117 });
103 //Si el articulo ya fue agregado 118 //Si el articulo ya fue agregado
104 if(existeArticulo.length) { 119 if(existeArticulo.length) {
105 //Solo sumo cantidad 120 //Solo sumo cantidad
106 var total = parseInt(existeArticulo[0].cantidad) + parseInt(punto.cantidadACargar); 121 var total = parseInt(existeArticulo[0].cantidad) +
122 parseInt(punto.cantidadACargar);
107 existeArticulo[0].cantidad = total; 123 existeArticulo[0].cantidad = total;
108 }else { 124 }else {
109 //Agrego el articulo con la cantidad 125 //Agrego el articulo con la cantidad
110 punto.articulosAgregados.push({ 126 punto.articulosAgregados.push({
111 id: articulo.idArticulo, 127 id: articulo.idArticulo,
112 descripcion: articulo.descripcion, 128 descripcion: articulo.descripcion,
113 cantidad: punto.cantidadACargar, 129 cantidad: punto.cantidadACargar,
114 index: $scope.articuloSeleccionado 130 index: $scope.articuloSeleccionado
115 }); 131 });
116 } 132 }
117 punto.cantidadACargar = 0; 133 punto.cantidadACargar = 0;
118 } 134 }
119 } 135 }
120 }; 136 };
121 137
122 $scope.quitarArticulo = function(articulo, idx, punto) { 138 $scope.quitarArticulo = function(articulo, idx, punto) {
123 var articuloAEliminar = $scope.articulos.filter(function(art) { 139 var articuloAEliminar = $scope.articulos.filter(function(art) {
124 return art.id == articulo.id; 140 return art.id === articulo.id;
125 }); 141 });
126 var restante = parseInt(articuloAEliminar[0].restante); 142 var restante = parseInt(articuloAEliminar[0].restante);
127 restante += parseInt(articulo.cantidad); 143 restante += parseInt(articulo.cantidad);
128 articuloAEliminar[0].restante = restante; 144 articuloAEliminar[0].restante = restante;
129 145
130 punto.cargado -= parseInt(punto.articulosAgregados[idx].cantidad); 146 punto.cargado -= parseInt(punto.articulosAgregados[idx].cantidad);
131 punto.articulosAgregados.splice(idx, 1); 147 punto.articulosAgregados.splice(idx, 1);
132 }; 148 };
133 149
134 function actualizarTabla() { 150 function actualizarTabla() {
135 focaModalPuntoDescargaService 151 focaModalPuntoDescargaService
136 .getPuntosDescargaByClienDom(filters.idDomicilio, filters.idCliente) 152 .getPuntosDescargaByClienDom(filters.idDomicilio, filters.idCliente)
137 .then(function(res) { 153 .then(function(res) {
138 $scope.puntosDescarga = res.data; 154 $scope.puntosDescarga = res.data;
139 }); 155 });
140 } 156 }
141 function verCargaArticulos() { 157 function verCargaArticulos() {
142 $scope.puntosACargar = []; 158 $scope.puntosACargar = [];
143 $scope.cargaArticulos = true; 159 $scope.cargaArticulos = true;
144 $scope.puntosSeleccionados.forEach(function(idx) { 160 $scope.puntosSeleccionados.forEach(function(idx) {
145 $scope.puntosACargar.push($scope.puntosDescarga[idx]); 161 $scope.puntosACargar.push($scope.puntosDescarga[idx]);
146 }); 162 });
147 163
148 $scope.puntosACargar.map(function(punto) { 164 $scope.puntosACargar.map(function(punto) {
149 punto.articulosAgregados = []; 165 punto.articulosAgregados = [];
150 punto.cantidadACargar = 0; 166 punto.cantidadACargar = 0;
151 punto.cargado = 0; 167 punto.cargado = 0;
152 }); 168 });
153 } 169 }
154 function cargarArticulos() { 170 function cargarArticulos() {
155 $uibModalInstance.close($scope.puntosACargar); 171 $uibModalInstance.close($scope.puntosACargar);
156 } 172 }
157 function cargarPuntos(puntosDescarga) { 173 function cargarPuntos(puntosDescarga) {
158 //Si existen puntos ya cargados 174 //Si existen puntos ya cargados
159 if(puntosDescarga) { 175 if(puntosDescarga) {
160 if(!puntosDescarga[0].cargado) { 176 if(!puntosDescarga[0].cargado) {
161 agregarTotalCargado(puntosDescarga); 177 agregarTotalCargado(puntosDescarga);
162 } 178 }
163 $scope.puntosACargar = puntosDescarga; 179 $scope.puntosACargar = puntosDescarga;
164 $scope.cargaArticulos = true; 180 $scope.cargaArticulos = true;
165 //Recorro los puntos 181 //Recorro los puntos
166 puntosDescarga.forEach(function(punto) { 182 puntosDescarga.forEach(function(punto) {
167 //Recorro los articulos cargados en cada punto 183 //Recorro los articulos cargados en cada punto
168 punto.articulosAgregados.forEach(function(articulo) { 184 punto.articulosAgregados.forEach(function(articulo) {
169 var articuloARestar = $scope.articulos.filter(function(art) { 185 var articuloARestar = $scope.articulos.filter(function(art) {
170 return art.idArticulo == articulo.id; 186 return art.idArticulo === articulo.id;
171 }); 187 });
172 articuloARestar[0].restante -= articulo.cantidad; 188 articuloARestar[0].restante -= articulo.cantidad;
173 }); 189 });
174 }); 190 });
175 } 191 }
176 } 192 }
177 function agregarTotalCargado(puntosDescarga) { 193 function agregarTotalCargado(puntosDescarga) {
178 puntosDescarga.map(function(punto) { 194 puntosDescarga.map(function(punto) {
179 punto.cantidadACargar = 0; 195 punto.cantidadACargar = 0;
180 punto.cargado = 0; 196 punto.cargado = 0;
181 }); 197 });
182 //Agrego cantidad de combustible cargada en los puntos de descarga 198 //Agrego cantidad de combustible cargada en los puntos de descarga
183 puntosDescarga.forEach(function(punto) { 199 puntosDescarga.forEach(function(punto) {
184 punto.articulosAgregados.forEach(function(articulo) { 200 punto.articulosAgregados.forEach(function(articulo) {
185 punto.cargado += articulo.cantidad; 201 punto.cargado += articulo.cantidad;
186 }); 202 });
187 }); 203 });
188 } 204 }
189 }] 205 }]
190 ); 206 );
191 207
src/js/osm-directive.js
1 angular.module('focaModalPuntoDescarga').directive('osmPuntoDescarga', function() { 1 angular.module('focaModalPuntoDescarga').directive('osmPuntoDescarga', 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 contenedor.className = 'w-100 h-50 mt-3'; 6 contenedor.className = 'w-100 h-50 mt-3';
7 el.append(contenedor); 7 el.append(contenedor);
8 scope.map = L.map(contenedor).setView([-32.89214159952345, -68.84572999101856], attrs.zoom); 8 scope.map = L.map(contenedor).setView([-32.89214159952345, -68.84572999101856], attrs.zoom);
9 L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png').addTo(scope.map); 9 L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png').addTo(scope.map);
10 }, 10 },
11 controller: ['$scope', '$timeout', function($scope, $timeout) { 11 controller: ['$scope', '$timeout', function($scope, $timeout) {
12 //resuelve bug mapa gris en modales 12 //resuelve bug mapa gris en modales
13 $timeout(function() { 13 $timeout(function() {
14 $scope.map.invalidateSize(); 14 $scope.map.invalidateSize();
15 }, 1000); 15 }, 100);
16 16
17 $scope.markers = []; 17 $scope.markers = [];
18 $scope.$watchGroup(['latitud', 'longitud'], function() { 18 $scope.$watchGroup(['latitud', 'longitud'], function() {
19 for(var i in $scope.markers) { 19 for(var i in $scope.markers) {
20 $scope.map.removeLayer($scope.markers[i]); 20 $scope.map.removeLayer($scope.markers[i]);
21 } 21 }
22 $scope.markers.push( 22 $scope.markers.push(
23 L.marker([$scope.latitud, $scope.longitud], {draggable:'true'}) 23 L.marker([$scope.latitud, $scope.longitud], {draggable:'true'})
24 .addTo($scope.map) 24 .addTo($scope.map)
25 .on('dragend', function() { 25 .on('dragend', function() {
26 $scope.latitud = this.getLatLng().lat; 26 $scope.latitud = this.getLatLng().lat;
27 $scope.longitud = this.getLatLng().lng; 27 $scope.longitud = this.getLatLng().lng;
28 $scope.$apply(); 28 $scope.$apply();
29 }) 29 })
30 ); 30 );
31 }); 31 });
32 }], 32 }],
33 scope: { 33 scope: {
34 latitud: '=', 34 latitud: '=',
35 longitud: '=', 35 longitud: '=',
36 zoom: '=' 36 zoom: '='
37 } 37 }
38 }; 38 };
39 }); 39 });
40 40
src/views/modal-punto-descarga.html
1 <div class="modal-header d-flex"> 1 <div class="modal-header d-flex">
2 <h5 class="modal-title my-1" ng-hide="ingreso || cargaArticulos">Búsqueda de puntos de descarga</h5> 2 <h5 class="modal-title my-1" ng-hide="ingreso || cargaArticulos">Búsqueda de puntos de descarga</h5>
3 <h5 class="modal-title my-1" ng-show="ingreso">Crear punto de descarga</h5> 3 <h5 class="modal-title my-1" ng-show="ingreso">Crear punto de descarga</h5>
4 <h5 class="modal-title my-1" ng-show="cargaArticulos">Cargar artículos en puntos de descarga</h5> 4 <h5 class="modal-title my-1" ng-show="cargaArticulos">Cargar artículos en puntos de descarga</h5>
5 <button 5 <button
6 class="btn btn-primary" 6 class="btn btn-primary"
7 title="Nuevo" 7 title="Nuevo"
8 ng-click="ingreso = true" 8 ng-click="ingreso = true"
9 ng-hide="ingreso || cargaArticulos"> 9 ng-hide="ingreso || cargaArticulos">
10 <i class="fa fa-plus" aria-hidden="true"></i> 10 <i class="fa fa-plus" aria-hidden="true"></i>
11 </button> 11 </button>
12 </div> 12 </div>
13 <div class="modal-body" id="modal-body"> 13 <div class="modal-body" id="modal-body">
14 <table 14 <table
15 class="table table-striped table-sm col-12" 15 class="table table-striped table-sm col-12"
16 ng-hide="ingreso || cargaArticulos"> 16 ng-hide="ingreso || cargaArticulos">
17 <thead> 17 <thead>
18 <tr> 18 <tr>
19 <th>Código</th> 19 <th>Código</th>
20 <th>Descripción</th> 20 <th>Descripción</th>
21 <th>Latitud</th> 21 <th>Latitud</th>
22 <th>Longitud</th> 22 <th>Longitud</th>
23 <th></th> 23 <th></th>
24 </tr> 24 </tr>
25 </thead> 25 </thead>
26 <tbody> 26 <tbody>
27 <tr ng-show="!puntosDescarga.length"> 27 <tr ng-show="!puntosDescarga.length">
28 <td colspan="3"> 28 <td colspan="3">
29 No se encontraron resultados. 29 No se encontraron resultados.
30 </td> 30 </td>
31 </tr> 31 </tr>
32 <tr class="selected" 32 <tr class="selected"
33 ng-repeat="(key, puntoDescarga) in puntosDescarga | filter: filters" 33 ng-repeat="(key, puntoDescarga) in puntosDescarga | filter: filters"
34 > 34 >
35 <td ng-bind="puntoDescarga.id | rellenarDigitos: 3: 0"></td> 35 <td
36 <td ng-bind="puntoDescarga.descripcion"></td> 36 ng-bind="puntoDescarga.id | rellenarDigitos: 3: 0"
37 <td ng-bind="puntoDescarga.latitud"></td> 37 ng-click="seleccionarPunto(key)"></td>
38 <td ng-bind="puntoDescarga.longitud"></td> 38 <td
39 <td class="d-md-none text-primary"> 39 ng-bind="puntoDescarga.descripcion"
40 <i class="fa fa-circle-thin" aria-hidden="true"></i> 40 ng-click="seleccionarPunto(key)"></td>
41 </td> 41 <td
42 <td class="d-none d-md-table-cell"> 42 ng-bind="puntoDescarga.latitud"
43 ng-click="seleccionarPunto(key)"></td>
44 <td
45 ng-bind="puntoDescarga.longitud"
46 ng-click="seleccionarPunto(key)"></td>
47 <td>
43 <input 48 <input
44 type="checkbox" 49 type="checkbox"
45 class="custom-control-input float-right" 50 class="custom-control-input float-right"
46 id="checkSelect{{key}}"> 51 id="checkSelect{{key}}"
52 ng-model="puntoDescarga.seleccionado"
53 ng-change="seleccionarPunto(key, true)"
54 >
47 <label 55 <label
48 class="custom-control-label float-right" 56 class="custom-control-label float-right"
49 for="checkSelect{{key}}" 57 for="checkSelect{{key}}"></label>
50 ng-click="seleccionarPunto(key)"></label>
51 <button 58 <button
52 type="button" 59 type="button"
53 class="btn btn-xs p-1 float-right mr-5" 60 class="btn btn-xs p-1 float-right mr-5"
54 ng-click="eliminar(key, puntoDescarga.id)" 61 ng-click="eliminar(key, puntoDescarga)"
55 title="Eliminar"> 62 title="Eliminar">
56 <i class="fa fa-trash" aria-hidden="true"></i> 63 <i class="fa fa-trash" aria-hidden="true"></i>
57 </button> 64 </button>
58 <button 65 <button
59 type="button" 66 type="button"
60 class="btn btn-xs p-1 float-right mr-1" 67 class="btn btn-xs p-1 float-right mr-1"
61 ng-click="editar(puntoDescarga.id)" 68 ng-click="editar(puntoDescarga.id)"
62 title="Editar"> 69 title="Editar">
63 <i class="fa fa-pencil" aria-hidden="true"></i> 70 <i class="fa fa-pencil" aria-hidden="true"></i>
64 </button> 71 </button>
65 </td> 72 </td>
66 </tr> 73 </tr>
67 </tbody> 74 </tbody>
68 </table> 75 </table>
69 <div ng-show="cargaArticulos"> 76 <div ng-show="cargaArticulos">
70 <div ng-show="!articulos.length"> 77 <div ng-show="!articulos.length">
71 <h6>No existen articulos para agregar</h6> 78 <h6>No existen articulos para agregar</h6>
72 </div> 79 </div>
73 <div ng-show="articulos.length"> 80 <div ng-show="articulos.length">
74 <div class="row"> 81 <div class="row">
75 <div class="col-12"> 82 <div class="col-12">
76 <table class="table table-sm"> 83 <table class="table table-sm">
77 <thead> 84 <thead>
78 <tr> 85 <tr>
79 <th></th> 86 <th></th>
80 <th>Articulo</th> 87 <th>Articulo</th>
81 <th>Total</th> 88 <th>Total</th>
82 <th>Restante</th> 89 <th>Restante</th>
83 </tr> 90 </tr>
84 </thead> 91 </thead>
85 <tbody> 92 <tbody>
86 <tr ng-repeat="(key, articulo) in articulos"> 93 <tr ng-repeat="(key, articulo) in articulos">
87 <td> 94 <td>
88 <input 95 <input
89 type="radio" 96 type="radio"
90 ng-value="key" 97 ng-value="key"
91 ng-model="$parent.articuloSeleccionado" 98 ng-model="$parent.articuloSeleccionado"
92 > 99 >
93 </td> 100 </td>
94 <td ng-bind="articulo.descripcion"></td> 101 <td ng-bind="articulo.descripcion"></td>
95 <td ng-bind="articulo.cantidad"></td> 102 <td ng-bind="articulo.cantidad"></td>
96 <td ng-bind="articulo.restante"></td> 103 <td ng-bind="articulo.restante"></td>
97 </tr> 104 </tr>
98 </tbody> 105 </tbody>
99 </table> 106 </table>
100 </div> 107 </div>
101 </div> 108 </div>
102 <div class="row"> 109 <div class="row">
103 <div class="col-12"> 110 <div class="col-12">
104 <h5 class="col-12 my-3">Puntos de descarga</h5> 111 <h5 class="col-12 my-3">Puntos de descarga</h5>
105 <table class="table table-sm"> 112 <table class="table table-sm">
106 <thead> 113 <thead>
107 <tr> 114 <tr>
108 <th>Lugar</th> 115 <th>Lugar</th>
109 <th class="text-right">Total cargado</th> 116 <th class="text-right">Total cargado</th>
110 <th class="text-right">Cantidad</th> 117 <th class="text-right">Cantidad</th>
111 <th></th> 118 <th></th>
112 </tr> 119 </tr>
113 </thead> 120 </thead>
114 <tbody> 121 <tbody>
115 <tr ng-repeat="punto in puntosACargar"> 122 <tr ng-repeat="punto in puntosACargar">
116 <td ng-bind="punto.descripcion"></td> 123 <td ng-bind="punto.descripcion"></td>
117 <td ng-bind="punto.cargado" class="text-right"></td> 124 <td ng-bind="punto.cargado" class="text-right"></td>
118 <td> 125 <td>
119 <input 126 <input
120 type="text" 127 type="text"
121 class="form-control col-4 float-right" 128 class="form-control col-4 float-right"
122 id="inputCantidad" 129 id="inputCantidad"
123 placeholder="A cargar" 130 placeholder="A cargar"
124 ng-model="punto.cantidadACargar" 131 ng-model="punto.cantidadACargar"
125 ng-keypress="agregarArticulo(punto, $event.keyCode)" 132 ng-keypress="agregarArticulo(punto, $event.keyCode)"
126 > 133 >
127 </td> 134 </td>
128 <td> 135 <td>
129 <button 136 <button
130 class="btn btn-sm btn-outline-primary ml-auto" 137 class="btn btn-sm btn-outline-primary ml-auto"
131 type="button" 138 type="button"
132 ng-click="agregarArticulo(punto)" 139 ng-click="agregarArticulo(punto)"
133 > 140 >
134 Agregar 141 Agregar
135 </button> 142 </button>
136 </td> 143 </td>
137 </tr> 144 </tr>
138 </tbody> 145 </tbody>
139 </table> 146 </table>
140 <table class="table table-sm"> 147 <table class="table table-sm">
141 <thead> 148 <thead>
142 <tr> 149 <tr>
143 <th>Lugar</th> 150 <th>Lugar</th>
144 <th>Articulo</th> 151 <th>Articulo</th>
145 <th class="text-right">Cantidad</th> 152 <th class="text-right">Cantidad</th>
146 <th></th> 153 <th></th>
147 </tr> 154 </tr>
148 </thead> 155 </thead>
149 <tbody ng-repeat="punto in puntosACargar"> 156 <tbody ng-repeat="punto in puntosACargar">
150 <tr ng-repeat="(key, articulo) in punto.articulosAgregados"> 157 <tr ng-repeat="(key, articulo) in punto.articulosAgregados">
151 <td ng-bind="punto.descripcion"></td> 158 <td ng-bind="punto.descripcion"></td>
152 <td ng-bind="articulo.descripcion" class="p-2"></td> 159 <td ng-bind="articulo.descripcion" class="p-2"></td>
153 <td ng-bind="articulo.cantidad" class="text-right p-2"></td> 160 <td ng-bind="articulo.cantidad" class="text-right p-2"></td>
154 <td class="p-2"> 161 <td class="p-2">
155 <button 162 <button
156 type="button" 163 type="button"
157 class="btn btn-xs p-1 float-right mr-5" 164 class="btn btn-xs p-1 float-right mr-5"
158 ng-click="quitarArticulo(articulo, key, punto)" 165 ng-click="quitarArticulo(articulo, key, punto)"
159 title="Eliminar"> 166 title="Eliminar">
160 <i class="fa fa-trash" aria-hidden="true"></i> 167 <i class="fa fa-trash" aria-hidden="true"></i>
161 </button> 168 </button>
162 </td> 169 </td>
163 </tr> 170 </tr>
164 </tbody> 171 </tbody>
165 </table> 172 </table>
166 </div> 173 </div>
167 </div> 174 </div>
168 </div> 175 </div>
169 </div> 176 </div>
170 <form ng-show="ingreso"> 177 <form ng-show="ingreso">
171 <div class="row"> 178 <div class="row">
172 <div class="col-12"> 179 <div class="col-12">
173 <label>Descripción</label> 180 <label>Descripción</label>
174 <input 181 <input
175 type="text" 182 type="text"
176 class="form-control form-control-sm" 183 class="form-control form-control-sm"
177 ng-model="puntoDescarga.descripcion" 184 ng-model="puntoDescarga.descripcion"
178 uppercase-only> 185 uppercase-only>
179 </div> 186 </div>
180 </div> 187 </div>
181 <div class="row"> 188 <div class="row">
182 <div class="col-6"> 189 <div class="col-6">
183 <label>Latitud</label> 190 <label>Latitud</label>
184 <input 191 <input
185 type="text" 192 type="text"
186 class="form-control form-control-sm" 193 class="form-control form-control-sm"
187 ng-model="puntoDescarga.latitud" 194 ng-model="puntoDescarga.latitud"
188 ng-required="true" 195 ng-required="true"
189 /> 196 />
190 </div> 197 </div>
191 <div class="col-6"> 198 <div class="col-6">
192 <label>Longitud</label> 199 <label>Longitud</label>
193 <input 200 <input
194 type="text" 201 type="text"
195 class="form-control form-control-sm" 202 class="form-control form-control-sm"
196 ng-model="puntoDescarga.longitud" 203 ng-model="puntoDescarga.longitud"
197 ng-required="true" 204 ng-required="true"
198 /> 205 />
199 </div> 206 </div>
200 </div> 207 </div>
201 <osm-punto-descarga 208 <osm-punto-descarga
202 latitud="puntoDescarga.latitud" 209 latitud="puntoDescarga.latitud"
203 longitud="puntoDescarga.longitud" 210 longitud="puntoDescarga.longitud"
204 zoom="14" 211 zoom="14"
212 ng-if="ingreso"
205 /> 213 />
206 </form> 214 </form>
207 </div> 215 </div>
208 <div class="modal-footer"> 216 <div class="modal-footer">
209 <button 217 <button
210 class="btn btn-sm btn-secondary my-1" 218 class="btn btn-sm btn-secondary my-1"
211 type="button" 219 type="button"
212 ng-click="cancel()">Cancelar</button> 220 ng-click="cancel()">Cancelar</button>
213 <button 221 <button
214 class="btn btn-sm btn-primary my-1" 222 class="btn btn-sm btn-primary my-1"
215 type="button" 223 type="button"
216 ng-click="aceptar()" 224 ng-click="aceptar()"
217 ng-hide="ingreso">Aceptar</button> 225 ng-hide="ingreso">Aceptar</button>
218 <button 226 <button
219 class="btn btn-sm btn-primary my-1" 227 class="btn btn-sm btn-primary my-1"
220 type="button" 228 type="button"
221 ng-click="guardar()" 229 ng-click="guardar()"
222 ng-show="ingreso">Guardar</button> 230 ng-show="ingreso">Guardar</button>
223 </div> 231 </div>