예제 #1
0
        public async Task <Object> GetGeneralStatistics(TSTBGeneralStatisticsParams userParams)
        {
            var result      = _context.DanhSachTaiSanThietBi.AsQueryable();
            var totalTSTB   = 0;    // tổng số TSTB
            var hoatDongTot = 0;    // tổng số TSTB đang hoạt động tốt
            var dangSuaChua = 0;    // tổng số TSTB đang sửa chửa
            var dangBaoHanh = 0;    // tổng số TSTB đang bảo hành
            var daQuaSuDung = 0;    // tổng số TSTB đã qua sử dụng

            if (userParams != null && userParams.StartingTime.GetHashCode() != 0 && userParams.EndingTime.GetHashCode() != 0)
            {
                totalTSTB   = result.Count();
                hoatDongTot = result.Where(x => x.ThoiGianTao >= userParams.StartingTime && x.ThoiGianTao <= userParams.EndingTime && x.TinhTrang == "Hoạt động tốt").Count();
                dangSuaChua = result.Where(x => x.ThoiGianTao >= userParams.StartingTime && x.ThoiGianTao <= userParams.EndingTime && x.TinhTrang == "Đang sửa chữa").Count();
                dangBaoHanh = result.Where(x => x.ThoiGianTao >= userParams.StartingTime && x.ThoiGianTao <= userParams.EndingTime && x.TinhTrang == "Đang bảo hành").Count();
                daQuaSuDung = result.Where(x => x.ThoiGianTao >= userParams.StartingTime && x.ThoiGianTao <= userParams.EndingTime && x.TinhTrang == "Đã qua sử dụng").Count();
            }
            else
            {
                totalTSTB   = result.Count();
                hoatDongTot = result.Where(x => x.TinhTrang == "Hoạt động tốt").Count();
                dangSuaChua = result.Where(x => x.TinhTrang == "Đang sửa chữa").Count();
                dangBaoHanh = result.Where(x => x.TinhTrang == "Đang bảo hành").Count();
                daQuaSuDung = result.Where(x => x.TinhTrang == "Đã qua sử dụng").Count();
            }

            return(new
            {
                Total = totalTSTB,
                HoatDongTot = hoatDongTot,
                DangSuaChua = dangSuaChua,
                DangBaoHanh = dangBaoHanh,
                DaQuaSuDung = daQuaSuDung,
            });
        }
예제 #2
0
        public async Task <IActionResult> GetGeneralStatistics([FromQuery] TSTBGeneralStatisticsParams userParams)
        {
            try
            {
                var result = await _repo.GetGeneralStatistics(userParams);

                return(StatusCode(200, new SuccessResponseDto
                {
                    Message = "Lấy dữ liệu thống kê tổng quan về " + _entityName + " thành công!",
                    Result = new SuccessResponseResultWithSingleDataDto
                    {
                        Data = result
                    }
                }));
            }
            catch (Exception e)
            {
                return(StatusCode(500, new FailedResponseDto
                {
                    Message = "Lấy dữ liệu thống kê tổng quan về " + _entityName + " thất bại!",
                    Result = new FailedResponseResultDto
                    {
                        Errors = e
                    }
                }));
            }
        }