StudentOrderController.java 40 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778
  1. package com.ym.mec.student.controller;
  2. import com.alibaba.fastjson.JSON;
  3. import com.ym.mec.auth.api.client.SysUserFeignService;
  4. import com.ym.mec.auth.api.entity.SysUser;
  5. import com.ym.mec.biz.dal.dao.*;
  6. import com.ym.mec.biz.dal.dto.*;
  7. import com.ym.mec.biz.dal.entity.*;
  8. import com.ym.mec.biz.dal.enums.CourseViewTypeEnum;
  9. import com.ym.mec.biz.dal.enums.DealStatusEnum;
  10. import com.ym.mec.biz.dal.enums.GroupType;
  11. import com.ym.mec.biz.dal.enums.OrderTypeEnum;
  12. import com.ym.mec.biz.dal.page.StudentPaymentOrderQueryInfo;
  13. import com.ym.mec.biz.service.*;
  14. import com.ym.mec.common.controller.BaseController;
  15. import com.ym.mec.common.entity.HttpResponseResult;
  16. import com.ym.mec.common.page.PageInfo;
  17. import com.ym.mec.common.tenant.TenantContextHolder;
  18. import com.ym.mec.thirdparty.adapay.Payment;
  19. import com.ym.mec.thirdparty.yqpay.Msg;
  20. import com.ym.mec.util.date.DateUtil;
  21. import com.ym.mec.util.http.HttpUtil;
  22. import io.swagger.annotations.Api;
  23. import io.swagger.annotations.ApiImplicitParam;
  24. import io.swagger.annotations.ApiImplicitParams;
  25. import io.swagger.annotations.ApiOperation;
  26. import org.apache.commons.collections.CollectionUtils;
  27. import org.apache.commons.lang.StringUtils;
  28. import org.slf4j.Logger;
  29. import org.slf4j.LoggerFactory;
  30. import org.springframework.beans.factory.annotation.Autowired;
  31. import org.springframework.beans.factory.annotation.Value;
  32. import org.springframework.http.HttpStatus;
  33. import org.springframework.scheduling.annotation.EnableScheduling;
  34. import org.springframework.web.bind.annotation.*;
  35. import javax.servlet.http.HttpServletResponse;
  36. import java.io.IOException;
  37. import java.math.BigDecimal;
  38. import java.net.URLEncoder;
  39. import java.util.*;
  40. import java.util.stream.Collectors;
  41. @RequestMapping("studentOrder")
  42. @Api(tags = "订单回调")
  43. @RestController
  44. @EnableScheduling
  45. public class StudentOrderController extends BaseController {
  46. private static final Logger logger = LoggerFactory.getLogger(StudentOrderController.class);
  47. @Autowired
  48. private StudentPaymentOrderService studentPaymentOrderService;
  49. @Autowired
  50. private VipGroupService vipGroupService;
  51. @Autowired
  52. private MusicGroupService musicGroupService;
  53. @Autowired
  54. private StudentPaymentOrderDetailService studentPaymentOrderDetailService;
  55. @Autowired
  56. private StudentPaymentOrderDao studentPaymentOrderDao;
  57. @Autowired
  58. private SysConfigDao sysConfigDao;
  59. @Autowired
  60. private SporadicChargeInfoService sporadicChargeInfoService;
  61. @Autowired
  62. private OrganizationDao organizationDao;
  63. @Autowired
  64. private CourseScheduleEvaluateDao courseScheduleEvaluateDao;
  65. @Autowired
  66. private TenantPaymentOrderService tenantPaymentOrderService;
  67. @Autowired
  68. private StudentGoodsSellDao studentGoodsSellDao;
  69. @Autowired
  70. private LuckDrawCountService luckDrawCountService;
  71. @Autowired
  72. private DegreeRegistrationDao degreeRegistrationDao;
  73. @Autowired
  74. private SysUserFeignService sysUserFeignService;
  75. @Autowired
  76. private MusicGroupPaymentCalenderDao musicGroupPaymentCalenderDao;
  77. @Autowired
  78. private MusicGroupPaymentCalenderCourseSettingsDao musicGroupPaymentCalenderCourseSettingsDao;
  79. @Autowired
  80. private ReplacementInstrumentActivityDao replacementInstrumentActivityDao;
  81. @Autowired
  82. private ChildrenDayDegreeDetailDao childrenDayDegreeDetailDao;
  83. @Autowired
  84. private CloudTeacherOrderService cloudTeacherOrderService;
  85. @Autowired
  86. private SysCouponCodeDao sysCouponCodeDao;
  87. @Autowired
  88. private StudentRegistrationDao studentRegistrationDao;
  89. @Autowired
  90. private VipGroupActivityDao vipGroupActivityDao;
  91. @Autowired
  92. private SellOrderService sellOrderService;
  93. @Autowired
  94. private TenantOrderRecordService tenantOrderRecordService;
  95. @Autowired
  96. private OrderPayOpsService orderPayOpsService;
  97. @Value("${spring.profiles.active:dev}")
  98. private String profiles;
  99. @ApiOperation(value = "查询订单列表")
  100. @GetMapping("/queryPage")
  101. public Object findGroupUsers(StudentPaymentOrderQueryInfo queryInfo) {
  102. SysUser user = sysUserFeignService.queryUserInfo();
  103. if (user == null) {
  104. return failed(HttpStatus.FORBIDDEN, "请登录");
  105. }
  106. queryInfo.setStudentId(user.getId());
  107. PageInfo<StudentPaymentOrderDto> studentPaymentOrderPageInfo = studentPaymentOrderService.OrderQueryPage(queryInfo);
  108. return succeed(studentPaymentOrderPageInfo);
  109. }
  110. @PostMapping("/notify")
  111. public Msg notify(@ModelAttribute Msg msg) throws Exception {
  112. logger.info(msg.toString());
  113. Map<String, Object> rqMap = new LinkedHashMap<String, Object>();
  114. rqMap.put("code", msg.getCode());
  115. rqMap.put("msg", msg.getMsg());
  116. rqMap.put("responseType", msg.getResponseType());
  117. rqMap.put("responseParameters", msg.getResponseParameters());
  118. rqMap.put("sign", msg.getSign());
  119. //boolean rs = YqPayUtil.verify(rqMap);
  120. msg.setMsg("fail");
  121. Map<String, String> notifyMap = new HashMap<>();
  122. //if (rs) {
  123. notifyMap = JSON.parseObject(msg.getResponseParameters(), Map.class);
  124. //}
  125. //支付中订单存在,更新状态
  126. if (msg.getResponseType().equals("1") && notifyMap.size() > 0) {
  127. String tradeState = msg.getCode().equals("88") ? "1" : "0";
  128. String channelType = notifyMap.get("channelType").equals("1") ? "WXPay" : (notifyMap.get("channelType").equals("2") ? "Alipay" : "quickPay");
  129. notifyMap.put("tradeState", tradeState);
  130. notifyMap.put("totalMoney", notifyMap.get("payAmount"));
  131. notifyMap.put("merOrderNo", notifyMap.get("merMerOrderNo"));
  132. notifyMap.put("channelType", channelType);
  133. studentPaymentOrderService.updateOrder(notifyMap);
  134. msg.setCode("000000");
  135. msg.setMsg("success");
  136. }
  137. return msg;
  138. }
  139. @ApiOperation(value = "查询订单状态")
  140. @PostMapping("/checkOrderStatus")
  141. public Object checkOrderStatus(String orderNo) {
  142. if (StringUtils.isBlank(orderNo)) {
  143. return failed("请指定订单");
  144. }
  145. StudentPaymentOrder orderByOrderNo = studentPaymentOrderService.findOrderByOrderNo(orderNo);
  146. if (Objects.isNull(orderByOrderNo)) {
  147. Map<String, Object> tenantOrder = tenantOrderRecordService.checkTenantOrder(orderNo);
  148. if (Objects.nonNull(tenantOrder)) {
  149. return succeed(tenantOrder);
  150. }
  151. return failed("未找到指定订单");
  152. }
  153. HashMap<String, Object> orderDetail = new HashMap<>();
  154. orderDetail.put("order", orderByOrderNo);
  155. orderDetail.put("groupType", orderByOrderNo.getGroupType());
  156. if (OrderTypeEnum.APPLY.equals(orderByOrderNo.getType())) {
  157. StudentRegistration studentRegistration = studentRegistrationDao.getStudentRegister(orderByOrderNo.getMusicGroupId(), orderByOrderNo.getUserId());
  158. if (studentRegistration.getPayingStatus().equals(2)) {
  159. orderDetail.put("payingStatus", studentRegistration.getPayingStatus());
  160. }
  161. }
  162. if (orderByOrderNo.getGroupType().equals(GroupType.MUSIC)) {
  163. MusicGroup musicGroup = musicGroupService.get(orderByOrderNo.getMusicGroupId());
  164. List<Goods> goodsList = studentPaymentOrderDetailService.findApplyOrderGoods(orderByOrderNo.getId());
  165. List<String> orderDetailType = studentPaymentOrderDetailService.getOrderDetailType(orderByOrderNo.getId());
  166. List<StudentPaymentOrderDetail> orderDetail1 = studentPaymentOrderDetailService.getOrderDetail(orderByOrderNo.getId());
  167. String kitGroupPurchaseType = orderDetail1.stream().filter(e -> e.getGoodsList() != null).filter(e -> e.getKitGroupPurchaseType() != null).map(e -> e.getKitGroupPurchaseType().getCode()).collect(Collectors.joining(","));
  168. orderDetail.put("goods", goodsList);
  169. orderDetail.put("kitGroupPurchaseType", kitGroupPurchaseType);
  170. orderDetail.put("course", musicGroup.getCourseForm());
  171. orderDetail.put("ownershipType", musicGroup.getOwnershipType());
  172. orderDetail.put("detailType", orderDetailType);
  173. orderDetail.put("chargeTypeId", musicGroup.getChargeTypeId());
  174. orderDetail.put("courseViewType", musicGroup.getCourseViewType());
  175. //新的课程形态10.27
  176. MusicGroupPaymentCalender musicGroupRegCalender = musicGroupPaymentCalenderDao.getMusicGroupRegCalender(musicGroup.getId());
  177. if (musicGroupRegCalender != null) {
  178. List<MusicGroupPaymentCalenderCourseSettings> courseSettings = musicGroupPaymentCalenderCourseSettingsDao.getMusicGroupRegCalenderCourseSettings(musicGroup.getId());
  179. musicGroupRegCalender.setMusicGroupPaymentCalenderCourseSettingsList(courseSettings);
  180. }
  181. orderDetail.put("calender", musicGroupRegCalender);
  182. //判断是否是系统收费
  183. if (musicGroup.getCourseViewType() == CourseViewTypeEnum.MEMBER_FEE) {
  184. orderDetail.put("member", cloudTeacherOrderService.queryOrderInfoByOrderId(orderByOrderNo.getId()));
  185. }
  186. } else if (orderByOrderNo.getGroupType().equals(GroupType.VIP)) {
  187. if (StringUtils.isNotEmpty(orderByOrderNo.getMusicGroupId())) {
  188. VipBuyResultDto vipBuyResultInfo = vipGroupService.findVipBuyResultInfo(Integer.valueOf(orderByOrderNo.getMusicGroupId()));
  189. orderDetail.put("detail", vipBuyResultInfo);
  190. }
  191. } else if (orderByOrderNo.getGroupType().equals(GroupType.SPORADIC)) {
  192. if (Objects.nonNull(orderByOrderNo.getMusicGroupId())) {
  193. SporadicChargeInfo info = sporadicChargeInfoService.get(Integer.valueOf(orderByOrderNo.getMusicGroupId()));
  194. orderDetail.put("detail", info);
  195. }
  196. if (orderByOrderNo.getType().equals(OrderTypeEnum.DOUBLE_ELEVEN2020)) {
  197. LuckDrawCount luckDrawCount = luckDrawCountService.get(orderByOrderNo.getUserId().longValue());
  198. orderDetail.put("drawTimes", luckDrawCount == null ? 0 : luckDrawCount.getAvailableCount());
  199. } else if (OrderTypeEnum.DEGREE_REGISTRATION.equals(orderByOrderNo.getType())) {
  200. DegreeRegistration degreeRegistration = degreeRegistrationDao.get(orderByOrderNo.getClassGroupId());
  201. orderDetail.put("degree", degreeRegistration);
  202. List<StudentPaymentOrderDetail> studentPaymentOrderDetails = studentPaymentOrderDetailService.getOrderDetail(orderByOrderNo.getId());
  203. if (!CollectionUtils.isEmpty(studentPaymentOrderDetails)) {
  204. orderDetail.put("additionCourseInfo", studentPaymentOrderDetails.get(0).getGoodsIdList());
  205. }
  206. }
  207. } else if (orderByOrderNo.getGroupType().equals(GroupType.GOODS_SELL)) {
  208. orderDetail.put("detail", studentGoodsSellDao.getStudentGoodsSellDto(orderNo));
  209. } else if (orderByOrderNo.getGroupType().equals(GroupType.REPLACEMENT)) {
  210. orderDetail.put("detail", replacementInstrumentActivityDao.getInfo(Integer.parseInt(orderByOrderNo.getMusicGroupId())));
  211. } else if (orderByOrderNo.getGroupType().equals(GroupType.DEGREE)) {
  212. orderDetail.put("detail", childrenDayDegreeDetailDao.getByOrderId(orderByOrderNo.getId()));
  213. } else if (orderByOrderNo.getGroupType().equals(GroupType.ACTIVITY)) {
  214. orderDetail.put("detail", vipGroupActivityDao.queryByIds(orderByOrderNo.getActivityId()));
  215. } else if (orderByOrderNo.getGroupType().equals(GroupType.MEMBER)) {
  216. CloudTeacherOrderDto orderDto = cloudTeacherOrderService.queryOrderInfoByOrderId(orderByOrderNo.getId());
  217. orderDetail.put("detail", orderDto);
  218. if (orderDto != null) {
  219. Map<String, Object> map = new HashMap<>(1);
  220. map.put("paymentOrderId", orderDto.getCloudTeacherOrder().getOrderId());
  221. orderDetail.put("couponList", sysCouponCodeDao.querySysCouponUseList(map));
  222. }
  223. }
  224. return succeed(orderDetail);
  225. }
  226. @ApiOperation(value = "台牌支付")
  227. @PostMapping("/executePayment")
  228. @ApiImplicitParams({
  229. @ApiImplicitParam(name = "amount", value = "支付金额", required = true, dataType = "BigDecimal"),
  230. @ApiImplicitParam(name = "orderNo", value = "订单号", required = true, dataType = "String"),
  231. @ApiImplicitParam(name = "payChannel", value = "支付方式(alipay-支付宝app支付)", required = true, dataType = "String"),
  232. })
  233. public Object executePayment(BigDecimal amount, String orderNo, String payChannel, String notifyUrl, String returnUrl, String orderSubject, String orderBody, String sign, String code, String platform) {
  234. try {
  235. Map<String, Object> payment = orderPayOpsService.executePayment(amount, orderNo, payChannel, returnUrl, orderSubject, orderBody, sign, code, platform);
  236. return succeed(payment);
  237. } catch (Exception e) {
  238. return failed(e.getMessage());
  239. }
  240. }
  241. @GetMapping("/authorize")
  242. public String authorize(@RequestParam("returnUrl") String returnUrl) {
  243. String appId = "wxcf8e8b33a9477845";
  244. String url = URLEncoder.encode("http://wxwechat.utools.club/studentOrder/userInfo");
  245. String redirectURL = String.format("https://open.weixin.qq.com/connect/oauth2/authorize?appid=%s&redirect_uri=%s&response_type=code&scope=snsapi_base&state=1&connect_redirect=1#wechat_redirect",
  246. appId, url);
  247. return "redirect:" + redirectURL;
  248. }
  249. @GetMapping("/userInfo")
  250. public Object userInfo(@RequestParam("code") String code,
  251. @RequestParam("state") String returnUrl) throws Exception {
  252. String appId = "wxcf8e8b33a9477845";
  253. String appSecret = "1286452b9c68b13325dece7cdf892645";
  254. String wxMpOAuth2AccessTokenUrl = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=%s&secret=%s&code=%s&grant_type=authorization_code";
  255. wxMpOAuth2AccessTokenUrl = String.format(wxMpOAuth2AccessTokenUrl, appId, appSecret, code);
  256. Map<String, String> map = JSON.parseObject(HttpUtil.get(wxMpOAuth2AccessTokenUrl, new HashMap<>()), Map.class);
  257. if (!map.containsKey("openid")) {
  258. return failed("授权失败,请重新授权");
  259. }
  260. return map.get("openid");
  261. }
  262. // @Scheduled(cron = "0/30 * * * * ?")
  263. @GetMapping("/setSuccessStatus")
  264. public HttpResponseResult setSuccessStatus(String orderNo) throws Exception {
  265. if (!profiles.equals("dev") && !profiles.equals("test")) {
  266. return failed("非法操作");
  267. }
  268. List<StudentPaymentOrder> payingOrders = studentPaymentOrderService.findOrdersByStatus(DealStatusEnum.ING, "ADAPAY");
  269. String[] statusArr = {"0", "1", "7"};
  270. for (StudentPaymentOrder payingOrder : payingOrders) {
  271. if (StringUtils.isNotBlank(orderNo) && !orderNo.equals(payingOrder.getOrderNo())) {
  272. continue;
  273. }
  274. Map<String, String> rpMap = new HashMap<>();
  275. rpMap.put("tradeState", "1");
  276. rpMap.put("remarks", "模拟支付成功");
  277. rpMap.put("merOrderNo", payingOrder.getOrderNo());
  278. rpMap.put("orderNo", payingOrder.getOrderNo());
  279. rpMap.put("channelType", "1");
  280. rpMap.put("simulation", "1");
  281. String channelType = rpMap.get("channelType").equals("1") ? "WXPay" : (rpMap.get("channelType").equals("2") ? "Alipay" : "quickPay");
  282. rpMap.put("channelType", channelType);
  283. if (Arrays.asList(statusArr).contains(rpMap.get("tradeState"))) {
  284. try {
  285. studentPaymentOrderService.updateOrder(rpMap); //更新订单
  286. } catch (Exception e) {
  287. e.printStackTrace();
  288. continue;
  289. }
  290. }
  291. }
  292. return succeed();
  293. }
  294. @GetMapping("/getOrderStatus")
  295. private HttpResponseResult getOrderStatus(String transNo) throws Exception {
  296. // if (orderId == null) {
  297. // return failed("订单号必须填");
  298. // }
  299. // StudentPaymentOrder order = studentPaymentOrderService.get(orderId);
  300. // if(order == null){
  301. // return failed("订单不存在");
  302. // }
  303. Map<String, Object> payment = Payment.queryPayment(transNo);
  304. return succeed(payment);
  305. }
  306. @RequestMapping("paymentResult")
  307. public void paymentResult(HttpServletResponse response, String orderNo, String type) {
  308. try {
  309. String baseApiUrl = sysConfigDao.findConfigValue(SysConfigService.BASE_API_URL);
  310. if (type != null && type.equals("edu")) {
  311. baseApiUrl = sysConfigDao.findConfigValue(SysConfigService.EDU_TEACHER_BASE_URL);
  312. }
  313. response.sendRedirect(baseApiUrl + "/#/paymentresult?orderNo=" + orderNo);
  314. } catch (IOException e) {
  315. e.printStackTrace();
  316. }
  317. }
  318. @GetMapping("/getLuckStatis")
  319. public HttpResponseResult getLuckStatis() {
  320. List<Organization> organs = organizationDao.findAllOrgans();
  321. List<OrderStatisDto> orders = studentPaymentOrderDao.getLuckStatis();
  322. for (Organization organ : organs) {
  323. boolean flag = false;
  324. for (OrderStatisDto order : orders) {
  325. if (organ.getName().equals(order.getOrganName())) {
  326. flag = true;
  327. break;
  328. }
  329. }
  330. if (!flag) {
  331. OrderStatisDto orderStatisDto = new OrderStatisDto();
  332. orderStatisDto.setOrganName(organ.getName());
  333. orderStatisDto.setMoney(BigDecimal.ZERO);
  334. orderStatisDto.setNums(0);
  335. orders.add(orderStatisDto);
  336. }
  337. }
  338. BigDecimal totalMoney = BigDecimal.ZERO;
  339. Integer totalNum = 0;
  340. Iterator<OrderStatisDto> iterator = orders.iterator();
  341. while (iterator.hasNext()) {
  342. OrderStatisDto order = iterator.next();
  343. if (order.getOrganName().equals("总部国际") || order.getOrganName().equals("阳光总部国际") || order.getOrganName().equals("武汉小学")) {
  344. iterator.remove();
  345. continue;
  346. }
  347. totalMoney = totalMoney.add(order.getMoney());
  348. totalNum += order.getNums();
  349. }
  350. orders = orders.stream().sorted(Comparator.comparing(OrderStatisDto::getNums).reversed()).collect(Collectors.toList());
  351. LuckStatisDto luckStatisDto = new LuckStatisDto();
  352. luckStatisDto.setOrderStatisDtoList(orders);
  353. luckStatisDto.setTotalNum(totalNum);
  354. luckStatisDto.setTotalMoney(totalMoney);
  355. return succeed(luckStatisDto);
  356. }
  357. @GetMapping("/getPracticeGroupStatis")
  358. public HttpResponseResult getPracticeGroupStatis() {
  359. List<Organization> organs = organizationDao.findAllOrgans();
  360. Integer tenantId = TenantContextHolder.getTenantId();
  361. List<PracticeGroupsDto> hasReportNums = courseScheduleEvaluateDao.getHasReportNums(tenantId);
  362. List<PracticeGroupsDto> organMoneys = courseScheduleEvaluateDao.getOrganMoney(tenantId);
  363. List<PracticeGroupsDto> organPracticeGroups = courseScheduleEvaluateDao.getOrganPracticeGroups(tenantId);
  364. List<PracticeGroupsDto> practiceGroupsFrees = courseScheduleEvaluateDao.getPracticeGroupsFree(tenantId);
  365. List<PracticeGroupsDto> practiceGroupsBuys = courseScheduleEvaluateDao.getPracticeGroupsBuy(tenantId);
  366. List<PracticeGroupsDto> practiceGroupsRenews = courseScheduleEvaluateDao.getPracticeGroupsRenew(tenantId);
  367. Date startTime = DateUtil.getFirstDayOfMonth(new Date());
  368. List<PracticeGroupsDto> monthOrganBuyMoneys = courseScheduleEvaluateDao.getMonthOrganMoney(OrderTypeEnum.PRACTICE_GROUP_BUY, startTime, tenantId);
  369. List<PracticeGroupsDto> monthOrganRenewMoneys = courseScheduleEvaluateDao.getMonthOrganMoney(OrderTypeEnum.PRACTICE_GROUP_RENEW, startTime, tenantId);
  370. //List<PracticeGroupsDto> monthOrganBuyMoneys = courseScheduleEvaluateDao.getOrganNewPracticeGroupsOfMonth(OrderTypeEnum.PRACTICE_GROUP_BUY,startTime);
  371. //List<PracticeGroupsDto> monthOrganRenewMoneys = courseScheduleEvaluateDao.getOrganNewPracticeGroupsOfMonth(OrderTypeEnum.PRACTICE_GROUP_RENEW,startTime);
  372. List<PracticeGroupsDto> practiceGroups = new ArrayList<>();
  373. for (Organization organ : organs) {
  374. PracticeGroupsDto practiceGroupsDto = new PracticeGroupsDto();
  375. practiceGroupsDto.setOrganName(organ.getName());
  376. practiceGroupsDto.setOrganId(organ.getId());
  377. //体验人数
  378. for (PracticeGroupsDto practiceGroupsFree : practiceGroupsFrees) {
  379. if (organ.getId().equals(practiceGroupsFree.getOrganId())) {
  380. practiceGroupsDto.setTotalNums(practiceGroupsFree.getTotalNums());
  381. break;
  382. }
  383. }
  384. //购买人数
  385. for (PracticeGroupsDto practiceGroupsBuy : practiceGroupsBuys) {
  386. if (organ.getId().equals(practiceGroupsBuy.getOrganId())) {
  387. practiceGroupsDto.setBuyNums(practiceGroupsBuy.getBuyNums());
  388. break;
  389. }
  390. }
  391. //续费人数
  392. for (PracticeGroupsDto practiceGroupsRenew : practiceGroupsRenews) {
  393. if (organ.getId().equals(practiceGroupsRenew.getOrganId())) {
  394. practiceGroupsDto.setRenewNums(practiceGroupsRenew.getRenewNums());
  395. break;
  396. }
  397. }
  398. //已完成人数
  399. for (PracticeGroupsDto organPracticeGroup : organPracticeGroups) {
  400. if (organ.getId().equals(organPracticeGroup.getOrganId()) && organPracticeGroup.getBuyNums() >= organPracticeGroup.getTotalNums()) {
  401. practiceGroupsDto.setOverNums(practiceGroupsDto.getOverNums() + 1);
  402. }
  403. }
  404. //已提交报告人数
  405. for (PracticeGroupsDto hasReportNum : hasReportNums) {
  406. if (organ.getId().equals(hasReportNum.getOrganId())) {
  407. practiceGroupsDto.setReportNums(hasReportNum.getReportNums());
  408. break;
  409. }
  410. }
  411. //成交金额
  412. for (PracticeGroupsDto organMoney : organMoneys) {
  413. if (organ.getId().equals(organMoney.getOrganId())) {
  414. practiceGroupsDto.setTotalMoney(organMoney.getTotalMoney());
  415. break;
  416. }
  417. }
  418. //当月新增金额和人数
  419. for (PracticeGroupsDto monthOrganBuyMoney : monthOrganBuyMoneys) {
  420. if (organ.getId().equals(monthOrganBuyMoney.getOrganId())) {
  421. practiceGroupsDto.setMonthBuyMoney(monthOrganBuyMoney.getTotalMoney());
  422. practiceGroupsDto.setMonthBuyNums(monthOrganBuyMoney.getBuyNums());
  423. break;
  424. }
  425. }
  426. //当月续费金额和人数
  427. for (PracticeGroupsDto monthOrganRenewMoney : monthOrganRenewMoneys) {
  428. if (organ.getId().equals(monthOrganRenewMoney.getOrganId())) {
  429. practiceGroupsDto.setMonthRenewNums(monthOrganRenewMoney.getBuyNums());
  430. practiceGroupsDto.setMonthRenewMoney(monthOrganRenewMoney.getTotalMoney());
  431. break;
  432. }
  433. }
  434. if (practiceGroupsDto.getTotalNums() > 0) {
  435. double scale = new BigDecimal(practiceGroupsDto.getBuyNums()).multiply(new BigDecimal(100)).divide(new BigDecimal(practiceGroupsDto.getTotalNums()), 2, BigDecimal.ROUND_HALF_UP).doubleValue();
  436. practiceGroupsDto.setBuyScale(scale);
  437. }
  438. practiceGroups.add(practiceGroupsDto);
  439. }
  440. BigDecimal totalMoney = BigDecimal.ZERO;
  441. Integer totalNum = 0;
  442. Integer buyNum = 0;
  443. Integer renewNum = 0;
  444. Integer overNum = 0;
  445. Integer reportNum = 0;
  446. Integer monthBuyNums = 0;
  447. Integer monthRenewNums = 0;
  448. BigDecimal monthBuyMoney = BigDecimal.ZERO;
  449. BigDecimal monthRenewMoney = BigDecimal.ZERO;
  450. Iterator<PracticeGroupsDto> iterator = practiceGroups.iterator();
  451. while (iterator.hasNext()) {
  452. PracticeGroupsDto next = iterator.next();
  453. if (next.getOrganName().equals("总部国际") || next.getOrganName().equals("阳光总部国际") || next.getOrganName().equals("武汉小学")) {
  454. iterator.remove();
  455. continue;
  456. }
  457. totalMoney = totalMoney.add(next.getTotalMoney());
  458. totalNum += next.getTotalNums();
  459. overNum += next.getOverNums();
  460. buyNum += next.getBuyNums();
  461. reportNum += next.getReportNums();
  462. renewNum += next.getRenewNums();
  463. monthBuyNums += next.getMonthBuyNums();
  464. monthRenewNums += next.getMonthRenewNums();
  465. monthBuyMoney = monthBuyMoney.add(next.getMonthBuyMoney());
  466. monthRenewMoney = monthRenewMoney.add(next.getMonthRenewMoney());
  467. }
  468. practiceGroups = practiceGroups.stream().sorted(Comparator.comparingDouble(PracticeGroupsDto::getBuyScale).reversed()).collect(Collectors.toList());
  469. PracticeGroupStatisDto practiceGroupStatisDto = new PracticeGroupStatisDto();
  470. practiceGroupStatisDto.setPracticeGroupsDtoList(practiceGroups);
  471. practiceGroupStatisDto.setTotalMoney(totalMoney);
  472. practiceGroupStatisDto.setTotalNum(totalNum);
  473. practiceGroupStatisDto.setBuyNum(buyNum);
  474. practiceGroupStatisDto.setRenewNum(renewNum);
  475. practiceGroupStatisDto.setOverNum(overNum);
  476. practiceGroupStatisDto.setReportNum(reportNum);
  477. practiceGroupStatisDto.setMonthBuyNums(monthBuyNums);
  478. practiceGroupStatisDto.setMonthBuyMoney(monthBuyMoney);
  479. practiceGroupStatisDto.setMonthRenewNums(monthRenewNums);
  480. practiceGroupStatisDto.setMonthRenewMoney(monthRenewMoney);
  481. if (totalNum > 0) {
  482. BigDecimal scale = new BigDecimal(buyNum).multiply(new BigDecimal(100)).divide(new BigDecimal(totalNum), 2, BigDecimal.ROUND_HALF_UP);
  483. practiceGroupStatisDto.setBuyScale(scale);
  484. }
  485. return succeed(practiceGroupStatisDto);
  486. }
  487. @GetMapping("/getPracticeStatis")
  488. public HttpResponseResult getPracticeStatis() {
  489. Date nowDate = new Date();
  490. List<Organization> organs = organizationDao.findAllOrgans();
  491. Integer tenantId = TenantContextHolder.getTenantId();
  492. //除去禁止的体验人数
  493. // List<Practice4OrganDto> organTryNums = courseScheduleEvaluateDao.getTryNums();
  494. // List<Practice4OrganDto> organPracticeTryNums = courseScheduleEvaluateDao.getPracticeTryNums();
  495. // List<Practice4OrganDto> organVipTryNums = courseScheduleEvaluateDao.getVipTryNums();
  496. // List<Practice4OrganDto> organPracticeAndVipTryNums = courseScheduleEvaluateDao.getPracticeAndVipTryNums();
  497. List<Practice4OrganDto> allTryNums = courseScheduleEvaluateDao.getAllTryNums(tenantId);
  498. List<Practice4OrganDto> practiceBuyNums = courseScheduleEvaluateDao.getPracticeBuyNums(nowDate, null, tenantId);
  499. List<Practice4OrganDto> vipBuyNums = courseScheduleEvaluateDao.getVipBuyNums(nowDate, null, tenantId);
  500. List<Practice4OrganDto> practiceAndVipBuyNums = courseScheduleEvaluateDao.getPracticeAndVipNums(nowDate, null, tenantId);
  501. Date startTime = DateUtil.getFirstDayOfMonth(nowDate);
  502. Date endTime = DateUtil.addMonths(startTime, 1);
  503. //当月新增网管课人数
  504. List<PracticeGroupsDto> monthOrganPracticeBuyMoneys = courseScheduleEvaluateDao.getMonthOrganMoney(OrderTypeEnum.PRACTICE_GROUP_BUY, startTime, tenantId);
  505. //当月新增VIP人数
  506. List<PracticeGroupsDto> monthOrganVipBuyMoneys = courseScheduleEvaluateDao.getMonthOrganMoney(OrderTypeEnum.SMALL_CLASS_TO_BUY, startTime, tenantId);
  507. //当月续费人数
  508. List<PracticeGroupsDto> monthOrganRenewMoneys = courseScheduleEvaluateDao.getMonthOrganMoney(OrderTypeEnum.PRACTICE_GROUP_RENEW, startTime, tenantId);
  509. //本月总人数
  510. List<Practice4OrganDto> nowMonthPracticeBuyNums = courseScheduleEvaluateDao.getPracticeBuyNums(startTime, endTime, tenantId);
  511. List<Practice4OrganDto> nowMonthVipBuyNums = courseScheduleEvaluateDao.getVipBuyNums(startTime, endTime, tenantId);
  512. List<Practice4OrganDto> nowMonthPracticeAndVipBuyNums = courseScheduleEvaluateDao.getPracticeAndVipNums(startTime, endTime, tenantId);
  513. //上月总人数
  514. Date lastMonthStartTime = DateUtil.addMonths(startTime, -1);
  515. List<Practice4OrganDto> lastMonthPracticeBuyNums = courseScheduleEvaluateDao.getPracticeBuyNums(lastMonthStartTime, startTime, tenantId);
  516. List<Practice4OrganDto> lastMonthVipBuyNums = courseScheduleEvaluateDao.getVipBuyNums(lastMonthStartTime, startTime, tenantId);
  517. List<Practice4OrganDto> lastMonthPracticeAndVipBuyNums = courseScheduleEvaluateDao.getPracticeAndVipNums(lastMonthStartTime, startTime, tenantId);
  518. List<Practice4OrganDto> practice4Organs = new ArrayList<>();
  519. for (Organization organ : organs) {
  520. Practice4OrganDto practice4OrganDto = new Practice4OrganDto();
  521. practice4OrganDto.setOrganName(organ.getName());
  522. practice4OrganDto.setOrganId(organ.getId());
  523. //体验人数(除去禁止)
  524. // for (Practice4OrganDto organTryNum : organTryNums) {
  525. // if (organ.getId().equals(organTryNum.getOrganId())) {
  526. // practice4OrganDto.setTryNum(practice4OrganDto.getTryNum() + organTryNum.getTryNum());
  527. // break;
  528. // }
  529. // }
  530. // //网管课体验人数(禁止)
  531. // for (Practice4OrganDto organPracticeTryNum : organPracticeTryNums) {
  532. // if (organ.getId().equals(organPracticeTryNum.getOrganId())) {
  533. // practice4OrganDto.setTryNum(practice4OrganDto.getTryNum() + organPracticeTryNum.getTryNum());
  534. // break;
  535. // }
  536. // }
  537. // //vip课体验人数(禁止)
  538. // for (Practice4OrganDto organVipTryNum : organVipTryNums) {
  539. // if (organ.getId().equals(organVipTryNum.getOrganId())) {
  540. // practice4OrganDto.setTryNum(practice4OrganDto.getTryNum() + organVipTryNum.getTryNum());
  541. // break;
  542. // }
  543. // }
  544. // //减去vip中在网管课的人数
  545. // for (Practice4OrganDto organPracticeAndVipTryNum : organPracticeAndVipTryNums) {
  546. // if (organ.getId().equals(organPracticeAndVipTryNum.getOrganId())) {
  547. // practice4OrganDto.setTryNum(practice4OrganDto.getTryNum() - organPracticeAndVipTryNum.getTryNum());
  548. // break;
  549. // }
  550. // }
  551. for (Practice4OrganDto allTryNum : allTryNums) {
  552. if (organ.getId().equals(allTryNum.getOrganId())) {
  553. practice4OrganDto.setTryNum(allTryNum.getTryNum());
  554. }
  555. }
  556. //网管课转化人数
  557. for (Practice4OrganDto practiceBuyNum : practiceBuyNums) {
  558. if (organ.getId().equals(practiceBuyNum.getOrganId())) {
  559. practice4OrganDto.setPracticeNum(practiceBuyNum.getPracticeNum());
  560. break;
  561. }
  562. }
  563. //VIP课转化人数
  564. for (Practice4OrganDto vipBuyNum : vipBuyNums) {
  565. if (organ.getId().equals(vipBuyNum.getOrganId())) {
  566. practice4OrganDto.setVipNum(vipBuyNum.getVipNum());
  567. break;
  568. }
  569. }
  570. for (Practice4OrganDto practiceAndVipBuyNum : practiceAndVipBuyNums) {
  571. if (organ.getId().equals(practiceAndVipBuyNum.getOrganId())) {
  572. practice4OrganDto.setVipNum(practice4OrganDto.getVipNum() - practiceAndVipBuyNum.getPracticeNum());
  573. break;
  574. }
  575. }
  576. practice4OrganDto.setTotalNum(practice4OrganDto.getPracticeNum() + practice4OrganDto.getVipNum());
  577. //当月新增网管课人数
  578. for (PracticeGroupsDto monthOrganPracticeBuyMoney : monthOrganPracticeBuyMoneys) {
  579. if (organ.getId().equals(monthOrganPracticeBuyMoney.getOrganId())) {
  580. practice4OrganDto.setPractice4MonthNum(monthOrganPracticeBuyMoney.getBuyNums());
  581. practice4OrganDto.setTotalMoney(practice4OrganDto.getTotalMoney().add(monthOrganPracticeBuyMoney.getTotalMoney()));
  582. break;
  583. }
  584. }
  585. //当月新增VIP课人数
  586. for (PracticeGroupsDto monthOrganVipBuyMoney : monthOrganVipBuyMoneys) {
  587. if (organ.getId().equals(monthOrganVipBuyMoney.getOrganId())) {
  588. practice4OrganDto.setVip4MonthNum(monthOrganVipBuyMoney.getBuyNums());
  589. practice4OrganDto.setTotalMoney(practice4OrganDto.getTotalMoney().add(monthOrganVipBuyMoney.getTotalMoney()));
  590. break;
  591. }
  592. }
  593. //当月续费人数
  594. for (PracticeGroupsDto monthOrganRenewMoney : monthOrganRenewMoneys) {
  595. if (organ.getId().equals(monthOrganRenewMoney.getOrganId())) {
  596. practice4OrganDto.setRenew4MonthNum(monthOrganRenewMoney.getBuyNums());
  597. practice4OrganDto.setTotalMoney(practice4OrganDto.getTotalMoney().add(monthOrganRenewMoney.getTotalMoney()));
  598. break;
  599. }
  600. }
  601. //同比上月增减人数
  602. for (Practice4OrganDto nowMonthPracticeBuyNum : nowMonthPracticeBuyNums) {
  603. if (organ.getId().equals(nowMonthPracticeBuyNum.getOrganId())) {
  604. practice4OrganDto.setChange4MonthNum(nowMonthPracticeBuyNum.getPracticeNum());
  605. break;
  606. }
  607. }
  608. for (Practice4OrganDto nowMonthVipBuyNum : nowMonthVipBuyNums) {
  609. if (organ.getId().equals(nowMonthVipBuyNum.getOrganId())) {
  610. practice4OrganDto.setChange4MonthNum(practice4OrganDto.getChange4MonthNum() + nowMonthVipBuyNum.getVipNum());
  611. break;
  612. }
  613. }
  614. for (Practice4OrganDto nowMonthPracticeAndVipBuyNum : nowMonthPracticeAndVipBuyNums) {
  615. if (organ.getId().equals(nowMonthPracticeAndVipBuyNum.getOrganId())) {
  616. practice4OrganDto.setChange4MonthNum(practice4OrganDto.getChange4MonthNum() - nowMonthPracticeAndVipBuyNum.getPracticeNum());
  617. break;
  618. }
  619. }
  620. //上月人数
  621. for (Practice4OrganDto lastMonthPracticeBuyNum : lastMonthPracticeBuyNums) {
  622. if (organ.getId().equals(lastMonthPracticeBuyNum.getOrganId())) {
  623. practice4OrganDto.setChange4MonthNum(practice4OrganDto.getChange4MonthNum() - lastMonthPracticeBuyNum.getPracticeNum());
  624. break;
  625. }
  626. }
  627. for (Practice4OrganDto lastMonthVipBuyNum : lastMonthVipBuyNums) {
  628. if (organ.getId().equals(lastMonthVipBuyNum.getOrganId())) {
  629. practice4OrganDto.setChange4MonthNum(practice4OrganDto.getChange4MonthNum() - lastMonthVipBuyNum.getVipNum());
  630. break;
  631. }
  632. }
  633. for (Practice4OrganDto lastMonthPracticeAndVipBuyNum : lastMonthPracticeAndVipBuyNums) {
  634. if (organ.getId().equals(lastMonthPracticeAndVipBuyNum.getOrganId())) {
  635. practice4OrganDto.setChange4MonthNum(practice4OrganDto.getChange4MonthNum() + lastMonthPracticeAndVipBuyNum.getPracticeNum());
  636. break;
  637. }
  638. }
  639. if (practice4OrganDto.getTryNum() > 0) {
  640. double scale = new BigDecimal(practice4OrganDto.getTotalNum()).multiply(new BigDecimal(100)).divide(new BigDecimal(practice4OrganDto.getTryNum()), 2, BigDecimal.ROUND_HALF_UP).doubleValue();
  641. practice4OrganDto.setScale(scale);
  642. }
  643. practice4Organs.add(practice4OrganDto);
  644. }
  645. practice4Organs = practice4Organs.stream().sorted(Comparator.comparingDouble(Practice4OrganDto::getScale).reversed()).collect(Collectors.toList());
  646. return succeed(practice4Organs);
  647. }
  648. @GetMapping("/getUserApplyOrders")
  649. public HttpResponseResult<List<StudentPaymentOrderExportDto>> getUserApplyOrders(String musicGroupId) {
  650. SysUser sysUser = sysUserFeignService.queryUserInfo();
  651. if (sysUser == null) {
  652. return failed(HttpStatus.FORBIDDEN, "请登录");
  653. }
  654. return succeed(studentPaymentOrderService.getUserApplyOrders(sysUser.getId(), musicGroupId));
  655. }
  656. @GetMapping("/reConfirmOrder")
  657. public HttpResponseResult<List<StudentPaymentOrder>> reConfirmOrder(Date startTime, Date endTime) {
  658. if (!profiles.equals("prod")) {
  659. return failed("测试环境不支持");
  660. }
  661. return succeed(studentPaymentOrderService.reConfirmOrder(startTime, endTime));
  662. }
  663. @GetMapping("/getMusicGroupApplyCalender")
  664. public HttpResponseResult<MusicGroupPaymentCalender> getMusicGroupApplyCalender(String musicGroupId) {
  665. MusicGroupPaymentCalender musicGroupRegCalender = musicGroupPaymentCalenderDao.getMusicGroupRegCalender(musicGroupId);
  666. if (musicGroupRegCalender != null) {
  667. MusicGroup musicGroup = musicGroupService.get(musicGroupId);
  668. musicGroupRegCalender.setChargeTypeId(musicGroup.getChargeTypeId());
  669. List<MusicGroupPaymentCalenderCourseSettings> courseSettings = musicGroupPaymentCalenderCourseSettingsDao.getMusicGroupRegCalenderCourseSettings(musicGroupId);
  670. musicGroupRegCalender.setMusicGroupPaymentCalenderCourseSettingsList(courseSettings);
  671. musicGroupRegCalender.setCourseViewType(musicGroup.getCourseViewType());
  672. }
  673. return succeed(musicGroupRegCalender);
  674. }
  675. @GetMapping("confirmTeacherOrder")
  676. public Object confirmOrder(String orderNo) {
  677. TenantPaymentOrder tenantPaymentOrder = tenantPaymentOrderService.queryByOrderNo(orderNo);
  678. tenantPaymentOrderService.confirmOrder(tenantPaymentOrder);
  679. return succeed();
  680. }
  681. @GetMapping("fixSellOrder")
  682. public HttpResponseResult<List<SellOrder>> fixSellOrder(String orderNo) {
  683. StudentPaymentOrder order = studentPaymentOrderService.findOrderByOrderNo(orderNo);
  684. List<SellOrder> sellOrders = new ArrayList<>();
  685. if (order == null || !order.getStatus().equals(DealStatusEnum.SUCCESS) || !order.getType().equals(OrderTypeEnum.APPLY)) {
  686. return succeed(sellOrders);
  687. }
  688. List<StudentPaymentOrderDetail> orderDetails = studentPaymentOrderDetailService.getOrderGoodsDetail(order.getId());
  689. //销售订单详情
  690. if (orderDetails.size() > 0) {
  691. MusicGroup musicGroup = musicGroupService.get(order.getMusicGroupId());
  692. BigDecimal couponRemitFee = order.getCouponRemitFee();
  693. if (couponRemitFee.compareTo(BigDecimal.ZERO) > 0) {
  694. BigDecimal musicFee = orderDetails.stream().filter(o -> o.getType().getCode().equals("MUSICAL")
  695. || o.getType().getCode().equals("ACCESSORIES") || o.getType().getCode().equals("TEACHING"))
  696. .map(o -> o.getPrice()).reduce(BigDecimal.ZERO, BigDecimal::add);
  697. BigDecimal expectAmount = order.getExpectAmount();
  698. //获取比例
  699. BigDecimal ratioAmount = musicFee.divide(expectAmount, 6, BigDecimal.ROUND_HALF_UP);
  700. //获取分配的减免金额
  701. couponRemitFee = couponRemitFee.multiply(ratioAmount).setScale(2, BigDecimal.ROUND_HALF_UP);
  702. }
  703. sellOrders = sellOrderService.addOrderDetail2SellOrder(orderDetails, order, musicGroup, couponRemitFee);
  704. }
  705. return succeed(sellOrders);
  706. }
  707. }