Blame view

fw-morax-server/src/main/java/cn/fw/morax/server/controller/app/EvalPoolController.java 11.8 KB
bf4d326c   姜超   feature(*): 控制器修改
1
2
3
4
5
6
7
8
9
10
  package cn.fw.morax.server.controller.app;
  
  
  import cn.fw.common.exception.BusinessException;
  import cn.fw.common.page.AppPage;
  import cn.fw.common.web.annotation.ControllerMethod;
  import cn.fw.common.web.auth.LoginAuthBean;
  import cn.fw.common.web.auth.annotation.CurrentUser;
  import cn.fw.data.base.domain.common.Message;
  import cn.fw.morax.common.utils.PublicUtil;
bf4d326c   姜超   feature(*): 控制器修改
11
  import cn.fw.morax.domain.dto.eval.EvalGroupIndicatorRankDTO;
bf4d326c   姜超   feature(*): 控制器修改
12
  import cn.fw.morax.domain.dto.query.EvalPoolQueryDTO;
e1778851   姜超   feature(*): 计算考评调整
13
  import cn.fw.morax.domain.enums.EvalScopeEnum;
bf4d326c   姜超   feature(*): 控制器修改
14
15
16
  import cn.fw.morax.domain.vo.SelectorVO;
  import cn.fw.morax.domain.vo.eval.*;
  import cn.fw.morax.domain.vo.kpi.KpiIndicatorRankVO;
bf4d326c   姜超   feature(*): 控制器修改
17
18
19
20
21
22
23
24
25
26
27
28
29
  import cn.fw.morax.service.biz.eval.*;
  import cn.fw.security.auth.client.annotation.Authorization;
  import cn.fw.security.auth.client.annotation.IgnoreAuth;
  import cn.fw.security.auth.client.annotation.IgnoreUserToken;
  import cn.fw.security.auth.client.enums.AuthType;
  import lombok.RequiredArgsConstructor;
  import lombok.extern.slf4j.Slf4j;
  import org.springframework.validation.annotation.Validated;
  import org.springframework.web.bind.annotation.*;
  
  import javax.validation.constraints.NotNull;
  import java.time.LocalDate;
  import java.time.YearMonth;
5ff2c525   姜超   feature(*): 并列排名计算
30
  import java.util.List;
bf4d326c   姜超   feature(*): 控制器修改
31
32
33
  import java.util.Objects;
  import java.util.Set;
  
5ff2c525   姜超   feature(*): 并列排名计算
34
  import static cn.fw.common.businessvalidator.Validator.BV;
bf4d326c   姜超   feature(*): 控制器修改
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
  import static cn.fw.common.web.util.ResultBuilder.success;
  
  /**
   * 考评池
   *
   * @author jiangchao
   * @since 2022-11-09
   */
  @Slf4j
  @RequiredArgsConstructor
  @Authorization(AuthType.APP)
  @Validated
  @IgnoreAuth
  @RestController
  @RequestMapping("/app/eval-pool")
  public class EvalPoolController {
  
      private final EvalPoolService evalPoolService;
      private final EvalGroupPoolService evalGroupPoolService;
bf4d326c   姜超   feature(*): 控制器修改
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
  
      /**
       * 人员考评池列表
       *
       * @param dto
       * @return
       * @ignoreParams currentUser
       */
      @GetMapping("/staffs")
      @ControllerMethod("人员考评池列表")
      public Message<AppPage<EvalUserPoolVO>> queryUserPool(@Validated EvalPoolQueryDTO dto) {
          if (PublicUtil.isEmpty(dto.getMonthly())) {
              dto.setMonthly(YearMonth.now());
          }
          return success(evalPoolService.queryUserPool(dto));
      }
  
      /**
       * 本月可查看的其他考评池选项
       *
       * @param user      用户id
       * @param userId    用户id [管理层查看人员薪酬详情时需传值]
b5babc65   姜超   feature(*): 参数修改
76
       * @param monthly 月度 [员工人查看自己的酬详情时需传值]
bf4d326c   姜超   feature(*): 控制器修改
77
78
79
80
81
82
       * @return 薪酬池选项
       * @ignoreParams user
       */
      @GetMapping("/staff-selector")
      @IgnoreUserToken
      @ControllerMethod("本月可查看的其他考评池选项")
b5babc65   姜超   feature(*): 参数修改
83
84
85
      public Message<Set<SelectorVO>> evalPoolSelector(@CurrentUser LoginAuthBean user, Long userId, @RequestParam(required = false) YearMonth monthly) {
          if (Objects.isNull(monthly)) {
              monthly = YearMonth.now();
bf4d326c   姜超   feature(*): 控制器修改
86
87
88
89
          }
          if (Objects.isNull(userId)) {
              userId = user.getUserId();
          }
b5babc65   姜超   feature(*): 参数修改
90
          return success(evalGroupPoolService.evalPoolSelector(userId, monthly));
bf4d326c   姜超   feature(*): 控制器修改
91
92
93
94
95
96
      }
  
      /**
       * 考评详情查询 (查看自己考评详情)
       *
       * @param userId    用户id
b5babc65   姜超   feature(*): 参数修改
97
       * @param monthly 月度
bf4d326c   姜超   feature(*): 控制器修改
98
99
100
101
102
103
       * @return 绩效池详情
       * @ignoreParams userId
       */
      @GetMapping("/own-detail")
      @ControllerMethod("考评详情查询")
      public Message<EvalUserPoolVO> evalPoolOwnDetail(@CurrentUser Long userId,
b5babc65   姜超   feature(*): 参数修改
104
105
106
                                                       @RequestParam(required = false) YearMonth monthly) {
          if (Objects.isNull(monthly)) {
              monthly = YearMonth.now();
bf4d326c   姜超   feature(*): 控制器修改
107
          }
b5babc65   姜超   feature(*): 参数修改
108
          return success(evalGroupPoolService.queryUserPoolDetail(userId, monthly));
bf4d326c   姜超   feature(*): 控制器修改
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
      }
  
      /**
       * 考评详情查询 (查看他人考评详情)
       *
       * @param evalPoolId    用户id
       * @return 绩效池详情
       * @ignoreParams userId
       */
      @GetMapping("/staff")
      @ControllerMethod("考评详情查询")
      public Message<EvalUserPoolVO> evalPoolDetail(@NotNull(message = "考评池id不能为空") Long evalPoolId) {
          return success(evalGroupPoolService.queryPoolDetail(evalPoolId));
      }
  
      /**
       * 员工考评得分详情
       *
       * @param evalPoolId
       * @param evalGroupIndicatorId
       * @return
       */
      @GetMapping("/staff/score-detail")
      @IgnoreAuth
      @ControllerMethod("员工考评得分详情")
      public Message<EvalPoolIndicatorDetailVO> getStaffHitIndicatorDetail(@NotNull(message = "考评池id不能为空") Long evalPoolId,
                                                                      @NotNull(message = "指标id不能为空") Long evalGroupIndicatorId,
                                                                      @NotNull(message = "日期不能为空") @RequestParam("dataDate") LocalDate dataDate) {
          return success(evalGroupPoolService.staffHitIndicatorDetail(evalPoolId, evalGroupIndicatorId, dataDate));
      }
  
      /**
       * 员工奖惩详情
       *
       * @param evalPoolId
       * @param evalGroupRewardId
       * @return
       */
      @GetMapping("/staff/reward-detail")
      @IgnoreAuth
      @ControllerMethod("员工奖惩详情")
      public Message<EvalPoolRewardDetailVO> getStaffRewardDetail(@NotNull(message = "考评池id不能为空") Long evalPoolId,
                                                                  @NotNull(message = "指标id不能为空") Long evalGroupRewardId,
                                                                  @NotNull(message = "日期不能为空") @RequestParam("dataDate") LocalDate dataDate) {
          return success(evalGroupPoolService.staffHitRewardDetail(evalPoolId, evalGroupRewardId, dataDate));
      }
  
      /**
       * 人员考评指标排名
       *
       * @param dto
       * @return
       */
      @GetMapping("/staff-indicator-rank")
      @ControllerMethod("人员考评指标排名")
      public Message<KpiIndicatorRankVO> queryKpiIndicatorRank(@Validated EvalGroupIndicatorRankDTO dto) {
e1778851   姜超   feature(*): 计算考评调整
165
166
          if (dto.getIsEvalGroupIndicator() && PublicUtil.isEmpty(dto.getEvalGroupIndicatorParamId()) &&
                  PublicUtil.isEmpty(dto.getEvalGroupIndicatorPreconditionId())) {
bf4d326c   姜超   feature(*): 控制器修改
167
                  throw new BusinessException("参数错误");
f90ec7e4   姜超   feature(*): 新增台阶类型
168
169
170
          }
          if (! dto.getIsEvalGroupIndicator() && PublicUtil.isEmpty(dto.getEvalGroupRewardParamId()) &&
                  PublicUtil.isEmpty(dto.getEvalGroupRewardPreconditionId())) {
bf4d326c   姜超   feature(*): 控制器修改
171
                  throw new BusinessException("参数错误");
bf4d326c   姜超   feature(*): 控制器修改
172
          }
e1778851   姜超   feature(*): 计算考评调整
173
          return success(evalGroupPoolService.queryIndicatorRank(dto, EvalScopeEnum.STAFF));
bf4d326c   姜超   feature(*): 控制器修改
174
175
176
      }
  
      /**
e1778851   姜超   feature(*): 计算考评调整
177
178
179
180
181
182
183
184
185
186
187
       * 门店考评指标排名
       *
       * @param dto
       * @return
       */
      @GetMapping("/shop-indicator-rank")
      @ControllerMethod("门店考评指标排名")
      public Message<KpiIndicatorRankVO> queryShopIndicatorRank(@Validated EvalGroupIndicatorRankDTO dto) {
          if (dto.getIsEvalGroupIndicator() && PublicUtil.isEmpty(dto.getEvalGroupIndicatorParamId()) &&
                  PublicUtil.isEmpty(dto.getEvalGroupIndicatorPreconditionId())) {
              throw new BusinessException("参数错误");
f90ec7e4   姜超   feature(*): 新增台阶类型
188
189
190
          }
          if (! dto.getIsEvalGroupIndicator() && PublicUtil.isEmpty(dto.getEvalGroupRewardParamId()) &&
                  PublicUtil.isEmpty(dto.getEvalGroupRewardPreconditionId())) {
e1778851   姜超   feature(*): 计算考评调整
191
192
193
194
195
              throw new BusinessException("参数错误");
          }
          return success(evalGroupPoolService.queryIndicatorRank(dto, EvalScopeEnum.SHOP));
      }
  
5ff2c525   姜超   feature(*): 并列排名计算
196
      /**
c4a10f17   姜超   feature(*): 保存排名名次修改
197
       *  门店、人员考评条件指标排名(排名条件使用)
5ff2c525   姜超   feature(*): 并列排名计算
198
199
200
201
202
203
204
205
206
207
208
209
210
       *
       * @param preconditionId
       * @param dataDate
       * @return
       */
      @GetMapping("/reward-cond-rank")
      @ControllerMethod("门店、人员考评条件指标排名")
      public Message<List<EvalGroupRewardRankLogVO>> queryRewardCondRank(Long preconditionId,
                                                                         @NotNull(message = "日期不能为空") @RequestParam("dataDate") LocalDate dataDate) {
          return success(evalGroupPoolService.getRewardCondRankLogs(preconditionId, dataDate));
      }
  
      /**
c4a10f17   姜超   feature(*): 保存排名名次修改
211
       *  门店、人员考评提成指标排名(排名计算使用)
5ff2c525   姜超   feature(*): 并列排名计算
212
       *
220b9724   姜超   feature(*): 代码调整
213
       * @param evalGroupRewardId
5ff2c525   姜超   feature(*): 并列排名计算
214
215
216
       * @param dataDate
       * @return
       */
220b9724   姜超   feature(*): 代码调整
217
218
219
      @GetMapping("/reward-rank")
      @ControllerMethod("门店、人员考评奖惩排名")
      public Message<List<EvalGroupRewardRankLogVO>> queryRewardCommissionRank(Long evalGroupRewardId,
5ff2c525   姜超   feature(*): 并列排名计算
220
                                                                               @NotNull(message = "日期不能为空") @RequestParam("dataDate") LocalDate dataDate) {
220b9724   姜超   feature(*): 代码调整
221
          return success(evalGroupPoolService.queryRewardCommissionRank(evalGroupRewardId, dataDate));
5ff2c525   姜超   feature(*): 并列排名计算
222
223
      }
  
c4a10f17   姜超   feature(*): 保存排名名次修改
224
225
226
227
228
229
230
231
232
      /**
       *  门店、人员考评奖惩占比(占比计算使用)
       *
       * @param evalGroupRewardId
       * @param dataDate
       * @return
       */
      @GetMapping("/reward-proportion")
      @ControllerMethod("门店、人员考评奖惩占比")
9161579f   姜超   feature(*): 排名返回名称
233
234
      public Message<List<EvalGroupRewardHitLogVO>> queryUserRewardProportion(@NotNull(message = "奖惩id不能为空") Long evalGroupRewardId,
                                                                              @NotNull(message = "类型不能为空") Integer scopeType,
c4a10f17   姜超   feature(*): 保存排名名次修改
235
                                                                               @NotNull(message = "日期不能为空") @RequestParam("dataDate") LocalDate dataDate) {
9161579f   姜超   feature(*): 排名返回名称
236
237
238
          EvalScopeEnum scopeTypeEnum = EvalScopeEnum.ofValue(scopeType);
          BV.notNull(scopeTypeEnum, "参数错误");
          return success(evalGroupPoolService.queryRewardProportion(scopeTypeEnum, evalGroupRewardId, dataDate));
c4a10f17   姜超   feature(*): 保存排名名次修改
239
      }
5ff2c525   姜超   feature(*): 并列排名计算
240
  
e1778851   姜超   feature(*): 计算考评调整
241
  
9161579f   姜超   feature(*): 排名返回名称
242
  
e1778851   姜超   feature(*): 计算考评调整
243
      /**
bf4d326c   姜超   feature(*): 控制器修改
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
       * 门店考评池列表
       *
       * @param dto
       * @return
       * @ignoreParams currentUser
       */
      @GetMapping("/shops")
      @ControllerMethod("门店考评池列表")
      public Message<AppPage<EvalShopPoolVO>> queryShopPool(@Validated EvalPoolQueryDTO dto) {
          if (PublicUtil.isEmpty(dto.getMonthly())) {
              dto.setMonthly(YearMonth.now());
          }
          return success(evalPoolService.queryShopPool(dto));
      }
  
      /**
       * 门店考评详情查询
       *
       * @param evalPoolId    用户id
       * @return 绩效池详情
       * @ignoreParams userId
       */
      @GetMapping("/shop")
      @ControllerMethod("门店考评详情查询")
      public Message<EvalShopPoolVO> queryShopPoolDetail(@NotNull(message = "考评池id不能为空") Long evalPoolId) {
          return success(evalGroupPoolService.queryShopPoolDetail(evalPoolId));
      }
  
      /**
       * 门店考评得分详情
       *
       * @param evalPoolId
       * @param evalGroupIndicatorId
       * @return
       */
      @GetMapping("/shop/score-detail")
      @IgnoreAuth
      @ControllerMethod("门店考评得分详情")
      public Message<EvalPoolIndicatorDetailVO> getShopHitIndicatorDetail(@NotNull(message = "考评池id不能为空") Long evalPoolId,
                                                                           @NotNull(message = "指标id不能为空") Long evalGroupIndicatorId,
                                                                           @NotNull(message = "日期不能为空") @RequestParam("dataDate") LocalDate dataDate) {
          return success(evalGroupPoolService.shopHitIndicatorDetail(evalPoolId, evalGroupIndicatorId, dataDate));
      }
  
          /**
       * 门店奖惩详情
       *
       * @param evalPoolId
       * @param evalGroupRewardId
       * @return
       */
      @GetMapping("/shop/reward-detail")
      @IgnoreAuth
      @ControllerMethod("门店奖惩详情")
      public Message<EvalPoolRewardDetailVO> getShopRewardDetail(@NotNull(message = "考评池id不能为空") Long evalPoolId,
                                                                  @NotNull(message = "指标id不能为空") Long evalGroupRewardId,
                                                                  @NotNull(message = "日期不能为空") @RequestParam("dataDate") LocalDate dataDate) {
          return success(evalGroupPoolService.shopHitRewardDetail(evalPoolId, evalGroupRewardId, dataDate));
      }
  
  }