123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437 |
- using DocumentFormat.OpenXml.Office2010.Excel;
- using Hotline.Caching.Interfaces;
- using Hotline.File;
- using Hotline.Repository.SqlSugar.Extensions;
- using Hotline.Settings;
- using Hotline.Share.Attributes;
- using Hotline.Share.Dtos;
- using Hotline.Share.Dtos.Snapshot;
- using Hotline.Share.Tools;
- using Hotline.Snapshot;
- using Hotline.Snapshot.Interfaces;
- using Hotline.Tools;
- using Mapster;
- using SqlSugar;
- using System;
- using System.Collections.Generic;
- using System.ComponentModel;
- using System.Linq;
- using System.Text;
- using System.Threading;
- using System.Threading.Tasks;
- using XF.Domain.Dependency;
- using XF.Domain.Exceptions;
- namespace Hotline.Application.Snapshot;
- public class IndustryApplication : IIndustryApplication, IScopeDependency
- {
- private readonly IIndustryRepository _industryRepository;
- private readonly IFileRepository _fileRepository;
- private readonly ISystemSettingCacheManager _sysSetting;
- private readonly IIndustryCaseRepository _industryCaseRepository;
- private readonly ISnapshotSMSTemplateRepository _snapshotSMSTemplateRepository;
- private readonly IPractitionerRepository _practitionerRepository;
- private readonly IVolunteerRepository _volunteerRepository;
- private readonly IVolunteerReportRepository _volunteerReportRepository;
- private readonly IIndustryLogRepository _industryLogRepository;
- private readonly ISystemOrganizeRepository _systemOrganizeRepository;
- public IndustryApplication(IIndustryRepository industryRepository, IFileRepository fileRepository, ISystemSettingCacheManager sysSetting, IIndustryCaseRepository industryCaseRepository, ISnapshotSMSTemplateRepository snapshotSMSTemplateRepository, IPractitionerRepository practitionerRepository, IVolunteerRepository volunteerRepository, IVolunteerReportRepository volunteerReportRepository, IIndustryLogRepository industryLogRepository, ISystemOrganizeRepository systemOrganizeRepository)
- {
- _industryRepository = industryRepository;
- _fileRepository = fileRepository;
- _sysSetting = sysSetting;
- _industryCaseRepository = industryCaseRepository;
- _snapshotSMSTemplateRepository = snapshotSMSTemplateRepository;
- _practitionerRepository = practitionerRepository;
- _volunteerRepository = volunteerRepository;
- _volunteerReportRepository = volunteerReportRepository;
- _industryLogRepository = industryLogRepository;
- _systemOrganizeRepository = systemOrganizeRepository;
- }
- /// <summary>
- /// 新增行业
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- /// <exception cref="NotImplementedException"></exception>
- public async Task<string> AddIndustryAsync(AddIndustryDto dto, CancellationToken cancellationToken)
- {
- if (dto.ApproveOrgId.NotNullOrEmpty() && dto.ApproveOrgName.IsNullOrEmpty())
- {
- await _systemOrganizeRepository.GetAsync(dto.ApproveOrgId, cancellationToken)
- .Then(async org => { dto.ApproveOrgName = org.Name; });
- }
- var entity = dto.Adapt<Industry>();
- var id = await _industryRepository.AddAsync(entity, cancellationToken);
- if (dto.Files.NotNullOrEmpty())
- {
- var fileEntities = dto.Files.Adapt<List<Hotline.File.File>>();
- fileEntities.ForEach(m => m.Key = id);
- await _fileRepository.AddRangeAsync(fileEntities, cancellationToken);
- }
- return id;
- }
- [ExportExcel("行业集合")]
- public ISugarQueryable<IndustryItemsOutDto> GetIndustres(IndustryListInDto dto)
- {
- var query = _industryRepository.Queryable()
- .WhereIF(dto.Name.NotNullOrEmpty(), m => m.Name.Contains(dto.Name))
- .WhereIF(dto.ApproveOrgName.NotNullOrEmpty(), m => m.ApproveOrgName.Contains(dto.ApproveOrgName))
- .OrderByDescending(m => m.CreationTime)
- .Select<IndustryItemsOutDto>();
- return query;
- }
- public async Task<IndustryDetailOutDto> GetIndustryDetailAsync(string id)
- {
- var fileServiceUrl = _sysSetting.FileServerUrl;
- var fileDownloadApi = fileServiceUrl + _sysSetting.FileDownloadApi;
- var industry = await _industryRepository.GetAsync(id);
- var files = await _fileRepository.GetByKeyAsync(id, CancellationToken.None);
- var outDto = industry.Adapt<IndustryDetailOutDto>();
- outDto.Files = files.Adapt<IList<IndustryFileDto>>();
- return outDto;
- }
- /// <summary>
- /// 修改行业
- /// </summary>
- /// <param name="dto"></param>
- /// <param name="requestAborted"></param>
- /// <returns></returns>
- /// <exception cref="NotImplementedException"></exception>
- public async Task UpdateIndustryAsync(UpdateIndustryInDto dto, CancellationToken requestAborted)
- {
- dto.ValidateObject();
- if (dto.ApproveOrgId.NotNullOrEmpty() && dto.ApproveOrgName.IsNullOrEmpty())
- {
- await _systemOrganizeRepository.GetAsync(dto.ApproveOrgId, requestAborted)
- .Then(async org => { dto.ApproveOrgName = org.Name; });
- }
- var entity = await _industryRepository.GetAsync(dto.Id) ?? throw UserFriendlyException.SameMessage($"行业不存在 {dto.Id}");
- if (dto.Files.NotNullOrEmpty())
- {
- var fileEntities = dto.Files.Adapt<List<File.File>>();
- fileEntities.ForEach(m => m.Key = entity.Id);
- await _fileRepository.Removeable().Where(m => m.Key == entity.Id).ExecuteCommandAsync(requestAborted);
- await _fileRepository.AddRangeAsync(fileEntities, requestAborted);
- }
- dto.Adapt(entity);
- await _industryRepository.UpdateAsync(entity, requestAborted);
- }
- #region 行业线索
- [ExportExcel("行业线索")]
- public ISugarQueryable<IndustryCaseItemOutDto> GetIndustryCaseItems(IndustryCaseItemInDto dto)
- {
- var query = _industryCaseRepository.Queryable()
- .LeftJoin<Industry>((c, i) => c.IndustryId == i.Id)
- .WhereIF(dto.IndustryName.NotNullOrEmpty(), (c, i) => i.Name.Contains(dto.IndustryName))
- .WhereIF(dto.CaseName.NotNullOrEmpty(), (c, i) => c.Name.Contains(dto.CaseName))
- .OrderByDescending((c, i) => c.CreationTime)
- .Select<IndustryCaseItemOutDto>((c, i) =>
- new IndustryCaseItemOutDto
- {
- Id = c.Id,
- Name = c.Name,
- IndustryId = i.Id,
- IndustryName = i.Name
- }, true);
- return query;
- }
- /// <summary>
- /// 添加行业线索
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- public async Task<string> AddIndustryCaseAsync(AddIndustryCaseDto dto)
- {
- dto.ValidateObject();
- var entity = dto.Adapt<IndustryCase>();
- return await _industryCaseRepository.AddAsync(entity);
- }
- /// <summary>
- /// 修改行业线索
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- public async Task UpdateIndustryCaseAsync(UpdateIndustryCaseDto dto)
- {
- dto.ValidateObject();
- var entity = await _industryCaseRepository.GetAsync(dto.Id)
- ?? throw UserFriendlyException.SameMessage($"行业线索不存在 {dto.Id}");
- dto.Adapt(entity);
- await _industryCaseRepository.UpdateAsync(entity);
- }
- public async Task<IndustryCase> GetIndustryCaseAsync(string caseId)
- {
- return await _industryCaseRepository.GetAsync(caseId);
- }
- #endregion
- #region 行业短信模板
- /// <summary>
- /// 行业模板集合
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- [ExportExcel("行业审批短信")]
- public ISugarQueryable<SnapshotSMSTemplateItemsOutDto> GetSMSTemplates(SnapshotSMSTemplateItemsInDto dto)
- {
- var query = _snapshotSMSTemplateRepository.Queryable()
- .LeftJoin<Industry>((s, i) => s.IndustryId == i.Id)
- .WhereIF(dto.IndustryName.NotNullOrEmpty(), (s, i) => i.Name.Contains(dto.IndustryName))
- .OrderByDescending((s, i) => s.DisplayOrder)
- .Select<SnapshotSMSTemplateItemsOutDto>();
- return query;
- }
- /// <summary>
- /// 添加行业模板
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- public async Task<string> AddSMSTemplateAsync(AddSnapshotSMSTemplateInDto dto)
- {
- dto.ValidateObject();
- var entity = dto.Adapt<SnapshotSMSTemplate>();
- return await _snapshotSMSTemplateRepository.AddAsync(entity);
- }
- /// <summary>
- /// 修改行业模板
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- public async Task UpdateSMSTemplateAsync(UpdateSnapshotSMSTemplateInDto dto)
- {
- dto.ValidateObject();
- var entity = await _snapshotSMSTemplateRepository.GetAsync(dto.Id)
- ?? throw UserFriendlyException.SameMessage($"行业短信模板不存在 {dto.Id}");
- dto.Adapt(entity);
- await _snapshotSMSTemplateRepository.UpdateAsync(entity);
- }
- /// <summary>
- /// 短信详情
- /// </summary>
- /// <param name="id"></param>
- /// <returns></returns>
- public async Task<SnapshotSMSTemplateItemsOutDto> GetSMSTemplateDetailAsync(string id)
- {
- return await _snapshotSMSTemplateRepository.Queryable()
- .LeftJoin<Industry>((s, i) => s.IndustryId == i.Id)
- .Where((s, i) => s.Id == id)
- .Select((s, i) => new SnapshotSMSTemplateItemsOutDto
- {
- Status = s.Status
- }, true)
- .FirstAsync();
- }
- #endregion
- #region 区域从业人员
- /// <summary>
- /// 区域从业人员集合
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- /// <exception cref="NotImplementedException"></exception>
- [ExportExcel("区域从业人员")]
- public ISugarQueryable<PractitionerItemsOutDto> GetPractitionerItems(PractitionerItemsInDto dto)
- {
- var query = _practitionerRepository.Queryable()
- .WhereIF(dto.Name.NotNullOrEmpty(), m => m.Name.Contains(dto.Name!))
- .WhereIF(dto.SystemAreaName.NotNullOrEmpty(), m => m.SystemAreaName.Contains(dto.SystemAreaName!))
- .WhereIF(dto.PhoneNumber.NotNullOrEmpty(), m => m.PhoneNumber.Contains(dto.PhoneNumber!))
- .OrderByDescending(m => m.CreationTime)
- .Select<PractitionerItemsOutDto>();
- return query;
- }
- /// <summary>
- /// 添加区域从业人员
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- public async Task<string> AddPractitionerAsync(AddPractitionerInDto dto)
- {
- dto.ValidateObject();
- var entity = dto.Adapt<Practitioner>();
- return await _practitionerRepository.AddAsync(entity);
- }
- /// <summary>
- /// 区域从业人员详情
- /// </summary>
- /// <param name="id"></param>
- /// <returns></returns>
- public async Task<PractitionerItemsOutDto> GetPractitionerAsync(string id)
- {
- return (await _practitionerRepository.GetAsync(id)).Adapt<PractitionerItemsOutDto>();
- }
- /// <summary>
- /// 删除区域从业人员
- /// </summary>
- /// <param name="id"></param>
- /// <returns></returns>
- public async Task DeletePractitionerAsync(IList<string> id)
- {
- await _practitionerRepository.Updateable()
- .SetColumns(m => m.IsDeleted, true)
- .Where(m => id.Contains(m.Id))
- .ExecuteCommandAsync();
- }
- /// <summary>
- /// 修改区域从业人员
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- public async Task UpdatePractitionerAsync(UpdatePractitionerInDto dto)
- {
- dto.ValidateObject();
- var entity = await _practitionerRepository.GetAsync(dto.Id) ?? throw UserFriendlyException.SameMessage($"从业人员不存在 {dto.Id}");
- dto.Adapt(entity);
- await _practitionerRepository.UpdateAsync(entity);
- }
- #endregion
- #region 志愿者
- /// <summary>
- /// 志愿者集合
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- [ExportExcel("志愿者名单")]
- public ISugarQueryable<VolunteerItemsOutDto> GetVolunteerItems(VolunteerItemsInDto dto)
- {
- var query = _volunteerRepository.Queryable()
- .WhereIF(dto.Name.NotNullOrEmpty(), m => m.Name.Contains(dto.Name))
- .WhereIF(dto.PhoneNumber.NotNullOrEmpty(), m => m.PhoneNumber.Contains(dto.PhoneNumber))
- .OrderByDescending(m => m.CreationTime)
- .Select<VolunteerItemsOutDto>();
- return query;
- }
- /// <summary>
- /// 添加志愿者
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- public async Task<string> AddVolunteerAsync(AddVolunteerInDto dto)
- {
- var entity = dto.Adapt<Volunteer>();
- entity.Id = await _volunteerRepository.AddAsync(entity);
- return entity.Id;
- }
- /// <summary>
- /// 批量删除志愿者
- /// </summary>
- /// <param name="ids"></param>
- /// <returns></returns>
- public async Task DeleteVolunteerAsync(IList<string> ids)
- {
- await _volunteerRepository.Updateable()
- .SetColumns(m => m.IsDeleted, true)
- .Where(m => ids.Contains(m.Id))
- .ExecuteCommandAsync();
- }
- /// <summary>
- /// 志愿者详情
- /// </summary>
- /// <param name="id"></param>
- /// <returns></returns>
- public async Task<Volunteer> GetVolunteerAsync(string id)
- {
- return await _volunteerRepository.GetAsync(id);
- }
- /// <summary>
- /// 修改志愿者
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- public async Task UpdateVolunteerAsync(UpdateVolunteerInDto dto)
- {
- dto.ValidateObject();
- var entity = await _volunteerRepository.GetAsync(dto.Id) ?? throw UserFriendlyException.SameMessage($"志愿者不存在 {dto.Id}");
- dto.Adapt(entity);
- await _volunteerRepository.UpdateAsync(entity);
- }
- /// <summary>
- /// 志愿者上报集合
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- [ExportExcel("志愿者上报")]
- public ISugarQueryable<VolunteerReportItemsOutDto> GetVolunteerReportItems(VolunteerReportItemsInDto dto)
- {
- var query = _volunteerReportRepository.Queryable()
- .LeftJoin<SystemDicData>((volunteer, dic) => volunteer.JobType == dic.Id)
- .WhereIF(dto.Name.NotNullOrEmpty(), m => m.Name.Contains(dto.Name))
- .WhereIF(dto.PhoneNumber.NotNullOrEmpty(), m => m.PhoneNumber.Contains(dto.PhoneNumber))
- .OrderByDescending(m => m.CreationTime)
- .Select((volunteer, dic) => new VolunteerReportItemsOutDto
- {
- JobType = dic.DicDataName,
- FullAddress = volunteer.Address + volunteer.FullAddress
- }, true);
- return query;
- }
- /// <summary>
- /// 行业修改记录
- /// </summary>
- /// <param name="dto"></param>
- /// <returns></returns>
- public ISugarQueryable<IndustryLogItemsOutDto> GetIndustryLogItems(IndustryLogItemsInDto dto)
- {
- var query = _industryLogRepository.Queryable()
- .WhereIF(dto.No.NotNullOrEmpty(), m => m.No.Contains(dto.No))
- .WhereIF(dto.ChangeName.NotNullOrEmpty(), m => m.CreatorName.Contains(dto.ChangeName))
- .WhereIF(dto.IndustryName.NotNullOrEmpty(), m => m.IndustryName.Contains(dto.IndustryName))
- .WhereIF(dto.oldIndustryName.NotNullOrEmpty(), m => m.OldIndustryName.Contains(dto.oldIndustryName))
- .WhereIF(dto.BeginTime.HasValue && dto.EndTime.HasValue, m => m.CreationTime >= dto.BeginTime.Value && m.CreationTime <= dto.EndTime.Value)
- .Select<IndustryLogItemsOutDto>();
- return query;
- }
- /// <summary>
- /// 删除行业短信模板
- /// </summary>
- /// <param name="ids"></param>
- /// <returns></returns>
- public async Task DeleteSMSTemplateAsync(IList<string> ids)
- {
- await _snapshotSMSTemplateRepository.Queryable()
- .Where(m => ids.Contains(m.Id))
- .ToListAsync()
- .Then(async sms => {
- for (int i = 0;i < sms.Count;i++)
- {
- sms[i].IsDeleted = true;
- await _snapshotSMSTemplateRepository.UpdateAsync(sms[i]);
- }
- });
- }
- #endregion
- }
|