using AutoMapper;
using LinqKit;
using Ropin.Inspection.Common.Accessor.Interface;
using Ropin.Inspection.Model;
using Ropin.Inspection.Model.Entities;
using Ropin.Inspection.Repository;
using Ropin.Inspection.Repository.Interface;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Linq.Expressions;
using System.Text;
using System.Threading.Tasks;

namespace Ropin.Inspection.Service
{
    public class TdevMaintenancePlanService : ITdevMaintenancePlanService
    {
        private readonly ITdevMaintenancePlanRepository _repository;
        private readonly ITdevMaintenancePlanContentRepository _devMaintenancePlanContentRepository;
        private readonly IMapper _mapper;
        private readonly IClaimsAccessor _claims;
        public TdevMaintenancePlanService(IClaimsAccessor claims, ITdevMaintenancePlanContentRepository devMaintenancePlanContentRepository,ITdevMaintenancePlanRepository repository, IMapper mapper)
        {
            _repository = repository;
            _devMaintenancePlanContentRepository = devMaintenancePlanContentRepository;
            _mapper = mapper;
            _claims = claims;
        }
        public async Task CreateOneAsync(TdevMaintenancePlanViewModel viewModel)
        {
            var content = _mapper.Map<TDEV_MaintenancePlan>(viewModel);
            content.C_ID = Guid.NewGuid().ToString();
            content.C_CreateBy = _claims.ApiUserId;
            content.D_CreateOn = DateTime.Now;
            content.C_Status = "1";
            _repository.Create(content);
            var result = await _repository.SaveAsync();
            IList <TDEV_MaintenancePlanContent> planContentList = new List<TDEV_MaintenancePlanContent>();
            foreach (var item in viewModel.MaintenancePlanContentList)
            {
                planContentList.Add(new TDEV_MaintenancePlanContent {
                    C_ID = Guid.NewGuid().ToString(),
                    C_DeviceTempOpsContentCode = item,
                    C_MaintenancePlanCode = content.C_ID,
                    //I_Cycle = 0,
                    C_CreateBy = _claims.ApiUserId,
                    D_CreateOn = DateTime.Now,
                });
            }
            await _devMaintenancePlanContentRepository.CreateRangeAsync(planContentList);

            if (!result)
            {
                throw new Exception("创建失败");
            }
        }

        public async Task DeleteAsync(Guid id)
        {
            var content = await _repository.GetByIdAsync(id);
            if (content == null)
            {
                throw new Exception("数据库中没有此数据");
            }
            //_repository.Delete(content);
            //var result = await _repository.SaveAsync();
            content.C_LastUpdatedBy = _claims.ApiUserId;
            content.D_LastUpdatedOn = DateTime.Now;
            content.C_Status = "0";
            _repository.Update(content);
            var result = await _repository.SaveAsync();
            if (!result)
            {
                throw new Exception("删除失败");
            }
        }
        public async Task DeleteAsync(string code)
        {
            var items = await _repository.GetByConditionAsync(C => C.C_ID == code);
            var content = items.FirstOrDefault();
            if (content == null)
            {
                throw new Exception("没有此数据");
            }
            content.C_LastUpdatedBy = _claims.ApiUserId;
            content.D_LastUpdatedOn = DateTime.Now;
            content.C_Status = "0";
            _repository.Update(content);
            var result = await _repository.SaveAsync();
            if (!result)
            {
                throw new Exception("删除失败");
            }
        }
        public async Task<IEnumerable<TdevMaintenancePlanViewModel>> GetAllAsync()
        {
            var pagedList = await _repository.GetAllAsync();
            var contentDtoList = _mapper.Map<IEnumerable<TdevMaintenancePlanViewModel>>(pagedList.Where(i => i.C_Status == "1").ToList());
            return contentDtoList.ToList();
        }
        public async Task<IEnumerable<TdevMaintenancePlanViewModel>> GetConditionAsync(TdevMaintenancePlanSearchModel searchModel)
        {
            var predicate = PredicateBuilder.New<TDEV_MaintenancePlan>(true);//查询条件,推荐后台使用这种方式灵活筛选
            #region 添加条件查询
            //predicate = predicate.And(i => i.C_Status.Equals("1"));
            if (!string.IsNullOrEmpty(searchModel.C_DevTempCode))
            {
                predicate = predicate.And(i => i.C_DevTempCode.Equals(searchModel.C_DevTempCode));
            }
            if (!string.IsNullOrEmpty(searchModel.C_StoreCode))
            {
                if (searchModel.IsPublic)
                {
                    predicate = predicate.And(i => i.C_StoreCode.Equals(searchModel.C_StoreCode) || i.C_StoreCode.Equals("public"));
                }
                else
                {
                    predicate = predicate.And(i => i.C_StoreCode.Equals(searchModel.C_StoreCode));
                }

            }
            if (!string.IsNullOrEmpty(searchModel.C_ID))
            {
                predicate = predicate.And(i => i.C_ID.Equals(searchModel.C_ID));
            }
            if (!string.IsNullOrEmpty(searchModel.C_Name))
            {
                predicate = predicate.And(i => i.C_Name.Contains(searchModel.C_Name));
            }
            #endregion
            var list = await _repository.GetPageAsync(predicate, "C_Name,-D_CreateOn", searchModel.IsPagination, searchModel.PageIndex, searchModel.PageSize);
            searchModel.TotalCount = list.Totals;
            var dtoList = _mapper.Map<List<TDEV_MaintenancePlan>, List<TdevMaintenancePlanViewModel>>(list.Rows);

            
            return dtoList;
        }
        //private async Task<TdevMaintenancePlanViewModel> GetPlanContentByIdAsync(string id)
        //{
            
        //    await _devMaintenancePlanContentRepository.GetByConditionAsync(sm);
        //}

        public async Task<TdevMaintenancePlanViewModel> GetByIdAsync(Guid id)
        {
            var content = await _repository.GetByIdAsync(id);
            var contentDto = _mapper.Map<TdevMaintenancePlanViewModel>(content);
            return contentDto;
        }


        public async Task UpdateAsync(string code, TdevMaintenancePlanUpdateModel updateModel)
        {
            var items = await _repository.GetByConditionAsync(C => C.C_ID == code);
            var content = items.FirstOrDefault();
            if (content == null)
            {
                throw new Exception("没有此数据");
            }
            content.C_LastUpdatedBy = _claims.ApiUserId;
            content.D_LastUpdatedOn = DateTime.Now;
            _mapper.Map(updateModel, content, typeof(TdevMaintenancePlanUpdateModel), typeof(TDEV_MaintenancePlan));
            _repository.Update(content);
            var result = await _repository.SaveAsync();

            IEnumerable<TDEV_MaintenancePlanContent> planContent = await _devMaintenancePlanContentRepository.GetByConditionAsync(PredicateBuilder.New<TDEV_MaintenancePlanContent>(true).And(i => i.C_MaintenancePlanCode.Equals(code)));
            await _devMaintenancePlanContentRepository.RemoveRangeAsync(planContent);
            IList<TDEV_MaintenancePlanContent> planContentList = new List<TDEV_MaintenancePlanContent>();
            foreach (var item in updateModel.MaintenancePlanContentList)
            {
                planContentList.Add(new TDEV_MaintenancePlanContent
                {
                    C_ID = Guid.NewGuid().ToString(),
                    C_DeviceTempOpsContentCode = item,
                    C_MaintenancePlanCode = content.C_ID,
                    //I_Cycle = 0,
                    C_CreateBy = _claims.ApiUserId,
                    D_CreateOn = DateTime.Now,
                });
            }
            await _devMaintenancePlanContentRepository.CreateRangeAsync(planContentList);



            if (!result)
            {
                throw new Exception("更新失败");
            }
        }

        public Task<int> UpdateOneAsync(TdevMaintenancePlanViewModel viewModel, params string[] fields)
        {
            throw new NotImplementedException();
        }

        public Task<bool> IsExistAsync(Guid id)
        {
            throw new NotImplementedException();
        }

        public Task<IEnumerable<TdevMaintenancePlanViewModel>> GetByConditionAsync(Expression<Func<TdevMaintenancePlanViewModel, bool>> expression)
        {
            throw new NotImplementedException();
        }

        public Task UpdateAsync(string code, TpntAreaUpdateModel updateModel)
        {
            throw new NotImplementedException();
        }

        public Task<IEnumerable<TdevMaintenancePlanViewModel>> GetConditionAsync(TpntAreaSearchModel searchModel)
        {
            throw new NotImplementedException();
        }
    }
}