public ActionResult Find(PermisosUsuarioFindViewModel model)
        {
            //LoggerFactory.CreateLog().Debug(string.Format(CultureInfo.InvariantCulture, "Presentation Layer - FindPermisosUsuario Controller Begin"));
            //int totalCount = 0;

            try
            {
                // Add find logic here
                if (ModelState.IsValid)
                {
                    if (model.OrderBy == null)
                    {
                        model.OrderBy = "Id";
                    }

                    string sort        = "Id";
                    var    filtros     = GenerateExpression(model);
                    var    pagedResult = _servicePermisosUsuario.FindPagedByFilter(filtros, null, 1, model.PageSize, model.OrderBy, "Asc", null, null);
                    model.Paginate(pagedResult, "");

                    //var PermisosUsuarioDetails = _serviceAlim.Query(
                    //    new PermisosUsuarioQuery().Withfilter(filtros))
                    //    .OrderBy(n => n.OrderBy("Id", "Asc"))
                    //    .SelectPage(1, model.PageSize, out totalCount);
                    //var pagelist = new { total = totalCount, rows = PermisosUsuarioDetails.ToList() };

                    //var pagedResult = _servicePermisosUsuario.FindPagedByFilter(expression, includes, 1, model.PageSize, "Id", model.OrderBy, model.Ascendent, null, null);
                    //model.Paginate(pagedResult, expression.SerializedExpression);

                    TempData.Clear();
                    TempData.Add("FilterPermisosUsuario", model);

                    //LoggerFactory.CreateLog().Debug(string.Format(CultureInfo.InvariantCulture, "Presentation Layer - FindPermisosUsuario Controller End"));
                    return(PartialView("_PermisosUsuarioFindPartialView", model));
                }
            }
            catch (Exception ex)
            {
                //LoggerFactory.CreateLog().Error(string.Format(CultureInfo.InvariantCulture, "Presentation Layer - FindPermisosUsuario Controller ERROR"), ex);
            }

            ModelState.AddModelError("", PresentationResources.Error);
            return(View("PermisosUsuarioFindView", new PermisosUsuarioFindViewModel(_servicePermisosUsuario, _serviceRolUsuario, _serviceUsuario)));
        }
        // GET
        public ActionResult Find(int?page = 1, string sort = "Id", string sortDir = "ASC")
        {
            //LoggerFactory.CreateLog().Debug(string.Format(CultureInfo.InvariantCulture, "Presentation Layer - FindPermisosUsuario Controller Begin"));

            try
            {
                // Add find logic here
                PermisosUsuarioFindViewModel model;

                if (Request.IsAjaxRequest() && TempData.ContainsKey("FilterPermisosUsuario"))
                {
                    model = (PermisosUsuarioFindViewModel)TempData.Peek("FilterPermisosUsuario");
                    var filtros     = GenerateExpression(model);
                    var pagedResult = _servicePermisosUsuario.FindPagedByFilter(filtros, null, page != null ? (int)page : model.PageIndex, model.PageSize, sort, sortDir, null, null);
                    model.Paginate(pagedResult, "");

                    //var pagedResult = _servicePermisosUsuario.FindPagedByFilter(new CustomQuery<PermisosUsuario> { SerializedExpression = model.Filter }, null, page != null ? (int)page : model.PageIndex, model.PageSize, sort, sortDir == "ASC", null);
                    //model.Paginate(pagedResult, model.Filter);

                    //LoggerFactory.CreateLog().Debug(string.Format(CultureInfo.InvariantCulture, "Presentation Layer - FindPagedPermisosUsuario Controller End"));
                    return(PartialView("_PermisosUsuarioFindPartialView", model));
                }
                else
                {
                    TempData.Remove("FilterPermisosUsuario");
                    model = new PermisosUsuarioFindViewModel(_servicePermisosUsuario, _serviceRolUsuario, _serviceUsuario);
                    //LoggerFactory.CreateLog().Debug(string.Format(CultureInfo.InvariantCulture, "Presentation Layer - FindPermisosUsuario Controller End"));
                    return(View("PermisosUsuarioFindView", model));
                }
            }
            catch (Exception ex)
            {
                //LoggerFactory.CreateLog().Error(string.Format(CultureInfo.InvariantCulture, "Presentation Layer - FindPermisosUsuario Controller ERROR"), ex);
            }

            return(RedirectToAction("Index", "Home"));
        }
        //private static QueryObject<PermisosUsuario> GenerateExpression(PermisosUsuarioFindViewModel model)
        private static IEnumerable <filterRule> GenerateExpression(PermisosUsuarioFindViewModel model)
        {
            //LoggerFactory.CreateLog().Debug(string.Format(CultureInfo.InvariantCulture, "Presentation Layer - FindAlim Controller Begin"));
            //var filters = JsonConvert.DeserializeObject<IEnumerable<filterRule>>(filterRules);
            //return Json(pagelist, JsonRequestBehavior.AllowGet);
            IList <filterRule> filtros = new List <filterRule>();

            if (model != null)
            {
                if (model.PermisosUsuario.Id.HasValue)
                {
                    filtros.Add(new filterRule()
                    {
                        op = "equal", field = "Id", value = model.PermisosUsuario.Id.Value.ToString()
                    });
                }
                //And(d => d.Id == model.PermisosUsuario.Id.Value);
                if (model.PermisosUsuario.IdUsuario.HasValue)
                {
                    filtros.Add(new filterRule()
                    {
                        op = "equal", field = "IdUsuario", value = model.PermisosUsuario.IdUsuario.Value.ToString()
                    });
                }
                //And(d => d.IdUsuario == model.PermisosUsuario.IdUsuario.Value);
                if (model.PermisosUsuario.IdRol.HasValue)
                {
                    filtros.Add(new filterRule()
                    {
                        op = "equal", field = "IdRol", value = model.PermisosUsuario.IdRol.Value.ToString()
                    });
                }
                //And(d => d.IdRol == model.PermisosUsuario.IdRol.Value);
                if (model.PermisosUsuario.FechaInicio.HasValue)
                {
                    filtros.Add(new filterRule()
                    {
                        op = "equal", field = "FechaInicio", value = model.PermisosUsuario.FechaInicio.Value.ToString()
                    });
                }
                //And(d => d.FechaInicio == model.PermisosUsuario.FechaInicio.Value);
                if (model.PermisosUsuario.FechaTermino.HasValue)
                {
                    filtros.Add(new filterRule()
                    {
                        op = "equal", field = "FechaTermino", value = model.PermisosUsuario.FechaTermino.Value.ToString()
                    });
                }
                //And(d => d.FechaTermino == model.PermisosUsuario.FechaTermino.Value);
                if (model.PermisosUsuario.CreatedBy.HasValue)
                {
                    filtros.Add(new filterRule()
                    {
                        op = "equal", field = "CreatedBy", value = model.PermisosUsuario.CreatedBy.Value.ToString()
                    });
                }
                //And(d => d.CreatedBy == model.PermisosUsuario.CreatedBy.Value);
                if (model.PermisosUsuario.CreatedDate.HasValue)
                {
                    filtros.Add(new filterRule()
                    {
                        op = "equal", field = "CreatedDate", value = model.PermisosUsuario.CreatedDate.Value.ToString()
                    });
                }
                //And(d => d.CreatedDate == model.PermisosUsuario.CreatedDate.Value);
            }

            return(filtros);
            //return new QueryObject<PermisosUsuario>(expression ?? (d => true));
        }