public ActionResult Index(int?estado, DateTime?FechaEmisionDesde, DateTime?FechaEmisionHasta, int page = 1)
        {
            GetEstado();

            if (FechaEmisionDesde != null)
            {
                string fechaD = Convert.ToDateTime(FechaEmisionDesde).Year.ToString() + "/" + Convert.ToDateTime(FechaEmisionDesde).Month.ToString() + "/" + Convert.ToDateTime(FechaEmisionDesde).Day.ToString();
                FechaEmisionD = Convert.ToDateTime(fechaD);
            }

            if (FechaEmisionHasta != null)
            {
                string fechaH = Convert.ToDateTime(FechaEmisionHasta).Year.ToString() + "/" + Convert.ToDateTime(FechaEmisionHasta).Month.ToString() + "/" + Convert.ToDateTime(FechaEmisionHasta).Day.ToString();
                FechaEmisionH = Convert.ToDateTime(fechaH);
            }
            FacturaProveedoresVMIndex model = new FacturaProveedoresVMIndex {
                estado = estado, FechaEmisionDesde = FechaEmisionDesde == null ? FechaEmisionDesde : FechaEmisionD, FechaEmisionHasta = FechaEmisionHasta == null ? FechaEmisionHasta : FechaEmisionH, page = page
            };

            try
            {
                IEnumerable <ListFacturaProveedores> list = _repo.FacturaProveedoresList(model.estado, model.FechaEmisionDesde, model.FechaEmisionHasta);

                model.list       = list.OrderBy(o => o.FechaFactura).Skip((page - 1) * _pageSize).Take(_pageSize);
                model.pagingInfo = new PagingInfo
                {
                    CurrentPage  = page,
                    ItemsPerPage = _pageSize,
                    TotalItems   = list.Count()
                };
            }
            catch
            {
                ModelState.AddModelError("", "Se produjo un error, en caso de persistir, ponerse en contacto con el Administrador.");
            }
            return(View(model));
        }