123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247 |
- package com.ozs.web.controller.plan;
- import com.ozs.common.annotation.Log;
- import com.ozs.common.constant.ModularConstans;
- import com.ozs.common.core.controller.BaseController;
- import com.ozs.common.core.domain.AjaxResult;
- import com.ozs.common.core.domain.model.LoginUser;
- import com.ozs.common.enums.BusinessType;
- import com.ozs.common.enums.SysFileRefEnum;
- import com.ozs.common.exception.ServiceException;
- import com.ozs.common.utils.StringUtils;
- import com.ozs.common.utils.file.FileUtils;
- import com.ozs.common.utils.poi.ExcelUtil;
- import com.ozs.framework.web.service.TokenService;
- import com.ozs.plan.doman.ProvisionalPlan;
- import com.ozs.plan.doman.vo.requestVo.ProvisionalPlanVo;
- import com.ozs.plan.service.PlanQuarterService;
- import com.ozs.plan.service.ProvisionalPlanService;
- import com.ozs.plan.service.impl.PlanQuarterServiceImpl;
- import com.ozs.system.domain.SysFileRef;
- import com.ozs.system.service.ISysDeptService;
- import com.ozs.system.service.SysFileRefService;
- import io.swagger.annotations.Api;
- import io.swagger.annotations.ApiOperation;
- import lombok.extern.slf4j.Slf4j;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.http.MediaType;
- import org.springframework.security.access.prepost.PreAuthorize;
- import org.springframework.util.ObjectUtils;
- import org.springframework.web.bind.annotation.GetMapping;
- import org.springframework.web.bind.annotation.PostMapping;
- import org.springframework.web.bind.annotation.RequestBody;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.bind.annotation.RestController;
- import org.springframework.web.multipart.MultipartFile;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- import java.io.InputStream;
- import java.text.SimpleDateFormat;
- import java.util.ArrayList;
- import java.util.Date;
- import java.util.List;
- import java.util.stream.Collectors;
- /**
- * 临时计划
- *
- * @author sunhh
- */
- @Api(tags = "临时计划")
- @Slf4j
- @RestController
- @RequestMapping("/plan/provisionalPlan")
- public class ProvisionalPlanController extends BaseController {
- @Autowired
- private PlanQuarterService quarterService;
- @Autowired
- private PlanQuarterServiceImpl quarterServiceImpl;
- @Autowired
- private ProvisionalPlanService provisionalPlanService;
- @Autowired
- private TokenService tokenService;
- @Autowired
- private ISysDeptService iSysDeptService;
- @Autowired
- private PlanQuarterServiceImpl planQuarterServiceImpl;
- @Autowired
- private SysFileRefService sysFileRefService;
- @ApiOperation(value = "新增临时计划")
- @PostMapping("/insertProvisionalPlan")
- @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:insertProvisionalPlan')")
- @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.INSERT)
- public AjaxResult insertProvisionalPlan(@RequestBody ProvisionalPlan provisionalPlan, HttpServletRequest request) {
- //获取采购单位
- LoginUser loginUser = tokenService.getLoginUser(request);
- provisionalPlan.setPurchaseDeptId(String.valueOf(loginUser.getDeptId()));
- provisionalPlan.setCreated(String.valueOf(loginUser.getUserId()));
- provisionalPlan.setCreateTime(new Date());
- // planType计划类型(0:季度计划,1:临时计划)
- provisionalPlan.setPlanType("1");
- // 项目状态(0:计划待提交,1:计划待审核,2:计划已退回,3:计划已审核)
- provisionalPlan.setProjectStatus("0");
- provisionalPlan.setIsExcess(iSysDeptService.isExcessOrNo(provisionalPlan.getProjectType(), provisionalPlan.getEvaluation(), Long.valueOf(provisionalPlan.getPurchaseDeptId())));
- boolean save = provisionalPlanService.save(provisionalPlan);
- log.info("provisionalPlan的主键id:{}", provisionalPlan.getPlanPracticalId());
- List<SysFileRef> sysFileRefs = provisionalPlan.getSysFileRefs();
- if (!ObjectUtils.isEmpty(sysFileRefs)) {
- if (save) {
- for (SysFileRef ref : sysFileRefs) {
- ref.setRedId(provisionalPlan.getPlanPracticalId());
- ref.setType(SysFileRefEnum.PLAN_TEMPORARY.getType());
- ref.setCreated(provisionalPlan.getCreated());
- ref.setCreateTime(new Date());
- ref.setUpdated(provisionalPlan.getCreated());
- ref.setUpdateTime(new Date());
- sysFileRefService.save(ref);
- }
- }
- }
- return toAjax(save);
- }
- @ApiOperation(value = "删除临时计划", notes = "必传 plan_practical_id")
- @PostMapping("/deleteProvisionalPlan")
- @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:deleteProvisionalPlan')")
- @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.DELETE)
- public AjaxResult deleteProvisionalPlan(@RequestBody ProvisionalPlan provisionalPlan) {
- if (StringUtils.isNull(provisionalPlan) || StringUtils.isNull(provisionalPlan.getPlanPracticalId())) {
- return error("临时计划id不能为空");
- }
- return toAjax(provisionalPlanService.deleteProvisionalPlanById(provisionalPlan.getPlanPracticalId()));
- }
- @ApiOperation(value = "修改临时计划", notes = "必传 plan_year_id 及修改数据")
- @PostMapping("/updateProvisionalPlan")
- @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:updateProvisionalPlan')")
- @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.UPDATE)
- public AjaxResult updateProvisionalPlan(@RequestBody ProvisionalPlanVo provisionalPlan) {
- if (StringUtils.isNull(provisionalPlan) || StringUtils.isNull(provisionalPlan.getPlanPracticalId())) {
- return error("临时计划id和修改数据不能为空");
- }
- provisionalPlan.setIsExcess(iSysDeptService.isExcessOrNo(provisionalPlan.getProjectType(), provisionalPlan.getEvaluation(), Long.valueOf(provisionalPlan.getPurchaseDeptId())));
- return toAjax(provisionalPlanService.updateProvisionalPlanById(provisionalPlan));
- }
- @ApiOperation(value = "查询临时计划")
- @PostMapping("/selectProvisionalPlan")
- @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:selectProvisionalPlan')")
- @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.QUERY)
- public AjaxResult selectProvisionalPlan(@RequestBody ProvisionalPlanVo vo, HttpServletRequest request) {
- if (StringUtils.isNull(vo)
- || StringUtils.isNull(vo.getPageNum())
- || StringUtils.isNull(vo.getPageSize())) {
- throw new ServiceException("分页参数不能为空!");
- }
- LoginUser loginUser = tokenService.getLoginUser(request);
- return provisionalPlanService.selectProvisionalPlan(vo, request, loginUser);
- }
- @ApiOperation(value = "查询临时计划-审核单位")
- @PostMapping("/selectProvisionalPlanAudit")
- @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:selectProvisionalPlanAudit')")
- @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.QUERY)
- public AjaxResult selectProvisionalPlanAudit(@RequestBody ProvisionalPlanVo vo, HttpServletRequest request) {
- if (StringUtils.isNull(vo)
- || StringUtils.isNull(vo.getPageNum())
- || StringUtils.isNull(vo.getPageSize())) {
- throw new ServiceException("分页参数不能为空!");
- }
- LoginUser loginUser = tokenService.getLoginUser(request);
- return provisionalPlanService.selectProvisionalPlanAudit(vo, request, loginUser);
- }
- @ApiOperation(value = "查询临时计划详情")
- @PostMapping("/selectById")
- @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:selectById')")
- @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.QUERY)
- public AjaxResult selectById(@RequestBody ProvisionalPlanVo provisionalPlanVo) {
- if (StringUtils.isNull(provisionalPlanVo) || StringUtils.isNull(provisionalPlanVo.getPlanPracticalId())) {
- throw new ServiceException("id不能为空!");
- }
- return provisionalPlanService.seletById(provisionalPlanVo.getPlanPracticalId());
- }
- @ApiOperation(value = "导入临时计划")
- @PostMapping("/importProvisionalPlan")
- @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:importProvisionalPlan')")
- @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.INSERT)
- public AjaxResult importProvisionalPlan(MultipartFile file, boolean updateSupport) throws Exception {
- ExcelUtil<ProvisionalPlan> util = new ExcelUtil<>(ProvisionalPlan.class);
- List<ProvisionalPlan> provisionalPlans = util.importExcel(file.getInputStream());
- if (StringUtils.isNull(provisionalPlans) || provisionalPlans.size() == 0) {
- throw new ServiceException("导入临时计划数据不能为空!");
- }
- //获取采购单位-
- LoginUser loginUser = getLoginUser();
- String message = provisionalPlanService.importProvisionalPlan(provisionalPlans, updateSupport, loginUser);
- return success(message);
- }
- @ApiOperation(value = "导出临时计划")
- @PostMapping("/exportProvisionalPlan")
- @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:exportProvisionalPlan')")
- @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.EXPORT)
- public void exportProvisionalPlan(HttpServletResponse response, @RequestBody ProvisionalPlanVo provisionalPlanVo, HttpServletRequest request) throws Exception {
- LoginUser loginUser = tokenService.getLoginUser(request);
- List<ProvisionalPlan> list = provisionalPlanService.selectProvisionalPlanExport(provisionalPlanVo, loginUser);
- ExcelUtil<ProvisionalPlan> util = new ExcelUtil<>(ProvisionalPlan.class);
- util.exportExcel(response, list, "临时计划数据");
- }
- @ApiOperation(value = "提交临时计划")
- @PostMapping("/commitProvisionalPlan")
- @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:commitProvisionalPlan')")
- @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.UPDATE)
- public AjaxResult commitProvisionalPlan(@RequestBody ProvisionalPlanVo provisionalPlanVo) {
- if (StringUtils.isNull(provisionalPlanVo) || StringUtils.isNull(provisionalPlanVo.getPlanPracticalId())) {
- return error("提交的临时计划ID不能为空!");
- }
- return toAjax(provisionalPlanService.commitProvisionalPlan(provisionalPlanVo));
- }
- @ApiOperation(value = "审核通过")
- @PostMapping("/auditPass")
- @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:auditPass')")
- @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.UPDATE)
- public AjaxResult auditPass(@RequestBody ProvisionalPlanVo provisionalPlanVo, HttpServletRequest request) {
- if (StringUtils.isNull(provisionalPlanVo) || StringUtils.isNull(provisionalPlanVo.getPlanPracticalId())) {
- return error("审核数据ID不能为空!");
- }
- LoginUser loginUser = tokenService.getLoginUser(request);
- provisionalPlanVo.setUpdated(String.valueOf(loginUser.getUserId()));
- return provisionalPlanService.auditPass(provisionalPlanVo);
- }
- @ApiOperation(value = "审核不通过")
- @PostMapping("/auditNoPass")
- @PreAuthorize("@ss.hasPermi('plan:provisionalPlan:auditNoPass')")
- @Log(title = ModularConstans.provisionalPlan, businessType = BusinessType.UPDATE)
- public AjaxResult auditNoPass(@RequestBody ProvisionalPlanVo provisionalPlanVo, HttpServletRequest request) {
- if (StringUtils.isNull(provisionalPlanVo) || StringUtils.isNull(provisionalPlanVo.getPlanPracticalId())) {
- return error("审核数据ID不能为空!");
- }
- LoginUser loginUser = tokenService.getLoginUser(request);
- provisionalPlanVo.setUpdated(String.valueOf(loginUser.getUserId()));
- return provisionalPlanService.auditNoPass(provisionalPlanVo);
- }
- @ApiOperation("模板下载")
- @GetMapping("/downloaExcel")
- public void downloadZip(HttpServletResponse response) {
- try {
- InputStream resourceAsStream = this.getClass().getResourceAsStream("/template/provisionalPlan.xlsx");
- response.setContentType(MediaType.APPLICATION_OCTET_STREAM_VALUE);
- FileUtils.setAttachmentResponseHeader(response, "临时计划导入模板.xlsx");
- FileUtils.writeBytesByInput(resourceAsStream, response.getOutputStream());
- } catch (Exception e) {
- log.error("下载文件失败", e);
- }
- }
- }
|