| | |
| | | using System.Text; |
| | | using System.Text.RegularExpressions; |
| | | using System.Threading.Tasks; |
| | | using static System.Runtime.InteropServices.JavaScript.JSType; |
| | | |
| | | namespace FlexJobApi.UserServer.Application |
| | | { |
| | |
| | | /// 灵工命令处理器 |
| | | /// </summary> |
| | | public class EnterpriseEmployeesCommandHandler( |
| | | IRepository<EnterpriseEmployee> rep |
| | | IRepository<EnterpriseEmployee> rep, |
| | | IRepository<User> repUser |
| | | ) : |
| | | IRequestHandler<ImportEnterpriseEmployeesCommand, ImportEnterpriseEmployeesCommandResult>, |
| | | IRequestHandler<EditEnterpriseEmployeeCommand, Guid> |
| | | { |
| | | private readonly IRepository<EnterpriseEmployee> rep = rep; |
| | | private readonly IRepository<User> repUser = repUser; |
| | | |
| | | /// <summary> |
| | | /// 导入灵工信息 |
| | |
| | | var identities = models.DistinctSelect(it => it.Identity); |
| | | var enterpriseEmployees = await rep.AsQueryable() |
| | | .Where(it => it.EnterpriseId == logier.EnterpriseId && identities.Contains(it.Identity)) |
| | | .ToListAsync(); |
| | | var userIds = enterpriseEmployees.DistinctSelect(it => it.UserId.HasValue, it => it.UserId!.Value); |
| | | var users = await repUser.AsQueryable() |
| | | .Where(it => userIds.Contains(it.Id)) |
| | | .ToListAsync(); |
| | | var successList = new List<ImportEnterpriseEmployeesCommandModel>(); |
| | | foreach (var model in models) |
| | |
| | | } |
| | | else |
| | | { |
| | | var canUpdate = true; |
| | | if (enterpriseEmployee.UserId.HasValue) |
| | | { |
| | | errors.Add("该灵工已报名无法修改信息"); |
| | | var user = users.FirstOrDefault(it => it.Id == enterpriseEmployee.UserId.Value)!; |
| | | if (user.IsReal == true) |
| | | { |
| | | canUpdate = false; |
| | | errors.Add("已实名无法修改信息"); |
| | | } |
| | | else |
| | | { |
| | | user.Name = model.Name; |
| | | user.ContactPhoneNumber = model.ContactPhoneNumber; |
| | | user.Identity = model.Identity; |
| | | user.Gender = model.Gender; |
| | | user.Birthday = model.Birthday; |
| | | user.Age = model.Age; |
| | | await repUser.UpdateAsync(user); |
| | | } |
| | | } |
| | | else |
| | | if (canUpdate) |
| | | { |
| | | enterpriseEmployee.Name = model.Name; |
| | | enterpriseEmployee.ContactPhoneNumber = model.ContactPhoneNumber; |
| | |
| | | return request.SaveData<EnterpriseEmployee, EditEnterpriseEmployeeCommand>( |
| | | q => q.Where(it => it.EnterpriseId == logier.EnterpriseId), |
| | | it => it.EnterpriseId == logier.EnterpriseId && it.Id != request.Id && it.Identity == request.Identity, |
| | | (entity) => |
| | | async (entity) => |
| | | { |
| | | if (request.Id.HasValue && entity.UserId.HasValue) |
| | | { |
| | | throw Oops.Oh(EnumErrorCodeType.s510, "该灵工已报名无法修改信息"); |
| | | var user = await repUser.AsQueryable().FirstOrDefaultAsync(it => it.Id == entity.UserId.Value); |
| | | if (user!.IsReal == true) |
| | | { |
| | | throw Oops.Oh(EnumErrorCodeType.s510, "已实名无法修改信息"); |
| | | } |
| | | else |
| | | { |
| | | user.Name = request.Name; |
| | | user.ContactPhoneNumber = request.ContactPhoneNumber; |
| | | user.Identity = request.Identity; |
| | | user.Birthday = request.Identity.GetBirthday(); |
| | | user.Gender = request.Gender; |
| | | user.Age = request.Age; |
| | | await repUser.UpdateAsync(user); |
| | | } |
| | | } |
| | | request.Adapt(entity); |
| | | }, |