package cn.cslg.pas.service;
import cn.cslg.pas.common.core.base.Constants;
import cn.cslg.pas.common.core.exception.CustomException;
import cn.cslg.pas.common.model.PersonnelVO;
import cn.cslg.pas.common.model.dto.UploadFileDTO;
import cn.cslg.pas.common.model.params.*;
import cn.cslg.pas.common.model.vo.*;
import cn.cslg.pas.common.utils.SecurityUtils.LoginUtils;
import cn.cslg.pas.common.utils.*;
import cn.cslg.pas.common.utils.SecurityUtils.SecurityUtils;
import cn.cslg.pas.domain.*;
import cn.cslg.pas.mapper.ProjectMapper;
import cn.dev33.satoken.stp.StpUtil;
import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.collection.IterUtil;
import cn.hutool.core.date.DateField;
import cn.hutool.core.date.DateUtil;
import cn.hutool.core.io.FileUtil;
import cn.hutool.core.io.IoUtil;
import cn.hutool.core.util.IdUtil;
import cn.hutool.core.util.ZipUtil;
import cn.hutool.extra.spring.SpringUtil;
import cn.hutool.poi.excel.ExcelReader;
import cn.hutool.poi.excel.ExcelUtil;
import cn.hutool.poi.excel.ExcelWriter;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import lombok.RequiredArgsConstructor;
import org.apache.poi.ss.usermodel.PictureData;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Lazy;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.transaction.interceptor.TransactionAspectSupport;
import org.springframework.web.multipart.MultipartFile;
import javax.servlet.http.HttpServletResponse;
import java.io.*;
import java.nio.charset.StandardCharsets;
import java.util.*;
import java.util.stream.Collectors;
/**
*
* 专题库表 服务实现类
*
*
* @author 王岩
* @since 2022-01-24
*/
@Service
@RequiredArgsConstructor(onConstructor_ = {@Lazy})
public class ProjectService extends ServiceImpl {
private final ClientService clientService;
private final ProjectUserService projectUserService;
private final PatentService patentService;
private final PatentApplicantService patentApplicantService;
private final PatentAgencyService patentAgencyService;
private final PatentAgentService patentAgentService;
private final PatentAgentLinkService patentAgentLinkService;
private final PatentLicensorService patentLicensorService;
private final PatentPledgeService patentPledgeService;
private final PatentAffairService patentAffairService;
private final PatentApplicantLinkService patentApplicantLinkService;
private final PatentApplicantMergeLinkService patentApplicantMergeLinkService;
private final PatentInventorService patentInventorService;
private final PatentInventorLinkService patentInventorLinkService;
private final PatentSimpleFamilyService patentSimpleFamilyService;
private final PatentSimpleFamilyLinkService patentSimpleFamilyLinkService;
private final PatentClassNumberService patentClassNumberService;
private final PatentClassNumberLinkService patentClassNumberLinkService;
private final ProjectPatentLinkService projectPatentLinkService;
private final TaskService taskService;
private final PatentImageService patentImageService;
private final ProjectFieldPatentLinkService projectFieldPatentLinkService;
private final ProjectFolderService projectFolderService;
private final ProjectFolderPatentLinkService projectFolderPatentLinkService;
private final ProjectFieldService projectFieldService;
private final ProjectFieldOptionService projectFieldOptionService;
private final ProjectFieldTreeService projectFieldTreeService;
private final ProjectFieldTextService projectFieldTextService;
private final ProjectFileService projectFileService;
private final SystemDictService systemDictService;
private final PatentInstructionService patentInstructionService;
private final PatentInstructionTextService patentInstructionTextService;
private final PatentRightService patentRightService;
private final FileUtils fileUtils;
private final PatentLabelService patentLabelService;
private final CacheUtils cacheUtils;
private final ProjectExportService projectExportService;
private final ProjectService projectService;
private final PatentInventorMergeService patentInventorMergeService;
private final UserService userService;
private final ApiUtils apiUtils;
private final LoginUtils loginUtils;
public Project getProjectByName(String name) {
LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(Project::getName, name);
queryWrapper.last("limit 1");
return this.getOne(queryWrapper);
}
public IPage getPageList(ProjectVO params) {
Map m = new HashMap<>();
m.put("token", LoginUtils.getToken());
m.put("loginId", loginUtils.getId());
m.put("functionId", 8);
PersonnelVO user = cacheUtils.getLoginUserPersonnel(loginUtils.getId());
List projectIds = new ArrayList() {{
add(-1);
}};
if (params.getMyself()) {
projectIds.addAll(projectUserService.getProIdByUserId(loginUtils.getId()));
}
if (user.getUsername().equals(Constants.ADMIN_USERNAME)) {
projectIds.addAll(projectService.list().stream().map(Project::getId).collect(Collectors.toList()));
}
params.setProIds(projectIds);
params.setCreateBy(loginUtils.getId());
SecurityUtils.startDataScope(m);
IPage pageList = baseMapper.getPageList(new Page<>(params.getCurrent(), params.getSize()), params);
List dataList = pageList.getRecords();
// try {
// Map map = new HashMap<>();
// map.put("departmentId", dataList.stream().map(Project::getDepartmentId).collect(Collectors.toList()));
// String jsonObject = apiUtils.invokeApi(new JSONObject(map), "/permission/api/system/getDepartmentById", "post", "data");
// JSONArray jsonArray1 = JSON.parseArray(jsonObject);
// List departmentList = jsonArray1.toJavaList(ProjectVO.Department.class);
// for (Project project : dataList) {
// for (ProjectVO.Department department : departmentList) {
// if (project.getDepartmentId().equals(department.getId())) {
// project.setDepartmentName(department.getDepartmentName());
// }
// }
// }
//
// Map map1 = new HashMap<>();
// map1.put("personnelId", dataList.stream().map(Project::getPersonnelId).collect(Collectors.toList()));
// String jsonObject1 = apiUtils.invokeApi(new JSONObject(map1), "/permission/api/system/getPersonnelById", "post", "data");
// JSONArray jsonArray = JSON.parseArray(jsonObject1);
// List personnelList = jsonArray.toJavaList(ProjectVO.Personnel.class);
// for (Project project : dataList) {
// for (ProjectVO.Personnel personnel : personnelList) {
// if (project.getPersonnelId().equals(personnel.getId())) {
// project.setPersonnelName(personnel.getPersonnelName());
// }
// }
// }
// } catch (IOException e) {
// e.printStackTrace();
// }
this.setDataList(dataList);
pageList.setRecords(dataList);
return pageList;
}
public List getProjectByIds(List ids) {
if (ids == null || ids.size() == 0) {
return new ArrayList<>();
}
LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.in(Project::getId, ids);
return this.list(queryWrapper);
}
public List getProjectByCreateId(Integer createBy) {
LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(Project::getCreateBy, createBy);
return this.list(queryWrapper);
}
public Project getProjectById(Integer id) {
Project project = this.getById(id);
Client client = clientService.getById(project.getClientId());
if (client != null) {
project.setClientName(client.getName());
}
return project;
}
private void setDataList(List dataList) {
List systemDictList = systemDictService.getSystemDictListByType(Arrays.asList(Constants.ENTERPRISE_APPLICATION_SCENARIO, Constants.INVESTIGATION_TYPE));
dataList.forEach(item -> {
if (StringUtils.isNotEmpty(item.getScenario())) {
item.setScenarioList(StringUtils.changeStringToInteger(item.getScenario(), ","));
item.setScenarioName(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.ENTERPRISE_APPLICATION_SCENARIO) && item.getScenarioList().contains(Integer.parseInt(systemDict.getValue()))).map(SystemDict::getLabel).collect(Collectors.toList()));
item.setScenario(null);
}
if (StringUtils.isNotEmpty(item.getType())) {
item.setTypeList(StringUtils.changeStringToInteger(item.getType(), ","));
item.setTypeName(systemDictList.stream().filter(systemDict -> systemDict.getType().equals(Constants.INVESTIGATION_TYPE) && item.getTypeList().contains(Integer.parseInt(systemDict.getValue()))).map(SystemDict::getLabel).collect(Collectors.toList()));
item.setType(null);
}
});
}
public List getAllProjectByMySelf() {
PersonnelVO user = cacheUtils.getLoginUserPersonnel(loginUtils.getId());
LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();
List proIds = new ArrayList<>();
if (!user.getUsername().equals(Constants.ADMIN_USERNAME)) {
proIds.addAll(projectUserService.getProIdByUserId(user.getId()));
proIds.addAll(this.getProjectByCreateId(loginUtils.getId()).stream().map(Project::getId).collect(Collectors.toList()));
if (proIds.size() != 0) {
queryWrapper.in(Project::getId, proIds);
} else {
queryWrapper.eq(Project::getId, -1);
}
}
List projectList = this.list(queryWrapper);
this.setDataList(projectList);
return projectList;
}
public Map