1234567891011121314151617181920212223242526272829303132333435363738394041 |
- using System.Collections.Generic;
- using System.Linq;
- using System.Threading.Tasks;
- using GxPress.Entity;
- using GxPress.Result.Department;
- using SqlKata;
- namespace GxPress.Service.Implement.Department
- {
- public partial class DepartmentService
- {
-
-
-
-
-
- public async Task<bool> DeleteAsync(int id)
- {
- var departments = new List<DepartmentResult>();
- var department = await _departmentRepository.GetAsync(id);
- departments.Add(_mapper.Map<DepartmentResult>(department));
-
- departments = await _departmentRepository.GetDepartmentById(id, departments.Select(n => _mapper.Map<DepartmentResult>(n)).ToList());
- foreach (var item in departments)
- {
- var users = await _userRepository.GetUserByDepartmentIdAsync(item.Id);
- var enumerable = users as User[] ?? users.ToArray();
- if (enumerable.Any())
- {
- await _userService.DeleteUsersAsync(enumerable.Select(n => n.Id));
- }
- }
-
- Query q = new Query();
- q.WhereIn(nameof(department.Id), departments.Select(n => n.Id));
- return await _departmentRepository.DeleteAsync(q);
-
- }
- }
- }
|