MonthlyCustomersController.java 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517
  1. package com.kmall.admin.controller.statistics;
  2. import com.kmall.admin.dao.statistics.MonthlyCustomersDao;
  3. import com.kmall.admin.dao.statistics.WechatFollowersDao;
  4. import com.kmall.admin.entity.MonthlySalesGrowthEntity;
  5. import com.kmall.admin.entity.ProductStoreRelaEntity;
  6. import com.kmall.admin.entity.WechatFollowersEntity;
  7. import com.kmall.admin.fromcomm.entity.SysUserEntity;
  8. import com.kmall.admin.service.statistics.MonthlyCustomersService;
  9. import com.kmall.admin.utils.ParamUtils;
  10. import com.kmall.admin.utils.ShiroUtils;
  11. import com.kmall.common.utils.R;
  12. import com.kmall.common.utils.excel.ExcelExport;
  13. import com.kmall.common.utils.excel.ExcelUtil;
  14. import org.apache.shiro.SecurityUtils;
  15. import org.springframework.beans.factory.annotation.Autowired;
  16. import org.springframework.web.bind.annotation.RequestMapping;
  17. import org.springframework.web.bind.annotation.RequestParam;
  18. import org.springframework.web.bind.annotation.RestController;
  19. import javax.servlet.http.HttpServletRequest;
  20. import javax.servlet.http.HttpServletResponse;
  21. import java.math.BigDecimal;
  22. import java.math.RoundingMode;
  23. import java.text.ParseException;
  24. import java.text.SimpleDateFormat;
  25. import java.util.*;
  26. /**
  27. * @author zhangchuangbiao
  28. * @version 1.0
  29. * 2020-09-01 14:35
  30. */
  31. @RestController
  32. @RequestMapping("/monthly")
  33. public class MonthlyCustomersController {
  34. @Autowired
  35. private MonthlyCustomersService monthlyCustomersService;
  36. @Autowired
  37. private ExcelUtil excelUtil;
  38. @Autowired
  39. private MonthlyCustomersDao monthlyCustomersDao;
  40. @Autowired
  41. private WechatFollowersDao wechatFollowersDao;
  42. private void calculateDifferentMonth(List<String> monthList, String startMonth, String endMonth) throws ParseException {
  43. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM");
  44. Calendar bef = Calendar.getInstance();
  45. Calendar aft = Calendar.getInstance();
  46. bef.setTime(sdf.parse(startMonth));
  47. aft.setTime(sdf.parse(endMonth));
  48. do {
  49. monthList.add(sdf.format(bef.getTime()));
  50. bef.add(Calendar.MONTH, 1);
  51. }
  52. while (bef.compareTo(aft) <= 0);
  53. }
  54. /**
  55. * 每月销售额查询
  56. * @param startMonth
  57. * @param endMonth
  58. * @return
  59. */
  60. @RequestMapping("/customersQuery")
  61. public R queryMonthlyCustomers(@RequestParam("startMonth") String startMonth, @RequestParam("endMonth") String endMonth) {
  62. List<String> dateList = new ArrayList<>();
  63. Map<String, Object> returnMap = new HashMap<>();
  64. try {
  65. calculateDifferentMonth(dateList, startMonth, endMonth);
  66. } catch (ParseException e) {
  67. e.printStackTrace();
  68. }
  69. try {
  70. String merchSn = null;
  71. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  72. if(!"1".equals(sysUser.getRoleType())){
  73. merchSn = sysUser.getMerchSn();
  74. }
  75. Map<String,Object> map = monthlyCustomersService.queryMonthlyCustomers(startMonth,endMonth,merchSn);
  76. returnMap.put("dateList", dateList);
  77. returnMap.putAll(map);
  78. } catch (Exception e) {
  79. e.printStackTrace();
  80. return R.error(e.getMessage());
  81. }
  82. return R.ok(returnMap);
  83. }
  84. /**
  85. * 每月销售额销售量导出
  86. * @param params
  87. * @param response
  88. * @param request
  89. * @return
  90. */
  91. @RequestMapping("/monthlySalesGrowthExport")
  92. public R monthlySalesGrowthExport(@RequestParam Map<String, Object> params, HttpServletResponse response, HttpServletRequest request) {
  93. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  94. if (Objects.isNull(params.get("startMonth")) || "".equals(params.get("startMonth"))){
  95. return R.error("请先选择开始时间");
  96. }
  97. if (Objects.isNull(params.get("endMonth")) || "".equals(params.get("endMonth"))){
  98. return R.error("请先选择结束时间");
  99. }
  100. String merchSn = null;
  101. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  102. if(!"1".equals(sysUser.getRoleType())){
  103. merchSn = sysUser.getMerchSn();
  104. }
  105. List<MonthlySalesGrowthEntity> monthlySalesGrowthEntities = monthlyCustomersDao.queryMonthlyCustomers((String) params.get("startMonth"), (String) params.get("endMonth"), merchSn);
  106. ExcelExport ee = new ExcelExport("Monthly Sales Growth");
  107. String[] header = new String[]{"序号","商户编号","商户名称","销售额","销售数量","年-月"};
  108. List<Map<String, Object>> list = new ArrayList<>();
  109. int count = 1;
  110. if (monthlySalesGrowthEntities!=null && monthlySalesGrowthEntities.size()>0) {
  111. for (MonthlySalesGrowthEntity monthlySalesGrowthEntity : monthlySalesGrowthEntities) {
  112. LinkedHashMap<String, Object> map = new LinkedHashMap<>();
  113. map.put("OrderNumber",count++);
  114. map.put("MerchSn",monthlySalesGrowthEntity.getMerchSn());
  115. map.put("MerchName",monthlySalesGrowthEntity.getMerchName());
  116. map.put("TotalSales",monthlySalesGrowthEntity.getTotalSales());
  117. map.put("TotalNumber",monthlySalesGrowthEntity.getTotalNumber());
  118. map.put("YearAndMonth",monthlySalesGrowthEntity.getYearAndMonth());
  119. list.add(map);
  120. }
  121. }
  122. ee.addSheetByMap("Monthly Sales Growth", list, header);
  123. ee.export(response);
  124. return R.ok();
  125. }
  126. /**
  127. * 导出销售额销售数客单数客单价
  128. * @param params
  129. * @param response
  130. * @param request
  131. * @return
  132. */
  133. @RequestMapping("/monthlySalesGrowthExport2")
  134. public R monthlySalesGrowthExport2(@RequestParam Map<String, Object> params, HttpServletResponse response, HttpServletRequest request) {
  135. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  136. if (Objects.isNull(params.get("startMonth")) || "".equals(params.get("startMonth"))){
  137. return R.error("请先选择开始时间");
  138. }
  139. if (Objects.isNull(params.get("endMonth")) || "".equals(params.get("endMonth"))){
  140. return R.error("请先选择结束时间");
  141. }
  142. String merchSn = null;
  143. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  144. if(!"1".equals(sysUser.getRoleType())){
  145. merchSn = sysUser.getMerchSn();
  146. }
  147. List<MonthlySalesGrowthEntity> monthlySalesGrowthEntities = monthlyCustomersDao.queryMonthlyCustomers((String) params.get("startMonth"), (String) params.get("endMonth"), merchSn);
  148. ExcelExport ee = new ExcelExport("Monthly Customers&Avg Basket");
  149. String[] header = new String[]{"序号","商户编号","商户名称","销售额","销售数量","客户数","客单价","年-月"};
  150. List<Map<String, Object>> list = new ArrayList<>();
  151. int count = 1;
  152. if (monthlySalesGrowthEntities!=null && monthlySalesGrowthEntities.size()>0) {
  153. for (MonthlySalesGrowthEntity monthlySalesGrowthEntity : monthlySalesGrowthEntities) {
  154. LinkedHashMap<String, Object> map = new LinkedHashMap<>();
  155. map.put("OrderNumber",count++);
  156. map.put("MerchSn",monthlySalesGrowthEntity.getMerchSn());
  157. map.put("MerchName",monthlySalesGrowthEntity.getMerchName());
  158. map.put("TotalSales",monthlySalesGrowthEntity.getTotalSales());
  159. map.put("TotalNumber",monthlySalesGrowthEntity.getTotalNumber());
  160. map.put("TotalCustomers",monthlySalesGrowthEntity.getTotalCustomers());
  161. String avgBasketSale = new BigDecimal(monthlySalesGrowthEntity.getTotalSales()).divide(new BigDecimal(monthlySalesGrowthEntity.getTotalNumber()),3, RoundingMode.HALF_UP).toString();
  162. map.put("avgBasketSale",avgBasketSale);
  163. map.put("YearAndMonth",monthlySalesGrowthEntity.getYearAndMonth());
  164. list.add(map);
  165. }
  166. }
  167. ee.addSheetByMap("Monthly Customers&Avg Basket", list, header);
  168. ee.export(response);
  169. return R.ok();
  170. }
  171. /**
  172. * 销售前10的产品
  173. * @param month
  174. * @param week
  175. * @return
  176. */
  177. @RequestMapping("/top10ForProduct")
  178. public R top10ForProduct(@RequestParam("month") String month, @RequestParam("week") String week){
  179. String merchSn = null;
  180. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  181. if(!"1".equals(sysUser.getRoleType())){
  182. merchSn = sysUser.getMerchSn();
  183. }
  184. Map<String,Object> map = monthlyCustomersService.top10ForProduct(month,week,merchSn);
  185. return R.ok(map);
  186. }
  187. /**
  188. * 销售前10的品牌/供应商的商品
  189. * @param startDate
  190. * @param endDate
  191. * @return
  192. */
  193. @RequestMapping("/top10ByBrandAndSupplier")
  194. public R top10ByBrandAndSupplier(@RequestParam("startDate") String startDate,
  195. @RequestParam("endDate") String endDate){
  196. String merchSn = null;
  197. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  198. if(!"1".equals(sysUser.getRoleType())){
  199. merchSn = sysUser.getMerchSn();
  200. }
  201. Map<String,Object> map = monthlyCustomersService.top10ByBrandAndSupplier(startDate,endDate,merchSn);
  202. return R.ok(map);
  203. }
  204. /**
  205. * 每周销售额销售量图表查询
  206. * @param startWeek
  207. * @param endWeek
  208. * @return
  209. * @throws ParseException
  210. */
  211. @RequestMapping("/customersQueryByWeek")
  212. public R queryWeeklyCustomers(@RequestParam("startWeek") String startWeek, @RequestParam("endWeek") String endWeek) throws ParseException {
  213. List<String> dateList = new ArrayList<>();
  214. try {
  215. calculateDifferentWeek(dateList, startWeek, endWeek);
  216. } catch (ParseException e) {
  217. e.printStackTrace();
  218. }
  219. String merchSn = null;
  220. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  221. if(!"1".equals(sysUser.getRoleType())){
  222. merchSn = sysUser.getMerchSn();
  223. }
  224. SimpleDateFormat weekSdf = new SimpleDateFormat("yyyy");
  225. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  226. Calendar bef = Calendar.getInstance();
  227. Calendar aft = Calendar.getInstance();
  228. bef.setFirstDayOfWeek(Calendar.MONDAY);
  229. aft.setFirstDayOfWeek(Calendar.MONDAY);
  230. bef.setTime(sdf.parse(startWeek));
  231. aft.setTime(sdf.parse(endWeek));
  232. int befWeek = bef.get(Calendar.WEEK_OF_YEAR);
  233. int aftWeek = aft.get(Calendar.WEEK_OF_YEAR);
  234. if(befWeek<10){
  235. startWeek =weekSdf.format(bef.getTime())+"-0"+befWeek;
  236. }else{
  237. startWeek =weekSdf.format(bef.getTime())+"-"+befWeek;
  238. }
  239. if(aftWeek<10){
  240. endWeek =weekSdf.format(aft.getTime())+"-0"+aftWeek;
  241. }else{
  242. endWeek =weekSdf.format(aft.getTime())+"-"+aftWeek;
  243. }
  244. Map<String,Object> map = monthlyCustomersService.queryWeeklyCustomers(startWeek,endWeek,merchSn);
  245. Map<String, Object> returnMap = new HashMap<>();
  246. returnMap.put("dateList", dateList);
  247. returnMap.putAll(map);
  248. return R.ok(returnMap);
  249. }
  250. @RequestMapping("/weeklySalesSummaryExport")
  251. public R weeklySalesSummaryExport(@RequestParam Map<String, Object> params, HttpServletResponse response, HttpServletRequest request) throws ParseException {
  252. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  253. if (Objects.isNull(params.get("startWeek"))){
  254. return R.error("请先选择开始时间");
  255. }
  256. if (Objects.isNull(params.get("endWeek"))){
  257. return R.error("请先选择结束时间");
  258. }
  259. String startWeek = (String) params.get("startWeek");
  260. String endWeek = (String) params.get("endWeek");
  261. String merchSn = null;
  262. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  263. if(!"1".equals(sysUser.getRoleType())){
  264. merchSn = sysUser.getMerchSn();
  265. }
  266. SimpleDateFormat weekSdf = new SimpleDateFormat("yyyy");
  267. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  268. Calendar bef = Calendar.getInstance();
  269. Calendar aft = Calendar.getInstance();
  270. bef.setFirstDayOfWeek(Calendar.MONDAY);
  271. aft.setFirstDayOfWeek(Calendar.MONDAY);
  272. bef.setTime(sdf.parse(startWeek));
  273. aft.setTime(sdf.parse(endWeek));
  274. int befWeek = bef.get(Calendar.WEEK_OF_YEAR);
  275. int aftWeek = aft.get(Calendar.WEEK_OF_YEAR);
  276. if(befWeek<10){
  277. startWeek =weekSdf.format(bef.getTime())+"-0"+befWeek;
  278. }else{
  279. startWeek =weekSdf.format(bef.getTime())+"-"+befWeek;
  280. }
  281. if(aftWeek<10){
  282. endWeek =weekSdf.format(aft.getTime())+"-0"+aftWeek;
  283. }else{
  284. endWeek =weekSdf.format(aft.getTime())+"-"+aftWeek;
  285. }
  286. List<MonthlySalesGrowthEntity> monthlySalesGrowthEntities = monthlyCustomersDao.queryWeeklyCustomers(startWeek, endWeek, merchSn);
  287. ExcelExport ee = new ExcelExport("Weekly Sales Summary");
  288. String[] header = new String[]{"序号","商户编号","商户名称","销售额","销售数量","年-周"};
  289. List<Map<String, Object>> list = new ArrayList<>();
  290. int count = 1;
  291. if (monthlySalesGrowthEntities!=null && monthlySalesGrowthEntities.size()>0) {
  292. for (MonthlySalesGrowthEntity monthlySalesGrowthEntity : monthlySalesGrowthEntities) {
  293. LinkedHashMap<String, Object> map = new LinkedHashMap<>();
  294. map.put("OrderNumber",count++);
  295. map.put("MerchSn",monthlySalesGrowthEntity.getMerchSn());
  296. map.put("MerchName",monthlySalesGrowthEntity.getMerchName());
  297. map.put("TotalSales",monthlySalesGrowthEntity.getTotalSales());
  298. map.put("TotalNumber",monthlySalesGrowthEntity.getTotalNumber());
  299. map.put("YearAndWeek",monthlySalesGrowthEntity.getYearAndWeek());
  300. list.add(map);
  301. }
  302. }
  303. ee.addSheetByMap("Weekly Sales Summary", list, header);
  304. ee.export(response);
  305. return R.ok();
  306. }
  307. private void calculateDifferentWeek(List<String> weekList, String startWeek, String endWeek) throws ParseException {
  308. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  309. SimpleDateFormat weekSdf = new SimpleDateFormat("yyyy");
  310. Calendar bef = Calendar.getInstance();
  311. Calendar aft = Calendar.getInstance();
  312. bef.setFirstDayOfWeek(Calendar.MONDAY);
  313. aft.setFirstDayOfWeek(Calendar.MONDAY);
  314. bef.setTime(sdf.parse(startWeek));
  315. aft.setTime(sdf.parse(endWeek));
  316. do {
  317. int i = bef.get(Calendar.WEEK_OF_YEAR);
  318. if (i<10){
  319. weekList.add(weekSdf.format(bef.getTime())+"-0"+i);
  320. }else{
  321. weekList.add(weekSdf.format(bef.getTime())+"-"+i);
  322. }
  323. bef.set(Calendar.DAY_OF_MONTH,bef.get(Calendar.DAY_OF_MONTH)+7); //给当前时间增加一周
  324. }
  325. while (bef.compareTo(aft) <= 0);
  326. }
  327. /**
  328. * 每月微信好友图表查询
  329. * @param startMonth
  330. * @param endMonth
  331. * @return
  332. */
  333. @RequestMapping("/queryMonthlyWechatFollowers")
  334. public R queryMonthlyWechatFollowers(@RequestParam("startMonth") String startMonth, @RequestParam("endMonth") String endMonth) {
  335. List<String> dateList = new ArrayList<>();
  336. Map<String, Object> returnMap = new HashMap<>();
  337. try {
  338. calculateDifferentMonth(dateList, startMonth, endMonth);
  339. } catch (ParseException e) {
  340. e.printStackTrace();
  341. }
  342. try {
  343. String merchSn = null;
  344. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  345. if(!"1".equals(sysUser.getRoleType())){
  346. merchSn = sysUser.getMerchSn();
  347. }
  348. Map<String,Object> map = monthlyCustomersService.queryMonthlyWechatFollowers(startMonth,endMonth,merchSn);
  349. returnMap.put("dateList", dateList);
  350. returnMap.putAll(map);
  351. } catch (Exception e) {
  352. e.printStackTrace();
  353. return R.error(e.getMessage());
  354. }
  355. return R.ok(returnMap);
  356. }
  357. /**
  358. * 添加微信好友数据
  359. * @param wechatFollowers
  360. * @return
  361. */
  362. @RequestMapping("/addWechatFollowers")
  363. public R addWechatFollowers( @RequestParam("wechatFollowers") Integer wechatFollowers) {
  364. try {
  365. String merchSn = null;
  366. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  367. if(!"1".equals(sysUser.getRoleType())){
  368. merchSn = sysUser.getMerchSn();
  369. }
  370. WechatFollowersEntity wechatFollowersEntity = new WechatFollowersEntity();
  371. wechatFollowersEntity.setCreaterSn(ShiroUtils.getUserId().toString());
  372. wechatFollowersEntity.setCreateTime(new Date());
  373. wechatFollowersEntity.setWechatFollowers(wechatFollowers);
  374. wechatFollowersEntity.setMerchSn(merchSn);
  375. monthlyCustomersService.addWechatFollowers(wechatFollowersEntity);
  376. } catch (Exception e) {
  377. e.printStackTrace();
  378. return R.error(e.getMessage());
  379. }
  380. return R.ok("添加成功");
  381. }
  382. /**
  383. * 品牌销售数量
  384. * @param startDate
  385. * @param endDate
  386. * @return
  387. */
  388. @RequestMapping("/salesByCategory")
  389. public R salesByCategory(@RequestParam("startDate") String startDate, @RequestParam("endDate") String endDate){
  390. String merchSn = null;
  391. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  392. if(!"1".equals(sysUser.getRoleType())){
  393. merchSn = sysUser.getMerchSn();
  394. }
  395. return R.ok().put("list",monthlyCustomersService.salesByCategory(startDate,endDate,merchSn));
  396. }
  397. /**
  398. * 每月品牌销售数量查询
  399. * @param startMonth
  400. * @param endMonth
  401. * @return
  402. */
  403. @RequestMapping("/monthlyCategory")
  404. public R monthlyCategory(@RequestParam("startMonth") String startMonth, @RequestParam("endMonth") String endMonth) {
  405. List<String> dateList = new ArrayList<>();
  406. Map<String, Object> returnMap = new HashMap<>();
  407. try {
  408. calculateDifferentMonth(dateList, startMonth, endMonth);
  409. } catch (ParseException e) {
  410. e.printStackTrace();
  411. }
  412. try {
  413. String merchSn = null;
  414. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  415. if(!"1".equals(sysUser.getRoleType())){
  416. merchSn = sysUser.getMerchSn();
  417. }
  418. Map<String,Object> map = monthlyCustomersService.monthlyCategory(startMonth,endMonth,merchSn);
  419. returnMap.put("dateList", dateList);
  420. returnMap.putAll(map);
  421. } catch (Exception e) {
  422. e.printStackTrace();
  423. return R.error(e.getMessage());
  424. }
  425. return R.ok(returnMap);
  426. }
  427. @RequestMapping("/exportSelectedMonthData")
  428. public R exportSelectedMonthData(@RequestParam("startMonth") String startMonth, @RequestParam("endMonth") String endMonth) {
  429. List<String> dateList = new ArrayList<>();
  430. Map<String, Object> returnMap = new HashMap<>();
  431. try {
  432. calculateDifferentMonth(dateList, startMonth, endMonth);
  433. } catch (ParseException e) {
  434. e.printStackTrace();
  435. }
  436. try {
  437. String merchSn = null;
  438. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  439. if(!"1".equals(sysUser.getRoleType())){
  440. merchSn = sysUser.getMerchSn();
  441. }
  442. Map<String,Object> map = monthlyCustomersService.exportSelectedMonthData(startMonth,endMonth,merchSn,dateList.size());
  443. returnMap.put("dateList", dateList);
  444. returnMap.putAll(map);
  445. } catch (Exception e) {
  446. e.printStackTrace();
  447. return R.error(e.getMessage());
  448. }
  449. return R.ok(returnMap);
  450. }
  451. }