PatentService.java 94 KB

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