SystemController.cs 41 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058
  1. using System.Collections;
  2. using static OpenAI.GPT3.ObjectModels.SharedModels.IOpenAiModels;
  3. namespace OASystem.API.Controllers
  4. {
  5. /// <summary>
  6. /// 系统设置
  7. /// </summary>
  8. //[Authorize]
  9. [Route("api/[controller]/[action]")]
  10. public class SystemController : ControllerBase
  11. {
  12. private readonly CompanyRepository _syscomRep;
  13. private readonly DepartmentRepository _sysDepRep;
  14. private readonly UsersRepository _userRep;
  15. private readonly IMapper _mapper;
  16. private readonly SetDataRepository _setDataRepository;
  17. private readonly SystemMenuPermissionRepository _SystemMenuPermissionRepository;
  18. private readonly CompanyRepository _CompanyRepository;
  19. private readonly PageFunctionPermissionRepository _PageFunctionPermissionRepository;
  20. private readonly SystemMenuAndFunctionRepository _SystemMenuAndFunctionRepository;
  21. private readonly JobPostAuthorityRepository _JobPostAuthorityRepository;
  22. private readonly JobPostRepository _jobRep;
  23. private readonly UserAuthorityRepository _UserAuthorityRepository;
  24. public SystemController( CompanyRepository syscom, DepartmentRepository sysDepRep, UsersRepository userRep,
  25. IMapper mapper, SetDataRepository setDataRepository, CompanyRepository companyRepository,
  26. SystemMenuPermissionRepository systemMenuPermissionRepository, PageFunctionPermissionRepository pageFunctionPermissionRepository,
  27. SystemMenuAndFunctionRepository systemMenuAndFunctionRepository, JobPostAuthorityRepository jobPostAuthorityRepository, JobPostRepository jobRep
  28. , UserAuthorityRepository userAuthorityRepository)
  29. {
  30. _syscomRep = syscom;
  31. _sysDepRep = sysDepRep;
  32. _userRep = userRep;
  33. _mapper = mapper;
  34. _setDataRepository = setDataRepository;
  35. _CompanyRepository = companyRepository;
  36. _SystemMenuPermissionRepository = systemMenuPermissionRepository;
  37. _PageFunctionPermissionRepository = pageFunctionPermissionRepository;
  38. _SystemMenuAndFunctionRepository = systemMenuAndFunctionRepository;
  39. _JobPostAuthorityRepository = jobPostAuthorityRepository;
  40. _UserAuthorityRepository = userAuthorityRepository;
  41. }
  42. #region 企业操作
  43. /// <summary>
  44. /// 查询企业数据
  45. /// </summary>
  46. /// <param name="dto"></param>
  47. /// <returns></returns>
  48. [HttpPost]
  49. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  50. public async Task<IActionResult> getCompanyList(DtoBase dto)
  51. {
  52. try
  53. {
  54. if (dto.PortType == 1)
  55. {
  56. var CompanyDataResult = _CompanyRepository.GetCompanyData();
  57. if (CompanyDataResult.Code != 0)
  58. {
  59. return Ok(JsonView(CompanyDataResult.Msg));
  60. }
  61. List<CompanyView> companyListView = _mapper.Map<List<CompanyView>>(CompanyDataResult.Data);
  62. for (int i = 0; i < companyListView.Count; i++)
  63. {
  64. if (companyListView[i].ParentCompanyId != 0)
  65. {
  66. companyListView[i].ParentCompanyName = companyListView.Find(x => x.Id == companyListView[i].ParentCompanyId).CompanyName;
  67. }
  68. if (companyListView[i].ContactUserId!=0)
  69. {
  70. var user = _userRep.QueryDto<Sys_Users,UserInfoWebView>(x => x.Id == companyListView[i].ContactUserId).ToList();
  71. if (user.Count!=0)
  72. {
  73. companyListView[i].ContactUserName = user[0].CnName;
  74. }
  75. }
  76. }
  77. return Ok(JsonView(true, "查询成功!", companyListView));
  78. }
  79. else if (dto.PortType == 2)
  80. {
  81. var CompanyDataResult = _CompanyRepository.GetCompanyData();
  82. if (CompanyDataResult.Code != 0)
  83. {
  84. return Ok(JsonView(CompanyDataResult.Msg));
  85. }
  86. return Ok(JsonView(true,"查询成功!", CompanyDataResult.Data));
  87. }
  88. else if (dto.PortType == 3)
  89. {
  90. return Ok(JsonView(false, "暂无数据!"));
  91. }
  92. else
  93. {
  94. return Ok(JsonView(false, "暂无数据!"));
  95. }
  96. }
  97. catch (Exception ex)
  98. {
  99. return Ok(JsonView(false, "程序错误!"));
  100. throw;
  101. }
  102. }
  103. /// <summary>
  104. /// 添加企业数据
  105. /// </summary>
  106. /// <param name="dto"></param>
  107. /// <returns></returns>
  108. [HttpPost]
  109. [ProducesResponseType(typeof(JsonView),StatusCodes.Status200OK)]
  110. public async Task<IActionResult> AddCompany(AddCompanyDto dto)
  111. {
  112. try
  113. {
  114. if (string.IsNullOrWhiteSpace(dto.CompanyName) || dto.CreateUserId == 0 || string.IsNullOrWhiteSpace(dto.CompanyCode))
  115. {
  116. return Ok(JsonView(false, "请检查信息是否输入完整!"));
  117. }
  118. else if (string.IsNullOrWhiteSpace(dto.Tel))
  119. {
  120. return Ok(JsonView(false, "请检查联系方式是否输入正确!"));
  121. }
  122. else
  123. {
  124. Sys_Company _Company = _mapper.Map<Sys_Company>(dto);
  125. int id = await _syscomRep.AddAsyncReturnId(_Company);
  126. if (id == 0)
  127. {
  128. return Ok(JsonView(false, "添加失败!"));
  129. }
  130. return Ok(JsonView(true,"添加成功", new { Id = id }));
  131. }
  132. }
  133. catch (Exception)
  134. {
  135. return Ok(JsonView(false, "程序错误!"));
  136. throw;
  137. }
  138. }
  139. /// <summary>
  140. /// 企业修改
  141. /// </summary>
  142. /// <param name="dto"></param>
  143. /// <returns></returns>
  144. [HttpPost]
  145. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  146. public async Task<IActionResult>EditCompany(EditCompanyDto dto)
  147. {
  148. try
  149. {
  150. if (string.IsNullOrWhiteSpace(dto.CompanyName) || string.IsNullOrWhiteSpace(dto.CompanyCode) || string.IsNullOrWhiteSpace(dto.Address) || dto.ContactUserId == 0)
  151. {
  152. return Ok(JsonView(false, "请检查信息是否输入完整!"));
  153. }
  154. else if (string.IsNullOrWhiteSpace(dto.Tel))
  155. {
  156. return Ok(JsonView(false, "请检查联系方式是否输入正确!"));
  157. }
  158. else
  159. {
  160. bool res = await _syscomRep.UpdateAsync(a => a.Id == dto.Id, a => new Sys_Company
  161. {
  162. CompanyName = dto.CompanyName,
  163. CompanyCode = dto.CompanyCode,
  164. Address = dto.Address,
  165. ParentCompanyId = dto.ParentCompanyId,
  166. Tel = dto.Tel,
  167. ContactUserId = dto.ContactUserId,
  168. Remark=dto.Remark,
  169. });
  170. if (!res) { return Ok(JsonView(false, "修改失败")); }
  171. return Ok(JsonView(true,"修改成功!"));
  172. }
  173. }
  174. catch (Exception)
  175. {
  176. return Ok(JsonView(false, "程序错误!"));
  177. throw;
  178. }
  179. }
  180. /// <summary>
  181. /// 企业删除
  182. /// </summary>
  183. /// <param name="dto"></param>
  184. /// <returns></returns>
  185. [HttpPost]
  186. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  187. public async Task<IActionResult> DelCompany(DelCompanyDto dto)
  188. {
  189. try
  190. {
  191. bool res = await _syscomRep.SoftDeleteAsync<Sys_Company>(dto.Id.ToString());
  192. if (!res) { return Ok(JsonView(false, "删除失败")); }
  193. return Ok(JsonView(true, "删除成功"));
  194. }
  195. catch (Exception)
  196. {
  197. return Ok(JsonView(false, "程序错误!"));
  198. throw;
  199. }
  200. }
  201. #endregion
  202. #region 部门操作
  203. /// <summary>
  204. /// 查询部门数据
  205. /// </summary>
  206. /// <param name="dto"></param>
  207. /// <returns></returns>
  208. [HttpPost]
  209. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  210. public async Task<IActionResult> QueryDepartmentList(DepartmentDto dto)
  211. {
  212. try
  213. {
  214. if (dto.PortType==1)
  215. {
  216. if (dto.CompanyId!=0)
  217. {
  218. var result = _sysDepRep.QueryDto<Sys_Department, DepartmentIView>(s => s.CompanyId == dto.CompanyId).ToList();
  219. if (result.Count == 0)
  220. {
  221. return Ok(JsonView(false, "暂无数据!"));
  222. }
  223. for (int i = 0; i < result.Count; i++)
  224. {
  225. if (result[i].ParentDepId != 0)
  226. {
  227. result[i].ParentDepName = result.Find(x => x.Id == result[i].ParentDepId).ParentDepName;
  228. }
  229. var company = _sysDepRep.QueryDto<Sys_Company, CompanyView>(s => s.Id == result[i].CompanyId).ToList();
  230. if (company.Count != 0)
  231. {
  232. result[i].CompanyName = company[0].CompanyName;
  233. }
  234. return Ok(JsonView(true, "查询成功!", result));
  235. }
  236. }
  237. else
  238. {
  239. var result = _sysDepRep.QueryDto<Sys_Department, DepartmentIView>(s => s.IsDel <=1).ToList();
  240. if (result.Count == 0)
  241. {
  242. return Ok(JsonView(false, "暂无数据!"));
  243. }
  244. for (int i = 0; i < result.Count; i++)
  245. {
  246. if (result[i].ParentDepId != 0)
  247. {
  248. result[i].ParentDepName = result.Find(x => x.Id == result[i].ParentDepId).ParentDepName;
  249. }
  250. var company = _sysDepRep.QueryDto<Sys_Company, CompanyView>(s => s.Id == result[i].CompanyId).ToList();
  251. if (company.Count != 0)
  252. {
  253. result[i].CompanyName = company[0].CompanyName;
  254. }
  255. }
  256. return Ok(JsonView(true, "查询成功!", result));
  257. }
  258. return Ok(JsonView(false, "暂无数据!"));
  259. }
  260. else if (dto.PortType==2)
  261. {
  262. var result = _sysDepRep.QueryDto<Sys_Department, DepartmentIView>(s => s.CompanyId == dto.CompanyId).ToList();
  263. if (result.Count == 0)
  264. {
  265. return Ok(JsonView(false, "暂无数据!"));
  266. }
  267. return Ok(JsonView(true,"查询成功!",result));
  268. }
  269. else if (dto.PortType == 3)
  270. {
  271. return Ok(JsonView(false, "暂无数据!"));
  272. }
  273. else
  274. {
  275. return Ok(JsonView(false, "暂无数据!"));
  276. }
  277. }
  278. catch (Exception ex)
  279. {
  280. return Ok(JsonView(false, "程序错误!"));
  281. throw;
  282. }
  283. }
  284. /// <summary>
  285. /// 部门添加
  286. /// </summary>
  287. /// <param name="dto"></param>
  288. /// <returns></returns>
  289. [HttpPost]
  290. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  291. public async Task<IActionResult> AddDepartment(AddDepartmentDto dto)
  292. {
  293. try
  294. {
  295. if (dto.CreateUserId == 0 || string.IsNullOrWhiteSpace(dto.DepName) || dto.CompanyId == 0 || string.IsNullOrWhiteSpace(dto.DepCode))
  296. {
  297. return Ok(JsonView(false, "请检查信息是否输入完整!"));
  298. }
  299. else
  300. {
  301. Sys_Department _Department = _mapper.Map<Sys_Department>(dto);
  302. int id = await _sysDepRep.AddAsyncReturnId(_Department);
  303. if (id == 0)
  304. {
  305. return Ok(JsonView(false, "添加失败!"));
  306. }
  307. return Ok(JsonView(true, "添加成功!", new { Id = id }));
  308. }
  309. }
  310. catch (Exception)
  311. {
  312. return Ok(JsonView(false, "程序错误!"));
  313. throw;
  314. }
  315. }
  316. /// <summary>
  317. /// 部门修改
  318. /// </summary>
  319. /// <param name="dto"></param>
  320. /// <returns></returns>
  321. [HttpPost]
  322. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  323. public async Task<IActionResult> EditDepartment(EditDepartmentDto dto)
  324. {
  325. try
  326. {
  327. if (dto.Id==0 || string.IsNullOrWhiteSpace(dto.DepName) || dto.CompanyId == 0 || string.IsNullOrWhiteSpace(dto.DepCode))
  328. {
  329. return Ok(JsonView(false, "请检查信息是否输入完整!"));
  330. }
  331. else
  332. {
  333. bool res = await _sysDepRep.UpdateAsync<Sys_Department>(a => a.Id == dto.Id, a => new Sys_Department
  334. {
  335. CompanyId=dto.CompanyId,
  336. DepCode=dto.DepCode,
  337. DepName=dto.DepName,
  338. ParentDepId=dto.ParentDepId,
  339. Remark=dto.Remark,
  340. });
  341. if (!res)
  342. {
  343. return Ok(JsonView(false, "修改失败!"));
  344. }
  345. return Ok(JsonView(true, "修改成功!"));
  346. }
  347. }
  348. catch (Exception)
  349. {
  350. return Ok(JsonView(false, "程序错误!"));
  351. throw;
  352. }
  353. }
  354. /// <summary>
  355. /// 部门删除
  356. /// </summary>
  357. /// <param name="dto"></param>
  358. /// <returns></returns>
  359. [HttpPost]
  360. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  361. public async Task<IActionResult> DelDepartment(DelDepartmentDto dto)
  362. {
  363. try
  364. {
  365. if (dto.Id == 0)
  366. {
  367. return Ok(JsonView(-1, "请检查信息是否输入完整!", null));
  368. }
  369. else
  370. {
  371. bool res =await _sysDepRep.SoftDeleteAsync<Sys_Department>(dto.Id.ToString());
  372. if (!res)
  373. {
  374. return Ok(JsonView(false, "删除失败!"));
  375. }
  376. return Ok(JsonView(true, "删除成功!"));
  377. }
  378. }
  379. catch (Exception)
  380. {
  381. return Ok(JsonView(false, "程序错误!"));
  382. throw;
  383. }
  384. }
  385. #endregion
  386. #region 岗位板块
  387. /// <summary>
  388. /// 岗位查询
  389. /// </summary>
  390. /// <param name="dto"></param>
  391. /// <returns></returns>
  392. [HttpPost]
  393. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  394. public async Task<IActionResult> QueryJobPost(QueryJobPostDto dto)
  395. {
  396. try
  397. {
  398. if (dto.PortType == 1)
  399. {
  400. var result = _sysDepRep.QueryDto<Sys_JobPost, JobPostView>(s => s.CompanyId == dto.CompanyId && s.DepId == dto.DepId).ToList();
  401. if (result.Count == 0)
  402. {
  403. return Ok(JsonView(false, "暂无数据!"));
  404. }
  405. return Ok(JsonView(true, "查询成功!", result));
  406. }
  407. else if (dto.PortType == 2)
  408. {
  409. var result = _jobRep.QueryDto<Sys_JobPost, JobPostView>(s => s.CompanyId == dto.CompanyId && s.DepId==dto.DepId).ToList();
  410. if (result.Count == 0)
  411. {
  412. return Ok(JsonView(false, "暂无数据!"));
  413. }
  414. return Ok(JsonView(true, "查询成功!", result));
  415. }
  416. else if (dto.PortType == 3)
  417. {
  418. return Ok(JsonView(false, "暂无数据!"));
  419. }
  420. else
  421. {
  422. return Ok(JsonView(false, "暂无数据!"));
  423. }
  424. }
  425. catch (Exception ex)
  426. {
  427. return Ok(JsonView(false, "程序错误!"));
  428. throw;
  429. }
  430. }
  431. /// <summary>
  432. /// 添加岗位
  433. /// </summary>
  434. /// <param name="dto"></param>
  435. /// <returns></returns>
  436. [HttpPost]
  437. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  438. public async Task<IActionResult> AddJobPost(AddJobPostDto dto)
  439. {
  440. try
  441. {
  442. Sys_JobPost sys_Job = _mapper.Map<Sys_JobPost>(dto);
  443. int id = await _jobRep.AddAsyncReturnId(sys_Job);
  444. if (id == 0)
  445. {
  446. return Ok(JsonView(false, "添加失败"));
  447. }
  448. return Ok(JsonView(true, "添加成功", new { Id = id }));
  449. }
  450. catch (Exception ex)
  451. {
  452. return Ok(JsonView(false, "程序错误!"));
  453. throw;
  454. }
  455. }
  456. /// <summary>
  457. /// 修改岗位
  458. /// </summary>
  459. /// <param name="dto"></param>
  460. /// <returns></returns>
  461. [HttpPost]
  462. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  463. public async Task<IActionResult> EditJobPost(EditJobPostDto dto)
  464. {
  465. try
  466. {
  467. bool res = await _jobRep.UpdateAsync<Sys_JobPost>(a=>a.Id==dto.Id,a =>new Sys_JobPost
  468. {
  469. CompanyId=dto.CompanyId,
  470. DepId=dto.DepId,
  471. JobName=dto.JobName,
  472. Remark=dto.Remark,
  473. });
  474. if (!res)
  475. {
  476. return Ok(JsonView(false, "修改失败"));
  477. }
  478. return Ok(JsonView(true, "修改成功"));
  479. }
  480. catch (Exception ex)
  481. {
  482. return Ok(JsonView(false, "程序错误!"));
  483. throw;
  484. }
  485. }
  486. /// <summary>
  487. /// 删除岗位
  488. /// </summary>
  489. /// <param name="dto"></param>
  490. /// <returns></returns>
  491. [HttpPost]
  492. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  493. public async Task<IActionResult> DelJobPost(DelJobPostDto dto)
  494. {
  495. try
  496. {
  497. bool res = await _jobRep.SoftDeleteAsync<Sys_JobPost>(dto.Id.ToString());
  498. if (!res)
  499. {
  500. return Ok(JsonView(false, "删除失败!"));
  501. }
  502. return Ok(JsonView(true, "删除成功"));
  503. }
  504. catch (Exception)
  505. {
  506. return Ok(JsonView(false, "程序错误!"));
  507. throw;
  508. }
  509. }
  510. #endregion
  511. #region 用户操作
  512. /// <summary>
  513. /// 查询所有员工(web)
  514. /// </summary>
  515. /// <param name="dto"></param>
  516. /// <returns></returns>
  517. //[OASystemAuthentication]
  518. [HttpPost]
  519. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  520. public async Task<IActionResult> GetUserList(DtoBase dto)
  521. {
  522. try
  523. {
  524. var result = _userRep.GetUserList(dto.PortType, string.Empty);
  525. if (result.Result.Code != 0)
  526. {
  527. return Ok(JsonView(false, "暂无数据!"));
  528. }
  529. return Ok(JsonView(true, "查询成功!", result.Result.Data));
  530. }
  531. catch (Exception)
  532. {
  533. return Ok(JsonView(false, "程序错误!"));
  534. throw;
  535. }
  536. }
  537. /// <summary>
  538. /// 查询用户数据
  539. /// </summary>
  540. /// <param name="dto"></param>
  541. /// <returns></returns>
  542. [HttpPost]
  543. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  544. public async Task<IActionResult> QueryUserList(UserDto dto)
  545. {
  546. try
  547. {
  548. string sqlWhere = string.Empty;
  549. if (dto.CompanyId!=0)
  550. {
  551. sqlWhere += string.Format(@" And su.CompanyId={0}", dto.CompanyId);
  552. }
  553. if (dto.DepId != 0)
  554. {
  555. sqlWhere += string.Format(@" And su.DepId={0}", dto.DepId);
  556. }
  557. if (dto.JobPostId != 0)
  558. {
  559. sqlWhere += string.Format(@" And su.JobPostId={0}", dto.JobPostId);
  560. }
  561. if (!string.IsNullOrEmpty(sqlWhere.Trim()))
  562. {
  563. Regex r = new Regex("And");
  564. sqlWhere = r.Replace(sqlWhere, "Where", 1);
  565. }
  566. string userSqlWhere = string.Format(@"Select sc.CompanyName,sd.DepName,sjp.JobName,su.* From Sys_Users su
  567. Inner Join Sys_Company sc On su.CompanyId = sc.Id
  568. Inner Join Sys_Department sd On su.DepId = sd.Id
  569. Inner Join Sys_JobPost sjp On su.JobPostId = sjp.Id {0}", sqlWhere);
  570. var _userList =_userRep.GetListBySqlWithNolock(userSqlWhere);
  571. if (_userList.Count == 0)
  572. {
  573. return Ok(JsonView(false, "暂无数据!"));
  574. }
  575. List<UserInfoWebView> userList = _mapper.Map<List<UserInfoWebView>>(_userList);
  576. return Ok(JsonView(true,"查询成功!", userList));
  577. }
  578. catch (Exception)
  579. {
  580. return Ok(JsonView(false, "程序错误!"));
  581. throw;
  582. }
  583. }
  584. /// <summary>
  585. /// 修改用户信息(上级修改/分配 公司、部门、岗位、工号等信息)
  586. /// </summary>
  587. /// <param name="dto"></param>
  588. /// <returns></returns>
  589. [HttpPost]
  590. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  591. public async Task<IActionResult> EditUser(EditUserDto dto)
  592. {
  593. try
  594. {
  595. bool res = await _userRep.UpdateAsync<Sys_Users>(a => a.Id == dto.Id, a => new Sys_Users
  596. {
  597. Number = dto.Number,
  598. CompanyId = dto.CompanyId,
  599. DepId = dto.DepId,
  600. JobPostId = dto.JobPostId,
  601. Ext = dto.Ext,
  602. UsePeriod = dto.UsePeriod,
  603. HrAudit = dto.HrAudit
  604. });
  605. if (!res)
  606. {
  607. return Ok(JsonView(false, "修改失败!"));
  608. }
  609. return Ok(JsonView(true, "修改成功!"));
  610. }
  611. catch (Exception)
  612. {
  613. return Ok(JsonView(false, "程序错误!"));
  614. throw;
  615. }
  616. }
  617. /// <summary>
  618. /// 修改用户信息(登录用户修改个人信息)
  619. /// </summary>
  620. /// <param name="dto"></param>
  621. /// <returns></returns>
  622. [HttpPost]
  623. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  624. public async Task<IActionResult> EditMyUser(EditMyUserDto dto)
  625. {
  626. try
  627. {
  628. if (string.IsNullOrWhiteSpace(dto.CnName) || string.IsNullOrWhiteSpace(dto.Address) || string.IsNullOrWhiteSpace(dto.IDCard) || dto.Sex != 0 && dto.Sex != 1 ||
  629. string.IsNullOrWhiteSpace(dto.MaritalStatus) || string.IsNullOrWhiteSpace(dto.HomeAddress)|| dto.Birthday>=DateTime.Now.AddYears(-1))
  630. {
  631. return Ok(JsonView(false, "请完善你的个人信息!"));
  632. }
  633. else if (string.IsNullOrWhiteSpace(dto.GraduateInstitutions) || string.IsNullOrWhiteSpace(dto.Professional) || dto.Education == 0 || string.IsNullOrWhiteSpace(dto.GraduateInstitutions))
  634. {
  635. return Ok(JsonView(false, "请完善你的学历信息!"));
  636. }
  637. else if (string.IsNullOrWhiteSpace(dto.Phone) || string.IsNullOrWhiteSpace(dto.UrgentPhone) || string.IsNullOrWhiteSpace(dto.Email))
  638. {
  639. return Ok(JsonView(false, "请检查联系方式、紧急联系人及邮箱输写是否正确!"));
  640. }
  641. else
  642. {
  643. bool res = await _userRep.UpdateAsync<Sys_Users>(a => a.Id == dto.Id, a => new Sys_Users
  644. {
  645. CnName = dto.CnName,
  646. EnName = dto.EnName,
  647. Sex = dto.Sex,
  648. Phone = dto.Phone,
  649. UrgentPhone = dto.UrgentPhone,
  650. Email = dto.Email,
  651. Address = dto.Address,
  652. Edate = dto.Edate,
  653. Birthday = dto.Birthday,
  654. IDCard = dto.IDCard,
  655. GraduateInstitutions = dto.GraduateInstitutions,
  656. Professional = dto.Professional,
  657. Education = dto.Education,
  658. TheOrAdultEducation = dto.TheOrAdultEducation,
  659. MaritalStatus = dto.MaritalStatus,
  660. HomeAddress = dto.HomeAddress,
  661. WorkExperience = dto.WorkExperience,
  662. Certificate = dto.Certificate
  663. });
  664. if (!res)
  665. {
  666. return Ok(JsonView(false, "修改失败!"));
  667. }
  668. return Ok(JsonView(true, "修改成功!"));
  669. }
  670. }
  671. catch (Exception)
  672. {
  673. return Ok(JsonView(false, "程序错误!"));
  674. throw;
  675. }
  676. }
  677. #endregion
  678. #region 权限模块
  679. /// <summary>
  680. /// 权限数据页面初始化
  681. /// </summary>
  682. /// <param name="dto"></param>
  683. /// <returns></returns>
  684. //[Authorize]
  685. [HttpPost]
  686. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  687. public async Task<IActionResult> GetAuth(AuthDto dto)
  688. {
  689. Result result = new Result();
  690. //模块数据
  691. var setDataResult = await _setDataRepository.GetSySDefultModule(_setDataRepository);
  692. if (setDataResult.Code != 0)
  693. {
  694. return Ok(JsonView(setDataResult.Msg));
  695. }
  696. //操作方式
  697. var PageOperation = _PageFunctionPermissionRepository.QueryDto<Sys_PageFunctionPermission, Sys_PageFunctionPermission>().ToList();
  698. //获取所有关联页面
  699. var Sys_SystemMenuAndFunction = _SystemMenuAndFunctionRepository.QueryDto<Sys_SystemMenuAndFunction, SystemMenuAndFunctionView>().ToList();
  700. //页面数据
  701. var SystemMenuPermissionData = _SystemMenuPermissionRepository.QueryDto<Sys_SystemMenuPermission, SystemMenuPermissionView>(x=>x.Mid == dto.moduleId).ToList();
  702. if (SystemMenuPermissionData == null || SystemMenuPermissionData.Count() == 0)
  703. {
  704. return Ok(JsonView("暂无数据"));
  705. }
  706. ArrayList viewData = new ArrayList();
  707. //组合页面数据
  708. foreach (var item in SystemMenuPermissionData)
  709. {
  710. ArrayList ids = new ArrayList();
  711. foreach (var viewop in PageOperation)
  712. {
  713. var op = Sys_SystemMenuAndFunction.FirstOrDefault(x => x.SmId == item.Id && x.FId == viewop.Id);
  714. if (op != null)
  715. {
  716. ids.Add(viewop.Id);
  717. }
  718. }
  719. viewData.Add(new
  720. {
  721. Id = item.Id,
  722. Mid = item.Mid,
  723. Name = item.Name,
  724. SystemMenuCode = item.SystemMenuCode,
  725. opList = ids,
  726. selList = new string[0]
  727. }) ;
  728. }
  729. //公司数据
  730. var CompanyDataResult = _CompanyRepository.GetCompanyData();
  731. if (CompanyDataResult.Code != 0)
  732. {
  733. return Ok(JsonView(CompanyDataResult.Msg));
  734. }
  735. result.Code = 0;
  736. result.Msg = "成功!";
  737. var Dyresult = new
  738. {
  739. setDataResult = setDataResult.Data,
  740. CompanyDataResult = CompanyDataResult.Data,
  741. SystemMenuPermissionData = viewData,
  742. PageOperation = PageOperation,
  743. };
  744. return Ok(JsonView(200, "成功!", Dyresult));
  745. }
  746. /// <summary>
  747. /// 获取职务权限
  748. /// </summary>
  749. /// <param name="dto"></param>
  750. /// <returns></returns>
  751. [HttpPost]
  752. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  753. public IActionResult QueryJobAuth(QueryJobAuthDto dto)
  754. {
  755. //选中的操作权限
  756. var DBdata = _JobPostAuthorityRepository.QueryDto<Sys_JobPostAuthority, JobPostAuthorityView>(x=>x.JpId == dto.jobid).ToList();
  757. var SystemMenuPermissionData = _SystemMenuPermissionRepository.QueryDto<Sys_SystemMenuPermission, SystemMenuPermissionView>(x => x.Mid == dto.moduleId).ToList();
  758. if (SystemMenuPermissionData == null || SystemMenuPermissionData.Count() == 0)
  759. {
  760. return Ok(JsonView("暂无数据"));
  761. }
  762. //所有操作
  763. var PageOperation = _PageFunctionPermissionRepository.QueryDto<Sys_PageFunctionPermission, Sys_PageFunctionPermission>().ToList();
  764. //获取所有关联页面
  765. var Sys_SystemMenuAndFunction = _SystemMenuAndFunctionRepository.QueryDto<Sys_SystemMenuAndFunction, SystemMenuAndFunctionView>().ToList();
  766. ArrayList viewData = new ArrayList();
  767. //组合页面数据
  768. foreach (var item in SystemMenuPermissionData)
  769. {
  770. ArrayList ids = new ArrayList();
  771. foreach (var viewop in PageOperation)
  772. {
  773. var op = Sys_SystemMenuAndFunction.FirstOrDefault(x => x.SmId == item.Id && x.FId == viewop.Id);
  774. if (op != null)
  775. {
  776. ids.Add(viewop.Id);
  777. }
  778. }
  779. //获取本职务的页面拥有的权限
  780. var DBwhere = DBdata.Where(x => x.SmId == item.Id && x.JpId == dto.jobid).ToList();
  781. viewData.Add(new
  782. {
  783. Id = item.Id,
  784. Mid = item.Mid,
  785. Name = item.Name,
  786. SystemMenuCode = item.SystemMenuCode,
  787. opList = ids,
  788. selList = DBwhere.Select(x => x.FId)
  789. }) ;
  790. }
  791. return Ok(JsonView(200, "成功!", viewData));
  792. }
  793. /// <summary>
  794. /// 保存岗位权限
  795. /// </summary>
  796. /// <param name="dto"></param>
  797. /// <returns></returns>
  798. [HttpPost]
  799. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  800. public async Task<IActionResult> SaveJobAuth(SaveJobDto dto)
  801. {
  802. //获取所有关联页面
  803. var Sys_SystemMenuAndFunction = _SystemMenuAndFunctionRepository.QueryDto<Sys_SystemMenuAndFunction, SystemMenuAndFunctionView>().ToList();
  804. List<Sys_JobPostAuthority> adds = new List<Sys_JobPostAuthority>();
  805. foreach (var item in dto.Savejobs)
  806. {
  807. foreach (var fid in item.FIds)
  808. {
  809. var whereobj = Sys_SystemMenuAndFunction.FirstOrDefault(x => x.FId == fid && x.SmId == item.SmId);
  810. if (whereobj != null)
  811. {
  812. adds.Add(new Sys_JobPostAuthority
  813. {
  814. CreateTime = DateTime.Now,
  815. CreateUserId = 245,
  816. FId = fid,
  817. JpId = dto.Jpid,
  818. SmId = item.SmId
  819. });
  820. }
  821. }
  822. }
  823. _JobPostAuthorityRepository.BeginTran();
  824. try
  825. { //删除岗位
  826. bool isdel = await _JobPostAuthorityRepository.DeleteAsync<Sys_JobPostAuthority>(x => x.JpId == dto.Jpid);
  827. int UpRows = _JobPostAuthorityRepository.Adds<Sys_JobPostAuthority>(adds);
  828. //获取所有职位员工
  829. var jobUserAll = await QueryUserList(new UserDto { PortType = 2, JobPostId = dto.Jpid });
  830. List<UserInfoWebView> users = null;
  831. var QueryUserListApiResult = (((jobUserAll as OkObjectResult).Value) as OASystem.Domain.ViewModels.JsonView);
  832. if (QueryUserListApiResult != null)
  833. {
  834. if (QueryUserListApiResult.Code == 200)
  835. {
  836. users = QueryUserListApiResult.Data as List<UserInfoWebView>;
  837. }
  838. }
  839. if (users != null && users.Count > 0)
  840. {
  841. List<Sys_UserAuthority> userAuth = null;
  842. foreach (var user in users)
  843. {
  844. //删除个人级岗位权限
  845. isdel = await _UserAuthorityRepository.DeleteAsync<Sys_UserAuthority>(x => x.IsTemp == 1 &&
  846. x.UId == user.Id);
  847. userAuth = adds.Select(x=> new Sys_UserAuthority
  848. {
  849. CreateTime = DateTime.Now,
  850. CreateUserId = 235,
  851. FId = x.FId,
  852. SmId = x.SmId,
  853. UId = user.Id,
  854. IsTemp = 1,
  855. }).ToList();
  856. //添加个人级别岗位
  857. int AddRows = _UserAuthorityRepository.Adds<Sys_UserAuthority>(userAuth);
  858. }
  859. }
  860. }
  861. catch (Exception ex)
  862. {
  863. _JobPostAuthorityRepository.RollbackTran();
  864. return Ok(JsonView("系统错误!"));
  865. }
  866. _JobPostAuthorityRepository.CommitTran();
  867. return Ok(JsonView(200, "成功", new { }));
  868. }
  869. /// <summary>
  870. /// 获取员工权限
  871. /// </summary>
  872. /// <param name="dto"></param>
  873. /// <returns></returns>
  874. [HttpPost]
  875. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  876. public IActionResult QueryUserAuth(QueryUserAuthDto dto)
  877. {
  878. //选中的员工操作权限
  879. var DBdata = _UserAuthorityRepository.QueryDto<Sys_UserAuthority, UserAuthorityView>(x => x.UId == dto.Userid).ToList();
  880. var SystemMenuPermissionData = _SystemMenuPermissionRepository.QueryDto<Sys_SystemMenuPermission, SystemMenuPermissionView>(x => x.Mid == dto.moduleId).ToList();
  881. if (SystemMenuPermissionData == null || SystemMenuPermissionData.Count() == 0)
  882. {
  883. return Ok(JsonView("暂无数据"));
  884. }
  885. //所有操作
  886. var PageOperation = _PageFunctionPermissionRepository.QueryDto<Sys_PageFunctionPermission, Sys_PageFunctionPermission>().ToList();
  887. //获取所有关联页面
  888. var Sys_SystemMenuAndFunction = _SystemMenuAndFunctionRepository.QueryDto<Sys_SystemMenuAndFunction, SystemMenuAndFunctionView>().ToList();
  889. ArrayList viewData = new ArrayList();
  890. //组合页面数据
  891. foreach (var item in SystemMenuPermissionData)
  892. {
  893. ArrayList ids = new ArrayList();
  894. foreach (var viewop in PageOperation)
  895. {
  896. var op = Sys_SystemMenuAndFunction.FirstOrDefault(x => x.SmId == item.Id && x.FId == viewop.Id);
  897. if (op != null)
  898. {
  899. ids.Add(viewop.Id);
  900. }
  901. }
  902. //获取本员工拥有的权限
  903. var DBwhere = DBdata.Where(x => x.SmId == item.Id && x.UId == dto.Userid).ToList();
  904. viewData.Add(new
  905. {
  906. Id = item.Id,
  907. Mid = item.Mid,
  908. Name = item.Name,
  909. SystemMenuCode = item.SystemMenuCode,
  910. opList = ids,
  911. selList = DBwhere.Select(x => x.FId)
  912. });
  913. }
  914. return Ok(JsonView(200, "成功!", viewData));
  915. }
  916. /// <summary>
  917. /// 保存员工权限
  918. /// </summary>
  919. /// <param name="dto"></param>
  920. /// <returns></returns>
  921. [HttpPost]
  922. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  923. public async Task<IActionResult> SaveUserAuth(SaveUserDto dto)
  924. {
  925. //获取所有关联页面
  926. var Sys_SystemMenuAndFunction = _SystemMenuAndFunctionRepository.QueryDto<Sys_SystemMenuAndFunction, SystemMenuAndFunctionView>().ToList();
  927. List<Sys_UserAuthority> adds = new List<Sys_UserAuthority>();
  928. foreach (var item in dto.Savejobs)
  929. {
  930. foreach (var fid in item.FIds)
  931. {
  932. var whereobj = Sys_SystemMenuAndFunction.FirstOrDefault(x => x.FId == fid && x.SmId == item.SmId);
  933. if (whereobj != null)
  934. {
  935. adds.Add(new Sys_UserAuthority
  936. {
  937. CreateTime = DateTime.Now,
  938. CreateUserId = 235,
  939. FId = fid,
  940. UId = dto.uid,
  941. SmId = item.SmId,
  942. IsTemp = 0
  943. });
  944. }
  945. }
  946. }
  947. _JobPostAuthorityRepository.BeginTran();
  948. try
  949. {
  950. List<Sys_UserAuthority> userAuth = null;
  951. //删除个人级岗位权限
  952. bool isdel = await _UserAuthorityRepository.DeleteAsync<Sys_UserAuthority>(x=> x.UId == dto.uid);
  953. userAuth = adds.Select(x => new Sys_UserAuthority
  954. {
  955. CreateTime = DateTime.Now,
  956. CreateUserId = 235,
  957. FId = x.FId,
  958. SmId = x.SmId,
  959. UId = dto.uid,
  960. IsTemp = 0,
  961. }).ToList();
  962. //添加个人级别岗位
  963. int AddRows = _UserAuthorityRepository.Adds<Sys_UserAuthority>(userAuth);
  964. }
  965. catch (Exception ex)
  966. {
  967. _JobPostAuthorityRepository.RollbackTran();
  968. return Ok(JsonView("系统错误!"));
  969. }
  970. _JobPostAuthorityRepository.CommitTran();
  971. return Ok(JsonView(200, "成功", new { }));
  972. }
  973. #endregion
  974. }
  975. }