using AutoMapper; using MySqlX.XDevAPI.Common; using OASystem.Domain; using OASystem.Domain.Dtos.Groups; using OASystem.Domain.Entities.Groups; using OASystem.Domain.Entities.Resource; using OASystem.Domain.ViewModels.Groups; using SqlSugar; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using Result = OASystem.Domain.Result; namespace OASystem.Infrastructure.Repositories.Groups { /// /// 倒推表 仓储 /// public class InvertedListRepository:BaseRepository { private readonly IMapper _mapper; private readonly Result _result; private readonly DelegationInfoRepository _delegationInfoRep; public InvertedListRepository(SqlSugarClient sqlSugar, IMapper mapper, DelegationInfoRepository delegationInfoRep) : base(sqlSugar) { _mapper = mapper; _result = new Result() { Code = -1, Msg = "系统错误!", Data = new List() { } }; _delegationInfoRep = delegationInfoRep; } /// /// 基础数据 /// /// public async Task _Init() { dynamic groupData = null; var groupData1 = await _delegationInfoRep.PostShareGroupInfos(1); if (groupData1.Code == 0) { groupData = groupData1.Data; } var setData = await _sqlSugar.Queryable().Where(it => it.IsDel == 0).ToListAsync(); var officialTypeData = setData.Where(it => it.STid == 81).Select(it => new { it.Id,it.Name }).ToList(); var visaTypeData = setData.Where(it => it.STid == 82).Select(it => new { it.Id, it.Name }).ToList(); _result.Code = 0; _result.Msg = "操作成功!"; _result.Data = new { groupData = groupData, officialTypeData = officialTypeData, visaTypeData = visaTypeData }; return _result; } /// /// Info /// /// public async Task _Info(int portTypeId,int diId) { #region 参数验证 if (portTypeId < 1) { _result.Msg = "请输入有效的PortType参数值"; return _result; } if (diId < 1) { _result.Msg = "请输入有效的DiId参数值"; return _result; } #endregion string sql = string.Format(@$"Select * From Grp_InvertedList Where Isdel={0} And DiId = {diId}"); var info = await _sqlSugar.SqlQueryable(sql).FirstAsync(); if (info == null) { info = new InvertedListInfoView(); info.IsQuery = true; var groupInfo = await _sqlSugar.Queryable().Where(it => it.IsDel == 0 && it.Id == diId).FirstAsync(); if (groupInfo == null) { _result.Msg = @$"团组数据不存在!"; return _result; } List visitCountry = new List(); string grpVisitCountry = groupInfo.VisitCountry; if (!string.IsNullOrEmpty(grpVisitCountry)) { grpVisitCountry = _delegationInfoRep.FormartTeamName(grpVisitCountry); visitCountry = grpVisitCountry.Split("、").ToList(); } string sqqzRemark = ""; //签证费用标准 var visaFeeDatas = await _sqlSugar.Queryable().Where(it => it.IsDel == 0).ToListAsync(); List visaCountryInfos = new List(); string countryStr = ""; string countryDesc = ""; foreach (var item in visitCountry) { int visaDays = Convert.ToInt32(visaFeeDatas.Find(it => it.VisaCountry.Equals(item.Trim()))?.VisaTime ?? "0"); visaCountryInfos.Add(new VisaCountryInfo() { Country = item, OfficialTypeId = -1, VisaTypeId = -1, VisaDay = visaDays }); countryStr += $"{item}、"; countryDesc += $"{item}签证{visaDays}个工作日,"; } if (countryStr.Length > 0) { countryStr = countryStr.Substring(0, countryStr.Length - 1); } if (countryDesc.Length > 0) { countryDesc = countryDesc.Substring(0, countryDesc.Length - 1); } sqqzRemark = $"申请{countryStr}签证;{countryDesc}\r\n(签证周期仅供参考)"; info.VisaCountryData = visaCountryInfos; info.SendVisaRemark = sqqzRemark; _result.Data = info; _result.Msg = "未查询到数据!"; _result.Code = 0; return _result; } int ilId = info.Id; string visaSql = string.Format(@$"Select * From Grp_InvertedListVisaCountry Where Isdel={0} And ILId = {ilId}"); var visaCountryInfo = await _sqlSugar.SqlQueryable(visaSql).ToListAsync(); info.VisaCountryData = visaCountryInfo; _result.Data = info; _result.Code = 0; return _result; } /// /// Create /// /// /// public async Task _Create(int userId,int diId) { #region 参数验证 if (diId < 1) { _result.Msg = $@"请输入有效的DiId参数值!"; return _result; } if (userId < 1) { _result.Msg = $@"请输入有效的UserId参数值!"; return _result; } #endregion var selectInfo = await _sqlSugar.Queryable().Where(it => it.IsDel == 0 && it.DiId == diId).FirstAsync(); if (selectInfo != null) { _result.Msg = @$"该数据已存在,不可重复创建!"; return _result; } var groupInfo = await _sqlSugar.Queryable().Where(it => it.IsDel == 0 && it.Id == diId).FirstAsync(); if (groupInfo == null) { _result.Msg = @$"团组数据不存在,不可创建!"; return _result; } if (string.IsNullOrEmpty( groupInfo.VisitDate.ToString())) { _result.Msg = @$"团组出访时间未填写,不可创建!"; return _result; } DateTime visitDt = groupInfo.VisitDate; List visitCountry = new List(); string grpVisitCountry = groupInfo.VisitCountry; if (!string.IsNullOrEmpty(grpVisitCountry)) { grpVisitCountry = _delegationInfoRep.FormartTeamName(grpVisitCountry); visitCountry = grpVisitCountry.Split("、").ToList(); } //签证费用标准 var visaFeeDatas = await _sqlSugar.Queryable().Where(it => it.IsDel == 0).ToListAsync(); string sqqzRemark = ""; List visaCountryInfos = new List(); string countryStr = string.Empty,countryDesc = string.Empty; foreach (var item in visitCountry) { int visaDays = Convert.ToInt32(visaFeeDatas.Find(it => it.VisaCountry.Equals(item.Trim()))?.VisaTime ?? "0"); visaCountryInfos.Add(new VisaCountryInfo() { Country = item, OfficialTypeId = -1, VisaTypeId = -1, VisaDay = visaDays }); countryStr += $"{item}、"; countryDesc += $"{item}签证{visaDays}个工作日,"; } if (countryStr.Length > 0) countryStr = countryStr[..^1]; if (countryDesc.Length > 0) countryDesc = countryDesc[..^1]; sqqzRemark = $"申请{countryStr}签证;{countryDesc}\r\n(签证周期仅供参考)"; /* * 默认步骤所需提前天数 * A 自然日 B 工作日 */ int approvalData_advanceDays = -60, //报批资料准备 approval_advanceDays = -45, //报批 IssueApproval_advanceDays = -33, //出批件、办护照 //ApplyPassport_advanceDays = -30, //办护照 VisaInformation_advanceDays = -16, //签证资料准备 sendVisa_advanceDays = -12, //送签 issueVisa_advanceDays = -5, //出签 preTripMeeting_advanceDays = -3, //行前会 airportdDropOff_advanceDays = 0; //送机 var info = new Grp_InvertedList() { DiId = diId, ApprovalDataDt = visitDt.AddDays(approvalData_advanceDays).ToString("yyyy-MM-dd"), ApprovalDt = visitDt.AddDays(approval_advanceDays).ToString("yyyy-MM-dd"), ApprovalType = -1, IssueApprovalDt = visitDt.AddDays(IssueApproval_advanceDays).ToString("yyyy-MM-dd"), //ApplyPassportDt = visitDt.AddDays(ApplyPassport_advanceDays).ToString("yyyy-MM-dd"), VisaInformationDt = visitDt.AddDays(VisaInformation_advanceDays).ToString("yyyy-MM-dd"), SendVisaDt = visitDt.AddDays(sendVisa_advanceDays).ToString("yyyy-MM-dd"), IssueVisaDt = visitDt.AddDays(issueVisa_advanceDays).ToString("yyyy-MM-dd"), AirTicketDt = visitDt.AddDays(issueVisa_advanceDays).ToString("yyyy-MM-dd"), //机票 应国交部要求默认使用出签时间 HotelDt = visitDt.AddDays(issueVisa_advanceDays).ToString("yyyy-MM-dd"), //酒店 应国交部要求默认使用出签时间 PreTripMeetingDt = visitDt.AddDays(preTripMeeting_advanceDays).ToString("yyyy-MM-dd"), AirportdDropOffDt = visitDt.AddDays(airportdDropOff_advanceDays).ToString("yyyy-MM-dd"), CreateUserId = userId, }; if (!string.IsNullOrEmpty(sqqzRemark)) info.SendVisaRemark = sqqzRemark; _sqlSugar.BeginTran(); int add1 = await _sqlSugar.Insertable(info).ExecuteReturnIdentityAsync(); if (add1<1) { _result.Msg = $@"倒推表添加失败!"; _sqlSugar.RollbackTran(); return _result; } var _InvertedListVisaCountries = new List(); foreach (var item in visitCountry) { int days = Convert.ToInt32(visaFeeDatas.Find(x => x.VisaCountry.Equals(item.Trim()))?.VisaTime ?? "0"); _InvertedListVisaCountries.Add(new Grp_InvertedListVisaCountry() { ILId = add1, Country = item, OfficialTypeId = -1, VisaTypeId = -1, VisaDay = days, }); } int add2 = await _sqlSugar.Insertable(_InvertedListVisaCountries).ExecuteReturnIdentityAsync(); _sqlSugar.CommitTran(); _result.Code = 0; _result.Msg = @$"操作成功!"; return _result; } /// /// Update /// /// /// public async Task _Update(InvertedListUpdateDto dto) { #region 参数验证 if (dto.DiId < 1) { _result.Msg = $@"请输入有效的DiId参数值!"; return _result; } if (dto.Id < 1) { _result.Msg = $@"请输入有效的Id参数值!"; return _result; } #endregion Grp_InvertedList _InvertedList = _mapper.Map(dto); List _InvertedListVisaCountries = new List(); if (dto.VisaCountryData.Count > 0) { _InvertedListVisaCountries = _mapper.Map>(dto.VisaCountryData); } _sqlSugar.BeginTran(); int update1 = await _sqlSugar.Updateable(_InvertedList) .IgnoreColumns(it => new { it.CreateTime,it.IsDel }) .ExecuteCommandAsync(); if (update1 < 1) { _sqlSugar.RollbackTran(); _result.Msg = @$"修改失败!"; return _result; } if (_InvertedListVisaCountries.Count > 0) { int update2 = await _sqlSugar.Updateable(_InvertedListVisaCountries) .IgnoreColumns(it => new { it.CreateTime, it.IsDel }) .ExecuteCommandAsync(); if (update2 < 1) { _sqlSugar.RollbackTran(); _result.Msg = @$"修改失败!"; return _result; } } _sqlSugar.CommitTran(); _result.Code = 0; _result.Msg = @$"操作成功!"; return _result; } } }