PatentProjectService.java 40 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906
  1. package cn.cslg.pas.service.business;
  2. import cn.cslg.pas.common.dto.ClientDTO;
  3. import cn.cslg.pas.common.dto.business.*;
  4. import cn.cslg.pas.common.model.cronModel.*;
  5. import cn.cslg.pas.common.model.request.GroupRequest;
  6. import cn.cslg.pas.common.model.request.QueryRequest;
  7. import cn.cslg.pas.common.model.request.StringRequest;
  8. import cn.cslg.pas.common.utils.CacheUtils;
  9. import cn.cslg.pas.common.utils.LoginUtils;
  10. import cn.cslg.pas.common.vo.DepartmentVO;
  11. import cn.cslg.pas.common.vo.ProductOrCategoryVO;
  12. import cn.cslg.pas.common.vo.business.PatentProjectVO;
  13. import cn.cslg.pas.common.vo.business.ReportCountVO;
  14. import cn.cslg.pas.domain.business.*;
  15. import cn.cslg.pas.exception.UnLoginException;
  16. import cn.cslg.pas.exception.XiaoShiException;
  17. import cn.cslg.pas.factorys.businessFactory.Business;
  18. import cn.cslg.pas.factorys.reGroupFactory.QueryGroupFactory;
  19. import cn.cslg.pas.factorys.reGroupFactory.QueryGroupImp;
  20. import cn.cslg.pas.mapper.PatentProjectMapper;
  21. import cn.cslg.pas.service.common.FileManagerService;
  22. import cn.cslg.pas.service.permissions.PermissionService;
  23. import cn.cslg.pas.service.query.FormatQueryService;
  24. import com.alibaba.fastjson.JSON;
  25. import com.alibaba.fastjson.JSONObject;
  26. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  27. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  28. import lombok.extern.slf4j.Slf4j;
  29. import org.springframework.beans.BeanUtils;
  30. import org.springframework.beans.factory.annotation.Autowired;
  31. import org.springframework.stereotype.Service;
  32. import org.springframework.transaction.annotation.Transactional;
  33. import org.springframework.web.multipart.MultipartFile;
  34. import java.io.IOException;
  35. import java.util.ArrayList;
  36. import java.util.Arrays;
  37. import java.util.List;
  38. import java.util.stream.Collectors;
  39. @Service
  40. @Slf4j
  41. public class PatentProjectService extends ServiceImpl<PatentProjectMapper, PatentProject> implements Business {
  42. @Autowired
  43. private PatentProjectMapper patentProjectMapper;
  44. @Autowired
  45. private FormatQueryService formatQueryService;
  46. @Autowired
  47. private QueryGroupFactory queryGroupFactory;
  48. @Autowired
  49. private CacheUtils cacheUtils;
  50. @Autowired
  51. private LoginUtils loginUtils;
  52. @Autowired
  53. private PermissionService permissionService;
  54. @Autowired
  55. private AssoProjectEventService assoProjectEventService;
  56. @Autowired
  57. private AssoProjectTreeNodeService assoProjectTreeNodeService;
  58. @Autowired
  59. private AssoProjectFileService assoProjectFileService;
  60. @Autowired
  61. private FileManagerService fileManagerService;
  62. @Autowired
  63. private AssoProjectService assoProjectService;
  64. @Autowired
  65. private EventService eventService;
  66. @Autowired
  67. private ScenarioService scenarioService;
  68. @Autowired
  69. private MatterService matterService;
  70. @Autowired
  71. private ProductService productService;
  72. @Autowired
  73. private ProductCategoryService productCategoryService;
  74. @Autowired
  75. private ProjectService projectService;
  76. @Autowired
  77. private AssoProjectScenarioService assoProjectScenarioService;
  78. @Override
  79. @Transactional(rollbackFor = Exception.class)
  80. public Object queryMessage(QueryRequest queryRequest) throws Exception {
  81. List<String> sqls = formatQueryService.reSqls(queryRequest, "patentProject");
  82. sqls =this.loadSearchSql(sqls);
  83. //根据sql查询专题库信息
  84. List<PatentProjectVO> patentProjectVOS = patentProjectMapper.getPatentProject(sqls.get(0), sqls.get(1), sqls.get(2));
  85. Long total = patentProjectMapper.getPatentProjectCount(sqls.get(0));
  86. //装载专利数据库信息
  87. this.loadPatentProject(patentProjectVOS);
  88. Records records = new Records();
  89. records.setCurrent(queryRequest.getCurrent());
  90. records.setSize(queryRequest.getSize());
  91. records.setData(patentProjectVOS);
  92. records.setTotal(total);
  93. return records;
  94. }
  95. @Override
  96. @Transactional(rollbackFor = Exception.class)
  97. public Integer addMessage(Object object, List<MultipartFile> files) {
  98. return null;
  99. }
  100. /**
  101. * @param object
  102. * @param files
  103. * @return
  104. */
  105. @Override
  106. @Transactional(rollbackFor = Exception.class)
  107. public Object updateMessage(Object object, List<MultipartFile> files) {
  108. return null;
  109. }
  110. @Override
  111. @Transactional(rollbackFor = Exception.class)
  112. public Object deleteMessage(List<Integer> ids) throws IOException {
  113. //TODO 检查是否有关联报告,如果有则提示不允许删除
  114. LambdaQueryWrapper<AssoProject> reportExistWrapper = new LambdaQueryWrapper<>();
  115. reportExistWrapper.in(AssoProject::getProjectId, ids);
  116. reportExistWrapper.eq(AssoProject::getAssoProjectType, 2);
  117. List<AssoProject> assoProjects = assoProjectService.list(reportExistWrapper);
  118. if (assoProjects.size() != 0) {
  119. throw new XiaoShiException("待删除专题库集合中有关联报告,无法删除!");
  120. }
  121. //TODO 根据id删除专利数据库和文件关联表
  122. LambdaQueryWrapper<AssoProjectFile> deleteFileWrapper = new LambdaQueryWrapper<>();
  123. deleteFileWrapper.in(AssoProjectFile::getProjectId, ids);
  124. assoProjectFileService.remove(deleteFileWrapper);
  125. //TODO 根据id删除专利数据库和事件的关联表
  126. LambdaQueryWrapper<AssoProjectEvent> deleteEventWrapper = new LambdaQueryWrapper<>();
  127. deleteEventWrapper.in(AssoProjectEvent::getProjectId, ids);
  128. assoProjectEventService.remove(deleteEventWrapper);
  129. //TODO 根据id删除专利数据库的自定义字段的标引(es部分,暂时不做)
  130. //TODO 根据id删除专利数据库的自定义字段(自定义字段模块未完成,暂时不做)
  131. //TODO 根据id删除专利数据库和应用场景关联
  132. LambdaQueryWrapper<AssoProjectScenario> deleteScenarioWrapper = new LambdaQueryWrapper<>();
  133. deleteScenarioWrapper.in(AssoProjectScenario::getProjectId, ids);
  134. assoProjectScenarioService.remove(deleteScenarioWrapper);
  135. //TODO 根据id删除任务信息(任务模块未完成,暂时不做)
  136. //TODO 根据id删除任专利关联信息(es部分,暂时不做)
  137. //TODO 根据id删除导入任务信息(导入任务模块未完成,暂时不做)
  138. //删除专利数据库
  139. LambdaQueryWrapper<PatentProject> patentProjectLambdaQueryWrapper = new LambdaQueryWrapper<>();
  140. patentProjectLambdaQueryWrapper.in(PatentProject::getProjectId, ids);
  141. this.remove(patentProjectLambdaQueryWrapper);
  142. projectService.removeBatchByIds(ids);
  143. //
  144. return ids;
  145. }
  146. /**
  147. * 查询专题库分组信息
  148. *
  149. * @param groupRequest
  150. * @return
  151. * @throws Exception
  152. */
  153. @Transactional(rollbackFor = Exception.class)
  154. public Object getGroup(GroupRequest groupRequest, String tableName) throws Exception {
  155. StringRequest stringRequest = new StringRequest();
  156. BeanUtils.copyProperties(groupRequest, stringRequest);
  157. List<String> sqls = formatQueryService.reSqls(stringRequest, tableName);
  158. sqls=this.loadSearchSql(sqls);
  159. //格式化 分组
  160. GroupConfig groupConfig = null;
  161. if (groupRequest.getGroupBy() != null) {
  162. String json = CommonService.readJsonFile(tableName + ".json");
  163. List<GroupConfig> groupConfigs = JSON.parseArray(json, GroupConfig.class);
  164. groupConfig = groupConfigs.stream().filter(item -> groupRequest.getGroupBy().equals(item.getField())).findFirst().orElse(null);
  165. if (groupConfig == null) {
  166. throw new XiaoShiException("未找到配置");
  167. }
  168. }
  169. tableName = "patent_project as pp left join project as p on pp.project_id = p.id ";
  170. //返回分组数据
  171. QueryGroupImp queryGroupImp = queryGroupFactory.getClass(groupConfig.getGroupClass());
  172. ReGroupDataVO reGroupDataVO = queryGroupImp.getGroup(sqls, tableName, groupConfig.getSqlField());
  173. //装载数据
  174. GroupVO groupVO = new GroupVO();
  175. groupVO.setField(groupRequest.getGroupBy());
  176. groupVO.setValues(reGroupDataVO.getValues());
  177. Records records = new Records();
  178. records.setCurrent(groupRequest.getCurrent());
  179. records.setSize(groupRequest.getSize());
  180. records.setData(groupVO);
  181. records.setTotal(reGroupDataVO.getTotal());
  182. return records;
  183. }
  184. /**
  185. * 添加
  186. *
  187. * @param object
  188. * @return
  189. */
  190. @Override
  191. @Transactional(rollbackFor = Exception.class)
  192. public Object addMessage(Object object) {
  193. if (object == null) {
  194. throw new XiaoShiException("参数不能为空");
  195. }
  196. //TODO 校验参数
  197. PatentProjectDTO patentProjectDTO = (PatentProjectDTO) object;
  198. //判断是否选择更新并且上传了cron表达式
  199. if (patentProjectDTO.getIfUpdate() != false) {
  200. if (patentProjectDTO.getCrons() == null && patentProjectDTO.getCrons().equals("")) {
  201. throw new XiaoShiException("选择更新,则cron表达式不能为空!");
  202. }
  203. }
  204. //校验必传参数是否上传
  205. if (patentProjectDTO.getHeadId() == null) {
  206. throw new XiaoShiException("负责人id不能为空");
  207. }
  208. //获取登陆人信息 用于设置创建人
  209. PersonnelVO personnelVO = new PersonnelVO();
  210. try {
  211. personnelVO = cacheUtils.getLoginUser(loginUtils.getId());
  212. } catch (Exception e) {
  213. throw new UnLoginException("未登录");
  214. }
  215. /**
  216. * 装载project
  217. */
  218. Project project = new Project();
  219. BeanUtils.copyProperties(patentProjectDTO, project);
  220. //TODO 当委托方id或者委托方名称不为空时,
  221. if (patentProjectDTO.getEntrustId() != null || patentProjectDTO.getEntrustName() != null) {
  222. //根据创建人的租户类型设置project的委托类型
  223. if (personnelVO.getTenantType().equals("1")) {
  224. project.setEntrustType(1);
  225. //当委托方id不为空时
  226. if (patentProjectDTO.getEntrustId() != null) {
  227. project.setEntrustId(patentProjectDTO.getEntrustId());
  228. }
  229. //若且租户类型为代理机构,并且委托方id为空,委托方名称不为空时,新增委托方
  230. else {
  231. ClientDTO clientDTO = new ClientDTO();
  232. clientDTO.setName(patentProjectDTO.getEntrustName());
  233. clientDTO.setTenantId(personnelVO.getTenantId());
  234. try {
  235. String res = permissionService.addClient(clientDTO);
  236. JSONObject jsonObject = JSONObject.parseObject(res);
  237. Integer clientId = Integer.parseInt(jsonObject.get("data").toString());
  238. project.setEntrustId(clientId.toString());
  239. } catch (Exception e) {
  240. throw new XiaoShiException("网络异常");
  241. }
  242. }
  243. } else {
  244. if (patentProjectDTO.getEntrustId() != null) {
  245. project.setEntrustType(0);
  246. project.setEntrustId(patentProjectDTO.getEntrustId());
  247. }
  248. }
  249. }
  250. project.setCreateId(personnelVO.getId());
  251. project.setTenantId(personnelVO.getTenantId());
  252. project.setType(1);
  253. project.insert();
  254. /**
  255. * 装载patentProject
  256. */
  257. PatentProject patentProject = new PatentProject();
  258. BeanUtils.copyProperties(patentProjectDTO, patentProject);
  259. patentProject.setProjectId(project.getId());
  260. patentProject.insert();
  261. /**
  262. * 装载事件与project关联
  263. */
  264. List<AssoProjectEvent> assoProjectEvents = new ArrayList<>();
  265. List<ProjectEventDTO> events = patentProjectDTO.getEvents();
  266. if (events != null && events.size() != 0) {
  267. //遍历传入的事件集合
  268. for (ProjectEventDTO projectEventDTO : events) {
  269. AssoProjectEvent assoProjectEvent = new AssoProjectEvent();
  270. //事件id和处理事项id
  271. BeanUtils.copyProperties(projectEventDTO, assoProjectEvent);
  272. //项目id
  273. assoProjectEvent.setProjectId(project.getId());
  274. //创建人
  275. assoProjectEvent.setCreateId(personnelVO.getId());
  276. //类型为专题库
  277. assoProjectEvent.setProjectType(0);
  278. assoProjectEvents.add(assoProjectEvent);
  279. }
  280. }
  281. //装载应用场景和project关联
  282. List<Integer> scenarios = patentProjectDTO.getScenarioIds();
  283. if (scenarios != null && scenarios.size() > 0) {
  284. for (Integer item : scenarios) {
  285. AssoProjectEvent assoProjectEvent = new AssoProjectEvent();
  286. //项目id
  287. assoProjectEvent.setProjectId(project.getId());
  288. //创建人
  289. assoProjectEvent.setCreateId(personnelVO.getId());
  290. //类型为专题库
  291. assoProjectEvent.setProjectType(0);
  292. //装载场景id
  293. assoProjectEvent.setScenarioId(item);
  294. assoProjectEvents.add(assoProjectEvent);
  295. }
  296. }
  297. //装载应用场景和project关联
  298. List<Integer> matter = patentProjectDTO.getMatterIds();
  299. if (matter != null && matter.size() > 0) {
  300. for (Integer item : matter) {
  301. AssoProjectEvent assoProjectEvent = new AssoProjectEvent();
  302. //项目id
  303. assoProjectEvent.setProjectId(project.getId());
  304. //创建人
  305. assoProjectEvent.setCreateId(personnelVO.getId());
  306. //类型为专题库
  307. assoProjectEvent.setProjectType(0);
  308. //装载处理事项id
  309. assoProjectEvent.setMatterId(item);
  310. assoProjectEvents.add(assoProjectEvent);
  311. }
  312. }
  313. //统一进行保存
  314. if (assoProjectEvents != null && assoProjectEvents.size() != 0) {
  315. assoProjectEventService.saveBatch(assoProjectEvents);
  316. }
  317. /**
  318. * 装载树结构和project关联
  319. */
  320. List<AssoProjectTreeNode> assoProjectTreeNodes = new ArrayList<>();
  321. List<ProjectTreesDTO> trees = patentProjectDTO.getTrees();
  322. if (trees != null && trees.size() != 0) {
  323. //遍历传入的树
  324. for (ProjectTreesDTO projectTreesDTO : trees) {
  325. List<Integer> valueIds = projectTreesDTO.getValueIds();
  326. if(valueIds==null||valueIds.size()==0){
  327. valueIds = Arrays.asList(0);
  328. }
  329. //遍历值id集合
  330. for (Integer valueId : valueIds) {
  331. AssoProjectTreeNode assoProjectTreeNode = new AssoProjectTreeNode();
  332. BeanUtils.copyProperties(projectTreesDTO, assoProjectTreeNode);
  333. //专题库、报告id
  334. assoProjectTreeNode.setProjectId(project.getId());
  335. //值id
  336. assoProjectTreeNode.setValueId(valueId);
  337. assoProjectTreeNodes.add(assoProjectTreeNode);
  338. }
  339. }
  340. if (assoProjectTreeNodes != null && assoProjectTreeNodes.size() != 0) {
  341. assoProjectTreeNodeService.saveBatch(assoProjectTreeNodes);
  342. }
  343. }
  344. /**
  345. * 装载和附件关联
  346. */
  347. List<AssoProjectFile> assoProjectFiles = new ArrayList<>();
  348. List<String> fileGuids = patentProjectDTO.getFileGuids();
  349. if (fileGuids != null && fileGuids.size() != 0) {
  350. for (String fileGuid : fileGuids) {
  351. AssoProjectFile assoProjectFile = new AssoProjectFile();
  352. assoProjectFile.setProjectId(project.getId());
  353. assoProjectFile.setFileGuid(fileGuid);
  354. assoProjectFile.setCreateId(personnelVO.getId());
  355. assoProjectFiles.add(assoProjectFile);
  356. }
  357. if (assoProjectFiles != null && assoProjectFiles.size() != 0) {
  358. assoProjectFileService.saveBatch(assoProjectFiles);
  359. }
  360. }
  361. return project.getId();
  362. }
  363. @Override
  364. public Object updateMessage(Object object) {
  365. if (object == null) {
  366. throw new XiaoShiException("参数不能为空");
  367. }
  368. //TODO 校验参数
  369. UpdatePatentProjectDTO updatePatentProjectDTO = (UpdatePatentProjectDTO) object;
  370. //判断是否选择更新并且上传了cron表达式
  371. if (updatePatentProjectDTO.getIfUpdate() != false) {
  372. if (updatePatentProjectDTO.getCrons() == null && updatePatentProjectDTO.getCrons().equals("")) {
  373. throw new XiaoShiException("选择更新,则cron表达式不能为空!");
  374. }
  375. }
  376. //校验必传参数是否上传
  377. if (updatePatentProjectDTO.getHeadId() == null) {
  378. throw new XiaoShiException("负责人id不能为空");
  379. }
  380. //获取登陆人信息 用于设置创建人
  381. PersonnelVO personnelVO = new PersonnelVO();
  382. try {
  383. personnelVO = cacheUtils.getLoginUser(loginUtils.getId());
  384. } catch (Exception e) {
  385. throw new UnLoginException("未登录");
  386. }
  387. //TODO 更新基本信息
  388. //根据传入对象id查询project对象
  389. Project project = projectService.getById(updatePatentProjectDTO.getId());
  390. BeanUtils.copyProperties(updatePatentProjectDTO, project);
  391. //当委托方id不为空时
  392. if (updatePatentProjectDTO.getEntrustId() != null) {
  393. project.setEntrustId(updatePatentProjectDTO.getEntrustId());
  394. } else {//若且租户类型为代理机构,并且委托方id为空,委托方名称不为空时,新增委托方
  395. ClientDTO clientDTO = new ClientDTO();
  396. clientDTO.setName(updatePatentProjectDTO.getEntrustName());
  397. clientDTO.setTenantId(personnelVO.getTenantId());
  398. try {
  399. String res = permissionService.addClient(clientDTO);
  400. JSONObject jsonObject = JSONObject.parseObject(res);
  401. Integer clientId = Integer.parseInt(jsonObject.get("data").toString());
  402. project.setEntrustId(clientId.toString());
  403. } catch (Exception e) {
  404. throw new XiaoShiException("网络异常");
  405. }
  406. }
  407. project.updateById();
  408. /**
  409. * 装载patentProject
  410. */
  411. //根据projectId查询出patentProject
  412. LambdaQueryWrapper<PatentProject> queryWrapper = new LambdaQueryWrapper<>();
  413. queryWrapper.eq(PatentProject::getProjectId, project.getId());
  414. PatentProject patentProject = this.list(queryWrapper).get(0);
  415. //装载数据
  416. patentProject.setIfUpdate(updatePatentProjectDTO.getIfUpdate());
  417. patentProject.setStatus(updatePatentProjectDTO.getStatus());
  418. patentProject.setCrons(updatePatentProjectDTO.getCrons());
  419. patentProject.updateById();
  420. //TODO 更新场景
  421. //TODO 更新事件
  422. List<AssoProjectEvent> assoProjectEvents = new ArrayList<>();
  423. LambdaQueryWrapper<AssoProjectEvent> updateEventWrapper = new LambdaQueryWrapper<>();
  424. updateEventWrapper.eq(AssoProjectEvent::getProjectId, project.getId());
  425. assoProjectEventService.remove(updateEventWrapper);
  426. List<ProjectEventDTO> events = updatePatentProjectDTO.getEvents();
  427. if (events != null && events.size() != 0) {
  428. //遍历传入的事件集合
  429. for (ProjectEventDTO projectEventDTO : events) {
  430. AssoProjectEvent assoProjectEvent = new AssoProjectEvent();
  431. //事件id和处理事项id
  432. BeanUtils.copyProperties(projectEventDTO, assoProjectEvent);
  433. //项目id
  434. assoProjectEvent.setProjectId(project.getId());
  435. //创建人
  436. assoProjectEvent.setCreateId(personnelVO.getId());
  437. //类型为专题库
  438. assoProjectEvent.setProjectType(0);
  439. assoProjectEvents.add(assoProjectEvent);
  440. }
  441. }
  442. //装载应用场景和project关联
  443. List<Integer> scenarios = updatePatentProjectDTO.getScenarioIds();
  444. if (scenarios != null && scenarios.size() > 0) {
  445. for (Integer item : scenarios) {
  446. AssoProjectEvent assoProjectEvent = new AssoProjectEvent();
  447. //项目id
  448. assoProjectEvent.setProjectId(project.getId());
  449. //创建人
  450. assoProjectEvent.setCreateId(personnelVO.getId());
  451. //类型为专题库
  452. assoProjectEvent.setProjectType(0);
  453. //装载场景id
  454. assoProjectEvent.setScenarioId(item);
  455. assoProjectEvents.add(assoProjectEvent);
  456. }
  457. }
  458. //装载处理事项和project关联
  459. List<Integer> matter = updatePatentProjectDTO.getMatterIds();
  460. if (matter != null && matter.size() > 0) {
  461. for (Integer item : matter) {
  462. AssoProjectEvent assoProjectEvent = new AssoProjectEvent();
  463. //项目id
  464. assoProjectEvent.setProjectId(project.getId());
  465. //创建人
  466. assoProjectEvent.setCreateId(personnelVO.getId());
  467. //类型为专题库
  468. assoProjectEvent.setProjectType(0);
  469. //装载处理事项id
  470. assoProjectEvent.setMatterId(item);
  471. assoProjectEvents.add(assoProjectEvent);
  472. }
  473. }
  474. //统一进行保存
  475. if (assoProjectEvents != null && assoProjectEvents.size() != 0) {
  476. assoProjectEventService.saveBatch(assoProjectEvents);
  477. }
  478. /**
  479. * 装载树结构和project关联
  480. */
  481. List<AssoProjectTreeNode> assoProjectTreeNodes = new ArrayList<>();
  482. LambdaQueryWrapper<AssoProjectTreeNode> updateTreeWrapper = new LambdaQueryWrapper<>();
  483. updateTreeWrapper.eq(AssoProjectTreeNode::getProjectId, project.getId());
  484. assoProjectTreeNodeService.remove(updateTreeWrapper);
  485. List<ProjectTreesDTO> trees = updatePatentProjectDTO.getTrees();
  486. if (trees != null && trees.size() != 0) {
  487. //遍历传入的树
  488. for (ProjectTreesDTO projectTreesDTO : trees) {
  489. List<Integer> valueIds = projectTreesDTO.getValueIds();
  490. if(valueIds==null||valueIds.size()==0){
  491. valueIds = Arrays.asList(0);
  492. }
  493. //遍历值id集合
  494. for (Integer valueId : valueIds) {
  495. AssoProjectTreeNode assoProjectTreeNode = new AssoProjectTreeNode();
  496. BeanUtils.copyProperties(projectTreesDTO, assoProjectTreeNode);
  497. //专题库、报告id
  498. assoProjectTreeNode.setProjectId(project.getId());
  499. //值id
  500. assoProjectTreeNode.setValueId(valueId);
  501. assoProjectTreeNodes.add(assoProjectTreeNode);
  502. }
  503. }
  504. if (assoProjectTreeNodes != null && assoProjectTreeNodes.size() != 0) {
  505. assoProjectTreeNodeService.saveBatch(assoProjectTreeNodes);
  506. }
  507. }
  508. //TODO 若产品或产品类别技术类别有更新,则删除产品或产品类别技术类别和专利的标引(只需判断,删除部分,待es完成)
  509. //TODO 更新关联附件
  510. /**
  511. * 装载和附件关联
  512. */
  513. List<AssoProjectFile> assoProjectFiles = new ArrayList<>();
  514. LambdaQueryWrapper<AssoProjectFile> updateFileWrapper = new LambdaQueryWrapper<>();
  515. updateFileWrapper.eq(AssoProjectFile::getProjectId, project.getId());
  516. assoProjectFileService.remove(updateFileWrapper);
  517. List<String> fileGuids = updatePatentProjectDTO.getFileGuids();
  518. if (fileGuids != null && fileGuids.size() != 0) {
  519. for (String fileGuid : fileGuids) {
  520. AssoProjectFile assoProjectFile = new AssoProjectFile();
  521. assoProjectFile.setProjectId(project.getId());
  522. assoProjectFile.setFileGuid(fileGuid);
  523. assoProjectFile.setCreateId(personnelVO.getId());
  524. assoProjectFiles.add(assoProjectFile);
  525. }
  526. if (assoProjectFiles != null && assoProjectFiles.size() != 0) {
  527. assoProjectFileService.saveBatch(assoProjectFiles);
  528. }
  529. }
  530. return project.getId();
  531. }
  532. /**
  533. * @param patentProjectVOS
  534. * @throws IOException
  535. */
  536. private void loadPatentProject(List<PatentProjectVO> patentProjectVOS) throws IOException {
  537. List<String> createIds = new ArrayList<>();
  538. List<String> departmentIds = new ArrayList<>();
  539. List<Integer> clientIds = new ArrayList<>();
  540. List<Integer> ids = new ArrayList<>();
  541. List<DepartmentVO> departmentVOS = new ArrayList<>();
  542. List<ReportCountVO> reportCountVOS = new ArrayList<>();
  543. List<Client> clients = new ArrayList<>();
  544. List<AssoProjectEvent> assoProjectEvents = new ArrayList<>();
  545. List<AssoProjectTreeNode> assoProjectTreeNodes = new ArrayList<>();
  546. List<Event> events = new ArrayList<>();
  547. List<Scenario> scenarios = new ArrayList<>();
  548. List<Matter> matters = new ArrayList<>();
  549. List<Product> products = new ArrayList<>();
  550. List<ProductCategory> productCategories = new ArrayList<>();
  551. //TODO 技术分类
  552. //获得创建人id集合
  553. patentProjectVOS.forEach(
  554. item -> {
  555. if (item.getCreateId() != null) {
  556. createIds.add(item.getCreateId());
  557. }
  558. if (item.getHeadId() != null) {
  559. createIds.add(item.getHeadId());
  560. }
  561. if (item.getId() != null) {
  562. ids.add(item.getId());
  563. }
  564. if (item.getDepartmentId() != null) {
  565. departmentIds.add(item.getDepartmentId());
  566. }
  567. if (item.getEntrustType() != null && item.getEntrustType().equals(2)) {
  568. departmentIds.add(item.getEntrustId());
  569. }
  570. if (item.getEntrustType() != null && item.getEntrustType().equals(1)) {
  571. clientIds.add(Integer.parseInt(item.getEntrustId()));
  572. }
  573. }
  574. );
  575. List<Personnel> personnels = new ArrayList<>();
  576. List<String> guids = new ArrayList<>();
  577. List<SystemFile> systemFiles = new ArrayList<>();
  578. List<AssoProjectFile> assoEventFiles = new ArrayList<>();
  579. //查询创建人名称
  580. if (createIds.size() != 0) {
  581. String res = permissionService.getPersonnelByIdsFromPCS(createIds);
  582. JSONObject jsonObject = JSONObject.parseObject(res);
  583. personnels = JSONObject.parseArray(jsonObject.getString("data"), Personnel.class);
  584. }
  585. //查询部门名称
  586. if (departmentIds.size() != 0) {
  587. String json = permissionService.getDepartmentByIdsFromPCS(departmentIds);
  588. departmentVOS = JSON.parseArray(json, DepartmentVO.class);
  589. }
  590. if (ids.size() != 0) {
  591. //根据事件id获得专利数据库文件关联表
  592. LambdaQueryWrapper<AssoProjectFile> queryWrapper = new LambdaQueryWrapper<>();
  593. queryWrapper.in(AssoProjectFile::getProjectId, ids);
  594. assoEventFiles = assoProjectFileService.list(queryWrapper);
  595. guids = assoEventFiles.stream().map(AssoProjectFile::getFileGuid).collect(Collectors.toList());
  596. //根据事件id分组查询事件关联专题库或报告数量
  597. reportCountVOS = assoProjectService.getBaseMapper().getReportCount(ids);
  598. }
  599. //查询文件
  600. if (guids.size() != 0) {
  601. String res = fileManagerService.getSystemFileFromFMS(guids);
  602. systemFiles = JSONObject.parseArray(res, SystemFile.class);
  603. }
  604. //查询客户名称
  605. if (clientIds.size() != 0) {
  606. String res = permissionService.getClientByIdsFromPCS(clientIds);
  607. JSONObject jsonObject = JSONObject.parseObject(res);
  608. clients = JSONObject.parseArray(jsonObject.getString("data"), Client.class);
  609. }
  610. //查询应用场景、调查类型、事件和专题库的关联
  611. if (ids != null && ids.size() > 0) {
  612. LambdaQueryWrapper<AssoProjectEvent> assoProjectEventQueryWrapper = new LambdaQueryWrapper<>();
  613. assoProjectEventQueryWrapper.in(AssoProjectEvent::getProjectId, ids);
  614. assoProjectEvents = assoProjectEventService.list(assoProjectEventQueryWrapper);
  615. //查询事件
  616. if (assoProjectEvents != null && assoProjectEvents.size() != 0) {
  617. scenarios = scenarioService.list();
  618. matters = matterService.list();
  619. List<Integer> eventIds = assoProjectEvents.stream().filter(item -> item.getEventId() != null).map(AssoProjectEvent::getEventId).collect(Collectors.toList());
  620. if (eventIds.size() != 0) {
  621. LambdaQueryWrapper<Event> eventQueryWrapper = new LambdaQueryWrapper<>();
  622. eventQueryWrapper.in(Event::getId, eventIds);
  623. events = eventService.list(eventQueryWrapper);
  624. }
  625. }
  626. }
  627. //查询和产品,产品分类,技术分类关联列表
  628. if (ids != null && ids.size() > 0) {
  629. LambdaQueryWrapper<AssoProjectTreeNode> assoProjectTreeNodeQueryWrapper = new LambdaQueryWrapper<>();
  630. assoProjectTreeNodeQueryWrapper.in(AssoProjectTreeNode::getProjectId, ids);
  631. assoProjectTreeNodes = assoProjectTreeNodeService.list(assoProjectTreeNodeQueryWrapper);
  632. if (assoProjectTreeNodes != null && assoProjectTreeNodes.size() > 0) {
  633. List<Integer> productIds = assoProjectTreeNodes.stream().filter(item -> item.getTreeType().equals(2)).map(AssoProjectTreeNode::getFieldId).collect(Collectors.toList());
  634. if (productIds.size() != 0) {
  635. LambdaQueryWrapper<Product> productQueryWrapper = new LambdaQueryWrapper<>();
  636. productQueryWrapper.in(Product::getId, productIds);
  637. products = productService.list(productQueryWrapper);
  638. }
  639. List<Integer> productCategoryIds = assoProjectTreeNodes.stream().filter(item -> item.getTreeType().equals(3)).map(AssoProjectTreeNode::getFieldId).collect(Collectors.toList());
  640. if (productCategoryIds.size() != 0) {
  641. LambdaQueryWrapper<ProductCategory> productCategoryQueryWrapper = new LambdaQueryWrapper<>();
  642. productCategoryQueryWrapper.in(ProductCategory::getId, productCategoryIds);
  643. productCategories = productCategoryService.list(productCategoryQueryWrapper);
  644. }
  645. }
  646. }
  647. //装载信息
  648. for (PatentProjectVO patentProjectVO : patentProjectVOS) {
  649. //装载人员信息
  650. Personnel personnel = personnels.stream().filter(item -> item.getId().equals(patentProjectVO.getCreateId())).findFirst().orElse(null);
  651. if (personnel != null) {
  652. patentProjectVO.setCreateName(personnel.getPersonnelName());
  653. }
  654. if (patentProjectVO.getHeadId() != null) {
  655. Personnel headPersonnel = personnels.stream().filter(item -> item.getId().equals(patentProjectVO.getHeadId())).findFirst().orElse(null);
  656. if (headPersonnel != null) {
  657. patentProjectVO.setHeadName(headPersonnel.getPersonnelName());
  658. }
  659. }
  660. //装载文件信息
  661. List<AssoProjectFile> assoProjectFileTemp = assoEventFiles.stream().filter(item -> item.getProjectId().equals(patentProjectVO.getId())).collect(Collectors.toList());
  662. if (assoProjectFileTemp.size() != 0) {
  663. List<String> guidTemp = assoProjectFileTemp.stream().map(AssoProjectFile::getFileGuid).collect(Collectors.toList());
  664. if (guidTemp.size() != 0) {
  665. List<SystemFile> systemFileTemp = systemFiles.stream().filter(item -> guidTemp.contains(item.getGuid())).collect(Collectors.toList());
  666. if (systemFileTemp.size() != 0) {
  667. patentProjectVO.setSystemFileList(systemFileTemp);
  668. }
  669. }
  670. }
  671. //装载报告数量
  672. if (reportCountVOS.size() != 0) {
  673. //报告数量
  674. ReportCountVO reportCountVO = reportCountVOS.stream().filter(item ->
  675. item.getProjectId().equals(patentProjectVO.getId())).findFirst().orElse(null);
  676. //设置报告数量
  677. if (reportCountVO != null) {
  678. patentProjectVO.setReportProjectNum(reportCountVO.getProjectCount());
  679. } else {
  680. patentProjectVO.setReportProjectNum(0);
  681. }
  682. } else {
  683. patentProjectVO.setReportProjectNum(0);
  684. }
  685. //装载部门
  686. if (patentProjectVO.getDepartmentId() != null) {
  687. DepartmentVO departmentVO = departmentVOS.stream().filter(item -> item.getDepartId().equals(patentProjectVO.getDepartmentId())).findFirst().orElse(null);
  688. if (departmentVO != null) {
  689. patentProjectVO.setDepartmentName(departmentVO.getDepartName());
  690. }
  691. }
  692. //裝載委托方
  693. if (patentProjectVO.getEntrustType() != null) {
  694. //当委托方为客户时
  695. if (patentProjectVO.getEntrustType().equals(1)) {
  696. Client client = clients.stream().filter(item -> item.getId().equals(Integer.parseInt(patentProjectVO.getEntrustId()))).findFirst().orElse(null);
  697. if (client != null) {
  698. patentProjectVO.setEntrustName(client.getName());
  699. }
  700. } else if (patentProjectVO.getEntrustType().equals(2)) {
  701. DepartmentVO departmentVO = departmentVOS.stream().filter(item -> item.getDepartId().equals(patentProjectVO.getEntrustId())).findFirst().orElse(null);
  702. if (departmentVO != null) {
  703. patentProjectVO.setEntrustName(departmentVO.getDepartName());
  704. }
  705. }
  706. }
  707. //装载事件 应用场景,处理事项
  708. List<Integer> eventIds = new ArrayList<>();
  709. List<Integer> matterIds = new ArrayList<>();
  710. List<Integer> scenarioIds = new ArrayList<>();
  711. List<String> eventTmpNames = new ArrayList<>();
  712. List<String> matterTmpNames = new ArrayList<>();
  713. List<String> scenarioTmpNames = new ArrayList<>();
  714. if (assoProjectEvents != null) {
  715. List<AssoProjectEvent> assoProjectEventTmps = assoProjectEvents.stream().filter(item -> item.getProjectId().equals(patentProjectVO.getId())).collect(Collectors.toList());
  716. if (assoProjectEventTmps.size() != 0) {
  717. //过滤出事件
  718. eventIds = assoProjectEventTmps.stream().filter(item -> item.getEventId() != null).map(AssoProjectEvent::getEventId).collect(Collectors.toList());
  719. matterIds = assoProjectEventTmps.stream().filter(item -> item.getMatterId() != null).map(AssoProjectEvent::getMatterId).collect(Collectors.toList());
  720. scenarioIds = assoProjectEventTmps.stream().filter(item -> item.getScenarioId() != null).map(AssoProjectEvent::getScenarioId).collect(Collectors.toList());
  721. List<Integer> eventIdsFilter = eventIds;
  722. List<Integer> matterIdsFilter = matterIds;
  723. List<Integer> scenarioIdsFilter = scenarioIds;
  724. List<Event> eventTmps = events.stream().filter(item -> eventIdsFilter.contains(item.getId())).collect(Collectors.toList());
  725. List<Matter> matterTmps = matters.stream().filter(item -> matterIdsFilter.contains(item.getId())).collect(Collectors.toList());
  726. List<Scenario> scenarioTmps = scenarios.stream().filter(item -> scenarioIdsFilter.contains(item.getId())).collect(Collectors.toList());
  727. eventTmpNames = eventTmps.stream().map(Event::getName).collect(Collectors.toList());
  728. eventIds = eventTmps.stream().map(Event::getId).collect(Collectors.toList());
  729. matterTmpNames = matterTmps.stream().map(Matter::getName).collect(Collectors.toList());
  730. matterIds = matterTmps.stream().map(Matter::getId).collect(Collectors.toList());
  731. scenarioTmpNames = scenarioTmps.stream().map(Scenario::getName).collect(Collectors.toList());
  732. scenarioIds = scenarioTmps.stream().map(Scenario::getId).collect(Collectors.toList());
  733. }
  734. }
  735. patentProjectVO.setScenarioIds(scenarioIds);
  736. patentProjectVO.setMatterIds(matterIds);
  737. patentProjectVO.setEventIds(eventIds);
  738. patentProjectVO.setScenarioNames(scenarioTmpNames);
  739. patentProjectVO.setMatterNames(matterTmpNames);
  740. patentProjectVO.setEventNames(eventTmpNames);
  741. //装载产品,产品分类,技术分类
  742. if (assoProjectTreeNodes != null) {
  743. AssoProjectTreeNode assoProjectTreeNode = assoProjectTreeNodes.stream().filter(item -> item.getProjectId().equals(patentProjectVO.getId()) && (item.getTreeType().equals(2) || item.getTreeType().equals(3))).
  744. findFirst().orElse(null);
  745. if (assoProjectTreeNode != null) {
  746. ProductOrCategoryVO productOrCategoryVO = new ProductOrCategoryVO();
  747. productOrCategoryVO.setValueIds(Arrays.asList(assoProjectTreeNode.getValueId()));
  748. if (assoProjectTreeNode.getTreeType().equals(2)) {
  749. Product product = products.stream().filter(item -> item.getId().equals(assoProjectTreeNode.getFieldId())).findFirst().orElse(null);
  750. if (product != null) {
  751. productOrCategoryVO.setName(product.getName());
  752. productOrCategoryVO.setId(product.getId());
  753. productOrCategoryVO.setType(2);
  754. patentProjectVO.setProductOrCategory(productOrCategoryVO);
  755. }
  756. } else if (assoProjectTreeNode.getTreeType().equals(3)) {
  757. ProductCategory productCategory = productCategories.stream().filter(item -> item.getId().equals(assoProjectTreeNode.getFieldId())).findFirst().orElse(null);
  758. if (productCategory != null) {
  759. productOrCategoryVO.setName(productCategory.getName());
  760. productOrCategoryVO.setId(productCategory.getId());
  761. productOrCategoryVO.setType(3);
  762. patentProjectVO.setProductOrCategory(productOrCategoryVO);
  763. }
  764. }
  765. }
  766. }
  767. }
  768. }
  769. //装载查询语句
  770. private List<String> loadSearchSql(List<String> sqls){
  771. PersonnelVO personnelVO =cacheUtils.getLoginUser(loginUtils.getId());
  772. String id =personnelVO.getId();
  773. Integer tenantId= personnelVO.getTenantId();
  774. Integer roleType = personnelVO.getRoleType();
  775. String rootSql = "";
  776. if (roleType == null || roleType.equals(0)) {
  777. rootSql ="(p.create_id ="+id+" or p.head_id="+id+" or p.id in (select project_id from asso_project_person where person_id ="+id+"))";
  778. }
  779. else if(roleType.equals(2))
  780. {
  781. rootSql="p.tenantId="+tenantId;
  782. }
  783. if (sqls.get(0) != null && !sqls.get(0).equals("") && !rootSql.equals("")) {
  784. sqls.set(0, rootSql + " and" + "(" + sqls.get(0) + ")");
  785. } else if ((sqls.get(0) == null || sqls.get(0).equals("")) && !rootSql.equals("")) {
  786. sqls.set(0, rootSql);
  787. }
  788. return sqls;
  789. }
  790. }