Commit 05fc8709be2bd960efdc271bcd50e1b420b0a607

Authored by Nicolás Guarnieri
Exists in master

Merge remote-tracking branch 'upstream/master'

src/js/controller.js
1 angular.module('focaCrearNotaPedido') .controller('notaPedidoCtrl', 1 angular.module('focaCrearNotaPedido') .controller('notaPedidoCtrl',
2 [ 2 [
3 '$scope', '$uibModal', '$location', '$filter', 'crearNotaPedidoService', 3 '$scope', '$uibModal', '$location', '$filter', 'crearNotaPedidoService',
4 'focaModalService', 4 'focaModalService',
5 function( 5 function(
6 $scope, $uibModal, $location, $filter, crearNotaPedidoService, focaModalService 6 $scope, $uibModal, $location, $filter, crearNotaPedidoService, focaModalService
7 ) { 7 ) {
8 $scope.botonera = [ 8 $scope.botonera = [
9 {texto: 'Vendedor', accion: function() {$scope.seleccionarVendedor();}}, 9 {texto: 'Vendedor', accion: function() {$scope.seleccionarVendedor();}},
10 {texto: 'Cliente', accion: function() {$scope.seleccionarCliente();}}, 10 {texto: 'Cliente', accion: function() {$scope.seleccionarCliente();}},
11 {texto: 'Proveedor', accion: function() {}}, 11 {texto: 'Proveedor', accion: function() {}},
12 {texto: 'Moneda', accion: function() {$scope.abrirModalMoneda();}}, 12 {texto: 'Moneda', accion: function() {$scope.abrirModalMoneda();}},
13 { 13 {
14 texto: 'Precios y condiciones', 14 texto: 'Precios y condiciones',
15 accion: function() {$scope.abrirModalListaPrecio();}}, 15 accion: function() {$scope.abrirModalListaPrecio();}},
16 {texto: 'Flete', accion: function() {$scope.abrirModalFlete();}}, 16 {texto: 'Flete', accion: function() {$scope.abrirModalFlete();}},
17 {texto: '', accion: function() {}}, 17 {texto: '', accion: function() {}},
18 {texto: '', accion: function() {}} 18 {texto: '', accion: function() {}}
19 ]; 19 ];
20 20
21 $scope.show = false; 21 $scope.show = false;
22 $scope.cargando = true; 22 $scope.cargando = true;
23 $scope.dateOptions = { 23 $scope.dateOptions = {
24 maxDate: new Date(), 24 maxDate: new Date(),
25 minDate: new Date(2010, 0, 1) 25 minDate: new Date(2010, 0, 1)
26 }; 26 };
27 27
28 $scope.notaPedido = { 28 $scope.notaPedido = {
29 vendedor: {}, 29 vendedor: {},
30 cliente: {}, 30 cliente: {},
31 domicilio: {dom: ''}, 31 domicilio: {dom: ''},
32 moneda: {detalle: ''} 32 moneda: {detalle: ''}
33 }; 33 };
34 34
35 $scope.cabecera = []; 35 $scope.cabecera = [];
36 36
37 $scope.now = new Date(); 37 $scope.now = new Date();
38 $scope.puntoVenta = Math.round(Math.random() * 10000); 38 $scope.puntoVenta = Math.round(Math.random() * 10000);
39 $scope.comprobante = Math.round(Math.random() * 1000000); 39 $scope.comprobante = Math.round(Math.random() * 1000000);
40 40
41 $scope.articulosTabla = []; 41 $scope.articulosTabla = [];
42 var idLista; 42 var idLista;
43 var notaPedidoTemp = crearNotaPedidoService.getNotaPedido(); 43 var notaPedidoTemp = crearNotaPedidoService.getNotaPedido();
44 crearNotaPedidoService.getPrecioCondicion().then( 44 crearNotaPedidoService.getPrecioCondicion().then(
45 function(res) { 45 function(res) {
46 $scope.precioCondiciones = res.data; 46 $scope.precioCondiciones = res.data;
47 } 47 }
48 ); 48 );
49 if (notaPedidoTemp !== undefined) { 49 if (notaPedidoTemp !== undefined) {
50 notaPedidoTemp.fechaCarga = new Date(notaPedidoTemp.fechaCarga); 50 notaPedidoTemp.fechaCarga = new Date(notaPedidoTemp.fechaCarga);
51 $scope.notaPedido = notaPedidoTemp; 51 $scope.notaPedido = notaPedidoTemp;
52 $scope.notaPedido.flete = ($scope.notaPedido.flete).toString(); 52 $scope.notaPedido.flete = ($scope.notaPedido.flete).toString();
53 $scope.notaPedido.bomba = ($scope.notaPedido.bomba).toString(); 53 $scope.notaPedido.bomba = ($scope.notaPedido.bomba).toString();
54 idLista = $scope.notaPedido.precioCondicion; 54 idLista = $scope.notaPedido.precioCondicion;
55 crearNotaPedidoService 55 crearNotaPedidoService
56 .getArticulosByIdNotaPedido($scope.notaPedido.id).then( 56 .getArticulosByIdNotaPedido($scope.notaPedido.id).then(
57 function(res) { 57 function(res) {
58 $scope.articulosTabla = res.data; 58 $scope.articulosTabla = res.data;
59 } 59 }
60 ); 60 );
61 //TODO DOMICILIOS QUE SE CARGAN AL EDITAR NOTA DE PEDIDO 61 //TODO DOMICILIOS QUE SE CARGAN AL EDITAR NOTA DE PEDIDO
62 //(NO REQUERIDO EN ESTA VERSION) 62 //(NO REQUERIDO EN ESTA VERSION)
63 // crearNotaPedidoService.getDomiciliosByIdNotaPedido($scope.notaPedido.id).then( 63 // crearNotaPedidoService.getDomiciliosByIdNotaPedido($scope.notaPedido.id).then(
64 // function(res) { 64 // function(res) {
65 // $scope.notaPedido.domicilio = res.data; 65 // $scope.notaPedido.domicilio = res.data;
66 // } 66 // }
67 // ); 67 // );
68 } else { 68 } else {
69 $scope.notaPedido.fechaCarga = new Date(); 69 $scope.notaPedido.fechaCarga = new Date();
70 $scope.notaPedido.bomba = '0'; 70 $scope.notaPedido.bomba = '0';
71 $scope.notaPedido.flete = '0'; 71 $scope.notaPedido.flete = '0';
72 idLista = undefined; 72 idLista = undefined;
73 } 73 }
74 //TO DO - FUNCIONES PARA MULTIPLES DOMICILIOS NO IMPLEMENTADAS EN ESTA DEMO 74 //TO DO - FUNCIONES PARA MULTIPLES DOMICILIOS NO IMPLEMENTADAS EN ESTA DEMO
75 // $scope.addNewDom = function() { 75 // $scope.addNewDom = function() {
76 // $scope.notaPedido.domicilio.push({ 'id': 0 }); 76 // $scope.notaPedido.domicilio.push({ 'id': 0 });
77 // }; 77 // };
78 // $scope.removeNewChoice = function(choice) { 78 // $scope.removeNewChoice = function(choice) {
79 // if ($scope.notaPedido.domicilio.length > 1) { 79 // if ($scope.notaPedido.domicilio.length > 1) {
80 // $scope.notaPedido.domicilio.splice($scope.notaPedido.domicilio.findIndex( 80 // $scope.notaPedido.domicilio.splice($scope.notaPedido.domicilio.findIndex(
81 // function(c) { 81 // function(c) {
82 // return c.$$hashKey === choice.$$hashKey; 82 // return c.$$hashKey === choice.$$hashKey;
83 // } 83 // }
84 // ), 1); 84 // ), 1);
85 // } 85 // }
86 // }; 86 // };
87 $scope.crearNotaPedido = function() { 87 $scope.crearNotaPedido = function() {
88 if($scope.articulosTabla.length === 0) { 88 if($scope.articulosTabla.length === 0) {
89 focaModalService.alert('Debe cargar almenos un articulo'); 89 focaModalService.alert('Debe cargar almenos un articulo');
90 return; 90 return;
91 } 91 }
92 if($scope.notaPedido.domicilio.id === undefined) { 92 if($scope.notaPedido.domicilio.id === undefined) {
93 $scope.notaPedido.domicilio.id = 0; 93 $scope.notaPedido.domicilio.id = 0;
94 } 94 }
95 var date = new Date(); 95 var date = new Date();
96 var notaPedido = { 96 var notaPedido = {
97 id: 0, 97 id: 0,
98 fechaCarga: new Date(date.getTime() - (date.getTimezoneOffset() * 60000)) 98 fechaCarga: new Date(date.getTime() - (date.getTimezoneOffset() * 60000))
99 .toISOString().slice(0, 19).replace('T', ' '), 99 .toISOString().slice(0, 19).replace('T', ' '),
100 vendedor: $scope.notaPedido.vendedor.nombre, 100 vendedor: $scope.notaPedido.vendedor.nombre,
101 idCliente: $scope.notaPedido.cliente.id, 101 idCliente: $scope.notaPedido.cliente.id,
102 domicilio: $scope.notaPedido.domicilio, 102 domicilio: $scope.notaPedido.domicilio,
103 precioCondicion: $scope.notaPedido.precioCondicion, 103 precioCondicion: $scope.notaPedido.precioCondicion,
104 bomba: $scope.notaPedido.bomba, 104 bomba: $scope.notaPedido.bomba,
105 flete: $scope.notaPedido.flete, 105 flete: $scope.notaPedido.flete,
106 total: $scope.getTotal() 106 total: $scope.getTotal()
107 }; 107 };
108 crearNotaPedidoService.crearNotaPedido(notaPedido).then( 108 crearNotaPedidoService.crearNotaPedido(notaPedido).then(
109 function(data) { 109 function(data) {
110 focaModalService.alert('Nota pedido creada'); 110 focaModalService.alert('Nota pedido creada');
111 if($scope.notaPedido.flete === 1) { 111 if($scope.notaPedido.flete === 1) {
112 var flete = { 112 var flete = {
113 idNotaPedido: data.data.id, 113 idNotaPedido: data.data.id,
114 idTransportista: $scope.notaPedido.fleteId, 114 idTransportista: $scope.notaPedido.fleteId,
115 idChofer: $scope.notaPedido.chofer.id, 115 idChofer: $scope.notaPedido.chofer.id,
116 idVehiculo: $scope.notaPedido.vehiculo.id, 116 idVehiculo: $scope.notaPedido.vehiculo.id,
117 kilometros: $scope.notaPedido.kilometros, 117 kilometros: $scope.notaPedido.kilometros,
118 costoKilometro: $scope.notaPedido.costoUnitarioKmFlete 118 costoKilometro: $scope.notaPedido.costoUnitarioKmFlete
119 }; 119 };
120 crearNotaPedidoService.crearFlete(flete); 120 crearNotaPedidoService.crearFlete(flete);
121 } 121 }
122 var articulosNotaPedido = $scope.articulosTabla; 122 var articulosNotaPedido = $scope.articulosTabla;
123 for(var i = 0; i < articulosNotaPedido.length; i++) { 123 for(var i = 0; i < articulosNotaPedido.length; i++) {
124 delete articulosNotaPedido[i].edit; 124 delete articulosNotaPedido[i].edit;
125 articulosNotaPedido[i].idNotaPedido = data.data.id; 125 articulosNotaPedido[i].idNotaPedido = data.data.id;
126 crearNotaPedidoService 126 crearNotaPedidoService
127 .crearArticulosParaNotaPedido(articulosNotaPedido[i]); 127 .crearArticulosParaNotaPedido(articulosNotaPedido[i]);
128 } 128 }
129 $scope.limpiarPantalla(); 129 $scope.limpiarPantalla();
130 } 130 }
131 ); 131 );
132 }; 132 };
133 133
134 $scope.seleccionarArticulo = function() { 134 $scope.seleccionarArticulo = function() {
135 if (idLista === undefined) { 135 if (idLista === undefined) {
136 focaModalService.alert( 136 focaModalService.alert(
137 'Primero seleccione una lista de precio y condicion'); 137 'Primero seleccione una lista de precio y condicion');
138 return; 138 return;
139 } 139 }
140 var modalInstance = $uibModal.open( 140 var modalInstance = $uibModal.open(
141 { 141 {
142 ariaLabelledBy: 'Busqueda de Productos', 142 ariaLabelledBy: 'Busqueda de Productos',
143 templateUrl: 'modal-busqueda-productos.html', 143 templateUrl: 'modal-busqueda-productos.html',
144 controller: 'modalBusquedaProductosCtrl', 144 controller: 'modalBusquedaProductosCtrl',
145 resolve: { idLista: function() { return idLista; } }, 145 resolve: { idLista: function() { return idLista; } },
146 size: 'lg' 146 size: 'lg'
147 } 147 }
148 ); 148 );
149 modalInstance.result.then( 149 modalInstance.result.then(
150 function(producto) { 150 function(producto) {
151 var newArt = 151 var newArt =
152 { 152 {
153 id: 0, 153 id: 0,
154 codigo: producto.codigo, 154 codigo: producto.codigo,
155 sector: producto.sector, 155 sector: producto.sector,
156 sectorCodigo: producto.sector + '-' + producto.codigo,
156 descripcion: producto.descripcion, 157 descripcion: producto.descripcion,
157 item: $scope.articulosTabla.length + 1, 158 item: $scope.articulosTabla.length + 1,
158 nombre: producto.descripcion, 159 nombre: producto.descripcion,
159 precio: producto.precio.toFixed(2), 160 precio: producto.precio.toFixed(2),
160 costoUnitario: producto.costo, 161 costoUnitario: producto.costo,
161 edit: false 162 edit: false
162 }; 163 };
163 $scope.articuloACargar = newArt; 164 $scope.articuloACargar = newArt;
164 $scope.cargando = false; 165 $scope.cargando = false;
165 }, function() { 166 }, function() {
166 // funcion ejecutada cuando se cancela el modal 167 // funcion ejecutada cuando se cancela el modal
167 } 168 }
168 ); 169 );
169 }; 170 };
170 171
171 $scope.seleccionarVendedor = function() { 172 $scope.seleccionarVendedor = function() {
172 var modalInstance = $uibModal.open( 173 var modalInstance = $uibModal.open(
173 { 174 {
174 ariaLabelledBy: 'Busqueda de Vendedores', 175 ariaLabelledBy: 'Busqueda de Vendedores',
175 templateUrl: 'modal-vendedores.html', 176 templateUrl: 'modal-vendedores.html',
176 controller: 'modalVendedoresCtrl', 177 controller: 'modalVendedoresCtrl',
177 size: 'lg' 178 size: 'lg'
178 } 179 }
179 ); 180 );
180 modalInstance.result.then( 181 modalInstance.result.then(
181 function(vendedor) { 182 function(vendedor) {
182 addCabecera('Vendedor:', vendedor.NomVen); 183 addCabecera('Vendedor:', vendedor.NomVen);
183 $scope.notaPedido.vendedor.nombre = vendedor.NomVen; 184 $scope.notaPedido.vendedor.nombre = vendedor.NomVen;
184 }, function() { 185 }, function() {
185 186
186 } 187 }
187 ); 188 );
188 }; 189 };
189 190
190 $scope.seleccionarPetrolera = function() { 191 $scope.seleccionarPetrolera = function() {
191 var modalInstance = $uibModal.open( 192 var modalInstance = $uibModal.open(
192 { 193 {
193 ariaLabelledBy: 'Busqueda de Petrolera', 194 ariaLabelledBy: 'Busqueda de Petrolera',
194 templateUrl: 'modal-petroleras.html', 195 templateUrl: 'modal-petroleras.html',
195 controller: 'modalPetrolerasCtrl', 196 controller: 'modalPetrolerasCtrl',
196 size: 'lg' 197 size: 'lg'
197 } 198 }
198 ); 199 );
199 modalInstance.result.then( 200 modalInstance.result.then(
200 function(petrolera) { 201 function(petrolera) {
201 $scope.notaPedido.petrolera = petrolera.NOM; 202 $scope.notaPedido.petrolera = petrolera.NOM;
202 }, function() { 203 }, function() {
203 204
204 } 205 }
205 ); 206 );
206 }; 207 };
207 208
208 $scope.seleccionarCliente = function() { 209 $scope.seleccionarCliente = function() {
209 var modalInstance = $uibModal.open( 210 var modalInstance = $uibModal.open(
210 { 211 {
211 ariaLabelledBy: 'Busqueda de Cliente', 212 ariaLabelledBy: 'Busqueda de Cliente',
212 templateUrl: 'foca-busqueda-cliente-modal.html', 213 templateUrl: 'foca-busqueda-cliente-modal.html',
213 controller: 'focaBusquedaClienteModalController', 214 controller: 'focaBusquedaClienteModalController',
214 size: 'lg' 215 size: 'lg'
215 } 216 }
216 ); 217 );
217 modalInstance.result.then( 218 modalInstance.result.then(
218 function(cliente) { 219 function(cliente) {
219 $scope.notaPedido.cliente.nombre = cliente.nom; 220 $scope.notaPedido.cliente.nombre = cliente.nom;
220 $scope.notaPedido.cliente.id = cliente.cod; 221 $scope.notaPedido.cliente.id = cliente.cod;
221 crearNotaPedidoService.getDomiciliosByIdCliente(cliente.cod).then( 222 crearNotaPedidoService.getDomiciliosByIdCliente(cliente.cod).then(
222 function(data) { 223 function(data) {
223 if(data.data.length === 0){ 224 if(data.data.length === 0){
224 focaModalService 225 focaModalService
225 .alert('El cliente no tienen domicilios de entrega') 226 .alert('El cliente no tienen domicilios de entrega')
226 .then( 227 .then(
227 function() { 228 function() {
228 $scope.seleccionarCliente(); 229 $scope.seleccionarCliente();
229 $scope.notaPedido.cliente = {nombre: ''}; 230 $scope.notaPedido.cliente = {nombre: ''};
230 } 231 }
231 ); 232 );
232 return; 233 return;
233 } 234 }
234 var modalInstanceDomicilio = $uibModal.open( 235 var modalInstanceDomicilio = $uibModal.open(
235 { 236 {
236 ariaLabelledBy: 'Busqueda de Domicilios', 237 ariaLabelledBy: 'Busqueda de Domicilios',
237 templateUrl: 'modal-domicilio.html', 238 templateUrl: 'modal-domicilio.html',
238 controller: 'focaModalDomicilioController', 239 controller: 'focaModalDomicilioController',
239 resolve: { idCliente: function() { return cliente.cod; }}, 240 resolve: { idCliente: function() { return cliente.cod; }},
240 size: 'lg', 241 size: 'lg',
241 backdrop: 'static', 242 backdrop: 'static',
242 } 243 }
243 ); 244 );
244 modalInstanceDomicilio.result.then( 245 modalInstanceDomicilio.result.then(
245 function(domicilio) { 246 function(domicilio) {
246 focaModalService.alert('Domicilio elegido' + domicilio.dom); 247 focaModalService.alert('Domicilio elegido' + domicilio.dom);
247 }, function() { 248 }, function() {
248 $scope.notaPedido.cliente.nombre = ''; 249 $scope.notaPedido.cliente.nombre = '';
249 $scope.notaPedido.cliente.id = ''; 250 $scope.notaPedido.cliente.id = '';
250 removeCabecera('Cliente:'); 251 removeCabecera('Cliente:');
251 $scope.seleccionarCliente(); 252 $scope.seleccionarCliente();
252 return; 253 return;
253 } 254 }
254 ); 255 );
255 } 256 }
256 ); 257 );
257 addCabecera('Cliente:', cliente.nom); 258 addCabecera('Cliente:', cliente.nom);
258 }, function() { 259 }, function() {
259 260
260 } 261 }
261 ); 262 );
262 }; 263 };
263 264
264 $scope.mostrarFichaCliente = function() { 265 $scope.mostrarFichaCliente = function() {
265 $uibModal.open( 266 $uibModal.open(
266 { 267 {
267 ariaLabelledBy: 'Datos del Cliente', 268 ariaLabelledBy: 'Datos del Cliente',
268 templateUrl: 'foca-crear-nota-pedido-ficha-cliente.html', 269 templateUrl: 'foca-crear-nota-pedido-ficha-cliente.html',
269 controller: 'focaCrearNotaPedidoFichaClienteController', 270 controller: 'focaCrearNotaPedidoFichaClienteController',
270 size: 'lg' 271 size: 'lg'
271 } 272 }
272 ); 273 );
273 }; 274 };
274 275
275 $scope.getTotal = function() { 276 $scope.getTotal = function() {
276 var total = 0; 277 var total = 0;
277 var arrayTempArticulos = $scope.articulosTabla; 278 var arrayTempArticulos = $scope.articulosTabla;
278 for (var i = 0; i < arrayTempArticulos.length; i++) { 279 for (var i = 0; i < arrayTempArticulos.length; i++) {
279 total += arrayTempArticulos[i].precio * arrayTempArticulos[i].cantidad; 280 total += arrayTempArticulos[i].precio * arrayTempArticulos[i].cantidad;
280 } 281 }
281 return total.toFixed(2); 282 return total.toFixed(2);
282 }; 283 };
283 284
284 $scope.getSubTotal = function() { 285 $scope.getSubTotal = function() {
285 if($scope.articuloACargar) { 286 if($scope.articuloACargar) {
286 return $scope.articuloACargar.precio * $scope.articuloACargar.cantidad; 287 return $scope.articuloACargar.precio * $scope.articuloACargar.cantidad;
287 } 288 }
288 }; 289 };
289 290
290 $scope.abrirModalListaPrecio = function() { 291 $scope.abrirModalListaPrecio = function() {
291 var modalInstance = $uibModal.open( 292 var modalInstance = $uibModal.open(
292 { 293 {
293 ariaLabelledBy: 'Busqueda de Precio Condición', 294 ariaLabelledBy: 'Busqueda de Precio Condición',
294 templateUrl: 'modal-precio-condicion.html', 295 templateUrl: 'modal-precio-condicion.html',
295 controller: 'focaModalPrecioCondicionController', 296 controller: 'focaModalPrecioCondicionController',
296 size: 'lg' 297 size: 'lg'
297 } 298 }
298 ); 299 );
299 modalInstance.result.then( 300 modalInstance.result.then(
300 function(precioCondicion) { 301 function(precioCondicion) {
301 $scope.notaPedido.precioCondicion = precioCondicion.nombre; 302 $scope.notaPedido.precioCondicion = precioCondicion.nombre;
302 idLista = precioCondicion.idListaPrecio; 303 idLista = precioCondicion.idListaPrecio;
303 $scope.articulosTabla = []; 304 $scope.articulosTabla = [];
304 305
305 addCabecera('Precios y condiciones:', precioCondicion.nombre); 306 addCabecera('Precios y condiciones:', precioCondicion.nombre);
306 }, function() { 307 }, function() {
307 308
308 } 309 }
309 ); 310 );
310 }; 311 };
311 312
312 $scope.abrirModalFlete = function() { 313 $scope.abrirModalFlete = function() {
313 var modalInstance = $uibModal.open( 314 var modalInstance = $uibModal.open(
314 { 315 {
315 ariaLabelledBy: 'Busqueda de Flete', 316 ariaLabelledBy: 'Busqueda de Flete',
316 templateUrl: 'modal-flete.html', 317 templateUrl: 'modal-flete.html',
317 controller: 'focaModalFleteController', 318 controller: 'focaModalFleteController',
318 size: 'lg', 319 size: 'lg',
319 resolve: { 320 resolve: {
320 parametrosFlete: 321 parametrosFlete:
321 function() { 322 function() {
322 return { 323 return {
323 flete: $scope.notaPedido.flete, 324 flete: $scope.notaPedido.flete,
324 bomba: $scope.notaPedido.bomba, 325 bomba: $scope.notaPedido.bomba,
325 kilometros: $scope.notaPedido.kilometros 326 kilometros: $scope.notaPedido.kilometros
326 }; 327 };
327 } 328 }
328 } 329 }
329 } 330 }
330 ); 331 );
331 modalInstance.result.then( 332 modalInstance.result.then(
332 function(datos) { 333 function(datos) {
333 $scope.notaPedido.flete = datos.flete; 334 $scope.notaPedido.flete = datos.flete;
334 $scope.notaPedido.bomba = datos.bomba; 335 $scope.notaPedido.bomba = datos.bomba;
335 $scope.notaPedido.kilometros = datos.kilometros; 336 $scope.notaPedido.kilometros = datos.kilometros;
336 337
337 addCabecera('Flete:', datos.flete); 338 addCabecera('Flete:', datos.flete);
338 if(datos.flete === 'si') { 339 if(datos.flete === 'si') {
339 addCabecera('Bomba:', datos.bomba); 340 addCabecera('Bomba:', datos.bomba);
340 addCabecera('Kilometros:', datos.kilometros); 341 addCabecera('Kilometros:', datos.kilometros);
341 } else { 342 } else {
342 removeCabecera('Bomba:'); 343 removeCabecera('Bomba:');
343 removeCabecera('Kilometros:'); 344 removeCabecera('Kilometros:');
344 } 345 }
345 }, function() { 346 }, function() {
346 347
347 } 348 }
348 ); 349 );
349 }; 350 };
350 351
351 $scope.abrirModalMoneda = function() { 352 $scope.abrirModalMoneda = function() {
352 var modalInstance = $uibModal.open( 353 var modalInstance = $uibModal.open(
353 { 354 {
354 ariaLabelledBy: 'Busqueda de Moneda', 355 ariaLabelledBy: 'Busqueda de Moneda',
355 templateUrl: 'modal-moneda.html', 356 templateUrl: 'modal-moneda.html',
356 controller: 'focaModalMonedaController', 357 controller: 'focaModalMonedaController',
357 size: 'lg' 358 size: 'lg'
358 } 359 }
359 ); 360 );
360 modalInstance.result.then( 361 modalInstance.result.then(
361 function(moneda) { 362 function(moneda) {
362 $scope.notaPedido.moneda = { 363 $scope.notaPedido.moneda = {
363 id: moneda.ID, 364 id: moneda.ID,
364 detalle: moneda.DETALLE, 365 detalle: moneda.DETALLE,
365 simbolo: moneda.SIMBOLO 366 simbolo: moneda.SIMBOLO
366 }; 367 };
367 368
368 addCabecera('Moneda:', moneda.DETALLE); 369 addCabecera('Moneda:', moneda.DETALLE);
369 }, function() { 370 }, function() {
370 371
371 } 372 }
372 ); 373 );
373 }; 374 };
374 375
375 $scope.agregarATabla = function(key) { 376 $scope.agregarATabla = function(key) {
376 if(key === 13) { 377 if(key === 13) {
377 if($scope.articuloACargar.cantidad === undefined || 378 if($scope.articuloACargar.cantidad === undefined ||
378 $scope.articuloACargar.cantidad === 0 || 379 $scope.articuloACargar.cantidad === 0 ||
379 $scope.articuloACargar.cantidad === null ){ 380 $scope.articuloACargar.cantidad === null ){
380 focaModalService.alert('El valor debe ser al menos 1'); 381 focaModalService.alert('El valor debe ser al menos 1');
381 return; 382 return;
382 } 383 }
384 delete $scope.articuloACargar.sectorCodigo;
383 $scope.articulosTabla.unshift($scope.articuloACargar); 385 $scope.articulosTabla.unshift($scope.articuloACargar);
384 $scope.cargando = true; 386 $scope.cargando = true;
385 } 387 }
386 }; 388 };
387 389
388 $scope.quitarArticulo = function(key) { 390 $scope.quitarArticulo = function(key) {
389 $scope.articulosTabla.splice(key, 1); 391 $scope.articulosTabla.splice(key, 1);
390 }; 392 };
391 393
392 $scope.editarArticulo = function(key, articulo) { 394 $scope.editarArticulo = function(key, articulo) {
393 if(key === 13) { 395 if(key === 13) {
394 if(articulo.cantidad === null || articulo.cantidad === 0 || 396 if(articulo.cantidad === null || articulo.cantidad === 0 ||
395 articulo.cantidad === undefined){ 397 articulo.cantidad === undefined){
396 focaModalService.alert('El valor debe ser al menos 1'); 398 focaModalService.alert('El valor debe ser al menos 1');
397 return; 399 return;
398 } 400 }
399 articulo.edit = false; 401 articulo.edit = false;
400 } 402 }
401 }; 403 };
402 404
403 $scope.cambioEdit = function(articulo) { 405 $scope.cambioEdit = function(articulo) {
404 articulo.edit = true; 406 articulo.edit = true;
405 }; 407 };
406 408
407 $scope.limpiarFlete = function() { 409 $scope.limpiarFlete = function() {
408 $scope.notaPedido.fleteNombre = ''; 410 $scope.notaPedido.fleteNombre = '';
409 $scope.notaPedido.chofer = ''; 411 $scope.notaPedido.chofer = '';
410 $scope.notaPedido.vehiculo = ''; 412 $scope.notaPedido.vehiculo = '';
411 $scope.notaPedido.kilometros = ''; 413 $scope.notaPedido.kilometros = '';
412 $scope.notaPedido.costoUnitarioKmFlete = ''; 414 $scope.notaPedido.costoUnitarioKmFlete = '';
413 $scope.choferes = ''; 415 $scope.choferes = '';
414 $scope.vehiculos = ''; 416 $scope.vehiculos = '';
415 }; 417 };
416 418
417 $scope.limpiarPantalla = function() { 419 $scope.limpiarPantalla = function() {
418 $scope.limpiarFlete(); 420 $scope.limpiarFlete();
419 $scope.notaPedido.flete = '0'; 421 $scope.notaPedido.flete = '0';
420 $scope.notaPedido.bomba = '0'; 422 $scope.notaPedido.bomba = '0';
421 $scope.notaPedido.precioCondicion = ''; 423 $scope.notaPedido.precioCondicion = '';
422 $scope.articulosTabla = []; 424 $scope.articulosTabla = [];
423 $scope.notaPedido.vendedor.nombre = ''; 425 $scope.notaPedido.vendedor.nombre = '';
424 $scope.notaPedido.cliente = {nombre: ''}; 426 $scope.notaPedido.cliente = {nombre: ''};
425 $scope.notaPedido.domicilio = {dom: ''}; 427 $scope.notaPedido.domicilio = {dom: ''};
426 $scope.domiciliosCliente = []; 428 $scope.domiciliosCliente = [];
427 }; 429 };
428 430
429 $scope.resetFilter = function() { 431 $scope.resetFilter = function() {
430 $scope.articuloACargar = {}; 432 $scope.articuloACargar = {};
431 $scope.cargando = true; 433 $scope.cargando = true;
432 }; 434 };
433 435
434 $scope.selectFocus = function($event) { 436 $scope.selectFocus = function($event) {
435 $event.target.select(); 437 $event.target.select();
436 }; 438 };
437 439
438 $scope.salir = function() { 440 $scope.salir = function() {
439 $location.path('/'); 441 $location.path('/');
440 }; 442 };
441 443
442 function addCabecera(label, valor) { 444 function addCabecera(label, valor) {
443 var propiedad = $filter('filter')($scope.cabecera, {label: label}); 445 var propiedad = $filter('filter')($scope.cabecera, {label: label});
444 if(propiedad.length === 1) { 446 if(propiedad.length === 1) {
445 propiedad[0].valor = valor; 447 propiedad[0].valor = valor;
446 } else { 448 } else {
447 $scope.cabecera.push({label: label, valor: valor}); 449 $scope.cabecera.push({label: label, valor: valor});
448 } 450 }
449 } 451 }
450 452
451 function removeCabecera(label) { 453 function removeCabecera(label) {
452 var propiedad = $filter('filter')($scope.cabecera, {label: label}); 454 var propiedad = $filter('filter')($scope.cabecera, {label: label});
453 if(propiedad.length === 1){ 455 if(propiedad.length === 1){
454 $scope.cabecera.splice($scope.cabecera.indexOf(propiedad[0]), 1); 456 $scope.cabecera.splice($scope.cabecera.indexOf(propiedad[0]), 1);
455 } 457 }
456 } 458 }
457 } 459 }
458 ] 460 ]
459 ) 461 )
460 .controller('notaPedidoListaCtrl', [ 462 .controller('notaPedidoListaCtrl', [
461 '$scope', 463 '$scope',
462 'crearNotaPedidoService', 464 'crearNotaPedidoService',
463 '$location', 465 '$location',
464 function($scope, crearNotaPedidoService, $location) { 466 function($scope, crearNotaPedidoService, $location) {
465 crearNotaPedidoService.obtenerNotaPedido().then(function(datos) { 467 crearNotaPedidoService.obtenerNotaPedido().then(function(datos) {
466 $scope.notaPedidos = datos.data; 468 $scope.notaPedidos = datos.data;
467 }); 469 });
468 $scope.editar = function(notaPedido) { 470 $scope.editar = function(notaPedido) {
469 crearNotaPedidoService.setNotaPedido(notaPedido); 471 crearNotaPedidoService.setNotaPedido(notaPedido);
470 $location.path('/venta-nota-pedido/abm/'); 472 $location.path('/venta-nota-pedido/abm/');
471 }; 473 };
472 $scope.crearPedido = function() { 474 $scope.crearPedido = function() {
473 crearNotaPedidoService.clearNotaPedido(); 475 crearNotaPedidoService.clearNotaPedido();
474 $location.path('/venta-nota-pedido/abm/'); 476 $location.path('/venta-nota-pedido/abm/');
475 }; 477 };
476 } 478 }
477 ]) 479 ])
478 .controller('focaCrearNotaPedidoFichaClienteController', [ 480 .controller('focaCrearNotaPedidoFichaClienteController', [
479 '$scope', 481 '$scope',
480 'crearNotaPedidoService', 482 'crearNotaPedidoService',
481 '$location', 483 '$location',
482 function($scope, crearNotaPedidoService, $location) { 484 function($scope, crearNotaPedidoService, $location) {
483 crearNotaPedidoService.obtenerNotaPedido().then(function(datos) { 485 crearNotaPedidoService.obtenerNotaPedido().then(function(datos) {
484 $scope.notaPedidos = datos.data; 486 $scope.notaPedidos = datos.data;
485 }); 487 });
486 $scope.editar = function(notaPedido) { 488 $scope.editar = function(notaPedido) {
487 crearNotaPedidoService.setNotaPedido(notaPedido); 489 crearNotaPedidoService.setNotaPedido(notaPedido);
488 $location.path('/venta-nota-pedido/abm/'); 490 $location.path('/venta-nota-pedido/abm/');
489 }; 491 };
490 $scope.crearPedido = function() { 492 $scope.crearPedido = function() {
491 crearNotaPedidoService.clearNotaPedido(); 493 crearNotaPedidoService.clearNotaPedido();
492 $location.path('/venta-nota-pedido/abm/'); 494 $location.path('/venta-nota-pedido/abm/');
493 }; 495 };
494 } 496 }
495 ]); 497 ]);
496 498
src/views/nota-pedido.html
1 <div class="crear-nota-pedido"> 1 <div class="crear-nota-pedido">
2 <form name="formCrearNota" ng-submit="crearNotaPedido()"> 2 <form name="formCrearNota" ng-submit="crearNotaPedido()">
3 <div class="row"> 3 <div class="row">
4 <div class="col-md-10 offset-md-1 col-lg-8 offset-lg-2"> 4 <div class="col-md-10 offset-md-1 col-lg-8 offset-lg-2">
5 <div class="row p-1 panel-informativo"> 5 <div class="row p-1 panel-informativo">
6 <div class="col-12"> 6 <div class="col-12">
7 <div class="row"> 7 <div class="row">
8 <div class="col-5"> 8 <div class="col-5">
9 <div class="h4">NOTA DE PEDIDO</div> 9 <div class="h6">NOTA DE PEDIDO</div>
10 </div> 10 </div>
11 <div class="col-3">Nº {{puntoVenta}}-{{comprobante}}</div> 11 <div class="col-3">Nº {{puntoVenta}}-{{comprobante}}</div>
12 <div class="col-4 text-right"> 12 <div class="col-4 text-right">
13 Fecha: {{ now | date:'dd/MM/yyyy HH:mm'}} 13 Fecha: {{ now | date:'dd/MM/yyyy HH:mm'}}
14 </div> 14 </div>
15 </div> 15 </div>
16 <div class="row"> 16 <div class="row">
17 <div class="col-auto" ng-repeat="cab in cabecera"> 17 <div class="col-auto" ng-repeat="cab in cabecera">
18 <span class="label" ng-bind="cab.label"></span> 18 <span class="label" ng-bind="cab.label"></span>
19 <span class="valor" ng-bind="cab.valor"></span> 19 <span class="valor" ng-bind="cab.valor"></span>
20 </div> 20 </div>
21 </div> 21 </div>
22 </div> 22 </div>
23 </div> 23 </div>
24 <div class="row p-1 botonera-secundaria"> 24 <div class="row p-1 botonera-secundaria">
25 <div class="col-12"> 25 <div class="col-12">
26 <div class="row"> 26 <div class="row">
27 <div class="col-3 px-0 py-0" ng-repeat="boton in botonera"> 27 <div class="col-3 px-0 py-0" ng-repeat="boton in botonera">
28 <button 28 <button
29 type="button" 29 type="button"
30 class="btn btn-default btn-block btn-xs text-left py-2" 30 class="btn btn-default btn-block btn-xs text-left py-2"
31 ng-click="boton.accion()" 31 ng-click="boton.accion()"
32 > 32 >
33 <i 33 <i
34 class="fa fa-arrow-circle-right" 34 class="fa fa-arrow-circle-right"
35 ng-show="boton.texto != ''" 35 ng-show="boton.texto != ''"
36 ></i> 36 ></i>
37 &nbsp; 37 &nbsp;
38 {{boton.texto}} 38 {{boton.texto}}
39 </button> 39 </button>
40 </div> 40 </div>
41 </div> 41 </div>
42 </div> 42 </div>
43 </div> 43 </div>
44 </div> 44 </div>
45 </div> 45 </div>
46 </form> 46 </form>
47 <div class="row"> 47 <div class="row">
48 <div class="col-md-10 col-lg-8 offset-md-1 offset-lg-2"> 48 <div class="col-md-10 col-lg-8 offset-md-1 offset-lg-2">
49 <div class="row grilla-articulos align-items-end"> 49 <div class="row grilla-articulos align-items-end">
50 <table class="table table-striped table-sm table-dark"> 50 <table class="table table-striped table-sm table-dark">
51 <thead> 51 <thead>
52 <tr> 52 <tr>
53 <th>Código</th> 53 <th>Código</th>
54 <th>Descripción</th> 54 <th>Descripción</th>
55 <th>Cantidad</th> 55 <th>Cantidad</th>
56 <th>Precio Unitario</th> 56 <th>Precio Unitario</th>
57 <th>SubTotal</th> 57 <th>SubTotal</th>
58 <th> 58 <th>
59 <button 59 <button
60 class="btn btn-outline-secondary selectable" 60 class="btn btn-outline-secondary selectable"
61 style="float: right;" 61 style="float: right;"
62 ng-click="show = !show; masMenos()" 62 ng-click="show = !show; masMenos()"
63 > 63 >
64 <i 64 <i
65 class="fa fa-chevron-down" 65 class="fa fa-chevron-down"
66 ng-hide="show" 66 ng-hide="show"
67 aria-hidden="true" 67 aria-hidden="true"
68 > 68 >
69 </i> 69 </i>
70 <i 70 <i
71 class="fa fa-chevron-up" 71 class="fa fa-chevron-up"
72 ng-show="show" 72 ng-show="show"
73 aria-hidden="true"> 73 aria-hidden="true">
74 </i> 74 </i>
75 </button> 75 </button>
76 </th> 76 </th>
77 </tr> 77 </tr>
78 </thead> 78 </thead>
79 <tbody> 79 <tbody>
80 <tr ng-show="!cargando"> 80 <tr ng-show="!cargando">
81 <td><input 81 <td><input
82 class="form-control" 82 class="form-control"
83 ng-model="articuloACargar.sector + '-' + articuloACargar.codigo" 83 ng-model="articuloACargar.sectorCodigo"
84 readonly></td> 84 readonly></td>
85 <td><input 85 <td><input
86 class="form-control" 86 class="form-control"
87 ng-model="articuloACargar.descripcion" 87 ng-model="articuloACargar.descripcion"
88 readonly></td> 88 readonly></td>
89 <td class="text-right"><input 89 <td class="text-right"><input
90 class="form-control" 90 class="form-control"
91 type="number" 91 type="number"
92 min="1" 92 min="1"
93 ng-model="articuloACargar.cantidad" 93 ng-model="articuloACargar.cantidad"
94 foca-focus="!cargando" 94 foca-focus="!cargando"
95 esc-key="resetFilter()" 95 esc-key="resetFilter()"
96 ng-keypress="agregarATabla($event.keyCode)"></td> 96 ng-keypress="agregarATabla($event.keyCode)"></td>
97 <td class="text-right"><input 97 <td class="text-right"><input
98 class="form-control" 98 class="form-control"
99 ng-value="articuloACargar.precio | currency: '$'" 99 ng-value="articuloACargar.precio | currency: '$'"
100 readonly></td> 100 readonly></td>
101 <td class="text-right"><input 101 <td class="text-right"><input
102 class="form-control" 102 class="form-control"
103 ng-value="getSubTotal() | currency: '$'" 103 ng-value="getSubTotal() | currency: '$'"
104 readonly></td> 104 readonly></td>
105 <td class="text-center"><button 105 <td class="text-center"><button
106 class="btn btn-outline-secondary btn-sm" 106 class="btn btn-outline-secondary btn-sm"
107 ng-click="agregarATabla(13)"> 107 ng-click="agregarATabla(13)">
108 <i class="fa fa-save"></i> 108 <i class="fa fa-save"></i>
109 </button></td> 109 </button></td>
110 </tr> 110 </tr>
111 <tr 111 <tr
112 ng-repeat="(key, articulo) in articulosTabla" 112 ng-repeat="(key, articulo) in articulosTabla"
113 ng-show="show || key == 0" 113 ng-show="show || key == 0"
114 > 114 >
115 <td ng-bind="articulo.sector + '-' + articulo.codigo"></td> 115 <td ng-bind="articulo.sector + '-' + articulo.codigo"></td>
116 <td ng-bind="articulo.descripcion"></td> 116 <td ng-bind="articulo.descripcion"></td>
117 <td class="text-right"><input 117 <td class="text-right"><input
118 ng-show="articulo.edit" 118 ng-show="articulo.edit"
119 ng-model="articulo.cantidad" 119 ng-model="articulo.cantidad"
120 class="form-control" 120 class="form-control"
121 type="number" 121 type="number"
122 min="1" 122 min="1"
123 foca-focus="articulo.edit" 123 foca-focus="articulo.edit"
124 ng-keypress="editarArticulo($event.keyCode, articulo)" 124 ng-keypress="editarArticulo($event.keyCode, articulo)"
125 ng-focus="selectFocus($event)" 125 ng-focus="selectFocus($event)"
126 > 126 >
127 <i 127 <i
128 class="selectable" 128 class="selectable"
129 ng-click="cambioEdit(articulo)" 129 ng-click="cambioEdit(articulo)"
130 ng-hide="articulo.edit" 130 ng-hide="articulo.edit"
131 ng-bind="articulo.cantidad"> 131 ng-bind="articulo.cantidad">
132 </i> 132 </i>
133 </td> 133 </td>
134 <td class="text-right" ng-bind="articulo.precio | currency: '$'"></td> 134 <td class="text-right" ng-bind="articulo.precio | currency: '$'"></td>
135 <td 135 <td
136 class="text-right" 136 class="text-right"
137 ng-bind="(articulo.precio * articulo.cantidad) | currency: '$'"> 137 ng-bind="(articulo.precio * articulo.cantidad) | currency: '$'">
138 </td> 138 </td>
139 <td class="text-center"> 139 <td class="text-center">
140 <button 140 <button
141 class="btn btn-outline-secondary btn-sm" 141 class="btn btn-outline-secondary btn-sm"
142 ng-click="quitarArticulo(key)" 142 ng-click="quitarArticulo(key)"
143 > 143 >
144 <i class="fa fa-trash"></i> 144 <i class="fa fa-trash"></i>
145 </button> 145 </button>
146 </td> 146 </td>
147 </tr> 147 </tr>
148 <tr ng-show="cargando"> 148 <tr ng-show="cargando">
149 <td colspan="6"> 149 <td colspan="6">
150 <input 150 <input
151 placeholder="Seleccione Articulo" 151 placeholder="Seleccione Articulo"
152 class="form-control form-control-sm" 152 class="form-control form-control-sm"
153 readonly 153 readonly
154 ng-click="seleccionarArticulo()" 154 ng-click="seleccionarArticulo()"
155 /> 155 />
156 </td> 156 </td>
157 </tr> 157 </tr>
158 </tbody> 158 </tbody>
159 <tfoot> 159 <tfoot>
160 <tr class=""> 160 <tr class="">
161 <td colspan="3"> 161 <td colspan="3">
162 <strong>Cantidad Items:</strong> 162 <strong>Cantidad Items:</strong>
163 <a ng-bind="articulosTabla.length"></a> 163 <a ng-bind="articulosTabla.length"></a>
164 </td> 164 </td>
165 <td class="text-right table-celda-total"><h3>Total:</h3></td> 165 <td class="text-right table-celda-total"><h3>Total:</h3></td>
166 <td class="table-celda-total text-right" colspan="1"> 166 <td class="table-celda-total text-right" colspan="1">
167 <h3>{{getTotal() | currency: '$'}}</h3> 167 <h3>{{getTotal() | currency: '$'}}</h3>
168 </td> 168 </td>
169 <td colspan="2" class="text-right"> 169 <td colspan="2" class="text-right">
170 <button 170 <button
171 type="button" 171 type="button"
172 class="btn btn-default btn-sm" 172 class="btn btn-default btn-sm"
173 > 173 >
174 Totales 174 Totales
175 </button> 175 </button>
176 </td> 176 </td>
177 </tr> 177 </tr>
178 </tfoot> 178 </tfoot>
179 </table> 179 </table>
180 </div> 180 </div>
181 </div> 181 </div>
182 <div class="col-auto my-2 col-lg-2 botonera-lateral"> 182 <div class="col-auto my-2 col-lg-2 botonera-lateral">
183 <div class="row align-items-end"> 183 <div class="row align-items-end">
184 <div class="col-12"> 184 <div class="col-12">
185 <button 185 <button
186 ng-click="crearNotaPedido()" 186 ng-click="crearNotaPedido()"
187 type="submit" 187 type="submit"
188 title="Crear nota pedido" 188 title="Crear nota pedido"
189 class="btn btn-default btn-block mb-2"> 189 class="btn btn-default btn-block mb-2">
190 Guardar 190 Guardar
191 </button> 191 </button>
192 <button 192 <button
193 ng-click="salir()" 193 ng-click="salir()"
194 type="button" 194 type="button"
195 title="Salir" 195 title="Salir"
196 class="btn btn-default btn-block"> 196 class="btn btn-default btn-block">
197 Salir 197 Salir
198 </button> 198 </button>
199 </div> 199 </div>
200 </div> 200 </div>
201 </div> 201 </div>
202 </div> 202 </div>
203 </div> 203 </div>
204 <!-- 204 <!--
205 <form name="formCrearNota"> 205 <form name="formCrearNota">
206 <uib-tabset active="active"> 206 <uib-tabset active="active">
207 <uib-tab index="0" heading="General"> 207 <uib-tab index="0" heading="General">
208 <input type="hidden" name="id" ng-model="notaPedido.id" /> 208 <input type="hidden" name="id" ng-model="notaPedido.id" />
209 <div> 209 <div>
210 <div class="col-auto my-2"> 210 <div class="col-auto my-2">
211 <button type="submit" title="Siguiente" class="btn btn-primary float-right">Siguiente</button> 211 <button type="submit" title="Siguiente" class="btn btn-primary float-right">Siguiente</button>
212 </div> 212 </div>
213 </div> 213 </div>
214 <br> 214 <br>
215 <br> 215 <br>
216 <div class="row"> 216 <div class="row">
217 <div class="col-md-2"> 217 <div class="col-md-2">
218 <div class="col-auto"> 218 <div class="col-auto">
219 <label>Fecha de carga</label> 219 <label>Fecha de carga</label>
220 </div> 220 </div>
221 </div> 221 </div>
222 <div class="col-md-3"> 222 <div class="col-md-3">
223 <div class="col-auto"> 223 <div class="col-auto">
224 <input type="date" class="form-control" ng-model="notaPedido.fechaCarga" ng-required="true"> 224 <input type="date" class="form-control" ng-model="notaPedido.fechaCarga" ng-required="true">
225 </div> 225 </div>
226 </div> 226 </div>
227 <div class="col-md-2"> 227 <div class="col-md-2">
228 <div class="col-auto"> 228 <div class="col-auto">
229 <label>Kilómetros</label> 229 <label>Kilómetros</label>
230 </div> 230 </div>
231 </div> 231 </div>
232 <div class="col-md-3"> 232 <div class="col-md-3">
233 <div class="col-auto"> 233 <div class="col-auto">
234 <input type="number" min="0" step="0.01" class="form-control" placeholder="Kilómetros recorridos para la entrega en el cliente" 234 <input type="number" min="0" step="0.01" class="form-control" placeholder="Kilómetros recorridos para la entrega en el cliente"
235 ng-model="notaPedido.kilometros" ng-required="true"> 235 ng-model="notaPedido.kilometros" ng-required="true">
236 </div> 236 </div>
237 </div> 237 </div>
238 </div> 238 </div>
239 <div class="row my-3"> 239 <div class="row my-3">
240 <div class="col-md-2"> 240 <div class="col-md-2">
241 <div class="col-auto"> 241 <div class="col-auto">
242 <label>Jurisdicción de IIBB</label> 242 <label>Jurisdicción de IIBB</label>
243 </div> 243 </div>
244 </div> 244 </div>
245 <div class="col-md-3"> 245 <div class="col-md-3">
246 <div class="col-auto"> 246 <div class="col-auto">
247 <input type="text" class="form-control" placeholder="Jurisdicción de IIBB donde se realiza la entrega" 247 <input type="text" class="form-control" placeholder="Jurisdicción de IIBB donde se realiza la entrega"
248 ng-model="notaPedido.jurisdiccionIIBB" ng-required="true"> 248 ng-model="notaPedido.jurisdiccionIIBB" ng-required="true">
249 </div> 249 </div>
250 </div> 250 </div>
251 <div class="col-md-2"> 251 <div class="col-md-2">
252 <div class="col-auto"> 252 <div class="col-auto">
253 <label>Costo de financiación</label> 253 <label>Costo de financiación</label>
254 </div> 254 </div>
255 </div> 255 </div>
256 <div class="col-md-3"> 256 <div class="col-md-3">
257 <div class="col-auto"> 257 <div class="col-auto">
258 <div class="input-group mb-2"> 258 <div class="input-group mb-2">
259 <div class="input-group-prepend"> 259 <div class="input-group-prepend">
260 <div class="input-group-text">$</div> 260 <div class="input-group-text">$</div>
261 </div> 261 </div>
262 <input type="number" min="0" step="0.01" class="form-control" placeholder="Costo de financiación" 262 <input type="number" min="0" step="0.01" class="form-control" placeholder="Costo de financiación"
263 ng-model="notaPedido.costoFinanciacion"> 263 ng-model="notaPedido.costoFinanciacion">
264 </div> 264 </div>
265 </div> 265 </div>
266 </div> 266 </div>
267 </div> 267 </div>
268 <div class="row"> 268 <div class="row">
269 <div class="col-md-2"> 269 <div class="col-md-2">
270 <div class="col-auto"> 270 <div class="col-auto">
271 <label>Bomba</label> 271 <label>Bomba</label>
272 </div> 272 </div>
273 </div> 273 </div>
274 <div class="col-md-1"> 274 <div class="col-md-1">
275 <div class="col-auto"> 275 <div class="col-auto">
276 <div class="form-check custom-radio custom-control-inline"> 276 <div class="form-check custom-radio custom-control-inline">
277 <input class="form-check-input" type="radio" name="radioBomba" value="1" ng-model="notaPedido.bomba"> 277 <input class="form-check-input" type="radio" name="radioBomba" value="1" ng-model="notaPedido.bomba">
278 <label class="form-check-label"> 278 <label class="form-check-label">
279 Si 279 Si
280 </label> 280 </label>
281 </div> 281 </div>
282 <div class="form-check custom-radio custom-control-inline"> 282 <div class="form-check custom-radio custom-control-inline">
283 <input class="form-check-input" type="radio" name="radioBomba" value="0" ng-model="notaPedido.bomba"> 283 <input class="form-check-input" type="radio" name="radioBomba" value="0" ng-model="notaPedido.bomba">
284 <label class="form-check-label"> 284 <label class="form-check-label">
285 No 285 No
286 </label> 286 </label>
287 </div> 287 </div>
288 </div> 288 </div>
289 </div> 289 </div>
290 <div class="col-md-1"> 290 <div class="col-md-1">
291 <div class="col-auto"> 291 <div class="col-auto">
292 <label>Flete</label> 292 <label>Flete</label>
293 </div> 293 </div>
294 </div> 294 </div>
295 <div class="col-md-1"> 295 <div class="col-md-1">
296 <div class="col-auto"> 296 <div class="col-auto">
297 <div class="form-check custom-radio custom-control-inline"> 297 <div class="form-check custom-radio custom-control-inline">
298 <input class="form-check-input" type="radio" name="radioFlete" value="1" ng-model="notaPedido.flete"> 298 <input class="form-check-input" type="radio" name="radioFlete" value="1" ng-model="notaPedido.flete">
299 <label class="form-check-label"> 299 <label class="form-check-label">
300 Si 300 Si
301 </label> 301 </label>
302 </div> 302 </div>
303 <div class="form-check custom-radio custom-control-inline"> 303 <div class="form-check custom-radio custom-control-inline">
304 <input class="form-check-input" type="radio" name="radioFlete" value="0" ng-model="notaPedido.flete"> 304 <input class="form-check-input" type="radio" name="radioFlete" value="0" ng-model="notaPedido.flete">
305 <label class="form-check-label"> 305 <label class="form-check-label">
306 FOB 306 FOB
307 </label> 307 </label>
308 </div> 308 </div>
309 </div> 309 </div>
310 </div> 310 </div>
311 <div class="col-md-2"> 311 <div class="col-md-2">
312 <div class="col-auto"> 312 <div class="col-auto">
313 <label>Costo unitario kilometro flete</label> 313 <label>Costo unitario kilometro flete</label>
314 </div> 314 </div>
315 </div> 315 </div>
316 <div class="col-md-3"> 316 <div class="col-md-3">
317 <div class="col-auto"> 317 <div class="col-auto">
318 <div class="input-group mb-2"> 318 <div class="input-group mb-2">
319 <div class="input-group-prepend"> 319 <div class="input-group-prepend">
320 <div class="input-group-text">$</div> 320 <div class="input-group-text">$</div>
321 </div> 321 </div>
322 <input type="number" min="0" step="0.01" class="form-control" placeholder="Costo unitario del kilometro del flete" 322 <input type="number" min="0" step="0.01" class="form-control" placeholder="Costo unitario del kilometro del flete"
323 ng-model="notaPedido.costoUnitarioKmFlete" ng-required="true"> 323 ng-model="notaPedido.costoUnitarioKmFlete" ng-required="true">
324 </div> 324 </div>
325 </div> 325 </div>
326 </div> 326 </div>
327 </div> 327 </div>
328 <div class="row my-3"> 328 <div class="row my-3">
329 <div class="col-md-2"> 329 <div class="col-md-2">
330 <div class="col-auto"> 330 <div class="col-auto">
331 <label>Vendedor</label> 331 <label>Vendedor</label>
332 </div> 332 </div>
333 </div> 333 </div>
334 <div class="col-md-3"> 334 <div class="col-md-3">
335 <div class="col-auto"> 335 <div class="col-auto">
336 <input type="text" class="form-control" placeholder="Seleccione vendedor" ng-model="notaPedido.vendedor" 336 <input type="text" class="form-control" placeholder="Seleccione vendedor" ng-model="notaPedido.vendedor"
337 ng-click="seleccionarVendedor()" readonly> 337 ng-click="seleccionarVendedor()" readonly>
338 </div> 338 </div>
339 </div> 339 </div>
340 <div class="col-md-2"> 340 <div class="col-md-2">
341 <div class="col-auto"> 341 <div class="col-auto">
342 <label>Petrolera</label> 342 <label>Petrolera</label>
343 </div> 343 </div>
344 </div> 344 </div>
345 <div class="col-md-3"> 345 <div class="col-md-3">
346 <div class="col-auto"> 346 <div class="col-auto">
347 <input type="text" class="form-control" placeholder="Seleccione petrolera" ng-model="notaPedido.petrolera" 347 <input type="text" class="form-control" placeholder="Seleccione petrolera" ng-model="notaPedido.petrolera"
348 ng-click="seleccionarPetrolera()" readonly> 348 ng-click="seleccionarPetrolera()" readonly>
349 </div> 349 </div>
350 </div> 350 </div>
351 </div> 351 </div>
352 </div> 352 </div>
353 <div class="row"> 353 <div class="row">
354 <div class="col-md-2"> 354 <div class="col-md-2">
355 <div class="col-auto"> 355 <div class="col-auto">
356 <label>Cliente</label> 356 <label>Cliente</label>
357 </div> 357 </div>
358 </div> 358 </div>
359 <div class="col-md-3"> 359 <div class="col-md-3">
360 <div class="col-auto"> 360 <div class="col-auto">
361 <input type="text" class="form-control" placeholder="Seleccione cliente" ng-model="notaPedido.cliente" 361 <input type="text" class="form-control" placeholder="Seleccione cliente" ng-model="notaPedido.cliente"
362 ng-click="seleccionarCliente()" ng-change="obtenerDomicilios()" readonly> 362 ng-click="seleccionarCliente()" ng-change="obtenerDomicilios()" readonly>
363 </div> 363 </div>
364 </div> 364 </div>
365 <div class="col-md-2"> 365 <div class="col-md-2">
366 <div class="col-auto"> 366 <div class="col-auto">
367 <label>Domicilio</label> 367 <label>Domicilio</label>
368 </div> 368 </div>
369 </div> 369 </div>
370 <div class="col-md-4"> 370 <div class="col-md-4">
371 <div class="col-md-12 row" ng-repeat="domicilio in notaPedido.domicilio"> 371 <div class="col-md-12 row" ng-repeat="domicilio in notaPedido.domicilio">
372 <div class="col-auto"> 372 <div class="col-auto">
373 <input type="text" ng-model="domicilio.dom" placeholder="Domicilio" uib-typeahead=" 373 <input type="text" ng-model="domicilio.dom" placeholder="Domicilio" uib-typeahead="
374 domi.dom 374 domi.dom
375 for domi 375 for domi
376 in domiciliosCliente 376 in domiciliosCliente
377 " 377 "
378 typeahead-no-results="sinResultados" typeahead-min-length="0" typeahead-on-select="seleccionar($item)" 378 typeahead-no-results="sinResultados" typeahead-min-length="0" typeahead-on-select="seleccionar($item)"
379 class="form-control mb-2" ng-disabled="domicilio.id > 0" ng-required="true"> 379 class="form-control mb-2" ng-disabled="domicilio.id > 0" ng-required="true">
380 <i ng-show="cargandoClientes" class="fas fa-sync"></i> 380 <i ng-show="cargandoClientes" class="fas fa-sync"></i>
381 <div ng-show="sinResultados"> 381 <div ng-show="sinResultados">
382 No se encontraron resultados. 382 No se encontraron resultados.
383 </div> 383 </div>
384 </div> 384 </div>
385 <a class="btn" ng-click="removeNewChoice(domicilio)" ng-if="domicilio.id==0">-</a> 385 <a class="btn" ng-click="removeNewChoice(domicilio)" ng-if="domicilio.id==0">-</a>
386 <a class="btn" ng-click="addNewDom()">+</a> 386 <a class="btn" ng-click="addNewDom()">+</a>
387 </div> 387 </div>
388 </div> 388 </div>
389 </div> 389 </div>
390 </uib-tab> 390 </uib-tab>
391 <uib-tab index="1" heading="Producto" disable="formCrearNota.$invalid"> 391 <uib-tab index="1" heading="Producto" disable="formCrearNota.$invalid">
392 <div> 392 <div>
393 <div class="col-auto my-2"> 393 <div class="col-auto my-2">
394 <button ng-click="crearNotaPedido()" type="button" title="Crear nota pedido" class="btn btn-primary float-right">Crear</button> 394 <button ng-click="crearNotaPedido()" type="button" title="Crear nota pedido" class="btn btn-primary float-right">Crear</button>
395 </div> 395 </div>
396 </div> 396 </div>
397 <br> 397 <br>
398 <br> 398 <br>
399 <div class="row"> 399 <div class="row">
400 <div class="col-md-2"> 400 <div class="col-md-2">
401 <div class="col-auto"> 401 <div class="col-auto">
402 <label>Precios y condiciones</label> 402 <label>Precios y condiciones</label>
403 </div> 403 </div>
404 </div> 404 </div>
405 <div class="col-md-4"> 405 <div class="col-md-4">
406 <div class="col-auto"> 406 <div class="col-auto">
407 <select class="form-control" ng-change="cargarArticulos()" ng-model="notaPedido.precioCondicion" ng-options="preCond.id as preCond.nombre for preCond in precioCondiciones"> 407 <select class="form-control" ng-change="cargarArticulos()" ng-model="notaPedido.precioCondicion" ng-options="preCond.id as preCond.nombre for preCond in precioCondiciones">
408 </select> 408 </select>
409 </div> 409 </div>
410 </div> 410 </div>
411 <div class="col-md-2"> 411 <div class="col-md-2">
412 <div class="col-auto"> 412 <div class="col-auto">
413 <label>Producto</label> 413 <label>Producto</label>
414 </div> 414 </div>
415 </div> 415 </div>
416 <div class="col-md-4"> 416 <div class="col-md-4">
417 <div class="col-auto"> 417 <div class="col-auto">
418 <input type="text" class="form-control" placeholder="Seleccione producto" ng-model="notaPedido.producto" 418 <input type="text" class="form-control" placeholder="Seleccione producto" ng-model="notaPedido.producto"
419 ng-click="seleccionarArticulo()" readonly> 419 ng-click="seleccionarArticulo()" readonly>
420 </div> 420 </div>
421 </div> 421 </div>
422 </div> 422 </div>
423 <div class="col-md-12"> 423 <div class="col-md-12">
424 <table class="table my-3 table-hover table-nonfluid"> 424 <table class="table my-3 table-hover table-nonfluid">
425 <thead> 425 <thead>
426 <tr> 426 <tr>
427 <th>Código</th> 427 <th>Código</th>
428 <th>Nombre</th> 428 <th>Nombre</th>
429 <th>Precio unitario</th> 429 <th>Precio unitario</th>
430 <th>Costo unitario bruto</th> 430 <th>Costo unitario bruto</th>
431 <th>Cantidad</th> 431 <th>Cantidad</th>
432 <th>Subtotal</th> 432 <th>Subtotal</th>
433 </tr> 433 </tr>
434 </thead> 434 </thead>
435 <tbody> 435 <tbody>
436 <tr ng-repeat="articulo in articulosTabla"> 436 <tr ng-repeat="articulo in articulosTabla">
437 <td ng-bind="articulo.codigo"></td> 437 <td ng-bind="articulo.codigo"></td>
438 <td ng-bind="articulo.nombre"></td> 438 <td ng-bind="articulo.nombre"></td>
439 <td ng-bind="articulo.precio"></td> 439 <td ng-bind="articulo.precio"></td>
440 <td ng-bind="articulo.costoUnitario"></td> 440 <td ng-bind="articulo.costoUnitario"></td>
441 <td><input ng-model="articulo.cantidad" class="form-control" type="number" min="0" value="1"></td> 441 <td><input ng-model="articulo.cantidad" class="form-control" type="number" min="0" value="1"></td>
442 <td ng-bind="getSubTotal(articulo.item)"></td> 442 <td ng-bind="getSubTotal(articulo.item)"></td>
443 </tr> 443 </tr>
444 </tbody> 444 </tbody>
445 </table> 445 </table>
446 </div> 446 </div>
447 </uib-tab> 447 </uib-tab>
448 </uib-tabset> 448 </uib-tabset>
449 </form>--> 449 </form>-->