using NPOI.SS.Formula.Functions; using OASystem.API.OAMethodLib.AMapApi; using OASystem.Domain.AesEncryption; using OASystem.Domain.Dtos.CRM; using OASystem.Domain.Entities.Customer; using OASystem.Infrastructure.Repositories.CRM; namespace OASystem.API.Controllers { /// /// 签证客户资料相关 /// [Route("api/[controller]/[action]")] //[ApiController] public class CRMController : ControllerBase { private readonly VisaDeleClientCompanyRepository _clientCompanyRepository; private readonly VisaDeleClientRepository _clientRepository; private readonly CustomerCertRepository _customerCertRep; private readonly CustomerFamilyRepository _customerFamilyRep; private readonly CustomerSchoolRepository _customerSchoolRep; private readonly CustomerCompanyRepository _customerCompanyRep; private readonly GeocodeService _geocodeService; /// /// 初始化 /// /// /// /// /// /// /// /// public CRMController( VisaDeleClientCompanyRepository clientCompanyRepository, VisaDeleClientRepository clientRepository, CustomerCertRepository customerCertRep, CustomerFamilyRepository customerFamilyRep, CustomerSchoolRepository customerSchoolRep, CustomerCompanyRepository customerCompanyRep, GeocodeService geocodeService ) { this._clientCompanyRepository = clientCompanyRepository; this._clientRepository = clientRepository; this._customerCertRep = customerCertRep; this._customerFamilyRep = customerFamilyRep; this._customerSchoolRep = customerSchoolRep; _customerCompanyRep = customerCompanyRep; _geocodeService = geocodeService; } /// /// 获取签证客户公司列表 /// /// /// [HttpPost] [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)] public async Task GetClientCompanyList(DtoBase dto) { var clientCompanyData = await _clientCompanyRepository.GetCrm_ClientCompanyList(dto); if (clientCompanyData.Code != 0) { return Ok(JsonView(false, clientCompanyData.Msg == null ? "操作失败" : clientCompanyData.Msg)); } return Ok(JsonView(clientCompanyData.Data, clientCompanyData.Data.Count)); } /// /// 签证客户公司列表操作(Status:1.新增,2.修改) /// /// /// [HttpPost] [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)] public async Task OperationClientCompany(OperationClientCompanyDto dto) { try { if (dto.CompanyName == "") { return Ok(JsonView(false, "请检查客户单位名称是否填写!")); } if (dto.Address == "") { return Ok(JsonView(false, "请检查客户单位地址是否填写!")); } if (dto.PostCodes == "") { return Ok(JsonView(false, "请检查客户单位邮编是否填写!")); } Result clientCompanyData = await _clientCompanyRepository.OperationClientCompany(dto); if (clientCompanyData.Code != 0) { return Ok(JsonView(false, clientCompanyData.Msg)); } return Ok(JsonView(true, clientCompanyData.Msg)); } catch (Exception) { return Ok(JsonView(false, "程序错误!")); throw; } } /// /// 签证客户公司列表操作(删除) /// /// [HttpPost] [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)] public async Task DelClientCompany(DelBaseDto dto) { try { var res = await _clientCompanyRepository.SoftDeleteByIdAsync(dto.Id.ToString(), dto.DeleteUserId); if (!res) { return Ok(JsonView(false, "删除失败")); } return Ok(JsonView(true, "删除成功!")); } catch (Exception ex) { return Ok(JsonView(false, "程序错误!")); throw; } } /// /// 获取签证客户列表 /// /// /// [HttpPost] [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)] public async Task GetClientList(DtoBase dto) { var clientData = await _clientRepository.GetCrmList(dto); if (clientData.Code != 0) { return Ok(JsonView(false, clientData.Msg == null ? "操作失败" : clientData.Msg)); } return Ok(JsonView(clientData.Data, clientData.Data.Count)); } /// /// 根据Id获取签证客户信息 /// /// /// [HttpPost] [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)] public async Task CustomerInfo(CustomerDto dto) { try { Crm_DeleClient crm_Dele = await _clientRepository.GetAsync(x => x.Id == dto.Id); if (crm_Dele == null) { return Ok(JsonView(false, "查询失败!")); } EncryptionProcessor.DecryptProperties(crm_Dele); List _VisaCustomerCompany = _clientRepository.Query(x => x.DcId == crm_Dele.Id && x.IsDel == 0).ToList();//客户工作经历表 List _VisaCustomerSchool = _clientRepository.Query(x => x.DcId == crm_Dele.Id && x.IsDel == 0).ToList();//客户学历表 List _VisaCustomerFamily = _clientRepository.Query(x => x.DcId == crm_Dele.Id && x.IsDel == 0).ToList();//客户学历表 List _CustomerCerts = _clientRepository.Query(x => x.DcId == crm_Dele.Id && x.IsDel == 0).ToList();//客户证件表 Crm_CustomerCompany _CustomerCompany = await _clientCompanyRepository.GetAsync(x => x.Id == crm_Dele.CrmCompanyId);//客户公司信息 var data = new { DeleClient = crm_Dele, WorkExperience = _VisaCustomerCompany, CustomerSchool = _VisaCustomerSchool, CustomerFamily = _VisaCustomerFamily, CustomerCompany = _CustomerCompany, CustomerCerts = _CustomerCerts }; return Ok(JsonView(true, "查询成功!", data)); } catch (Exception) { return Ok(JsonView(false, "程序错误!")); throw; } } /// /// 客户资料操作(Status:1.新增,2.修改) /// /// /// [HttpPost] [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)] public async Task EditCustomer(DeleClientOpDto dto) { try { Domain.Result result = await _clientRepository.OpCustomer(dto); if (result.Code != 0) { return Ok(JsonView(false, result.Msg)); } return Ok(JsonView(true, result.Msg)); } catch (Exception) { return Ok(JsonView(false, "程序错误!")); throw; } } /// /// 客户资料操作删除 /// /// /// [HttpPost] [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)] public async Task DelCustomer(DeleClientDelDto dto) { Result result = await _clientRepository.DelCustomer(dto); if (result.Code != 0) { return Ok(JsonView(false, result.Msg)); } return Ok(JsonView(true, result.Msg)); } /// /// 证件表数据删除 /// /// /// [HttpPost] [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)] public async Task DelCustomerCerts(DelBaseDto dto) { var result = await _customerCertRep.SoftDeleteByIdAsync(dto.Id.ToString(), dto.DeleteUserId); if (!result) { return Ok(JsonView(false, "删除失败")); } return Ok(JsonView(true, "删除成功!")); } /// /// 家庭成员表数据删除 /// /// /// [HttpPost] [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)] public async Task DelCustomerFamily(DelBaseDto dto) { var result = await _customerFamilyRep.SoftDeleteByIdAsync(dto.Id.ToString(), dto.DeleteUserId); if (!result) { return Ok(JsonView(false, "删除失败")); } return Ok(JsonView(true, "删除成功!")); } /// /// 客户学历表数据删除 /// /// /// [HttpPost] [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)] public async Task DelCustomerSchool(DelBaseDto dto) { var result = await _customerSchoolRep.SoftDeleteByIdAsync(dto.Id.ToString(), dto.DeleteUserId); if (!result) { return Ok(JsonView(false, "删除失败")); } return Ok(JsonView(true, "删除成功!")); } /// /// 客户工作经历表数据删除 /// /// /// [HttpPost] [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)] public async Task DelVisaCustomerCompany(DelBaseDto dto) { var result = await _customerCompanyRep.SoftDeleteByIdAsync(dto.Id.ToString(), dto.DeleteUserId); if (!result) { return Ok(JsonView(false, "删除失败")); } return Ok(JsonView(true, "删除成功!")); } /// /// 客户资料导入 /// /// /// [HttpPost] [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)] public async Task PostClient(DelBaseDto dto) { var result = await _customerCompanyRep.SoftDeleteByIdAsync(dto.Id.ToString(), dto.DeleteUserId); if (!result) { return Ok(JsonView(false, "删除失败")); } return Ok(JsonView(true, "删除成功!")); } /// /// 客户资料 地址经纬度查询 /// /// 省份 /// 城市 /// 区域 /// [HttpPost] [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)] public async Task ClientCompanyNautica(string province,string city,string area) { if (string.IsNullOrEmpty(province) && string.IsNullOrEmpty(city) && string.IsNullOrEmpty(area)) { return Ok(JsonView(false, "省份、城市、区域,其中一个必须有值!", Array.Empty())); } var datas = await _customerCertRep._sqlSugar.Queryable() .Where(x => x.IsDel == 0 && !string.IsNullOrEmpty(x.Address)) .Select(x => new Crm_NewClientData() { Id = x.Id, Address = x.Address }) .ToListAsync(); foreach (var item in datas) EncryptionProcessor.DecryptProperties(item); var seledtIds = datas .WhereIF(!string.IsNullOrEmpty(province), x => x.Address.Contains(province)) .WhereIF(!string.IsNullOrEmpty(city), x => x.Address.Contains(city)) .WhereIF(!string.IsNullOrEmpty(area), x => x.Address.Contains(area)) .Select(x => x.Id) .ToList(); if (!seledtIds.Any()) return Ok(JsonView(false, "暂无相关地址信息!", Array.Empty())); var clients = await _customerCertRep._sqlSugar.Queryable() .Where(x => seledtIds.Contains(x.Id)) .Select(x => new Crm_NewClientData() { Id = x.Id, Client = x.Client, Address = x.Address }) .ToListAsync(); foreach (var item in clients) EncryptionProcessor.DecryptProperties(item); var requestData = clients.Select(x => x.Address).ToList(); var aMapResults = await _geocodeService.GetGeocodesAsync(requestData); var res = new List(); foreach (var item in aMapResults) { var client = clients.Find(x => x.Address.Equals(item.Address))?.Client ?? "-"; if (item.Status.Equals("Success")) { res.Add(new { client = client, address = item.Address, Longitude =item.Longitude, Latitude = item.Latitude, }); } else { res.Add(new { client = client, address = item.Address, Longitude = 0d, Latitude = 0d, }); } } return Ok(JsonView(res)); } } }