angular.module('focaModalLocalidad') .controller('focaModalLocalidadController', [ '$timeout', '$filter', '$scope', '$uibModalInstance', 'focaModalLocalidadService', 'filters', function($timeout, $filter, $scope, $uibModalInstance, focaModalLocalidadService, filters) { $scope.filters = filters.busqueda; $scope.provincias = []; $scope.primerBusqueda = false; $scope.searchLoading = false; // pagination $scope.numPerPage = 10; $scope.currentPage = 1; $scope.filteredLocalidades = []; $scope.currentPageLocalidades = []; $scope.selectedLocalidades = -1; $scope.busquedaPress = function(key) { if (key === 13) { $scope.searchLoading = true; focaModalLocalidadService.getLocalidadesByIdProvincia(filters.idProvincia) .then( function(res) { $scope.searchLoading = false; $scope.primerBusqueda = true; $scope.provincias = res.data; $scope.search(true); primera(); } ); } }; $scope.search = function(pressed) { if($scope.provincias.length > 0) { $scope.filteredLocalidades = $filter('filter')( $scope.provincias, { $: $scope.filters } ); if(pressed && $scope.filteredLocalidades.length === 0){ $timeout(function() { angular.element('#search')[0].focus(); $scope.filters = ''; }); } $scope.lastPage = Math.ceil( $scope.filteredLocalidades.length / $scope.numPerPage ); $scope.resetPage(); } }; $scope.resetPage = function() { $scope.currentPage = 1; $scope.selectPage(1); }; $scope.selectPage = function(page) { var start = (page - 1) * $scope.numPerPage; var end = start + $scope.numPerPage; $scope.paginas = []; $scope.paginas = calcularPages(page); $scope.currentPageLocalidades = $scope.filteredLocalidades.slice(start, end); $scope.currentPage = page; }; $scope.select = function(vendedor) { $uibModalInstance.close(vendedor); }; $scope.cancel = function() { $uibModalInstance.dismiss('cancel'); }; $scope.busquedaDown = function(key) { if (key === 40) { primera(key); } }; $scope.itemLocalidad = function(key) { if (key === 38) { anterior(key); } if (key === 40) { siguiente(key); } if (key === 37) { retrocederPagina(); } if (key === 39) { avanzarPagina(); } }; function calcularPages(paginaActual) { var paginas = []; paginas.push(paginaActual); if (paginaActual - 1 > 1) { paginas.unshift(paginaActual - 1); if (paginaActual - 2 > 1) { paginas.unshift(paginaActual - 2); } } if (paginaActual + 1 < $scope.lastPage) { paginas.push(paginaActual + 1); if (paginaActual + 2 < $scope.lastPage) { paginas.push(paginaActual + 2); } } if (paginaActual !== 1) { paginas.unshift(1); } if (paginaActual !== $scope.lastPage) { paginas.push($scope.lastPage); } return paginas; } function primera() { $scope.selectedLocalidades = 0; } function anterior() { if ($scope.selectedLocalidades === 0 && $scope.currentPage > 1) { retrocederPagina(); } else { $scope.selectedLocalidades--; } } function siguiente() { if ($scope.selectedLocalidades < $scope.currentPageLocalidades.length - 1) { $scope.selectedLocalidades++; } else { avanzarPagina(); } } function retrocederPagina() { if ($scope.currentPage > 1) { $scope.selectPage($scope.currentPage - 1); $scope.selectedLocalidades = $scope.numPerPage - 1; } } function avanzarPagina() { if ($scope.currentPage < $scope.lastPage) { $scope.selectPage($scope.currentPage + 1); $scope.selectedLocalidades = 0; } } $scope.busquedaPress(13); }] );