java110
2020-05-28 f7b32b8f0143ea03f81ff5a54a5fd1fd208b921b
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
package com.java110.fee.listener.fee;
 
import com.alibaba.fastjson.JSONObject;
import com.java110.utils.constant.ResponseConstant;
import com.java110.utils.constant.StatusConstant;
import com.java110.utils.exception.ListenerExecuteException;
import com.java110.entity.center.Business;
import com.java110.event.service.AbstractBusinessServiceDataFlowListener;
import com.java110.fee.dao.IFeeServiceDao;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
 
import java.util.HashMap;
import java.util.List;
import java.util.Map;
 
/**
 * 费用 服务侦听 父类
 * Created by wuxw on 2018/7/4.
 */
public abstract class AbstractFeeBusinessServiceDataFlowListener extends AbstractBusinessServiceDataFlowListener {
    private static Logger logger = LoggerFactory.getLogger(AbstractFeeBusinessServiceDataFlowListener.class);
 
 
    /**
     * 获取 DAO工具类
     *
     * @return
     */
    public abstract IFeeServiceDao getFeeServiceDaoImpl();
 
    /**
     * 刷新 businessFeeInfo 数据
     * 主要将 数据库 中字段和 接口传递字段建立关系
     *
     * @param businessFeeInfo
     */
    protected void flushBusinessFeeInfo(Map businessFeeInfo, String statusCd) {
        businessFeeInfo.put("newBId", businessFeeInfo.get("b_id"));
        businessFeeInfo.put("amount", businessFeeInfo.get("amount"));
        businessFeeInfo.put("operate", businessFeeInfo.get("operate"));
        businessFeeInfo.put("incomeObjId", businessFeeInfo.get("income_obj_id"));
        businessFeeInfo.put("feeTypeCd", businessFeeInfo.get("fee_type_cd"));
        businessFeeInfo.put("startTime", businessFeeInfo.get("start_time"));
        businessFeeInfo.put("endTime", businessFeeInfo.get("end_time"));
        businessFeeInfo.put("communityId", businessFeeInfo.get("community_id"));
        businessFeeInfo.put("feeId", businessFeeInfo.get("fee_id"));
        businessFeeInfo.put("userId", businessFeeInfo.get("user_id"));
        businessFeeInfo.put("payerObjId", businessFeeInfo.get("payer_obj_id"));
        businessFeeInfo.put("feeFlag", businessFeeInfo.get("fee_flag"));
        businessFeeInfo.put("state", businessFeeInfo.get("state"));
        businessFeeInfo.put("configId", businessFeeInfo.get("config_id"));
        businessFeeInfo.put("billType", businessFeeInfo.get("bill_type"));
 
        businessFeeInfo.remove("bId");
        businessFeeInfo.put("statusCd", statusCd);
    }
 
 
    /**
     * 当修改数据时,查询instance表中的数据 自动保存删除数据到business中
     *
     * @param businessFee 费用信息
     */
    protected void autoSaveDelBusinessFee(Business business, JSONObject businessFee) {
//自动插入DEL
        Map info = new HashMap();
        info.put("feeId", businessFee.getString("feeId"));
        info.put("communityId", businessFee.getString("communityId"));
        info.put("statusCd", StatusConstant.STATUS_CD_VALID);
        List<Map> currentFeeInfos = getFeeServiceDaoImpl().getFeeInfo(info);
        if (currentFeeInfos == null || currentFeeInfos.size() != 1) {
            throw new ListenerExecuteException(ResponseConstant.RESULT_PARAM_ERROR, "未找到需要修改数据信息,入参错误或数据有问题,请检查" + info);
        }
 
        Map currentFeeInfo = currentFeeInfos.get(0);
 
        currentFeeInfo.put("bId", business.getbId());
 
        currentFeeInfo.put("amount", currentFeeInfo.get("amount"));
        currentFeeInfo.put("operate", currentFeeInfo.get("operate"));
        currentFeeInfo.put("incomeObjId", currentFeeInfo.get("income_obj_id"));
        currentFeeInfo.put("feeTypeCd", currentFeeInfo.get("fee_type_cd"));
        currentFeeInfo.put("startTime", currentFeeInfo.get("start_time"));
        currentFeeInfo.put("endTime", currentFeeInfo.get("end_time"));
        currentFeeInfo.put("communityId", currentFeeInfo.get("community_id"));
        currentFeeInfo.put("feeId", currentFeeInfo.get("fee_id"));
        currentFeeInfo.put("userId", currentFeeInfo.get("user_id"));
        currentFeeInfo.put("payerObjId", currentFeeInfo.get("payer_obj_id"));
        currentFeeInfo.put("feeFlag", currentFeeInfo.get("fee_flag"));
        currentFeeInfo.put("state", currentFeeInfo.get("state"));
        currentFeeInfo.put("configId", currentFeeInfo.get("config_id"));
        currentFeeInfo.put("billType", currentFeeInfo.get("bill_type"));
 
        currentFeeInfo.put("operate", StatusConstant.OPERATE_DEL);
        getFeeServiceDaoImpl().saveBusinessFeeInfo(currentFeeInfo);
 
        for(Object key : currentFeeInfo.keySet()) {
            if(businessFee.get(key) == null) {
                businessFee.put(key.toString(), currentFeeInfo.get(key));
            }
        }
    }
 
 
}