| | |
| | | package com.nanometer.smartlab.service; |
| | | |
| | | import com.nanometer.smartlab.dao.OpeApplyDao; |
| | | import com.nanometer.smartlab.entity.OpeApply; |
| | | import com.nanometer.smartlab.entity.OpeApplyReserve; |
| | | import com.nanometer.smartlab.entity.OpeOrder; |
| | | import com.nanometer.smartlab.entity.SysUser; |
| | | import com.nanometer.smartlab.dao.SysReagentDao; |
| | | import com.nanometer.smartlab.entity.*; |
| | | import com.nanometer.smartlab.entity.enumtype.ApplyStatus; |
| | | import com.nanometer.smartlab.entity.enumtype.SeeFlag; |
| | | import com.nanometer.smartlab.entity.enumtype.ValidFlag; |
| | | import com.nanometer.smartlab.exception.AlarmCode; |
| | | import com.nanometer.smartlab.exception.AlarmException; |
| | | import com.nanometer.smartlab.exception.BusinessException; |
| | |
| | | import com.nanometer.smartlab.util.MessageUtil; |
| | | import org.apache.commons.lang.StringUtils; |
| | | import org.apache.log4j.Logger; |
| | | import org.apache.poi.hssf.usermodel.HSSFWorkbook; |
| | | import org.apache.poi.ss.usermodel.CellType; |
| | | import org.apache.poi.ss.usermodel.Row; |
| | | import org.apache.poi.ss.usermodel.Sheet; |
| | | import org.apache.poi.ss.usermodel.Workbook; |
| | | import org.apache.poi.xssf.usermodel.XSSFWorkbook; |
| | | import org.primefaces.event.FileUploadEvent; |
| | | import org.primefaces.model.UploadedFile; |
| | | import org.springframework.beans.factory.annotation.Value; |
| | | import org.springframework.context.annotation.Lazy; |
| | | import org.springframework.dao.DataAccessException; |
| | | import org.springframework.dao.DataIntegrityViolationException; |
| | |
| | | import org.springframework.util.CollectionUtils; |
| | | |
| | | import javax.annotation.Resource; |
| | | import java.io.IOException; |
| | | import java.io.InputStream; |
| | | import java.math.BigDecimal; |
| | | import java.sql.Timestamp; |
| | | import java.util.ArrayList; |
| | | import java.util.HashMap; |
| | | import java.util.List; |
| | | import java.util.Map; |
| | | import java.text.DecimalFormat; |
| | | import java.text.ParseException; |
| | | import java.text.SimpleDateFormat; |
| | | import java.util.*; |
| | | |
| | | /** |
| | | * Created by johnny on 17/12/12. |
| | |
| | | @Lazy |
| | | @Resource |
| | | OpeWarehouseReserveService opeWarehouseReserveService; |
| | | |
| | | @Lazy |
| | | @Resource |
| | | SysReagentService sysReagentService; |
| | | @Resource |
| | | SysSequenceService sysSequenceService; |
| | | @Resource |
| | | private SysUserService sysUserService; |
| | | @Resource |
| | | private BaseMetaService baseMetaService; |
| | | |
| | | @Value("${activeEnv}") |
| | | private String activeEnv; |
| | | |
| | | @Transactional(propagation = Propagation.REQUIRED) |
| | | public List<OpeApply> getOpeApplyList(String reagentName, Timestamp startDeadline, Timestamp endDeadline, Integer status, |
| | | public List<OpeApply> getOpeApplyList(String reagentName, Timestamp startDeadline, String controlProduct,Timestamp endDeadline, Integer status, |
| | | String applyUserId, String approveUserId, String queryCas, |
| | | Integer first, Integer pageSize,String applyCode,String applyUserName) { |
| | | Integer first, Integer pageSize,String applyCode,String applyUserName,Byte isShow) { |
| | | try { |
| | | Map<String, Object> params = new HashMap<String, Object>(); |
| | | if (StringUtils.isNotBlank(reagentName)) { |
| | |
| | | params.put("startDeadline", startDeadline); |
| | | params.put("endDeadline", endDeadline); |
| | | params.put("status", status); |
| | | params.put("isShow", isShow); |
| | | params.put("controlProduct", controlProduct); |
| | | |
| | | if (StringUtils.isNotBlank(applyUserId)) { |
| | | SysUser sysUser = sysUserService.getSysUser(applyUserId); |
| | | // 不是管理员时,加入applyUserId |
| | | if (sysUser.getSeeFlag().getKey() != SeeFlag.MANAGE.getKey()) { |
| | | if (sysUser.getSeeFlag().getKey() != SeeFlag.MANAGE.getKey() |
| | | && sysUser.getSeeFlag().getKey() != SeeFlag.LEADING.getKey()) { |
| | | params.put("applyUserId", applyUserId); |
| | | } |
| | | |
| | |
| | | if (StringUtils.isNotBlank(approveUserId)) { |
| | | SysUser sysUser = sysUserService.getSysUser(approveUserId); |
| | | // 不是管理员时,加入applyUserId |
| | | if (sysUser.getSeeFlag().getKey() != SeeFlag.MANAGE.getKey()) { |
| | | if (sysUser.getSeeFlag().getKey() != SeeFlag.MANAGE.getKey() |
| | | && sysUser.getSeeFlag().getKey() != SeeFlag.LEADING.getKey()) { |
| | | params.put("approveUserId", approveUserId); |
| | | } |
| | | } |
| | |
| | | if (StringUtils.isNotBlank(approveUserId)) { |
| | | SysUser sysUser = sysUserService.getSysUser(approveUserId); |
| | | // 不是管理员时,加入applyUserId |
| | | if (sysUser.getSeeFlag().getKey() != SeeFlag.MANAGE.getKey()) { |
| | | if (sysUser.getSeeFlag().getKey() != SeeFlag.MANAGE.getKey() |
| | | && sysUser.getSeeFlag().getKey() != SeeFlag.LEADING.getKey()) { |
| | | params.put("approveUserId", approveUserId); |
| | | } |
| | | } |
| | |
| | | } |
| | | |
| | | @Transactional(propagation = Propagation.REQUIRED) |
| | | public int getOpeApplyTotalCount(String reagentName, Timestamp startDeadline, Timestamp endDeadline, Integer status, |
| | | String applyUserId, String approveUserId, String queryCas,String applyCode,String applyUserName) { |
| | | public int getOpeApplyTotalCount(String reagentName, Timestamp startDeadline,String controlProduct, Timestamp endDeadline, Integer status, |
| | | String applyUserId, String approveUserId, String queryCas,String applyCode,String applyUserName,Byte isShow) { |
| | | try { |
| | | Map<String, Object> params = new HashMap<String, Object>(); |
| | | if (StringUtils.isNotBlank(reagentName)) { |
| | |
| | | params.put("startDeadline", startDeadline); |
| | | params.put("endDeadline", endDeadline); |
| | | params.put("status", status); |
| | | params.put("isShow", isShow); |
| | | params.put("controlProduct", controlProduct); |
| | | |
| | | if (StringUtils.isNotBlank(applyUserId)) { |
| | | SysUser sysUser = sysUserService.getSysUser(applyUserId); |
| | | // 不是管理员时,加入applyUserId |
| | | if (sysUser.getSeeFlag().getKey() != SeeFlag.MANAGE.getKey()) { |
| | | if (sysUser.getSeeFlag().getKey() != SeeFlag.MANAGE.getKey() |
| | | && sysUser.getSeeFlag().getKey() != SeeFlag.LEADING.getKey()) { |
| | | params.put("applyUserId", applyUserId); |
| | | } |
| | | |
| | |
| | | public boolean updateSelectedOpeApplyStatus(String memo, List<String> applyIds, String adminUserId, List<String> adminApplyIds,List<String> firstUserIds) { |
| | | boolean apply = false, adminApply = false; |
| | | if (!CollectionUtils.isEmpty(applyIds)) { |
| | | apply = this.updateOpeApplyStatus(ApplyStatus.APPROVED, memo, applyIds); |
| | | if("gslab".equalsIgnoreCase(activeEnv)){ |
| | | apply = this.updateOpeApplyStatus(ApplyStatus.Price_CONFIRM, memo, applyIds); |
| | | }else{ |
| | | apply = this.updateOpeApplyStatus(ApplyStatus.APPROVED, memo, applyIds); |
| | | } |
| | | } |
| | | if (!CollectionUtils.isEmpty(adminApplyIds)) { |
| | | adminApply = this.updateOpeApplyAdminStatus2(memo, adminApplyIds, adminUserId,firstUserIds); |
| | |
| | | } |
| | | |
| | | @Override |
| | | public int getOpeApplyReserveTotalCountByNameFor(String id,String reagentName, String personName,String productSn,String applyCode,Integer status,Integer isAllApply) { |
| | | public int getOpeApplyReserveTotalCountByNameFor(String id,String reagentName, String personName,String productSn,String applyCode,Integer status,Integer isAllApply,boolean isExpired) { |
| | | try { |
| | | Map<String, Object> params = new HashMap<String, Object>(); |
| | | params.put("reagentName", reagentName); |
| | |
| | | params.put("userId",id); |
| | | params.put("productSn",productSn); |
| | | params.put("applyCode",applyCode); |
| | | params.put("status",status); |
| | | if (isExpired) { |
| | | params.put("status",ApplyStatus.EXPIRED.getKey()); |
| | | }else{ |
| | | params.put("status", status); |
| | | } |
| | | params.put("isAllApply",isAllApply); |
| | | return this.opeApplyDao.getOpeApplyReserveTotalCountFor(params); |
| | | } catch (DataAccessException e) { |
| | |
| | | } |
| | | @Override |
| | | public List<OpeApplyReserve> getOpeApplyReserveListByNameFor(String id,String reagentName, String personName, Integer first, |
| | | Integer pageSize,String productSn,String applyCode,Integer status,Integer isAllApply) { |
| | | Integer pageSize,String productSn,String applyCode,Integer status,Integer isAllApply,boolean isExpired) { |
| | | try { |
| | | Map<String, Object> params = new HashMap<String, Object>(); |
| | | params.put("reagentName", reagentName); |
| | |
| | | params.put("pageSize", pageSize); |
| | | params.put("productSn",productSn); |
| | | params.put("applyCode",applyCode); |
| | | params.put("status",status); |
| | | if (isExpired) { |
| | | params.put("status",ApplyStatus.EXPIRED.getKey()); |
| | | }else{ |
| | | params.put("status", status); |
| | | } |
| | | params.put("isAllApply",isAllApply); |
| | | return this.opeApplyDao.getOpeApplyReserveListFor(params); |
| | | } catch (DataAccessException e) { |
| | |
| | | |
| | | } |
| | | |
| | | @Override |
| | | @Transactional |
| | | public void importApply(FileUploadEvent event,SysUser user) throws IOException { |
| | | |
| | | |
| | | UploadedFile file = event.getFile(); |
| | | InputStream is = file.getInputstream(); |
| | | boolean isExcel2003 = true; |
| | | if (file.getFileName().matches("^.+\\.(?i)(xlsx)$")) { |
| | | isExcel2003 = false; |
| | | } |
| | | Workbook wb = null; |
| | | if (isExcel2003) { |
| | | wb = new HSSFWorkbook(is); |
| | | } else { |
| | | wb = new XSSFWorkbook(is); |
| | | } |
| | | Sheet sheet = wb.getSheetAt(0); |
| | | int totalRows = sheet.getPhysicalNumberOfRows(); |
| | | ArrayList<OpeApply> adds = new ArrayList<>(); |
| | | Row row = null; |
| | | int totalCells = 0; |
| | | for (int i = 1; i < totalRows; i++) { |
| | | List<String> valuesList = new ArrayList<String>(); |
| | | row = sheet.getRow(i); |
| | | |
| | | totalCells = row.getLastCellNum(); |
| | | //第10列是课题,其他都不能为空 |
| | | for (int index = 0; index < totalCells; index++) { |
| | | String cellInfo = ""; |
| | | if (row.getCell(index) != null) { |
| | | if (row.getCell(index).getCellType() == CellType.BLANK && index != 9) { |
| | | throw new BusinessException(ExceptionEnumCode.PARAM_NULL, "第" + ++i + "行:除了课题组都不能为空"); |
| | | } |
| | | if (row.getCell(index).getCellType() == CellType.NUMERIC) { |
| | | DecimalFormat df = new DecimalFormat("#######"); //格式化number String字符 |
| | | cellInfo = df.format(row.getCell(index).getNumericCellValue()); |
| | | }else{ |
| | | cellInfo = row.getCell(index).getStringCellValue(); |
| | | } |
| | | } |
| | | valuesList.add(cellInfo); |
| | | } |
| | | |
| | | Map<String,Object> detail = new HashMap<>(); |
| | | detail.put("product_sn", valuesList.get(0)); |
| | | detail.put("name", valuesList.get(1)); |
| | | detail.put("reagent_format", valuesList.get(2)); |
| | | detail.put("packing", valuesList.get(3)); |
| | | detail.put("cas", valuesList.get(4)); |
| | | detail.put("product_home", valuesList.get(5)); |
| | | detail.put("reagent_type", valuesList.get(6)); |
| | | SysReagent sysReagent = sysReagentService.getReagentByDetail(detail); |
| | | if (sysReagent == null) throw new BusinessException(ExceptionEnumCode.PARAM_NO_EXIST, i+"行:试剂不存在或者有多条,导入失败"); |
| | | |
| | | //申购数量 |
| | | Integer num = new Double(valuesList.get(7)).intValue(); |
| | | if (num < 1) throw new BusinessException(ExceptionEnumCode.PARAM_NO_EXIST, i+"行:试剂申购数量不合法,导入失败"); |
| | | |
| | | //申购人姓名 |
| | | String applyUserName = valuesList.get(8); |
| | | SysUser applyUser = sysUserService.getUserByName(applyUserName); |
| | | if (applyUser == null) throw new BusinessException(ExceptionEnumCode.PARAM_NO_EXIST, i+"行:申购人不存在或者申购人姓名存在重复,导入失败"); |
| | | //课题组名称 |
| | | String objective = valuesList.get(9); |
| | | |
| | | String format = "yyyy-MM-dd"; |
| | | SimpleDateFormat dateFormat = new SimpleDateFormat(format); |
| | | Date applyDate = null; |
| | | int cellnum = 10; |
| | | CellType type = row.getCell(cellnum).getCellType(); |
| | | Object value = row.getCell(cellnum); |
| | | if (null == value || StringUtils.isBlank(value.toString())) { |
| | | throw new BusinessException(ExceptionEnumCode.PARAM_NO_EXIST, i+"行,申购日期不能为空"); |
| | | } else { |
| | | if (type.equals(CellType.NUMERIC)) { |
| | | try { |
| | | applyDate = row.getCell(cellnum).getDateCellValue(); |
| | | } catch (Exception e) { |
| | | e.printStackTrace(); |
| | | throw new BusinessException(ExceptionEnumCode.PARAM_NO_EXIST, i+"行,申购日期解析错误,请检查是否有无效字符"); |
| | | } |
| | | } else if (type.equals(CellType.STRING)) { |
| | | String cellInfo = row.getCell(10).getStringCellValue(); |
| | | try { |
| | | applyDate = dateFormat.parse(cellInfo); |
| | | } catch (ParseException e) { |
| | | e.printStackTrace(); |
| | | throw new BusinessException(ExceptionEnumCode.PARAM_NO_EXIST, i+"行:申购日期不合法,应如2016-10-09,导入失败"); |
| | | } |
| | | } else { |
| | | throw new BusinessException(ExceptionEnumCode.PARAM_NO_EXIST, i+"行:申购日期解析错误,请检查是否有无效字符"); |
| | | } |
| | | } |
| | | |
| | | //选择的审批人姓名 |
| | | String approveUserName = valuesList.get(11); |
| | | //根据姓名获取用户信息的id |
| | | SysUser approveUser = sysUserService.getUserByName(approveUserName); |
| | | if (approveUser == null) throw new BusinessException(ExceptionEnumCode.PARAM_NO_EXIST, i+"行:审批人不存在或者审批人姓名存在重复,导入失败"); |
| | | |
| | | OpeApply opeApply = new OpeApply(); |
| | | opeApply.setId(IDUtils.uuid()); |
| | | opeApply.setValidFlag(ValidFlag.VALID); |
| | | opeApply.setStatus(ApplyStatus.PENDING_APPROVAL); |
| | | opeApply.setApplyCode(sysSequenceService.getApplyCode()); |
| | | //设置试剂id |
| | | opeApply.setReagent(sysReagent); |
| | | assert applyDate != null; |
| | | Timestamp applyTime = new Timestamp(applyDate.getTime()); |
| | | opeApply.setCreateTime(applyTime); |
| | | opeApply.setUpdateTime(applyTime); |
| | | //价格 |
| | | opeApply.setApplyPrice(sysReagent.getPrice()); |
| | | //申购数量 |
| | | opeApply.setNum(num); |
| | | //申购人 |
| | | opeApply.setApplyUserId(applyUser.getId()); |
| | | //选择的审批人 |
| | | opeApply.setApproveUserId(approveUser.getId()); |
| | | //选择的课题组信息 |
| | | opeApply.setObjective(objective); |
| | | |
| | | adds.add(opeApply); |
| | | |
| | | } |
| | | |
| | | if (adds.size() > 0) { |
| | | opeApplyDao.insertList(adds); |
| | | } |
| | | |
| | | } |
| | | |
| | | @Override |
| | | public OpeApplyReserve getOpeApplyReserveListByNameForRowData(String rowKey) { |
| | | return opeApplyDao.getOpeApplyReserveListByNameForRowData(rowKey); |
| | | } |
| | | |
| | | @Override |
| | | public int getOpeApplySupplerRequireMngTotalCount(SysUser user,String reagentName, Timestamp startDeadline, Timestamp endDeadline, int status, byte isShow) { |
| | | Map<String, Object> params = new HashMap<>(); |
| | | params.put("reagentName",reagentName ); |
| | | params.put("startDeadline", startDeadline); |
| | | params.put("endDeadline", endDeadline); |
| | | params.put("status", status); |
| | | params.put("isShow", isShow); |
| | | //看到供应商是自己的单位的数据 |
| | | String company = baseMetaService.getBaseMetaValue(user.getCompany()); |
| | | if (user.getSeeFlag().getKey() != SeeFlag.MANAGE.getKey() |
| | | && user.getSeeFlag().getKey() != SeeFlag.LEADING.getKey()) { |
| | | params.put("company", company); |
| | | } |
| | | return this.opeApplyDao.getOpeApplySupplerRequireMngTotalCount(params); |
| | | } |
| | | |
| | | @Override |
| | | public List<OpeApply> getOpeApplySupplerRequireMngList(SysUser user,String reagentName, Timestamp startDeadline, Timestamp endDeadline, int status, int first, int pageSize, byte isShow) { |
| | | Map<String, Object> params = new HashMap<>(); |
| | | params.put("reagentName", reagentName); |
| | | params.put("startDeadline", startDeadline); |
| | | params.put("endDeadline", endDeadline); |
| | | params.put("status", status); |
| | | params.put("isShow", isShow); |
| | | //看到供应商是自己的单位的数据 |
| | | String company = baseMetaService.getBaseMetaValue(user.getCompany()); |
| | | if (user.getSeeFlag().getKey() != SeeFlag.MANAGE.getKey() |
| | | && user.getSeeFlag().getKey() != SeeFlag.LEADING.getKey()) { |
| | | params.put("company", company); |
| | | } |
| | | |
| | | return this.opeApplyDao.getOpeApplySupplerRequireMngList(params); |
| | | } |
| | | |
| | | } |