ProjectServiceImpl.java 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780
  1. package com.hssx.cloudmodel.service.impl;
  2. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  3. import com.github.pagehelper.PageHelper;
  4. import com.github.pagehelper.PageInfo;
  5. import com.hssx.cloudmodel.constant.Constant;
  6. import com.hssx.cloudmodel.entity.*;
  7. import com.hssx.cloudmodel.entity.vo.MouldVO;
  8. import com.hssx.cloudmodel.entity.vo.ProjectVO;
  9. import com.hssx.cloudmodel.entity.vo.UserVO;
  10. import com.hssx.cloudmodel.mapper.*;
  11. import com.hssx.cloudmodel.service.ProjectService;
  12. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  13. import com.hssx.cloudmodel.util.HttpRespMsg;
  14. import com.hssx.cloudmodel.util.ListUtil;
  15. import com.hssx.cloudmodel.util.PageUtil;
  16. import org.springframework.beans.factory.annotation.Autowired;
  17. import org.springframework.stereotype.Service;
  18. import javax.annotation.Resource;
  19. import javax.jws.soap.SOAPBinding;
  20. import java.text.SimpleDateFormat;
  21. import java.util.*;
  22. import java.util.stream.Collector;
  23. import java.util.stream.Collectors;
  24. /**
  25. * <p>
  26. * 服务实现类
  27. * </p>
  28. *
  29. * @author 吴涛涛
  30. * @since 2019-07-27
  31. */
  32. @Service
  33. public class ProjectServiceImpl extends ServiceImpl<ProjectMapper, Project> implements ProjectService {
  34. @Resource
  35. ProjectMapper projectMapper;
  36. @Resource
  37. ProjectUserMapper projectUserMapper;
  38. @Resource
  39. UserMapper userMapper;
  40. @Resource
  41. CompanyMapper companyMapper;
  42. @Resource
  43. CustomCompanyMapper customCompanyMapper;
  44. @Resource
  45. MouldMapper mouldMapper;
  46. @Resource
  47. ProjectApproveMapper projectApproveMapper;
  48. @Resource
  49. PowerMapper powerMapper;
  50. @Resource
  51. UserCompanyMapper userCompanyMapper;
  52. @Override
  53. public HttpRespMsg addAndUpdateProject(Project project, Integer flag, User user, String userIds,
  54. String customerCompanyIds, String customerCompanyNames, String modelIds,
  55. Integer customerApproverId, Integer ownerApproverId) {
  56. HttpRespMsg msg = new HttpRespMsg();
  57. if (user != null) {
  58. QueryWrapper<Project> qw = new QueryWrapper<>();
  59. qw.orderByDesc("id").last("limit 1");
  60. Project lastProject = projectMapper.selectOne(qw);
  61. if (flag == 0) {
  62. synchronized (this) {
  63. int count = 1;
  64. if (lastProject != null) {
  65. //YMXM201903220001
  66. String numStr = lastProject.getProjectNo().substring(13);
  67. int num = Integer.valueOf(numStr).intValue();
  68. count += num;
  69. }
  70. long time = System.currentTimeMillis();
  71. Company company = companyMapper.selectById(user.getCompanyId());
  72. SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd");
  73. String seq = sdf.format(time) + String.format("%04d", count);
  74. project.setCreatorId(user.getId());
  75. project.setCreator(user.getUsername());
  76. project.setOwnerCompany(user.getCompanyId());
  77. project.setOwnerCompanyName(company.getCompanyName());
  78. project.setProjectNo(Constant.PROJECT_PREFIX + seq);
  79. projectMapper.insert(project);
  80. //给项目经理添加一条上传权限
  81. if(null != project.getManagerId()){
  82. Integer cot = powerMapper.selectCount(new QueryWrapper<Power>().eq("user_id", project.getManagerId()).eq("project_id", project.getId()).eq("power_type", 0));
  83. if(cot==0){
  84. Power power = new Power();
  85. power.setUserId(project.getManagerId());
  86. power.setProjectId(project.getId());
  87. power.setPowerType(Constant.UPDATE_AUTHORITY);
  88. powerMapper.insert(power);
  89. }
  90. }
  91. //添加生产方关联公司
  92. if (customerCompanyIds != null && !"".equals(customerCompanyIds) && customerCompanyNames != null && !"".equals(customerCompanyNames)) {
  93. List<Integer> ides = ListUtil.convertIntegerIdsArrayToList(customerCompanyIds);
  94. String[] split = customerCompanyNames.split(",");
  95. int index = 0;
  96. for (String cusCompany : split) {
  97. CustomCompany customCompany = new CustomCompany();
  98. customCompany.setCompanyId(ides.get(index));
  99. customCompany.setCompanyName(cusCompany);
  100. customCompany.setProjectId(project.getId());
  101. customCompanyMapper.insert(customCompany);
  102. index++;
  103. }
  104. }
  105. //添加模具
  106. if (modelIds != null && !"".equals(modelIds)) {
  107. List<Integer> modelList = ListUtil.convertIntegerIdsArrayToList(modelIds);
  108. int index = 1;
  109. if (modelList.size() > 0) {
  110. for (Integer id : modelList) {
  111. Mould mould = new Mould();
  112. mould.setId(id);
  113. mould.setProjectId(project.getId());
  114. mould.setBelongProjectGrade(index / modelList.size() + "");
  115. mouldMapper.updateById(mould);
  116. }
  117. }
  118. }
  119. }
  120. } else if (flag == 1) {
  121. Project pro = projectMapper.selectById(project.getId());
  122. projectMapper.updateById(project);
  123. //删除参与人与项目项目经理相同id的人
  124. projectUserMapper.delete(new QueryWrapper<ProjectUser>().eq("user_id", project.getManagerId()).eq("project_id", project.getId()));
  125. //删除之前添加的生产方公司
  126. customCompanyMapper.delete(new QueryWrapper<CustomCompany>().eq("project_id", project.getId()));
  127. //删除之前的项目经理上传权限
  128. powerMapper.delete(new QueryWrapper<Power>().eq("user_id", pro.getManagerId()).eq("project_id", pro.getId()).eq("power_type", 0));
  129. //重新添加项目经理上传权限
  130. if(null != project.getManagerId()){
  131. Integer cot = powerMapper.selectCount(new QueryWrapper<Power>().eq("user_id", project.getManagerId()).eq("project_id", project.getId()).eq("power_type", 0));
  132. if(cot==0){
  133. Power power = new Power();
  134. power.setUserId(project.getManagerId());
  135. power.setProjectId(project.getId());
  136. power.setPowerType(Constant.UPDATE_AUTHORITY);
  137. powerMapper.insert(power);
  138. }
  139. }
  140. //重新添加生产方公司
  141. if (customerCompanyIds != null && !"".equals(customerCompanyIds) && customerCompanyNames != null && !"".equals(customerCompanyNames)) {
  142. List<Integer> ides = ListUtil.convertIntegerIdsArrayToList(customerCompanyIds);
  143. String[] split = customerCompanyNames.split(",");
  144. int index = 0;
  145. for (String cusCompany : split) {
  146. CustomCompany customCompany = new CustomCompany();
  147. customCompany.setCompanyId(ides.get(index));
  148. customCompany.setCompanyName(cusCompany);
  149. customCompany.setProjectId(project.getId());
  150. customCompanyMapper.insert(customCompany);
  151. index++;
  152. }
  153. }
  154. //删除之前的项目审批人
  155. projectApproveMapper.delete(new QueryWrapper<ProjectApprove>().eq("project_id", project.getId()));
  156. //删除权限表里的审批权限数据
  157. powerMapper.delete(new QueryWrapper<Power>().eq("project_id", project.getId()).eq("power_type", Constant.APPROVAL_AUTHORITY));
  158. //删除之前项目参与人的下载权限
  159. projectMapper.selectById(project.getId());
  160. List<Integer> approverIds = projectApproveMapper.selectList(new QueryWrapper<ProjectApprove>().eq("project_id", project.getId()))
  161. .stream()
  162. .map(ProjectApprove::getApproverId)
  163. .collect(Collectors.toList());
  164. approverIds.add(-1);
  165. powerMapper.delete(new QueryWrapper<Power>().in("user_id", approverIds));
  166. //删除之前分配的人员
  167. QueryWrapper<ProjectUser> qwPro = new QueryWrapper<>();
  168. qwPro.eq("project_id", project.getId());
  169. projectUserMapper.delete(qwPro);
  170. //再次重新分配
  171. this.handOutProject(project, userIds);
  172. //重新添加审批人
  173. //1.添加生产方审批人
  174. if (null != customerApproverId) {
  175. User customerExaminer = userMapper.selectById(customerApproverId);
  176. Company company = companyMapper.selectById(customerExaminer.getCompanyId());
  177. ProjectApprove projectApprove = new ProjectApprove();
  178. projectApprove.setApproverId(customerExaminer.getId());
  179. projectApprove.setApproverName(customerExaminer.getUsername());
  180. projectApprove.setCompanyId(customerExaminer.getCompanyId());
  181. projectApprove.setCompanyName(company.getCompanyName());
  182. projectApprove.setProjectId(project.getId());
  183. projectApprove.setSubordinateType(customerExaminer.getSubordinateType());
  184. projectApproveMapper.insert(projectApprove);
  185. Power power = new Power();
  186. power.setUserId(customerExaminer.getId());
  187. power.setProjectId(project.getId());
  188. power.setPowerType(Constant.APPROVAL_AUTHORITY);
  189. powerMapper.insert(power);
  190. //审批人默认有下载权限
  191. power.setUserId(customerExaminer.getId());
  192. power.setProjectId(project.getId());
  193. power.setPowerType(Constant.DOWNLOAD_AUTHORITY);
  194. powerMapper.insert(power);
  195. //将审批人加入到参与人中
  196. ProjectUser projectUser = new ProjectUser();
  197. projectUser.setUserId(customerExaminer.getId());
  198. projectUser.setSubordinateType(customerExaminer.getSubordinateType());
  199. projectUser.setProjectId(project.getId());
  200. projectUser.setSubordinate(customerExaminer.getCompanyId());
  201. projectUser.setRoleType(1);//审批人
  202. projectUserMapper.insert(projectUser);
  203. }
  204. if (null != ownerApproverId) {
  205. //2.添加资产方审批人
  206. User ownerExaminer = userMapper.selectById(ownerApproverId);
  207. Company company = companyMapper.selectById(ownerExaminer.getCompanyId());
  208. ProjectApprove ownerProjectApprove = new ProjectApprove();
  209. ownerProjectApprove.setApproverId(ownerExaminer.getId());
  210. ownerProjectApprove.setApproverName(ownerExaminer.getUsername());
  211. ownerProjectApprove.setCompanyId(ownerExaminer.getCompanyId());
  212. ownerProjectApprove.setCompanyName(company.getCompanyName());
  213. ownerProjectApprove.setProjectId(project.getId());
  214. ownerProjectApprove.setSubordinateType(ownerExaminer.getSubordinateType());
  215. projectApproveMapper.insert(ownerProjectApprove);
  216. Power power = new Power();
  217. power.setUserId(ownerExaminer.getId());
  218. power.setProjectId(project.getId());
  219. power.setPowerType(Constant.APPROVAL_AUTHORITY);
  220. powerMapper.insert(power);
  221. //审批人默认有下载权限
  222. power.setUserId(ownerExaminer.getId());
  223. power.setProjectId(project.getId());
  224. power.setPowerType(Constant.DOWNLOAD_AUTHORITY);
  225. powerMapper.insert(power);
  226. //将审批人加入到参与人中
  227. ProjectUser projectUser = new ProjectUser();
  228. projectUser.setUserId(ownerExaminer.getId());
  229. projectUser.setSubordinateType(ownerExaminer.getSubordinateType());
  230. projectUser.setProjectId(project.getId());
  231. projectUser.setSubordinate(ownerExaminer.getCompanyId());
  232. projectUser.setRoleType(1);//审批人
  233. projectUserMapper.insert(projectUser);
  234. }
  235. //删除之前分配与项目关联的模具,即将之前的关联项目id修改成未关联
  236. mouldMapper.updateMouldByProjectId(project);
  237. //再次模具的分配
  238. if (modelIds != null && !"".equals(modelIds)) {
  239. List<Integer> modelList = ListUtil.convertIntegerIdsArrayToList(modelIds);
  240. int index = 1;
  241. if (modelList.size() > 0) {
  242. for (Integer id : modelList) {
  243. Mould mould = new Mould();
  244. mould.setId(id);
  245. mould.setProjectId(project.getId());
  246. mould.setBelongProjectGrade(index / modelList.size() + "");
  247. mouldMapper.updateById(mould);
  248. }
  249. }
  250. }
  251. }
  252. } else {
  253. msg.setError("当前角色涉及权限问题,请重新登录");
  254. }
  255. return msg;
  256. }
  257. @Override
  258. public HttpRespMsg handOutProject(Project project, String userIds) {
  259. HttpRespMsg msg = new HttpRespMsg();
  260. Project pro = projectMapper.selectById(project.getId());
  261. List<Integer> ids = new ArrayList<>();
  262. if (userIds != null && userIds != "") {
  263. List<String> list = ListUtil.convertLongIdsArrayToList(userIds);
  264. if (list().size() > 0) {
  265. for (String id : list) {
  266. User user = userMapper.selectById(id);
  267. ProjectUser projectUser = new ProjectUser();
  268. projectUser.setUserId(Integer.parseInt(id));
  269. projectUser.setProjectId(project.getId());
  270. projectUser.setSubordinate(user.getSubordinateType());
  271. projectUserMapper.insert(projectUser);
  272. }
  273. }
  274. } else {
  275. msg.setError("用户id不能为null和空");
  276. }
  277. return msg;
  278. }
  279. @Override
  280. public HttpRespMsg getList(String keyName, PageUtil page, User user) {
  281. HttpRespMsg msg = new HttpRespMsg();
  282. if (user != null) {
  283. PageHelper.startPage(page.getPageNum(), page.getPageSize());
  284. List<Integer> uIds = new ArrayList<>();
  285. List<ProjectVO> projects = new ArrayList<>();
  286. List<Integer> projectIds = new ArrayList<>();
  287. if (Constant.SYS_PARENT_ID == user.getParentId()) {
  288. projects = projectMapper.getProjectListByUid(keyName, user);
  289. } else if (Constant.SYS_ID == user.getParentId()) {
  290. if (user.getSubordinateType() == 0) {
  291. QueryWrapper<Project> qwr = new QueryWrapper<>();
  292. //资产方管理员,看到自己创建的项目
  293. qwr.select("id").eq("creator_id", user.getId());
  294. projectIds = projectMapper.selectList(qwr).stream().map(Project::getId).collect(Collectors.toList());
  295. projectIds.add(-1);
  296. projects = projectMapper.getProjectListByUidInProjectIds(keyName, projectIds);
  297. } else if (user.getSubordinateType() == 1) {
  298. projectIds = customCompanyMapper.selectList(new QueryWrapper<CustomCompany>().eq("company_id", user.getCompanyId())).stream().map(CustomCompany::getProjectId).collect(Collectors.toList());
  299. projectIds.add(-1);
  300. projects = projectMapper.getProjectListByUidInProjectIds(keyName, projectIds);
  301. }
  302. } else {
  303. QueryWrapper<Project> qwPro = new QueryWrapper<>();
  304. qwPro.eq("manager_id", user.getId());
  305. projectIds = projectMapper.selectList(qwPro).stream().map(Project::getId).collect(Collectors.toList());
  306. projectIds.add(-1);
  307. //项目经理或者普通用户
  308. projectIds.addAll(projectUserMapper.selectList(new QueryWrapper<ProjectUser>()
  309. .eq("user_id", user.getId()))
  310. .stream()
  311. .map(ProjectUser::getProjectId)
  312. .collect(Collectors.toList()));
  313. //作为审批人
  314. projectIds.addAll(projectApproveMapper.selectList(new QueryWrapper<ProjectApprove>()
  315. .eq("approver_id", user.getId()))
  316. .stream()
  317. .map(ProjectApprove::getProjectId)
  318. .collect(Collectors.toList()));
  319. projects = projectMapper.getProjectListByUidInProjectIds(keyName, projectIds);
  320. }
  321. PageInfo<ProjectVO> pageInfos = new PageInfo<>(projects);
  322. msg.data = pageInfos;
  323. } else {
  324. msg.setError("当前用户不存,或涉及到权限问题,请重新登录");
  325. }
  326. // QueryWrapper<Project> qw = new QueryWrapper<>();
  327. // qw.select("project_name", "creator", "charger", "indate");
  328. // if (keyName != null) {
  329. // qw.like("project_name", keyName);
  330. // }
  331. return msg;
  332. }
  333. @Override
  334. public HttpRespMsg getUserByCompanyIdOrSubordinateType(User user) {
  335. HttpRespMsg msg = new HttpRespMsg();
  336. List<User> users = new ArrayList<>();
  337. QueryWrapper<User> qw = new QueryWrapper<>();
  338. if (user.getCompanyId() != null) {
  339. qw.eq("company_id", user.getCompanyId());
  340. } else if (user.getSubordinateType() != null) {
  341. qw.eq("subordinate_type", user.getSubordinateType());
  342. }
  343. users = userMapper.selectList(qw);
  344. msg.data = users;
  345. return msg;
  346. }
  347. @Override
  348. public HttpRespMsg getProjectDetail(Project project, String token) {
  349. Map<String, Object> map = new HashMap<>();
  350. HttpRespMsg msg = new HttpRespMsg();
  351. User user = userMapper.selectOne(new QueryWrapper<User>().eq("head_imgurl", token));
  352. List<ProjectVO> projects = new ArrayList<>();
  353. String keyName = null;
  354. if (user != null) {
  355. List<Integer> uIds = new ArrayList<>();
  356. List<Integer> projectIds = new ArrayList<>();
  357. if (Constant.SYS_PARENT_ID == user.getParentId()) {
  358. projects = projectMapper.getProjectListByUid(keyName, user);
  359. } else if (Constant.SYS_ID == user.getParentId()) {
  360. if (user.getSubordinateType() == 0) {
  361. QueryWrapper<Project> qwr = new QueryWrapper<>();
  362. //资产方管理员,看到自己创建的项目
  363. qwr.select("id").eq("creator_id", user.getId());
  364. projectIds = projectMapper.selectList(qwr).stream().map(Project::getId).collect(Collectors.toList());
  365. projectIds.add(-1);
  366. projects = projectMapper.getProjectListByUidInProjectIds(keyName, projectIds);
  367. } else if (user.getSubordinateType() == 1) {
  368. projectIds = customCompanyMapper.selectList(new QueryWrapper<CustomCompany>().eq("company_id", user.getCompanyId())).stream().map(CustomCompany::getProjectId).collect(Collectors.toList());
  369. projectIds.add(-1);
  370. projects = projectMapper.getProjectListByUidInProjectIds(keyName, projectIds);
  371. }
  372. } else {
  373. QueryWrapper<Project> qwPro = new QueryWrapper<>();
  374. qwPro.eq("manager_id", user.getId());
  375. projectIds = projectMapper.selectList(qwPro).stream().map(Project::getId).collect(Collectors.toList());
  376. projectIds.add(-1);
  377. //项目经理或者普通用户
  378. projectIds.addAll(projectUserMapper.selectList(new QueryWrapper<ProjectUser>()
  379. .eq("user_id", user.getId()))
  380. .stream()
  381. .map(ProjectUser::getProjectId)
  382. .collect(Collectors.toList()));
  383. //作为审批人
  384. projectIds.addAll(projectApproveMapper.selectList(new QueryWrapper<ProjectApprove>()
  385. .eq("approver_id", user.getId()))
  386. .stream()
  387. .map(ProjectApprove::getProjectId)
  388. .collect(Collectors.toList()));
  389. projects = projectMapper.getProjectListByUidInProjectIds(keyName, projectIds);
  390. }
  391. } else {
  392. msg.setError("当前用户不存,或涉及到权限问题,请重新登录");
  393. }
  394. List<Integer> pIds = projects.stream().map(Project::getId).collect(Collectors.toList());
  395. if(!pIds.contains(project.getId())){
  396. msg.setError("您没有查看该项目的权限");
  397. return msg;
  398. }
  399. ProjectVO vo = projectMapper.getProjectById(project.getId());
  400. if (Constant.SYS_PARENT_ID == user.getParentId()) {
  401. //当前人超级管理员 ,对项目只可以浏览
  402. map.put("update", 0);
  403. map.put("download", 0);
  404. map.put("view", 1);
  405. map.put("approve", 0);
  406. } else if (Constant.SYS_ID == user.getParentId()) {
  407. //当前为系统管理员
  408. if (Constant.ASSETS_COMPANY == user.getSubordinateType()) {
  409. map.put("update", 1);
  410. map.put("download", 1);
  411. map.put("view", 1);
  412. map.put("approve", 0);
  413. } else if (Constant.PRODUCER_COMPANY == user.getSubordinateType()) {
  414. map.put("update", 0);
  415. map.put("download", 1);
  416. map.put("view", 1);
  417. map.put("approve", 0);
  418. }
  419. } else if (vo.getManagerId() == user.getId()) {
  420. //当前人是该项目的项目经理
  421. Integer approve = 0;
  422. if (projectApproveMapper.selectCount(new QueryWrapper<ProjectApprove>().eq("approver_id", user.getId())) > 0) {
  423. //查看当前项目经理是否为审批人
  424. approve = 1;
  425. }
  426. map.put("update", 1);
  427. map.put("download", 1);
  428. map.put("view", 1);
  429. map.put("approve", approve);
  430. } /*else if (projectApproveMapper.selectCount(new QueryWrapper<ProjectApprove>().eq("approver_id", user.getId())) > 0) {
  431. //是否为审批人
  432. //该项目的参与人
  433. Integer update = 0;
  434. Integer download = 0;
  435. Integer view = 0;
  436. Integer approve = 1;
  437. List<Power> powers = powerMapper.selectList(new QueryWrapper<Power>().eq("project_id", project.getId()).eq("user_id", user.getId()));
  438. if (powers.size() > 0) {
  439. for (Power power : powers) {
  440. if (power.getPowerType() == 0) {
  441. update = 1;
  442. } else if (power.getPowerType() == 1) {
  443. download = 1;
  444. } else if (power.getPowerType() == 2) {
  445. view = 1;
  446. } else {
  447. approve = 1;
  448. }
  449. }
  450. }
  451. map.put("update", update);
  452. map.put("download", download);
  453. map.put("view", view);
  454. map.put("approve", approve);
  455. }*/ else {
  456. //该项目的参与人
  457. Integer update = 0;
  458. Integer download = 0;
  459. Integer view = 0;
  460. Integer approve = 0;
  461. List<Power> powers = powerMapper.selectList(new QueryWrapper<Power>().eq("project_id", project.getId()).eq("user_id", user.getId()));
  462. if (powers.size() > 0) {
  463. for (Power power : powers) {
  464. if (power.getPowerType() == 0) {
  465. update = 1;
  466. } else if (power.getPowerType() == 1) {
  467. download = 1;
  468. } else if (power.getPowerType() == 2) {
  469. view = 1;
  470. } else {
  471. approve = 1;
  472. }
  473. }
  474. }
  475. map.put("update", update);
  476. map.put("download", download);
  477. map.put("view", view);
  478. map.put("approve", approve);
  479. }
  480. List<User> users = projectMapper.getProjectUserById(project.getId());
  481. vo.setParticipateUsers(users);
  482. //处理users按照客户呼和供应商分组
  483. System.out.println("users===>" + users);
  484. // for (User user : users) {
  485. // if (user.getSubordinateType() == 0) {
  486. // //资产方
  487. // vo.getOwnerUsers().add(user);
  488. // } else if (user.getSubordinateType() == 1) {
  489. // //生产方
  490. // vo.getCustomUsers().add(user);
  491. // }
  492. // }
  493. map.put("vo", vo);
  494. msg.data = map;
  495. return msg;
  496. }
  497. @Override
  498. public HttpRespMsg getUserListByCompanyIds(String companyIds, Integer id, Integer projectId) {
  499. HttpRespMsg msg = new HttpRespMsg();
  500. User user = userMapper.selectById(id);
  501. QueryWrapper<User> qw = new QueryWrapper<User>();
  502. List<Integer> ids = new ArrayList<>();
  503. ids.add(-1);
  504. if (!"".equals(companyIds) && companyIds != null) {
  505. ids = ListUtil.convertIntegerIdsArrayToList(companyIds);
  506. }
  507. List<Integer> uids = new ArrayList<>();
  508. uids.add(-1);
  509. if(Constant.SYS_ID == user.getParentId()){
  510. //资产方管理员
  511. uids = userCompanyMapper.selectList(new QueryWrapper<UserCompany>().eq("cooperation_company_id", user.getCompanyId()).in("belong_company_id",ids)).stream().map(UserCompany::getUserId).collect(Collectors.toList());
  512. List<Integer> userIds = userMapper.selectList(new QueryWrapper<User>().eq("company_id", user.getCompanyId()).ne("parent_id",1)).stream().map(User::getId).collect(Collectors.toList());
  513. uids.addAll(userIds);
  514. qw.in("id",uids).ne("id",id);
  515. }else{
  516. //项目经理
  517. if(null != projectId){
  518. Project pro = projectMapper.selectById(projectId);
  519. user = userMapper.selectById(pro.getCreatorId());
  520. uids = userCompanyMapper.selectList(new QueryWrapper<UserCompany>().eq("cooperation_company_id", user.getCompanyId()).in("belong_company_id",ids)).stream().map(UserCompany::getUserId).collect(Collectors.toList());
  521. List<Integer> userIds = userMapper.selectList(new QueryWrapper<User>().eq("company_id", user.getCompanyId()).ne("parent_id",1)).stream().map(User::getId).collect(Collectors.toList());
  522. uids.addAll(userIds);
  523. qw.in("id",uids).ne("id",user.getId());
  524. }
  525. }
  526. msg.data = userMapper.selectList(qw);
  527. return msg;
  528. }
  529. @Override
  530. public HttpRespMsg getModelListByCompanyId(User user) {
  531. HttpRespMsg msg = new HttpRespMsg();
  532. QueryWrapper<Mould> qw = new QueryWrapper<>();
  533. Integer companyId = -1;
  534. if (Constant.SYS_ID == user.getParentId()) {
  535. //此时是admin
  536. User admin = userMapper.selectOne(new QueryWrapper<User>().eq("id", user.getId()));
  537. companyId = admin.getCompanyId();
  538. // qw.eq("company_id", admin.getCompanyId());
  539. } else if (Constant.SYS_PARENT_ID == user.getParentId()) {
  540. //系统管理员
  541. // qw.eq("company_type",Constant.ASSETS_COMPANY);
  542. } else {
  543. //此时是项目经理
  544. User admin = userMapper.selectOne(new QueryWrapper<User>().eq("id", user.getParentId()));
  545. companyId = admin.getCompanyId();
  546. // qw.eq("company_id", admin.getCompanyId());
  547. }
  548. // List<Mould> moulds = mouldMapper.selectList(new QueryWrapper<Mould>().eq("company_id", companyId).isNull("project_id"));
  549. msg.data = mouldMapper.selectListByCompanyId(companyId,null);
  550. return msg;
  551. }
  552. @Override
  553. public HttpRespMsg getModelListByUser(UserVO userVO, PageUtil page) {
  554. HttpRespMsg msg = new HttpRespMsg();
  555. List<Integer> set = new ArrayList<>();
  556. set.add(-1);
  557. List<MouldVO> moulds = new ArrayList<>();
  558. if (userVO.getId() != null) {
  559. //资产方管理员,获取他公司下的所有模具
  560. PageHelper.startPage(page.getPageNum(), page.getPageSize());
  561. if (Constant.SYS_PARENT_ID == userVO.getParentId()) {
  562. //超级管理员,获取平台所有模具
  563. moulds = mouldMapper.selectListByCondition(userVO);
  564. } else if (Constant.SYS_ID == userVO.getParentId()) {
  565. if (Constant.ASSETS_COMPANY == userVO.getSubordinateType()) {
  566. //资产方管理员
  567. moulds = mouldMapper.selectListByCondition(userVO);
  568. } else if (Constant.PRODUCER_COMPANY == userVO.getSubordinateType()) {
  569. set = customCompanyMapper.selectList(new QueryWrapper<CustomCompany>().eq("company_id", userVO.getCompanyId())).stream().map(CustomCompany::getProjectId).collect(Collectors.toList());
  570. set.add(-1);
  571. moulds = mouldMapper.selectListByConditionByProject(userVO, set);
  572. }
  573. } else {
  574. //普通用户或者项目经理
  575. //充当项目经理参与的项目
  576. if (userVO.getProjectId() != -1) {
  577. set.add(userVO.getProjectId());
  578. set.add(-1);
  579. moulds = mouldMapper.selectListByConditionByProject(userVO, set);
  580. } else {
  581. QueryWrapper<Project> qw = new QueryWrapper<>();
  582. qw.eq("manager_id", userVO.getId());
  583. List<Project> projects = projectMapper.selectList(qw);
  584. if (projects.size() > 0) {
  585. for (Project project : projects) {
  586. set.add(project.getId());
  587. }
  588. }
  589. // //充当普通人员参与的项目
  590. List<ProjectUser> projectUsers = projectUserMapper.selectList(new QueryWrapper<ProjectUser>().eq("user_id", userVO.getId()));
  591. if (projectUsers.size() > 0) {
  592. for (ProjectUser projectUser : projectUsers) {
  593. set.add(projectUser.getProjectId());
  594. }
  595. }
  596. // //充当审批人员参与的项目
  597. List<ProjectApprove> projectss = projectApproveMapper.selectList(new QueryWrapper<ProjectApprove>().eq("approver_id", userVO.getId()));
  598. if (projectss.size() > 0) {
  599. for (ProjectApprove projectUser : projectss) {
  600. set.add(projectUser.getProjectId());
  601. }
  602. }
  603. set.add(-1);
  604. moulds = mouldMapper.selectListByConditionByProject(userVO, set);
  605. }
  606. }
  607. PageInfo<MouldVO> pageInfo = new PageInfo<>(moulds);
  608. msg.data = pageInfo;
  609. } else {
  610. msg.setError("用户不存在,或者未登录!");
  611. }
  612. return msg;
  613. }
  614. @Override
  615. public HttpRespMsg getListByUser(String token) {
  616. HttpRespMsg msg = new HttpRespMsg();
  617. List<Integer> ides = new ArrayList<>();
  618. ides.add(-1);
  619. User user = userMapper.selectOne(new QueryWrapper<User>().eq("head_imgurl", token));
  620. List<Project> projects = new ArrayList<>();
  621. if (user != null) {
  622. QueryWrapper<Project> qw = new QueryWrapper<>();
  623. qw.select("id", "project_name");
  624. if (Constant.SYS_PARENT_ID == user.getParentId()) {
  625. //系统超级管理员,可获得所有项目
  626. projects = projectMapper.selectList(qw);
  627. } else if (Constant.SYS_ID == user.getParentId()) {
  628. //资产方管理员
  629. qw.eq("owner_company", user.getCompanyId());
  630. projects = projectMapper.selectList(qw);
  631. } else {
  632. QueryWrapper<Project> qwPro = new QueryWrapper<>();
  633. qwPro.eq("manager_id", user.getId());
  634. List<Project> projectList = projectMapper.selectList(qw);
  635. for (Project project : projectList) {
  636. ides.add(project.getId());
  637. }
  638. //项目经理或者普通用户
  639. List<ProjectUser> projectUsers = projectUserMapper.selectList(new QueryWrapper<ProjectUser>().eq("user_id", user.getId()));
  640. for (ProjectUser projectUser : projectUsers) {
  641. ides.add(projectUser.getProjectId());
  642. }
  643. //作为审批人
  644. List<ProjectApprove> projectApproves = projectApproveMapper.selectList(new QueryWrapper<ProjectApprove>().eq("approver_id", user.getId()));
  645. for (ProjectApprove projectApprove : projectApproves) {
  646. ides.add(projectApprove.getProjectId());
  647. }
  648. qw.in("id", ides);
  649. projects = projectMapper.selectList(qw);
  650. }
  651. msg.data = projects;
  652. } else {
  653. msg.setError("当前用户未登录,或者用户不存在");
  654. }
  655. return msg;
  656. }
  657. @Override
  658. public HttpRespMsg getProjectListByUserAndCompany(UserVO userVO) {
  659. HttpRespMsg msg = new HttpRespMsg();
  660. User user = userMapper.selectOne(new QueryWrapper<User>().eq("head_imgurl", userVO.getToken()));
  661. List<Project> list = new ArrayList<>();
  662. if (user == null) {
  663. msg.setError("当前用户未登录,或者用户不存在");
  664. return msg;
  665. } else {
  666. if (Constant.SYS_ID == user.getParentId()) {
  667. //admin创建人员,获取该公司下的所有项目
  668. list = projectMapper.selectList(new QueryWrapper<Project>().eq("owner_company", user.getCompanyId()));
  669. } else {
  670. //项目经理创建人员,获取当前项目经理的充当项目经理的任务
  671. list = projectMapper.selectList(new QueryWrapper<Project>().eq("manager_id", user.getId()));
  672. }
  673. msg.data = list;
  674. }
  675. return msg;
  676. }
  677. @Override
  678. public HttpRespMsg getModelListMapByUser(UserVO userVO) {
  679. HttpRespMsg msg = new HttpRespMsg();
  680. userVO.setProjectId(-1);
  681. userVO.setMouleMap(-1);
  682. List<Integer> set = new ArrayList<>();
  683. set.add(-1);
  684. List<MouldVO> moulds = new ArrayList<>();
  685. if (userVO.getId() != null) {
  686. //资产方管理员,获取他公司下的所有模具
  687. if (Constant.SYS_PARENT_ID == userVO.getParentId()) {
  688. //超级管理员,获取平台所有模具
  689. moulds = mouldMapper.selectListByCondition(userVO);
  690. } else if (Constant.SYS_ID == userVO.getParentId()) {
  691. if (Constant.ASSETS_COMPANY == userVO.getSubordinateType()) {
  692. //资产方管理员
  693. moulds = mouldMapper.selectListByCondition(userVO);
  694. } else if (Constant.PRODUCER_COMPANY == userVO.getSubordinateType()) {
  695. set = customCompanyMapper.selectList(new QueryWrapper<CustomCompany>().eq("company_id", userVO.getCompanyId())).stream().map(CustomCompany::getProjectId).collect(Collectors.toList());
  696. set.add(-1);
  697. moulds = mouldMapper.selectListByConditionByProject(userVO, set);
  698. }
  699. } else {
  700. //普通用户或者项目经理
  701. //充当项目经理参与的项目
  702. if (userVO.getProjectId() != -1) {
  703. set.add(userVO.getProjectId());
  704. set.add(-1);
  705. moulds = mouldMapper.selectListByConditionByProject(userVO, set);
  706. } else {
  707. QueryWrapper<Project> qw = new QueryWrapper<>();
  708. qw.eq("manager_id", userVO.getId());
  709. List<Project> projects = projectMapper.selectList(qw);
  710. if (projects.size() > 0) {
  711. for (Project project : projects) {
  712. set.add(project.getId());
  713. }
  714. }
  715. // //充当普通人员参与的项目
  716. List<ProjectUser> projectUsers = projectUserMapper.selectList(new QueryWrapper<ProjectUser>().eq("user_id", userVO.getId()));
  717. if (projectUsers.size() > 0) {
  718. for (ProjectUser projectUser : projectUsers) {
  719. set.add(projectUser.getProjectId());
  720. }
  721. }
  722. // //充当审批人员参与的项目
  723. List<ProjectApprove> projectss = projectApproveMapper.selectList(new QueryWrapper<ProjectApprove>().eq("approver_id", userVO.getId()));
  724. if (projectss.size() > 0) {
  725. for (ProjectApprove projectUser : projectss) {
  726. set.add(projectUser.getProjectId());
  727. }
  728. }
  729. set.add(-1);
  730. moulds = mouldMapper.selectListByConditionByProject(userVO, set);
  731. }
  732. }
  733. msg.data = moulds;
  734. } else {
  735. msg.setError("用户不存在,或者未登录!");
  736. }
  737. return msg;
  738. }
  739. @Override
  740. public HttpRespMsg getModelListByCompanyIdAndProjectId(UserVO userVO) {
  741. HttpRespMsg msg = new HttpRespMsg();
  742. User user = userMapper.selectOne(new QueryWrapper<User>().eq("head_imgurl", userVO.getToken()));
  743. QueryWrapper<Mould> qw = new QueryWrapper<>();
  744. Integer companyId = -1;
  745. if (Constant.SYS_ID == user.getParentId()) {
  746. //此时是admin
  747. User admin = userMapper.selectOne(new QueryWrapper<User>().eq("id", user.getId()));
  748. companyId = admin.getCompanyId();
  749. // qw.eq("company_id", admin.getCompanyId());
  750. } else if (Constant.SYS_PARENT_ID == user.getParentId()) {
  751. //系统管理员
  752. // qw.eq("company_type",Constant.ASSETS_COMPANY);
  753. } else {
  754. //此时是项目经理
  755. User admin = userMapper.selectOne(new QueryWrapper<User>().eq("id", user.getParentId()));
  756. companyId = admin.getCompanyId();
  757. // qw.eq("company_id", admin.getCompanyId());
  758. }
  759. // List<Mould> moulds = mouldMapper.selectList(new QueryWrapper<Mould>().eq("company_id", companyId).isNull("project_id"));
  760. msg.data = mouldMapper.selectListByCompanyId(companyId,userVO.getProjectId());
  761. return msg;
  762. }
  763. }