k94314517
2025-05-21 7222d2bcedd4b959107cfb0086a8bab10a2c15e0
git ch
已添加1个文件
已修改7个文件
801 ■■■■■ 文件已修改
server/platform/src/main/java/com/doumee/api/business/SettleClaimsController.java 42 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
server/service/src/main/java/com/doumee/core/utils/Constants.java 29 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
server/service/src/main/java/com/doumee/dao/business/model/SettleClaims.java 96 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
server/service/src/main/java/com/doumee/dao/business/model/SettleClaimsExt.java 14 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
server/service/src/main/java/com/doumee/dao/business/vo/SettleClaimsExcelVO.java 90 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
server/service/src/main/java/com/doumee/dao/business/vo/SettleParentStatusVO.java 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
server/service/src/main/java/com/doumee/service/business/SettleClaimsService.java 3 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
server/service/src/main/java/com/doumee/service/business/impl/SettleClaimsServiceImpl.java 525 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
server/platform/src/main/java/com/doumee/api/business/SettleClaimsController.java
@@ -10,10 +10,13 @@
import com.doumee.core.model.PageData;
import com.doumee.dao.business.dto.SCSupplementDTO;
import com.doumee.dao.business.model.SettleClaims;
import com.doumee.dao.business.vo.SettleClaimsExcelVO;
import com.doumee.service.business.SettleClaimsService;
import com.github.xiaoymin.knife4j.core.util.CollectionUtils;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletResponse;
@@ -141,7 +144,31 @@
    @PostMapping("/exportExcel")
    @RequiresPermissions("business:settleclaims:exportExcel")
    public void exportExcel (@RequestBody PageWrap<SettleClaims> pageWrap, HttpServletResponse response) {
        ExcelExporter.build(SettleClaims.class).export(settleClaimsService.findPage(pageWrap).getRecords(), "理赔申请表", response);
        ExcelExporter.build(SettleClaims.class).export(settleClaimsService.findPage(pageWrap).getRecords(), "报案理赔_"+System.currentTimeMillis(), response);
    }
    @ApiOperation("分页查询 - æ‰‹åЍ录入")
    @PostMapping("/pageForSD")
    @RequiresPermissions("business:settleclaims:query")
    public ApiResponse<PageData<SettleClaims>> pageForSD (@RequestBody PageWrap<SettleClaims> pageWrap) {
        return ApiResponse.success(settleClaimsService.findPageForSd(pageWrap));
    }
    @ApiOperation("导出Excel")
    @PostMapping("/exportForSDExcel")
    @RequiresPermissions("business:settleclaims:exportExcel")
    public void exportForSDExcel (@RequestBody PageWrap<SettleClaims> pageWrap, HttpServletResponse response) {
        List<SettleClaims> settleClaimsList = settleClaimsService.findPageForSd(pageWrap).getRecords();
        List<SettleClaimsExcelVO> settleClaimsExcelVOList = new ArrayList<>();
        if (CollectionUtils.isNotEmpty(settleClaimsList)){
            for (SettleClaims settleClaims:settleClaimsList) {
                SettleClaimsExcelVO settleClaimsExcelVO = new SettleClaimsExcelVO();
                BeanUtils.copyProperties(settleClaims,settleClaimsExcelVO);
                settleClaimsExcelVOList.add(settleClaimsExcelVO);
            }
        }
        ExcelExporter.build(SettleClaimsExcelVO.class).export(settleClaimsExcelVOList, "案件录入_"+System.currentTimeMillis(), response);
    }
    @ApiOperation("根据ID查询")
@@ -150,6 +177,17 @@
    public ApiResponse<SettleClaims> findById(@PathVariable Integer id) {
        return ApiResponse.success(settleClaimsService.getSettleClaimsDetail(id));
    }
    @ApiOperation("根据ID查询 - æ‰‹åЍ录入")
    @GetMapping("/getDetailForSd")
    @RequiresPermissions("business:settleclaims:query")
    public ApiResponse<SettleClaims> getDetailForSd(@RequestParam Integer id) {
        return ApiResponse.success(settleClaimsService.getSettleClaimsDetailForSd(id));
    }
    @ApiOperation("删除附件")
    @GetMapping("/delFile/{id}/{fileId}")
    @RequiresPermissions("business:settleclaims:query")
server/service/src/main/java/com/doumee/core/utils/Constants.java
@@ -769,6 +769,7 @@
        LP_FILE(32, "保险公司上传理赔材料一览表", "保险公司上传理赔材料一览表"),
        LP_OTHER_FILE(33, "理赔其他材料", "理赔其他材料"),
        LP_PAY_FILE(34, "打款凭证", "打款凭证"),
        LP_DZBD_FILE(35, "电子保单", "电子保单"),
        ;
        // æˆå‘˜å˜é‡
@@ -1938,7 +1939,7 @@
        // 8商议审批拒绝 9已受理 10待核赔  11已核赔 12已确认金额 13已结案 14已撤案
        WAIT_ACCEPTANCE(0, "暂存中",0),
        RETURN_ACCEPTANCE(1, "已报案",1),
        DEAL_ING(2, "待立案 ï¼ˆå¼ƒç”¨ï¼‰",0),
        DEAL_ING(2, "待立案",0),
        CONFIRM_INFORMATION(3, "已立案",1),
        FINISH_ACCEPTANCE(4, "立案退回",1),
        WAIT_DEAL(5, "待受理",2),
@@ -2083,23 +2084,25 @@
    public  enum SettleClaimsLogParentStatus {
        BA(1, "报案","已报案"),
        LA(2, "立案","已立案"),
        SL(3, "受理","已受理"),
        LS(4, "理算","已理算"),
        HP(5, "核赔","已核赔"),
        JA(6, "结案","已结案"),
        BA(1, "报案","已报案","已报案"),
        LA(2, "立案","已立案","待立案"),
        SL(3, "受理","已受理","待受理"),
        LS(4, "理算","已理算","待理算"),
        HP(5, "核赔","已核赔","待核赔"),
        JA(6, "结案","已结案","待结案"),
        ;
        // æˆå‘˜å˜é‡
        private String name;
        private String info;
        private String waitInfo;
        private int key;
        // æž„造方法
        SettleClaimsLogParentStatus(int key, String name,String info) {
        SettleClaimsLogParentStatus(int key, String name,String info,String waitInfo) {
            this.name = name;
            this.info = info;
            this.key = key;
            this.waitInfo = waitInfo;
        }
        // æ™®é€šæ–¹æ³•
@@ -2156,6 +2159,16 @@
        public void setInfo(String info) {
            this.info = info;
        }
        public String getWaitInfo() {
            return waitInfo;
        }
        public void setWaitInfo(String waitInfo) {
            this.waitInfo = waitInfo;
        }
    }
server/service/src/main/java/com/doumee/dao/business/model/SettleClaims.java
@@ -26,206 +26,154 @@
public class SettleClaims {
    @TableId(type = IdType.AUTO)
    @ApiModelProperty(value = "主键", example = "1")
    @ExcelColumn(name="主键")
    private Integer id;
    @ApiModelProperty(value = "创建人编码", example = "1")
    @ExcelColumn(name="创建人编码")
    private Integer creator;
    @ApiModelProperty(value = "创建时间")
    @ExcelColumn(name="创建时间")
    private Date createDate;
    @ApiModelProperty(value = "更新人编码", example = "1")
    @ExcelColumn(name="更新人编码")
    private Integer editor;
    @ApiModelProperty(value = "更新时间")
    @ExcelColumn(name="更新时间")
    private Date editDate;
    @ApiModelProperty(value = "是否删除0否 1是", example = "1")
    @ExcelColumn(name="是否删除0否 1是")
    private Integer isdeleted;
    @ApiModelProperty(value = "备注")
    @ExcelColumn(name="备注")
    private String remark;
    @ApiModelProperty(value = "排序码", example = "1")
    @ExcelColumn(name="排序码")
    private Integer sortnum;
    @ApiModelProperty(value = "方案编码(关联solutions)", example = "1")
    @ExcelColumn(name="方案编码(关联solutions)")
    private Integer solutionId;
    @ApiModelProperty(value = "企业编码(关联company)", example = "1")
    @ExcelColumn(name="企业编码(关联company)")
    private Integer companyId;
    @ApiModelProperty(value = "人员编码(关联memeber)", example = "1")
    @ExcelColumn(name="人员编码(关联memeber)")
    private Integer memberId;
    @ApiModelProperty(value = "事故发生时间")
    @ExcelColumn(name="事故发生时间")
    private String happenTime;
    @ApiModelProperty(value = "证件号")
    @ExcelColumn(name="证件号")
    private String idcardNo;
    @ApiModelProperty(value = "派遣单位编码(关联dispatch_unit)", example = "1")
    @ExcelColumn(name="派遣单位编码(关联dispatch_unit)")
    private Integer duId;
    @ApiModelProperty(value = "工种编码(关联worktype)", example = "1")
    @ExcelColumn(name="工种编码(关联worktype)")
    private Integer worktypeId;
    @ApiModelProperty(value = "费用", example = "1")
    @ExcelColumn(name="费用")
    private BigDecimal fee;
    @ApiModelProperty(value = "审核时间")
    @ExcelColumn(name="审核时间")
    private Date checkDate;
    @ApiModelProperty(value = "最近操作备注")
    @ExcelColumn(name="最近操作备注")
    private String checkInfo;
    @ApiModelProperty(value = "最近操作人编码(关联system_user)", example = "1")
    @ExcelColumn(name="最近操作人编码(关联system_user)")
    private Integer checkUserId;
    @ApiModelProperty(value = "单号")
    @ExcelColumn(name="单号")
    @ExcelColumn(name="报案号",index = 1,width = 20)
    private String code;
    @ApiModelProperty(value = "状态 0暂存中 1已报案 2待立案 3已立案 4立案退回 5待受理 6拒绝受理 7商议待审批 8商议审批拒绝 9已受理 10待核赔  11已核赔 12待结案 13已结案 14已撤案", example = "1")
    @ExcelColumn(name="状态 0暂存中 1已报案 2待立案 3已立案 4立案退回 5待受理 6拒绝受理 7商议待审批 8商议审批拒绝 9已受理 10待核赔  11已核赔 12待结案 13已结案 14已撤案")
    private Integer status;
    @ApiModelProperty(value = "事故类型 0工作期间受伤 1上下班途中受伤 2非工作时间受伤 3意外受伤", example = "1")
    @ExcelColumn(name="事故类型 0工作期间受伤 1上下班途中受伤 2非工作时间受伤 3意外受伤")
    private Integer type;
    @ApiModelProperty(value = "就诊类型:0住院 1门诊", example = "1")
    @ExcelColumn(name="就诊类型:0住院 1门诊")
    private Integer inHospital;
    @ApiModelProperty(value = "是否有医疗保险 0是 1否", example = "1")
    @ExcelColumn(name="是否有医疗保险 0是 1否")
    private Integer medicalInsurance;
    @ApiModelProperty(value = "事故描述")
    @ExcelColumn(name="事故描述")
    private String content;
    @ApiModelProperty(value = "报案人姓名")
    @ExcelColumn(name="报案人姓名")
    @ExcelColumn(name="报案人",index = 3,width = 20)
    private String informantName;
    @ApiModelProperty(value = "医疗理赔")
    @ExcelColumn(name="医疗理赔")
    private BigDecimal ylClaimAccount;
    @ApiModelProperty(value = "误工理赔")
    @ExcelColumn(name="误工理赔")
    private BigDecimal wgClaimAccount;
    @ApiModelProperty(value = "死亡理赔")
    @ExcelColumn(name="死亡理赔")
    private BigDecimal swClaimAccount;
    @ApiModelProperty(value = "伤残理赔")
    @ExcelColumn(name="伤残理赔")
    private BigDecimal scClaimAccount;
    @ApiModelProperty(value = "理赔总额")
    @ExcelColumn(name="理赔总额")
    private BigDecimal claimAccount;
    @ApiModelProperty(value = "报案人联系方式")
    @ExcelColumn(name="报案人联系方式")
    private String informantPhone;
    @ApiModelProperty(value = "就诊医疗机构")
    @ExcelColumn(name="就诊医疗机构")
    private String hospital;
    @ApiModelProperty(value = "出险地区(关联areas)", example = "1")
    @ExcelColumn(name="出险地区(关联areas)")
    private String areaId;
    @ApiModelProperty(value = "出险地区名称(省市)")
    @ExcelColumn(name="出险地区名称(省市)")
    private String areaInfo;
    @ApiModelProperty(value = "报案号")
    @ExcelColumn(name="报案号")
    @ExcelColumn(name="保司报案号",index = 2,width = 20)
    private String reportNum;
    @ApiModelProperty(value = "投保申请编码(关联insurance_apply_", example = "1")
    @ExcelColumn(name="投保申请编码(关联insurance_apply_")
    private Integer insuranceApplyId;
    @ApiModelProperty(value = "是否伤残: 0是 1否 2待确定")
    @ExcelColumn(name="是否伤残: 0是 1否 2待确定")
    private String hurtType;
    private Integer hurtType;
    @ApiModelProperty(value = "受理类型:0直接受理 1商议受理")
    @ExcelColumn(name="受理类型:0直接受理 1商议受理")
    private String shouliType;
    private Integer shouliType;
    @ApiModelProperty(value = "理赔来源 0企业 1平台录入 2其他 ")
    @ExcelColumn(name="理赔来源 0企业 1平台录入 2其他")
    private Integer origin;
    @ApiModelProperty(value = "受理商议问题 0资料缺失,1延迟报案 2超职业类别 3其他(多个用英文逗号隔开)")
    @ExcelColumn(name="受理商议问题 0资料缺失,1延迟报案 2超职业类别 3其他(多个用英文逗号隔开)")
    private String syProblemOpts;
    @ApiModelProperty(value = "是否风险案件 0否 1是")
    @ExcelColumn(name="是否风险案件 0否 1是")
    private Integer isRisk;
    @ApiModelProperty(value = "是否多次出险风险 0否1是 ")
    @ExcelColumn(name="是否多次出险风险 0否1是 ")
    private Integer riskTimesCx;
    @ApiModelProperty(value = "是否疑似重复报案风险 0否1是 ")
    @ExcelColumn(name="是否疑似重复报案风险 0否1是 ")
    private Integer riskRepeat;
    @ApiModelProperty(value = "是否索赔多次过多风险 0否1是")
    @ExcelColumn(name="是否索赔多次过多风险 0否1是")
    private Integer riskTimesSp;
    @ApiModelProperty(value = "是否新员工出险风险 0否1是")
    @ExcelColumn(name="是否新员工出险风险 0否1是")
    private Integer riskNewUser    ;
    @ApiModelProperty(value = "设计敏感词,多个英文逗号隔开")
    @ExcelColumn(name="设计敏感词,多个英文逗号隔开")
    private String riskSensitive;
    @ApiModelProperty(value = "报案号设置状态 0未设置 1已设置 2已修改")
    @ExcelColumn(name="报案号设置状态 0未设置 1已设置 2已修改")
    private Integer reportNumStatus;
    @ApiModelProperty(value = "所有赔付项信息(json数组[{name:“伙食费”,val:100,info:“伙食费说明”,type:0}]),type:0主要赔付项 1其他赔付项 2定损方案费用\t")
    @ExcelColumn(name="所有赔付项信息")
    private String accountContent;
    @ApiModelProperty(value = "其他赔付项总额")
    @ExcelColumn(name="其他赔付项总额")
    private BigDecimal otherAccount;
    @ApiModelProperty(value = "是否可赔付医保外用药")
    @ExcelColumn(name="是否可赔付医保外用药")
    private String payForYbwyy;
    private Integer payForYbwyy;
    @ApiModelProperty(value = "整体状态 0未提交 1待立案 2待受理 3")
    @ExcelColumn(name="整体状态")
    private String allStatus;
    @ApiModelProperty(value = "收款银行")
    @ExcelColumn(name="收款银行")
    private String receiveBank;
    @ApiModelProperty(value = "收款人")
    @ExcelColumn(name="收款人")
    private String receiveUserName;
    @ApiModelProperty(value = "收款账户")
    @ExcelColumn(name="收款账户")
    private String receiveAccount;
    @ApiModelProperty(value = "风险信息集合")
@@ -244,7 +192,6 @@
    @ApiModelProperty(value = "核赔所有赔付项信息(json数组[{name:“伙食费”,val:100,info:“伙食费说明”,type:0}]),type:0主要赔付项 1其他赔付项 2定损方案费用\t")
    @ExcelColumn(name="核赔所有赔付项信息")
    private String hpAccountContent;
    @ApiModelProperty(value = "核赔主要金额")
@@ -253,6 +200,15 @@
    @ApiModelProperty(value = "核赔其他金额")
    private BigDecimal hpOtherAccount;
    @ApiModelProperty(value = "赔偿金额")
    @TableField(exist = false)
    @ExcelColumn(name="赔偿金额",index = 10,width = 16)
    private BigDecimal pcAccount;
    @ApiModelProperty(value = "状态描述")
    @TableField(exist = false)
    @ExcelColumn(name="案件状态",index = 11,width = 16)
    private String statusName;
    @ApiModelProperty(value = "保险单附件")
    @TableField(exist = false)
@@ -276,6 +232,9 @@
    @ApiModelProperty(value = "伤残资料")
    @TableField(exist = false)
    private List<Multifile> disabilityFileList;
    @ApiModelProperty(value = "电子保单")
    @TableField(exist = false)
    private List<Multifile> dzbdFileList;
    @ApiModelProperty(value = "赔付结案资料")
    @TableField(exist = false)
@@ -290,30 +249,38 @@
    @TableField(exist = false)
    private List<Multifile> payFileList;
    @ApiModelProperty(value = "日志列表")
    @TableField(exist = false)
    List<SettleClaimsLog> settleClaimsLogList;
    @ApiModelProperty(value = "出险人")
    @TableField(exist = false)
    @ExcelColumn(name="出险人",index = 4,width = 16)
    private String memberName;
    @ApiModelProperty(value = "出险人身份证")
    @ExcelColumn(name="身份证号",index = 5,width = 16)
    @TableField(exist = false)
    private String memberIdcardNo;
    @ApiModelProperty(value = "企业名称")
    @ExcelColumn(name="投保单位",index = 6,width = 16)
    @TableField(exist = false)
    private String companyName;
    @ApiModelProperty(value = "保险方案名称")
    @TableField(exist = false)
    @ExcelColumn(name="保险方案",index = 8,width = 16)
    private String solutionName;
    @ApiModelProperty(value = "派遣单位名称")
    @TableField(exist = false)
    @ExcelColumn(name="用人单位",index = 7,width = 16)
    private String duName;
    @ApiModelProperty(value = "工种名称")
    @TableField(exist = false)
    private String worktypeName;
    @ApiModelProperty(value = "保单号")
    @TableField(exist = false)
    @ExcelColumn(name="保单号",index = 9,width = 16)
    private String applyCode;
    @ApiModelProperty(value = "保险生效起期")
    @TableField(exist = false)
@@ -340,4 +307,9 @@
    @TableField(exist = false)
    private List<CompensationVO> accountList;
    @ApiModelProperty(value = "报案时间 æŸ¥è¯¢ä½¿ç”¨ yyyy-MM-dd")
    @TableField(exist = false)
    private String createDateStr;
}
server/service/src/main/java/com/doumee/dao/business/model/SettleClaimsExt.java
@@ -8,6 +8,8 @@
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
import com.fasterxml.jackson.annotation.JsonFormat;
import org.springframework.format.annotation.DateTimeFormat;
import java.util.Date;
import java.math.BigDecimal;
@@ -72,6 +74,8 @@
    @ApiModelProperty(value = "出险人出生日期")
    @ExcelColumn(name="出险人出生日期")
    @DateTimeFormat(pattern = "yyyy-MM-dd")
    @JsonFormat(pattern="yyyy-MM-dd")
    private Date memberBirthday;
    @ApiModelProperty(value = "出险人年纪", example = "1")
@@ -130,8 +134,10 @@
    @ExcelColumn(name="是否已注销 0是 1否")
    private Integer logoff;
    @ApiModelProperty(value = "注销事件")
    @ExcelColumn(name="注销事件")
    @ApiModelProperty(value = "注销时间")
    @ExcelColumn(name="注销时间")
    @DateTimeFormat(pattern = "yyyy-MM-dd")
    @JsonFormat(pattern="yyyy-MM-dd")
    private Date logoffDate;
    @ApiModelProperty(value = "注销处理人")
@@ -168,6 +174,8 @@
    @ApiModelProperty(value = "人员伤亡-出院时间")
    @ExcelColumn(name="人员伤亡-出院时间")
    @DateTimeFormat(pattern = "yyyy-MM-dd")
    @JsonFormat(pattern="yyyy-MM-dd")
    private Date rsCyDate;
    @ApiModelProperty(value = "人员伤亡-医疗机构")
@@ -244,6 +252,8 @@
    @ApiModelProperty(value = "鉴定信息-评定日期")
    @ExcelColumn(name="鉴定信息-评定日期")
    @DateTimeFormat(pattern = "yyyy-MM-dd")
    @JsonFormat(pattern="yyyy-MM-dd")
    private Date jdPdDate;
    @ApiModelProperty(value = "鉴定信息-伤残等级 0-10", example = "1")
server/service/src/main/java/com/doumee/dao/business/vo/SettleClaimsExcelVO.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,90 @@
package com.doumee.dao.business.vo;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.doumee.core.annotation.excel.ExcelColumn;
import com.doumee.dao.business.model.Multifile;
import com.doumee.dao.business.model.SettleClaimsExt;
import com.doumee.dao.business.model.SettleClaimsLog;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import java.math.BigDecimal;
import java.util.Date;
import java.util.List;
/**
 * ç†èµ”申请表
 * @author æ±Ÿè¹„蹄
 * @date 2024/01/16 10:03
 */
@Data
@ApiModel("案件录入导出表")
public class SettleClaimsExcelVO {
    @ApiModelProperty(value = "报案号")
    @ExcelColumn(name="案件号",index = 1,width = 20)
    private String reportNum;
    @ApiModelProperty(value = "企业名称")
    @ExcelColumn(name="投保单位",index = 2,width = 16)
    @TableField(exist = false)
    private String companyName;
    @ApiModelProperty(value = "报案人姓名")
    @ExcelColumn(name="报案人",index = 3,width = 20)
    private String informantName;
    @ApiModelProperty(value = "创建时间")
    @ExcelColumn(name="报案时间",index = 4,width = 20,dateFormat = "yyyy-MM-dd HH:mm:ss")
    private Date createDate;
    @ApiModelProperty(value = "出险时间")
    @ExcelColumn(name="出险时间",index = 5,width = 20,dateFormat = "yyyy-MM-dd HH:mm:ss")
    private String happenTime;
    @ApiModelProperty(value = "出险人")
    @ExcelColumn(name="出险人",index = 6,width = 16)
    private String memberName;
    @ApiModelProperty(value = "出险人身份证")
    @ExcelColumn(name="身份证号",index = 7,width = 16)
    private String memberIdcardNo;
    @ApiModelProperty(value = "保险方案名称")
    @ExcelColumn(name="保险方案",index = 8,width = 16)
    private String solutionName;
    @ApiModelProperty(value = "保单号")
    @ExcelColumn(name="保单号",index = 9,width = 16)
    private String applyCode;
    @ApiModelProperty(value = "保险生效起期")
    @ExcelColumn(name="保险生效起期",index = 10,width = 16)
    private Date baoxianStartTime;
    @ApiModelProperty(value = "保险生效止期")
    @ExcelColumn(name="保险生效止期",index = 11,width = 16)
    private Date baoxianEndTime;
    @ApiModelProperty(value = "就诊类型:0住院 1门诊", example = "1")
    @ExcelColumn(name="就诊类型",index = 12,width = 16,valueMapping = "0=住院;1=门诊;")
    private Integer inHospital;
    @ApiModelProperty(value = "赔偿金额")
    @ExcelColumn(name="赔偿金额",index = 13,width = 16)
    private BigDecimal pcAccount;
    @ApiModelProperty(value = "状态描述")
    @TableField(exist = false)
    @ExcelColumn(name="案件状态",index = 14,width = 16)
    private String statusName;
}
server/service/src/main/java/com/doumee/dao/business/vo/SettleParentStatusVO.java
@@ -21,7 +21,7 @@
    @ApiModelProperty(value = "操作时间")
    private Date optDate;
    @ApiModelProperty(value = "类型:0=已处理;1=处理中;2=待处理;3=已驳回")
    @ApiModelProperty(value = "类型:0=已处理;1=处理中;2=待处理;3=已驳回、已撤案")
    private Integer status;
}
server/service/src/main/java/com/doumee/service/business/SettleClaimsService.java
@@ -107,6 +107,7 @@
     */
    PageData<SettleClaims> findPage(PageWrap<SettleClaims> pageWrap);
    PageData<SettleClaims> findPageForSd(PageWrap<SettleClaims> pageWrap);
    /**
     * æ¡ä»¶ç»Ÿè®¡
     *
@@ -117,6 +118,8 @@
    SettleClaims getSettleClaimsDetail(Integer id);
    SettleClaims getSettleClaimsDetailForSd(Integer id);
    void exportFiles(Integer id, HttpServletResponse response);
    Integer addCode(SettleClaims settleClaims);
server/service/src/main/java/com/doumee/service/business/impl/SettleClaimsServiceImpl.java
@@ -449,13 +449,19 @@
        settleClaimsExtMapper.insert(settleClaims.getExtData());
        //处理附件开始
        multifileJoinMapper.update(null,new UpdateWrapper<Multifile>().lambda()
                .set(Multifile::getIsdeleted,Constants.ZERO)
                .set(Multifile::getIsdeleted,Constants.ONE)
                .eq(Multifile::getObjId,model.getId())
                .in(Multifile::getObjType,Constants.MultiFile.LP_YGGX_FILE.getKey()
                .in(Multifile::getObjType
                        ,Constants.MultiFile.LP_YGGX_FILE.getKey()
                        ,Constants.MultiFile.LP_ZYCL_FILE.getKey()
                        ,Constants.MultiFile.LP_MZCL_FILE.getKey()
                        ,Constants.MultiFile.LP_OTHER_FILE.getKey()
                        ,Constants.MultiFile.LP_SCZL_FILE.getKey()));
                        ,Constants.MultiFile.LP_SCZL_FILE.getKey()
                        ,Constants.MultiFile.LP_SGXC_FILE.getKey()
                        ,Constants.MultiFile.LP_DZBD_FILE.getKey()
                )
        );
        dealSysFileListBiz(settleClaims);
    }
@@ -487,12 +493,16 @@
        List<Multifile> outpatientFileList = settleClaims.getOutpatientFileList();//门诊材料
        List<Multifile> otherFileList = settleClaims.getOtherFileList();//其他材料
        List<Multifile> disabilityFileList = settleClaims.getDisabilityFileList();//伤残材料
        List<Multifile> dzbdFileList = settleClaims.getDzbdFileList();//电子保单
        List<Multifile> reportFileList = settleClaims.getReportFileList();//报案视频
        List<Multifile> insetList = new ArrayList<>();
        insetList.addAll(getMultifileListByObjtype(relationFileList,Constants.MultiFile.LP_YGGX_FILE.getKey(),settleClaims));
        insetList.addAll(getMultifileListByObjtype(hospitalFileList,Constants.MultiFile.LP_ZYCL_FILE.getKey(),settleClaims));
        insetList.addAll(getMultifileListByObjtype(outpatientFileList,Constants.MultiFile.LP_MZCL_FILE.getKey(),settleClaims));
        insetList.addAll(getMultifileListByObjtype(otherFileList,Constants.MultiFile.LP_OTHER_FILE.getKey(),settleClaims));
        insetList.addAll(getMultifileListByObjtype(disabilityFileList,Constants.MultiFile.LP_SCZL_FILE.getKey(),settleClaims));
        insetList.addAll(getMultifileListByObjtype(dzbdFileList,Constants.MultiFile.LP_DZBD_FILE.getKey(),settleClaims));
        insetList.addAll(getMultifileListByObjtype(reportFileList,Constants.MultiFile.LP_SGXC_FILE.getKey(),settleClaims));
        if(CollectionUtils.isNotEmpty(insetList)){
                multifileJoinMapper.insert(insetList);
        }
@@ -510,6 +520,7 @@
                        || StringUtils.isBlank(multifile.getName())  ){
                    continue;
                }
                multifile.setId(null);
                multifile.setCreator(model.getEditor());
                multifile.setCreateDate(model.getEditDate());
                multifile.setEditor(model.getEditor());
@@ -723,6 +734,122 @@
            settleClaims.setOtherFileList(multifileList.stream().filter(m->m.getObjType().equals(Constants.MultiFile.LP_OTHER_FILE.getKey())).collect(Collectors.toList()));
            settleClaims.setPayFileList(multifileList.stream().filter(m->m.getObjType().equals(Constants.MultiFile.LP_PAY_FILE.getKey())).collect(Collectors.toList()));
            settleClaims.setDzbdFileList(multifileList.stream().filter(m->m.getObjType().equals(Constants.MultiFile.LP_DZBD_FILE.getKey())).collect(Collectors.toList()));
        }
        //查询操作记录
        List<SettleClaimsLog> settleClaimsLogList = settleClaimsLogJoinMapper.selectJoinList(SettleClaimsLog.class,
                new MPJLambdaWrapper<SettleClaimsLog>()
                        .selectAll(SettleClaimsLog.class)
                        .selectAs(SystemUser::getRealname,SettleClaimsLog::getCreatorName)
                        .selectAs(SystemUser::getType,SettleClaimsLog::getCreatorType)
                        .selectAs(Company::getName,SettleClaimsLog::getCompanyName)
                        .leftJoin(SystemUser.class,SystemUser::getId,SettleClaimsLog::getCreator)
                        .leftJoin(Company.class,Company::getId,SystemUser::getCompanyId)
                        .eq(SettleClaimsLog::getSettleClainmsId,settleClaims.getId())
                        .orderByAsc(SettleClaimsLog::getCreateDate)
        );
        settleClaims.setSettleClaimsLogList(settleClaimsLogList);
        SettleClaimsLog lastConfirm = settleClaimsLogMapper.selectOne(new QueryWrapper<SettleClaimsLog>().lambda()
                .eq(SettleClaimsLog::getSettleClainmsId,settleClaims.getId())
                .eq(SettleClaimsLog::getObjType,Constants.SettleClaimsLogType.PLATFORM_CONFIRM_INFORMATION.getKey())
                .orderByDesc(SettleClaimsLog::getCreateDate)
                .last(" limit 1")
        );
        Multifile multifile = multifileJoinMapper.selectOne(new QueryWrapper<Multifile>()
                .lambda()
                .eq(Multifile::getObjId,settleClaims.getId())
                .eq(Multifile::getIsdeleted,Constants.ZERO)
                .in(Multifile::getObjType,
                        Constants.MultiFile.LP_SGXC_FILE.getKey(),
                        Constants.MultiFile.LP_YGGX_FILE.getKey(),
                        Constants.MultiFile.LP_MZCL_FILE.getKey(),
                        Constants.MultiFile.LP_ZYCL_FILE.getKey(),
                        Constants.MultiFile.LP_SCZL_FILE.getKey(),
                        Constants.MultiFile.LP_JACL_FILE.getKey())
                .orderByDesc(Multifile::getCreateDate)
                .last(" limit 1")
        );
        if(!Objects.isNull(lastConfirm)&&!Objects.isNull(multifile)){
            settleClaims.setFinishDate(lastConfirm.getCreateDate().compareTo(multifile.getCreateDate())>=0?lastConfirm.getCreateDate():multifile.getCreateDate());
        }else if(!Objects.isNull(lastConfirm)&&Objects.isNull(multifile)){
            settleClaims.setFinishDate(lastConfirm.getCreateDate());
        }
        return settleClaims;
    }
    @Override
    public SettleClaims getSettleClaimsDetailForSd(Integer id){
        MPJLambdaWrapper<SettleClaims>  queryWrapper =    new MPJLambdaWrapper<SettleClaims>();
        queryWrapper.selectAll(SettleClaims.class)
                .selectAs(SettleClaimsExt::getBxOrg,SettleClaims::getCompanyName)
                .selectAs(SettleClaimsExt::getBxName,SettleClaims::getSolutionName)
                .selectAs(SettleClaimsExt::getMemberName,SettleClaims::getMemberName)
                .selectAs(SettleClaimsExt::getMemberIdcard,SettleClaims::getMemberIdcardNo)
                .selectAs(SettleClaimsExt::getBxStartdate,SettleClaims::getBaoxianStartTime)
                .selectAs(SettleClaimsExt::getBxEnddate,SettleClaims::getBaoxianEndTime)
                .selectAs(SettleClaimsExt::getBxCode,SettleClaims::getApplyCode)
                .innerJoin(SettleClaimsExt.class,SettleClaimsExt::getSettileClaimsId,SettleClaims::getId)
                .eq(SettleClaims::getId,id);
        SettleClaims settleClaims = settleClaimsJoinMapper.selectJoinOne(SettleClaims.class,queryWrapper);
        if(settleClaims == null){
            throw new BusinessException(ResponseStatus.DATA_EMPTY);
        }
        if(StringUtils.isNotBlank(settleClaims.getHpAccountContent())){
            settleClaims.setAccountList(JSONArray.parseArray(settleClaims.getHpAccountContent(),CompensationVO.class ));
        }
        List<Multifile> multifileList = multifileJoinMapper.selectJoinList(Multifile.class,
                new MPJLambdaWrapper<Multifile>()
                        .selectAll(Multifile.class)
                        .selectAs(SystemUser::getRealname,Multifile::getCreatorName)
                        .leftJoin(SystemUser.class,SystemUser::getId,Multifile::getCreator)
                        .eq(Multifile::getObjId,id)
                        .eq(Multifile::getIsdeleted,Constants.ZERO)
                        .orderByAsc(Multifile::getCreateDate)
        );
        String rPath = systemDictDataBiz.queryByCode(Constants.OSS,Constants.RESOURCE_PATH).getCode();
        String path = rPath+ systemDictDataBiz.queryByCode(Constants.OSS,Constants.SETTLE_FILE).getCode();
        if(multifileList!=null){
            for(Multifile f : multifileList){
                if(f!=null&& StringUtils.isNotBlank(f.getFileurl())){
                    f.setFileurlFull(path+f.getFileurl());
                }
            }
        }
        Multifile baoxiandanFile = multifileJoinMapper.selectOne(new QueryWrapper<Multifile>()
                .lambda().eq(Multifile::getObjId,settleClaims.getInsuranceApplyId())
                .eq(Multifile::getIsdeleted,Constants.ZERO)
                .eq(Multifile::getObjType,Constants.MultiFile.BD_DONE_PDF.getKey())
                .last("limit 1"));
        if(baoxiandanFile!=null&& StringUtils.isNotBlank(baoxiandanFile.getFileurl())){
            path = rPath+ systemDictDataBiz.queryByCode(Constants.OSS,Constants.APPLY_FILE).getCode();
            baoxiandanFile.setFileurlFull(path+baoxiandanFile.getFileurl());
        }
        settleClaims.setBaoxiandanFile(baoxiandanFile);//保险单
        if(CollectionUtils.isNotEmpty(multifileList)){
            settleClaims.setReportFileList(multifileList.stream().filter(m->m.getObjType().equals(Constants.MultiFile.LP_SGXC_FILE.getKey())).collect(Collectors.toList()));
            settleClaims.setRelationFileList(multifileList.stream().filter(m->m.getObjType().equals(Constants.MultiFile.LP_YGGX_FILE.getKey())).collect(Collectors.toList()));
            settleClaims.setOutpatientFileList(multifileList.stream().filter(m->m.getObjType().equals(Constants.MultiFile.LP_MZCL_FILE.getKey())).collect(Collectors.toList()));
            settleClaims.setHospitalFileList(multifileList.stream().filter(m->m.getObjType().equals(Constants.MultiFile.LP_ZYCL_FILE.getKey())).collect(Collectors.toList()));
            settleClaims.setDisabilityFileList(multifileList.stream().filter(m->m.getObjType().equals(Constants.MultiFile.LP_SCZL_FILE.getKey())).collect(Collectors.toList()));
            settleClaims.setCompensationFileList(multifileList.stream().filter(m->m.getObjType().equals(Constants.MultiFile.LP_JACL_FILE.getKey())).collect(Collectors.toList()));
            settleClaims.setOtherFileList(multifileList.stream().filter(m->m.getObjType().equals(Constants.MultiFile.LP_OTHER_FILE.getKey())).collect(Collectors.toList()));
            settleClaims.setPayFileList(multifileList.stream().filter(m->m.getObjType().equals(Constants.MultiFile.LP_PAY_FILE.getKey())).collect(Collectors.toList()));
            settleClaims.setDzbdFileList(multifileList.stream().filter(m->m.getObjType().equals(Constants.MultiFile.LP_DZBD_FILE.getKey())).collect(Collectors.toList()));
        }
        //查询操作记录
@@ -771,6 +898,7 @@
                    .eq(SettleClaimsExt::getSettileClaimsId,settleClaims.getId())
                    .last("limit 1")));
        }
        settleClaims.setExtData(settleClaimsExtMapper.selectOne(new QueryWrapper<SettleClaimsExt>().lambda().eq(SettleClaimsExt::getSettileClaimsId,id).last("limit 1")));
        return settleClaims;
    }
@@ -912,7 +1040,7 @@
    @Override
    public void deleteById(Integer id) {
        settleClaimsMapper.deleteById(id);
        settleClaimsMapper.update(new UpdateWrapper<SettleClaims>().lambda().set(SettleClaims::getIsdeleted,Constants.ONE).eq(SettleClaims::getId,id));
    }
    @Override
@@ -976,6 +1104,8 @@
                .selectAs(Worktype::getName,SettleClaims::getWorktypeName)
                .selectAs(InsuranceApply::getStartTime,SettleClaims::getBaoxianStartTime)
                .selectAs(DispatchUnit::getName,SettleClaims::getDuName)
                .selectAs(InsuranceApply::getStartTime,SettleClaims::getBaoxianStartTime)
                .selectAs(InsuranceApply::getEndTime,SettleClaims::getBaoxianEndTime)
                .leftJoin(Company.class,Company::getId,SettleClaims::getCompanyId)
                .leftJoin(Member.class,Member::getId,SettleClaims::getMemberId)
                .leftJoin(DispatchUnit.class,DispatchUnit::getId,SettleClaims::getDuId)
@@ -995,113 +1125,26 @@
            //企业用户只看自己的数据
            pageWrap.getModel().setCompanyId(user.getCompanyId());
        }
        queryWrapper.eq(SettleClaims::getIsdeleted,Constants.ZERO);
        queryWrapper.eq(SettleClaims::getOrigin,Constants.ZERO);
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getMemberName()),Member::getName, pageWrap.getModel().getMemberName());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getMemberIdcardNo()),Member::getIdcardNo, pageWrap.getModel().getMemberIdcardNo());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getInformantName()),SettleClaims::getInformantName, pageWrap.getModel().getInformantName());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getDuName()),DispatchUnit::getName, pageWrap.getModel().getDuName());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getCreateDateStr()),SettleClaims::getCreateDate, pageWrap.getModel().getCreateDateStr());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getHappenTime()),SettleClaims::getHappenTime, pageWrap.getModel().getHappenTime());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getDuName()),DispatchUnit::getName, pageWrap.getModel().getDuName());
        queryWrapper.eq(pageWrap.getModel().getBaseSolutionId()!=null,Solutions::getBaseId, pageWrap.getModel().getBaseSolutionId());
        queryWrapper.eq(pageWrap.getModel().getBaseDuId()!=null,DispatchUnit::getBaseId, pageWrap.getModel().getBaseDuId());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getSolutionName()),Solutions::getName, pageWrap.getModel().getSolutionName());
        queryWrapper.eq(pageWrap.getModel().getInHospital()!=null,SettleClaims::getInHospital, pageWrap.getModel().getInHospital());
        queryWrapper.eq(pageWrap.getModel().getStatus()!=null,SettleClaims::getStatus, pageWrap.getModel().getStatus());
        queryWrapper.eq(pageWrap.getModel().getCompanyId()!=null,SettleClaims::getCompanyId, pageWrap.getModel().getCompanyId());
        queryWrapper.eq(pageWrap.getModel().getOrigin()!=null,SettleClaims::getOrigin, pageWrap.getModel().getOrigin());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getCode()),SettleClaims::getCode, pageWrap.getModel().getCode());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getReportNum()),SettleClaims::getReportNum, pageWrap.getModel().getReportNum());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getApplyCode()),InsuranceApply::getCode, pageWrap.getModel().getApplyCode());
        if (pageWrap.getModel().getId() != null) {
            queryWrapper.eq(SettleClaims::getId, pageWrap.getModel().getId());
        }
        if (pageWrap.getModel().getCreator() != null) {
            queryWrapper.eq(SettleClaims::getCreator, pageWrap.getModel().getCreator());
        }
        if (pageWrap.getModel().getCreateDate() != null) {
            queryWrapper.ge(SettleClaims::getCreateDate, Utils.Date.getStart(pageWrap.getModel().getCreateDate()));
            queryWrapper.le(SettleClaims::getCreateDate, Utils.Date.getEnd(pageWrap.getModel().getCreateDate()));
        }
        if (pageWrap.getModel().getEditor() != null) {
            queryWrapper.eq(SettleClaims::getEditor, pageWrap.getModel().getEditor());
        }
        if (pageWrap.getModel().getEditDate() != null) {
            queryWrapper.ge(SettleClaims::getEditDate, Utils.Date.getStart(pageWrap.getModel().getEditDate()));
            queryWrapper.le(SettleClaims::getEditDate, Utils.Date.getEnd(pageWrap.getModel().getEditDate()));
        }
        if (pageWrap.getModel().getIsdeleted() != null) {
            queryWrapper.eq(SettleClaims::getIsdeleted, pageWrap.getModel().getIsdeleted());
        }
        if (pageWrap.getModel().getRemark() != null) {
            queryWrapper.eq(SettleClaims::getRemark, pageWrap.getModel().getRemark());
        }
        if (pageWrap.getModel().getSortnum() != null) {
            queryWrapper.eq(SettleClaims::getSortnum, pageWrap.getModel().getSortnum());
        }
        if (pageWrap.getModel().getSolutionId() != null) {
            queryWrapper.eq(SettleClaims::getSolutionId, pageWrap.getModel().getSolutionId());
        }
        if (pageWrap.getModel().getCompanyId() != null) {
            queryWrapper.eq(SettleClaims::getCompanyId, pageWrap.getModel().getCompanyId());
        }
        if (pageWrap.getModel().getMemberId() != null) {
            queryWrapper.eq(SettleClaims::getMemberId, pageWrap.getModel().getMemberId());
        }
        if (pageWrap.getModel().getHappenTime() != null) {
            queryWrapper.eq(SettleClaims::getHappenTime, pageWrap.getModel().getHappenTime());
        }
        if (pageWrap.getModel().getIdcardNo() != null) {
            queryWrapper.eq(SettleClaims::getIdcardNo, pageWrap.getModel().getIdcardNo());
        }
        if (pageWrap.getModel().getDuId() != null) {
            queryWrapper.eq(SettleClaims::getDuId, pageWrap.getModel().getDuId());
        }
        if (pageWrap.getModel().getWorktypeId() != null) {
            queryWrapper.eq(SettleClaims::getWorktypeId, pageWrap.getModel().getWorktypeId());
        }
        if (pageWrap.getModel().getFee() != null) {
            queryWrapper.eq(SettleClaims::getFee, pageWrap.getModel().getFee());
        }
        if (pageWrap.getModel().getCheckInfo() != null) {
            queryWrapper.eq(SettleClaims::getCheckInfo, pageWrap.getModel().getCheckInfo());
        }
        if (pageWrap.getModel().getCheckUserId() != null) {
            queryWrapper.eq(SettleClaims::getCheckUserId, pageWrap.getModel().getCheckUserId());
        }
        if (pageWrap.getModel().getCode() != null) {
            queryWrapper.eq(SettleClaims::getCode, pageWrap.getModel().getCode());
        }
        if (pageWrap.getModel().getStatus() != null) {
            if(pageWrap.getModel().getStatus().equals(Constants.ZERO)){
                queryWrapper.in(SettleClaims::getStatus, Constants.SettleClaimsStatus.WAIT_ACCEPTANCE.getKey()
                        ,Constants.SettleClaimsStatus.DEAL_ING.getKey()
                        ,Constants.SettleClaimsStatus.CONFIRM_INFORMATION.getKey());
            }else{
                queryWrapper.eq(SettleClaims::getStatus, pageWrap.getModel().getStatus());
            }
        }
        if (pageWrap.getModel().getType() != null) {
            queryWrapper.eq(SettleClaims::getType, pageWrap.getModel().getType());
        }
        if (pageWrap.getModel().getInHospital() != null) {
            queryWrapper.eq(SettleClaims::getInHospital, pageWrap.getModel().getInHospital());
        }
        if (pageWrap.getModel().getMedicalInsurance() != null) {
            queryWrapper.eq(SettleClaims::getMedicalInsurance, pageWrap.getModel().getMedicalInsurance());
        }
        if (pageWrap.getModel().getContent() != null) {
            queryWrapper.eq(SettleClaims::getContent, pageWrap.getModel().getContent());
        }
        if (pageWrap.getModel().getInformantName() != null) {
            queryWrapper.eq(SettleClaims::getInformantName, pageWrap.getModel().getInformantName());
        }
        if (pageWrap.getModel().getInformantPhone() != null) {
            queryWrapper.eq(SettleClaims::getInformantPhone, pageWrap.getModel().getInformantPhone());
        }
        if (pageWrap.getModel().getAreaId() != null) {
            queryWrapper.eq(SettleClaims::getAreaId, pageWrap.getModel().getAreaId());
        }
        if (pageWrap.getModel().getAreaInfo() != null) {
            queryWrapper.eq(SettleClaims::getAreaInfo, pageWrap.getModel().getAreaInfo());
        }
        if (pageWrap.getModel().getReportNum() != null) {
            queryWrapper.eq(SettleClaims::getReportNum, pageWrap.getModel().getReportNum());
        }
        if (pageWrap.getModel().getInsuranceApplyId() != null) {
            queryWrapper.eq(SettleClaims::getInsuranceApplyId, pageWrap.getModel().getInsuranceApplyId());
        }
        queryWrapper.orderByDesc(SettleClaims::getCreateDate);
        /*for(PageWrap.SortData sortData: pageWrap.getSorts()) {
            if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) {
@@ -1111,8 +1154,51 @@
            }
        }*/
        PageData<SettleClaims> pageData = PageData.from(settleClaimsJoinMapper.selectJoinPage(page,SettleClaims.class, queryWrapper));
        for (SettleClaims settleClaims:pageData.getRecords()) {
            settleClaims.setStatusName(Constants.SettleClaimsStatus.getName(settleClaims.getStatus()));
            settleClaims.setPcAccount(settleClaims.getHpAccount().add(settleClaims.getHpOtherAccount()));
        }
        return pageData;
    }
    @Override
    public PageData<SettleClaims> findPageForSd(PageWrap<SettleClaims> pageWrap) {
        IPage<SettleClaims> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
        LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
        Utils.MP.blankToNull(pageWrap.getModel());
        MPJLambdaWrapper<SettleClaims>  queryWrapper = new MPJLambdaWrapper<SettleClaims>();
        queryWrapper.selectAll(SettleClaims.class)
                .selectAs(SettleClaimsExt::getBxOrg,SettleClaims::getCompanyName)
                .selectAs(SettleClaimsExt::getBxName,SettleClaims::getSolutionName)
                .selectAs(SettleClaimsExt::getMemberName,SettleClaims::getMemberName)
                .selectAs(SettleClaimsExt::getMemberIdcard,SettleClaims::getMemberIdcardNo)
                .selectAs(SettleClaimsExt::getBxStartdate,SettleClaims::getBaoxianStartTime)
                .selectAs(SettleClaimsExt::getBxEnddate,SettleClaims::getBaoxianEndTime)
                .selectAs(SettleClaimsExt::getBxCode,SettleClaims::getApplyCode)
                .innerJoin(SettleClaimsExt.class,SettleClaimsExt::getSettileClaimsId,SettleClaims::getId);
        queryWrapper.eq(SettleClaims::getIsdeleted,Constants.ZERO);
        queryWrapper.eq(SettleClaims::getOrigin,Constants.ONE);
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getReportNum()),SettleClaims::getReportNum, pageWrap.getModel().getReportNum());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getCompanyName()),SettleClaimsExt::getBxOrg, pageWrap.getModel().getCompanyName());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getInformantName()),SettleClaims::getInformantName, pageWrap.getModel().getInformantName());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getHappenTime()),SettleClaims::getHappenTime, pageWrap.getModel().getHappenTime());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getCreateDateStr()),SettleClaims::getCreateDate, pageWrap.getModel().getCreateDateStr());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getMemberName()),SettleClaimsExt::getMemberName, pageWrap.getModel().getMemberName());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getSolutionName()),SettleClaimsExt::getBxName, pageWrap.getModel().getSolutionName());
        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getApplyCode()),SettleClaimsExt::getBxCode, pageWrap.getModel().getApplyCode());
        queryWrapper.eq(pageWrap.getModel().getInHospital()!=null,SettleClaims::getInHospital, pageWrap.getModel().getInHospital());
        queryWrapper.eq(pageWrap.getModel().getStatus()!=null,SettleClaims::getStatus, pageWrap.getModel().getStatus());
        queryWrapper.orderByDesc(SettleClaims::getCreateDate);
        PageData<SettleClaims> pageData = PageData.from(settleClaimsJoinMapper.selectJoinPage(page,SettleClaims.class, queryWrapper));
        for (SettleClaims settleClaims:pageData.getRecords()) {
            settleClaims.setStatusName(Constants.SettleClaimsStatus.getName(settleClaims.getStatus()));
            settleClaims.setPcAccount(settleClaims.getHpAccount().add(settleClaims.getHpOtherAccount()));
        }
        return pageData;
    }
    @Override
    public long count(SettleClaims settleClaims) {
@@ -2203,101 +2289,140 @@
    }
//
//    public List<SettleParentStatusVO> getParentStatus(SettleClaims settleClaims){
//        List<SettleParentStatusVO> settleParentStatusVOList = new ArrayList<>();
//        List<SettleClaimsLog> settleClaimsLogList = settleClaimsLogMapper
//                .selectList(new QueryWrapper<SettleClaimsLog>().lambda().eq(SettleClaimsLog::getObjId,settleClaims.getId()).orderByDesc(SettleClaimsLog::getCreateDate));
//        //立案退回状态数据
//        if(Constants.equalsInteger(settleClaims.getStatus(),Constants.SettleClaimsStatus.FINISH_ACCEPTANCE.getKey())){
//            SettleParentStatusVO settleParentStatusVO = new SettleParentStatusVO();
//            settleParentStatusVO.setParentTitle("报案");
//            settleParentStatusVO.setStatus(Constants.ONE);
//            settleParentStatusVO.setChildTitle(Constants.SettleClaimsStatus.FINISH_ACCEPTANCE.getName());
//            Optional<SettleClaimsLog> optionalSettleClaimsLog = settleClaimsLogList.stream()
//                    .filter(i->Constants.equalsInteger(i.getObjType(),Constants.SettleClaimsLogType.PLATFORM_RETURN.getKey())).findFirst();
//            if(optionalSettleClaimsLog.isPresent()){
//                settleParentStatusVO.setOptDate(optionalSettleClaimsLog.get().getCreateDate());
//            }
//            settleParentStatusVOList.add(settleParentStatusVO);
//            return settleParentStatusVOList;
//        }
//        //暂存状态 æ— ä¸»æµç¨‹æ•°æ®
//        if(Constants.equalsInteger(settleClaims.getStatus(),Constants.SettleClaimsStatus.WAIT_ACCEPTANCE.getKey())){
//            return settleParentStatusVOList;
//        }
//        //商议审批不通过
//        if(Constants.equalsInteger(settleClaims.getStatus(),Constants.SettleClaimsStatus.WAIT_DISCUSS_REJECT.getKey())){
//
//            SettleParentStatusVO settleParentStatusBAVO = new SettleParentStatusVO();
//            settleParentStatusBAVO.setParentTitle("报案");
//            settleParentStatusBAVO.setChildTitle("已报案");
//            settleParentStatusBAVO.setStatus(Constants.ZERO);
//            Optional<SettleClaimsLog> optionalSettleClaimsBALog = settleClaimsLogList.stream()
//                    .filter(i->Constants.equalsInteger(i.getParentStatus(),Constants.ONE)).findFirst();
//            if(optionalSettleClaimsBALog.isPresent()){
//                settleParentStatusBAVO.setOptDate(optionalSettleClaimsBALog.get().getCreateDate());
//            }
//            settleParentStatusVOList.add(settleParentStatusBAVO);
//
//            SettleParentStatusVO settleParentStatusLAVO = new SettleParentStatusVO();
//            settleParentStatusLAVO.setParentTitle("立案");
//            settleParentStatusLAVO.setChildTitle("已立案");
//            settleParentStatusLAVO.setStatus(Constants.ZERO);
//            Optional<SettleClaimsLog> optionalSettleClaimsLALog = settleClaimsLogList.stream()
//                    .filter(i->Constants.equalsInteger(i.getParentStatus(),Constants.TWO)).findFirst();
//            if(optionalSettleClaimsLALog.isPresent()){
//                settleParentStatusLAVO.setOptDate(optionalSettleClaimsBALog.get().getCreateDate());
//            }
//            settleParentStatusVOList.add(settleParentStatusBAVO);
//
//            SettleParentStatusVO settleParentStatusSLVO = new SettleParentStatusVO();
//            settleParentStatusSLVO.setParentTitle("受理");
//            settleParentStatusSLVO.setChildTitle("商议拒绝");
//            settleParentStatusSLVO.setStatus(Constants.TWO);
//            Optional<SettleClaimsLog> optionalSettleClaimsSLLog = settleClaimsLogList.stream()
//                    .filter(i->Constants.equalsInteger(i.getParentStatus(),Constants.THREE)).findFirst();
//            if(optionalSettleClaimsSLLog.isPresent()){
//                settleParentStatusSLVO.setOptDate(optionalSettleClaimsSLLog.get().getCreateDate());
//            }
//            settleParentStatusVOList.add(settleParentStatusSLVO);
//
//            return settleParentStatusVOList;
//        }
//
//        if(Constants.equalsInteger(settleClaims.getStatus(),Constants.SettleClaimsStatus.RETURN.getKey())){
//            List<SettleClaimsLog> settleClaimsLogs = settleClaimsLogList.stream()
//                    .filter(i->i.getParentStatus()<Constants.SettleClaimsStatus.RETURN.getParentKey()).collect(Collectors.toList());
//
//            for (int i = 1; i <= 5; i++) {
//                SettleParentStatusVO s = new SettleParentStatusVO();
//                Constants.SettleClaimsLogParentStatus  parentStatus = Constants.SettleClaimsLogParentStatus.getAll(i);
//                s.setParentTitle(parentStatus.getName());
//                s.set(parentStatus.getInfo());
//                s.setStatus(Constants.ZERO);
//
//            }
//            SettleParentStatusVO settleParentStatusCHVO = new SettleParentStatusVO();
//            settleParentStatusCHVO.setParentTitle("已撤案");
//            settleParentStatusCHVO.setChildTitle("企业主动撤案");
//            settleParentStatusCHVO.setStatus(Constants.TWO);
//            Optional<SettleClaimsLog> optionalSettleClaimsSLLog = settleClaimsLogList.stream()
//                    .filter(i->Constants.equalsInteger(i.getStatus(),Constants.SettleClaimsLogType.RETURN_SETTLE.getKey())).findFirst();
//            if(optionalSettleClaimsSLLog.isPresent()){
//                settleParentStatusCHVO.setOptDate(optionalSettleClaimsSLLog.get().getCreateDate());
//            }
//            settleParentStatusVOList.add(settleParentStatusCHVO);
//
//
//            return settleParentStatusVOList;
//
//        }
//
//
//        return settleParentStatusVOList;
//
//
//    }
    public List<SettleParentStatusVO> getParentStatus(SettleClaims settleClaims){
        List<SettleParentStatusVO> settleParentStatusVOList = new ArrayList<>();
        List<SettleClaimsLog> settleClaimsLogList = settleClaimsLogMapper
                .selectList(new QueryWrapper<SettleClaimsLog>().lambda().eq(SettleClaimsLog::getObjId,settleClaims.getId()).orderByDesc(SettleClaimsLog::getCreateDate));
        //立案退回状态数据
        if(Constants.equalsInteger(settleClaims.getStatus(),Constants.SettleClaimsStatus.FINISH_ACCEPTANCE.getKey())){
            SettleParentStatusVO settleParentStatusVO = new SettleParentStatusVO();
            settleParentStatusVO.setParentTitle("报案");
            settleParentStatusVO.setStatus(Constants.ONE);
            settleParentStatusVO.setChildTitle(Constants.SettleClaimsStatus.FINISH_ACCEPTANCE.getName());
            Optional<SettleClaimsLog> optionalSettleClaimsLog = settleClaimsLogList.stream()
                    .filter(i->Constants.equalsInteger(i.getObjType(),Constants.SettleClaimsLogType.PLATFORM_RETURN.getKey())).findFirst();
            if(optionalSettleClaimsLog.isPresent()){
                settleParentStatusVO.setOptDate(optionalSettleClaimsLog.get().getCreateDate());
            }
            settleParentStatusVOList.add(settleParentStatusVO);
            return settleParentStatusVOList;
        }
        //暂存状态 æ— ä¸»æµç¨‹æ•°æ®
        if(Constants.equalsInteger(settleClaims.getStatus(),Constants.SettleClaimsStatus.WAIT_ACCEPTANCE.getKey())){
            return settleParentStatusVOList;
        }
        //商议审批不通过
        if(Constants.equalsInteger(settleClaims.getStatus(),Constants.SettleClaimsStatus.WAIT_DISCUSS_REJECT.getKey())){
            SettleParentStatusVO settleParentStatusBAVO = new SettleParentStatusVO();
            settleParentStatusBAVO.setParentTitle("报案");
            settleParentStatusBAVO.setChildTitle("已报案");
            settleParentStatusBAVO.setStatus(Constants.ZERO);
            Optional<SettleClaimsLog> optionalSettleClaimsBALog = settleClaimsLogList.stream()
                    .filter(i->Constants.equalsInteger(i.getParentStatus(),Constants.ONE)).findFirst();
            if(optionalSettleClaimsBALog.isPresent()){
                settleParentStatusBAVO.setOptDate(optionalSettleClaimsBALog.get().getCreateDate());
            }
            settleParentStatusVOList.add(settleParentStatusBAVO);
            SettleParentStatusVO settleParentStatusLAVO = new SettleParentStatusVO();
            settleParentStatusLAVO.setParentTitle("立案");
            settleParentStatusLAVO.setChildTitle("已立案");
            settleParentStatusLAVO.setStatus(Constants.ZERO);
            Optional<SettleClaimsLog> optionalSettleClaimsLALog = settleClaimsLogList.stream()
                    .filter(i->Constants.equalsInteger(i.getParentStatus(),Constants.TWO)).findFirst();
            if(optionalSettleClaimsLALog.isPresent()){
                settleParentStatusLAVO.setOptDate(optionalSettleClaimsBALog.get().getCreateDate());
            }
            settleParentStatusVOList.add(settleParentStatusBAVO);
            SettleParentStatusVO settleParentStatusSLVO = new SettleParentStatusVO();
            settleParentStatusSLVO.setParentTitle("受理");
            settleParentStatusSLVO.setChildTitle("商议拒绝");
            settleParentStatusSLVO.setStatus(Constants.THREE);
            Optional<SettleClaimsLog> optionalSettleClaimsSLLog = settleClaimsLogList.stream()
                    .filter(i->Constants.equalsInteger(i.getParentStatus(),Constants.THREE)).findFirst();
            if(optionalSettleClaimsSLLog.isPresent()){
                settleParentStatusSLVO.setOptDate(optionalSettleClaimsSLLog.get().getCreateDate());
            }
            settleParentStatusVOList.add(settleParentStatusSLVO);
            return settleParentStatusVOList;
        }
        //主动撤销
        if(Constants.equalsInteger(settleClaims.getStatus(),Constants.SettleClaimsStatus.RETURN.getKey())){
            List<SettleClaimsLog> settleClaimsLogs = settleClaimsLogList.stream()
                    .filter(i->i.getParentStatus()<Constants.SettleClaimsStatus.RETURN.getParentKey()).collect(Collectors.toList());
            //获取当前日志最大的父状态
            Optional<Integer> optionalInteger = settleClaimsLogs.stream().map(i->i.getParentStatus()).max(Comparator.comparingInt(o -> o));
            if(optionalInteger.isPresent()){
                for (int i = 1; i <= 5; i++) {
                    SettleParentStatusVO s = new SettleParentStatusVO();
                    Constants.SettleClaimsLogParentStatus  parentStatus = Constants.SettleClaimsLogParentStatus.getAll(i);
                    s.setParentTitle(parentStatus.getName());
                    s.setChildTitle(parentStatus.getInfo());
                    s.setStatus(Constants.ZERO);
                    //如果是等于父状态 åˆ™åŽ»æŸ¥è¯¢å®žé™…çš„ä¸šåŠ¡çŠ¶æ€
                    if(Constants.equalsInteger(i,optionalInteger.get())){
                        Optional<SettleClaimsLog> settleClaimsLogOptional = settleClaimsLogList.stream()
                                .filter(j->Constants.equalsInteger(j.getParentStatus(),optionalInteger.get())).findFirst();
                        if(settleClaimsLogOptional.isPresent()){
                            s.setChildTitle(Constants.SettleClaimsLogType.getName(settleClaimsLogOptional.get().getObjType()));
                        }
                    }
                    settleParentStatusVOList.add(s);
                }
            }
            //添加撤案数据
            SettleParentStatusVO settleParentStatusCHVO = new SettleParentStatusVO();
            settleParentStatusCHVO.setParentTitle("已撤案");
            settleParentStatusCHVO.setChildTitle("企业主动撤案");
            settleParentStatusCHVO.setStatus(Constants.THREE);
            Optional<SettleClaimsLog> optionalSettleClaimsSLLog = settleClaimsLogList.stream()
                    .filter(i->Constants.equalsInteger(i.getStatus(),Constants.SettleClaimsLogType.RETURN_SETTLE.getKey())).findFirst();
            if(optionalSettleClaimsSLLog.isPresent()){
                settleParentStatusCHVO.setOptDate(optionalSettleClaimsSLLog.get().getCreateDate());
            }
            settleParentStatusVOList.add(settleParentStatusCHVO);
            return settleParentStatusVOList;
        }
        List<SettleClaimsLog> settleClaimsLogs = settleClaimsLogList.stream()
                .filter(i->i.getParentStatus()<Constants.SettleClaimsStatus.RETURN.getParentKey()).collect(Collectors.toList());
        Optional<Integer> optionalInteger = settleClaimsLogs.stream().map(i->i.getParentStatus()).max(Comparator.comparingInt(o -> o));
        if(optionalInteger.isPresent()){
            for (int i = 1; i <= 6; i++) {
                SettleParentStatusVO s = new SettleParentStatusVO();
                Constants.SettleClaimsLogParentStatus  parentStatus = Constants.SettleClaimsLogParentStatus.getAll(i);
                s.setParentTitle(parentStatus.getName());
                if(optionalInteger.get()>i){
                    //如果最大的父业务状态 å¤§äºŽ é»˜è®¤çš„6类数据 åˆ™ç›´æŽ¥æ˜¾ç¤ºé»˜è®¤é…ç½®
                    s.setChildTitle(parentStatus.getInfo());
                    s.setStatus(Constants.ZERO);
                }else if(optionalInteger.get()<i){
                    //如果最大的父业务状态 å°äºŽ é»˜è®¤çš„6类数据 åˆ™ç›´æŽ¥æ˜¾ç¤ºé»˜è®¤æœªå¤„理配置
                    s.setChildTitle(parentStatus.getWaitInfo());
                    s.setStatus(Constants.TWO);
                }else{
                    //如果是等于父状态 åˆ™åŽ»æŸ¥è¯¢å®žé™…çš„ä¸šåŠ¡çŠ¶æ€
                    if(Constants.equalsInteger(i,optionalInteger.get())){
                        Optional<SettleClaimsLog> settleClaimsLogOptional = settleClaimsLogList.stream()
                                .filter(j->Constants.equalsInteger(j.getParentStatus(),optionalInteger.get())).findFirst();
                        if(settleClaimsLogOptional.isPresent()){
                            s.setChildTitle(Constants.SettleClaimsLogType.getName(settleClaimsLogOptional.get().getObjType()));
                        }
                    }
                    s.setStatus(Constants.ONE);
                }
                settleParentStatusVOList.add(s);
            }
        }
        return settleParentStatusVOList;
    }