|
@@ -1,10 +1,18 @@
|
1
|
1
|
package com.ruoyi.web.controller.oa;
|
2
|
2
|
|
|
3
|
+import java.math.BigDecimal;
|
|
4
|
+import java.text.ParseException;
|
|
5
|
+import java.text.SimpleDateFormat;
|
|
6
|
+import java.util.Calendar;
|
3
|
7
|
import java.util.Date;
|
4
|
8
|
import java.util.List;
|
5
|
9
|
import java.util.stream.Collectors;
|
6
|
10
|
import javax.servlet.http.HttpServletResponse;
|
7
|
11
|
|
|
12
|
+import com.alibaba.fastjson2.JSONArray;
|
|
13
|
+import com.alibaba.fastjson2.JSONObject;
|
|
14
|
+import com.ruoyi.oa.domain.CmcCarApproval;
|
|
15
|
+import com.ruoyi.oa.domain.CmcContract;
|
8
|
16
|
import com.ruoyi.oa.service.ICmcProjectService;
|
9
|
17
|
import org.springframework.beans.factory.annotation.Autowired;
|
10
|
18
|
import org.springframework.web.bind.annotation.GetMapping;
|
|
@@ -69,6 +77,57 @@ public class CmcBorrowController extends BaseController
|
69
|
77
|
return success(cmcBorrowService.selectCmcBorrowByBorrowId(borrowId));
|
70
|
78
|
}
|
71
|
79
|
|
|
80
|
+ /**
|
|
81
|
+ * 获取cmc借款统计信息
|
|
82
|
+ */
|
|
83
|
+ @GetMapping("/statistic")
|
|
84
|
+ public AjaxResult getBorrowStatistic(CmcBorrow cmcBorrow) throws ParseException
|
|
85
|
+ {
|
|
86
|
+ JSONObject jsonObject = new JSONObject();
|
|
87
|
+ JSONArray yearArray = new JSONArray();
|
|
88
|
+ JSONObject yearObject = new JSONObject();
|
|
89
|
+ JSONArray amountArray = new JSONArray();
|
|
90
|
+ JSONObject amountObject = new JSONObject();
|
|
91
|
+ JSONArray usageArray = new JSONArray();
|
|
92
|
+ JSONObject usageObject = new JSONObject();
|
|
93
|
+ JSONArray usageAmountArray = new JSONArray();
|
|
94
|
+ JSONObject usageAmountObject = new JSONObject();
|
|
95
|
+ //每年借款金额
|
|
96
|
+ if (cmcBorrow.getApplyDate() == null) {
|
|
97
|
+ for (int i = 2019; i <= Calendar.getInstance().get(Calendar.YEAR); i++) {
|
|
98
|
+ cmcBorrow.setApplyDate(new SimpleDateFormat("yyyy").parse(String.valueOf(i)));
|
|
99
|
+ List<CmcBorrow> yearList = cmcBorrowService.selectCmcBorrowList(cmcBorrow);
|
|
100
|
+ yearObject.put(String.valueOf(i), yearList.size());
|
|
101
|
+ BigDecimal amount = new BigDecimal(0);
|
|
102
|
+ for (CmcBorrow borrow : yearList) {
|
|
103
|
+ if (borrow.getManagerAmount() != null)
|
|
104
|
+ amount = amount.add(borrow.getManagerAmount());
|
|
105
|
+ }
|
|
106
|
+ amountObject.put(String.valueOf(i), amount);
|
|
107
|
+ }
|
|
108
|
+ cmcBorrow.setApplyDate(null);
|
|
109
|
+ }
|
|
110
|
+ else {
|
|
111
|
+ yearObject.put(new SimpleDateFormat("yyyy").format(cmcBorrow.getApplyDate()), cmcBorrowService.selectCmcBorrowList(cmcBorrow).size());
|
|
112
|
+ BigDecimal amount = new BigDecimal(0);
|
|
113
|
+ for (CmcBorrow borrow : cmcBorrowService.selectCmcBorrowList(cmcBorrow)) {
|
|
114
|
+ if (borrow.getManagerAmount() != null)
|
|
115
|
+ amount = amount.add(borrow.getManagerAmount());
|
|
116
|
+ }
|
|
117
|
+ amountObject.put(new SimpleDateFormat("yyyy").format(cmcBorrow.getApplyDate()), amount);
|
|
118
|
+ }
|
|
119
|
+ getBorrowUsageStatistic(cmcBorrow, usageObject, usageAmountObject);
|
|
120
|
+ yearArray.add(yearObject);
|
|
121
|
+ amountArray.add(amountObject);
|
|
122
|
+ usageArray.add(usageObject);
|
|
123
|
+ usageAmountArray.add(usageAmountObject);
|
|
124
|
+ jsonObject.put("year", yearArray);
|
|
125
|
+ jsonObject.put("amount", amountArray);
|
|
126
|
+ jsonObject.put("usage", usageArray);
|
|
127
|
+ jsonObject.put("usageAmount", usageAmountArray);
|
|
128
|
+ return success(jsonObject);
|
|
129
|
+ }
|
|
130
|
+
|
72
|
131
|
/**
|
73
|
132
|
* 新增cmc借款申请
|
74
|
133
|
*/
|
|
@@ -122,4 +181,27 @@ public class CmcBorrowController extends BaseController
|
122
|
181
|
{
|
123
|
182
|
return success(cmcBorrowService.deleteCmcBorrowByBorrowIds(borrowIds));
|
124
|
183
|
}
|
|
184
|
+
|
|
185
|
+ //各用途借款次数
|
|
186
|
+ public void getBorrowUsageStatistic(CmcBorrow cmcBorrow, JSONObject usageObject, JSONObject usageAmountObject) {
|
|
187
|
+ cmcBorrow.setBorrowUsage("0");
|
|
188
|
+ List<CmcBorrow> usageList = cmcBorrowService.selectCmcBorrowList(cmcBorrow);
|
|
189
|
+ usageObject.put("项目借款", usageList.size());
|
|
190
|
+ BigDecimal pAmount = new BigDecimal(0);
|
|
191
|
+ for (CmcBorrow borrow : usageList) {
|
|
192
|
+ if (borrow.getManagerAmount() != null)
|
|
193
|
+ pAmount = pAmount.add(borrow.getManagerAmount());
|
|
194
|
+ }
|
|
195
|
+ usageAmountObject.put("项目借款", pAmount);
|
|
196
|
+ cmcBorrow.setBorrowUsage("1");
|
|
197
|
+ usageList = cmcBorrowService.selectCmcBorrowList(cmcBorrow);
|
|
198
|
+ usageObject.put("非项目借款", usageList.size());
|
|
199
|
+ BigDecimal oAmount = new BigDecimal(0);
|
|
200
|
+ for (CmcBorrow borrow : usageList) {
|
|
201
|
+ if (borrow.getManagerAmount() != null)
|
|
202
|
+ oAmount = oAmount.add(borrow.getManagerAmount());
|
|
203
|
+ }
|
|
204
|
+ usageAmountObject.put("非项目借款", oAmount);
|
|
205
|
+ }
|
|
206
|
+
|
125
|
207
|
}
|