jiazx0107@163.com
2023-05-31 607e62cd6ec91d53bac549299d986c23e5143d28
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
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
package com.ld.igds.common;
 
import java.util.List;
 
import com.bstek.bdf2.core.model.DefaultCompany;
import com.ld.igds.common.dto.DepotSerData;
import com.ld.igds.common.dto.THDto;
import com.ld.igds.data.SimpleDepot;
import com.ld.igds.inout.dto.InoutData;
import com.ld.igds.models.*;
 
 
/**
 * 仓库等基础数据信息接口维护,包括仓房,仓廒、系统配置等
 *
 * @author Andy
 */
public interface CoreCommonService {
 
    String BEAN_ID = "core.commonService";
 
    /**
     * 存放字典缓存
     *
     * @param list      需要缓存的数据
     * @param companyId 当前组织编码
     */
    void setCacheDepot(List<Depot> list, String companyId);
 
    /**
     * 根据组织编号获取缓存中的数据
     *
     * @param companyId 当前组织编码
     * @return
     */
    List<Depot> getCacheDepotList(String companyId);
 
    /**
     * 根据组织编码和分库编号获取列表
     *
     * @param companyId 组织编码
     * @param deptId    分库编码
     * @return
     */
    List<Depot> getCacheDepotList(String companyId, String deptId);
 
    /**
     * 根据组织编码和仓库编码获取仓库信息
     *
     * @param companyId
     * @param depotId
     * @return
     */
    Depot getCacheDepot(String companyId, String depotId);
 
    /**
     * 从数据库充查询
     *
     * @param companyId
     * @param depotId
     * @return
     */
    Depot getDepotById(String companyId, String depotId);
 
    /**
     * 将仓库配置参数信息存放在缓存中
     *
     * @param list
     * @param companyId
     */
    void setCacheDepotConf(List<DepotConf> list, String companyId);
 
    /**
     * 根据组织编码和仓库编码获取仓库的参数配置信息
     *
     * @param companyId
     * @param depotId
     * @return
     */
    DepotConf getCacheDepotConf(String companyId, String depotId);
 
    DepotConf getCacheDepotConfBySerId(String companyId, String serId);
 
    /**
     * 根据分机ID获取相同配置
     *
     * @param companyId
     * @param serId
     * @return
     */
    List<DepotConf> getCacheDepotConfBySerId2(String companyId, String serId);
 
    List<DepotConf> getCacheDepotConf(String companyId);
 
 
    /**
     * 根据仓库的集合获取仓库与分机的关系信息,分机不能重复
     *
     * @param companyId
     * @param depotIds  多个仓库Id的集合
     * @return
     */
    List<DepotSerData> getCacheDepotSerByDepots(String companyId, List<String> depotIds);
 
 
    /**
     * 根据当前仓库编号信息获取与当前仓库相同建筑物的所有仓库集合
     *
     * @param companyId
     * @param depotId
     * @return
     */
    List<Depot> getCacheCommonBuildingDepot(String companyId, String depotId);
 
    /**
     * 系统全局参数缓存
     *
     * @param companyId
     * @param data
     */
    void setCacheSysConf(String companyId, DicSysConf data);
 
    /**
     * 获取全局缓存配置,如果没有获取一个默认的值
     *
     * @return
     */
    DicSysConf getCacheSysConf(String companyId);
 
 
    /**
     * 仓库温湿度存放在缓存中,有效期半小时
     *
     * @param data
     */
    void setCacheTH(THDto data);
 
    /**
     * 根据组织编码-温湿度分机-温湿度配置获取缓的温湿度信息
     *
     * @param companyId
     * @param thSerId
     * @param thConf
     * @return
     */
    THDto getCacheTH(String companyId, String thSerId, String thConf);
 
    /**
     * 增加实际库存
     *
     * @param companyId
     * @param depotId   仓库
     * @param weight    重量 单位 KG
 
    void addStorage(String companyId, String depotId, Double weight);
     */
 
    /**
     * 减少实际库存
     *
     * @param companyId
     * @param depotId   仓库ID
     * @param weight    重量 单位 KG
 
    void reduceStorage(String companyId, String depotId, Double weight);
     */
 
    /**
     * 更新当前仓库的实时库存
     *
     * @param companyId
     * @param depotId
     * @param curStorage
     */
    void updateDepotStorage(String companyId, String depotId, Double curStorage);
 
    /**
     * 更新当前仓库的实时库存
     *
     * @param inoutData
 
    void updateDepotStorage(InoutData inoutData);
     */
 
    /**
     * 根据组织编码和仓库编码更新当前仓库状态
     *
     * @param companyId
     * @param depotId
     * @param status    目标状态
     */
    void updateDepotStatus(String companyId, String depotId, String status);
 
    /**
     * 根据数据跟新仓库信息
     *
     * @param depot
     */
    void updateDepot(Depot depot);
 
 
    /**
     * 根据仓库配置信息更新
     *
     * @param depotConf
     */
    void updateDepotConf(DepotConf depotConf);
 
    /**
     * 组织信息列表放入缓存
     *
     * @param list
     */
    void setCacheCompany(List<DefaultCompany> list);
 
    /**
     * @return
     */
    List<DefaultCompany> getCompanyList();
 
    /**
     * 只在新一轮出入库第一车进行初始化,获取最后一个库存记录进行判断,并生成一个新的记录以便记录第一车出入库作业时间,
     * <p>
     * 当前方法只记录出库第一车和入库第一车的事件和判断,满仓和空仓需要人为记录
     *
     * @param data
     */
    void initInoutDepotStore(InoutData data);
 
    /**
     * 根据仓库编码获取当前仓库最后一条记录
     *
     * @param depotId
     * @return
     */
    DepotStore getLastDepotStore(String depotId);
 
    /**
     * 新增加一个出入库库存记录
     *
     * @param store
     */
    void addDepotStore(DepotStore store, boolean updateDepot);
}