PatentService.java 101 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527
  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. patentDTO.setAffair(patentAffairService.getPatentAffairByPatentId(item.getId()));
  491. if (StringUtils.isNotEmpty(item.getAgencyId())) {
  492. patentDTO.setAgency(patentAgencyList.stream().filter(patentAgency -> patentAgency.getId().equals(Integer.parseInt(item.getAgencyId()))).findFirst().orElse(null));
  493. }
  494. PatentDTO.PatentFamily patentFamily = new PatentDTO.PatentFamily();
  495. patentFamily.setSimple(patentSimpleFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getSimpleFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  496. patentFamily.setInpadoc(patentInpadocFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getInpadocFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  497. patentFamily.setPatSnap(patentPatSnapFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getPatSnapFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  498. patentDTO.setFamily(patentFamily);
  499. patentDTO.setAgent(patentAgentList.stream().filter(patentAgent -> patentAgent.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  500. // TODO 性能优化
  501. patentDTO.setField(projectFieldService.getPatentFieldByPatentIdAndProjectId(params.getProjectId(), item.getId()));
  502. records.add(patentDTO);
  503. });
  504. pageList.setTotal(dataPage.getTotal());
  505. pageList.setRecords(records);
  506. pageList.setPages(dataPage.getPages());
  507. pageList.setSize(dataPage.getSize());
  508. pageList.setCurrent(dataPage.getCurrent());
  509. return pageList;
  510. }
  511. public List<PatentDTO> getPatentDTOListForRMS(PatentVO params) {
  512. List<PatentDTO> records = new ArrayList<>();
  513. if(params.getPatentNos()==null||params.getPatentNos().size()==0){
  514. return records;
  515. }
  516. List<Patent> dataPage = baseMapper.getPatent(params.getPatentNos(),-1,-1);
  517. List<Integer> patentIds = dataPage.stream().map(Patent::getId).collect(Collectors.toList());
  518. List<PatentApplicant> patentApplicantList = patentApplicantService.getPatentApplicantByPatentIds(patentIds);
  519. List<PatentInventor> patentInventorList = patentInventorService.getPatentInventorByPatentIds(patentIds);
  520. List<PatentClassNumberLink> patentClassNumberLinkList = patentClassNumberLinkService.getPatentClassNumberLinkByPatentIds(patentIds);
  521. List<PatentAgent> patentAgentList = patentAgentService.getPatentAgentByPatentIds(patentIds);
  522. List<PatentAgency> patentAgencyList = patentAgencyService.getPatentAgencyByIds(dataPage.stream().filter(item -> StringUtils.isNotEmpty(item.getAgencyId())).map(item -> Integer.parseInt(item.getAgencyId())).distinct().collect(Collectors.toList()));
  523. List<PatentSimpleFamilyLink> patentSimpleFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.stream().map(Patent::getSimpleFamily).collect(Collectors.toList()));
  524. List<PatentSimpleFamilyLink> patentInpadocFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.stream().map(Patent::getInpadocFamily).collect(Collectors.toList()));
  525. List<PatentSimpleFamilyLink> patentPatSnapFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.stream().map(Patent::getPatSnapFamily).collect(Collectors.toList()));
  526. List<SystemDict> systemDictList = systemDictService.getSystemDictListByType(Arrays.asList(Constants.PATENT_TYPE, Constants.PATENT_SIMPLE_STATUS));
  527. dataPage.forEach(item -> {
  528. PatentDTO patentDTO = new PatentDTO();
  529. BeanUtils.copyProperties(item, patentDTO);
  530. patentDTO.setApplicationDate(DateUtils.formatDate(item.getApplicationDate(), DateUtils.YYYY_MM_DD));
  531. patentDTO.setPriorityDate(DateUtils.formatDate(item.getPriorityDate(), DateUtils.YYYY_MM_DD));
  532. patentDTO.setPublicDate(DateUtils.formatDate(item.getPublicDate(), DateUtils.YYYY_MM_DD));
  533. patentDTO.setPublicAccreditDate(DateUtils.formatDate(item.getPublicAccreditDate(), DateUtils.YYYY_MM_DD));
  534. patentDTO.setFirstPublicDate(DateUtils.formatDate(item.getFirstPublicDate(), DateUtils.YYYY_MM_DD));
  535. 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());
  536. patentDTO.setSimpleStatusInt(item.getSimpleStatus());
  537. patentDTO.setType(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.PATENT_TYPE) && systemDict.getValue().equals(String.valueOf(item.getType()))).findFirst().orElse(new SystemDict()).getLabel());
  538. patentDTO.setApplicant(patentApplicantList.stream().filter(patentApplicant -> patentApplicant.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  539. patentDTO.setInventor(patentInventorList.stream().filter(patentInventor -> patentInventor.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  540. 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()));
  541. 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()));
  542. 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()));
  543. 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()));
  544. if (StringUtils.isNotEmpty(item.getAgencyId())) {
  545. patentDTO.setAgency(patentAgencyList.stream().filter(patentAgency -> patentAgency.getId().equals(Integer.parseInt(item.getAgencyId()))).findFirst().orElse(null));
  546. }
  547. PatentDTO.PatentFamily patentFamily = new PatentDTO.PatentFamily();
  548. patentFamily.setSimple(patentSimpleFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getSimpleFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  549. patentFamily.setInpadoc(patentInpadocFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getInpadocFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  550. patentFamily.setPatSnap(patentPatSnapFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getPatSnapFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  551. patentDTO.setFamily(patentFamily);
  552. patentDTO.setAffair(patentAffairService.getPatentAffairByPatentId(item.getId()));
  553. patentDTO.setAgent(patentAgentList.stream().filter(patentAgent -> patentAgent.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  554. // TODO 性能优化
  555. records.add(patentDTO);
  556. });
  557. return records;
  558. }
  559. //查询对比文件信息
  560. public List<PatentDTO> getRmsComparePatent(PatentVO params) {
  561. List<Patent> dataPage = baseMapper.getPatent(params.getPatentNos(),-1,-1);
  562. List<PatentDTO> records = new ArrayList<>();
  563. List<Integer> patentIds = dataPage.stream().map(Patent::getId).collect(Collectors.toList());
  564. List<PatentApplicant> patentApplicantList = patentApplicantService.getPatentApplicantByPatentIds(patentIds);
  565. List<PatentInventor> patentInventorList = patentInventorService.getPatentInventorByPatentIds(patentIds);
  566. List<PatentClassNumberLink> patentClassNumberLinkList = patentClassNumberLinkService.getPatentClassNumberLinkByPatentIds(patentIds);
  567. List<PatentAgent> patentAgentList = patentAgentService.getPatentAgentByPatentIds(patentIds);
  568. List<PatentAgency> patentAgencyList = patentAgencyService.getPatentAgencyByIds(dataPage.stream().filter(item -> StringUtils.isNotEmpty(item.getAgencyId())).map(item -> Integer.parseInt(item.getAgencyId())).distinct().collect(Collectors.toList()));
  569. List<PatentSimpleFamilyLink> patentSimpleFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.stream().map(Patent::getSimpleFamily).collect(Collectors.toList()));
  570. List<PatentSimpleFamilyLink> patentInpadocFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.stream().map(Patent::getInpadocFamily).collect(Collectors.toList()));
  571. List<PatentSimpleFamilyLink> patentPatSnapFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(dataPage.stream().map(Patent::getPatSnapFamily).collect(Collectors.toList()));
  572. List<SystemDict> systemDictList = systemDictService.getSystemDictListByType(Arrays.asList(Constants.PATENT_TYPE, Constants.PATENT_SIMPLE_STATUS));
  573. dataPage.forEach(item -> {
  574. PatentDTO patentDTO = new PatentDTO();
  575. BeanUtils.copyProperties(item, patentDTO);
  576. patentDTO.setApplicationDate(DateUtils.formatDate(item.getApplicationDate(), DateUtils.YYYY_MM_DD));
  577. patentDTO.setPriorityDate(DateUtils.formatDate(item.getPriorityDate(), DateUtils.YYYY_MM_DD));
  578. patentDTO.setPublicDate(DateUtils.formatDate(item.getPublicDate(), DateUtils.YYYY_MM_DD));
  579. patentDTO.setPublicAccreditDate(DateUtils.formatDate(item.getPublicAccreditDate(), DateUtils.YYYY_MM_DD));
  580. patentDTO.setFirstPublicDate(DateUtils.formatDate(item.getFirstPublicDate(), DateUtils.YYYY_MM_DD));
  581. 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());
  582. patentDTO.setSimpleStatusInt(item.getSimpleStatus());
  583. patentDTO.setType(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.PATENT_TYPE) && systemDict.getValue().equals(String.valueOf(item.getType()))).findFirst().orElse(new SystemDict()).getLabel());
  584. patentDTO.setApplicant(patentApplicantList.stream().filter(patentApplicant -> patentApplicant.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  585. patentDTO.setInventor(patentInventorList.stream().filter(patentInventor -> patentInventor.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  586. 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()));
  587. 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()));
  588. 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()));
  589. 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()));
  590. if (StringUtils.isNotEmpty(item.getAgencyId())) {
  591. patentDTO.setAgency(patentAgencyList.stream().filter(patentAgency -> patentAgency.getId().equals(Integer.parseInt(item.getAgencyId()))).findFirst().orElse(null));
  592. }
  593. PatentDTO.PatentFamily patentFamily = new PatentDTO.PatentFamily();
  594. patentFamily.setSimple(patentSimpleFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getSimpleFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  595. patentFamily.setInpadoc(patentInpadocFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getInpadocFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  596. patentFamily.setPatSnap(patentPatSnapFamilyLinkList.stream().filter(patentSimpleFamilyLink -> patentSimpleFamilyLink.getFamilyId().equals(item.getPatSnapFamily())).map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()));
  597. patentDTO.setFamily(patentFamily);
  598. patentDTO.setAffair(patentAffairService.getPatentAffairByPatentId(item.getId()));
  599. patentDTO.setAgent(patentAgentList.stream().filter(patentAgent -> patentAgent.getPatentId().equals(item.getId())).collect(Collectors.toList()));
  600. // TODO 性能优化
  601. records.add(patentDTO);
  602. });
  603. return records;
  604. }
  605. // 获得对比专利号
  606. public String getComPantentNos(QueryPatentVO params){
  607. List<String> patents = baseMapper.getListForRMS(params);
  608. return Response.success(patents);
  609. }
  610. // 获得带筛选条件的对比专利号
  611. public String getConPantentNos(QueryPatentVO params){
  612. List<String> patents = baseMapper.getConPantentNos(params);
  613. return Response.success(patents);
  614. }
  615. public PatentDTO getPatentDTOById(Integer id, Integer projectId) {
  616. Patent patent = baseMapper.selectById(id);
  617. PatentDTO patentDTO = new PatentDTO();
  618. BeanUtils.copyProperties(patent, patentDTO);
  619. List<SystemDict> systemDictList = systemDictService.getSystemDictListByType(Arrays.asList(Constants.PATENT_TYPE, Constants.PATENT_SIMPLE_STATUS, Constants.COUNTRIES));
  620. List<PatentClassNumberLink> patentClassNumberLinkList = patentClassNumberLinkService.getPatentClassNumberLinkByPatentIds(Collections.singletonList(id));
  621. if (patent.getPriorityNo() != null) {
  622. patentDTO.setPriorityNo(patent.getPriorityNo());
  623. } else {
  624. patentDTO.setPriorityNo("");
  625. }
  626. if (patent.getPriorityCountry() != null) {
  627. if (patent.getPriorityCountry().contains("\\|")) {
  628. List<String> countryList = StringUtils.changeStringToString(patent.getPriorityCountry().replaceAll(" ", ""), "\\|");
  629. patentDTO.setPriorityCountry(countryList);
  630. } else if (patent.getPriorityCountry().contains(",")) {
  631. List<String> countryList = StringUtils.changeStringToString(patent.getPriorityCountry().replaceAll(" ", ""), ",");
  632. patentDTO.setPriorityCountry(countryList);
  633. } else if (patent.getPriorityCountry().contains(";")) {
  634. List<String> countryList = StringUtils.changeStringToString(patent.getPriorityCountry().replaceAll(" ", ""), ";");
  635. patentDTO.setPriorityCountry(countryList);
  636. }
  637. } else {
  638. patentDTO.setPriorityCountry(Collections.singletonList(""));
  639. }
  640. patentDTO.setApplicationDate(DateUtils.formatDate(patent.getApplicationDate(), DateUtils.YYYY_MM_DD));
  641. patentDTO.setPriorityDate(DateUtils.formatDate(patent.getPriorityDate(), DateUtils.YYYY_MM_DD));
  642. patentDTO.setPublicDate(DateUtils.formatDate(patent.getPublicDate(), DateUtils.YYYY_MM_DD));
  643. patentDTO.setPublicAccreditDate(DateUtils.formatDate(patent.getPublicAccreditDate(), DateUtils.YYYY_MM_DD));
  644. patentDTO.setFirstPublicDate(DateUtils.formatDate(patent.getFirstPublicDate(), DateUtils.YYYY_MM_DD));
  645. 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());
  646. patentDTO.setType(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.PATENT_TYPE) && systemDict.getValue().equals(String.valueOf(patent.getType()))).findFirst().orElse(new SystemDict()).getLabel());
  647. patentDTO.setLabel(patentLabelService.getPatentLabelByPatentIdAndProjectId(patent.getId(), projectId));
  648. patentDTO.setApplicant(patentApplicantService.getPatentApplicantByPatentId(patent.getId()));
  649. patentDTO.setInventor(patentInventorService.getPatentInventorByPatentId(patent.getId()));
  650. if (StringUtils.isNotEmpty(patent.getAgencyId())) {
  651. patentDTO.setAgency(patentAgencyService.getPatentAgencyById(Integer.parseInt(patent.getAgencyId())));
  652. } else {
  653. PatentAgency patentAgency = new PatentAgency();
  654. patentAgency.setName("");
  655. patentDTO.setAgency(patentAgency);
  656. }
  657. patentDTO.setAgent(patentAgentService.getPatentAgentByPatentId(patent.getId()));
  658. patentDTO.setAffair(patentAffairService.getPatentAffairByPatentId(patent.getId()));
  659. if (projectId != null) {
  660. patentDTO.setField(projectFieldService.getPatentFieldByPatentIdAndProjectId(projectId, patent.getId()));
  661. }
  662. if (StringUtils.isNotEmpty(patent.getPriorityCountry())) {
  663. List<String> priorityList = PatentUtils.formatValue(patent.getPriorityCountry());
  664. List<String> priorityCountryList = new ArrayList<>();
  665. for (String priorityCountry : priorityList) {
  666. priorityCountryList.add(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.COUNTRIES) && systemDict.getValue().equals(priorityCountry)).findFirst().orElse(new SystemDict()).getLabel());
  667. }
  668. patentDTO.setPriorityCountry(priorityCountryList);
  669. }
  670. patentDTO.setInstruction(patentInstructionTextService.getPatentInstructionTextByPatentId(patent.getId()));
  671. patentDTO.setRights(patentRightService.getPatentRightByPatentId(patent.getId()));
  672. patentDTO.setImage(patentImageService.getPatentImageByPatentId(patent.getId()));
  673. patentDTO.setPdf(patentInstructionService.getPatentInstructionByPatentNo(patent.getPatentNo()));
  674. patentDTO.setIpc(patentClassNumberLinkList.stream().filter(patentClassNumberLink -> patentClassNumberLink.getType().equals(Constants.PATENT_CLASS_NUMBER_IPC) && patentClassNumberLink.getMain().equals(1)).findFirst().orElse(new PatentClassNumberLink()).getCode());
  675. patentDTO.setUpc(patentClassNumberLinkList.stream().filter(patentClassNumberLink -> patentClassNumberLink.getType().equals(Constants.PATENT_CLASS_NUMBER_UPC) && patentClassNumberLink.getMain().equals(1)).findFirst().orElse(new PatentClassNumberLink()).getCode());
  676. patentDTO.setIpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_IPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  677. patentDTO.setCpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_CPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  678. patentDTO.setUpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_UPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  679. patentDTO.setLocList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_LOC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  680. return patentDTO;
  681. }
  682. public PatentDTO getPatentDTOById(String patentNo) {
  683. LambdaQueryWrapper<Patent> wrapper = new LambdaQueryWrapper<>();
  684. wrapper.eq(Patent::getPatentNo, patentNo);
  685. List<Patent> patents =this.list(wrapper);
  686. PatentDTO patentDTO = new PatentDTO();
  687. //如果未查出专利则返回为空
  688. if (patents ==null||patents.size()==0) {
  689. return patentDTO;
  690. }
  691. Patent patent = patents.get(0);
  692. BeanUtils.copyProperties(patent, patentDTO);
  693. List<SystemDict> systemDictList = systemDictService.getSystemDictListByType(Arrays.asList(Constants.PATENT_TYPE, Constants.PATENT_SIMPLE_STATUS, Constants.COUNTRIES));
  694. List<PatentClassNumberLink> patentClassNumberLinkList = patentClassNumberLinkService.getPatentClassNumberLinkByPatentIds(Collections.singletonList(patent.getId()));
  695. if (patent.getPriorityNo() != null) {
  696. patentDTO.setPriorityNo(patent.getPriorityNo());
  697. } else {
  698. patentDTO.setPriorityNo("");
  699. }
  700. if (patent.getPriorityCountry() != null) {
  701. if (patent.getPriorityCountry().contains("\\|")) {
  702. List<String> countryList = StringUtils.changeStringToString(patent.getPriorityCountry().replaceAll(" ", ""), "\\|");
  703. patentDTO.setPriorityCountry(countryList);
  704. } else if (patent.getPriorityCountry().contains(",")) {
  705. List<String> countryList = StringUtils.changeStringToString(patent.getPriorityCountry().replaceAll(" ", ""), ",");
  706. patentDTO.setPriorityCountry(countryList);
  707. } else if (patent.getPriorityCountry().contains(";")) {
  708. List<String> countryList = StringUtils.changeStringToString(patent.getPriorityCountry().replaceAll(" ", ""), ";");
  709. patentDTO.setPriorityCountry(countryList);
  710. }
  711. } else {
  712. patentDTO.setPriorityCountry(Collections.singletonList(""));
  713. }
  714. patentDTO.setQuote("");
  715. if(patent.getQuote()!=null){
  716. patentDTO.setQuote(patent.getQuote());
  717. }
  718. patentDTO.setQuoted("");
  719. if(patent.getQuoted()!=null){
  720. patentDTO.setQuoted(patent.getQuoted());
  721. }
  722. //根据同族号,获得所有同族专利(三种同族)
  723. List<Integer> familyIds= new ArrayList<>();
  724. if(patent.getSimpleFamily()!=null)
  725. {familyIds.add(patent.getSimpleFamily());}
  726. if(patent.getInpadocFamily()!=null){
  727. familyIds.add(patent.getInpadocFamily());
  728. }
  729. if(patent.getPatSnapFamily()!=null){
  730. familyIds.add(patent.getPatSnapFamily());
  731. }
  732. if(familyIds.size()!=0) {
  733. LambdaQueryWrapper<PatentSimpleFamilyLink> queryWrapper = new LambdaQueryWrapper<>();
  734. queryWrapper.in(PatentSimpleFamilyLink::getFamilyId, familyIds);
  735. List<PatentSimpleFamilyLink> patentSimpleFamilyLinks = patentSimpleFamilyLinkService.list(queryWrapper);
  736. List<String> familyPatentNos = patentSimpleFamilyLinks.stream().map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList());
  737. PatentDTO.PatentFamily patentFamily =new PatentDTO.PatentFamily();
  738. patentFamily.setSimple(familyPatentNos);
  739. patentDTO.setFamily(patentFamily);
  740. }
  741. patentDTO.setApplicationDate(DateUtils.formatDate(patent.getApplicationDate(), DateUtils.YYYY_MM_DD));
  742. patentDTO.setPriorityDate(DateUtils.formatDate(patent.getPriorityDate(), DateUtils.YYYY_MM_DD));
  743. patentDTO.setPublicDate(DateUtils.formatDate(patent.getPublicDate(), DateUtils.YYYY_MM_DD));
  744. patentDTO.setPublicAccreditDate(DateUtils.formatDate(patent.getPublicAccreditDate(), DateUtils.YYYY_MM_DD));
  745. patentDTO.setFirstPublicDate(DateUtils.formatDate(patent.getFirstPublicDate(), DateUtils.YYYY_MM_DD));
  746. 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());
  747. patentDTO.setSimpleStatusInt(patent.getSimpleStatus());
  748. patentDTO.setType(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.PATENT_TYPE) && systemDict.getValue().equals(String.valueOf(patent.getType()))).findFirst().orElse(new SystemDict()).getLabel());
  749. patentDTO.setApplicant(patentApplicantService.getPatentApplicantByPatentId(patent.getId()));
  750. patentDTO.setInventor(patentInventorService.getPatentInventorByPatentId(patent.getId()));
  751. if (StringUtils.isNotEmpty(patent.getAgencyId())) {
  752. patentDTO.setAgency(patentAgencyService.getPatentAgencyById(Integer.parseInt(patent.getAgencyId())));
  753. } else {
  754. PatentAgency patentAgency = new PatentAgency();
  755. patentAgency.setName("");
  756. patentDTO.setAgency(patentAgency);
  757. }
  758. patentDTO.setAgent(patentAgentService.getPatentAgentByPatentId(patent.getId()));
  759. patentDTO.setAffair(patentAffairService.getPatentAffairByPatentId(patent.getId()));
  760. if (StringUtils.isNotEmpty(patent.getPriorityCountry())) {
  761. List<String> priorityList = PatentUtils.formatValue(patent.getPriorityCountry());
  762. List<String> priorityCountryList = new ArrayList<>();
  763. for (String priorityCountry : priorityList) {
  764. priorityCountryList.add(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.COUNTRIES) && systemDict.getValue().equals(priorityCountry)).findFirst().orElse(new SystemDict()).getLabel());
  765. }
  766. patentDTO.setPriorityCountry(priorityCountryList);
  767. }
  768. patentDTO.setInstruction(patentInstructionTextService.getPatentInstructionTextByPatentId(patent.getId()));
  769. patentDTO.setRights(patentRightService.getPatentRightByPatentId(patent.getId()));
  770. patentDTO.setImage(patentImageService.getPatentImageByPatentId(patent.getId()));
  771. patentDTO.setPdf(patentInstructionService.getPatentInstructionByPatentNo(patent.getPatentNo()));
  772. patentDTO.setIpc(patentClassNumberLinkList.stream().filter(patentClassNumberLink -> patentClassNumberLink.getType().equals(Constants.PATENT_CLASS_NUMBER_IPC) && patentClassNumberLink.getMain().equals(1)).findFirst().orElse(new PatentClassNumberLink()).getCode());
  773. patentDTO.setUpc(patentClassNumberLinkList.stream().filter(patentClassNumberLink -> patentClassNumberLink.getType().equals(Constants.PATENT_CLASS_NUMBER_UPC) && patentClassNumberLink.getMain().equals(1)).findFirst().orElse(new PatentClassNumberLink()).getCode());
  774. patentDTO.setIpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_IPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  775. patentDTO.setCpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_CPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  776. patentDTO.setUpcList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_UPC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  777. patentDTO.setLocList(patentClassNumberLinkList.stream().filter(patentClassNumber -> patentClassNumber.getType().equals(Constants.PATENT_CLASS_NUMBER_LOC)).map(PatentClassNumberLink::getCode).distinct().collect(Collectors.toList()));
  778. return patentDTO;
  779. }
  780. public List<Integer> getQueryPatentIds(PatentVO params) {
  781. if (params.getSelected() != null && params.getSelected().size() != 0 && params.getSelectId() != null && params.getSelectId()) {
  782. return params.getSelected().stream().distinct().collect(Collectors.toList());
  783. }
  784. this.setQueryPatentParams(params);
  785. List<Patent> patentList = baseMapper.getPageList(params);
  786. return patentList.stream().map(Patent::getId).distinct().collect(Collectors.toList());
  787. }
  788. @Async
  789. public void exportPatent(TaskParams taskParams) {
  790. try {
  791. List<PatentExportVO> selected = JsonUtils.jsonToList(taskParams.getSelected(), PatentExportVO.class);
  792. List<Integer> ids = StringUtils.changeStringToInteger(taskParams.getIds(), ",");
  793. if (selected != null) {
  794. List<String> columns = selected.stream().filter(PatentExportVO::getSelected).map(PatentExportVO::getKey).distinct().collect(Collectors.toList());
  795. List<String> headers = selected.stream().filter(PatentExportVO::getSelected).map(PatentExportVO::getName).distinct().collect(Collectors.toList());
  796. String fileName = IdUtil.simpleUUID() + ".xls";
  797. String directoryName = fileUtils.createDirectory();
  798. String savePath = fileUtils.getSavePath(directoryName);
  799. HSSFWorkbook hssfWorkbook = new HSSFWorkbook();
  800. HSSFSheet sheet = hssfWorkbook.createSheet();
  801. sheet.setDefaultColumnWidth(30);
  802. HSSFRow headerRow = sheet.createRow(0);
  803. headerRow.setHeight((short) 500);
  804. HSSFCellStyle headerCellStyle = hssfWorkbook.createCellStyle();
  805. HSSFCellStyle commonCellStyle = hssfWorkbook.createCellStyle();
  806. for (int i = 0; i < headers.size(); i++) {
  807. HSSFCell cell = headerRow.createCell(i);
  808. ExcelUtils.setExcelCellStyle(headerCellStyle);
  809. headerCellStyle.setAlignment(HorizontalAlignment.CENTER);
  810. headerCellStyle.setVerticalAlignment(VerticalAlignment.CENTER);
  811. headerCellStyle.setFillForegroundColor(HSSFColor.HSSFColorPredefined.SKY_BLUE.getIndex());
  812. headerCellStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
  813. headerCellStyle.setWrapText(true);
  814. cell.setCellStyle(headerCellStyle);
  815. cell.setCellValue(headers.get(i));
  816. }
  817. for (int i = 0; i < ids.size(); i++) {
  818. Map<String, Object> map = new LinkedHashMap<>();
  819. PatentDTO patent = this.getPatentDTOById(ids.get(i), taskParams.getProjectId());
  820. if (patent == null) {
  821. continue;
  822. }
  823. String country = PatentUtils.getPatentCountry(patent.getPatentNo());
  824. for (int j = 0; j < columns.size(); j++) {
  825. String column = columns.get(j);
  826. PatentExportVO patentExportVO = selected.stream().filter(item -> item.getKey().equals(column)).findFirst().orElse(new PatentExportVO());
  827. Object value = null;
  828. switch (column) {
  829. case "pname":
  830. value = patent.getName();
  831. break;
  832. case "pname_out":
  833. value = patent.getNameOut();
  834. break;
  835. case "patentno":
  836. value = patent.getPatentNo();
  837. break;
  838. case "abstract":
  839. value = patent.getAbstractStr();
  840. break;
  841. case "abstract_out":
  842. value = patent.getAbstractOut();
  843. break;
  844. case "abstract_path":
  845. break;
  846. case "applicationno":
  847. value = patent.getApplicationNo();
  848. break;
  849. case "appdate":
  850. value = patent.getApplicationDate();
  851. break;
  852. case "publicno":
  853. value = patent.getPublicNo();
  854. break;
  855. case "publicdate":
  856. value = patent.getPublicDate();
  857. break;
  858. case "fpublicdate":
  859. value = patent.getFirstPublicDate();
  860. break;
  861. case "publictono":
  862. value = patent.getPublicAccreditNo();
  863. break;
  864. case "publictodate":
  865. value = patent.getPublicAccreditDate();
  866. break;
  867. case "tags":
  868. value = StringUtils.join(patent.getLabel().stream().map(PatentLabel::getName).distinct().collect(Collectors.toList()), "\n");
  869. break;
  870. case "bureau":
  871. value = patent.getBureau();
  872. break;
  873. case "simplefamily":
  874. List<PatentSimpleFamilyLink> patentSimpleFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(Collections.singletonList(patent.getSimpleFamily()));
  875. value = StringUtils.join(patentSimpleFamilyLinkList.stream().map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()), Constants.SEPARATOR_VERTICAL_BAR);
  876. break;
  877. case "inpadocfamily":
  878. List<PatentSimpleFamilyLink> patentInpadocFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(Collections.singletonList(patent.getInpadocFamily()));
  879. value = StringUtils.join(patentInpadocFamilyLinkList.stream().map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()), Constants.SEPARATOR_VERTICAL_BAR);
  880. break;
  881. case "patsnapfamily":
  882. List<PatentSimpleFamilyLink> patentPatSnapFamilyLinkList = patentSimpleFamilyLinkService.getPatentSimpleFamilyLinkByFamilyIds(Collections.singletonList(patent.getPatSnapFamily()));
  883. value = StringUtils.join(patentPatSnapFamilyLinkList.stream().map(PatentSimpleFamilyLink::getPatentNo).collect(Collectors.toList()), Constants.SEPARATOR_VERTICAL_BAR);
  884. break;
  885. case "ipc":
  886. value = StringUtils.join(patent.getIpcList(), Constants.SEPARATOR_VERTICAL_BAR);
  887. break;
  888. case "upc":
  889. value = StringUtils.join(patent.getUpcList(), Constants.SEPARATOR_VERTICAL_BAR);
  890. break;
  891. case "intclassno":
  892. value = patent.getIpc();
  893. break;
  894. case "intclasscpcno":
  895. value = StringUtils.join(patent.getCpcList(), Constants.SEPARATOR_VERTICAL_BAR);
  896. break;
  897. case "intclassupcno":
  898. value = patent.getUpc();
  899. break;
  900. case "intclasslocno":
  901. value = StringUtils.join(patent.getLocList(), Constants.SEPARATOR_VERTICAL_BAR);
  902. break;
  903. case "pstatus":
  904. value = patent.getSimpleStatus();
  905. break;
  906. case "ptype":
  907. value = patent.getType();
  908. break;
  909. case "law_datetime":
  910. value = PatentUtils.getPatentAffair(patent.getAffair(), 0);
  911. break;
  912. case "law_status":
  913. value = PatentUtils.getPatentAffair(patent.getAffair(), 1);
  914. break;
  915. case "law_simplestatus":
  916. value = PatentUtils.getPatentAffair(patent.getAffair(), 2);
  917. break;
  918. case "law_content":
  919. value = PatentUtils.getPatentAffair(patent.getAffair(), 3);
  920. break;
  921. case "applicant":
  922. 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);
  923. break;
  924. case "applicant1":
  925. 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);
  926. break;
  927. case "rightholder":
  928. 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);
  929. break;
  930. case "rightholder1":
  931. 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);
  932. break;
  933. case "applicantcountry":
  934. value = PatentUtils.getPeopleCountry(patent.getApplicant().stream().filter(item -> item.getDataType().equals(2)).collect(Collectors.toList()));
  935. break;
  936. case "rightholdercountry":
  937. value = PatentUtils.getPeopleCountry(patent.getApplicant().stream().filter(item -> item.getDataType().equals(1)).collect(Collectors.toList()));
  938. break;
  939. case "applicantaddress":
  940. value = PatentUtils.getPeopleAddress(patent.getApplicant().stream().filter(item -> item.getDataType().equals(2)).collect(Collectors.toList()));
  941. break;
  942. case "rightholderaddress":
  943. value = PatentUtils.getPeopleAddress(patent.getApplicant().stream().filter(item -> item.getDataType().equals(1)).collect(Collectors.toList()));
  944. break;
  945. case "applicantaddr":
  946. break;
  947. case "rightholderaddr":
  948. break;
  949. case "firstapplicant":
  950. PatentApplicant firstApplicant1 = patent.getApplicant().stream().filter(item -> item.getDataType().equals(2) && item.getOrder().equals(0)).findFirst().orElse(null);
  951. if (firstApplicant1 != null) {
  952. value = firstApplicant1.getName();
  953. }
  954. break;
  955. case "firstrightholder":
  956. PatentApplicant firstApplicant3 = patent.getApplicant().stream().filter(item -> item.getDataType().equals(1) && item.getOrder().equals(0)).findFirst().orElse(null);
  957. if (firstApplicant3 != null) {
  958. value = firstApplicant3.getName();
  959. }
  960. break;
  961. case "firstapplicantaddr":
  962. PatentApplicant firstApplicant2 = patent.getApplicant().stream().filter(item -> item.getDataType().equals(2) && item.getOrder().equals(0)).findFirst().orElse(null);
  963. if (firstApplicant2 != null) {
  964. value = firstApplicant2.getAddressStr();
  965. }
  966. break;
  967. case "firstrightholderaddr":
  968. PatentApplicant firstApplicant4 = patent.getApplicant().stream().filter(item -> item.getDataType().equals(1) && item.getOrder().equals(0)).findFirst().orElse(null);
  969. if (firstApplicant4 != null) {
  970. value = firstApplicant4.getAddressStr();
  971. }
  972. break;
  973. case "firstapplicantnum":
  974. value = patent.getApplicantNum();
  975. break;
  976. case "inventor":
  977. value = StringUtils.join(patent.getInventor().stream().map(PatentInventor::getName).distinct().collect(Collectors.toList()), Constants.SEPARATOR_VERTICAL_BAR);
  978. break;
  979. case "firstnventoraddr":
  980. value = patent.getInventor().stream().filter(PatentInventor::getFirst).findFirst().orElse(new PatentInventor()).getAddress();
  981. break;
  982. case "firstnventor":
  983. value = patent.getInventor().stream().filter(PatentInventor::getFirst).findFirst().orElse(new PatentInventor()).getName();
  984. break;
  985. case "inventornum":
  986. value = patent.getInventorNum();
  987. break;
  988. case "num2":
  989. value = patent.getRightNum();
  990. break;
  991. case "content":
  992. case "content_out":
  993. case "selfcontent":
  994. List<String> content = new ArrayList<>();
  995. if (column.equals("content")) {
  996. content = patent.getRights().stream().map(PatentRight::getContent).collect(Collectors.toList());
  997. }
  998. if (column.equals("content_out")) {
  999. content = patent.getRights().stream().map(PatentRight::getContentOut).collect(Collectors.toList());
  1000. }
  1001. if (column.equals("selfcontent")) {
  1002. content = patent.getRights().stream().filter(item -> item.getType().equals(1)).map(PatentRight::getContent).collect(Collectors.toList());
  1003. }
  1004. StringBuffer contentBuffer = new StringBuffer();
  1005. for (String s : content) {
  1006. contentBuffer.append(s);
  1007. switch (country) {
  1008. case "JP":
  1009. case "CN":
  1010. contentBuffer.append("。\n");
  1011. break;
  1012. default:
  1013. contentBuffer.append("\n");
  1014. }
  1015. }
  1016. value = contentBuffer.toString();
  1017. break;
  1018. case "priorityno":
  1019. value = patent.getPriorityNo();
  1020. break;
  1021. case "prioritycountry":
  1022. value = patent.getPriorityCountry();
  1023. break;
  1024. case "prioritydate":
  1025. value = patent.getPriorityDate();
  1026. break;
  1027. case "page":
  1028. value = patent.getDocPage();
  1029. break;
  1030. case "code":
  1031. value = patent.getCode();
  1032. break;
  1033. case "manual":
  1034. if (patent.getInstruction() != null) {
  1035. value = patent.getInstruction().getManual();
  1036. }
  1037. break;
  1038. case "simplefamilynum":
  1039. value = patent.getSimpleFamilyNum();
  1040. break;
  1041. case "inpadocfamilynum":
  1042. value = patent.getInpadocFamilyNum();
  1043. break;
  1044. case "patsnapfamilynum":
  1045. value = patent.getPatSnapFamilyNum();
  1046. break;
  1047. case "quoteno":
  1048. value = patent.getQuoteNum();
  1049. break;
  1050. case "quotedno":
  1051. value = patent.getQuotedNum();
  1052. break;
  1053. case "quotedno3":
  1054. value = patent.getQuotedNum3();
  1055. break;
  1056. case "quotedno5":
  1057. value = patent.getQuotedNum5();
  1058. break;
  1059. case "agency":
  1060. PatentAgency agency = patent.getAgency();
  1061. if (agency != null) {
  1062. value = agency.getName();
  1063. }
  1064. break;
  1065. case "agent":
  1066. value = StringUtils.join(patent.getAgent().stream().map(PatentAgent::getName).distinct().collect(Collectors.toList()), Constants.SEPARATOR_VERTICAL_BAR);
  1067. break;
  1068. case "wonational":
  1069. value = patent.getWo();
  1070. break;
  1071. case "examiner":
  1072. value = patent.getExaminer();
  1073. break;
  1074. case "assexaminer":
  1075. value = patent.getAidExaminer();
  1076. break;
  1077. case "quote":
  1078. value = patent.getQuote();
  1079. break;
  1080. case "quoted":
  1081. value = patent.getQuoted();
  1082. break;
  1083. case "nonpatentquote":
  1084. value = patent.getNotPatentQuote();
  1085. break;
  1086. case "epcountry":
  1087. value = patent.getEpStatus();
  1088. break;
  1089. default:
  1090. PatentDTO.Field field = patent.getField().stream().filter(item -> item.getId().equals(Integer.parseInt(column))).findFirst().orElse(null);
  1091. if (field != null) {
  1092. value = StringUtils.join(field.getSelected(), "\n");
  1093. }
  1094. }
  1095. map.put(patentExportVO.getName(), value);
  1096. }
  1097. HSSFRow row = sheet.createRow(i + 1);
  1098. row.setHeight((short) 800);
  1099. for (String key : map.keySet()) {
  1100. int index = headers.indexOf(key);
  1101. if (index != -1) {
  1102. HSSFCell cell = row.createCell(index);
  1103. ExcelUtils.setExcelCellStyle(commonCellStyle);
  1104. commonCellStyle.setVerticalAlignment(VerticalAlignment.TOP);
  1105. commonCellStyle.setWrapText(true);
  1106. cell.setCellStyle(commonCellStyle);
  1107. if (key.equals("摘要附图")) {
  1108. if (StringUtils.isNotEmpty(patent.getAbstractPath())) {
  1109. try {
  1110. byte[] pictureData = FileUtil.readBytes(fileUtils.getSystemPath(patent.getAbstractPath()));
  1111. if (pictureData != null) {
  1112. ExcelUtils.writePicture(sheet, index, i + 1, pictureData, HSSFWorkbook.PICTURE_TYPE_JPEG);
  1113. }
  1114. row.setHeight((short) 2500);
  1115. } catch (Exception e) {
  1116. }
  1117. }
  1118. } else if (StringUtils.isNotNull(map.get(key))) {
  1119. cell.setCellValue(String.valueOf(map.get(key)));
  1120. }
  1121. }
  1122. }
  1123. Integer total = ids.size();
  1124. WebSocketServer.sendInfo(Response.websocket(new TaskWebSocketDTO()
  1125. .setTaskId(taskParams.getTaskId())
  1126. .setProjectId(taskParams.getProjectId())
  1127. .setComplete(false)
  1128. .setIndex(i)
  1129. .setTaskType(Constants.TASK_EXPORT_PATENT)
  1130. .setPercentage(total == 0 ? 0 : Math.round((total.equals(i) ? (i * 1D) : (i + 1D)) / total * 100D))
  1131. .setFileName("")
  1132. .setOldName("")
  1133. .setUrl("")
  1134. .setTotal(total), ResponseEnum.PATENT_EXPORT_TASK_SUCCESS), taskParams.getUserId());
  1135. }
  1136. FileOutputStream fos = new FileOutputStream(savePath + fileName);
  1137. hssfWorkbook.write(fos);
  1138. fos.flush();
  1139. fos.close();
  1140. String url = fileUtils.getDirectory(fileName);
  1141. taskService.updateTime(taskParams.getTaskId(), 2, DateUtils.getDateTime(), url, fileName);
  1142. WebSocketServer.sendInfo(Response.websocket(new TaskWebSocketDTO()
  1143. .setTaskId(taskParams.getTaskId())
  1144. .setProjectId(taskParams.getProjectId())
  1145. .setComplete(true)
  1146. .setIndex(ids.size())
  1147. .setTaskType(Constants.TASK_EXPORT_PATENT)
  1148. .setPercentage(100L)
  1149. .setFileName(fileName)
  1150. .setOldName("")
  1151. .setUrl(url)
  1152. .setTotal(ids.size()), ResponseEnum.PATENT_EXPORT_TASK_SUCCESS), taskParams.getUserId());
  1153. }
  1154. } catch (Exception e) {
  1155. e.printStackTrace();
  1156. taskService.updateTime(taskParams.getTaskId(), 3, DateUtils.getDateTime(), null, null);
  1157. WebSocketServer.sendInfo(Response.error(ResponseEnum.PATENT_EXPORT_TASK_ERROR), taskParams.getUserId());
  1158. }
  1159. }
  1160. public IPage<PatentQueryFieldSourceDTO> getPatentQuerySourcePageList(PatentQueryFieldSourceVO params) {
  1161. return this.getPatentAttributeSourcePageList(params);
  1162. }
  1163. public IPage<PatentQueryFieldSourceDTO> getPatentAttributeSourcePageList(PatentQueryFieldSourceVO params) {
  1164. this.setPatentQuerySourceParams(params);
  1165. if (params.getKey().equals("40-0")) {
  1166. Integer projectId = params.getProjectId();
  1167. List<PatentQueryFieldSourceDTO> dataList = baseMapper.getCountStatus(projectId);
  1168. List<PatentQueryFieldSourceDTO> lstA = new ArrayList<>();
  1169. List<PatentQueryFieldSourceDTO> lstB = new ArrayList<>();
  1170. dataList.forEach(item -> {
  1171. if (StringUtils.changeStringToString(item.getLabel(), "\\|").size() > 1) {
  1172. lstA.add(item);
  1173. } else {
  1174. lstB.add(item);
  1175. }
  1176. });
  1177. lstA.forEach(item -> {
  1178. List<String> stringList = StringUtils.changeStringToString(item.getLabel(), "\\|");
  1179. stringList.forEach(x -> {
  1180. List<PatentQueryFieldSourceDTO> lstC = new ArrayList<>();
  1181. for (PatentQueryFieldSourceDTO patentQueryFieldSourceDTO : lstB) {
  1182. if (!lstB.stream().map(PatentQueryFieldSourceDTO::getLabel).collect(Collectors.toList()).contains(x)) {
  1183. PatentQueryFieldSourceDTO a = new PatentQueryFieldSourceDTO();
  1184. a.setCount(item.getCount());
  1185. a.setLabel(x);
  1186. lstC.add(a);
  1187. break;
  1188. }
  1189. if (patentQueryFieldSourceDTO.getLabel().equals(x)) {
  1190. patentQueryFieldSourceDTO.setCount(patentQueryFieldSourceDTO.getCount() + item.getCount());
  1191. }
  1192. }
  1193. lstB.addAll(lstC);
  1194. });
  1195. });
  1196. List<SystemDict> systemDictList = systemDictService.getSystemDictListByType(Collections.singletonList(Constants.PATENT_STATUS));
  1197. lstB.forEach(b -> {
  1198. Integer status = Integer.parseInt(systemDictList.stream()
  1199. .filter(systemDict -> systemDict.getType().equals(Constants.PATENT_STATUS) && systemDict.getLabel().equals(b.getLabel()))
  1200. .findFirst()
  1201. .orElse(new SystemDict()).getValue());
  1202. b.setValue(String.valueOf(status));
  1203. });
  1204. IPage<PatentQueryFieldSourceDTO> pageList = baseMapper.getPatentQuerySourcePageList(new Page<>(params.getCurrent(), params.getSize()), params, new ArrayList<>());
  1205. pageList.setRecords(lstB);
  1206. return pageList;
  1207. }
  1208. IPage<PatentQueryFieldSourceDTO> pageList = baseMapper.getPatentQuerySourcePageList(new Page<>(params.getCurrent(), params.getSize()), params, new ArrayList<>());
  1209. pageList.getRecords().forEach(item -> item.setIds(null));
  1210. return pageList;
  1211. }
  1212. public List<PatentQueryFieldSourceDTO> getPatentAttributeSourceList(PatentQueryFieldSourceVO params, List<Integer> patentIds) {
  1213. this.setPatentQuerySourceParams(params);
  1214. List<PatentQueryFieldSourceDTO> dataList = baseMapper.getPatentQuerySourcePageList(params, patentIds);
  1215. return dataList;
  1216. }
  1217. private void setPatentQuerySourceParams(PatentQueryFieldSourceVO params) {
  1218. List<Integer> field = StringUtils.changeStringToInteger(params.getKey(), "-");
  1219. Integer type = 0;
  1220. Integer level = 0;
  1221. Integer status = 0;
  1222. switch (params.getKey()) {
  1223. case "18-6":
  1224. case "18-7":
  1225. case "18-8":
  1226. case "23-6":
  1227. case "23-7":
  1228. case "23-8":
  1229. params.setApplicantType(2);
  1230. break;
  1231. case "19-6":
  1232. case "19-7":
  1233. case "19-8":
  1234. case "24-6":
  1235. case "24-7":
  1236. case "24-8":
  1237. params.setApplicantType(1);
  1238. break;
  1239. case "29-17":
  1240. case "30-17":
  1241. case "29-18":
  1242. case "29-19":
  1243. case "29-20":
  1244. case "30-18":
  1245. case "30-19":
  1246. case "30-20":
  1247. params.setApplicantType(field.get(0) == 29 ? 2 : 1);
  1248. break;
  1249. default:
  1250. params.setCustomFieldId(field.get(0));
  1251. if (params.getType().equals("6") && field.get(1).equals(0)) {
  1252. params.setCustomFieldTreeType(0);
  1253. } else {
  1254. params.setCustomFieldTreeType(null);
  1255. }
  1256. }
  1257. }
  1258. public void updatePatentCustomField(PatentCustomFieldParams params) {
  1259. List<CustomFieldDTO> dataList = new ArrayList<>();
  1260. for (String key : params.keySet()) {
  1261. List<String> fields = StringUtils.changeStringToString(key, ":");
  1262. if (fields.size() == 2) {
  1263. Object name = fields.get(0);
  1264. Object selected = params.get(key);
  1265. List<String> select = JsonUtils.jsonToList(JsonUtils.objectToJson(selected), String.class);
  1266. if (StringUtils.isNull(select)) {
  1267. select = new ArrayList<>();
  1268. }
  1269. CustomFieldDTO data = new CustomFieldDTO();
  1270. data.setName(name.toString());
  1271. data.setSelected(select);
  1272. data.setType(Integer.parseInt(fields.get(1)));
  1273. dataList.add(data);
  1274. }
  1275. }
  1276. for (CustomFieldDTO data : dataList) {
  1277. ProjectField projectField = projectFieldService.getProjectFieldByNameAndType(data.getName(), data.getType(), params.getProjectId(), params.getUserId());
  1278. projectFieldPatentLinkService.deleteByPatentIdAndProjectIdAndFieldId(params.getPatentId(), params.getProjectId(), projectField.getId());
  1279. switch (projectField.getType()) {
  1280. case 0:
  1281. case 1:
  1282. case 2:
  1283. for (String text : data.getSelected()) {
  1284. ProjectFieldText projectFieldText = projectFieldTextService.getProjectFieldTextByNameAndFieldId(text, projectField.getId());
  1285. if (projectFieldText == null) {
  1286. projectFieldText = new ProjectFieldText();
  1287. projectFieldText.setFieldId(projectField.getId());
  1288. projectFieldText.setText(text);
  1289. projectFieldText.insert();
  1290. }
  1291. projectFieldPatentLinkService.updateProjectPatentLink(params.getPatentId(), projectField.getType(), projectField.getId(), projectFieldText.getId(), params.getUserId(), params.getProjectId());
  1292. }
  1293. break;
  1294. case 3:
  1295. case 4:
  1296. case 5:
  1297. for (String option : data.getSelected()) {
  1298. ProjectFieldOption projectFieldOption = projectFieldOptionService.getProjectFieldOptionByNameAndFieldId(option, projectField.getId());
  1299. if (projectFieldOption == null) {
  1300. projectFieldOption = new ProjectFieldOption();
  1301. projectFieldOption.setFieldId(projectField.getId());
  1302. projectFieldOption.setName(option);
  1303. projectFieldOption.insert();
  1304. }
  1305. projectFieldPatentLinkService.updateProjectPatentLink(params.getPatentId(), projectField.getType(), projectField.getId(), projectFieldOption.getId(), params.getUserId(), params.getProjectId());
  1306. }
  1307. break;
  1308. case 6:
  1309. for (String tree : data.getSelected()) {
  1310. List<String> treeNode = StringUtils.changeStringToString(tree, "\\\\");
  1311. Integer treeNodeId = projectFieldTreeService.getTreeNodeIdByPathNameAndUpdateTreeData(treeNode, projectField);
  1312. if (treeNodeId != 0) {
  1313. projectFieldPatentLinkService.updateProjectPatentLink(params.getPatentId(), projectField.getType(), projectField.getId(), treeNodeId, params.getUserId(), params.getProjectId());
  1314. }
  1315. }
  1316. break;
  1317. }
  1318. }
  1319. }
  1320. public Map<String, Object> getBetweenPatentList(PatentVO params) {
  1321. this.setQueryPatentParams(params);
  1322. List<Patent> patentList = baseMapper.getPageList(params);
  1323. int index = patentList.stream().map(Patent::getId).collect(Collectors.toList()).indexOf(params.getPatentId());
  1324. Map<String, Object> map = new HashMap<>();
  1325. if (index > 0) {
  1326. Patent patent = patentList.get(index - 1);
  1327. Map<String, Object> prev = new HashMap<>();
  1328. prev.put("id", patent.getId());
  1329. prev.put("patentNo", patent.getPatentNo());
  1330. prev.put("total", index);
  1331. map.put("prev", prev);
  1332. }
  1333. if (index < patentList.size() - 1) {
  1334. Patent patent = patentList.get(index + 1);
  1335. Map<String, Object> next = new HashMap<>();
  1336. next.put("id", patent.getId());
  1337. next.put("patentNo", patent.getPatentNo());
  1338. next.put("total", patentList.size() - index - 1);
  1339. map.put("next", next);
  1340. }
  1341. return map;
  1342. }
  1343. 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) {
  1344. List<Patent> importPatentList = JsonUtils.jsonToList(patentJson, Patent.class);
  1345. List<PatentAffair> importPatentAffairList = JsonUtils.jsonToList(patentAffairJson, PatentAffair.class);
  1346. List<PatentAgency> importPatentAgencyList = JsonUtils.jsonToList(patentAgencyJson, PatentAgency.class);
  1347. List<PatentAgent> importPatentAgentList = JsonUtils.jsonToList(patentAgentJson, PatentAgent.class);
  1348. List<PatentAgentLink> importPatentAgentLinkList = JsonUtils.jsonToList(patentAgentLinkJson, PatentAgentLink.class);
  1349. List<PatentInventor> importPatentInventorList = JsonUtils.jsonToList(patentInventorJson, PatentInventor.class);
  1350. List<PatentInventorMerge> importPatentInventorMergeList = JsonUtils.jsonToList(patentInventorMergeJson, PatentInventorMerge.class);
  1351. List<PatentInventorLink> importPatentInventorLinkList = JsonUtils.jsonToList(patentInventorLinkJson, PatentInventorLink.class);
  1352. List<PatentApplicant> importPatentApplicantList = JsonUtils.jsonToList(patentApplicantJson, PatentApplicant.class);
  1353. List<PatentApplicantLink> importPatentApplicantLinkList = JsonUtils.jsonToList(patentApplicantLinkJson, PatentApplicantLink.class);
  1354. List<PatentApplicantMergeLink> importPatentApplicantMergeLinkList = JsonUtils.jsonToList(patentApplicantMergeLinkJson, PatentApplicantMergeLink.class);
  1355. List<PatentSimpleFamily> importPatentSimpleFamilyList = JsonUtils.jsonToList(patentFamilyJson, PatentSimpleFamily.class);
  1356. List<PatentSimpleFamilyLink> importPatentSimpleFamilyLinkList = JsonUtils.jsonToList(patentFamilyLinkJson, PatentSimpleFamilyLink.class);
  1357. List<PatentClassNumberLink> importPatentClassNumberLinkList = JsonUtils.jsonToList(patentClassNumberJson, PatentClassNumberLink.class);
  1358. List<PatentInstructionText> importPatentInstructionTextList = JsonUtils.jsonToList(patentInstructionTextJson, PatentInstructionText.class);
  1359. List<PatentRight> importPatentRightList = JsonUtils.jsonToList(patentRightJson, PatentRight.class);
  1360. List<PatentLicensor> importPatentLicensorList = JsonUtils.jsonToList(patentLicensorJson, PatentLicensor.class);
  1361. List<PatentPledge> importPatentPledgeList = JsonUtils.jsonToList(patentPledgeJson, PatentPledge.class);
  1362. List<Patent> localPatentList = this.getPatentListByPatentNo(importPatentList.stream().map(Patent::getPatentNo).collect(Collectors.toList()));
  1363. List<Patent> patentList = new ArrayList<>();
  1364. for (Patent importPatent : importPatentList) {
  1365. Patent localPatent = localPatentList.stream().filter(item -> item.getPatentNo().equals(importPatent.getPatentNo())).findFirst().orElse(null);
  1366. Integer patentId;
  1367. if (localPatent == null) {
  1368. localPatent = new Patent();
  1369. patentId = null;
  1370. } else {
  1371. patentId = localPatent.getId();
  1372. }
  1373. BeanUtils.copyProperties(importPatent, localPatent);
  1374. localPatent.setId(patentId);
  1375. if (StringUtils.isNotEmpty(importPatent.getAgencyId())) {
  1376. PatentAgency importPatentAgency = importPatentAgencyList.stream().filter(item -> item.getId().equals(Integer.valueOf(importPatent.getAgencyId()))).findFirst().orElse(new PatentAgency());
  1377. localPatent.setAgencyId(patentAgencyService.getAgencyStringIdByName(importPatentAgency.getName()));
  1378. }
  1379. localPatent.insertOrUpdate();
  1380. patentList.add(localPatent);
  1381. }
  1382. for (Patent patent : patentList) {
  1383. Patent importPatent = importPatentList.stream().filter(item -> item.getPatentNo().equals(patent.getPatentNo())).findFirst().orElse(new Patent());
  1384. patentAffairService.importPatentAffair(patent, importPatentList, importPatentAffairList);
  1385. patentAgentService.importPatentAgent(patent.getId(), importPatent.getId(), importPatentAgentList, importPatentAgentLinkList);
  1386. patentSimpleFamilyService.importPatentSimpleFamily(patent, importPatentSimpleFamilyList, importPatentSimpleFamilyLinkList);
  1387. patentInventorService.importPatentInventor(patent.getId(), importPatent.getId(), importPatentInventorList, importPatentInventorLinkList);
  1388. patentApplicantService.importPatentApplicant(projectId, patent.getId(), importPatent.getId(), importPatentApplicantList, importPatentApplicantLinkList);
  1389. patentClassNumberLinkService.importPatentClassNumberLink(patent.getId(), importPatent.getId(), importPatentClassNumberLinkList);
  1390. patentInstructionTextService.importPatentInstructionText(patent.getId(), importPatent.getId(), importPatentInstructionTextList);
  1391. patentRightService.importPatentRight(patent.getId(), importPatent.getId(), importPatentRightList);
  1392. patentLicensorService.importPatentLicensor(patent.getId(), importPatent.getId(), importPatentLicensorList);
  1393. patentPledgeService.importPatentPledge(patent.getId(), importPatent.getId(), importPatentPledgeList);
  1394. }
  1395. patentInventorMergeService.importPatentInventorMergeLink(projectId, importPatentInventorList, importPatentInventorMergeList);
  1396. patentApplicantMergeLinkService.importPatentApplicantMergeLink(projectId, importPatentApplicantList, importPatentApplicantMergeLinkList);
  1397. }
  1398. public String getPatentNos(Integer projectId) {
  1399. //根据专题库号获得专利id
  1400. LambdaQueryWrapper<ProjectPatentLink> wrapper = new LambdaQueryWrapper<>();
  1401. wrapper.select(ProjectPatentLink::getPatentId).eq(ProjectPatentLink::getProjectId, projectId);
  1402. List<ProjectPatentLink> projectPatentLinkList = projectPatentLinkService.list(wrapper);
  1403. List<Integer> patentIds = projectPatentLinkList.stream().map(ProjectPatentLink::getPatentId).collect(Collectors.toList());
  1404. //根据专利Id获得专利号
  1405. LambdaQueryWrapper<Patent> queryWrapper = new LambdaQueryWrapper<>();
  1406. queryWrapper.in(Patent::getId, patentIds);
  1407. List<Patent> patents = this.list(queryWrapper);
  1408. List<String> patentNos = patents.stream().map(Patent::getPatentNo).collect(Collectors.toList());
  1409. return Response.success(patentNos);
  1410. }
  1411. public String getPagination(List<String> list,int location){
  1412. Map map=new HashMap();
  1413. LambdaQueryWrapper<Patent> wrapper =new LambdaQueryWrapper<>();
  1414. wrapper.in(Patent::getPatentNo,list);
  1415. Integer totalNumber = Math.toIntExact(this.count(wrapper));
  1416. if(location>=totalNumber){
  1417. location=totalNumber;
  1418. int a=location-2;
  1419. int b=2;
  1420. List<Patent> patent = patentMapper.getPatent(list, a, b);
  1421. int front=location-1;
  1422. String str1 =patent.get(0).getPatentNo();
  1423. String srr2= patent.get(1).getPatentNo();
  1424. int i=patent.get(0).getId();
  1425. int j=patent.get(1).getId();
  1426. map.put("frontID",i);
  1427. map.put("currentID",j);
  1428. map.put("behindPatentNo",null);
  1429. map.put("frontNumber",front);
  1430. map.put("behindNumber",0);
  1431. map.put("frontPatentNo",str1);
  1432. map.put("currentPatentNo",srr2);
  1433. map.put("totalNumber",totalNumber);
  1434. return Response.success(map);
  1435. }
  1436. if(location==1){
  1437. int a=0;
  1438. int p=2;
  1439. List<Patent> patent = patentMapper.getPatent(list, a, p);
  1440. String str1 =patent.get(0).getPatentNo();
  1441. String srr2= patent.get(1).getPatentNo();
  1442. int i=patent.get(0).getId();
  1443. int j=patent.get(1).getId();
  1444. map.put("currentID",i);
  1445. map.put("behindID",j);
  1446. map.put("currentPatentNo",str1);
  1447. map.put("behindPatentNo",srr2);
  1448. map.put("frontPatentNo",null);
  1449. map.put("frontNumber",0);
  1450. int behindNumber=totalNumber-location;
  1451. map.put("behindNumber",behindNumber);
  1452. map.put("totalNumber",totalNumber);
  1453. return Response.success(map);
  1454. }
  1455. int a=location-2;
  1456. int p=3;
  1457. List<Patent> patent = patentMapper.getPatent(list, a, p);
  1458. String str1 =patent.get(0).getPatentNo();
  1459. String str2 =patent.get(1).getPatentNo();
  1460. String str3 =patent.get(2).getPatentNo();
  1461. int i=patent.get(0).getId();
  1462. int j=patent.get(1).getId();
  1463. int k=patent.get(2).getId();
  1464. map.put("frontID",i);
  1465. map.put("currentID",j);
  1466. map.put("behindID",k);
  1467. map.put("frontPatentNo",str1);
  1468. map.put("currentPatentNo",str2);
  1469. map.put("behindPatentNo",str3);
  1470. map.put("totalNumber",totalNumber);
  1471. int behindNumber=totalNumber-location;
  1472. int frontNumber=location-1;
  1473. map.put("behindNumber",behindNumber);
  1474. map.put("frontNumber",frontNumber);
  1475. return Response.success(map);
  1476. }
  1477. }