Browse Source

单船申报月报表

git-svn-id: https://192.168.57.71/svn/jsgkj@1809 931142cf-59ea-a443-aa0e-51397b428577
ld_xuhx 8 years ago
parent
commit
cda515badc

+ 143 - 0
gkjsjy/trunk/src/com/xt/jygl/gkjygl/cghzyxxgl/dcsb/ctl/DcsbybbCtl.java

@@ -16,6 +16,7 @@ import javax.persistence.criteria.CriteriaBuilder;
 import javax.persistence.criteria.CriteriaQuery;
 import javax.persistence.criteria.Predicate;
 import javax.persistence.criteria.Root;
+import javax.servlet.ServletOutputStream;
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
 
@@ -249,7 +250,149 @@ public class DcsbybbCtl extends BaseWebCtl {
 		putPageInfo(model, page, list);
 		return "gkjygl/cghzyxxgl/dcsbybb/dcsbybbmain";
 	}
+	//导出
+	@RequestMapping(value="/exportExcelAll")
+	@ResponseBody
+	public String exportExcelAll(HttpServletResponse response,SimplePageRequest page, Model model, final String gkjyr, final String szdid, final String szgkid, final String szgqid, final String jcg, final String nwm, final String hwzl, final String menuid, final String zysjq, final String zysjz, final HttpServletRequest request,final String dydlid) throws JsonProcessingException{
+		final Map<String, Object> cacheSCmap = CacheSearchCondition.cacheSCmap(request,"dcsbybb");
+		// 查询条件
+		Specification<DcsbybbEntity> spec = new Specification<DcsbybbEntity>() {
+
+			@Override
+			public Predicate toPredicate(Root<DcsbybbEntity> root, CriteriaQuery<?> query, CriteriaBuilder cb) {
+				List<Predicate> list = new ArrayList<Predicate>();
+				if (StringUtils.isNotEmpty(gkjyr)) {
+					list.add(cb.like(root.get("ssjyr").get("gkjyr").as(String.class), "%" + gkjyr + "%"));
+				} else if (isGET(request)) {
+					//list.add(cb.like(root.get("ssjyr").get("gkjyr").as(String.class), "%" + SearchCondition.ybbjyr + "%"));
+					CacheSearchCondition.predicateList(list, cacheSCmap, root, cb, "gkjyr","ssjyr","gkjyr");
+				}
+				if (StringUtils.isNotEmpty(szdid)) {
+					list.add(cb.like(root.get("szd").get("id").as(String.class), szdid + "%"));
+				} else if (isGET(request)) {
+					CacheSearchCondition.predicateList(list, cacheSCmap, root, cb, "id","szd","szdid");
+				}
+				if (StringUtils.isNotEmpty(szgkid)) {
+					list.add(cb.equal(root.get("szgk").get("id").as(String.class), szgkid));
+				} else if (isGET(request)) {
+					CacheSearchCondition.predicateList(list, cacheSCmap, root, cb, "id","szgk","szgkid");
+				}
+
+				if (StringUtils.isNotEmpty(szgqid)) {
+					list.add(cb.equal(root.get("szgq").get("id").as(String.class), szgqid));
+				} else if (isGET(request)) {
+					CacheSearchCondition.predicateList(list, cacheSCmap, root, cb, "id","szgq","szgqid");
+				}
+
+				if (StringUtils.isNotEmpty(jcg)) {
+					list.add(cb.equal(root.get("jcg").as(String.class), jcg));
+				} else if (isGET(request)) {
+					CacheSearchCondition.predicateList(list, cacheSCmap, root, cb, null,"jcg");
+				}
+				if (StringUtils.isNotEmpty(nwm)) {
+					list.add(cb.equal(root.get("nwm").as(String.class), nwm));
+				} else if (isGET(request)) {
+					CacheSearchCondition.predicateList(list, cacheSCmap, root, cb, null,"nwm");
+				}
+				if (StringUtils.isNotEmpty(dydlid)) {
+					list.add(cb.equal(root.get("hwzl").get("id").as(String.class), dydlid));
+				} else if (isGET(request)) {
+					CacheSearchCondition.predicateList(list, cacheSCmap, root, cb, "id", "hwzl", "dydlid");
+				}
+				SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM");
+				Date date;
+				if (StringUtils.isNotEmpty(zysjq)) {
+					try {
+						date = sdf.parse(zysjq);
+					} catch (ParseException e) {
+						date = null;
+						e.printStackTrace();
+					}
+					list.add(cb.greaterThanOrEqualTo(root.get("bgsj").as(Date.class), date));
+				} else if (isGET(request)) {
+					String val =(String)CacheSearchCondition.cacheSCmapVal(cacheSCmap,"zysjq");
+					if(StringUtils.isNotEmpty(val)){
+						try {
+							date = sdf.parse(val);
+						} catch (ParseException e) {
+							date = null;
+							e.printStackTrace();
+						}
+						list.add(cb.greaterThanOrEqualTo(root.get("bgsj").as(Date.class),date));
+					}	
+				}
+				
+				
+				if (StringUtils.isNotEmpty(zysjz)) {
+					try {
+						date = sdf.parse(zysjz);
+					} catch (ParseException e) {
+						date = null;
+						e.printStackTrace();
+					}
+					list.add(cb.lessThanOrEqualTo(root.get("bgsj").as(Date.class), date));
+				} else if (isGET(request)) {
+					String val =(String)CacheSearchCondition.cacheSCmapVal(cacheSCmap,"zysjz");
+					if(StringUtils.isNotEmpty(val)){
+						try {
+							date = sdf.parse(val);
+						} catch (ParseException e) {
+							date = null;
+							e.printStackTrace();
+						}
+						list.add(cb.lessThanOrEqualTo(root.get("bgsj").as(Date.class), date));
+					}	
+				}
+				
+				// 经营人只能查看自己企业下的数据,非经营人只能查看自己所在地的数据
+				if (isJyr()) {
+					list.add(cb.like(root.get("ssjyr").get("id").as(String.class), "%" + getSsjyr().getId() + "%"));
+				} else {
+					list.add(cb.like(root.get("szd").get("id").as(String.class), "%" + SecUtils.getCurrUser().getSzd().getId() + "%"));
+				}
+				list.add(cb.notEqual(root.get("recordStatus").as(Integer.class), BaseEntity.RECORD_STATE_DELETE));
+				list.add(cb.notEqual(root.get("recordStatus").as(Integer.class), BaseEntity.RECORE_STATE_COPY));
+				return cb.and(list.toArray(new Predicate[] {}));
+			}
+		};
 
+		
+		List<DcsbybbEntity> list = query.findAll(spec, DcsbybbEntity.class);
+		List<DcsbybbVo> voList = new ArrayList<DcsbybbVo>();
+		for (DcsbybbEntity entity : list) {
+			DcsbybbVo vo = new DcsbybbVo();
+			if (entity != null) {
+				BeanUtils.copyProperties(entity, vo);
+				vo.setSsjyr(entity.getSsjyr() != null ? entity.getSsjyr().getGkjyr() : "");
+				vo.setSzgk(entity.getSzgk() != null ? entity.getSzgk().getGkmc() : "");
+				vo.setSzgq(entity.getSzgq() != null ? entity.getSzgq().getGqmc() : "");
+				if (entity.getHwzl() != null) {
+					vo.setHwzlzw(securityMgr.codeService().findOne(entity.getHwzl().getId()).getText());
+				}
+				if (entity.getJcg() != null) {
+					vo.setJcg(securityMgr.codeService().findOne(entity.getJcg()).getText());
+				}
+				if (entity.getNwm() != null) {
+					vo.setNwm(securityMgr.codeService().findOne(entity.getNwm()).getText());
+				}
+				if(!StringUtils.isEmpty(entity.getBgsj())){
+					SimpleDateFormat dateTimeFormat = new SimpleDateFormat("yyyy-MM");
+					vo.setBgsj(dateTimeFormat.format(entity.getBgsj()));
+				}
+				voList.add(vo);
+			}
+		}	
+		response.setContentType("application/binary;charset=iso-8859-1");
+		try {
+				ServletOutputStream outputStream = response.getOutputStream();
+				String fileName = new String(("单船申报月报表").getBytes(), "iso-8859-1");
+				response.setHeader("Content-disposition", "attachment; filename=" + fileName + ".xlsx");// 组装附件名称和格式
+				dcsbybbService.exportExcelAll(voList, outputStream);
+			} catch (IOException e) {
+					e.printStackTrace();
+			}					
+		return null;
+	}
 	// 新增
 	@RequestMapping(value = "/add")
 	public String add(Model model) {

+ 12 - 0
gkjsjy/trunk/src/com/xt/jygl/gkjygl/cghzyxxgl/dcsb/service/DcsbybbService.java

@@ -3,7 +3,12 @@ package com.xt.jygl.gkjygl.cghzyxxgl.dcsb.service;
 import java.util.Date;
 import java.util.List;
 
+import javax.servlet.ServletOutputStream;
+
+import org.apache.poi.xssf.usermodel.XSSFWorkbook;
+
 import com.xt.jygl.gkjygl.cghzyxxgl.dcsb.entity.DcsbybbEntity;
+import com.xt.jygl.gkjygl.cghzyxxgl.dcsb.vo.DcsbybbVo;
 
 public interface DcsbybbService {
 
@@ -29,5 +34,12 @@ public interface DcsbybbService {
 	public void delete(String id);
 
 	public DcsbybbEntity findOne(String id);
+	
+	/**
+	 *  导出数据
+	 * */
+	public void exportExcelAll(List<DcsbybbVo> voList, ServletOutputStream outputStream);
+	
+	public void setXkzxxSheet(List<DcsbybbVo> voList, ServletOutputStream outputStream, XSSFWorkbook workBook);
 
 }

+ 104 - 0
gkjsjy/trunk/src/com/xt/jygl/gkjygl/cghzyxxgl/dcsb/service/impl/DcsbybbServiceImpl.java

@@ -1,17 +1,29 @@
 package com.xt.jygl.gkjygl.cghzyxxgl.dcsb.service.impl;
 
+import java.io.IOException;
+import java.text.SimpleDateFormat;
 import java.util.Date;
 import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
 
+import javax.servlet.ServletOutputStream;
+
+import org.apache.poi.xssf.usermodel.XSSFCell;
+import org.apache.poi.xssf.usermodel.XSSFCellStyle;
+import org.apache.poi.xssf.usermodel.XSSFRow;
+import org.apache.poi.xssf.usermodel.XSSFSheet;
+import org.apache.poi.xssf.usermodel.XSSFWorkbook;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 
+import com.xt.jygl.common.ExportUtil;
 import com.xt.jygl.common.service.JyglBaseService;
 import com.xt.jygl.gkjygl.cghzyxxgl.dcsb.dao.DcsbybbDao;
 import com.xt.jygl.gkjygl.cghzyxxgl.dcsb.entity.DcsbybbEntity;
 import com.xt.jygl.gkjygl.cghzyxxgl.dcsb.service.DcsbybbService;
+import com.xt.jygl.gkjygl.cghzyxxgl.dcsb.vo.DcsbVo;
+import com.xt.jygl.gkjygl.cghzyxxgl.dcsb.vo.DcsbybbVo;
 import com.xtframe.sec.common.SecRepository;
 import com.xtframe.util.StringUtils;
 
@@ -424,4 +436,96 @@ public class DcsbybbServiceImpl extends JyglBaseService<DcsbybbEntity, String> i
 		System.out.println(sb.toString());
 		return (List<Object>) dao.nativeQuery(sb.toString(), params);
 	}
+	/**
+	 * 导出数据
+	 * */
+	@Override
+	public void exportExcelAll(List<DcsbybbVo> voList, ServletOutputStream outputStream){
+		// 创建一个workbook 对应一个excel应用文件
+				XSSFWorkbook workBook = new XSSFWorkbook();
+				setXkzxxSheet(voList, outputStream, workBook);
+				try {
+					workBook.write(outputStream);
+					outputStream.flush();
+					outputStream.close();
+				} catch (IOException e) {
+					e.printStackTrace();
+				} finally {
+					try {
+						outputStream.close();
+					} catch (IOException e) {
+						e.printStackTrace();
+					}
+				}
+	}
+	
+	@Override
+	public void setXkzxxSheet(List<DcsbybbVo> voList, ServletOutputStream outputStream, XSSFWorkbook workBook) {
+		String[] titles = { "序号", "港口经营人", "进出港", "内外贸", "作业数量(吨)", "作业数量(TEU)", "货物种类第一大类", "所在港口", "所在港区","报告时间" };
+		// 在workbook中添加一个sheet,对应Excel文件中的sheet
+		XSSFSheet sheet = workBook.createSheet("港口申报月报表");
+		ExportUtil exportUtil = new ExportUtil(workBook, sheet);
+		XSSFCellStyle headStyle = exportUtil.getHeadStyle();
+		XSSFCellStyle bodyStyle = exportUtil.getBodyStyle();
+		// 构建表头
+		XSSFRow headRow = sheet.createRow(0);
+		XSSFCell cell = null;
+		for (int i = 0; i < titles.length; i++) {
+			cell = headRow.createCell(i);
+			cell.setCellStyle(headStyle);
+			cell.setCellValue(titles[i]);
+		}
+		//时间格式
+		//将建成时间精确到天
+		SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd");//小写的mm表示的是分钟  
+		// 构建表体数据
+		if (voList != null && voList.size() > 0) {
+			SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
+			for (int j = 0; j < voList.size(); j++) {
+				XSSFRow bodyRow = sheet.createRow(j + 1);
+				DcsbybbVo xkzxx = voList.get(j);
+				// 序号
+				cell = bodyRow.createCell(0);
+				cell.setCellStyle(bodyStyle);
+				cell.setCellValue(j + 1);
+				
+				cell = bodyRow.createCell(1);
+				cell.setCellStyle(bodyStyle);
+				cell.setCellValue(voList.get(j).getSsjyr());
+				
+				cell = bodyRow.createCell(2);
+				cell.setCellStyle(bodyStyle);
+				cell.setCellValue(voList.get(j).getJcg());
+				
+				cell = bodyRow.createCell(3);
+				cell.setCellStyle(bodyStyle);
+				cell.setCellValue(voList.get(j).getNwm());
+				
+				cell = bodyRow.createCell(4);
+				cell.setCellStyle(bodyStyle);
+				cell.setCellValue(voList.get(j).getZysl());
+				
+				cell = bodyRow.createCell(5);
+				cell.setCellStyle(bodyStyle);
+				cell.setCellValue(voList.get(j).getZyslteu());
+				
+				cell = bodyRow.createCell(6);
+				cell.setCellStyle(bodyStyle);
+				cell.setCellValue(voList.get(j).getHwzlzw());
+				
+				cell = bodyRow.createCell(7);
+				cell.setCellStyle(bodyStyle);
+				cell.setCellValue(voList.get(j).getSzgk());
+				
+				cell = bodyRow.createCell(8);
+				cell.setCellStyle(bodyStyle);
+				cell.setCellValue(voList.get(j).getSzgq());
+				
+				cell = bodyRow.createCell(9);
+				cell.setCellStyle(bodyStyle);
+				cell.setCellValue(voList.get(j).getBgsj());
+
+			}
+		}
+	}
 }