PatentService.java 102 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555
  1. package cn.cslg.pas.service;
  2. import cn.cslg.pas.common.core.base.Constants;
  3. import cn.cslg.pas.common.model.BaseEntity;
  4. import cn.cslg.pas.common.model.QueryPatentVO;
  5. import cn.cslg.pas.common.model.dto.PatentDTO;
  6. import cn.cslg.pas.common.model.dto.PatentQueryFieldSourceDTO;
  7. import cn.cslg.pas.common.model.dto.TaskWebSocketDTO;
  8. import cn.cslg.pas.domain.*;
  9. import cn.cslg.pas.common.model.vo.PatentExportVO;
  10. import cn.cslg.pas.common.model.vo.PatentQueryFieldSourceVO;
  11. import cn.cslg.pas.common.model.vo.PatentVO;
  12. import cn.cslg.pas.common.model.vo.TaskParams;
  13. import cn.cslg.pas.common.utils.*;
  14. import cn.cslg.pas.common.model.dto.CustomFieldDTO;
  15. import cn.cslg.pas.common.model.params.PatentCustomFieldParams;
  16. import cn.cslg.pas.common.utils.WebSocketServer;
  17. import cn.cslg.pas.mapper.PatentMapper;
  18. import cn.cslg.pas.common.utils.CacheUtils;
  19. import cn.cslg.pas.common.utils.PatentUtils;
  20. import cn.hutool.core.io.FileUtil;
  21. import cn.hutool.core.util.IdUtil;
  22. import com.alibaba.fastjson.JSON;
  23. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  24. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  25. import com.baomidou.mybatisplus.core.metadata.IPage;
  26. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  27. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  28. import lombok.RequiredArgsConstructor;
  29. import org.apache.ibatis.annotations.Param;
  30. import org.apache.poi.hssf.usermodel.*;
  31. import org.apache.poi.hssf.util.HSSFColor;
  32. import org.apache.poi.ss.usermodel.*;
  33. import org.springframework.beans.BeanUtils;
  34. import org.springframework.context.annotation.Lazy;
  35. import org.springframework.scheduling.annotation.Async;
  36. import org.springframework.stereotype.Service;
  37. import java.io.FileOutputStream;
  38. import java.util.*;
  39. import java.util.stream.Collectors;
  40. /**
  41. * <p>
  42. * 专利信息表 服务实现类
  43. * </p>
  44. *
  45. * @author 王岩
  46. * @since 2021-12-26
  47. */
  48. @Service
  49. @RequiredArgsConstructor(onConstructor_ = {@Lazy})
  50. public class PatentService extends ServiceImpl<PatentMapper, Patent> {
  51. private final PatentMapper patentMapper;
  52. private final PatentApplicantService patentApplicantService;
  53. private final PatentApplicantLinkService applicantAttributeService;
  54. private final ProjectPatentLinkService projectPatentLinkService;
  55. private final CustomAnalysisItemSourceService customAnalysisItemSourceService;
  56. private final CacheUtils cacheUtils;
  57. private final DataAnalysisService dataAnalysisService;
  58. private final PatentAffairService patentAffairService;
  59. private final ProjectFieldTreeService projectFieldTreeService;
  60. private final ProjectFieldOptionService projectFieldOptionService;
  61. private final PatentLabelService patentLabelService;
  62. private final ProjectFieldTextService projectFieldTextService;
  63. private final PatentFieldService patentFieldService;
  64. private final ProjectFieldService projectFieldService;
  65. private final TaskService taskService;
  66. private final FileUtils fileUtils;
  67. private final PatentImageService patentImageService;
  68. private final PatentInventorService patentInventorService;
  69. private final PatentAgencyService patentAgencyService;
  70. private final PatentAgentService patentAgentService;
  71. private final ProjectFolderPatentLinkService projectFolderPatentLinkService;
  72. private final PatentApplicantMergeLinkService patentApplicantMergeLinkService;
  73. private final AreaService areaService;
  74. private final PatentClassNumberService patentClassNumberService;
  75. private final PatentClassNumberLinkService patentClassNumberLinkService;
  76. private final ProjectFieldPatentLinkService projectFieldPatentLinkService;
  77. private final PatentInstructionService patentInstructionService;
  78. private final PatentSimpleFamilyService patentSimpleFamilyService;
  79. private final SystemDictService systemDictService;
  80. private final PatentSimpleFamilyLinkService patentSimpleFamilyLinkService;
  81. private final PatentRightService patentRightService;
  82. private final PatentInstructionTextService patentInstructionTextService;
  83. private final PatentLicensorService patentLicensorService;
  84. private final PatentPledgeService patentPledgeService;
  85. private final PatentInventorMergeService patentInventorMergeService;
  86. public List<Patent> getPatentListByIds(List<Integer> ids) {
  87. if (ids == null || ids.size() == 0) {
  88. return new ArrayList<>();
  89. }
  90. LambdaQueryWrapper<Patent> queryWrapper = new LambdaQueryWrapper<>();
  91. queryWrapper.in(Patent::getId, ids);
  92. return this.list(queryWrapper);
  93. }
  94. public List<Patent> getPatentListByPatentNo(List<String> patentNo) {
  95. if (patentNo == null || patentNo.size() == 0) {
  96. return new ArrayList<>();
  97. }
  98. LambdaQueryWrapper<Patent> queryWrapper = new LambdaQueryWrapper<>();
  99. queryWrapper.in(Patent::getPatentNo, patentNo);
  100. return this.list(queryWrapper);
  101. }
  102. public Patent getByPatentNo(String patentNo) {
  103. LambdaQueryWrapper<Patent> queryWrapper = new LambdaQueryWrapper<>();
  104. queryWrapper.eq(Patent::getPatentNo, patentNo);
  105. return this.getOne(queryWrapper);
  106. }
  107. public List<Patent> getPublicDateAndPatentNoByPatentNo(List<String> patentNo) {
  108. LambdaQueryWrapper<Patent> queryWrapper = new LambdaQueryWrapper<>();
  109. queryWrapper.select(Patent::getPublicDate, Patent::getPatentNo, Patent::getId, Patent::getPublicNo
  110. , Patent::getSimpleFamily, Patent::getInpadocFamily, Patent::getPatSnapFamily);
  111. queryWrapper.in(Patent::getPatentNo, patentNo);
  112. queryWrapper.last(" order by appdate, patentno");
  113. return this.list(queryWrapper);
  114. }
  115. public List<Patent> getPatentIdAndPatentNoByIds(List<Integer> ids) {
  116. if (ids == null || ids.size() == 0) {
  117. return new ArrayList<>();
  118. }
  119. LambdaQueryWrapper<Patent> queryWrapper = new LambdaQueryWrapper<>();
  120. queryWrapper.select(Patent::getPatentNo, Patent::getId);
  121. queryWrapper.in(Patent::getId, ids);
  122. return this.list(queryWrapper);
  123. }
  124. public Date getDateTime(String ids, Integer fieldId, String type) {
  125. String column = "";
  126. switch (fieldId) {
  127. case 25:
  128. column = "appdate";
  129. break;
  130. case 26:
  131. column = "publicdate";
  132. break;
  133. case 27:
  134. column = "publictodate";
  135. break;
  136. default:
  137. return new Date(baseMapper.getDateTime2(ids, fieldId, type) * 1000L);
  138. }
  139. return new Date(baseMapper.getDateTime(ids, column, type) * 1000L);
  140. }
  141. public String getPatentNumberTypeCount(Integer projectId, String id, Integer field, CustomAnalysisItemSource source) {
  142. QueryWrapper<Patent> queryWrapper = new QueryWrapper<>();
  143. List<Integer> ids = StringUtils.changeStringToInteger(id, ",");
  144. String column = "";
  145. List<String> options = Arrays.asList(">", ">=", "<", "<=");
  146. if (ids.size() == 0) {
  147. return null;
  148. }
  149. Integer mino = source.getMin().getOperator();
  150. Integer maxo = source.getMax().getOperator();
  151. Integer minv = source.getMin().getValue();
  152. Integer maxv = source.getMax().getValue();
  153. queryWrapper.lambda().in(Patent::getId, ids);
  154. switch (field) {
  155. case 32:
  156. column = "quoteno";
  157. break;
  158. case 33:
  159. column = "quotedno";
  160. break;
  161. case 34:
  162. column = "inpadocfamilynum";
  163. break;
  164. case 35:
  165. column = "simplefamilynum";
  166. break;
  167. case 55:
  168. column = "patsnapfamilynum";
  169. break;
  170. case 38:
  171. column = "num2";
  172. break;
  173. case 39:
  174. column = "num3";
  175. break;
  176. default:
  177. List<Integer> patentIds = baseMapper.getCustomFieldCount(ids, field, options.get(mino), options.get(maxo), minv, maxv);
  178. return StringUtils.join(patentIds.stream().distinct().collect(Collectors.toList()), ",");
  179. }
  180. if (mino.equals(0)) {
  181. queryWrapper.gt(column, minv);
  182. } else {
  183. queryWrapper.ge(column, minv);
  184. }
  185. if (maxo.equals(2)) {
  186. queryWrapper.lt(column, maxv);
  187. } else {
  188. queryWrapper.le(column, maxv);
  189. }
  190. List<Patent> patentList = this.list(queryWrapper);
  191. return StringUtils.join(patentList.stream().map(Patent::getId).distinct().collect(Collectors.toList()), ",");
  192. }
  193. public String getPatentDateTime2(Integer projectId, Integer field, Long startDate, Long endDate, String id) {
  194. LambdaQueryWrapper<Patent> queryWrapper = new LambdaQueryWrapper<>();
  195. List<Integer> ids = StringUtils.changeStringToInteger(id, ",");
  196. if (ids.size() == 0) {
  197. return null;
  198. }
  199. queryWrapper.in(Patent::getId, ids);
  200. switch (field) {
  201. case 25:
  202. queryWrapper.between(Patent::getApplicationDate, startDate, endDate);
  203. break;
  204. case 26:
  205. queryWrapper.between(Patent::getPublicDate, startDate, endDate);
  206. break;
  207. case 27:
  208. queryWrapper.between(Patent::getPublicAccreditDate, startDate, endDate);
  209. break;
  210. default:
  211. List<Integer> patentIds = baseMapper.getCustomFieldTime(ids, field, startDate, endDate);
  212. return StringUtils.join(patentIds.stream().distinct().collect(Collectors.toList()), ",");
  213. }
  214. List<Patent> patentList = this.list(queryWrapper);
  215. return StringUtils.join(patentList.stream().map(BaseEntity::getId).distinct().collect(Collectors.toList()), ",");
  216. }
  217. private void setQueryPatentParams(PatentVO params) {
  218. params.setSelfField(new ArrayList<>());
  219. List<String> customIds = new ArrayList<>();
  220. List<String> notInIds =new ArrayList<>();
  221. params.setCids(new ArrayList<>());
  222. if (StringUtils.isNotEmpty(params.getName())) {
  223. params.setNameSql(PatentUtils.formatTextQuerySql(params.getName(), "a.name"));
  224. }
  225. if (StringUtils.isNotEmpty(params.getAbstractStr())) {
  226. params.setAbstractStrSql(PatentUtils.formatTextQuerySql(params.getAbstractStr(), "a.abstract"));
  227. }
  228. if (StringUtils.isNotEmpty(params.getPublicNo())) {
  229. params.setPublicNoSql(PatentUtils.formatTextQuerySql(params.getPublicNo(), "a.publicno"));
  230. }
  231. if (StringUtils.isNotEmpty(params.getApplicationNo())) {
  232. params.setApplicationNoSql(PatentUtils.formatTextQuerySql(params.getApplicationNo(), "a.applicationno"));
  233. }
  234. if (StringUtils.isNotEmpty(params.getRightContent())) {
  235. params.setRightContentSql(PatentUtils.formatTextQuerySql(params.getRightContent(), "content"));
  236. }
  237. for (int i = 0; i < params.getField().size(); i++) {
  238. List<String> queryList = params.getField().get(i).getValue();
  239. String key = params.getField().get(i).getKey();
  240. List<Integer> field = StringUtils.changeStringToInteger(key, "-");
  241. if (queryList.size() == 0) {
  242. continue;
  243. }
  244. String fieldType = params.getField().get(i).getType();
  245. switch (key) {
  246. case "13":
  247. case "15":
  248. case "16":
  249. case "17":
  250. if (field.get(0) == 13) {
  251. params.setQueryClassNumberIpc(true);
  252. params.setWhereClassNumberIpc(queryList);
  253. params.setQueryClassNumberIpcMethod(params.getField().get(i).getClassId());
  254. }
  255. if (field.get(0) == 15) {
  256. params.setQueryClassNumberCpc(true);
  257. params.setWhereClassNumberCpc(queryList);
  258. params.setQueryClassNumberCpcMethod(params.getField().get(i).getClassId());
  259. }
  260. if (field.get(0) == 17) {
  261. params.setQueryClassNumberUpc(true);
  262. params.setWhereClassNumberUpc(queryList);
  263. params.setQueryClassNumberUpcMethod(params.getField().get(i).getClassId());
  264. }
  265. if (field.get(0) == 16) {
  266. params.setQueryClassNumberLoc(true);
  267. params.setWhereClassNumberLoc(queryList);
  268. params.setQueryClassNumberLocMethod(params.getField().get(i).getClassId());
  269. }
  270. break;
  271. case "18-6":
  272. params.setQueryApplicantOriginal(true);
  273. params.setWhereApplicantOriginal(queryList);
  274. break;
  275. case "19-6":
  276. params.setQueryApplicantCurrent(true);
  277. params.setWhereApplicantCurrent(queryList);
  278. break;
  279. case "20-0":
  280. params.setQueryInventor(true);
  281. params.setWhereInventor(queryList);
  282. break;
  283. case "20-1":
  284. params.setQueryInventor(true);
  285. params.setQueryInventorMerge(true);
  286. params.setWhereInventorMerge(queryList);
  287. break;
  288. case "18-7":
  289. params.setQueryApplicantOriginalStandard(true);
  290. params.setWhereApplicantOriginalStandard(queryList);
  291. break;
  292. case "19-7":
  293. params.setQueryApplicantCurrentStandard(true);
  294. params.setWhereApplicantCurrentStandard(queryList);
  295. break;
  296. case "18-8":
  297. params.setQueryApplicantOriginal(true);
  298. params.setQueryApplicantOriginalMerge(true);
  299. params.setWhereApplicantOriginalMerge(queryList);
  300. break;
  301. case "19-8":
  302. params.setQueryApplicantCurrent(true);
  303. params.setQueryApplicantCurrentMerge(true);
  304. params.setWhereApplicantCurrentMerge(queryList);
  305. break;
  306. case "28-0":
  307. params.setQueryBureau(true);
  308. params.setWhereBureau(queryList);
  309. break;
  310. case "37-0":
  311. params.setQueryType(true);
  312. params.setWhereType(queryList);
  313. break;
  314. case "36-0":
  315. params.setQueryStatus(true);
  316. params.setWhereStatus(queryList);
  317. break;
  318. case "25-12":
  319. params.setQueryAppDate(true);
  320. params.setWhereAppDate(queryList);
  321. break;
  322. case "26-12":
  323. params.setQueryPublicDate(true);
  324. params.setWherePublicDate(queryList);
  325. break;
  326. case "29-17":
  327. params.setQueryApplicantAddress(true);
  328. params.setQueryCountry(true);
  329. params.setWhereCountry(queryList);
  330. break;
  331. case "29-18":
  332. params.setQueryApplicantAddress(true);
  333. params.setQueryApplicantProvince(true);
  334. params.setWhereApplicantProvince(queryList);
  335. break;
  336. case "40-0":
  337. params.setQueryAffair(true);
  338. StringBuilder str = new StringBuilder();
  339. for (String s : queryList) {
  340. str.append(s).append("|");
  341. }
  342. params.setWhereAffair(str.substring(0, str.length() - 1));
  343. break;
  344. case "54-0":
  345. params.setQueryLabel(true);
  346. params.setWhereLabel(queryList);
  347. break;
  348. default:
  349. //判断值里面是否含空
  350. params.getField().get(i).setIsNull(queryList.stream().anyMatch(item -> item.equals("null")));
  351. params.getSelfField().add(params.getField().get(i));
  352. customIds.add(String.valueOf(field.get(0)));
  353. if(params.getField().get(i).getIsNull()==null||!params.getField().get(i).getIsNull()){
  354. params.getCids().add(field.get(0));
  355. }
  356. else if(params.getField().get(i).getIsNull()&&queryList.size()==1){
  357. notInIds.add(String.valueOf(field.get(0)));
  358. }
  359. }
  360. }
  361. if (customIds.size() != 0) {
  362. params.setCustomIds(customIds);
  363. }
  364. params.getField().forEach(item->{
  365. List<String> temIds =new ArrayList<>(notInIds);
  366. temIds.remove(item.getKey());
  367. item.setNotInIds(temIds);
  368. });
  369. }
  370. public List<Integer> getPatentListIds(PatentVO params) {
  371. this.setQueryFamilyParams(params);
  372. params.setSelected(new ArrayList<>());
  373. List<Integer> ids = this.getQueryPatentIds(params);
  374. return ids.stream().skip(params.getStartNumber() - 1).limit(params.getEndNumber() - params.getStartNumber() + 1).collect(Collectors.toList());
  375. }
  376. private void setQueryFamilyParams(PatentVO params) {
  377. switch (params.getFamily()) {
  378. case 0:
  379. params.setQuerySimpleFamily(false);
  380. params.setQueryInpadocFamily(false);
  381. params.setQueryPatSnapFamily(false);
  382. break;
  383. case 1:
  384. params.setQuerySimpleFamily(true);
  385. params.setQueryInpadocFamily(false);
  386. params.setQueryPatSnapFamily(false);
  387. break;
  388. case 2:
  389. params.setQuerySimpleFamily(false);
  390. params.setQueryInpadocFamily(true);
  391. params.setQueryPatSnapFamily(false);
  392. break;
  393. case 3:
  394. params.setQuerySimpleFamily(false);
  395. params.setQueryInpadocFamily(false);
  396. params.setQueryPatSnapFamily(true);
  397. break;
  398. }
  399. }
  400. public IPage<PatentDTO> getPageList(PatentVO params) {
  401. this.setQueryFamilyParams(params);
  402. this.setQueryPatentParams(params);
  403. IPage<Patent> dataPage = baseMapper.getPageList(new Page<>(params.getCurrent(), params.getSize()), params);
  404. IPage<PatentDTO> pageList = new Page<>();
  405. List<PatentDTO> records = new ArrayList<>();
  406. List<Integer> patentIds = dataPage.getRecords().stream().map(Patent::getId).collect(Collectors.toList());
  407. List<PatentApplicant> patentApplicantList = patentApplicantService.getPatentApplicantByPatentIds(patentIds);
  408. List<PatentInventor> patentInventorList = patentInventorService.getPatentInventorByPatentIds(patentIds);
  409. List<PatentLabel> patentLabelList = patentLabelService.getPatentLabelByPatentIdsAndProjectId(patentIds, params.getProjectId());
  410. List<PatentClassNumberLink> patentClassNumberLinkList = patentClassNumberLinkService.getPatentClassNumberLinkByPatentIds(patentIds);
  411. List<PatentAgent> patentAgentList = patentAgentService.getPatentAgentByPatentIds(patentIds);
  412. List<PatentAgency> patentAgencyList = patentAgencyService.getPatentAgencyByIds(dataPage.getRecords().stream().filter(item -> StringUtils.isNotEmpty(item.getAgencyId())).map(item -> Integer.parseInt(item.getAgencyId())).distinct().collect(Collectors.toList()));
  413. List<PatentSimpleFamilyLink> patentSimpleFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.getRecords().stream().map(Patent::getSimpleFamily).collect(Collectors.toList()));
  414. List<PatentSimpleFamilyLink> patentInpadocFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.getRecords().stream().map(Patent::getInpadocFamily).collect(Collectors.toList()));
  415. List<PatentSimpleFamilyLink> patentPatSnapFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.getRecords().stream().map(Patent::getPatSnapFamily).collect(Collectors.toList()));
  416. List<SystemDict> systemDictList = systemDictService.getSystemDictListByType(Arrays.asList(Constants.PATENT_TYPE, Constants.PATENT_SIMPLE_STATUS));
  417. //获得所有的自定义字段信息
  418. Map<Integer,List<PatentDTO.Field>> map =projectFieldService.getPatentFieldByPatentIdAndProjectId2(params.getProjectId(),patentIds);
  419. dataPage.getRecords().forEach(item -> {
  420. PatentDTO patentDTO = new PatentDTO();
  421. BeanUtils.copyProperties(item, patentDTO);
  422. patentDTO.setApplicationDate(DateUtils.formatDate(item.getApplicationDate(), DateUtils.YYYY_MM_DD));
  423. patentDTO.setPriorityDate(DateUtils.formatDate(item.getPriorityDate(), DateUtils.YYYY_MM_DD));
  424. patentDTO.setPublicDate(DateUtils.formatDate(item.getPublicDate(), DateUtils.YYYY_MM_DD));
  425. patentDTO.setPublicAccreditDate(DateUtils.formatDate(item.getPublicAccreditDate(), DateUtils.YYYY_MM_DD));
  426. patentDTO.setFirstPublicDate(DateUtils.formatDate(item.getFirstPublicDate(), DateUtils.YYYY_MM_DD));
  427. patentDTO.setSimpleStatus(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.PATENT_SIMPLE_STATUS) && systemDict.getValue().equals(String.valueOf(item.getSimpleStatus()))).findFirst().orElse(new SystemDict()).getLabel());
  428. patentDTO.setType(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.PATENT_TYPE) && systemDict.getValue().equals(String.valueOf(item.getType()))).findFirst().orElse(new SystemDict()).getLabel());
  429. patentDTO.setApplicant(patentApplicantList.stream().filter(patentApplicant -> patentApplicant.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  430. patentDTO.setInventor(patentInventorList.stream().filter(patentInventor -> patentInventor.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  431. patentDTO.setLabel(patentLabelList.stream().filter(patentLabel -> patentLabel.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  432. patentDTO.setIpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getPatentId().equals(item.getId()) && patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_IPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  433. patentDTO.setCpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getPatentId().equals(item.getId()) && patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_CPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  434. patentDTO.setUpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getPatentId().equals(item.getId()) && patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_UPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  435. patentDTO.setLocList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getPatentId().equals(item.getId()) && patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_LOC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  436. if (StringUtils.isNotEmpty(item.getAgencyId())) {
  437. patentDTO.setAgency(patentAgencyList.stream().filter(patentAgency -> patentAgency.getId().equals(Integer.parseInt(item.getAgencyId()))).findFirst().orElse(null));
  438. }
  439. PatentDTO.PatentFamily patentFamily = new PatentDTO.PatentFamily();
  440. patentFamily.setSimple(patentSimpleFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getSimpleFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  441. patentFamily.setInpadoc(patentInpadocFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getInpadocFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  442. patentFamily.setPatSnap(patentPatSnapFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getPatSnapFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  443. patentDTO.setFamily(patentFamily);
  444. patentDTO.setAgent(patentAgentList.stream().filter(patentAgent -> patentAgent.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  445. // TODO 性能优化
  446. patentDTO.setField(map.get(item.getId()));
  447. records.add(patentDTO);
  448. });
  449. pageList.setTotal(dataPage.getTotal());
  450. pageList.setRecords(records);
  451. pageList.setPages(dataPage.getPages());
  452. pageList.setSize(dataPage.getSize());
  453. pageList.setCurrent(dataPage.getCurrent());
  454. return pageList;
  455. }
  456. public IPage<PatentDTO> getPageListForRMS(QueryPatentVO params) {
  457. if(params.getObligeeName()!=null) {
  458. String obligeeName = params.getObligeeName().replace("(", "\\(");
  459. obligeeName = obligeeName.replace(")", "\\)");
  460. params.setObligeeName(obligeeName);
  461. }
  462. if(params.getApplicationName()!=null) {
  463. String applicationName =params.getApplicationName().replace("(","\\(");
  464. applicationName =applicationName.replace(")","\\)");
  465. params.setApplicationName(applicationName);}
  466. IPage<Patent> dataPage = baseMapper.getPageListForRMS2(new Page<>(params.getCurrent(), params.getSize()),params);
  467. IPage<PatentDTO> pageList = new Page<>();
  468. List<PatentDTO> records = new ArrayList<>();
  469. List<Integer> patentIds = dataPage.getRecords().stream().map(Patent::getId).collect(Collectors.toList());
  470. List<PatentApplicant> patentApplicantList = patentApplicantService.getPatentApplicantByPatentIds(patentIds);
  471. List<PatentInventor> patentInventorList = patentInventorService.getPatentInventorByPatentIds(patentIds);
  472. List<PatentLabel> patentLabelList = patentLabelService.getPatentLabelByPatentIdsAndProjectId(patentIds, params.getProjectId());
  473. List<PatentClassNumberLink> patentClassNumberLinkList = patentClassNumberLinkService.getPatentClassNumberLinkByPatentIds(patentIds);
  474. List<PatentAgent> patentAgentList = patentAgentService.getPatentAgentByPatentIds(patentIds);
  475. List<PatentAgency> patentAgencyList = patentAgencyService.getPatentAgencyByIds(dataPage.getRecords().stream().filter(item -> StringUtils.isNotEmpty(item.getAgencyId())).map(item -> Integer.parseInt(item.getAgencyId())).distinct().collect(Collectors.toList()));
  476. List<PatentSimpleFamilyLink> patentSimpleFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.getRecords().stream().map(Patent::getSimpleFamily).collect(Collectors.toList()));
  477. List<PatentSimpleFamilyLink> patentInpadocFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.getRecords().stream().map(Patent::getInpadocFamily).collect(Collectors.toList()));
  478. List<PatentSimpleFamilyLink> patentPatSnapFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.getRecords().stream().map(Patent::getPatSnapFamily).collect(Collectors.toList()));
  479. List<SystemDict> systemDictList = systemDictService.getSystemDictListByType(Arrays.asList(Constants.PATENT_TYPE, Constants.PATENT_SIMPLE_STATUS));
  480. dataPage.getRecords().forEach(item -> {
  481. PatentDTO patentDTO = new PatentDTO();
  482. BeanUtils.copyProperties(item, patentDTO);
  483. patentDTO.setApplicationDate(DateUtils.formatDate(item.getApplicationDate(), DateUtils.YYYY_MM_DD));
  484. patentDTO.setPriorityDate(DateUtils.formatDate(item.getPriorityDate(), DateUtils.YYYY_MM_DD));
  485. patentDTO.setPublicDate(DateUtils.formatDate(item.getPublicDate(), DateUtils.YYYY_MM_DD));
  486. patentDTO.setPublicAccreditDate(DateUtils.formatDate(item.getPublicAccreditDate(), DateUtils.YYYY_MM_DD));
  487. patentDTO.setFirstPublicDate(DateUtils.formatDate(item.getFirstPublicDate(), DateUtils.YYYY_MM_DD));
  488. patentDTO.setSimpleStatus(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.PATENT_SIMPLE_STATUS) && systemDict.getValue().equals(String.valueOf(item.getSimpleStatus()))).findFirst().orElse(new SystemDict()).getLabel());
  489. patentDTO.setType(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.PATENT_TYPE) && systemDict.getValue().equals(String.valueOf(item.getType()))).findFirst().orElse(new SystemDict()).getLabel());
  490. patentDTO.setApplicant(patentApplicantList.stream().filter(patentApplicant -> patentApplicant.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  491. patentDTO.setInventor(patentInventorList.stream().filter(patentInventor -> patentInventor.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  492. patentDTO.setLabel(patentLabelList.stream().filter(patentLabel -> patentLabel.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  493. patentDTO.setIpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getPatentId().equals(item.getId()) && patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_IPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  494. patentDTO.setCpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getPatentId().equals(item.getId()) && patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_CPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  495. patentDTO.setUpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getPatentId().equals(item.getId()) && patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_UPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  496. patentDTO.setLocList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getPatentId().equals(item.getId()) && patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_LOC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  497. patentDTO.setAffair(patentAffairService.getPatentAffairByPatentId(item.getId()));
  498. if (StringUtils.isNotEmpty(item.getAgencyId())) {
  499. patentDTO.setAgency(patentAgencyList.stream().filter(patentAgency -> patentAgency.getId().equals(Integer.parseInt(item.getAgencyId()))).findFirst().orElse(null));
  500. }
  501. PatentDTO.PatentFamily patentFamily = new PatentDTO.PatentFamily();
  502. patentFamily.setSimple(patentSimpleFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getSimpleFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  503. patentFamily.setInpadoc(patentInpadocFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getInpadocFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  504. patentFamily.setPatSnap(patentPatSnapFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getPatSnapFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  505. patentDTO.setFamily(patentFamily);
  506. patentDTO.setAgent(patentAgentList.stream().filter(patentAgent -> patentAgent.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  507. // TODO 性能优化
  508. patentDTO.setField(projectFieldService.getPatentFieldByPatentIdAndProjectId(params.getProjectId(), item.getId()));
  509. records.add(patentDTO);
  510. });
  511. pageList.setTotal(dataPage.getTotal());
  512. pageList.setRecords(records);
  513. pageList.setPages(dataPage.getPages());
  514. pageList.setSize(dataPage.getSize());
  515. pageList.setCurrent(dataPage.getCurrent());
  516. return pageList;
  517. }
  518. public List<PatentDTO> getPatentDTOListForRMS(PatentVO params) {
  519. List<PatentDTO> records = new ArrayList<>();
  520. if(params.getPatentNos()==null||params.getPatentNos().size()==0){
  521. return records;
  522. }
  523. List<Patent> dataPage = baseMapper.getPatent(params.getPatentNos(),-1,-1);
  524. List<Integer> patentIds = dataPage.stream().map(Patent::getId).collect(Collectors.toList());
  525. List<PatentApplicant> patentApplicantList = patentApplicantService.getPatentApplicantByPatentIds(patentIds);
  526. List<PatentInventor> patentInventorList = patentInventorService.getPatentInventorByPatentIds(patentIds);
  527. List<PatentClassNumberLink> patentClassNumberLinkList = patentClassNumberLinkService.getPatentClassNumberLinkByPatentIds(patentIds);
  528. List<PatentAgent> patentAgentList = patentAgentService.getPatentAgentByPatentIds(patentIds);
  529. List<PatentAgency> patentAgencyList = patentAgencyService.getPatentAgencyByIds(dataPage.stream().filter(item -> StringUtils.isNotEmpty(item.getAgencyId())).map(item -> Integer.parseInt(item.getAgencyId())).distinct().collect(Collectors.toList()));
  530. List<PatentSimpleFamilyLink> patentSimpleFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.stream().map(Patent::getSimpleFamily).collect(Collectors.toList()));
  531. List<PatentSimpleFamilyLink> patentInpadocFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.stream().map(Patent::getInpadocFamily).collect(Collectors.toList()));
  532. List<PatentSimpleFamilyLink> patentPatSnapFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.stream().map(Patent::getPatSnapFamily).collect(Collectors.toList()));
  533. List<SystemDict> systemDictList = systemDictService.getSystemDictListByType(Arrays.asList(Constants.PATENT_TYPE, Constants.PATENT_SIMPLE_STATUS));
  534. dataPage.forEach(item -> {
  535. PatentDTO patentDTO = new PatentDTO();
  536. BeanUtils.copyProperties(item, patentDTO);
  537. patentDTO.setApplicationDate(DateUtils.formatDate(item.getApplicationDate(), DateUtils.YYYY_MM_DD));
  538. patentDTO.setPriorityDate(DateUtils.formatDate(item.getPriorityDate(), DateUtils.YYYY_MM_DD));
  539. patentDTO.setPublicDate(DateUtils.formatDate(item.getPublicDate(), DateUtils.YYYY_MM_DD));
  540. patentDTO.setPublicAccreditDate(DateUtils.formatDate(item.getPublicAccreditDate(), DateUtils.YYYY_MM_DD));
  541. patentDTO.setFirstPublicDate(DateUtils.formatDate(item.getFirstPublicDate(), DateUtils.YYYY_MM_DD));
  542. patentDTO.setSimpleStatus(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.PATENT_SIMPLE_STATUS) && systemDict.getValue().equals(String.valueOf(item.getSimpleStatus()))).findFirst().orElse(new SystemDict()).getLabel());
  543. patentDTO.setSimpleStatusInt(item.getSimpleStatus());
  544. patentDTO.setType(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.PATENT_TYPE) && systemDict.getValue().equals(String.valueOf(item.getType()))).findFirst().orElse(new SystemDict()).getLabel());
  545. patentDTO.setApplicant(patentApplicantList.stream().filter(patentApplicant -> patentApplicant.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  546. patentDTO.setInventor(patentInventorList.stream().filter(patentInventor -> patentInventor.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  547. patentDTO.setIpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getPatentId().equals(item.getId()) && patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_IPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  548. patentDTO.setCpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getPatentId().equals(item.getId()) && patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_CPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  549. patentDTO.setUpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getPatentId().equals(item.getId()) && patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_UPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  550. patentDTO.setLocList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getPatentId().equals(item.getId()) && patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_LOC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  551. if (StringUtils.isNotEmpty(item.getAgencyId())) {
  552. patentDTO.setAgency(patentAgencyList.stream().filter(patentAgency -> patentAgency.getId().equals(Integer.parseInt(item.getAgencyId()))).findFirst().orElse(null));
  553. }
  554. PatentDTO.PatentFamily patentFamily = new PatentDTO.PatentFamily();
  555. patentFamily.setSimple(patentSimpleFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getSimpleFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  556. patentFamily.setInpadoc(patentInpadocFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getInpadocFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  557. patentFamily.setPatSnap(patentPatSnapFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getPatSnapFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  558. patentDTO.setFamily(patentFamily);
  559. patentDTO.setAffair(patentAffairService.getPatentAffairByPatentId(item.getId()));
  560. patentDTO.setAgent(patentAgentList.stream().filter(patentAgent -> patentAgent.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  561. // TODO 性能优化
  562. records.add(patentDTO);
  563. });
  564. return records;
  565. }
  566. //查询对比文件信息
  567. public List<PatentDTO> getRmsComparePatent(PatentVO params) {
  568. List<Patent> dataPage = baseMapper.getPatent(params.getPatentNos(),-1,-1);
  569. List<PatentDTO> records = new ArrayList<>();
  570. List<Integer> patentIds = dataPage.stream().map(Patent::getId).collect(Collectors.toList());
  571. List<PatentApplicant> patentApplicantList = patentApplicantService.getPatentApplicantByPatentIds(patentIds);
  572. List<PatentInventor> patentInventorList = patentInventorService.getPatentInventorByPatentIds(patentIds);
  573. List<PatentClassNumberLink> patentClassNumberLinkList = patentClassNumberLinkService.getPatentClassNumberLinkByPatentIds(patentIds);
  574. List<PatentAgent> patentAgentList = patentAgentService.getPatentAgentByPatentIds(patentIds);
  575. List<PatentAgency> patentAgencyList = patentAgencyService.getPatentAgencyByIds(dataPage.stream().filter(item -> StringUtils.isNotEmpty(item.getAgencyId())).map(item -> Integer.parseInt(item.getAgencyId())).distinct().collect(Collectors.toList()));
  576. List<PatentSimpleFamilyLink> patentSimpleFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.stream().map(Patent::getSimpleFamily).collect(Collectors.toList()));
  577. List<PatentSimpleFamilyLink> patentInpadocFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.stream().map(Patent::getInpadocFamily).collect(Collectors.toList()));
  578. List<PatentSimpleFamilyLink> patentPatSnapFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.stream().map(Patent::getPatSnapFamily).collect(Collectors.toList()));
  579. List<SystemDict> systemDictList = systemDictService.getSystemDictListByType(Arrays.asList(Constants.PATENT_TYPE, Constants.PATENT_SIMPLE_STATUS));
  580. dataPage.forEach(item -> {
  581. PatentDTO patentDTO = new PatentDTO();
  582. BeanUtils.copyProperties(item, patentDTO);
  583. patentDTO.setApplicationDate(DateUtils.formatDate(item.getApplicationDate(), DateUtils.YYYY_MM_DD));
  584. patentDTO.setPriorityDate(DateUtils.formatDate(item.getPriorityDate(), DateUtils.YYYY_MM_DD));
  585. patentDTO.setPublicDate(DateUtils.formatDate(item.getPublicDate(), DateUtils.YYYY_MM_DD));
  586. patentDTO.setPublicAccreditDate(DateUtils.formatDate(item.getPublicAccreditDate(), DateUtils.YYYY_MM_DD));
  587. patentDTO.setFirstPublicDate(DateUtils.formatDate(item.getFirstPublicDate(), DateUtils.YYYY_MM_DD));
  588. patentDTO.setSimpleStatus(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.PATENT_SIMPLE_STATUS) && systemDict.getValue().equals(String.valueOf(item.getSimpleStatus()))).findFirst().orElse(new SystemDict()).getLabel());
  589. patentDTO.setSimpleStatusInt(item.getSimpleStatus());
  590. patentDTO.setType(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.PATENT_TYPE) && systemDict.getValue().equals(String.valueOf(item.getType()))).findFirst().orElse(new SystemDict()).getLabel());
  591. patentDTO.setApplicant(patentApplicantList.stream().filter(patentApplicant -> patentApplicant.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  592. patentDTO.setInventor(patentInventorList.stream().filter(patentInventor -> patentInventor.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  593. patentDTO.setIpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getPatentId().equals(item.getId()) && patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_IPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  594. patentDTO.setCpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getPatentId().equals(item.getId()) && patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_CPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  595. patentDTO.setUpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getPatentId().equals(item.getId()) && patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_UPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  596. patentDTO.setLocList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getPatentId().equals(item.getId()) && patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_LOC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  597. if (StringUtils.isNotEmpty(item.getAgencyId())) {
  598. patentDTO.setAgency(patentAgencyList.stream().filter(patentAgency -> patentAgency.getId().equals(Integer.parseInt(item.getAgencyId()))).findFirst().orElse(null));
  599. }
  600. PatentDTO.PatentFamily patentFamily = new PatentDTO.PatentFamily();
  601. patentFamily.setSimple(patentSimpleFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getSimpleFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  602. patentFamily.setInpadoc(patentInpadocFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getInpadocFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  603. patentFamily.setPatSnap(patentPatSnapFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getPatSnapFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  604. patentDTO.setFamily(patentFamily);
  605. patentDTO.setAffair(patentAffairService.getPatentAffairByPatentId(item.getId()));
  606. patentDTO.setAgent(patentAgentList.stream().filter(patentAgent -> patentAgent.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  607. // TODO 性能优化
  608. records.add(patentDTO);
  609. });
  610. return records;
  611. }
  612. // 获得对比专利号
  613. public String getComPantentNos(QueryPatentVO params){
  614. if(params.getObligeeName()!=null) {
  615. String obligeeName = params.getObligeeName().replace("(", "\\(");
  616. obligeeName = obligeeName.replace(")", "\\)");
  617. params.setObligeeName(obligeeName);
  618. }
  619. if(params.getApplicationName()!=null) {
  620. String applicationName =params.getApplicationName().replace("(","\\(");
  621. applicationName =applicationName.replace(")","\\)");
  622. params.setApplicationName(applicationName);}
  623. List<String> patents = baseMapper.getListForRMS(params);
  624. return Response.success(patents);
  625. }
  626. // 获得带筛选条件的对比专利号
  627. public String getConPantentNos(QueryPatentVO params){
  628. List<String> patents = baseMapper.getConPantentNos(params);
  629. return Response.success(patents);
  630. }
  631. // 获得带筛选条件的专利
  632. public String getConPantents(QueryPatentVO params){
  633. if(params.getStartNumber()!=null&&params.getEndNumber()!=null){
  634. params.setEndNumber(params.getEndNumber()-params.getStartNumber()+1);
  635. }
  636. List<Patent> patents = baseMapper.getConPantents(params);
  637. return Response.success(patents);
  638. }
  639. public PatentDTO getPatentDTOById(Integer id, Integer projectId) {
  640. Patent patent = baseMapper.selectById(id);
  641. PatentDTO patentDTO = new PatentDTO();
  642. BeanUtils.copyProperties(patent, patentDTO);
  643. List<SystemDict> systemDictList = systemDictService.getSystemDictListByType(Arrays.asList(Constants.PATENT_TYPE, Constants.PATENT_SIMPLE_STATUS, Constants.COUNTRIES));
  644. List<PatentClassNumberLink> patentClassNumberLinkList = patentClassNumberLinkService.getPatentClassNumberLinkByPatentIds(Collections.singletonList(id));
  645. if (patent.getPriorityNo() != null) {
  646. patentDTO.setPriorityNo(patent.getPriorityNo());
  647. } else {
  648. patentDTO.setPriorityNo("");
  649. }
  650. if (patent.getPriorityCountry() != null) {
  651. if (patent.getPriorityCountry().contains("\\|")) {
  652. List<String> countryList = StringUtils.changeStringToString(patent.getPriorityCountry().replaceAll(" ", ""), "\\|");
  653. patentDTO.setPriorityCountry(countryList);
  654. } else if (patent.getPriorityCountry().contains(",")) {
  655. List<String> countryList = StringUtils.changeStringToString(patent.getPriorityCountry().replaceAll(" ", ""), ",");
  656. patentDTO.setPriorityCountry(countryList);
  657. } else if (patent.getPriorityCountry().contains(";")) {
  658. List<String> countryList = StringUtils.changeStringToString(patent.getPriorityCountry().replaceAll(" ", ""), ";");
  659. patentDTO.setPriorityCountry(countryList);
  660. }
  661. } else {
  662. patentDTO.setPriorityCountry(Collections.singletonList(""));
  663. }
  664. patentDTO.setApplicationDate(DateUtils.formatDate(patent.getApplicationDate(), DateUtils.YYYY_MM_DD));
  665. patentDTO.setPriorityDate(DateUtils.formatDate(patent.getPriorityDate(), DateUtils.YYYY_MM_DD));
  666. patentDTO.setPublicDate(DateUtils.formatDate(patent.getPublicDate(), DateUtils.YYYY_MM_DD));
  667. patentDTO.setPublicAccreditDate(DateUtils.formatDate(patent.getPublicAccreditDate(), DateUtils.YYYY_MM_DD));
  668. patentDTO.setFirstPublicDate(DateUtils.formatDate(patent.getFirstPublicDate(), DateUtils.YYYY_MM_DD));
  669. patentDTO.setSimpleStatus(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.PATENT_SIMPLE_STATUS) && systemDict.getValue().equals(String.valueOf(patent.getSimpleStatus()))).findFirst().orElse(new SystemDict()).getLabel());
  670. patentDTO.setType(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.PATENT_TYPE) && systemDict.getValue().equals(String.valueOf(patent.getType()))).findFirst().orElse(new SystemDict()).getLabel());
  671. patentDTO.setLabel(patentLabelService.getPatentLabelByPatentIdAndProjectId(patent.getId(), projectId));
  672. patentDTO.setApplicant(patentApplicantService.getPatentApplicantByPatentId(patent.getId()));
  673. patentDTO.setInventor(patentInventorService.getPatentInventorByPatentId(patent.getId()));
  674. if (StringUtils.isNotEmpty(patent.getAgencyId())) {
  675. patentDTO.setAgency(patentAgencyService.getPatentAgencyById(Integer.parseInt(patent.getAgencyId())));
  676. } else {
  677. PatentAgency patentAgency = new PatentAgency();
  678. patentAgency.setName("");
  679. patentDTO.setAgency(patentAgency);
  680. }
  681. patentDTO.setAgent(patentAgentService.getPatentAgentByPatentId(patent.getId()));
  682. patentDTO.setAffair(patentAffairService.getPatentAffairByPatentId(patent.getId()));
  683. if (projectId != null) {
  684. patentDTO.setField(projectFieldService.getPatentFieldByPatentIdAndProjectId(projectId, patent.getId()));
  685. }
  686. if (StringUtils.isNotEmpty(patent.getPriorityCountry())) {
  687. List<String> priorityList = PatentUtils.formatValue(patent.getPriorityCountry());
  688. List<String> priorityCountryList = new ArrayList<>();
  689. for (String priorityCountry : priorityList) {
  690. priorityCountryList.add(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.COUNTRIES) && systemDict.getValue().equals(priorityCountry)).findFirst().orElse(new SystemDict()).getLabel());
  691. }
  692. patentDTO.setPriorityCountry(priorityCountryList);
  693. }
  694. patentDTO.setInstruction(patentInstructionTextService.getPatentInstructionTextByPatentId(patent.getId()));
  695. patentDTO.setRights(patentRightService.getPatentRightByPatentId(patent.getId()));
  696. patentDTO.setImage(patentImageService.getPatentImageByPatentId(patent.getId()));
  697. patentDTO.setPdf(patentInstructionService.getPatentInstructionByPatentNo(patent.getPatentNo()));
  698. patentDTO.setIpc(patentClassNumberLinkList.stream().filter(patentClassNumberLink -> patentClassNumberLink.getType().equals(Constants.PATENT_CLASS_NUMBER_IPC) && patentClassNumberLink.getMain().equals(1)).findFirst().orElse(new PatentClassNumberLink()).getCode());
  699. patentDTO.setUpc(patentClassNumberLinkList.stream().filter(patentClassNumberLink -> patentClassNumberLink.getType().equals(Constants.PATENT_CLASS_NUMBER_UPC) && patentClassNumberLink.getMain().equals(1)).findFirst().orElse(new PatentClassNumberLink()).getCode());
  700. patentDTO.setIpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_IPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  701. patentDTO.setCpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_CPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  702. patentDTO.setUpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_UPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  703. patentDTO.setLocList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_LOC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  704. return patentDTO;
  705. }
  706. public PatentDTO getPatentDTOById(String patentNo,Integer projectId) {
  707. LambdaQueryWrapper<Patent> wrapper = new LambdaQueryWrapper<>();
  708. wrapper.eq(Patent::getPatentNo, patentNo);
  709. List<Patent> patents =this.list(wrapper);
  710. PatentDTO patentDTO = new PatentDTO();
  711. //如果未查出专利则返回为空
  712. if (patents ==null||patents.size()==0) {
  713. return patentDTO;
  714. }
  715. Patent patent = patents.get(0);
  716. BeanUtils.copyProperties(patent, patentDTO);
  717. List<SystemDict> systemDictList = systemDictService.getSystemDictListByType(Arrays.asList(Constants.PATENT_TYPE, Constants.PATENT_SIMPLE_STATUS, Constants.COUNTRIES));
  718. List<PatentClassNumberLink> patentClassNumberLinkList = patentClassNumberLinkService.getPatentClassNumberLinkByPatentIds(Collections.singletonList(patent.getId()));
  719. if (patent.getPriorityNo() != null) {
  720. patentDTO.setPriorityNo(patent.getPriorityNo());
  721. } else {
  722. patentDTO.setPriorityNo("");
  723. }
  724. if (patent.getPriorityCountry() != null) {
  725. if (patent.getPriorityCountry().contains("\\|")) {
  726. List<String> countryList = StringUtils.changeStringToString(patent.getPriorityCountry().replaceAll(" ", ""), "\\|");
  727. patentDTO.setPriorityCountry(countryList);
  728. } else if (patent.getPriorityCountry().contains(",")) {
  729. List<String> countryList = StringUtils.changeStringToString(patent.getPriorityCountry().replaceAll(" ", ""), ",");
  730. patentDTO.setPriorityCountry(countryList);
  731. } else if (patent.getPriorityCountry().contains(";")) {
  732. List<String> countryList = StringUtils.changeStringToString(patent.getPriorityCountry().replaceAll(" ", ""), ";");
  733. patentDTO.setPriorityCountry(countryList);
  734. }
  735. } else {
  736. patentDTO.setPriorityCountry(Collections.singletonList(""));
  737. }
  738. patentDTO.setQuote("");
  739. if(patent.getQuote()!=null){
  740. patentDTO.setQuote(patent.getQuote());
  741. }
  742. patentDTO.setQuoted("");
  743. if(patent.getQuoted()!=null){
  744. patentDTO.setQuoted(patent.getQuoted());
  745. }
  746. //根据同族号,获得所有同族专利(三种同族)
  747. List<Integer> familyIds= new ArrayList<>();
  748. if(patent.getSimpleFamily()!=null)
  749. {familyIds.add(patent.getSimpleFamily());}
  750. if(patent.getInpadocFamily()!=null){
  751. familyIds.add(patent.getInpadocFamily());
  752. }
  753. if(patent.getPatSnapFamily()!=null){
  754. familyIds.add(patent.getPatSnapFamily());
  755. }
  756. if(familyIds.size()!=0) {
  757. LambdaQueryWrapper<PatentSimpleFamilyLink> queryWrapper = new LambdaQueryWrapper<>();
  758. queryWrapper.in(PatentSimpleFamilyLink::getFamilyId, familyIds);
  759. List<PatentSimpleFamilyLink> patentSimpleFamilyLinks = patentSimpleFamilyLinkService.list(queryWrapper);
  760. List<String> familyPatentNos = patentSimpleFamilyLinks.stream().map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList());
  761. PatentDTO.PatentFamily patentFamily =new PatentDTO.PatentFamily();
  762. patentFamily.setSimple(familyPatentNos);
  763. patentDTO.setFamily(patentFamily);
  764. }
  765. patentDTO.setApplicationDate(DateUtils.formatDate(patent.getApplicationDate(), DateUtils.YYYY_MM_DD));
  766. patentDTO.setPriorityDate(DateUtils.formatDate(patent.getPriorityDate(), DateUtils.YYYY_MM_DD));
  767. patentDTO.setPublicDate(DateUtils.formatDate(patent.getPublicDate(), DateUtils.YYYY_MM_DD));
  768. patentDTO.setPublicAccreditDate(DateUtils.formatDate(patent.getPublicAccreditDate(), DateUtils.YYYY_MM_DD));
  769. patentDTO.setFirstPublicDate(DateUtils.formatDate(patent.getFirstPublicDate(), DateUtils.YYYY_MM_DD));
  770. patentDTO.setSimpleStatus(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.PATENT_SIMPLE_STATUS) && systemDict.getValue().equals(String.valueOf(patent.getSimpleStatus()))).findFirst().orElse(new SystemDict()).getLabel());
  771. patentDTO.setSimpleStatusInt(patent.getSimpleStatus());
  772. patentDTO.setType(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.PATENT_TYPE) && systemDict.getValue().equals(String.valueOf(patent.getType()))).findFirst().orElse(new SystemDict()).getLabel());
  773. patentDTO.setApplicant(patentApplicantService.getPatentApplicantByPatentId(patent.getId()));
  774. patentDTO.setInventor(patentInventorService.getPatentInventorByPatentId(patent.getId()));
  775. if(projectId!=null) {
  776. patentDTO.setLabel(patentLabelService.getPatentLabelByPatentIdAndProjectId(patent.getId(), projectId));
  777. }
  778. if (StringUtils.isNotEmpty(patent.getAgencyId())) {
  779. patentDTO.setAgency(patentAgencyService.getPatentAgencyById(Integer.parseInt(patent.getAgencyId())));
  780. } else {
  781. PatentAgency patentAgency = new PatentAgency();
  782. patentAgency.setName("");
  783. patentDTO.setAgency(patentAgency);
  784. }
  785. patentDTO.setAgent(patentAgentService.getPatentAgentByPatentId(patent.getId()));
  786. patentDTO.setAffair(patentAffairService.getPatentAffairByPatentId(patent.getId()));
  787. if (StringUtils.isNotEmpty(patent.getPriorityCountry())) {
  788. List<String> priorityList = PatentUtils.formatValue(patent.getPriorityCountry());
  789. List<String> priorityCountryList = new ArrayList<>();
  790. for (String priorityCountry : priorityList) {
  791. priorityCountryList.add(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.COUNTRIES) && systemDict.getValue().equals(priorityCountry)).findFirst().orElse(new SystemDict()).getLabel());
  792. }
  793. patentDTO.setPriorityCountry(priorityCountryList);
  794. }
  795. patentDTO.setInstruction(patentInstructionTextService.getPatentInstructionTextByPatentId(patent.getId()));
  796. patentDTO.setRights(patentRightService.getPatentRightByPatentId(patent.getId()));
  797. patentDTO.setImage(patentImageService.getPatentImageByPatentId(patent.getId()));
  798. patentDTO.setPdf(patentInstructionService.getPatentInstructionByPatentNo(patent.getPatentNo()));
  799. patentDTO.setIpc(patentClassNumberLinkList.stream().filter(patentClassNumberLink -> patentClassNumberLink.getType().equals(Constants.PATENT_CLASS_NUMBER_IPC) && patentClassNumberLink.getMain().equals(1)).findFirst().orElse(new PatentClassNumberLink()).getCode());
  800. patentDTO.setUpc(patentClassNumberLinkList.stream().filter(patentClassNumberLink -> patentClassNumberLink.getType().equals(Constants.PATENT_CLASS_NUMBER_UPC) && patentClassNumberLink.getMain().equals(1)).findFirst().orElse(new PatentClassNumberLink()).getCode());
  801. patentDTO.setIpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_IPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  802. patentDTO.setCpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_CPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  803. patentDTO.setUpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_UPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  804. patentDTO.setLocList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_LOC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  805. return patentDTO;
  806. }
  807. public List<Integer> getQueryPatentIds(PatentVO params) {
  808. if (params.getSelected() != null && params.getSelected().size() != 0 && params.getSelectId() != null && params.getSelectId()) {
  809. return params.getSelected().stream().distinct().collect(Collectors.toList());
  810. }
  811. this.setQueryPatentParams(params);
  812. List<Patent> patentList = baseMapper.getPageList(params);
  813. return patentList.stream().map(Patent::getId).distinct().collect(Collectors.toList());
  814. }
  815. @Async
  816. public void exportPatent(TaskParams taskParams) {
  817. try {
  818. List<PatentExportVO> selected = JsonUtils.jsonToList(taskParams.getSelected(), PatentExportVO.class);
  819. List<Integer> ids = StringUtils.changeStringToInteger(taskParams.getIds(), ",");
  820. if (selected != null) {
  821. List<String> columns = selected.stream().filter(PatentExportVO::getSelected).map(PatentExportVO::getKey).distinct().collect(Collectors.toList());
  822. List<String> headers = selected.stream().filter(PatentExportVO::getSelected).map(PatentExportVO::getName).distinct().collect(Collectors.toList());
  823. String fileName = IdUtil.simpleUUID() + ".xls";
  824. String directoryName = fileUtils.createDirectory();
  825. String savePath = fileUtils.getSavePath(directoryName);
  826. HSSFWorkbook hssfWorkbook = new HSSFWorkbook();
  827. HSSFSheet sheet = hssfWorkbook.createSheet();
  828. sheet.setDefaultColumnWidth(30);
  829. HSSFRow headerRow = sheet.createRow(0);
  830. headerRow.setHeight((short) 500);
  831. HSSFCellStyle headerCellStyle = hssfWorkbook.createCellStyle();
  832. HSSFCellStyle commonCellStyle = hssfWorkbook.createCellStyle();
  833. for (int i = 0; i < headers.size(); i++) {
  834. HSSFCell cell = headerRow.createCell(i);
  835. ExcelUtils.setExcelCellStyle(headerCellStyle);
  836. headerCellStyle.setAlignment(HorizontalAlignment.CENTER);
  837. headerCellStyle.setVerticalAlignment(VerticalAlignment.CENTER);
  838. headerCellStyle.setFillForegroundColor(HSSFColor.HSSFColorPredefined.SKY_BLUE.getIndex());
  839. headerCellStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
  840. headerCellStyle.setWrapText(true);
  841. cell.setCellStyle(headerCellStyle);
  842. cell.setCellValue(headers.get(i));
  843. }
  844. for (int i = 0; i < ids.size(); i++) {
  845. Map<String, Object> map = new LinkedHashMap<>();
  846. PatentDTO patent = this.getPatentDTOById(ids.get(i), taskParams.getProjectId());
  847. if (patent == null) {
  848. continue;
  849. }
  850. String country = PatentUtils.getPatentCountry(patent.getPatentNo());
  851. for (int j = 0; j < columns.size(); j++) {
  852. String column = columns.get(j);
  853. PatentExportVO patentExportVO = selected.stream().filter(item -> item.getKey().equals(column)).findFirst().orElse(new PatentExportVO());
  854. Object value = null;
  855. switch (column) {
  856. case "pname":
  857. value = patent.getName();
  858. break;
  859. case "pname_out":
  860. value = patent.getNameOut();
  861. break;
  862. case "patentno":
  863. value = patent.getPatentNo();
  864. break;
  865. case "abstract":
  866. value = patent.getAbstractStr();
  867. break;
  868. case "abstract_out":
  869. value = patent.getAbstractOut();
  870. break;
  871. case "abstract_path":
  872. break;
  873. case "applicationno":
  874. value = patent.getApplicationNo();
  875. break;
  876. case "appdate":
  877. value = patent.getApplicationDate();
  878. break;
  879. case "publicno":
  880. value = patent.getPublicNo();
  881. break;
  882. case "publicdate":
  883. value = patent.getPublicDate();
  884. break;
  885. case "fpublicdate":
  886. value = patent.getFirstPublicDate();
  887. break;
  888. case "publictono":
  889. value = patent.getPublicAccreditNo();
  890. break;
  891. case "publictodate":
  892. value = patent.getPublicAccreditDate();
  893. break;
  894. case "tags":
  895. value = StringUtils.join(patent.getLabel().stream().map(PatentLabel::getName).distinct().collect(Collectors.toList()), "\n");
  896. break;
  897. case "bureau":
  898. value = patent.getBureau();
  899. break;
  900. case "simplefamily":
  901. List<PatentSimpleFamilyLink> patentSimpleFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(Collections.singletonList(patent.getSimpleFamily()));
  902. value = StringUtils.join(patentSimpleFamilyLinkList.stream().map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()), Constants.SEPARATOR_VERTICAL_BAR);
  903. break;
  904. case "inpadocfamily":
  905. List<PatentSimpleFamilyLink> patentInpadocFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(Collections.singletonList(patent.getInpadocFamily()));
  906. value = StringUtils.join(patentInpadocFamilyLinkList.stream().map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()), Constants.SEPARATOR_VERTICAL_BAR);
  907. break;
  908. case "patsnapfamily":
  909. List<PatentSimpleFamilyLink> patentPatSnapFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(Collections.singletonList(patent.getPatSnapFamily()));
  910. value = StringUtils.join(patentPatSnapFamilyLinkList.stream().map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()), Constants.SEPARATOR_VERTICAL_BAR);
  911. break;
  912. case "ipc":
  913. value = StringUtils.join(patent.getIpcList(), Constants.SEPARATOR_VERTICAL_BAR);
  914. break;
  915. case "upc":
  916. value = StringUtils.join(patent.getUpcList(), Constants.SEPARATOR_VERTICAL_BAR);
  917. break;
  918. case "intclassno":
  919. value = patent.getIpc();
  920. break;
  921. case "intclasscpcno":
  922. value = StringUtils.join(patent.getCpcList(), Constants.SEPARATOR_VERTICAL_BAR);
  923. break;
  924. case "intclassupcno":
  925. value = patent.getUpc();
  926. break;
  927. case "intclasslocno":
  928. value = StringUtils.join(patent.getLocList(), Constants.SEPARATOR_VERTICAL_BAR);
  929. break;
  930. case "pstatus":
  931. value = patent.getSimpleStatus();
  932. break;
  933. case "ptype":
  934. value = patent.getType();
  935. break;
  936. case "law_datetime":
  937. value = PatentUtils.getPatentAffair(patent.getAffair(), 0);
  938. break;
  939. case "law_status":
  940. value = PatentUtils.getPatentAffair(patent.getAffair(), 1);
  941. break;
  942. case "law_simplestatus":
  943. value = PatentUtils.getPatentAffair(patent.getAffair(), 2);
  944. break;
  945. case "law_content":
  946. value = PatentUtils.getPatentAffair(patent.getAffair(), 3);
  947. break;
  948. case "applicant":
  949. value = StringUtils.join(patent.getApplicant().stream().filter(item -> item.getDataType().equals(2)).collect(Collectors.toList()).stream().map(PatentApplicant::getName).distinct().collect(Collectors.toList()), Constants.SEPARATOR_VERTICAL_BAR);
  950. break;
  951. case "applicant1":
  952. value = StringUtils.join(patent.getApplicant().stream().filter(item -> item.getDataType().equals(2)).collect(Collectors.toList()).stream().map(PatentApplicant::getShortName).distinct().collect(Collectors.toList()), Constants.SEPARATOR_VERTICAL_BAR);
  953. break;
  954. case "rightholder":
  955. value = StringUtils.join(patent.getApplicant().stream().filter(item -> item.getDataType().equals(1)).collect(Collectors.toList()).stream().map(PatentApplicant::getName).distinct().collect(Collectors.toList()), Constants.SEPARATOR_VERTICAL_BAR);
  956. break;
  957. case "rightholder1":
  958. value = StringUtils.join(patent.getApplicant().stream().filter(item -> item.getDataType().equals(1)).collect(Collectors.toList()).stream().map(PatentApplicant::getShortName).distinct().collect(Collectors.toList()), Constants.SEPARATOR_VERTICAL_BAR);
  959. break;
  960. case "applicantcountry":
  961. value = PatentUtils.getPeopleCountry(patent.getApplicant().stream().filter(item -> item.getDataType().equals(2)).collect(Collectors.toList()));
  962. break;
  963. case "rightholdercountry":
  964. value = PatentUtils.getPeopleCountry(patent.getApplicant().stream().filter(item -> item.getDataType().equals(1)).collect(Collectors.toList()));
  965. break;
  966. case "applicantaddress":
  967. value = PatentUtils.getPeopleAddress(patent.getApplicant().stream().filter(item -> item.getDataType().equals(2)).collect(Collectors.toList()));
  968. break;
  969. case "rightholderaddress":
  970. value = PatentUtils.getPeopleAddress(patent.getApplicant().stream().filter(item -> item.getDataType().equals(1)).collect(Collectors.toList()));
  971. break;
  972. case "applicantaddr":
  973. break;
  974. case "rightholderaddr":
  975. break;
  976. case "firstapplicant":
  977. PatentApplicant firstApplicant1 = patent.getApplicant().stream().filter(item -> item.getDataType().equals(2) && item.getOrder().equals(0)).findFirst().orElse(null);
  978. if (firstApplicant1 != null) {
  979. value = firstApplicant1.getName();
  980. }
  981. break;
  982. case "firstrightholder":
  983. PatentApplicant firstApplicant3 = patent.getApplicant().stream().filter(item -> item.getDataType().equals(1) && item.getOrder().equals(0)).findFirst().orElse(null);
  984. if (firstApplicant3 != null) {
  985. value = firstApplicant3.getName();
  986. }
  987. break;
  988. case "firstapplicantaddr":
  989. PatentApplicant firstApplicant2 = patent.getApplicant().stream().filter(item -> item.getDataType().equals(2) && item.getOrder().equals(0)).findFirst().orElse(null);
  990. if (firstApplicant2 != null) {
  991. value = firstApplicant2.getAddressStr();
  992. }
  993. break;
  994. case "firstrightholderaddr":
  995. PatentApplicant firstApplicant4 = patent.getApplicant().stream().filter(item -> item.getDataType().equals(1) && item.getOrder().equals(0)).findFirst().orElse(null);
  996. if (firstApplicant4 != null) {
  997. value = firstApplicant4.getAddressStr();
  998. }
  999. break;
  1000. case "firstapplicantnum":
  1001. value = patent.getApplicantNum();
  1002. break;
  1003. case "inventor":
  1004. value = StringUtils.join(patent.getInventor().stream().map(PatentInventor::getName).distinct().collect(Collectors.toList()), Constants.SEPARATOR_VERTICAL_BAR);
  1005. break;
  1006. case "firstnventoraddr":
  1007. value = patent.getInventor().stream().filter(PatentInventor::getFirst).findFirst().orElse(new PatentInventor()).getAddress();
  1008. break;
  1009. case "firstnventor":
  1010. value = patent.getInventor().stream().filter(PatentInventor::getFirst).findFirst().orElse(new PatentInventor()).getName();
  1011. break;
  1012. case "inventornum":
  1013. value = patent.getInventorNum();
  1014. break;
  1015. case "num2":
  1016. value = patent.getRightNum();
  1017. break;
  1018. case "content":
  1019. case "content_out":
  1020. case "selfcontent":
  1021. List<String> content = new ArrayList<>();
  1022. if (column.equals("content")) {
  1023. content = patent.getRights().stream().map(PatentRight::getContent).collect(Collectors.toList());
  1024. }
  1025. if (column.equals("content_out")) {
  1026. content = patent.getRights().stream().map(PatentRight::getContentOut).collect(Collectors.toList());
  1027. }
  1028. if (column.equals("selfcontent")) {
  1029. content = patent.getRights().stream().filter(item -> item.getType().equals(1)).map(PatentRight::getContent).collect(Collectors.toList());
  1030. }
  1031. StringBuffer contentBuffer = new StringBuffer();
  1032. for (String s : content) {
  1033. contentBuffer.append(s);
  1034. switch (country) {
  1035. case "JP":
  1036. case "CN":
  1037. contentBuffer.append("。\n");
  1038. break;
  1039. default:
  1040. contentBuffer.append("\n");
  1041. }
  1042. }
  1043. value = contentBuffer.toString();
  1044. break;
  1045. case "priorityno":
  1046. value = patent.getPriorityNo();
  1047. break;
  1048. case "prioritycountry":
  1049. value = patent.getPriorityCountry();
  1050. break;
  1051. case "prioritydate":
  1052. value = patent.getPriorityDate();
  1053. break;
  1054. case "page":
  1055. value = patent.getDocPage();
  1056. break;
  1057. case "code":
  1058. value = patent.getCode();
  1059. break;
  1060. case "manual":
  1061. if (patent.getInstruction() != null) {
  1062. value = patent.getInstruction().getManual();
  1063. }
  1064. break;
  1065. case "simplefamilynum":
  1066. value = patent.getSimpleFamilyNum();
  1067. break;
  1068. case "inpadocfamilynum":
  1069. value = patent.getInpadocFamilyNum();
  1070. break;
  1071. case "patsnapfamilynum":
  1072. value = patent.getPatSnapFamilyNum();
  1073. break;
  1074. case "quoteno":
  1075. value = patent.getQuoteNum();
  1076. break;
  1077. case "quotedno":
  1078. value = patent.getQuotedNum();
  1079. break;
  1080. case "quotedno3":
  1081. value = patent.getQuotedNum3();
  1082. break;
  1083. case "quotedno5":
  1084. value = patent.getQuotedNum5();
  1085. break;
  1086. case "agency":
  1087. PatentAgency agency = patent.getAgency();
  1088. if (agency != null) {
  1089. value = agency.getName();
  1090. }
  1091. break;
  1092. case "agent":
  1093. value = StringUtils.join(patent.getAgent().stream().map(PatentAgent::getName).distinct().collect(Collectors.toList()), Constants.SEPARATOR_VERTICAL_BAR);
  1094. break;
  1095. case "wonational":
  1096. value = patent.getWo();
  1097. break;
  1098. case "examiner":
  1099. value = patent.getExaminer();
  1100. break;
  1101. case "assexaminer":
  1102. value = patent.getAidExaminer();
  1103. break;
  1104. case "quote":
  1105. value = patent.getQuote();
  1106. break;
  1107. case "quoted":
  1108. value = patent.getQuoted();
  1109. break;
  1110. case "nonpatentquote":
  1111. value = patent.getNotPatentQuote();
  1112. break;
  1113. case "epcountry":
  1114. value = patent.getEpStatus();
  1115. break;
  1116. default:
  1117. PatentDTO.Field field = patent.getField().stream().filter(item -> item.getId().equals(Integer.parseInt(column))).findFirst().orElse(null);
  1118. if (field != null) {
  1119. value = StringUtils.join(field.getSelected(), "\n");
  1120. }
  1121. }
  1122. map.put(patentExportVO.getName(), value);
  1123. }
  1124. HSSFRow row = sheet.createRow(i + 1);
  1125. row.setHeight((short) 800);
  1126. for (String key : map.keySet()) {
  1127. int index = headers.indexOf(key);
  1128. if (index != -1) {
  1129. HSSFCell cell = row.createCell(index);
  1130. ExcelUtils.setExcelCellStyle(commonCellStyle);
  1131. commonCellStyle.setVerticalAlignment(VerticalAlignment.TOP);
  1132. commonCellStyle.setWrapText(true);
  1133. cell.setCellStyle(commonCellStyle);
  1134. if (key.equals("摘要附图")) {
  1135. if (StringUtils.isNotEmpty(patent.getAbstractPath())) {
  1136. try {
  1137. byte[] pictureData = FileUtil.readBytes(fileUtils.getSystemPath(patent.getAbstractPath()));
  1138. if (pictureData != null) {
  1139. ExcelUtils.writePicture(sheet, index, i + 1, pictureData, HSSFWorkbook.PICTURE_TYPE_JPEG);
  1140. }
  1141. row.setHeight((short) 2500);
  1142. } catch (Exception e) {
  1143. }
  1144. }
  1145. } else if (StringUtils.isNotNull(map.get(key))) {
  1146. cell.setCellValue(String.valueOf(map.get(key)));
  1147. }
  1148. }
  1149. }
  1150. Integer total = ids.size();
  1151. WebSocketServer.sendInfo(Response.websocket(new TaskWebSocketDTO()
  1152. .setTaskId(taskParams.getTaskId())
  1153. .setProjectId(taskParams.getProjectId())
  1154. .setComplete(false)
  1155. .setIndex(i)
  1156. .setTaskType(Constants.TASK_EXPORT_PATENT)
  1157. .setPercentage(total == 0 ? 0 : Math.round((total.equals(i) ? (i * 1D) : (i + 1D)) / total * 100D))
  1158. .setFileName("")
  1159. .setOldName("")
  1160. .setUrl("")
  1161. .setTotal(total), ResponseEnum.PATENT_EXPORT_TASK_SUCCESS), taskParams.getUserId());
  1162. }
  1163. FileOutputStream fos = new FileOutputStream(savePath + fileName);
  1164. hssfWorkbook.write(fos);
  1165. fos.flush();
  1166. fos.close();
  1167. String url = fileUtils.getDirectory(fileName);
  1168. taskService.updateTime(taskParams.getTaskId(), 2, DateUtils.getDateTime(), url, fileName);
  1169. WebSocketServer.sendInfo(Response.websocket(new TaskWebSocketDTO()
  1170. .setTaskId(taskParams.getTaskId())
  1171. .setProjectId(taskParams.getProjectId())
  1172. .setComplete(true)
  1173. .setIndex(ids.size())
  1174. .setTaskType(Constants.TASK_EXPORT_PATENT)
  1175. .setPercentage(100L)
  1176. .setFileName(fileName)
  1177. .setOldName("")
  1178. .setUrl(url)
  1179. .setTotal(ids.size()), ResponseEnum.PATENT_EXPORT_TASK_SUCCESS), taskParams.getUserId());
  1180. }
  1181. } catch (Exception e) {
  1182. e.printStackTrace();
  1183. taskService.updateTime(taskParams.getTaskId(), 3, DateUtils.getDateTime(), null, null);
  1184. WebSocketServer.sendInfo(Response.error(ResponseEnum.PATENT_EXPORT_TASK_ERROR), taskParams.getUserId());
  1185. }
  1186. }
  1187. public IPage<PatentQueryFieldSourceDTO> getPatentQuerySourcePageList(PatentQueryFieldSourceVO params) {
  1188. return this.getPatentAttributeSourcePageList(params);
  1189. }
  1190. public IPage<PatentQueryFieldSourceDTO> getPatentAttributeSourcePageList(PatentQueryFieldSourceVO params) {
  1191. this.setPatentQuerySourceParams(params);
  1192. if (params.getKey().equals("40-0")) {
  1193. Integer projectId = params.getProjectId();
  1194. List<PatentQueryFieldSourceDTO> dataList = baseMapper.getCountStatus(projectId);
  1195. List<PatentQueryFieldSourceDTO> lstA = new ArrayList<>();
  1196. List<PatentQueryFieldSourceDTO> lstB = new ArrayList<>();
  1197. dataList.forEach(item -> {
  1198. if (StringUtils.changeStringToString(item.getLabel(), "\\|").size() > 1) {
  1199. lstA.add(item);
  1200. } else {
  1201. lstB.add(item);
  1202. }
  1203. });
  1204. lstA.forEach(item -> {
  1205. List<String> stringList = StringUtils.changeStringToString(item.getLabel(), "\\|");
  1206. stringList.forEach(x -> {
  1207. List<PatentQueryFieldSourceDTO> lstC = new ArrayList<>();
  1208. for (PatentQueryFieldSourceDTO patentQueryFieldSourceDTO : lstB) {
  1209. if (!lstB.stream().map(PatentQueryFieldSourceDTO::getLabel).collect(Collectors.toList()).contains(x)) {
  1210. PatentQueryFieldSourceDTO a = new PatentQueryFieldSourceDTO();
  1211. a.setCount(item.getCount());
  1212. a.setLabel(x);
  1213. lstC.add(a);
  1214. break;
  1215. }
  1216. if (patentQueryFieldSourceDTO.getLabel().equals(x)) {
  1217. patentQueryFieldSourceDTO.setCount(patentQueryFieldSourceDTO.getCount() + item.getCount());
  1218. }
  1219. }
  1220. lstB.addAll(lstC);
  1221. });
  1222. });
  1223. List<SystemDict> systemDictList = systemDictService.getSystemDictListByType(Collections.singletonList(Constants.PATENT_STATUS));
  1224. lstB.forEach(b -> {
  1225. Integer status = Integer.parseInt(systemDictList.stream()
  1226. .filter(systemDict -> systemDict.getType().equals(Constants.PATENT_STATUS) && systemDict.getLabel().equals(b.getLabel()))
  1227. .findFirst()
  1228. .orElse(new SystemDict()).getValue());
  1229. b.setValue(String.valueOf(status));
  1230. });
  1231. IPage<PatentQueryFieldSourceDTO> pageList = baseMapper.getPatentQuerySourcePageList(new Page<>(params.getCurrent(), params.getSize()), params, new ArrayList<>());
  1232. pageList.setRecords(lstB);
  1233. return pageList;
  1234. }
  1235. IPage<PatentQueryFieldSourceDTO> pageList = baseMapper.getPatentQuerySourcePageList(new Page<>(params.getCurrent(), params.getSize()), params, new ArrayList<>());
  1236. pageList.getRecords().forEach(item -> item.setIds(null));
  1237. return pageList;
  1238. }
  1239. public List<PatentQueryFieldSourceDTO> getPatentAttributeSourceList(PatentQueryFieldSourceVO params, List<Integer> patentIds) {
  1240. this.setPatentQuerySourceParams(params);
  1241. List<PatentQueryFieldSourceDTO> dataList = baseMapper.getPatentQuerySourcePageList(params, patentIds);
  1242. return dataList;
  1243. }
  1244. private void setPatentQuerySourceParams(PatentQueryFieldSourceVO params) {
  1245. List<Integer> field = StringUtils.changeStringToInteger(params.getKey(), "-");
  1246. Integer type = 0;
  1247. Integer level = 0;
  1248. Integer status = 0;
  1249. switch (params.getKey()) {
  1250. case "18-6":
  1251. case "18-7":
  1252. case "18-8":
  1253. case "23-6":
  1254. case "23-7":
  1255. case "23-8":
  1256. params.setApplicantType(2);
  1257. break;
  1258. case "19-6":
  1259. case "19-7":
  1260. case "19-8":
  1261. case "24-6":
  1262. case "24-7":
  1263. case "24-8":
  1264. params.setApplicantType(1);
  1265. break;
  1266. case "29-17":
  1267. case "30-17":
  1268. case "29-18":
  1269. case "29-19":
  1270. case "29-20":
  1271. case "30-18":
  1272. case "30-19":
  1273. case "30-20":
  1274. params.setApplicantType(field.get(0) == 29 ? 2 : 1);
  1275. break;
  1276. default:
  1277. params.setCustomFieldId(field.get(0));
  1278. if (params.getType().equals("6") && field.get(1).equals(0)) {
  1279. params.setCustomFieldTreeType(0);
  1280. } else {
  1281. params.setCustomFieldTreeType(null);
  1282. }
  1283. }
  1284. }
  1285. public void updatePatentCustomField(PatentCustomFieldParams params) {
  1286. List<CustomFieldDTO> dataList = new ArrayList<>();
  1287. for (String key : params.keySet()) {
  1288. List<String> fields = StringUtils.changeStringToString(key, ":");
  1289. if (fields.size() == 2) {
  1290. Object name = fields.get(0);
  1291. Object selected = params.get(key);
  1292. List<String> select = JsonUtils.jsonToList(JsonUtils.objectToJson(selected), String.class);
  1293. if (StringUtils.isNull(select)) {
  1294. select = new ArrayList<>();
  1295. }
  1296. CustomFieldDTO data = new CustomFieldDTO();
  1297. data.setName(name.toString());
  1298. data.setSelected(select);
  1299. data.setType(Integer.parseInt(fields.get(1)));
  1300. dataList.add(data);
  1301. }
  1302. }
  1303. for (CustomFieldDTO data : dataList) {
  1304. ProjectField projectField = projectFieldService.getProjectFieldByNameAndType(data.getName(), data.getType(), params.getProjectId(), params.getUserId());
  1305. projectFieldPatentLinkService.deleteByPatentIdAndProjectIdAndFieldId(params.getPatentId(), params.getProjectId(), projectField.getId());
  1306. switch (projectField.getType()) {
  1307. case 0:
  1308. case 1:
  1309. case 2:
  1310. for (String text : data.getSelected()) {
  1311. ProjectFieldText projectFieldText = projectFieldTextService.getProjectFieldTextByNameAndFieldId(text, projectField.getId());
  1312. if (projectFieldText == null) {
  1313. projectFieldText = new ProjectFieldText();
  1314. projectFieldText.setFieldId(projectField.getId());
  1315. projectFieldText.setText(text);
  1316. projectFieldText.insert();
  1317. }
  1318. projectFieldPatentLinkService.updateProjectPatentLink(params.getPatentId(), projectField.getType(), projectField.getId(), projectFieldText.getId(), params.getUserId(), params.getProjectId());
  1319. }
  1320. break;
  1321. case 3:
  1322. case 4:
  1323. case 5:
  1324. for (String option : data.getSelected()) {
  1325. ProjectFieldOption projectFieldOption = projectFieldOptionService.getProjectFieldOptionByNameAndFieldId(option, projectField.getId());
  1326. if (projectFieldOption == null) {
  1327. projectFieldOption = new ProjectFieldOption();
  1328. projectFieldOption.setFieldId(projectField.getId());
  1329. projectFieldOption.setName(option);
  1330. projectFieldOption.insert();
  1331. }
  1332. projectFieldPatentLinkService.updateProjectPatentLink(params.getPatentId(), projectField.getType(), projectField.getId(), projectFieldOption.getId(), params.getUserId(), params.getProjectId());
  1333. }
  1334. break;
  1335. case 6:
  1336. for (String tree : data.getSelected()) {
  1337. List<String> treeNode = StringUtils.changeStringToString(tree, "\\\\");
  1338. Integer treeNodeId = projectFieldTreeService.getTreeNodeIdByPathNameAndUpdateTreeData(treeNode, projectField);
  1339. if (treeNodeId != 0) {
  1340. projectFieldPatentLinkService.updateProjectPatentLink(params.getPatentId(), projectField.getType(), projectField.getId(), treeNodeId, params.getUserId(), params.getProjectId());
  1341. }
  1342. }
  1343. break;
  1344. }
  1345. }
  1346. }
  1347. public Map<String, Object> getBetweenPatentList(PatentVO params) {
  1348. this.setQueryPatentParams(params);
  1349. List<Patent> patentList = baseMapper.getPageList(params);
  1350. int index = patentList.stream().map(Patent::getId).collect(Collectors.toList()).indexOf(params.getPatentId());
  1351. Map<String, Object> map = new HashMap<>();
  1352. if (index > 0) {
  1353. Patent patent = patentList.get(index - 1);
  1354. Map<String, Object> prev = new HashMap<>();
  1355. prev.put("id", patent.getId());
  1356. prev.put("patentNo", patent.getPatentNo());
  1357. prev.put("total", index);
  1358. map.put("prev", prev);
  1359. }
  1360. if (index < patentList.size() - 1) {
  1361. Patent patent = patentList.get(index + 1);
  1362. Map<String, Object> next = new HashMap<>();
  1363. next.put("id", patent.getId());
  1364. next.put("patentNo", patent.getPatentNo());
  1365. next.put("total", patentList.size() - index - 1);
  1366. map.put("next", next);
  1367. }
  1368. return map;
  1369. }
  1370. public void importPatent(Integer projectId, String patentJson, String patentAffairJson, String patentAgencyJson, String patentFamilyJson, String patentFamilyLinkJson, String patentInventorJson, String patentInventorLinkJson, String patentAgentJson, String patentAgentLinkJson, String patentApplicantJson, String patentApplicantLinkJson, String patentApplicantMergeLinkJson, String patentClassNumberJson, String patentInstructionTextJson, String patentRightJson, String patentLicensorJson, String patentPledgeJson, String patentInventorMergeJson) {
  1371. List<Patent> importPatentList = JsonUtils.jsonToList(patentJson, Patent.class);
  1372. List<PatentAffair> importPatentAffairList = JsonUtils.jsonToList(patentAffairJson, PatentAffair.class);
  1373. List<PatentAgency> importPatentAgencyList = JsonUtils.jsonToList(patentAgencyJson, PatentAgency.class);
  1374. List<PatentAgent> importPatentAgentList = JsonUtils.jsonToList(patentAgentJson, PatentAgent.class);
  1375. List<PatentAgentLink> importPatentAgentLinkList = JsonUtils.jsonToList(patentAgentLinkJson, PatentAgentLink.class);
  1376. List<PatentInventor> importPatentInventorList = JsonUtils.jsonToList(patentInventorJson, PatentInventor.class);
  1377. List<PatentInventorMerge> importPatentInventorMergeList = JsonUtils.jsonToList(patentInventorMergeJson, PatentInventorMerge.class);
  1378. List<PatentInventorLink> importPatentInventorLinkList = JsonUtils.jsonToList(patentInventorLinkJson, PatentInventorLink.class);
  1379. List<PatentApplicant> importPatentApplicantList = JsonUtils.jsonToList(patentApplicantJson, PatentApplicant.class);
  1380. List<PatentApplicantLink> importPatentApplicantLinkList = JsonUtils.jsonToList(patentApplicantLinkJson, PatentApplicantLink.class);
  1381. List<PatentApplicantMergeLink> importPatentApplicantMergeLinkList = JsonUtils.jsonToList(patentApplicantMergeLinkJson, PatentApplicantMergeLink.class);
  1382. List<PatentSimpleFamily> importPatentSimpleFamilyList = JsonUtils.jsonToList(patentFamilyJson, PatentSimpleFamily.class);
  1383. List<PatentSimpleFamilyLink> importPatentSimpleFamilyLinkList = JsonUtils.jsonToList(patentFamilyLinkJson, PatentSimpleFamilyLink.class);
  1384. List<PatentClassNumberLink> importPatentClassNumberLinkList = JsonUtils.jsonToList(patentClassNumberJson, PatentClassNumberLink.class);
  1385. List<PatentInstructionText> importPatentInstructionTextList = JsonUtils.jsonToList(patentInstructionTextJson, PatentInstructionText.class);
  1386. List<PatentRight> importPatentRightList = JsonUtils.jsonToList(patentRightJson, PatentRight.class);
  1387. List<PatentLicensor> importPatentLicensorList = JsonUtils.jsonToList(patentLicensorJson, PatentLicensor.class);
  1388. List<PatentPledge> importPatentPledgeList = JsonUtils.jsonToList(patentPledgeJson, PatentPledge.class);
  1389. List<Patent> localPatentList = this.getPatentListByPatentNo(importPatentList.stream().map(Patent::getPatentNo).collect(Collectors.toList()));
  1390. List<Patent> patentList = new ArrayList<>();
  1391. for (Patent importPatent : importPatentList) {
  1392. Patent localPatent = localPatentList.stream().filter(item -> item.getPatentNo().equals(importPatent.getPatentNo())).findFirst().orElse(null);
  1393. Integer patentId;
  1394. if (localPatent == null) {
  1395. localPatent = new Patent();
  1396. patentId = null;
  1397. } else {
  1398. patentId = localPatent.getId();
  1399. }
  1400. BeanUtils.copyProperties(importPatent, localPatent);
  1401. localPatent.setId(patentId);
  1402. if (StringUtils.isNotEmpty(importPatent.getAgencyId())) {
  1403. PatentAgency importPatentAgency = importPatentAgencyList.stream().filter(item -> item.getId().equals(Integer.valueOf(importPatent.getAgencyId()))).findFirst().orElse(new PatentAgency());
  1404. localPatent.setAgencyId(patentAgencyService.getAgencyStringIdByName(importPatentAgency.getName()));
  1405. }
  1406. localPatent.insertOrUpdate();
  1407. patentList.add(localPatent);
  1408. }
  1409. for (Patent patent : patentList) {
  1410. Patent importPatent = importPatentList.stream().filter(item -> item.getPatentNo().equals(patent.getPatentNo())).findFirst().orElse(new Patent());
  1411. patentAffairService.importPatentAffair(patent, importPatentList, importPatentAffairList);
  1412. patentAgentService.importPatentAgent(patent.getId(), importPatent.getId(), importPatentAgentList, importPatentAgentLinkList);
  1413. patentSimpleFamilyService.importPatentSimpleFamily(patent, importPatentSimpleFamilyList, importPatentSimpleFamilyLinkList);
  1414. patentInventorService.importPatentInventor(patent.getId(), importPatent.getId(), importPatentInventorList, importPatentInventorLinkList);
  1415. patentApplicantService.importPatentApplicant(projectId, patent.getId(), importPatent.getId(), importPatentApplicantList, importPatentApplicantLinkList);
  1416. patentClassNumberLinkService.importPatentClassNumberLink(patent.getId(), importPatent.getId(), importPatentClassNumberLinkList);
  1417. patentInstructionTextService.importPatentInstructionText(patent.getId(), importPatent.getId(), importPatentInstructionTextList);
  1418. patentRightService.importPatentRight(patent.getId(), importPatent.getId(), importPatentRightList);
  1419. patentLicensorService.importPatentLicensor(patent.getId(), importPatent.getId(), importPatentLicensorList);
  1420. patentPledgeService.importPatentPledge(patent.getId(), importPatent.getId(), importPatentPledgeList);
  1421. }
  1422. patentInventorMergeService.importPatentInventorMergeLink(projectId, importPatentInventorList, importPatentInventorMergeList);
  1423. patentApplicantMergeLinkService.importPatentApplicantMergeLink(projectId, importPatentApplicantList, importPatentApplicantMergeLinkList);
  1424. }
  1425. public String getPatentNos(Integer projectId) {
  1426. //根据专题库号获得专利id
  1427. LambdaQueryWrapper<ProjectPatentLink> wrapper = new LambdaQueryWrapper<>();
  1428. wrapper.select(ProjectPatentLink::getPatentId).eq(ProjectPatentLink::getProjectId, projectId);
  1429. List<ProjectPatentLink> projectPatentLinkList = projectPatentLinkService.list(wrapper);
  1430. List<Integer> patentIds = projectPatentLinkList.stream().map(ProjectPatentLink::getPatentId).collect(Collectors.toList());
  1431. //根据专利Id获得专利号
  1432. LambdaQueryWrapper<Patent> queryWrapper = new LambdaQueryWrapper<>();
  1433. queryWrapper.in(Patent::getId, patentIds);
  1434. List<Patent> patents = this.list(queryWrapper);
  1435. List<String> patentNos = patents.stream().map(Patent::getPatentNo).collect(Collectors.toList());
  1436. return Response.success(patentNos);
  1437. }
  1438. public String getPagination(List<String> list,int location){
  1439. Map map=new HashMap();
  1440. LambdaQueryWrapper<Patent> wrapper =new LambdaQueryWrapper<>();
  1441. wrapper.in(Patent::getPatentNo,list);
  1442. Integer totalNumber = Math.toIntExact(this.count(wrapper));
  1443. if(location>=totalNumber){
  1444. location=totalNumber;
  1445. int a=location-2;
  1446. int b=2;
  1447. List<Patent> patent = patentMapper.getPatent(list, a, b);
  1448. int front=location-1;
  1449. String str1 =patent.get(0).getPatentNo();
  1450. String srr2= patent.get(1).getPatentNo();
  1451. int i=patent.get(0).getId();
  1452. int j=patent.get(1).getId();
  1453. map.put("frontID",i);
  1454. map.put("currentID",j);
  1455. map.put("behindPatentNo",null);
  1456. map.put("frontNumber",front);
  1457. map.put("behindNumber",0);
  1458. map.put("frontPatentNo",str1);
  1459. map.put("currentPatentNo",srr2);
  1460. map.put("totalNumber",totalNumber);
  1461. return Response.success(map);
  1462. }
  1463. if(location==1){
  1464. int a=0;
  1465. int p=2;
  1466. List<Patent> patent = patentMapper.getPatent(list, a, p);
  1467. String str1 =patent.get(0).getPatentNo();
  1468. String srr2= patent.get(1).getPatentNo();
  1469. int i=patent.get(0).getId();
  1470. int j=patent.get(1).getId();
  1471. map.put("currentID",i);
  1472. map.put("behindID",j);
  1473. map.put("currentPatentNo",str1);
  1474. map.put("behindPatentNo",srr2);
  1475. map.put("frontPatentNo",null);
  1476. map.put("frontNumber",0);
  1477. int behindNumber=totalNumber-location;
  1478. map.put("behindNumber",behindNumber);
  1479. map.put("totalNumber",totalNumber);
  1480. return Response.success(map);
  1481. }
  1482. int a=location-2;
  1483. int p=3;
  1484. List<Patent> patent = patentMapper.getPatent(list, a, p);
  1485. String str1 =patent.get(0).getPatentNo();
  1486. String str2 =patent.get(1).getPatentNo();
  1487. String str3 =patent.get(2).getPatentNo();
  1488. int i=patent.get(0).getId();
  1489. int j=patent.get(1).getId();
  1490. int k=patent.get(2).getId();
  1491. map.put("frontID",i);
  1492. map.put("currentID",j);
  1493. map.put("behindID",k);
  1494. map.put("frontPatentNo",str1);
  1495. map.put("currentPatentNo",str2);
  1496. map.put("behindPatentNo",str3);
  1497. map.put("totalNumber",totalNumber);
  1498. int behindNumber=totalNumber-location;
  1499. int frontNumber=location-1;
  1500. map.put("behindNumber",behindNumber);
  1501. map.put("frontNumber",frontNumber);
  1502. return Response.success(map);
  1503. }
  1504. }