
21 changed files with 773 additions and 37 deletions
@ -0,0 +1,115 @@ |
|||
/********************************************************* |
|||
********************************************************* |
|||
******************** ******************* |
|||
************* ************ |
|||
******* _oo0oo_ ******* |
|||
*** o8888888o *** |
|||
* 88" . "88 * |
|||
* (| -_- |) * |
|||
* 0\ = /0 * |
|||
* ___/`---'\___ * |
|||
* .' \\| |// '. *
|
|||
* / \\||| : |||// \ *
|
|||
* / _||||| -:- |||||- \ * |
|||
* | | \\\ - /// | | *
|
|||
* | \_| ''\---/'' |_/ | * |
|||
* \ .-\__ '-' ___/-. / * |
|||
* ___'. .' /--.--\ `. .'___ * |
|||
* ."" '< `.___\_<|>_/___.' >' "". * |
|||
* | | : `- \`.;`\ _ /`;.`/ - ` : | | * |
|||
* \ \ `_. \_ __\ /__ _/ .-` / / * |
|||
* =====`-.____`.___ \_____/___.-`___.-'===== * |
|||
* `=---=' * |
|||
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * |
|||
*********__佛祖保佑__永无BUG__验收通过__钞票多多__********* |
|||
*********************************************************/ |
|||
package com.yxt.anrui.oa.api; |
|||
|
|||
import com.yxt.anrui.oa.biz.adexpatriatesapply.AdExpatriatesApplyDto; |
|||
import com.yxt.anrui.oa.biz.adexpatriateshomeapply.*; |
|||
import com.yxt.anrui.oa.biz.oaform.flowable.CompleteDto; |
|||
import com.yxt.anrui.oa.biz.oaform.flowable.NodeQuery; |
|||
import com.yxt.anrui.oa.biz.oaform.flowable.NodeVo; |
|||
import com.yxt.anrui.oa.biz.oaform.flowable.TaskDto; |
|||
import com.yxt.common.core.query.PagerQuery; |
|||
import com.yxt.common.core.result.ResultBean; |
|||
import com.yxt.common.core.vo.PagerVo; |
|||
import io.swagger.annotations.Api; |
|||
import io.swagger.annotations.ApiOperation; |
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.cloud.openfeign.SpringQueryMap; |
|||
import org.springframework.web.bind.annotation.*; |
|||
|
|||
import javax.validation.Valid; |
|||
import java.util.List; |
|||
|
|||
@Api(tags = "驻外人员探亲申请") |
|||
@RestController |
|||
@RequestMapping("v1/adexpatriateshomeapply") |
|||
public class AdExpatriatesHomeApplyRest { |
|||
|
|||
@Autowired |
|||
private AdExpatriatesHomeApplyService adExpatriatesHomeApplyService; |
|||
|
|||
@ApiOperation("根据条件分页查询数据的列表") |
|||
@PostMapping("/listPage") |
|||
public ResultBean<PagerVo<AdExpatriatesHomeApplyVo>> listPage(@RequestBody PagerQuery<AdExpatriatesHomeApplyQuery> pq) { |
|||
ResultBean rb = ResultBean.fireFail(); |
|||
PagerVo<AdExpatriatesHomeApplyVo> pv = adExpatriatesHomeApplyService.listPageVo(pq); |
|||
return rb.success().setData(pv); |
|||
} |
|||
|
|||
@ApiOperation("新增或修改") |
|||
@PostMapping("/save") |
|||
public ResultBean save(@RequestBody AdExpatriatesHomeApplyDto dto) { |
|||
ResultBean rb = ResultBean.fireFail(); |
|||
adExpatriatesHomeApplyService.saveOrUpdateDto(dto); |
|||
return rb.success(); |
|||
} |
|||
|
|||
@ApiOperation("根据sid批量删除") |
|||
@DeleteMapping("/delBySids") |
|||
public ResultBean delBySids(@RequestBody String[] sids) { |
|||
ResultBean rb = ResultBean.fireFail(); |
|||
adExpatriatesHomeApplyService.delAll(sids); |
|||
return rb.success(); |
|||
} |
|||
|
|||
@ApiOperation("根据SID获取一条记录") |
|||
@GetMapping("/fetchDetailsBySid/{sid}") |
|||
public ResultBean<AdExpatriatesHomeApplyVo> fetchDetailsBySid(@PathVariable("sid") String sid) { |
|||
ResultBean rb = ResultBean.fireFail(); |
|||
AdExpatriatesHomeApplyVo vo = adExpatriatesHomeApplyService.fetchDetailsVoBySid(sid); |
|||
return rb.success().setData(vo); |
|||
} |
|||
|
|||
@ApiOperation("提交审批流程") |
|||
@PostMapping("/submit") |
|||
public ResultBean submit(@RequestBody @Valid AdExpatriatesHomeApplyDto dto) { |
|||
return adExpatriatesHomeApplyService.submit(dto); |
|||
} |
|||
|
|||
@ApiOperation(value = "办理(同意)") |
|||
@PostMapping("/complete") |
|||
public ResultBean complete(@Valid @RequestBody CompleteDto dto) { |
|||
return adExpatriatesHomeApplyService.complete(dto); |
|||
} |
|||
|
|||
@ApiOperation(value = "驳回任务") |
|||
@PostMapping(value = "/reject") |
|||
public ResultBean reject(@Valid @RequestBody TaskDto dto) { |
|||
return adExpatriatesHomeApplyService.reject(dto); |
|||
} |
|||
|
|||
@ApiOperation(value = "获取上一个环节") |
|||
@GetMapping(value = "/getPreviousNodesForReject") |
|||
public ResultBean<List<NodeVo>> getPreviousNodesForReject(@Valid @SpringQueryMap NodeQuery query) { |
|||
return adExpatriatesHomeApplyService.getPreviousNodesForReject(query); |
|||
} |
|||
|
|||
@ApiOperation(value = "获取下一个环节") |
|||
@GetMapping(value = "/getNextNodesForSubmit") |
|||
public ResultBean<List<NodeVo>> getNextNodesForSubmit(@Valid @SpringQueryMap NodeQuery query) { |
|||
return adExpatriatesHomeApplyService.getNextNodesForSubmit(query); |
|||
} |
|||
} |
@ -0,0 +1,67 @@ |
|||
/********************************************************* |
|||
********************************************************* |
|||
******************** ******************* |
|||
************* ************ |
|||
******* _oo0oo_ ******* |
|||
*** o8888888o *** |
|||
* 88" . "88 * |
|||
* (| -_- |) * |
|||
* 0\ = /0 * |
|||
* ___/`---'\___ * |
|||
* .' \\| |// '. *
|
|||
* / \\||| : |||// \ *
|
|||
* / _||||| -:- |||||- \ * |
|||
* | | \\\ - /// | | *
|
|||
* | \_| ''\---/'' |_/ | * |
|||
* \ .-\__ '-' ___/-. / * |
|||
* ___'. .' /--.--\ `. .'___ * |
|||
* ."" '< `.___\_<|>_/___.' >' "". * |
|||
* | | : `- \`.;`\ _ /`;.`/ - ` : | | * |
|||
* \ \ `_. \_ __\ /__ _/ .-` / / * |
|||
* =====`-.____`.___ \_____/___.-`___.-'===== * |
|||
* `=---=' * |
|||
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * |
|||
*********__佛祖保佑__永无BUG__验收通过__钞票多多__********* |
|||
*********************************************************/ |
|||
package com.yxt.anrui.oa.biz.adexpatriateshomeapply; |
|||
|
|||
import com.baomidou.mybatisplus.annotation.TableName; |
|||
import com.yxt.common.core.domain.BaseEntity; |
|||
import io.swagger.annotations.ApiModel; |
|||
import io.swagger.annotations.ApiModelProperty; |
|||
import lombok.Data; |
|||
|
|||
@Data |
|||
@ApiModel(value = "驻外人员探亲申请", description = "驻外人员探亲申请") |
|||
@TableName("ad_expatriates_home_apply") |
|||
public class AdExpatriatesHomeApply extends BaseEntity { |
|||
private static final long serialVersionUID = 1L; |
|||
|
|||
@ApiModelProperty("申请人岗位sid") |
|||
private String postSid; // 申请人岗位sid
|
|||
@ApiModelProperty("申请人岗位名称") |
|||
private String postName; // 申请人岗位名称
|
|||
@ApiModelProperty("上次探亲休假探亲地") |
|||
private String lastAddress; // 上次探亲休假探亲地
|
|||
@ApiModelProperty("上次探亲休假开始时间") |
|||
private String lastStartDate; // 上次探亲休假开始时间
|
|||
@ApiModelProperty("上次探亲休假结束时间") |
|||
private String lastEndDate; // 上次探亲休假结束时间
|
|||
@ApiModelProperty("本次探亲休假探亲地") |
|||
private String thisAddress; // 本次探亲休假探亲地
|
|||
@ApiModelProperty("本次申请探亲休假开始时间") |
|||
private String thisStartDate; // 本次申请探亲休假开始时间
|
|||
@ApiModelProperty("本次申请探亲休假结束时间") |
|||
private String thisEndDate; // 本次申请探亲休假结束时间
|
|||
@ApiModelProperty("探亲家属关系") |
|||
private String relation; // 探亲家属关系
|
|||
@ApiModelProperty("探亲家属人数") |
|||
private String peoNum; // 探亲家属人数
|
|||
@ApiModelProperty("探亲类型") |
|||
private String homeType; // 探亲类型
|
|||
@ApiModelProperty("基础表单sid") |
|||
private String formSid; // 基础表单sid
|
|||
@ApiModelProperty("关联审批sid列表,英文逗号分隔") |
|||
private String linkFormSids; // 关联审批sid列表,英文逗号分隔
|
|||
|
|||
} |
@ -0,0 +1,74 @@ |
|||
/********************************************************* |
|||
********************************************************* |
|||
******************** ******************* |
|||
************* ************ |
|||
******* _oo0oo_ ******* |
|||
*** o8888888o *** |
|||
* 88" . "88 * |
|||
* (| -_- |) * |
|||
* 0\ = /0 * |
|||
* ___/`---'\___ * |
|||
* .' \\| |// '. *
|
|||
* / \\||| : |||// \ *
|
|||
* / _||||| -:- |||||- \ * |
|||
* | | \\\ - /// | | *
|
|||
* | \_| ''\---/'' |_/ | * |
|||
* \ .-\__ '-' ___/-. / * |
|||
* ___'. .' /--.--\ `. .'___ * |
|||
* ."" '< `.___\_<|>_/___.' >' "". * |
|||
* | | : `- \`.;`\ _ /`;.`/ - ` : | | * |
|||
* \ \ `_. \_ __\ /__ _/ .-` / / * |
|||
* =====`-.____`.___ \_____/___.-`___.-'===== * |
|||
* `=---=' * |
|||
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * |
|||
*********__佛祖保佑__永无BUG__验收通过__钞票多多__********* |
|||
*********************************************************/ |
|||
package com.yxt.anrui.oa.biz.adexpatriateshomeapply; |
|||
|
|||
import com.yxt.anrui.oa.biz.oaform.OaFormDto; |
|||
|
|||
import io.swagger.annotations.ApiModel; |
|||
import io.swagger.annotations.ApiModelProperty; |
|||
import lombok.Data; |
|||
|
|||
import java.util.ArrayList; |
|||
import java.util.List; |
|||
|
|||
@Data |
|||
@ApiModel(value = "驻外人员探亲申请 数据传输对象", description = "驻外人员探亲申请 数据传输对象") |
|||
public class AdExpatriatesHomeApplyDto extends OaFormDto { |
|||
|
|||
private String sid; // sid
|
|||
|
|||
@ApiModelProperty("申请人岗位sid") |
|||
private String postSid; // 申请人岗位sid
|
|||
@ApiModelProperty("申请人岗位名称") |
|||
private String postName; // 申请人岗位名称
|
|||
@ApiModelProperty("上次探亲休假探亲地") |
|||
private String lastAddress; // 上次探亲休假探亲地
|
|||
@ApiModelProperty("上次探亲休假开始时间") |
|||
private String lastStartDate; // 上次探亲休假开始时间
|
|||
@ApiModelProperty("上次探亲休假结束时间") |
|||
private String lastEndDate; // 上次探亲休假结束时间
|
|||
@ApiModelProperty("本次探亲休假探亲地") |
|||
private String thisAddress; // 本次探亲休假探亲地
|
|||
@ApiModelProperty("本次申请探亲休假开始时间") |
|||
private String thisStartDate; // 本次申请探亲休假开始时间
|
|||
@ApiModelProperty("本次申请探亲休假结束时间") |
|||
private String thisEndDate; // 本次申请探亲休假结束时间
|
|||
@ApiModelProperty("探亲家属关系") |
|||
private String relation; // 探亲家属关系
|
|||
@ApiModelProperty("探亲家属人数") |
|||
private String peoNum; // 探亲家属人数
|
|||
@ApiModelProperty("探亲类型") |
|||
private String homeType; // 探亲类型
|
|||
@ApiModelProperty("基础表单sid") |
|||
private String formSid; // 基础表单sid
|
|||
@ApiModelProperty("关联审批sid列表,英文逗号分隔") |
|||
private String linkFormSids; // 关联审批sid列表,英文逗号分隔
|
|||
|
|||
@ApiModelProperty("图片") |
|||
private List<String> files = new ArrayList<>(); |
|||
@ApiModelProperty("文件") |
|||
private List<String> appes = new ArrayList<>(); |
|||
} |
@ -0,0 +1,54 @@ |
|||
/********************************************************* |
|||
********************************************************* |
|||
******************** ******************* |
|||
************* ************ |
|||
******* _oo0oo_ ******* |
|||
*** o8888888o *** |
|||
* 88" . "88 * |
|||
* (| -_- |) * |
|||
* 0\ = /0 * |
|||
* ___/`---'\___ * |
|||
* .' \\| |// '. *
|
|||
* / \\||| : |||// \ *
|
|||
* / _||||| -:- |||||- \ * |
|||
* | | \\\ - /// | | *
|
|||
* | \_| ''\---/'' |_/ | * |
|||
* \ .-\__ '-' ___/-. / * |
|||
* ___'. .' /--.--\ `. .'___ * |
|||
* ."" '< `.___\_<|>_/___.' >' "". * |
|||
* | | : `- \`.;`\ _ /`;.`/ - ` : | | * |
|||
* \ \ `_. \_ __\ /__ _/ .-` / / * |
|||
* =====`-.____`.___ \_____/___.-`___.-'===== * |
|||
* `=---=' * |
|||
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * |
|||
*********__佛祖保佑__永无BUG__验收通过__钞票多多__********* |
|||
*********************************************************/ |
|||
package com.yxt.anrui.oa.biz.adexpatriateshomeapply; |
|||
|
|||
import com.baomidou.mybatisplus.core.conditions.Wrapper; |
|||
import com.baomidou.mybatisplus.core.metadata.IPage; |
|||
import com.baomidou.mybatisplus.core.mapper.BaseMapper; |
|||
import com.baomidou.mybatisplus.core.toolkit.Constants; |
|||
import org.apache.ibatis.annotations.Mapper; |
|||
import org.apache.ibatis.annotations.Param; |
|||
|
|||
/** |
|||
* Project: yxt-oa(驻外人员探亲申请) <br/> |
|||
* File: AdExpatriatesHomeApplyMapper.java <br/> |
|||
* Class: com.yxt.anrui.oa.biz.adexpatriateshomeapply.AdExpatriatesHomeApplyMapper <br/> |
|||
* Description: 驻外人员探亲申请. <br/> |
|||
* Copyright: Copyright (c) 2011 <br/> |
|||
* Company: https://gitee.com/liuzp315 <br/>
|
|||
* Makedate: 2025-01-21 15:36:23 <br/> |
|||
* |
|||
* @author liupopo |
|||
* @version 1.0 |
|||
* @since 1.0 |
|||
*/ |
|||
@Mapper |
|||
public interface AdExpatriatesHomeApplyMapper extends BaseMapper<AdExpatriatesHomeApply> { |
|||
|
|||
IPage<AdExpatriatesHomeApplyVo> selectPageVo(IPage<AdExpatriatesHomeApply> page, @Param(Constants.WRAPPER) Wrapper<AdExpatriatesHomeApply> qw); |
|||
|
|||
int selectBySid(String join); |
|||
} |
@ -0,0 +1,40 @@ |
|||
<?xml version="1.0" encoding="UTF-8" ?> |
|||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> |
|||
<mapper namespace="com.yxt.anrui.oa.biz.adexpatriateshomeapply.AdExpatriatesHomeApplyMapper"> |
|||
<!-- <where> ${ew.sqlSegment} </where>--> |
|||
<!-- ${ew.customSqlSegment} --> |
|||
<select id="selectPageVo" resultType="com.yxt.anrui.oa.biz.adexpatriateshomeapply.AdExpatriatesHomeApplyVo"> |
|||
SELECT aeh.sid, |
|||
aeh.remarks, |
|||
aeh.formSid, |
|||
ofm.billNo, |
|||
ofm.createByName, |
|||
ofm.deptSid, |
|||
ofm.deptName, |
|||
ofm.useOrgSid, |
|||
ofm.useOrgName, |
|||
DATE_FORMAT(ofm.finishTime) as finishTime, |
|||
ofm.procInstId, |
|||
ofm.procDefId, |
|||
ofm.taskId, |
|||
ofm.nodeId, |
|||
ofm.nodeState, |
|||
ofm.formType, |
|||
ofm.title, |
|||
ofm.createOrgSid, |
|||
ofm.createOrgName |
|||
FROM ad_expatriates_home_apply aeh |
|||
left join oa_form ofm on aeh.formSid = ofm.sid |
|||
<where> |
|||
${ew.sqlSegment} |
|||
</where> |
|||
</select> |
|||
|
|||
<select id="selectBySid" resultType="int"> |
|||
SELECT COUNT(*) |
|||
FROM ad_expatriates_home_apply aeh |
|||
left join oa_form ofm on aeh.formSid = ofm.sid |
|||
WHERE ofm.nodeState != '待提交' |
|||
and find_in_set(oa.sid, #{list}) |
|||
</select> |
|||
</mapper> |
@ -0,0 +1,40 @@ |
|||
/********************************************************* |
|||
********************************************************* |
|||
******************** ******************* |
|||
************* ************ |
|||
******* _oo0oo_ ******* |
|||
*** o8888888o *** |
|||
* 88" . "88 * |
|||
* (| -_- |) * |
|||
* 0\ = /0 * |
|||
* ___/`---'\___ * |
|||
* .' \\| |// '. *
|
|||
* / \\||| : |||// \ *
|
|||
* / _||||| -:- |||||- \ * |
|||
* | | \\\ - /// | | *
|
|||
* | \_| ''\---/'' |_/ | * |
|||
* \ .-\__ '-' ___/-. / * |
|||
* ___'. .' /--.--\ `. .'___ * |
|||
* ."" '< `.___\_<|>_/___.' >' "". * |
|||
* | | : `- \`.;`\ _ /`;.`/ - ` : | | * |
|||
* \ \ `_. \_ __\ /__ _/ .-` / / * |
|||
* =====`-.____`.___ \_____/___.-`___.-'===== * |
|||
* `=---=' * |
|||
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * |
|||
*********__佛祖保佑__永无BUG__验收通过__钞票多多__********* |
|||
*********************************************************/ |
|||
package com.yxt.anrui.oa.biz.adexpatriateshomeapply; |
|||
|
|||
import com.yxt.common.core.query.Query; |
|||
|
|||
import io.swagger.annotations.ApiModel; |
|||
import io.swagger.annotations.ApiModelProperty; |
|||
import lombok.Data; |
|||
|
|||
@Data |
|||
@ApiModel(value = "驻外人员探亲申请 查询条件", description = "驻外人员探亲申请 查询条件") |
|||
public class AdExpatriatesHomeApplyQuery implements Query { |
|||
|
|||
@ApiModelProperty("单据编号") |
|||
private String billNo; |
|||
} |
@ -0,0 +1,243 @@ |
|||
/********************************************************* |
|||
********************************************************* |
|||
******************** ******************* |
|||
************* ************ |
|||
******* _oo0oo_ ******* |
|||
*** o8888888o *** |
|||
* 88" . "88 * |
|||
* (| -_- |) * |
|||
* 0\ = /0 * |
|||
* ___/`---'\___ * |
|||
* .' \\| |// '. *
|
|||
* / \\||| : |||// \ *
|
|||
* / _||||| -:- |||||- \ * |
|||
* | | \\\ - /// | | *
|
|||
* | \_| ''\---/'' |_/ | * |
|||
* \ .-\__ '-' ___/-. / * |
|||
* ___'. .' /--.--\ `. .'___ * |
|||
* ."" '< `.___\_<|>_/___.' >' "". * |
|||
* | | : `- \`.;`\ _ /`;.`/ - ` : | | * |
|||
* \ \ `_. \_ __\ /__ _/ .-` / / * |
|||
* =====`-.____`.___ \_____/___.-`___.-'===== * |
|||
* `=---=' * |
|||
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * |
|||
*********__佛祖保佑__永无BUG__验收通过__钞票多多__********* |
|||
*********************************************************/ |
|||
package com.yxt.anrui.oa.biz.adexpatriateshomeapply; |
|||
|
|||
import cn.hutool.core.bean.BeanUtil; |
|||
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; |
|||
import com.baomidou.mybatisplus.core.metadata.IPage; |
|||
import com.yxt.anrui.oa.biz.adexpatriatesapply.AdExpatriatesApplyDto; |
|||
import com.yxt.anrui.oa.biz.oaappendix.OaAppendixService; |
|||
import com.yxt.anrui.oa.biz.oaform.OaFormRuleEnum; |
|||
import com.yxt.anrui.oa.biz.oaform.OaFormService; |
|||
import com.yxt.anrui.oa.biz.oaform.flowable.*; |
|||
import com.yxt.anrui.oa.feign.file.OaFileEnum; |
|||
import com.yxt.anrui.oa.feign.flowable.flow.ProcDefEnum; |
|||
import org.apache.commons.lang3.StringUtils; |
|||
import com.yxt.common.base.service.MybatisBaseService; |
|||
import com.yxt.common.base.utils.PagerUtil; |
|||
import com.yxt.common.core.query.PagerQuery; |
|||
import com.yxt.common.core.result.ResultBean; |
|||
import com.yxt.common.core.vo.PagerVo; |
|||
|
|||
import org.springframework.beans.factory.annotation.Autowired; |
|||
import org.springframework.stereotype.Service; |
|||
|
|||
import java.util.Collections; |
|||
import java.util.HashMap; |
|||
import java.util.List; |
|||
import java.util.Map; |
|||
|
|||
@Service |
|||
public class AdExpatriatesHomeApplyService extends MybatisBaseService<AdExpatriatesHomeApplyMapper, AdExpatriatesHomeApply> { |
|||
|
|||
@Autowired |
|||
private OaAppendixService oaAppendixService; |
|||
@Autowired |
|||
private OaFormService oaFormService; |
|||
|
|||
public PagerVo<AdExpatriatesHomeApplyVo> listPageVo(PagerQuery<AdExpatriatesHomeApplyQuery> pq) { |
|||
AdExpatriatesHomeApplyQuery query = pq.getParams(); |
|||
QueryWrapper<AdExpatriatesHomeApply> qw = new QueryWrapper<>(); |
|||
if (query != null) { |
|||
if (StringUtils.isNotBlank(query.getBillNo())) { |
|||
qw.like("ofm.billNo", query.getBillNo()); |
|||
} |
|||
} |
|||
IPage<AdExpatriatesHomeApply> page = PagerUtil.queryToPage(pq); |
|||
IPage<AdExpatriatesHomeApplyVo> pagging = baseMapper.selectPageVo(page, qw); |
|||
PagerVo<AdExpatriatesHomeApplyVo> p = PagerUtil.pageToVo(pagging, null); |
|||
return p; |
|||
} |
|||
|
|||
public ResultBean<String> saveOrUpdateDto(AdExpatriatesHomeApplyDto dto) { |
|||
ResultBean<String> rb = ResultBean.fireFail(); |
|||
String sid = dto.getSid(); |
|||
String homeType = dto.getHomeType(); |
|||
List<String> files = dto.getFiles(); |
|||
List<String> appes = dto.getAppes(); |
|||
if (StringUtils.isBlank(sid)) { |
|||
// 新建操作
|
|||
AdExpatriatesHomeApply entity = new AdExpatriatesHomeApply(); |
|||
BeanUtil.copyProperties(dto, entity, "sid"); |
|||
|
|||
if ("1".equals(homeType)){ |
|||
dto.setBillNo("ZWRYTQXJSQ"); |
|||
}else if ("2".equals(homeType)){ |
|||
dto.setBillNo("ZWRYJSTQSQ"); |
|||
} |
|||
|
|||
dto.setSid(entity.getSid()); |
|||
ResultBean<String> resultBean = oaFormService.saveOaForm(dto); |
|||
|
|||
if (!resultBean.getSuccess()) { |
|||
return rb; |
|||
} |
|||
|
|||
entity.setFormSid(resultBean.getData()); |
|||
baseMapper.insert(entity); |
|||
sid = entity.getSid(); |
|||
} else { |
|||
// 更新操作
|
|||
AdExpatriatesHomeApply entity = fetchBySid(sid); |
|||
BeanUtil.copyProperties(dto, entity, "id", "sid"); |
|||
baseMapper.updateById(entity); |
|||
} |
|||
// 处理附件
|
|||
saveFiles(sid, files, OaFileEnum.ADEXPATRIATESAPPLY.getAttachType(), "图片"); |
|||
saveFiles(sid, appes, OaFileEnum.ADEXPATRIATESAPPLY.getAttachType(), "文件"); |
|||
return rb.success().setData(sid); |
|||
} |
|||
|
|||
// 保存文件
|
|||
private void saveFiles(String sid, List<String> files, String attachType, String fileType) { |
|||
files.removeAll(Collections.singleton(null)); |
|||
oaAppendixService.saveFile(sid, files, attachType, fileType); |
|||
} |
|||
|
|||
public AdExpatriatesHomeApplyVo fetchDetailsVoBySid(String sid) { |
|||
AdExpatriatesHomeApply entity = fetchBySid(sid); |
|||
AdExpatriatesHomeApplyVo vo = new AdExpatriatesHomeApplyVo(); |
|||
BeanUtil.copyProperties(entity, vo); |
|||
return vo; |
|||
} |
|||
|
|||
/** |
|||
* 提交 |
|||
* |
|||
* @param dto |
|||
* @return |
|||
*/ |
|||
public ResultBean submit(AdExpatriatesHomeApplyDto dto) { |
|||
ResultBean rb = ResultBean.fireFail(); |
|||
ResultBean<String> stringResultBean = saveOrUpdateDto(dto); |
|||
if (!stringResultBean.getSuccess()) { |
|||
return rb.setMsg(stringResultBean.getData()); |
|||
} |
|||
String businessSid = stringResultBean.getData(); |
|||
|
|||
SubmitDto submitDto = new SubmitDto(); |
|||
submitDto.setUserSid(dto.getCreateBySid()); |
|||
submitDto.setBusinessSid(businessSid); |
|||
|
|||
Map<String, Object> formVariables = new HashMap<>(); |
|||
Map<String, Object> appMap = new HashMap<>(); |
|||
appMap.put("sid", businessSid); |
|||
//需和移动端沟通业务sid保存的属性具体值:appMap中sid不是固定的。移动端提供具体字段。
|
|||
formVariables.put("app", appMap); |
|||
submitDto.setFormVariables(formVariables); |
|||
submitDto.setProcDefId(ProcDefEnum.OAMENDAPPLY.getProDefId()); |
|||
//若申请单中选择了下一处理人,则需赋值给下一处理人字段,若没有则删除
|
|||
// submitDto.setNextNodeUserSids("");
|
|||
submitDto.setNextTaskId(dto.getTaskId()); |
|||
submitDto.setRule(OaFormRuleEnum.DIRECTLY_UNDER.getRule()); |
|||
return oaFormService.submit(submitDto); |
|||
} |
|||
|
|||
/** |
|||
* 办理(同意) |
|||
* |
|||
* @param dto |
|||
* @return |
|||
*/ |
|||
public ResultBean complete(CompleteDto dto) { |
|||
Map<String, Object> formVariables = dto.getFormVariables(); |
|||
//添加网关
|
|||
// formVariables.put("", "");
|
|||
Map<String, Object> appMap = new HashMap<>(); |
|||
appMap.put("sid", dto.getBusinessSid()); |
|||
formVariables.put("app", appMap); |
|||
dto.setFormVariables(formVariables); |
|||
BusinessVariablesDto businessVariablesDto = new BusinessVariablesDto(); |
|||
BeanUtil.copyProperties(dto, businessVariablesDto); |
|||
return oaFormService.complete(businessVariablesDto); |
|||
} |
|||
|
|||
/** |
|||
* 驳回 |
|||
* |
|||
* @param dto |
|||
* @return |
|||
*/ |
|||
public ResultBean reject(TaskDto dto) { |
|||
Map<String, Object> formVariables = dto.getFormVariables(); |
|||
//添加网关
|
|||
// formVariables.put("", "");
|
|||
//若有移动端,则需和移动端沟通具体参数,若没有删去即可。
|
|||
Map<String, Object> appMap = new HashMap<>(); |
|||
appMap.put("sid", dto.getBusinessSid()); |
|||
formVariables.put("app", appMap); |
|||
dto.setFormVariables(formVariables); |
|||
|
|||
return oaFormService.reject(dto); |
|||
} |
|||
|
|||
/** |
|||
* 提交时获取下一环节 |
|||
* |
|||
* @param query |
|||
* @return |
|||
*/ |
|||
public ResultBean<List<NodeVo>> getNextNodesForSubmit(NodeQuery query) { |
|||
Map<String, Object> formVariables = query.getFormVariables(); |
|||
//添加网关
|
|||
// formVariables.put("", "");
|
|||
//若有移动端,则需和移动端沟通具体参数,若没有删去即可。
|
|||
Map<String, Object> appMap = new HashMap<>(); |
|||
appMap.put("sid", query.getBusinessSid()); |
|||
formVariables.put("app", appMap); |
|||
query.setFormVariables(formVariables); |
|||
return oaFormService.getNextNodesForSubmit(query); |
|||
} |
|||
|
|||
/** |
|||
* 驳回时获取上一环节 |
|||
* |
|||
* @param query |
|||
* @return |
|||
*/ |
|||
public ResultBean<List<NodeVo>> getPreviousNodesForReject(NodeQuery query) { |
|||
Map<String, Object> formVariables = query.getFormVariables(); |
|||
//添加网关
|
|||
// formVariables.put("", "");
|
|||
//若有移动端,则需和移动端沟通具体参数,若没有删去即可。
|
|||
Map<String, Object> appMap = new HashMap<>(); |
|||
appMap.put("sid", query.getBusinessSid()); |
|||
formVariables.put("app", appMap); |
|||
query.setFormVariables(formVariables); |
|||
return oaFormService.getPreviousNodesForReject(query); |
|||
} |
|||
|
|||
public ResultBean delAll(String[] sids) { |
|||
ResultBean rb = ResultBean.fireFail(); |
|||
//查询该sid中是否有流程不是待提交的
|
|||
int count = baseMapper.selectBySid(StringUtils.join(sids, ",")); |
|||
if (count > 0) { |
|||
return rb.setMsg("删除的数据中包含已提交或已办结审批的数据,删除失败"); |
|||
} |
|||
delBySids(sids); |
|||
return rb.success(); |
|||
} |
|||
} |
@ -0,0 +1,74 @@ |
|||
/********************************************************* |
|||
********************************************************* |
|||
******************** ******************* |
|||
************* ************ |
|||
******* _oo0oo_ ******* |
|||
*** o8888888o *** |
|||
* 88" . "88 * |
|||
* (| -_- |) * |
|||
* 0\ = /0 * |
|||
* ___/`---'\___ * |
|||
* .' \\| |// '. *
|
|||
* / \\||| : |||// \ *
|
|||
* / _||||| -:- |||||- \ * |
|||
* | | \\\ - /// | | *
|
|||
* | \_| ''\---/'' |_/ | * |
|||
* \ .-\__ '-' ___/-. / * |
|||
* ___'. .' /--.--\ `. .'___ * |
|||
* ."" '< `.___\_<|>_/___.' >' "". * |
|||
* | | : `- \`.;`\ _ /`;.`/ - ` : | | * |
|||
* \ \ `_. \_ __\ /__ _/ .-` / / * |
|||
* =====`-.____`.___ \_____/___.-`___.-'===== * |
|||
* `=---=' * |
|||
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * |
|||
*********__佛祖保佑__永无BUG__验收通过__钞票多多__********* |
|||
*********************************************************/ |
|||
package com.yxt.anrui.oa.biz.adexpatriateshomeapply; |
|||
|
|||
import com.yxt.common.core.vo.Vo; |
|||
|
|||
import io.swagger.annotations.ApiModel; |
|||
import io.swagger.annotations.ApiModelProperty; |
|||
import lombok.Data; |
|||
|
|||
import java.util.ArrayList; |
|||
import java.util.List; |
|||
|
|||
@Data |
|||
@ApiModel(value = "驻外人员探亲申请 视图数据对象", description = "驻外人员探亲申请 视图数据对象") |
|||
public class AdExpatriatesHomeApplyVo implements Vo { |
|||
|
|||
private String sid; // sid
|
|||
|
|||
@ApiModelProperty("申请人岗位sid") |
|||
private String postSid; // 申请人岗位sid
|
|||
@ApiModelProperty("申请人岗位名称") |
|||
private String postName; // 申请人岗位名称
|
|||
@ApiModelProperty("上次探亲休假探亲地") |
|||
private String lastAddress; // 上次探亲休假探亲地
|
|||
@ApiModelProperty("上次探亲休假开始时间") |
|||
private String lastStartDate; // 上次探亲休假开始时间
|
|||
@ApiModelProperty("上次探亲休假结束时间") |
|||
private String lastEndDate; // 上次探亲休假结束时间
|
|||
@ApiModelProperty("本次探亲休假探亲地") |
|||
private String thisAddress; // 本次探亲休假探亲地
|
|||
@ApiModelProperty("本次申请探亲休假开始时间") |
|||
private String thisStartDate; // 本次申请探亲休假开始时间
|
|||
@ApiModelProperty("本次申请探亲休假结束时间") |
|||
private String thisEndDate; // 本次申请探亲休假结束时间
|
|||
@ApiModelProperty("探亲家属关系") |
|||
private String relation; // 探亲家属关系
|
|||
@ApiModelProperty("探亲家属人数") |
|||
private String peoNum; // 探亲家属人数
|
|||
@ApiModelProperty("探亲类型") |
|||
private String homeType; // 探亲类型
|
|||
@ApiModelProperty("基础表单sid") |
|||
private String formSid; // 基础表单sid
|
|||
@ApiModelProperty("关联审批sid列表,英文逗号分隔") |
|||
private String linkFormSids; // 关联审批sid列表,英文逗号分隔
|
|||
|
|||
@ApiModelProperty("图片") |
|||
private List<String> files = new ArrayList<>(); |
|||
@ApiModelProperty("附件") |
|||
private List<String> appes = new ArrayList<>(); |
|||
} |
Loading…
Reference in new issue