using AutoMapper; using Newtonsoft.Json; using OASystem.Domain; using OASystem.Domain.Dtos; using OASystem.Domain.Dtos.CRM; using OASystem.Domain.Dtos.UserDto; using OASystem.Domain.Entities.Customer; using OASystem.Domain.Entities.Groups; using OASystem.Domain.Entities.Resource; using OASystem.Domain.ViewModels.CRM; using OASystem.Domain.ViewModels.Groups; using System; using System.Collections.Generic; using System.Linq; using System.Runtime.Intrinsics.X86; using System.Text; using System.Threading.Tasks; namespace OASystem.Infrastructure.Repositories.CRM { /// /// 签证客户 仓库 /// public class VisaDeleClientRepository : BaseRepository { private readonly IMapper _mapper; public VisaDeleClientRepository(SqlSugarClient sqlSugar,IMapper mapper) : base(sqlSugar) { this._mapper = mapper; } /// /// 签证客户list /// /// /// public async Task GetCrmList(DtoBase dto) { Result result = new Result() { Code = -2 }; if (dto.PortType == 1 || dto.PortType == 2 || dto.PortType == 3) { string sql = string.Format(@"Select cdc.Id,LastName+FirstName ClientName,ccc.CompanyFullName,Sex,Marriage, Phone LandlinePhone,Tel,crmCard1.CertNo IDNo,crmCard2.CertNo PassportNo From Crm_DeleClient cdc Left Join Crm_CustomerCompany ccc On cdc.crmCompanyId = ccc.Id Left Join Crm_CustomerCert crmCard1 On crmCard1.SdId = 773 And cdc.Id = crmCard1.DcId And crmCard1.Isdel=0 Left Join Crm_CustomerCert crmCard2 On crmCard2.SdId = 774 And cdc.Id = crmCard2.DcId And crmCard2.IsDel=0 where cdc.IsDel='0' order By cdc.CreateTime desc"); var clientList = await _sqlSugar.SqlQueryable(sql).ToListAsync(); if (clientList.Count > 0) { result.Code = 0; result.Msg = "成功!"; result.Data = clientList; } else { result.Msg = "暂无数据!"; } } return result; } /// /// 签证客户操作 /// /// /// public async Task CrmClinetoperation(LoginDto loginDto) { Result result = new Result() { Code = -2 }; return result; } /// /// 签证客户 新增 /// /// /// public async Task CrmClinetAdd(Crm_DeleClient client) { int addId = -1; return addId; } /// /// 根据身份证识别修改ocr添加 /// /// /// public async Task SetCrmUpdPassIdCardOCR(SetCrmUpdPassIdCardOCRDto client) { string clientSql = string.Format(@"Select * From Crm_DeleClient Where LastName+FirstName='{0}' And Sex = {1}", client.ClientName, client.Sex); var clientInfo = await _sqlSugar.SqlQueryable(clientSql).FirstAsync(); if(clientInfo == null) return false; string cardSql = string.Format(@"Select * From Crm_CustomerCert Where SdId=773 And DcId={0}", clientInfo.Id); var cardInfo = await _sqlSugar.SqlQueryable(cardSql).FirstAsync(); if (cardInfo == null) //添加 { int cerdAdd = await _sqlSugar.Insertable(new Crm_CustomerCert { DcId = clientInfo.Id, SdId = 773, Country = "中国", CertNo = client.CerdNo, TargetCountry = "", IssueDt = new DateTime(1990, 1, 1), ExpiryDt = new DateTime(1990, 1, 1), CreateUserId = client.UserId, CreateTime = DateTime.Now, DeleteUserId = null, DeleteTime = "1990-01-01 00:00:00.000", Remark = "", IsDel = 0 }).ExecuteReturnIdentityAsync(); if (cerdAdd > 0) return true; } else //修改 { var cerdStatus = await _sqlSugar.Updateable() .Where(c => c.Id == cardInfo.Id) .SetColumns(c => new Crm_CustomerCert { CertNo = cardInfo.CertNo, IDCardAddress = cardInfo.IDCardAddress }).ExecuteCommandAsync(); if (cerdStatus > 0) return true; } return false; } public async Task OpCustomer(DeleClientOpDto dto) { Result result = new Result() { Code = -2, Msg = "未知错误" }; try { BeginTran(); int deleId = 0; if (dto.Status==1)//添加 { string selectSql = string.Format(@"select * from Crm_DeleClient where LastName+FirstName='{0}' and Phone='{1}' and IsDel='{2}'" , dto.DeleClient.LastName+dto.DeleClient.FirstName, dto.DeleClient.Phone, 0); var DeleClient = await _sqlSugar.SqlQueryable(selectSql).FirstAsync();//查询是否存在 if (DeleClient != null) { result = new Result() { Code = -1, Msg = "该客户已存在,请勿重复添加!" }; } else//不存在,可添加 { Crm_DeleClient _CountryFeeCost = _mapper.Map(dto.DeleClient); int id = await AddAsyncReturnId(_CountryFeeCost); if (id == 0) { result = new Result() { Code = -1, Msg = "添加失败!" }; } result = new Result() { Code = 0, Msg = "添加成功!" }; deleId = id; } } else if (dto.Status == 2)//修改 { deleId=dto.DeleClient.Id; DateTime? dateTime = null; bool isDt = DateTime.TryParse(dto.DeleClient.BirthDay, out DateTime dt); if (isDt) dateTime = dt; bool res = await UpdateAsync(a => a.Id == dto.DeleClient.Id, a => new Crm_DeleClient { DiId = dto.DeleClient.DiId, LastName = dto.DeleClient.LastName, FirstName = dto.DeleClient.FirstName, OldName = dto.DeleClient.OldName, Pinyin = dto.DeleClient.Pinyin, Sex = dto.DeleClient.Sex, Marriage = dto.DeleClient.Marriage, Phone = dto.DeleClient.Phone, BirthProvince = dto.DeleClient.BirthProvince, BirthCity = dto.DeleClient.BirthCity, BirthDay = dateTime, AirType = dto.DeleClient.AirType, SeatPref = dto.DeleClient.SeatPref, AirRemark = dto.DeleClient.AirRemark, RoomType = dto.DeleClient.RoomType, RoomPref = dto.DeleClient.RoomPref, Tel = dto.DeleClient.Tel, Email = dto.DeleClient.Email, Address = dto.DeleClient.Address, HighestEducation = dto.DeleClient.HighestEducation, PostCodes = dto.DeleClient.PostCodes, CrmCompanyId = dto.DeleClient.CrmCompanyId, Job = dto.DeleClient.Job, WorkState = dto.DeleClient.WorkState, WorkDate = dto.DeleClient.WorkDate, Wage = dto.DeleClient.Wage, ClientPhone = dto.DeleClient.ClientPhone, ClientFax = dto.DeleClient.ClientFax, ClientEmail = dto.DeleClient.ClientEmail, ClientLeader = dto.DeleClient.ClientLeader, ClientLeaderJob = dto.DeleClient.ClientLeaderJob, IsGetSchengen = dto.DeleClient.IsGetSchengen, StartTime = dto.DeleClient.StartTime, EndTime = dto.DeleClient.EndTime, IsFinger = dto.DeleClient.IsFinger, FingerDate = dto.DeleClient.FingerDate, IsVisitUC = dto.DeleClient.IsVisitUC, USADate = dto.DeleClient.USADate, USADays = dto.DeleClient.USADays, CanDate = dto.DeleClient.CanDate, CanDays = dto.DeleClient.CanDays, IsUSAVia = dto.DeleClient.IsUSAVia, GetUSAVisaDate = dto.DeleClient.GetUSAVisaDate, GetUPPlace = dto.DeleClient.GetUPPlace, USAVisaCate = dto.DeleClient.USAVisaCate, USAVisaCode = dto.DeleClient.USAVisaCode, USAFinger = dto.DeleClient.USAFinger, IsRejected = dto.DeleClient.IsRejected, RejectedDate = dto.DeleClient.RejectedDate, RejectedPlace = dto.DeleClient.RejectedPlace, RejectedVisa = dto.DeleClient.RejectedVisa, IsRevoke = dto.DeleClient.IsRevoke, IsLose = dto.DeleClient.IsLose, LoseDate = dto.DeleClient.LoseDate, LoseCode = dto.DeleClient.LoseCode, IsUSAVisa = dto.DeleClient.IsUSAVisa, MateUSA = dto.DeleClient.MateUSA, MateIden = dto.DeleClient.MateIden, WHUSA = dto.DeleClient.WHUSA, WHIden = dto.DeleClient.WHIden, ParentUSA = dto.DeleClient.ParentUSA, ParentIden = dto.DeleClient.ParentIden, ChildUSA = dto.DeleClient.ChildUSA, ChildIden = dto.DeleClient.ChildIden, BroUSA = dto.DeleClient.BroUSA, BroIden = dto.DeleClient.BroIden, Social = dto.DeleClient.Social, IsArmy = dto.DeleClient.IsArmy, ArmyState = dto.DeleClient.ArmyState, CostBearers = dto.DeleClient.CostBearers, TableOpName = dto.DeleClient.TableOpName, TableOpTel = dto.DeleClient.TableOpTel, TableDate = dto.DeleClient.TableDate, Party = dto.DeleClient.Party, Nationality = dto.DeleClient.Nationality, WeddingDate = dto.DeleClient.WeddingDate, DivorceDate = dto.DeleClient.DivorceDate, MateName = dto.DeleClient.MateName, MateBirthDay = dto.DeleClient.MateBirthDay, MateBirthCity = dto.DeleClient.MateBirthCity, MateBirthCountry = dto.DeleClient.MateBirthCountry, MateAddress = dto.DeleClient.MateAddress, MateClient = dto.DeleClient.MateClient, MateClientAddress = dto.DeleClient.MateClientAddress, MateJob = dto.DeleClient.MateJob, VisitCountry = dto.DeleClient.VisitCountry, Paper = dto.DeleClient.Paper, Papent = dto.DeleClient.Papent, PhD = dto.DeleClient.PhD, CreateUserId = dto.DeleClient.CreateUserId, Remark = dto.DeleClient.Remark, }); if (!res) { result = new Result() { Code = -1, Msg = "修改失败!" }; } result = new Result() { Code = 0, Msg = "修改成功!" }; } //进行其他表 if (result.Code == 0) {//家庭成员信息 foreach (CustomerFamily item in dto.CustomerFamily) { Crm_VisaCustomerFamily Crm_VisaCustomerFamily = _mapper.Map(item); Crm_VisaCustomerFamily.DcId = deleId; if (item.Id != 0)//修改 { int res = await _sqlSugar.Updateable().Where(a => a.Id == Crm_VisaCustomerFamily.Id).SetColumns(a => new Crm_VisaCustomerFamily { Appellation = Crm_VisaCustomerFamily.Appellation, Name = Crm_VisaCustomerFamily.Name, BirthDay = Crm_VisaCustomerFamily.BirthDay, BirthPlace = Crm_VisaCustomerFamily.BirthPlace, Politics = Crm_VisaCustomerFamily.Politics, Client = Crm_VisaCustomerFamily.Client, Address = Crm_VisaCustomerFamily.Address, IsEu = Crm_VisaCustomerFamily.IsEu, NameSnd = Crm_VisaCustomerFamily.NameSnd, BirthDaySnd = Crm_VisaCustomerFamily.BirthDaySnd, Nationality = Crm_VisaCustomerFamily.Nationality, IDCard = Crm_VisaCustomerFamily.IDCard, Reletionship = Crm_VisaCustomerFamily.Reletionship, IsUSA = Crm_VisaCustomerFamily.IsUSA, Remark = Crm_VisaCustomerFamily.Remark, }).ExecuteCommandAsync(); if (res==0) { result = new Result() { Code = -1, Msg = "家庭成员信息保存失败!" }; RollbackTran(); } } else if (item.Id == 0)//添加 { int sss= await _sqlSugar.Insertable(Crm_VisaCustomerFamily).ExecuteReturnIdentityAsync(); if (sss == 0) { result = new Result() { Code = -1, Msg = "家庭成员信息保存失败!" }; RollbackTran(); } } } //证件表信息 foreach (CustomerCerts item in dto.CustomerCert) { Crm_CustomerCert CustomerCert = _mapper.Map(item); CustomerCert.DcId = deleId; if (item.Id != 0)//修改 { int res = await _sqlSugar.Updateable().Where(a => a.Id == CustomerCert.Id).SetColumns(a => new Crm_CustomerCert { DcId=CustomerCert.DcId, SdId = CustomerCert.SdId, CertNo = CustomerCert.CertNo, Country = CustomerCert.Country, Area = CustomerCert.Area, TargetCountry = CustomerCert.TargetCountry, IssueDt = CustomerCert.IssueDt, ExpiryDt = CustomerCert.ExpiryDt, IDCardAddress = CustomerCert.IDCardAddress, CreateUserId = CustomerCert.CreateUserId, Remark = CustomerCert.Remark, }).ExecuteCommandAsync(); if (res == 0) { result = new Result() { Code = -1, Msg = "证件信息保存失败!" }; RollbackTran(); } } else if (item.Id == 0)//添加 { int sss = await _sqlSugar.Insertable(CustomerCert).ExecuteReturnIdentityAsync(); if (sss == 0) { result = new Result() { Code = -1, Msg = "证件信息保存失败!" }; RollbackTran(); } } } //客户工作经历表 foreach (VisaCustomerCompany item in dto.WorkExperience) { Crm_VisaCustomerCompany VisaCustomerCompany = _mapper.Map(item); VisaCustomerCompany.DcId = deleId; if (item.Id != 0)//修改 { int res = await _sqlSugar.Updateable().Where(a => a.Id == VisaCustomerCompany.Id).SetColumns(a => new Crm_VisaCustomerCompany { DcId=VisaCustomerCompany.DcId, Company = VisaCustomerCompany.Company, CompanyAddress = VisaCustomerCompany.CompanyAddress, Phone = VisaCustomerCompany.Phone, Job = VisaCustomerCompany.Job, LeaderName = VisaCustomerCompany.LeaderName, WorkStart = VisaCustomerCompany.WorkStart, WorkEnd = VisaCustomerCompany.WorkEnd, WorkState = VisaCustomerCompany.WorkState, CreateUserId = VisaCustomerCompany.CreateUserId, Remark = VisaCustomerCompany.Remark, }).ExecuteCommandAsync(); if (res == 0) { result = new Result() { Code = -1, Msg = "客户工作经历保存失败!" }; RollbackTran(); } } else if (item.Id == 0)//添加 { int sss = await _sqlSugar.Insertable(VisaCustomerCompany).ExecuteReturnIdentityAsync(); if (sss == 0) { result = new Result() { Code = -1, Msg = "客户工作经历保存失败!" }; RollbackTran(); } } } //客户学历表 foreach (VisaCustomerSchool item in dto.CustomerSchool) { Crm_VisaCustomerSchool VisaCustomerSchool = _mapper.Map(item); VisaCustomerSchool.DcId = deleId; if (item.Id != 0)//修改 { int res = await _sqlSugar.Updateable().Where(a => a.Id == VisaCustomerSchool.Id).SetColumns(a => new Crm_VisaCustomerSchool { DcId = VisaCustomerSchool.DcId, School = VisaCustomerSchool.School, Address = VisaCustomerSchool.Address, Teacher = VisaCustomerSchool.Teacher, Education = VisaCustomerSchool.Education, Subject = VisaCustomerSchool.Subject, StudyStart = VisaCustomerSchool.StudyStart, StudyEnd = VisaCustomerSchool.StudyEnd, CreateUserId = VisaCustomerSchool.CreateUserId, Remark = VisaCustomerSchool.Remark, }).ExecuteCommandAsync(); if (res == 0) { result = new Result() { Code = -1, Msg = "客户学历信息保存失败!" }; RollbackTran(); } } else if (item.Id == 0)//添加 { int sss = await _sqlSugar.Insertable(VisaCustomerSchool).ExecuteReturnIdentityAsync(); if (sss == 0) { result = new Result() { Code = -1, Msg = "客户学历信息保存失败!" }; RollbackTran(); } } } CommitTran(); } } catch (Exception ex) { return result = new Result() { Code = -2, Msg = "程序错误!" }; throw; } return result; } public async Task DelCustomer(DeleClientDelDto dto) { Result result = new Result() { Code = -2, Msg = "未知错误" }; try { bool isOk=await SoftDeleteByIdAsync(dto.Id.ToString(),dto.DeleteUserId); if (isOk)//删除其他表数据 { //客户工作经历 await _sqlSugar.Updateable().Where(a => a.DcId==dto.Id).SetColumns(a => new Crm_VisaCustomerCompany() { IsDel = 1, DeleteUserId = dto.DeleteUserId, DeleteTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") }).ExecuteCommandAsync(); //客户学历 await _sqlSugar.Updateable().Where(a => a.DcId == dto.Id).SetColumns(a => new Crm_VisaCustomerSchool() { IsDel = 1, DeleteUserId = dto.DeleteUserId, DeleteTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") }).ExecuteCommandAsync(); //客户家庭成员信息 await _sqlSugar.Updateable().Where(a => a.DcId == dto.Id).SetColumns(a => new Crm_VisaCustomerFamily() { IsDel = 1, DeleteUserId = dto.DeleteUserId, DeleteTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") }).ExecuteCommandAsync(); //客户证件表 await _sqlSugar.Updateable().Where(a => a.DcId == dto.Id).SetColumns(a => new Crm_CustomerCert() { IsDel = 1, DeleteUserId = dto.DeleteUserId, DeleteTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") }).ExecuteCommandAsync(); return result = new Result() { Code = 0, Msg = "删除成功!" }; } } catch (Exception ex) { return result = new Result() { Code = -2, Msg = "程序错误!" }; throw; } return result; } } }