|
|
|
@ -32,8 +32,10 @@ namespace Platform.Areas.UserCenter.Controllers
|
|
|
|
|
{
|
|
|
|
|
return query
|
|
|
|
|
.Include(o => o.Organ)
|
|
|
|
|
.Include(o => o.User);
|
|
|
|
|
.Include(o => o.User)
|
|
|
|
|
.Include(o => o.UserRoles).ThenInclude(o => o.OrganRole);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override IQueryable<OrganUser> Query(PagedListModel<EditOrganUserModel> model, IQueryable<OrganUser> query)
|
|
|
|
|
{
|
|
|
|
|
return query
|
|
|
|
@ -43,9 +45,10 @@ namespace Platform.Areas.UserCenter.Controllers
|
|
|
|
|
.WhereIf(model.Query.Type.HasValue, o => o.Type == model.Query.Type.Value)
|
|
|
|
|
.WhereIf(!string.IsNullOrEmpty(model.Query.CustomType), o => o.CustomType.Contains(model.Query.CustomType));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override void ToDisplayModel(OrganUser entity, EditOrganUserModel model)
|
|
|
|
|
{
|
|
|
|
|
if(entity!=null)
|
|
|
|
|
if (entity != null)
|
|
|
|
|
{
|
|
|
|
|
var name = this._organRepo.ReadOnlyTable()
|
|
|
|
|
.Where(o => o.Left <= entity.Organ.Left && o.Left > 1)
|
|
|
|
@ -54,17 +57,44 @@ namespace Platform.Areas.UserCenter.Controllers
|
|
|
|
|
.FirstOrDefault(o => o.Id == entity.OrganId)?.GetDisplayName();
|
|
|
|
|
ViewData.Add(model.OrganId, name);
|
|
|
|
|
ViewData.Add(model.UserId, $"{entity.User?.UserName} {entity.User?.RealName}");
|
|
|
|
|
model.Roles = entity.UserRoles.Select(o => o.OrganRoleId).ToList();
|
|
|
|
|
entity.UserRoles.ForEach(o => ViewData.Add(o.OrganRoleId, o.OrganRole.Name));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override void ToEditModel(OrganUser entity, EditOrganUserModel model)
|
|
|
|
|
{
|
|
|
|
|
base.ToEditModel(entity, model);
|
|
|
|
|
this.ViewData.SelectList(o => model.OrganId, () => this._ajax.GetOrgan(model.OrganId).SelectList());
|
|
|
|
|
if (model.OrganId.HasValue)
|
|
|
|
|
{
|
|
|
|
|
ViewData.SelectList(o => model.UserId, () => this._ajax.GetUser(model.OrganId.Value, model.UserId).SelectList());
|
|
|
|
|
}
|
|
|
|
|
if (entity != null)
|
|
|
|
|
{
|
|
|
|
|
model.Roles = entity.UserRoles.Select(o => o.OrganRoleId).ToList();
|
|
|
|
|
}
|
|
|
|
|
if (model.OrganId.HasValue)
|
|
|
|
|
{
|
|
|
|
|
ViewData.MultiSelectList(o => model.Roles, () => this._ajax.GetRole(model.OrganId.Value, model.Roles).MultiSelectList());
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override void ToEntity(EditOrganUserModel model, OrganUser entity)
|
|
|
|
|
{
|
|
|
|
|
foreach (var id in entity.UserRoles.Select(o => o.OrganRoleId).ToList())
|
|
|
|
|
{
|
|
|
|
|
if (!model.Roles.Any(o => o == id))
|
|
|
|
|
{
|
|
|
|
|
entity.UserRoles.RemoveAll(o => !o.IsReadOnly && o.OrganRoleId == id);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
foreach (var id in model.Roles)
|
|
|
|
|
{
|
|
|
|
|
if (!entity.UserRoles.Any(o => o.OrganRoleId == id))
|
|
|
|
|
{
|
|
|
|
|
entity.UserRoles.Add(new OrganUserRole { OrganRoleId = id });
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|