Commit e700d7112a73b8ca1d3e769cd1cd85bb226d1990
Exists in
master
Merge branch 'master' into 'master'
Master(efernandez) See merge request modulos-npm/foca-crear-nota-pedido!15
Showing
4 changed files
Show diff stats
package.json
| 1 | { | 1 | { |
| 2 | "name": "foca-crear-nota-pedido", | 2 | "name": "foca-crear-nota-pedido", |
| 3 | "version": "0.0.1", | 3 | "version": "0.0.1", |
| 4 | "description": "Listado y ABM nota de pedidos", | 4 | "description": "Listado y ABM nota de pedidos", |
| 5 | "main": "index.js", | 5 | "main": "index.js", |
| 6 | "scripts": { | 6 | "scripts": { |
| 7 | "test": "echo \"Error: no test specified\" && exit 1", | 7 | "test": "echo \"Error: no test specified\" && exit 1", |
| 8 | "compile": "gulp uglify", | 8 | "compile": "gulp uglify", |
| 9 | "gulp-pre-commit": "gulp pre-commit", | 9 | "gulp-pre-commit": "gulp pre-commit", |
| 10 | "postinstall": "npm run compile && gulp clean-post-install", | 10 | "postinstall": "npm run compile && gulp clean-post-install", |
| 11 | "install-dev": "npm install -D jasmine-core pre-commit angular angular-route bootstrap ui-bootstrap4 font-awesome gulp gulp-angular-templatecache gulp-connect gulp-clean gulp-htmlmin gulp-jshint gulp-rename gulp-replace gulp-sequence gulp-uglify-es gulp-uglify jquery jshint pump git+https://debo.suite.repo/modulos-npm/foca-directivas.git git+https://debo.suite.repo/modulos-npm/foca-modal-vendedores.git git+https://debo.suite.repo/modulos-npm/foca-modal-petroleras.git git+https://debo.suite.repo/nguarnieri/foca-modal-busqueda-productos git+https://debo.suite.repo/modulos-npm/foca-busqueda-cliente.git git+https://debo.suite.repo/modulos-npm/foca-modal-precio-condiciones.git git+https://debo.suite.repo/modulos-npm/foca-modal-flete git+https://debo.suite.repo/modulos-npm/foca-modal.git" | 11 | "install-dev": "npm install -D jasmine-core pre-commit angular angular-route bootstrap ui-bootstrap4 font-awesome gulp gulp-angular-templatecache gulp-connect gulp-clean gulp-htmlmin gulp-jshint gulp-rename gulp-replace gulp-sequence gulp-uglify-es gulp-uglify jquery jshint pump git+https://debo.suite.repo/modulos-npm/foca-directivas.git git+https://debo.suite.repo/modulos-npm/foca-modal-vendedores.git git+https://debo.suite.repo/modulos-npm/foca-modal-petroleras.git git+https://debo.suite.repo/modulos-npm/foca-modal-busqueda-productos git+https://debo.suite.repo/modulos-npm/foca-busqueda-cliente.git git+https://debo.suite.repo/modulos-npm/foca-modal-precio-condiciones.git git+https://debo.suite.repo/modulos-npm/foca-modal-flete git+https://debo.suite.repo/modulos-npm/foca-modal.git" |
| 12 | }, | 12 | }, |
| 13 | "pre-commit": [ | 13 | "pre-commit": [ |
| 14 | "gulp-pre-commit" | 14 | "gulp-pre-commit" |
| 15 | ], | 15 | ], |
| 16 | "repository": { | 16 | "repository": { |
| 17 | "type": "git", | 17 | "type": "git", |
| 18 | "url": "https://debo.suite.repo/modulos-npm/foca-crear-nota-pedido.git" | 18 | "url": "https://debo.suite.repo/modulos-npm/foca-crear-nota-pedido.git" |
| 19 | }, | 19 | }, |
| 20 | "author": "Foca Software", | 20 | "author": "Foca Software", |
| 21 | "license": "ISC", | 21 | "license": "ISC", |
| 22 | "peerDependencies": { | 22 | "peerDependencies": { |
| 23 | "foca-busqueda-cliente": "git+https://debo.suite.repo/modulos-npm/foca-busqueda-cliente.git", | 23 | "foca-busqueda-cliente": "git+https://debo.suite.repo/modulos-npm/foca-busqueda-cliente.git", |
| 24 | "foca-directivas": "git+https://debo.suite.repo/modulos-npm/foca-directivas.git", | 24 | "foca-directivas": "git+https://debo.suite.repo/modulos-npm/foca-directivas.git", |
| 25 | "foca-modal-busqueda-productos": "git+https://debo.suite.repo/nguarnieri/foca-modal-busqueda-productos", | 25 | "foca-modal-busqueda-productos": "git+https://debo.suite.repo/modulos-npm/foca-modal-busqueda-productos", |
| 26 | "foca-modal-petroleras": "git+https://debo.suite.repo/modulos-npm/foca-modal-petroleras.git", | 26 | "foca-modal-petroleras": "git+https://debo.suite.repo/modulos-npm/foca-modal-petroleras.git", |
| 27 | "foca-modal-vendedores": "git+https://debo.suite.repo/modulos-npm/foca-modal-vendedores.git" | 27 | "foca-modal-vendedores": "git+https://debo.suite.repo/modulos-npm/foca-modal-vendedores.git" |
| 28 | }, | 28 | }, |
| 29 | "devDependencies": { | 29 | "devDependencies": { |
| 30 | "angular": "^1.7.5", | 30 | "angular": "^1.7.5", |
| 31 | "angular-route": "^1.7.5", | 31 | "angular-route": "^1.7.5", |
| 32 | "bootstrap": "^4.1.3", | 32 | "bootstrap": "^4.1.3", |
| 33 | "foca-busqueda-cliente": "git+https://debo.suite.repo/modulos-npm/foca-busqueda-cliente.git", | 33 | "foca-busqueda-cliente": "git+https://debo.suite.repo/modulos-npm/foca-busqueda-cliente.git", |
| 34 | "foca-directivas": "git+https://debo.suite.repo/modulos-npm/foca-directivas.git", | 34 | "foca-directivas": "git+https://debo.suite.repo/modulos-npm/foca-directivas.git", |
| 35 | "foca-modal": "git+https://debo.suite.repo/modulos-npm/foca-modal.git", | 35 | "foca-modal": "git+https://debo.suite.repo/modulos-npm/foca-modal.git", |
| 36 | "foca-modal-busqueda-productos": "git+https://debo.suite.repo/nguarnieri/foca-modal-busqueda-productos", | 36 | "foca-modal-busqueda-productos": "git+https://debo.suite.repo/modulos-npm/foca-modal-busqueda-productos", |
| 37 | "foca-modal-flete": "git+https://debo.suite.repo/modulos-npm/foca-modal-flete", | 37 | "foca-modal-flete": "git+https://debo.suite.repo/modulos-npm/foca-modal-flete", |
| 38 | "foca-modal-petroleras": "git+https://debo.suite.repo/modulos-npm/foca-modal-petroleras.git", | 38 | "foca-modal-petroleras": "git+https://debo.suite.repo/modulos-npm/foca-modal-petroleras.git", |
| 39 | "foca-modal-precio-condiciones": "git+https://debo.suite.repo/modulos-npm/foca-modal-precio-condiciones.git", | 39 | "foca-modal-precio-condiciones": "git+https://debo.suite.repo/modulos-npm/foca-modal-precio-condiciones.git", |
| 40 | "foca-modal-vendedores": "git+https://debo.suite.repo/modulos-npm/foca-modal-vendedores.git", | 40 | "foca-modal-vendedores": "git+https://debo.suite.repo/modulos-npm/foca-modal-vendedores.git", |
| 41 | "font-awesome": "^4.7.0", | 41 | "font-awesome": "^4.7.0", |
| 42 | "gulp": "^3.9.1", | 42 | "gulp": "^3.9.1", |
| 43 | "gulp-angular-templatecache": "2.2.2", | 43 | "gulp-angular-templatecache": "2.2.2", |
| 44 | "gulp-clean": "^0.4.0", | 44 | "gulp-clean": "^0.4.0", |
| 45 | "gulp-concat": "^2.6.1", | 45 | "gulp-concat": "^2.6.1", |
| 46 | "gulp-connect": "^5.6.1", | 46 | "gulp-connect": "^5.6.1", |
| 47 | "gulp-htmlmin": "^5.0.1", | 47 | "gulp-htmlmin": "^5.0.1", |
| 48 | "gulp-jshint": "^2.1.0", | 48 | "gulp-jshint": "^2.1.0", |
| 49 | "gulp-rename": "^1.4.0", | 49 | "gulp-rename": "^1.4.0", |
| 50 | "gulp-replace": "^1.0.0", | 50 | "gulp-replace": "^1.0.0", |
| 51 | "gulp-sequence": "^1.0.0", | 51 | "gulp-sequence": "^1.0.0", |
| 52 | "gulp-uglify": "^3.0.1", | 52 | "gulp-uglify": "^3.0.1", |
| 53 | "gulp-uglify-es": "^1.0.4", | 53 | "gulp-uglify-es": "^1.0.4", |
| 54 | "jasmine-core": "^3.2.1", | 54 | "jasmine-core": "^3.2.1", |
| 55 | "jquery": "^3.3.1", | 55 | "jquery": "^3.3.1", |
| 56 | "jshint": "^2.9.6", | 56 | "jshint": "^2.9.6", |
| 57 | "pre-commit": "^1.2.2", | 57 | "pre-commit": "^1.2.2", |
| 58 | "pump": "^3.0.0", | 58 | "pump": "^3.0.0", |
| 59 | "ui-bootstrap4": "^3.0.5" | 59 | "ui-bootstrap4": "^3.0.5" |
| 60 | } | 60 | } |
| 61 | } | 61 | } |
| 62 | 62 |
src/js/controller.js
| 1 | angular.module('focaCrearNotaPedido') | 1 | angular.module('focaCrearNotaPedido') |
| 2 | .controller('notaPedidoCtrl', | 2 | .controller('notaPedidoCtrl', |
| 3 | ['$scope', '$uibModal', '$location', 'crearNotaPedidoService', 'focaModalService', | 3 | ['$scope', '$uibModal', 'crearNotaPedidoService', 'focaModalService', |
| 4 | function($scope, $uibModal, $location, crearNotaPedidoService, focaModalService) { | 4 | function($scope, $uibModal, crearNotaPedidoService, focaModalService) { |
| 5 | $scope.show = false; | 5 | $scope.show = false; |
| 6 | $scope.cargando = true; | 6 | $scope.cargando = true; |
| 7 | $scope.dateOptions = { | 7 | $scope.dateOptions = { |
| 8 | maxDate: new Date(), | 8 | maxDate: new Date(), |
| 9 | minDate: new Date(2010, 0, 1) | 9 | minDate: new Date(2010, 0, 1) |
| 10 | }; | 10 | }; |
| 11 | $scope.notaPedido = { | 11 | $scope.notaPedido = { |
| 12 | vendedor: {}, | 12 | vendedor: {}, |
| 13 | cliente: {} | 13 | cliente: {}, |
| 14 | domicilio: { dom: ''} | ||
| 14 | }; | 15 | }; |
| 15 | $scope.articulosTabla = []; | 16 | $scope.articulosTabla = []; |
| 16 | var idLista; | 17 | var idLista; |
| 17 | var notaPedidoTemp = crearNotaPedidoService.getNotaPedido(); | 18 | var notaPedidoTemp = crearNotaPedidoService.getNotaPedido(); |
| 18 | $scope.domiciliosCliente = crearNotaPedidoService.getDomicilios(1); | ||
| 19 | crearNotaPedidoService.getPrecioCondicion().then( | 19 | crearNotaPedidoService.getPrecioCondicion().then( |
| 20 | function(res) { | 20 | function(res) { |
| 21 | $scope.precioCondiciones = res.data; | 21 | $scope.precioCondiciones = res.data; |
| 22 | } | 22 | } |
| 23 | ); | 23 | ); |
| 24 | if (notaPedidoTemp !== undefined) { | 24 | if (notaPedidoTemp !== undefined) { |
| 25 | notaPedidoTemp.fechaCarga = new Date(notaPedidoTemp.fechaCarga); | 25 | notaPedidoTemp.fechaCarga = new Date(notaPedidoTemp.fechaCarga); |
| 26 | $scope.notaPedido = notaPedidoTemp; | 26 | $scope.notaPedido = notaPedidoTemp; |
| 27 | $scope.notaPedido.flete = ($scope.notaPedido.flete).toString(); | 27 | $scope.notaPedido.flete = ($scope.notaPedido.flete).toString(); |
| 28 | $scope.notaPedido.bomba = ($scope.notaPedido.bomba).toString(); | 28 | $scope.notaPedido.bomba = ($scope.notaPedido.bomba).toString(); |
| 29 | idLista = $scope.notaPedido.precioCondicion; | 29 | idLista = $scope.notaPedido.precioCondicion; |
| 30 | crearNotaPedidoService | 30 | crearNotaPedidoService |
| 31 | .getArticulosByIdNotaPedido($scope.notaPedido.id).then( | 31 | .getArticulosByIdNotaPedido($scope.notaPedido.id).then( |
| 32 | function(res) { | 32 | function(res) { |
| 33 | $scope.articulosTabla = res.data; | 33 | $scope.articulosTabla = res.data; |
| 34 | } | 34 | } |
| 35 | ); | 35 | ); |
| 36 | crearNotaPedidoService.getDomiciliosByIdNotaPedido($scope.notaPedido.id).then( | 36 | //TODO DOMICILIOS QUE SE CARGAN AL EDITAR NOTA DE PEDIDO |
| 37 | function(res) { | 37 | //(NO REQUERIDO EN ESTA VERSION) |
| 38 | $scope.notaPedido.domicilio = res.data; | 38 | // crearNotaPedidoService.getDomiciliosByIdNotaPedido($scope.notaPedido.id).then( |
| 39 | } | 39 | // function(res) { |
| 40 | ); | 40 | // $scope.notaPedido.domicilio = res.data; |
| 41 | // } | ||
| 42 | // ); | ||
| 41 | } else { | 43 | } else { |
| 42 | $scope.notaPedido.fechaCarga = new Date(); | 44 | $scope.notaPedido.fechaCarga = new Date(); |
| 43 | $scope.notaPedido.domicilio = [{ id: 0 }]; | 45 | $scope.notaPedido.bomba = '0'; |
| 44 | $scope.notaPedido.bomba = '1'; | ||
| 45 | $scope.notaPedido.flete = '0'; | 46 | $scope.notaPedido.flete = '0'; |
| 46 | idLista = undefined; | 47 | idLista = undefined; |
| 47 | } | 48 | } |
| 48 | $scope.addNewDom = function() { | 49 | //TO DO - FUNCIONES PARA MULTIPLES DOMICILIOS NO IMPLEMENTADAS EN ESTA DEMO |
| 49 | $scope.notaPedido.domicilio.push({ 'id': 0 }); | 50 | // $scope.addNewDom = function() { |
| 50 | }; | 51 | // $scope.notaPedido.domicilio.push({ 'id': 0 }); |
| 51 | $scope.removeNewChoice = function(choice) { | 52 | // }; |
| 52 | if ($scope.notaPedido.domicilio.length > 1) { | 53 | // $scope.removeNewChoice = function(choice) { |
| 53 | $scope.notaPedido.domicilio.splice($scope.notaPedido.domicilio.findIndex( | 54 | // if ($scope.notaPedido.domicilio.length > 1) { |
| 54 | function(c) { | 55 | // $scope.notaPedido.domicilio.splice($scope.notaPedido.domicilio.findIndex( |
| 55 | return c.$$hashKey === choice.$$hashKey; | 56 | // function(c) { |
| 56 | } | 57 | // return c.$$hashKey === choice.$$hashKey; |
| 57 | ), 1); | 58 | // } |
| 58 | } | 59 | // ), 1); |
| 59 | }; | 60 | // } |
| 61 | // }; | ||
| 60 | $scope.crearNotaPedido = function() { | 62 | $scope.crearNotaPedido = function() { |
| 63 | if($scope.articulosTabla.length === 0) { | ||
| 64 | focaModalService.alert('Debe cargar almenos un articulo'); | ||
| 65 | return; | ||
| 66 | } | ||
| 67 | if($scope.notaPedido.domicilio.id === undefined) { | ||
| 68 | $scope.notaPedido.domicilio.id = 0; | ||
| 69 | } | ||
| 70 | var date = new Date(); | ||
| 61 | var notaPedido = { | 71 | var notaPedido = { |
| 62 | id: 0, | 72 | id: 0, |
| 63 | fechaCarga: $scope.notaPedido.fechaCarga, | 73 | fechaCarga: new Date(date.getTime() - (date.getTimezoneOffset() * 60000)) |
| 74 | .toISOString().slice(0, 19).replace('T', ' '), | ||
| 64 | vendedor: $scope.notaPedido.vendedor.nombre, | 75 | vendedor: $scope.notaPedido.vendedor.nombre, |
| 65 | cliente: $scope.notaPedido.cliente.nombre, | 76 | idCliente: $scope.notaPedido.cliente.id, |
| 66 | domicilio: $scope.notaPedido.domicilio.id, | 77 | domicilio: $scope.notaPedido.domicilio, |
| 67 | precioCondicion: $scope.notaPedido.precioCondicion, | 78 | precioCondicion: $scope.notaPedido.precioCondicion, |
| 68 | bomba: $scope.notaPedido.bomba, | 79 | bomba: $scope.notaPedido.bomba, |
| 69 | flete: $scope.notaPedido.flete, | 80 | flete: $scope.notaPedido.flete, |
| 70 | total: $scope.getTotal() | 81 | total: $scope.getTotal() |
| 71 | }; | 82 | }; |
| 72 | crearNotaPedidoService.crearNotaPedido(notaPedido).then( | 83 | crearNotaPedidoService.crearNotaPedido(notaPedido).then( |
| 73 | function() { | 84 | function(data) { |
| 74 | focaModalService.alert('Nota pedido creada'); | 85 | focaModalService.alert('Nota pedido creada'); |
| 75 | // $location.path('/venta-nota-pedido'); | 86 | if($scope.notaPedido.flete === 1) { |
| 76 | // var flete = { | 87 | var flete = { |
| 77 | // idNotaPedido: data.data.id, | 88 | idNotaPedido: data.data.id, |
| 78 | // idTransportista: $scope.notaPedido.fleteId, | 89 | idTransportista: $scope.notaPedido.fleteId, |
| 79 | // idChofer: $scope.chofer.id, | 90 | idChofer: $scope.notaPedido.chofer.id, |
| 80 | // idVehiculo: $scope.vehiculo.id, | 91 | idVehiculo: $scope.notaPedido.vehiculo.id, |
| 81 | // kilometros: $scope.notaPedido.kilometros, | 92 | kilometros: $scope.notaPedido.kilometros, |
| 82 | // costoKilometro: $scope.notaPedido.costoUnitarioKmFlete | 93 | costoKilometro: $scope.notaPedido.costoUnitarioKmFlete |
| 83 | // }; | 94 | }; |
| 84 | //TO DO - Insert de flete | 95 | crearNotaPedidoService.crearFlete(flete); |
| 96 | } | ||
| 97 | var articulosNotaPedido = $scope.articulosTabla; | ||
| 98 | for(var i = 0; i < articulosNotaPedido.length; i++) { | ||
| 99 | delete articulosNotaPedido[i].edit; | ||
| 100 | articulosNotaPedido[i].idNotaPedido = data.data.id; | ||
| 101 | crearNotaPedidoService | ||
| 102 | .crearArticulosParaNotaPedido(articulosNotaPedido[i]); | ||
| 103 | } | ||
| 104 | $scope.limpiarPantalla(); | ||
| 85 | } | 105 | } |
| 86 | ); | 106 | ); |
| 87 | var articulosNotaPedido = $scope.articulosTabla; | ||
| 88 | for(var i = 0; i< articulosNotaPedido.length;i++) { | ||
| 89 | delete articulosNotaPedido[i].edit; | ||
| 90 | crearNotaPedidoService | ||
| 91 | .crearArticulosParaNotaPedido(articulosNotaPedido[i]).then( | ||
| 92 | function() { | ||
| 93 | return; | ||
| 94 | } | ||
| 95 | ); | ||
| 96 | } | ||
| 97 | $scope.notaPedido.precioCondicion = ''; | ||
| 98 | $scope.articulosTabla = []; | ||
| 99 | $scope.notaPedido.fleteNombre = ''; | ||
| 100 | $scope.notaPedido.chofer = ''; | ||
| 101 | $scope.notaPedido.vehiculo = ''; | ||
| 102 | $scope.notaPedido.kilometros = ''; | ||
| 103 | $scope.notaPedido.costoUnitarioKmFlete = ''; | ||
| 104 | $scope.notaPedido.vendedor.nombre = ''; | ||
| 105 | $scope.notaPedido.cliente.nombre = ''; | ||
| 106 | $scope.domicilio = ''; | ||
| 107 | $scope.notaPedido.flete = 0; | ||
| 108 | }; | ||
| 109 | $scope.siguienteTab = function() { | ||
| 110 | $scope.active = 1; | ||
| 111 | }; | 107 | }; |
| 112 | $scope.seleccionarArticulo = function() { | 108 | $scope.seleccionarArticulo = function() { |
| 113 | if (idLista === undefined) { | 109 | if (idLista === undefined) { |
| 114 | focaModalService.alert( | 110 | focaModalService.alert( |
| 115 | 'primero seleccione una lista de precio y condicion'); | 111 | 'primero seleccione una lista de precio y condicion'); |
| 116 | return; | 112 | return; |
| 117 | } | 113 | } |
| 118 | var modalInstance = $uibModal.open( | 114 | var modalInstance = $uibModal.open( |
| 119 | { | 115 | { |
| 120 | ariaLabelledBy: 'Busqueda de Productos', | 116 | ariaLabelledBy: 'Busqueda de Productos', |
| 121 | templateUrl: 'modal-busqueda-productos.html', | 117 | templateUrl: 'modal-busqueda-productos.html', |
| 122 | controller: 'modalBusquedaProductosCtrl', | 118 | controller: 'modalBusquedaProductosCtrl', |
| 123 | resolve: { idLista: function() { return idLista; } }, | 119 | resolve: { idLista: function() { return idLista; } }, |
| 124 | size: 'lg' | 120 | size: 'lg' |
| 125 | } | 121 | } |
| 126 | ); | 122 | ); |
| 127 | modalInstance.result.then( | 123 | modalInstance.result.then( |
| 128 | function(producto) { | 124 | function(producto) { |
| 129 | var newArt = | 125 | var newArt = |
| 130 | { | 126 | { |
| 131 | id: 0, | 127 | id: 0, |
| 132 | codigo: producto.codigo, | 128 | codigo: producto.codigo, |
| 133 | sector: producto.sector, | 129 | sector: producto.sector, |
| 134 | descripcion: producto.descripcion, | 130 | descripcion: producto.descripcion, |
| 135 | item: $scope.articulosTabla.length + 1, | 131 | item: $scope.articulosTabla.length + 1, |
| 136 | nombre: producto.descripcion, | 132 | nombre: producto.descripcion, |
| 137 | precio: producto.precio.toFixed(2), | 133 | precio: producto.precio.toFixed(2), |
| 138 | costoUnitario: producto.costo, | 134 | costoUnitario: producto.costo, |
| 139 | edit: false | 135 | edit: false |
| 140 | }; | 136 | }; |
| 141 | $scope.articuloACargar = newArt; | 137 | $scope.articuloACargar = newArt; |
| 142 | $scope.cargando = false; | 138 | $scope.cargando = false; |
| 143 | }, function() { | 139 | }, function() { |
| 144 | // funcion ejecutada cuando se cancela el modal | 140 | // funcion ejecutada cuando se cancela el modal |
| 145 | } | 141 | } |
| 146 | ); | 142 | ); |
| 147 | }; | 143 | }; |
| 148 | $scope.seleccionarVendedor = function() { | 144 | $scope.seleccionarVendedor = function() { |
| 149 | var modalInstance = $uibModal.open( | 145 | var modalInstance = $uibModal.open( |
| 150 | { | 146 | { |
| 151 | ariaLabelledBy: 'Busqueda de Vendedores', | 147 | ariaLabelledBy: 'Busqueda de Vendedores', |
| 152 | templateUrl: 'modal-vendedores.html', | 148 | templateUrl: 'modal-vendedores.html', |
| 153 | controller: 'modalVendedoresCtrl', | 149 | controller: 'modalVendedoresCtrl', |
| 154 | size: 'lg' | 150 | size: 'lg' |
| 155 | } | 151 | } |
| 156 | ); | 152 | ); |
| 157 | modalInstance.result.then( | 153 | modalInstance.result.then( |
| 158 | function(vendedor) { | 154 | function(vendedor) { |
| 159 | $scope.notaPedido.vendedor.nombre = vendedor.NomVen; | 155 | $scope.notaPedido.vendedor.nombre = vendedor.NomVen; |
| 160 | }, function() { | 156 | }, function() { |
| 161 | 157 | ||
| 162 | } | 158 | } |
| 163 | ); | 159 | ); |
| 164 | }; | 160 | }; |
| 165 | $scope.seleccionarPetrolera = function() { | 161 | $scope.seleccionarPetrolera = function() { |
| 166 | var modalInstance = $uibModal.open( | 162 | var modalInstance = $uibModal.open( |
| 167 | { | 163 | { |
| 168 | ariaLabelledBy: 'Busqueda de Petrolera', | 164 | ariaLabelledBy: 'Busqueda de Petrolera', |
| 169 | templateUrl: 'modal-petroleras.html', | 165 | templateUrl: 'modal-petroleras.html', |
| 170 | controller: 'modalPetrolerasCtrl', | 166 | controller: 'modalPetrolerasCtrl', |
| 171 | size: 'lg' | 167 | size: 'lg' |
| 172 | } | 168 | } |
| 173 | ); | 169 | ); |
| 174 | modalInstance.result.then( | 170 | modalInstance.result.then( |
| 175 | function(petrolera) { | 171 | function(petrolera) { |
| 176 | $scope.notaPedido.petrolera = petrolera.NOM; | 172 | $scope.notaPedido.petrolera = petrolera.NOM; |
| 177 | }, function() { | 173 | }, function() { |
| 178 | 174 | ||
| 179 | } | 175 | } |
| 180 | ); | 176 | ); |
| 181 | }; | 177 | }; |
| 182 | $scope.seleccionarCliente = function() { | 178 | $scope.seleccionarCliente = function() { |
| 183 | var modalInstance = $uibModal.open( | 179 | var modalInstance = $uibModal.open( |
| 184 | { | 180 | { |
| 185 | ariaLabelledBy: 'Busqueda de Cliente', | 181 | ariaLabelledBy: 'Busqueda de Cliente', |
| 186 | templateUrl: 'foca-busqueda-cliente-modal.html', | 182 | templateUrl: 'foca-busqueda-cliente-modal.html', |
| 187 | controller: 'focaBusquedaClienteModalController', | 183 | controller: 'focaBusquedaClienteModalController', |
| 188 | size: 'lg' | 184 | size: 'lg' |
| 189 | } | 185 | } |
| 190 | ); | 186 | ); |
| 191 | modalInstance.result.then( | 187 | modalInstance.result.then( |
| 192 | function(cliente) { | 188 | function(cliente) { |
| 189 | $scope.limpiarPantalla(); | ||
| 193 | $scope.notaPedido.cliente.nombre = cliente.nom; | 190 | $scope.notaPedido.cliente.nombre = cliente.nom; |
| 191 | $scope.notaPedido.cliente.id = cliente.cod; | ||
| 192 | crearNotaPedidoService.getDomiciliosByIdCliente(cliente.cod).then( | ||
| 193 | function(data) { | ||
| 194 | if(data.data.length === 0){ | ||
| 195 | focaModalService | ||
| 196 | .alert('El cliente no tienen domicilios de entrega') | ||
| 197 | .then( | ||
| 198 | function() { | ||
| 199 | $scope.seleccionarCliente(); | ||
| 200 | $scope.notaPedido.cliente = {nombre: ''}; | ||
| 201 | } | ||
| 202 | ); | ||
| 203 | return; | ||
| 204 | } | ||
| 205 | $scope.domiciliosCliente = data.data; | ||
| 206 | } | ||
| 207 | ); | ||
| 194 | }, function() { | 208 | }, function() { |
| 195 | 209 | ||
| 196 | } | 210 | } |
| 197 | ); | 211 | ); |
| 198 | }; | 212 | }; |
| 199 | $scope.mostrarFichaCliente = function() { | 213 | $scope.mostrarFichaCliente = function() { |
| 200 | $uibModal.open( | 214 | $uibModal.open( |
| 201 | { | 215 | { |
| 202 | ariaLabelledBy: 'Datos del Cliente', | 216 | ariaLabelledBy: 'Datos del Cliente', |
| 203 | templateUrl: 'foca-crear-nota-pedido-ficha-cliente.html', | 217 | templateUrl: 'foca-crear-nota-pedido-ficha-cliente.html', |
| 204 | controller: 'focaCrearNotaPedidoFichaClienteController', | 218 | controller: 'focaCrearNotaPedidoFichaClienteController', |
| 205 | size: 'lg' | 219 | size: 'lg' |
| 206 | } | 220 | } |
| 207 | ); | 221 | ); |
| 208 | }; | 222 | }; |
| 209 | $scope.obtenerDomicilios = function(id) { | ||
| 210 | crearNotaPedidoService.getDomicilios(id).then( | ||
| 211 | function(res) { | ||
| 212 | $scope.notaPedido.domicilio = res.data; | ||
| 213 | } | ||
| 214 | ); | ||
| 215 | }; | ||
| 216 | $scope.getTotal = function() { | 223 | $scope.getTotal = function() { |
| 217 | var total = 0; | 224 | var total = 0; |
| 218 | var array = $scope.articulosTabla; | 225 | var arrayTempArticulos = $scope.articulosTabla; |
| 219 | for (var i = 0; i < array.length; i++) { | 226 | for (var i = 0; i < arrayTempArticulos.length; i++) { |
| 220 | total += array[i].precio * array[i].cantidad; | 227 | total += arrayTempArticulos[i].precio * arrayTempArticulos[i].cantidad; |
| 221 | } | 228 | } |
| 222 | return total.toFixed(2); | 229 | return total.toFixed(2); |
| 223 | }; | 230 | }; |
| 224 | $scope.getSubTotal = function() { | 231 | $scope.getSubTotal = function() { |
| 225 | if($scope.articuloACargar) { | 232 | if($scope.articuloACargar) { |
| 226 | return $scope.articuloACargar.precio * $scope.articuloACargar.cantidad; | 233 | return $scope.articuloACargar.precio * $scope.articuloACargar.cantidad; |
| 227 | } | 234 | } |
| 228 | }; | 235 | }; |
| 229 | $scope.cargarArticulos = function() { | ||
| 230 | idLista = $scope.notaPedido.precioCondicion; | ||
| 231 | $scope.articulosTabla = []; | ||
| 232 | }; | ||
| 233 | $scope.abrirModalListaPrecio = function() { | 236 | $scope.abrirModalListaPrecio = function() { |
| 234 | var modalInstance = $uibModal.open( | 237 | var modalInstance = $uibModal.open( |
| 235 | { | 238 | { |
| 236 | ariaLabelledBy: 'Busqueda de Precio Condición', | 239 | ariaLabelledBy: 'Busqueda de Precio Condición', |
| 237 | templateUrl: 'modal-precio-condicion.html', | 240 | templateUrl: 'modal-precio-condicion.html', |
| 238 | controller: 'focaModalPrecioCondicionController', | 241 | controller: 'focaModalPrecioCondicionController', |
| 239 | size: 'lg' | 242 | size: 'lg' |
| 240 | } | 243 | } |
| 241 | ); | 244 | ); |
| 242 | modalInstance.result.then( | 245 | modalInstance.result.then( |
| 243 | function(precioCondicion) { | 246 | function(precioCondicion) { |
| 244 | $scope.notaPedido.precioCondicion = precioCondicion.nombre; | 247 | $scope.notaPedido.precioCondicion = precioCondicion.nombre; |
| 245 | idLista = precioCondicion.idListaPrecio; | 248 | idLista = precioCondicion.idListaPrecio; |
| 246 | $scope.articulosTabla = []; | 249 | $scope.articulosTabla = []; |
| 247 | }, function() { | 250 | }, function() { |
| 248 | 251 | ||
| 249 | } | 252 | } |
| 250 | ); | 253 | ); |
| 251 | }; | 254 | }; |
| 252 | $scope.abrirModalFlete = function() { | 255 | $scope.abrirModalFlete = function() { |
| 253 | if($scope.notaPedido.flete === '1') { | 256 | if($scope.notaPedido.flete === '1') { |
| 254 | var modalInstance = $uibModal.open( | 257 | var modalInstance = $uibModal.open( |
| 255 | { | 258 | { |
| 256 | ariaLabelledBy: 'Busqueda de Flete', | 259 | ariaLabelledBy: 'Busqueda de Flete', |
| 257 | templateUrl: 'modal-flete.html', | 260 | templateUrl: 'modal-flete.html', |
| 258 | controller: 'focaModalFleteController', | 261 | controller: 'focaModalFleteController', |
| 259 | size: 'lg' | 262 | size: 'lg' |
| 260 | } | 263 | } |
| 261 | ); | 264 | ); |
| 262 | modalInstance.result.then( | 265 | modalInstance.result.then( |
| 263 | function(flete) { | 266 | function(flete) { |
| 264 | $scope.choferes = ''; | 267 | $scope.limpiarFlete(); |
| 265 | $scope.vehiculos = ''; | ||
| 266 | $scope.notaPedido.chofer = ''; | ||
| 267 | $scope.notaPedido.vehiculo = ''; | ||
| 268 | $scope.notaPedido.costoUnitarioKmFlete = ''; | ||
| 269 | $scope.notaPedido.fleteNombre = flete.nombre; | 268 | $scope.notaPedido.fleteNombre = flete.nombre; |
| 270 | $scope.notaPedido.fleteId = flete.id; | 269 | $scope.notaPedido.fleteId = flete.id; |
| 271 | $scope.choferes = flete.chofer; | 270 | $scope.choferes = flete.chofer; |
| 272 | $scope.vehiculos = flete.vehiculo; | 271 | $scope.vehiculos = flete.vehiculo; |
| 273 | }, function() { | 272 | }, function() { |
| 274 | 273 | ||
| 275 | } | 274 | } |
| 276 | ); | 275 | ); |
| 277 | } | 276 | } |
| 278 | }; | 277 | }; |
| 279 | $scope.agregarATabla = function(key) { | 278 | $scope.agregarATabla = function(key) { |
| 280 | if(key === 13) { | 279 | if(key === 13) { |
| 281 | if($scope.articuloACargar.cantidad === undefined || | 280 | if($scope.articuloACargar.cantidad === undefined || |
| 282 | $scope.articuloACargar.cantidad === 0 || | 281 | $scope.articuloACargar.cantidad === 0 || |
| 283 | $scope.articuloACargar.cantidad === null ){ | 282 | $scope.articuloACargar.cantidad === null ){ |
| 284 | focaModalService.alert('El valor debe ser al menos 1'); | 283 | focaModalService.alert('El valor debe ser al menos 1'); |
| 285 | return; | 284 | return; |
| 286 | } | 285 | } |
| 287 | $scope.articulosTabla.unshift($scope.articuloACargar); | 286 | $scope.articulosTabla.unshift($scope.articuloACargar); |
| 288 | $scope.cargando = true; | 287 | $scope.cargando = true; |
| 289 | } | 288 | } |
| 290 | }; | 289 | }; |
| 291 | $scope.quitarArticulo = function(key) { | 290 | $scope.quitarArticulo = function(key) { |
| 292 | $scope.articulosTabla.splice(key, 1); | 291 | $scope.articulosTabla.splice(key, 1); |
| 293 | }; | 292 | }; |
| 294 | $scope.editarArticulo = function(key, articulo) { | 293 | $scope.editarArticulo = function(key, articulo) { |
| 295 | if(key === 13) { | 294 | if(key === 13) { |
| 296 | if(articulo.cantidad === null || articulo.cantidad === 0 || | 295 | if(articulo.cantidad === null || articulo.cantidad === 0 || |
| 297 | articulo.cantidad === undefined){ | 296 | articulo.cantidad === undefined){ |
| 298 | focaModalService.alert('El valor debe ser al menos 1'); | 297 | focaModalService.alert('El valor debe ser al menos 1'); |
| 299 | return; | 298 | return; |
| 300 | } | 299 | } |
| 301 | articulo.edit = false; | 300 | articulo.edit = false; |
| 302 | } | 301 | } |
| 303 | }; | 302 | }; |
| 304 | $scope.cambioEdit = function(articulo) { | 303 | $scope.cambioEdit = function(articulo) { |
| 305 | articulo.edit = true; | 304 | articulo.edit = true; |
| 306 | }; | 305 | }; |
| 307 | $scope.limpiarFlete = function() { | 306 | $scope.limpiarFlete = function() { |
| 308 | $scope.notaPedido.fleteNombre = ''; | 307 | $scope.notaPedido.fleteNombre = ''; |
| 309 | $scope.notaPedido.chofer = ''; | 308 | $scope.notaPedido.chofer = ''; |
| 310 | $scope.notaPedido.vehiculo = ''; | 309 | $scope.notaPedido.vehiculo = ''; |
| 311 | $scope.notaPedido.kilometros = ''; | 310 | $scope.notaPedido.kilometros = ''; |
| 312 | $scope.notaPedido.costoUnitarioKmFlete = ''; | 311 | $scope.notaPedido.costoUnitarioKmFlete = ''; |
| 312 | $scope.choferes = ''; | ||
| 313 | $scope.vehiculos = ''; | ||
| 313 | }; | 314 | }; |
| 314 | $scope.crearPedidoDemo = function() { | 315 | $scope.limpiarPantalla = function() { |
| 315 | focaModalService.alert('Pedido Creado'); | 316 | $scope.limpiarFlete(); |
| 317 | $scope.notaPedido.flete = '0'; | ||
| 318 | $scope.notaPedido.bomba = '0'; | ||
| 316 | $scope.notaPedido.precioCondicion = ''; | 319 | $scope.notaPedido.precioCondicion = ''; |
| 317 | $scope.articulosTabla = []; | 320 | $scope.articulosTabla = []; |
| 318 | $scope.notaPedido.fleteNombre = ''; | ||
| 319 | $scope.notaPedido.chofer = ''; | ||
| 320 | $scope.notaPedido.vehiculo = ''; | ||
| 321 | $scope.notaPedido.kilometros = ''; | ||
| 322 | $scope.notaPedido.costoUnitarioKmFlete = ''; | ||
| 323 | $scope.notaPedido.vendedor.nombre = ''; | 321 | $scope.notaPedido.vendedor.nombre = ''; |
| 324 | $scope.notaPedido.cliente.nombre = ''; | 322 | $scope.notaPedido.cliente = {nombre: ''}; |
| 325 | $scope.domicilio.dom = ''; | 323 | $scope.notaPedido.domicilio = {dom: ''}; |
| 326 | $scope.notaPedido.flete = 0; | 324 | $scope.domiciliosCliente = []; |
| 327 | }; | 325 | }; |
| 328 | $scope.resetFilter = function() { | 326 | $scope.resetFilter = function() { |
src/js/service.js
| 1 | angular.module('focaCrearNotaPedido') | 1 | angular.module('focaCrearNotaPedido') |
| 2 | .service('crearNotaPedidoService', ['$http', 'API_ENDPOINT', function($http, API_ENDPOINT) { | 2 | .service('crearNotaPedidoService', ['$http', 'API_ENDPOINT', function($http, API_ENDPOINT) { |
| 3 | var route = API_ENDPOINT.URL; | 3 | var route = API_ENDPOINT.URL; |
| 4 | return { | 4 | return { |
| 5 | crearNotaPedido: function(notaPedido) { | 5 | crearNotaPedido: function(notaPedido) { |
| 6 | return $http.post(route + '/nota-pedido', {notaPedido: notaPedido}); | 6 | return $http.post(route + '/nota-pedido', {notaPedido: notaPedido}); |
| 7 | }, | 7 | }, |
| 8 | obtenerNotaPedido: function() { | 8 | obtenerNotaPedido: function() { |
| 9 | return $http.get(route +'/nota-pedido'); | 9 | return $http.get(route +'/nota-pedido'); |
| 10 | }, | 10 | }, |
| 11 | setNotaPedido: function(notaPedido) { | 11 | setNotaPedido: function(notaPedido) { |
| 12 | this.notaPedido = notaPedido; | 12 | this.notaPedido = notaPedido; |
| 13 | }, | 13 | }, |
| 14 | clearNotaPedido: function() { | 14 | clearNotaPedido: function() { |
| 15 | this.notaPedido = undefined; | 15 | this.notaPedido = undefined; |
| 16 | }, | 16 | }, |
| 17 | getNotaPedido: function() { | 17 | getNotaPedido: function() { |
| 18 | return this.notaPedido; | 18 | return this.notaPedido; |
| 19 | }, | 19 | }, |
| 20 | getArticulosByIdNotaPedido: function(id) { | 20 | getArticulosByIdNotaPedido: function(id) { |
| 21 | return $http.get(route+'/articulos/nota-pedido/'+id); | 21 | return $http.get(route+'/articulos/nota-pedido/'+id); |
| 22 | }, | 22 | }, |
| 23 | crearArticulosParaNotaPedido: function(articuloNotaPedido) { | 23 | crearArticulosParaNotaPedido: function(articuloNotaPedido) { |
| 24 | return $http.post(route + '/articulos/nota-pedido', | 24 | return $http.post(route + '/articulos/nota-pedido', |
| 25 | {articuloNotaPedido: articuloNotaPedido}); | 25 | {articuloNotaPedido: articuloNotaPedido}); |
| 26 | }, | 26 | }, |
| 27 | getDomiciliosByIdNotaPedido: function(id) { | 27 | getDomiciliosByIdNotaPedido: function(id) { |
| 28 | return $http.get(route +'/nota-pedido/'+id+'/domicilios'); | 28 | return $http.get(route +'/nota-pedido/'+id+'/domicilios'); |
| 29 | }, | 29 | }, |
| 30 | //EN DESARROLLO | 30 | getDomiciliosByIdCliente: function(id) { |
| 31 | getDomicilios: function(id) { | 31 | var idTipoEntrega = 2;//Solo traigo los domicilios que tienen tipo 2 (tipo entrega) |
| 32 | // return $http.get(route + '/'+id) | 32 | return $http.get(route + '/domicilio/tipo/' + idTipoEntrega + '/cliente/' + id ); |
| 33 | id='le asigno un valor para pasar pre commit'; | ||
| 34 | var domicilio = [ | ||
| 35 | { | ||
| 36 | id: 1, | ||
| 37 | dom: 'RISSO PATRON 781' | ||
| 38 | }, | ||
| 39 | { | ||
| 40 | id: 2, | ||
| 41 | dom: 'MARIANO MORENO 533' | ||
| 42 | }, | ||
| 43 | { | ||
| 44 | id: 3, | ||
| 45 | dom: 'SALTA 796' | ||
| 46 | } | ||
| 47 | ]; | ||
| 48 | return domicilio; | ||
| 49 | }, | 33 | }, |
| 50 | getPrecioCondicion: function() { | 34 | getPrecioCondicion: function() { |
| 51 | return $http.get(route + '/precio-condicion'); | 35 | return $http.get(route + '/precio-condicion'); |
| 52 | }, | 36 | }, |
| 53 | getPrecioCondicionById: function(id) { | 37 | getPrecioCondicionById: function(id) { |
| 54 | return $http.get(route + '/precio-condicion/' + id); | 38 | return $http.get(route + '/precio-condicion/' + id); |
| 55 | }, | 39 | }, |
| 56 | getPlazoPagoByPrecioCondicion: function(id) { | 40 | getPlazoPagoByPrecioCondicion: function(id) { |
| 57 | return $http.get(route + '/plazo-pago/precio-condicion/'+ id); | 41 | return $http.get(route + '/plazo-pago/precio-condicion/'+ id); |
| 58 | }, | 42 | }, |
| 59 | crearFlete: function(flete) { | 43 | crearFlete: function(flete) { |
| 60 | return $http.post(route + '/flete', {flete : flete}); | 44 | return $http.post(route + '/flete', {flete : flete}); |
| 61 | } | 45 | } |
| 62 | }; | 46 | }; |
| 63 | }]); | 47 | }]); |
| 64 | 48 |
src/views/nota-pedido.html
| 1 | <div class="row"> | 1 | <form name="formCrearNota" ng-submit="crearNotaPedido()"> |
| 2 | <div class="col-md-10 col-lg-8 offset-md-1 offset-lg-2"> | 2 | <div class="row"> |
| 3 | <div class="row bg-secondary p-3"> | 3 | <div class="col-md-10 col-lg-8 offset-md-1 offset-lg-2"> |
| 4 | <div class="form-group col-12 col-sm-6 col-md-4"> | 4 | <div class="row bg-secondary p-3"> |
| 5 | <div class="input-group"> | 5 | <div class="form-group col-12 col-sm-6 col-md-4"> |
| 6 | <div class="input-group"> | ||
| 7 | <input | ||
| 8 | type="text" | ||
| 9 | class="form-control" | ||
| 10 | uib-datepicker-popup="dd/MM/yyyy" | ||
| 11 | ng-model="notaPedido.fechaCarga" | ||
| 12 | is-open="popup1.opened" | ||
| 13 | datepicker-options="dateOptions" | ||
| 14 | close-text="Cerrar" | ||
| 15 | current-text="Hoy" | ||
| 16 | clear-text="Borrar" | ||
| 17 | alt-input-formats="altInputFormats" | ||
| 18 | ng-required="true" | ||
| 19 | /> | ||
| 20 | <span class="input-group-append"> | ||
| 21 | <button type="button" class="btn btn-default" ng-click="popup1.opened = true"> | ||
| 22 | <i class="fa fa-calendar"></i> | ||
| 23 | </button> | ||
| 24 | </span> | ||
| 25 | </div> | ||
| 26 | </div> | ||
| 27 | <div class="form-group col-12 col-sm-6 col-md-4"> | ||
| 28 | <div class="input-group"> | ||
| 29 | <input | ||
| 30 | class="form-control selectable" | ||
| 31 | type="text" | ||
| 32 | ng-model="notaPedido.cliente.nombre" | ||
| 33 | placeholder="Seleccione Cliente" | ||
| 34 | readonly="true" | ||
| 35 | ng-click="seleccionarCliente()" | ||
| 36 | ng-required="true" | ||
| 37 | > | ||
| 38 | <span class="input-group-append"> | ||
| 39 | <button type="button" class="btn btn-default" ng-click="seleccionarCliente()"> | ||
| 40 | <i class="fa fa-search"></i> | ||
| 41 | </button> | ||
| 42 | </span> | ||
| 43 | </div> | ||
| 44 | </div> | ||
| 45 | <div class="form-group col-12 col-sm-6 col-md-4"> | ||
| 46 | <div class="input-group"> | ||
| 47 | <input | ||
| 48 | class="form-control" | ||
| 49 | type="text" | ||
| 50 | ng-model="notaPedido.vendedor.nombre" | ||
| 51 | placeholder="Seleccione Vendedor" | ||
| 52 | readonly="true" | ||
| 53 | > | ||
| 54 | <span class="input-group-append"> | ||
| 55 | <button type="button" class="btn btn-default" ng-click="seleccionarVendedor()"> | ||
| 56 | <i class="fa fa-search"></i> | ||
| 57 | </button> | ||
| 58 | </span> | ||
| 59 | </div> | ||
| 60 | </div> | ||
| 61 | <div class="form-group col-12 col-sm-6 col-md-4"> | ||
| 6 | <input | 62 | <input |
| 63 | class="form-control selectable" | ||
| 7 | type="text" | 64 | type="text" |
| 8 | class="form-control" | 65 | ng-model="notaPedido.domicilio" |
| 9 | uib-datepicker-popup="dd/MM/yyyy" | 66 | placeholder="Seleccione Domicilio" |
| 10 | ng-model="notaPedido.fechaCarga" | 67 | typeahead-min-length="0" |
| 11 | is-open="popup1.opened" | 68 | uib-typeahead="domi as domi.dom for domi in domiciliosCliente" |
| 12 | datepicker-options="dateOptions" | 69 | > |
| 13 | close-text="Cerrar" | ||
| 14 | current-text="Hoy" | ||
| 15 | clear-text="Borrar" | ||
| 16 | alt-input-formats="altInputFormats" | ||
| 17 | /> | ||
| 18 | <span class="input-group-append"> | ||
| 19 | <button type="button" class="btn btn-default" ng-click="popup1.opened = true"> | ||
| 20 | <i class="fa fa-calendar"></i> | ||
| 21 | </button> | ||
| 22 | </span> | ||
| 23 | </div> | 70 | </div> |
| 24 | </div> | 71 | <div class="form-group col-12 col-sm-6 col-md-4"> |
| 25 | <div class="form-group col-12 col-sm-6 col-md-4"> | ||
| 26 | <div class="input-group"> | ||
| 27 | <input | 72 | <input |
| 28 | class="form-control" | 73 | class="form-control selectable" |
| 29 | type="text" | 74 | type="text" |
| 30 | ng-model="notaPedido.vendedor.nombre" | ||
| 31 | placeholder="Seleccione Vendedor" | ||
| 32 | readonly="true" | 75 | readonly="true" |
| 76 | ng-model="notaPedido.precioCondicion" | ||
| 77 | ng-click="abrirModalListaPrecio()" | ||
| 78 | placeholder="Seleccione Lista de precio" | ||
| 33 | > | 79 | > |
| 34 | <span class="input-group-append"> | ||
| 35 | <button type="button" class="btn btn-default" ng-click="seleccionarVendedor()"> | ||
| 36 | <i class="fa fa-search"></i> | ||
| 37 | </button> | ||
| 38 | </span> | ||
| 39 | </div> | 80 | </div> |
| 40 | </div> | 81 | <div class="form-group col-12 col-sm-6 col-md-4"> |
| 41 | <div class="form-group col-12 col-sm-6 col-md-4"> | 82 | <label>Bomba</label> |
| 42 | <div class="input-group"> | 83 | <div class="form-check custom-radio custom-control-inline"> |
| 43 | <input | 84 | <input |
| 85 | class="form-check-input" | ||
| 86 | type="radio" | ||
| 87 | name="radioBomba" | ||
| 88 | value="1" | ||
| 89 | ng-model="notaPedido.bomba"> | ||
| 90 | <label class="form-check-label">Si</label> | ||
| 91 | </div> | ||
| 92 | <div class="form-check custom-radio custom-control-inline"> | ||
| 93 | <input | ||
| 94 | class="form-check-input" | ||
| 95 | type="radio" | ||
| 96 | name="radioBomba" | ||
| 97 | value="0" | ||
| 98 | ng-model="notaPedido.bomba"> | ||
| 99 | <label class="form-check-label">No</label> | ||
| 100 | </div> | ||
| 101 | </div> | ||
| 102 | <div class="form-group col-12 col-sm-6 col-md-4"> | ||
| 103 | <label>Flete</label> | ||
| 104 | <div class="form-check custom-radio custom-control-inline"> | ||
| 105 | <input | ||
| 106 | ng-change="limpiarFlete()" | ||
| 107 | class="form-check-input" | ||
| 108 | type="radio" | ||
| 109 | name="radioFlete" | ||
| 110 | value="1" | ||
| 111 | ng-model="notaPedido.flete"> | ||
| 112 | <label class="form-check-label">Si</label> | ||
| 113 | </div> | ||
| 114 | <div class="form-check custom-radio custom-control-inline"> | ||
| 115 | <input | ||
| 116 | class="form-check-input" | ||
| 117 | type="radio" | ||
| 118 | name="radioFlete" | ||
| 119 | value="0" | ||
| 120 | ng-model="notaPedido.flete"> | ||
| 121 | <label class="form-check-label">No</label> | ||
| 122 | </div> | ||
| 123 | </div> | ||
| 124 | <div class="form-group col-12 col-sm-6 col-md-4"> | ||
| 125 | <input | ||
| 44 | class="form-control selectable" | 126 | class="form-control selectable" |
| 45 | type="text" | 127 | type="text" |
| 46 | ng-model="notaPedido.cliente.nombre" | ||
| 47 | placeholder="Seleccione Cliente" | ||
| 48 | readonly="true" | 128 | readonly="true" |
| 49 | ng-click="seleccionarCliente()" | 129 | ng-show="notaPedido.flete == 1" |
| 130 | ng-model="notaPedido.fleteNombre" | ||
| 131 | ng-click="abrirModalFlete()" | ||
| 132 | placeholder="Seleccione Flete" | ||
| 50 | > | 133 | > |
| 51 | <span class="input-group-append"> | ||
| 52 | <button type="button" class="btn btn-default" ng-click="seleccionarCliente()"> | ||
| 53 | <i class="fa fa-search"></i> | ||
| 54 | </button> | ||
| 55 | </span> | ||
| 56 | </div> | 134 | </div> |
| 57 | </div> | 135 | <div class="form-group col-12 col-sm-6 col-md-4"> |
| 58 | <div class="form-group col-12 col-sm-6 col-md-4"> | ||
| 59 | <input | ||
| 60 | class="form-control selectable" | ||
| 61 | type="text" | ||
| 62 | ng-model="domicilio" | ||
| 63 | placeholder="Seleccione Domicilio" | ||
| 64 | typeahead-min-length="0" | ||
| 65 | uib-typeahead="domi as domi.dom for domi in domiciliosCliente" | ||
| 66 | > | ||
| 67 | </div> | ||
| 68 | <div class="form-group col-12 col-sm-6 col-md-4"> | ||
| 69 | <input | ||
| 70 | class="form-control selectable" | ||
| 71 | type="text" | ||
| 72 | readonly="true" | ||
| 73 | ng-model="notaPedido.precioCondicion" | ||
| 74 | ng-click="abrirModalListaPrecio()" | ||
| 75 | placeholder="Seleccione Lista de precio" | ||
| 76 | > | ||
| 77 | </div> | ||
| 78 | <div class="form-group col-12 col-sm-6 col-md-4"> | ||
| 79 | <label>Bomba</label> | ||
| 80 | <div class="form-check custom-radio custom-control-inline"> | ||
| 81 | <input | ||
| 82 | class="form-check-input" | ||
| 83 | type="radio" | ||
| 84 | name="radioBomba" | ||
| 85 | value="1" | ||
| 86 | ng-model="notaPedido.bomba"> | ||
| 87 | <label class="form-check-label">Si</label> | ||
| 88 | </div> | ||
| 89 | <div class="form-check custom-radio custom-control-inline"> | ||
| 90 | <input | 136 | <input |
| 91 | class="form-check-input" | 137 | class="form-control selectable" |
| 92 | type="radio" | 138 | type="text" |
| 93 | name="radioBomba" | 139 | ng-show="notaPedido.flete == 1" |
| 94 | value="0" | 140 | ng-model="notaPedido.chofer" |
| 95 | ng-model="notaPedido.bomba"> | 141 | placeholder="Seleccione Chofer" |
| 96 | <label class="form-check-label">No</label> | 142 | uib-typeahead="chofer as chofer.nombre for chofer in choferes" |
| 143 | typeahead-min-length="0" | ||
| 144 | > | ||
| 97 | </div> | 145 | </div> |
| 98 | </div> | 146 | <div class="form-group col-12 col-sm-6 col-md-4"> |
| 99 | <div class="form-group col-12 col-sm-6 col-md-4"> | ||
| 100 | <label>Flete</label> | ||
| 101 | <div class="form-check custom-radio custom-control-inline"> | ||
| 102 | <input | 147 | <input |
| 103 | ng-change="limpiarFlete()" | 148 | class="form-control selectable" |
| 104 | class="form-check-input" | 149 | type="text" |
| 105 | type="radio" | 150 | ng-show="notaPedido.flete == 1" |
| 106 | name="radioFlete" | 151 | ng-model="notaPedido.vehiculo" |
| 107 | value="1" | 152 | placeholder="Seleccione Vehículo" |
| 108 | ng-model="notaPedido.flete"> | 153 | uib-typeahead="vehiculo as vehiculo.tractor for vehiculo in vehiculos" |
| 109 | <label class="form-check-label">Si</label> | 154 | typeahead-min-length="0" |
| 110 | </div> | 155 | > |
| 111 | <div class="form-check custom-radio custom-control-inline"> | 156 | </div> |
| 112 | <input | 157 | <div class="form-group col-12 col-sm-6 col-md-4"> |
| 113 | class="form-check-input" | 158 | <input |
| 114 | type="radio" | 159 | class="form-control selectable" |
| 115 | name="radioFlete" | 160 | type="number" |
| 116 | value="0" | 161 | step="0.01" |
| 117 | ng-model="notaPedido.flete"> | 162 | ng-show="notaPedido.flete == 1" |
| 118 | <label class="form-check-label">No</label> | 163 | ng-model="notaPedido.costoUnitarioKmFlete" |
| 164 | placeholder="Costo por kilómetro" | ||
| 165 | > | ||
| 166 | </div> | ||
| 167 | <div class="form-group col-12 col-sm-6 col-md-4"> | ||
| 168 | <input | ||
| 169 | class="form-control selectable" | ||
| 170 | type="number" | ||
| 171 | step="0.1" | ||
| 172 | ng-show="notaPedido.flete == 1" | ||
| 173 | ng-model="notaPedido.kilometros" | ||
| 174 | placeholder="Kilómetros recorridos" | ||
| 175 | > | ||
| 119 | </div> | 176 | </div> |
| 120 | </div> | ||
| 121 | <div class="form-group col-12 col-sm-6 col-md-4"> | ||
| 122 | <input | ||
| 123 | class="form-control selectable" | ||
| 124 | type="text" | ||
| 125 | readonly="true" | ||
| 126 | ng-show="notaPedido.flete == 1" | ||
| 127 | ng-model="notaPedido.fleteNombre" | ||
| 128 | ng-click="abrirModalFlete()" | ||
| 129 | placeholder="Seleccione Flete" | ||
| 130 | > | ||
| 131 | </div> | ||
| 132 | <div class="form-group col-12 col-sm-6 col-md-4"> | ||
| 133 | <input | ||
| 134 | class="form-control selectable" | ||
| 135 | type="text" | ||
| 136 | ng-show="notaPedido.flete == 1" | ||
| 137 | ng-model="notaPedido.chofer" | ||
| 138 | placeholder="Seleccione Chofer" | ||
| 139 | uib-typeahead="chofer as chofer.nombre for chofer in choferes" | ||
| 140 | typeahead-min-length="0" | ||
| 141 | > | ||
| 142 | </div> | ||
| 143 | <div class="form-group col-12 col-sm-6 col-md-4"> | ||
| 144 | <input | ||
| 145 | class="form-control selectable" | ||
| 146 | type="text" | ||
| 147 | ng-show="notaPedido.flete == 1" | ||
| 148 | ng-model="notaPedido.vehiculo" | ||
| 149 | placeholder="Seleccione Vehículo" | ||
| 150 | uib-typeahead="vehiculo as vehiculo.tractor for vehiculo in vehiculos" | ||
| 151 | typeahead-min-length="0" | ||
| 152 | > | ||
| 153 | </div> | ||
| 154 | <div class="form-group col-12 col-sm-6 col-md-4"> | ||
| 155 | <input | ||
| 156 | class="form-control selectable" | ||
| 157 | type="number" | ||
| 158 | step="0.01" | ||
| 159 | ng-show="notaPedido.flete == 1" | ||
| 160 | ng-model="notaPedido.costoUnitarioKmFlete" | ||
| 161 | placeholder="Costo por kilómetro" | ||
| 162 | > | ||
| 163 | </div> | ||
| 164 | <div class="form-group col-12 col-sm-6 col-md-4"> | ||
| 165 | <input | ||
| 166 | class="form-control selectable" | ||
| 167 | type="number" | ||
| 168 | step="0.1" | ||
| 169 | ng-show="notaPedido.flete == 1" | ||
| 170 | ng-model="notaPedido.kilometros" | ||
| 171 | placeholder="Kilómetros recorridos" | ||
| 172 | > | ||
| 173 | </div> | 177 | </div> |
| 174 | </div> | 178 | </div> |
| 179 | <div class="col-auto my-2"> | ||
| 180 | <button | ||
| 181 | ng-click="crearNotaPedido()" | ||
| 182 | type="submit" | ||
| 183 | title="Crear nota pedido" | ||
| 184 | class="btn btn-primary float-right"> | ||
| 185 | Guardar | ||
| 186 | </button> | ||
| 187 | </div> | ||
| 175 | </div> | 188 | </div> |
| 176 | <div class="col-auto my-2"> | 189 | </form> |
| 177 | <button | ||
| 178 | ng-click="crearNotaPedido()" | ||
| 179 | type="button" | ||
| 180 | title="Crear nota pedido" | ||
| 181 | class="btn btn-primary float-right"> | ||
| 182 | Guardar | ||
| 183 | </button> | ||
| 184 | </div> | ||
| 185 | </div> | ||
| 186 | <div class="row"> | 190 | <div class="row"> |
| 187 | <div class="col-md-10 col-lg-8 offset-md-1 offset-lg-2"> | 191 | <div class="col-md-10 col-lg-8 offset-md-1 offset-lg-2"> |
| 188 | <div class="row"> | 192 | <div class="row"> |
| 189 | </div> | 193 | </div> |
| 190 | <div class="row"> | 194 | <div class="row"> |
| 191 | <table class="table table-striped table-sm"> | 195 | <table class="table table-striped table-sm"> |
| 192 | <thead> | 196 | <thead> |
| 193 | <tr> | 197 | <tr> |
| 194 | <th>Sector</th> | 198 | <th>Sector</th> |
| 195 | <th>Código</th> | 199 | <th>Código</th> |
| 196 | <th>Descripción</th> | 200 | <th>Descripción</th> |
| 197 | <th>Precio Unitario</th> | 201 | <th>Precio Unitario</th> |
| 198 | <th>Cantidad</th> | 202 | <th>Cantidad</th> |
| 199 | <th>SubTotal</th> | 203 | <th>SubTotal</th> |
| 200 | <th> | 204 | <th> |
| 201 | <button class="btn btn-outline-secondary selectable" style="float: right;" ng-click="show = !show; masMenos()" > | 205 | <button class="btn btn-outline-secondary selectable" style="float: right;" ng-click="show = !show; masMenos()" > |
| 202 | <i class="fa fa-chevron-down" ng-hide="show" aria-hidden="true"></i> | 206 | <i class="fa fa-chevron-down" ng-hide="show" aria-hidden="true"></i> |
| 203 | <i class="fa fa-chevron-up" ng-show="show" aria-hidden="true"></i> | 207 | <i class="fa fa-chevron-up" ng-show="show" aria-hidden="true"></i> |
| 204 | </button> | 208 | </button> |
| 205 | </th> | 209 | </th> |
| 206 | </tr> | 210 | </tr> |
| 207 | </thead> | 211 | </thead> |
| 208 | <tbody> | 212 | <tbody> |
| 209 | <tr ng-show="cargando"> | 213 | <tr ng-show="cargando"> |
| 210 | <td colspan="2"><input | 214 | <td colspan="2"><input |
| 211 | placeholder="Seleccione Articulo" | 215 | placeholder="Seleccione Articulo" |
| 212 | class="form-control" | 216 | class="form-control" |
| 213 | readonly | 217 | readonly |
| 214 | ng-click="seleccionarArticulo()"></td> | 218 | ng-click="seleccionarArticulo()" |
| 219 | foca-focus="cargando"></td> | ||
| 215 | <td></td> | 220 | <td></td> |
| 216 | <td></td> | 221 | <td></td> |
| 217 | <td></td> | 222 | <td></td> |
| 218 | <td></td> | 223 | <td></td> |
| 219 | <td></td> | 224 | <td></td> |
| 220 | </tr> | 225 | </tr> |
| 221 | <tr ng-show="!cargando"> | 226 | <tr ng-show="!cargando"> |
| 222 | <td><input | 227 | <td><input |
| 223 | class="form-control" | 228 | class="form-control" |
| 224 | ng-model="articuloACargar.sector" | 229 | ng-model="articuloACargar.sector" |
| 225 | readonly></td> | 230 | readonly></td> |
| 226 | <td><input | 231 | <td><input |
| 227 | class="form-control" | 232 | class="form-control" |
| 228 | ng-model="articuloACargar.codigo" | 233 | ng-model="articuloACargar.codigo" |
| 229 | readonly></td> | 234 | readonly></td> |
| 230 | <td><input | 235 | <td><input |
| 231 | class="form-control" | 236 | class="form-control" |
| 232 | ng-model="articuloACargar.descripcion" | 237 | ng-model="articuloACargar.descripcion" |
| 233 | readonly></td> | 238 | readonly></td> |
| 234 | <td><input | 239 | <td><input |
| 235 | class="form-control" | 240 | class="form-control" |
| 236 | ng-value="articuloACargar.precio | currency:'$'" | 241 | ng-value="articuloACargar.precio | currency:'$'" |
| 237 | readonly></td> | 242 | readonly></td> |
| 238 | <td><input | 243 | <td><input |
| 239 | class="form-control" | 244 | class="form-control" |
| 240 | type="number" | 245 | type="number" |
| 241 | min="1" | 246 | min="1" |
| 242 | ng-model="articuloACargar.cantidad" | 247 | ng-model="articuloACargar.cantidad" |
| 243 | foca-focus="!cargando" | 248 | foca-focus="!cargando" |
| 244 | esc-key="resetFilter()" | 249 | esc-key="resetFilter()" |
| 245 | ng-keypress="agregarATabla($event.keyCode)"></td> | 250 | ng-keypress="agregarATabla($event.keyCode)"></td> |
| 246 | <td><input | 251 | <td><input |
| 247 | class="form-control" | 252 | class="form-control" |
| 248 | ng-value="getSubTotal() | currency:'$'" | 253 | ng-value="getSubTotal() | currency:'$'" |
| 249 | readonly></td> | 254 | readonly></td> |
| 250 | <td class="text-center"><button | 255 | <td class="text-center"><button |
| 251 | class="btn btn-outline-secondary btn-sm" | 256 | class="btn btn-outline-secondary btn-sm" |
| 252 | ng-click="agregarATabla(13)"> | 257 | ng-click="agregarATabla(13)"> |
| 253 | <i class="fa fa-save"></i> | 258 | <i class="fa fa-save"></i> |
| 254 | </button></td> | 259 | </button></td> |
| 255 | </tr> | 260 | </tr> |
| 256 | <tr ng-repeat="(key, articulo) in articulosTabla" ng-show="show || key == 0"> | 261 | <tr ng-repeat="(key, articulo) in articulosTabla" ng-show="show || key == 0"> |
| 257 | <td ng-bind="articulo.sector"></td> | 262 | <td ng-bind="articulo.sector"></td> |
| 258 | <td ng-bind="articulo.codigo"></td> | 263 | <td ng-bind="articulo.codigo"></td> |
| 259 | <td ng-bind="articulo.descripcion"></td> | 264 | <td ng-bind="articulo.descripcion"></td> |
| 260 | <td ng-bind="articulo.precio | currency:'$'"></td> | 265 | <td ng-bind="articulo.precio | currency:'$'"></td> |
| 261 | <td><input | 266 | <td><input |
| 262 | ng-show="articulo.edit" | 267 | ng-show="articulo.edit" |
| 263 | ng-model="articulo.cantidad" | 268 | ng-model="articulo.cantidad" |
| 264 | class="form-control" | 269 | class="form-control" |
| 265 | type="number" | 270 | type="number" |
| 266 | min="1" | 271 | min="1" |
| 267 | foca-focus="articulo.edit" | 272 | foca-focus="articulo.edit" |
| 268 | ng-keypress="editarArticulo($event.keyCode, articulo)"> | 273 | ng-keypress="editarArticulo($event.keyCode, articulo)" |
| 274 | ng-focus="selectFocus($event)" | ||
| 275 | > | ||
| 269 | <i | 276 | <i |
| 270 | class="selectable" | 277 | class="selectable" |
| 271 | ng-click="cambioEdit(articulo)" | 278 | ng-click="cambioEdit(articulo)" |
| 272 | ng-hide="articulo.edit" | 279 | ng-hide="articulo.edit" |
| 273 | ng-bind="articulo.cantidad"> | 280 | ng-bind="articulo.cantidad"> |
| 274 | </i> | 281 | </i> |
| 275 | </td> | 282 | </td> |
| 276 | <td ng-bind="(articulo.precio * articulo.cantidad) | currency: '$'"></td> | 283 | <td ng-bind="(articulo.precio * articulo.cantidad) | currency: '$'"></td> |
| 277 | <td class="text-center"> | 284 | <td class="text-center"> |
| 278 | <button class="btn btn-outline-secondary btn-sm" ng-click="quitarArticulo(key)"> | 285 | <button class="btn btn-outline-secondary btn-sm" ng-click="quitarArticulo(key)"> |
| 279 | <i class="fa fa-trash"></i> | 286 | <i class="fa fa-trash"></i> |
| 280 | </button> | 287 | </button> |
| 281 | </td> | 288 | </td> |
| 282 | </tr> | 289 | </tr> |
| 283 | </tbody> | 290 | </tbody> |
| 284 | <tfoot> | 291 | <tfoot> |
| 285 | <tr class="table-secondary"> | 292 | <tr class="table-secondary"> |
| 286 | <td colspan="5"><b>Cantidad Items:</b> <a ng-bind="articulosTabla.length"></a> </td> | 293 | <td colspan="5"><b>Cantidad Items:</b> <a ng-bind="articulosTabla.length"></a> </td> |
| 287 | <td colspan="3">{{getTotal() | currency:'$'}}</td> | 294 | <td colspan="3">{{getTotal() | currency:'$'}}</td> |
| 288 | </tr> | 295 | </tr> |
| 289 | </tfoot> | 296 | </tfoot> |
| 290 | </table> | 297 | </table> |
| 291 | </div> | 298 | </div> |
| 292 | </div> | 299 | </div> |
| 293 | </div> | 300 | </div> |
| 294 | 301 | ||
| 295 | <!-- | 302 | <!-- |
| 296 | <form name="formCrearNota"> | 303 | <form name="formCrearNota"> |
| 297 | <uib-tabset active="active"> | 304 | <uib-tabset active="active"> |
| 298 | <uib-tab index="0" heading="General"> | 305 | <uib-tab index="0" heading="General"> |
| 299 | <input type="hidden" name="id" ng-model="notaPedido.id" /> | 306 | <input type="hidden" name="id" ng-model="notaPedido.id" /> |
| 300 | <div> | 307 | <div> |
| 301 | <div class="col-auto my-2"> | 308 | <div class="col-auto my-2"> |
| 302 | <button type="submit" title="Siguiente" class="btn btn-primary float-right">Siguiente</button> | 309 | <button type="submit" title="Siguiente" class="btn btn-primary float-right">Siguiente</button> |
| 303 | </div> | 310 | </div> |
| 304 | </div> | 311 | </div> |
| 305 | <br> | 312 | <br> |
| 306 | <br> | 313 | <br> |
| 307 | <div class="row"> | 314 | <div class="row"> |
| 308 | <div class="col-md-2"> | 315 | <div class="col-md-2"> |
| 309 | <div class="col-auto"> | 316 | <div class="col-auto"> |
| 310 | <label>Fecha de carga</label> | 317 | <label>Fecha de carga</label> |
| 311 | </div> | 318 | </div> |
| 312 | </div> | 319 | </div> |
| 313 | <div class="col-md-3"> | 320 | <div class="col-md-3"> |
| 314 | <div class="col-auto"> | 321 | <div class="col-auto"> |
| 315 | <input type="date" class="form-control" ng-model="notaPedido.fechaCarga" ng-required="true"> | 322 | <input type="date" class="form-control" ng-model="notaPedido.fechaCarga" ng-required="true"> |
| 316 | </div> | 323 | </div> |
| 317 | </div> | 324 | </div> |
| 318 | <div class="col-md-2"> | 325 | <div class="col-md-2"> |
| 319 | <div class="col-auto"> | 326 | <div class="col-auto"> |
| 320 | <label>Kilómetros</label> | 327 | <label>Kilómetros</label> |
| 321 | </div> | 328 | </div> |
| 322 | </div> | 329 | </div> |
| 323 | <div class="col-md-3"> | 330 | <div class="col-md-3"> |
| 324 | <div class="col-auto"> | 331 | <div class="col-auto"> |
| 325 | <input type="number" min="0" step="0.01" class="form-control" placeholder="Kilómetros recorridos para la entrega en el cliente" | 332 | <input type="number" min="0" step="0.01" class="form-control" placeholder="Kilómetros recorridos para la entrega en el cliente" |
| 326 | ng-model="notaPedido.kilometros" ng-required="true"> | 333 | ng-model="notaPedido.kilometros" ng-required="true"> |
| 327 | </div> | 334 | </div> |
| 328 | </div> | 335 | </div> |
| 329 | </div> | 336 | </div> |
| 330 | <div class="row my-3"> | 337 | <div class="row my-3"> |
| 331 | <div class="col-md-2"> | 338 | <div class="col-md-2"> |
| 332 | <div class="col-auto"> | 339 | <div class="col-auto"> |
| 333 | <label>Jurisdicción de IIBB</label> | 340 | <label>Jurisdicción de IIBB</label> |
| 334 | </div> | 341 | </div> |
| 335 | </div> | 342 | </div> |
| 336 | <div class="col-md-3"> | 343 | <div class="col-md-3"> |
| 337 | <div class="col-auto"> | 344 | <div class="col-auto"> |
| 338 | <input type="text" class="form-control" placeholder="Jurisdicción de IIBB donde se realiza la entrega" | 345 | <input type="text" class="form-control" placeholder="Jurisdicción de IIBB donde se realiza la entrega" |
| 339 | ng-model="notaPedido.jurisdiccionIIBB" ng-required="true"> | 346 | ng-model="notaPedido.jurisdiccionIIBB" ng-required="true"> |
| 340 | </div> | 347 | </div> |
| 341 | </div> | 348 | </div> |
| 342 | <div class="col-md-2"> | 349 | <div class="col-md-2"> |
| 343 | <div class="col-auto"> | 350 | <div class="col-auto"> |
| 344 | <label>Costo de financiación</label> | 351 | <label>Costo de financiación</label> |
| 345 | </div> | 352 | </div> |
| 346 | </div> | 353 | </div> |
| 347 | <div class="col-md-3"> | 354 | <div class="col-md-3"> |
| 348 | <div class="col-auto"> | 355 | <div class="col-auto"> |
| 349 | <div class="input-group mb-2"> | 356 | <div class="input-group mb-2"> |
| 350 | <div class="input-group-prepend"> | 357 | <div class="input-group-prepend"> |
| 351 | <div class="input-group-text">$</div> | 358 | <div class="input-group-text">$</div> |
| 352 | </div> | 359 | </div> |
| 353 | <input type="number" min="0" step="0.01" class="form-control" placeholder="Costo de financiación" | 360 | <input type="number" min="0" step="0.01" class="form-control" placeholder="Costo de financiación" |
| 354 | ng-model="notaPedido.costoFinanciacion"> | 361 | ng-model="notaPedido.costoFinanciacion"> |
| 355 | </div> | 362 | </div> |
| 356 | </div> | 363 | </div> |
| 357 | </div> | 364 | </div> |
| 358 | </div> | 365 | </div> |
| 359 | <div class="row"> | 366 | <div class="row"> |
| 360 | <div class="col-md-2"> | 367 | <div class="col-md-2"> |
| 361 | <div class="col-auto"> | 368 | <div class="col-auto"> |
| 362 | <label>Bomba</label> | 369 | <label>Bomba</label> |
| 363 | </div> | 370 | </div> |
| 364 | </div> | 371 | </div> |
| 365 | <div class="col-md-1"> | 372 | <div class="col-md-1"> |
| 366 | <div class="col-auto"> | 373 | <div class="col-auto"> |
| 367 | <div class="form-check custom-radio custom-control-inline"> | 374 | <div class="form-check custom-radio custom-control-inline"> |
| 368 | <input class="form-check-input" type="radio" name="radioBomba" value="1" ng-model="notaPedido.bomba"> | 375 | <input class="form-check-input" type="radio" name="radioBomba" value="1" ng-model="notaPedido.bomba"> |
| 369 | <label class="form-check-label"> | 376 | <label class="form-check-label"> |
| 370 | Si | 377 | Si |
| 371 | </label> | 378 | </label> |
| 372 | </div> | 379 | </div> |
| 373 | <div class="form-check custom-radio custom-control-inline"> | 380 | <div class="form-check custom-radio custom-control-inline"> |
| 374 | <input class="form-check-input" type="radio" name="radioBomba" value="0" ng-model="notaPedido.bomba"> | 381 | <input class="form-check-input" type="radio" name="radioBomba" value="0" ng-model="notaPedido.bomba"> |
| 375 | <label class="form-check-label"> | 382 | <label class="form-check-label"> |
| 376 | No | 383 | No |
| 377 | </label> | 384 | </label> |
| 378 | </div> | 385 | </div> |
| 379 | </div> | 386 | </div> |
| 380 | </div> | 387 | </div> |
| 381 | <div class="col-md-1"> | 388 | <div class="col-md-1"> |
| 382 | <div class="col-auto"> | 389 | <div class="col-auto"> |
| 383 | <label>Flete</label> | 390 | <label>Flete</label> |
| 384 | </div> | 391 | </div> |
| 385 | </div> | 392 | </div> |
| 386 | <div class="col-md-1"> | 393 | <div class="col-md-1"> |
| 387 | <div class="col-auto"> | 394 | <div class="col-auto"> |
| 388 | <div class="form-check custom-radio custom-control-inline"> | 395 | <div class="form-check custom-radio custom-control-inline"> |
| 389 | <input class="form-check-input" type="radio" name="radioFlete" value="1" ng-model="notaPedido.flete"> | 396 | <input class="form-check-input" type="radio" name="radioFlete" value="1" ng-model="notaPedido.flete"> |
| 390 | <label class="form-check-label"> | 397 | <label class="form-check-label"> |
| 391 | Si | 398 | Si |
| 392 | </label> | 399 | </label> |
| 393 | </div> | 400 | </div> |
| 394 | <div class="form-check custom-radio custom-control-inline"> | 401 | <div class="form-check custom-radio custom-control-inline"> |
| 395 | <input class="form-check-input" type="radio" name="radioFlete" value="0" ng-model="notaPedido.flete"> | 402 | <input class="form-check-input" type="radio" name="radioFlete" value="0" ng-model="notaPedido.flete"> |
| 396 | <label class="form-check-label"> | 403 | <label class="form-check-label"> |
| 397 | FOB | 404 | FOB |
| 398 | </label> | 405 | </label> |
| 399 | </div> | 406 | </div> |
| 400 | </div> | 407 | </div> |
| 401 | </div> | 408 | </div> |
| 402 | <div class="col-md-2"> | 409 | <div class="col-md-2"> |
| 403 | <div class="col-auto"> | 410 | <div class="col-auto"> |
| 404 | <label>Costo unitario kilometro flete</label> | 411 | <label>Costo unitario kilometro flete</label> |
| 405 | </div> | 412 | </div> |
| 406 | </div> | 413 | </div> |
| 407 | <div class="col-md-3"> | 414 | <div class="col-md-3"> |
| 408 | <div class="col-auto"> | 415 | <div class="col-auto"> |
| 409 | <div class="input-group mb-2"> | 416 | <div class="input-group mb-2"> |
| 410 | <div class="input-group-prepend"> | 417 | <div class="input-group-prepend"> |
| 411 | <div class="input-group-text">$</div> | 418 | <div class="input-group-text">$</div> |
| 412 | </div> | 419 | </div> |
| 413 | <input type="number" min="0" step="0.01" class="form-control" placeholder="Costo unitario del kilometro del flete" | 420 | <input type="number" min="0" step="0.01" class="form-control" placeholder="Costo unitario del kilometro del flete" |
| 414 | ng-model="notaPedido.costoUnitarioKmFlete" ng-required="true"> | 421 | ng-model="notaPedido.costoUnitarioKmFlete" ng-required="true"> |
| 415 | </div> | 422 | </div> |
| 416 | </div> | 423 | </div> |
| 417 | </div> | 424 | </div> |