Ejemplo n.º 1
0
        public async Task <StatusCodigo> GetById(StatusCodigoFilter model)
        {
            var _statuscodigo = await this.SingleOrDefaultAsync(this.GetAll(this.DataAgregation(model))
                                                                .Where(_ => _.StatusCodigoId == model.StatusCodigoId));

            return(_statuscodigo);
        }
Ejemplo n.º 2
0
        public async Task <dynamic> GetDataCustom(StatusCodigoFilter filters)
        {
            var querybase = await this.ToListAsync(this.GetBySimplefilters(filters).Select(_ => new
            {
                Id = _.StatusCodigoId
            }));

            return(querybase);
        }
Ejemplo n.º 3
0
        public async Task <PaginateResult <dynamic> > GetDataListCustomPaging(StatusCodigoFilter filters)
        {
            var querybase = await this.PagingDataListCustom <dynamic>(filters, this.GetBySimplefilters(filters).Select(_ => new
            {
                Id = _.StatusCodigoId
            }));

            return(querybase);
        }
Ejemplo n.º 4
0
        public async Task <IEnumerable <dynamic> > GetDataItem(StatusCodigoFilter filters)
        {
            var querybase = await this.ToListAsync(this.GetBySimplefilters(filters).Select(_ => new
            {
                Id   = _.StatusCodigoId,
                Name = _.Description
            }));

            return(querybase);
        }
Ejemplo n.º 5
0
        public IQueryable <StatusCodigo> GetBySimplefilters(StatusCodigoFilter filters)
        {
            var querybase = this.GetAll(this.DataAgregation(filters))
                            .WithBasicFilters(filters)
                            .WithCustomFilters(filters)
                            .OrderByDomain(filters)
                            .OrderByProperty(filters);

            return(querybase);
        }
Ejemplo n.º 6
0
 public static IQueryable <StatusCodigo> OrderByDomain(this IQueryable <StatusCodigo> queryBase, StatusCodigoFilter filters)
 {
     return(queryBase.OrderBy(_ => _.StatusCodigoId));
 }
        public static IQueryable <StatusCodigo> WithCustomFilters(this IQueryable <StatusCodigo> queryBase, StatusCodigoFilter filters)
        {
            var queryFilter = queryBase;


            return(queryFilter);
        }
        public async Task <IActionResult> Get([FromQuery] StatusCodigoFilter filters)
        {
            var result = new HttpResult <dynamic>(this._logger);

            try
            {
                if (filters.FilterBehavior == FilterBehavior.GetDataItem)
                {
                    var searchResult = await this._rep.GetDataItem(filters);

                    return(result.ReturnCustomResponse(searchResult, filters));
                }

                if (!this._user.GetClaims().GetTools().VerifyClaimsCanRead("StatusCodigo"))
                {
                    return(new ObjectResult(null)
                    {
                        StatusCode = (int)HttpStatusCode.Forbidden
                    });
                }


                if (filters.FilterBehavior == FilterBehavior.GetDataCustom)
                {
                    var searchResult = await this._rep.GetDataCustom(filters);

                    return(result.ReturnCustomResponse(searchResult, filters));
                }

                if (filters.FilterBehavior == FilterBehavior.GetDataListCustom)
                {
                    var searchResult = await this._rep.GetDataListCustom(filters);

                    return(result.ReturnCustomResponse(searchResult, filters));
                }

                if (filters.FilterBehavior == FilterBehavior.GetDataListCustomPaging)
                {
                    var paginatedResult = await this._rep.GetDataListCustomPaging(filters);

                    return(result.ReturnCustomResponse(paginatedResult.ToSearchResult <dynamic>(), filters));
                }


                if (filters.FilterBehavior == FilterBehavior.Export)
                {
                    var searchResult = await this._rep.GetDataListCustom(filters);

                    var export = new ExportExcelCustom <dynamic>(filters);
                    var file   = export.ExportFile(this.Response, searchResult, "StatusCodigo", this._env.RootPath);
                    return(File(file, export.ContentTypeExcel(), export.GetFileName()));
                }

                throw new InvalidOperationException("invalid FilterBehavior");
            }
            catch (Exception ex)
            {
                var responseEx = result.ReturnCustomException(ex, "Seed - StatusCodigo", filters, new ErrorMapCustom());
                return(responseEx);
            }
        }
        public static IQueryable <StatusCodigo> WithBasicFilters(this IQueryable <StatusCodigo> queryBase, StatusCodigoFilter filters)
        {
            var queryFilter = queryBase;

            if (filters.Ids.IsSent())
            {
                queryFilter = queryFilter.Where(_ => filters.GetIds().Contains(_.StatusCodigoId));
            }

            if (filters.StatusCodigoId.IsSent())
            {
                queryFilter = queryFilter.Where(_ => _.StatusCodigoId == filters.StatusCodigoId);
            }
            if (filters.Description.IsSent())
            {
                queryFilter = queryFilter.Where(_ => _.Description.Contains(filters.Description));
            }


            return(queryFilter);
        }