P15GEN2\59518
2025-10-10 9f6890646993d16260d4201d613c092132856127
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
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
package biz.policy.rule.action;
 
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
 
import biz.policy.OrderEvent;
import biz.policy.rule.CheckLevel;
import biz.policy.rule.CheckResult;
import biz.policy.rule.OrderCalculator;
import biz.policy.rule.RuleAction;
import foundation.dao.DataWriter;
import foundation.data.entity.Entity;
import foundation.data.entity.EntitySet;
import foundation.data.entity.Filter;
import foundation.data.object.DataObject;
import foundation.util.Util;
 
public class RebateQtyValidDateCheck extends RuleAction {
 
    public static String remark = "买赠池效期限制";
    
    public RebateQtyValidDateCheck() {
        super();
    }
 
    @Override
    public void createBoard(OrderCalculator calculator, CheckResult result) {
        EntitySet rebates = calculator.getQtyRebates();
        
        if (rebates == null || rebates.size() == 0 ) {
            return ;
        }
        
        Set<String> rebateIds = new HashSet<String>();
        int cnt = 0;
        
        for (Entity entity: rebates) {
            rebateIds.add(Util.quotedStr(entity.getString("record_id")));
        }
        
        DataObject dataObject = DataObject.getInstance("rebate_qty_detail");
        
        try {
            Filter filter = new Filter();
            filter = new Filter("expire_date", "<", Util.StringToDate(Util.newDateStr()));
            filter.add("id", "in", "(" + String.join(",", rebateIds) + ")");
            EntitySet invalidRebates = dataObject.getTableEntitySet(filter);
            
            for (Entity entity: invalidRebates) {
                String expireDate = Util.DataTimeToString(entity.getDate("expire_date"), Util.NORMALFORMAT);
                result.writeOneRemark("买赠编码:【" + entity.getString("code") + "】到期日期:" + expireDate);
                cnt++;
            }
                
        } catch (Exception e) {
            e.printStackTrace();
        }
        
        //5. 计算结果
        boolean success = cnt < 1;
        
        result.setSuccess(success);
        
        if (success) {
            result.clearRemarks();
        }
    }
 
    @Override
    public boolean check(OrderCalculator calculator, OrderEvent event, DataWriter dataWriter) {
        EntitySet rebates = calculator.getQtyRebates();
        
        if (rebates.size() == 0 ) {
            return true;
        }
        
        List<String> remarks = new ArrayList<String>();
        Set<String> rebateIds = new HashSet<String>();
        
        for (Entity entity: rebates) {
            rebateIds.add(Util.quotedStr(entity.getString("record_id")));
        }
        
        DataObject dataObject = DataObject.getInstance("rebate_qty_detail");
        
        try {
            Filter filter = new Filter();
            filter = new Filter("expire_date", "<", Util.StringToDate(Util.newDateStr()));
            filter.add("id", "in", "(" + String.join(",", rebateIds) + ")");
            EntitySet invalidRebates = dataObject.getTableEntitySet(filter);
            
            for (Entity entity: invalidRebates) {
                String expireDate = Util.DataTimeToString(entity.getDate("expire_date"), Util.NORMALFORMAT);
                remarks.add("买赠编码:【" + entity.getString("code") + "】到期日期:" + expireDate);
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        
        //计算结果
        boolean success = remarks.size() < 1;
        
        if (!success) {
            if(CheckLevel.Info.equals(meta.getLevel())) {
                dataWriter.reportOneAlert("RebateQtyValidDateCheck", "买赠明细效期检查不通过:" + meta.getTitle());
                for (String remark: remarks) {
                    dataWriter.reportOneAlert("RebateQtyValidDateCheck", "     " + remark);
                }
                
                return true;
            }
            
            dataWriter.reportOneError("RebateQtyValidDateCheck", "买赠明细效期检查不通过:" + meta.getTitle());
            for (String remark: remarks) {
                dataWriter.reportOneError("RebateQtyValidDateCheck", "     " + remark);
            }
        }
        
        return success;
    }
}