MonthlyCustomersController.java 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404
  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. @RequestMapping("/customersQuery")
  55. public R queryMonthlyCustomers(@RequestParam("startMonth") String startMonth, @RequestParam("endMonth") String endMonth) {
  56. List<String> dateList = new ArrayList<>();
  57. Map<String, Object> returnMap = new HashMap<>();
  58. try {
  59. calculateDifferentMonth(dateList, startMonth, endMonth);
  60. } catch (ParseException e) {
  61. e.printStackTrace();
  62. }
  63. try {
  64. String merchSn = null;
  65. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  66. if(!"1".equals(sysUser.getRoleType())){
  67. merchSn = sysUser.getMerchSn();
  68. }
  69. Map<String,Object> map = monthlyCustomersService.queryMonthlyCustomers(startMonth,endMonth,merchSn);
  70. returnMap.put("dateList", dateList);
  71. returnMap.putAll(map);
  72. } catch (Exception e) {
  73. e.printStackTrace();
  74. return R.error(e.getMessage());
  75. }
  76. return R.ok(returnMap);
  77. }
  78. /**
  79. * 每月销售额销售量导出
  80. * @param params
  81. * @param response
  82. * @param request
  83. * @return
  84. */
  85. @RequestMapping("/monthlySalesGrowthExport")
  86. public R monthlySalesGrowthExport(@RequestParam Map<String, Object> params, HttpServletResponse response, HttpServletRequest request) {
  87. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  88. if (Objects.isNull(params.get("startMonth")) || "".equals(params.get("startMonth"))){
  89. return R.error("请先选择开始时间");
  90. }
  91. if (Objects.isNull(params.get("endMonth")) || "".equals(params.get("endMonth"))){
  92. return R.error("请先选择结束时间");
  93. }
  94. String merchSn = null;
  95. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  96. if(!"1".equals(sysUser.getRoleType())){
  97. merchSn = sysUser.getMerchSn();
  98. }
  99. List<MonthlySalesGrowthEntity> monthlySalesGrowthEntities = monthlyCustomersDao.queryMonthlyCustomers((String) params.get("startMonth"), (String) params.get("endMonth"), merchSn);
  100. ExcelExport ee = new ExcelExport("Monthly Sales Growth");
  101. String[] header = new String[]{"序号","商户编号","商户名称","销售额","销售数量","年-月"};
  102. List<Map<String, Object>> list = new ArrayList<>();
  103. int count = 1;
  104. if (monthlySalesGrowthEntities!=null && monthlySalesGrowthEntities.size()>0) {
  105. for (MonthlySalesGrowthEntity monthlySalesGrowthEntity : monthlySalesGrowthEntities) {
  106. LinkedHashMap<String, Object> map = new LinkedHashMap<>();
  107. map.put("OrderNumber",count++);
  108. map.put("MerchSn",monthlySalesGrowthEntity.getMerchSn());
  109. map.put("MerchName",monthlySalesGrowthEntity.getMerchName());
  110. map.put("TotalSales",monthlySalesGrowthEntity.getTotalSales());
  111. map.put("TotalNumber",monthlySalesGrowthEntity.getTotalNumber());
  112. map.put("YearAndMonth",monthlySalesGrowthEntity.getYearAndMonth());
  113. list.add(map);
  114. }
  115. }
  116. ee.addSheetByMap("Monthly Sales Growth", list, header);
  117. ee.export(response);
  118. return R.ok();
  119. }
  120. /**
  121. * 导出销售额销售数客单数客单价
  122. * @param params
  123. * @param response
  124. * @param request
  125. * @return
  126. */
  127. @RequestMapping("/monthlySalesGrowthExport2")
  128. public R monthlySalesGrowthExport2(@RequestParam Map<String, Object> params, HttpServletResponse response, HttpServletRequest request) {
  129. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  130. if (Objects.isNull(params.get("startMonth")) || "".equals(params.get("startMonth"))){
  131. return R.error("请先选择开始时间");
  132. }
  133. if (Objects.isNull(params.get("endMonth")) || "".equals(params.get("endMonth"))){
  134. return R.error("请先选择结束时间");
  135. }
  136. String merchSn = null;
  137. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  138. if(!"1".equals(sysUser.getRoleType())){
  139. merchSn = sysUser.getMerchSn();
  140. }
  141. List<MonthlySalesGrowthEntity> monthlySalesGrowthEntities = monthlyCustomersDao.queryMonthlyCustomers((String) params.get("startMonth"), (String) params.get("endMonth"), merchSn);
  142. ExcelExport ee = new ExcelExport("Monthly Customers&Avg Basket");
  143. String[] header = new String[]{"序号","商户编号","商户名称","销售额","销售数量","客户数","客单价","年-月"};
  144. List<Map<String, Object>> list = new ArrayList<>();
  145. int count = 1;
  146. if (monthlySalesGrowthEntities!=null && monthlySalesGrowthEntities.size()>0) {
  147. for (MonthlySalesGrowthEntity monthlySalesGrowthEntity : monthlySalesGrowthEntities) {
  148. LinkedHashMap<String, Object> map = new LinkedHashMap<>();
  149. map.put("OrderNumber",count++);
  150. map.put("MerchSn",monthlySalesGrowthEntity.getMerchSn());
  151. map.put("MerchName",monthlySalesGrowthEntity.getMerchName());
  152. map.put("TotalSales",monthlySalesGrowthEntity.getTotalSales());
  153. map.put("TotalNumber",monthlySalesGrowthEntity.getTotalNumber());
  154. map.put("TotalCustomers",monthlySalesGrowthEntity.getTotalCustomers());
  155. String avgBasketSale = new BigDecimal(monthlySalesGrowthEntity.getTotalSales()).divide(new BigDecimal(monthlySalesGrowthEntity.getTotalNumber()),3, RoundingMode.HALF_UP).toString();
  156. map.put("avgBasketSale",avgBasketSale);
  157. map.put("YearAndMonth",monthlySalesGrowthEntity.getYearAndMonth());
  158. list.add(map);
  159. }
  160. }
  161. ee.addSheetByMap("Monthly Customers&Avg Basket", list, header);
  162. ee.export(response);
  163. return R.ok();
  164. }
  165. @RequestMapping("/top10ForProduct")
  166. public R top10ForProduct(@RequestParam("month") String month, @RequestParam("week") String week){
  167. Map<String,Object> map = monthlyCustomersService.top10ForProduct(month,week);
  168. return R.ok(map);
  169. }
  170. @RequestMapping("/top10ByBrandAndSupplier")
  171. public R top10ByBrandAndSupplier(@RequestParam("startDate") String startDate,
  172. @RequestParam("endDate") String endDate){
  173. Map<String,Object> map = monthlyCustomersService.top10ByBrandAndSupplier(startDate,endDate);
  174. return R.ok(map);
  175. }
  176. /**
  177. * 每周销售额销售量图表查询
  178. * @param startWeek
  179. * @param endWeek
  180. * @return
  181. * @throws ParseException
  182. */
  183. @RequestMapping("/customersQueryByWeek")
  184. public R queryWeeklyCustomers(@RequestParam("startWeek") String startWeek, @RequestParam("endWeek") String endWeek) throws ParseException {
  185. List<String> dateList = new ArrayList<>();
  186. try {
  187. calculateDifferentWeek(dateList, startWeek, endWeek);
  188. } catch (ParseException e) {
  189. e.printStackTrace();
  190. }
  191. String merchSn = null;
  192. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  193. if(!"1".equals(sysUser.getRoleType())){
  194. merchSn = sysUser.getMerchSn();
  195. }
  196. SimpleDateFormat weekSdf = new SimpleDateFormat("yyyy");
  197. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  198. Calendar bef = Calendar.getInstance();
  199. Calendar aft = Calendar.getInstance();
  200. bef.setFirstDayOfWeek(Calendar.MONDAY);
  201. aft.setFirstDayOfWeek(Calendar.MONDAY);
  202. bef.setTime(sdf.parse(startWeek));
  203. aft.setTime(sdf.parse(endWeek));
  204. int befWeek = bef.get(Calendar.WEEK_OF_YEAR);
  205. int aftWeek = aft.get(Calendar.WEEK_OF_YEAR);
  206. if(befWeek<10){
  207. startWeek =weekSdf.format(bef.getTime())+"-0"+befWeek;
  208. }else{
  209. startWeek =weekSdf.format(bef.getTime())+"-"+befWeek;
  210. }
  211. if(aftWeek<10){
  212. endWeek =weekSdf.format(aft.getTime())+"-0"+aftWeek;
  213. }else{
  214. endWeek =weekSdf.format(aft.getTime())+"-"+aftWeek;
  215. }
  216. Map<String,Object> map = monthlyCustomersService.queryWeeklyCustomers(startWeek,endWeek,merchSn);
  217. Map<String, Object> returnMap = new HashMap<>();
  218. returnMap.put("dateList", dateList);
  219. returnMap.putAll(map);
  220. return R.ok(returnMap);
  221. }
  222. @RequestMapping("/weeklySalesSummaryExport")
  223. public R weeklySalesSummaryExport(@RequestParam Map<String, Object> params, HttpServletResponse response, HttpServletRequest request) throws ParseException {
  224. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  225. if (Objects.isNull(params.get("startWeek"))){
  226. return R.error("请先选择开始时间");
  227. }
  228. if (Objects.isNull(params.get("endWeek"))){
  229. return R.error("请先选择结束时间");
  230. }
  231. String startWeek = (String) params.get("startWeek");
  232. String endWeek = (String) params.get("endWeek");
  233. String merchSn = null;
  234. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  235. if(!"1".equals(sysUser.getRoleType())){
  236. merchSn = sysUser.getMerchSn();
  237. }
  238. SimpleDateFormat weekSdf = new SimpleDateFormat("yyyy");
  239. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  240. Calendar bef = Calendar.getInstance();
  241. Calendar aft = Calendar.getInstance();
  242. bef.setFirstDayOfWeek(Calendar.MONDAY);
  243. aft.setFirstDayOfWeek(Calendar.MONDAY);
  244. bef.setTime(sdf.parse(startWeek));
  245. aft.setTime(sdf.parse(endWeek));
  246. int befWeek = bef.get(Calendar.WEEK_OF_YEAR);
  247. int aftWeek = aft.get(Calendar.WEEK_OF_YEAR);
  248. if(befWeek<10){
  249. startWeek =weekSdf.format(bef.getTime())+"-0"+befWeek;
  250. }else{
  251. startWeek =weekSdf.format(bef.getTime())+"-"+befWeek;
  252. }
  253. if(aftWeek<10){
  254. endWeek =weekSdf.format(aft.getTime())+"-0"+aftWeek;
  255. }else{
  256. endWeek =weekSdf.format(aft.getTime())+"-"+aftWeek;
  257. }
  258. List<MonthlySalesGrowthEntity> monthlySalesGrowthEntities = monthlyCustomersDao.queryWeeklyCustomers(startWeek, endWeek, merchSn);
  259. ExcelExport ee = new ExcelExport("Weekly Sales Summary");
  260. String[] header = new String[]{"序号","商户编号","商户名称","销售额","销售数量","年-周"};
  261. List<Map<String, Object>> list = new ArrayList<>();
  262. int count = 1;
  263. if (monthlySalesGrowthEntities!=null && monthlySalesGrowthEntities.size()>0) {
  264. for (MonthlySalesGrowthEntity monthlySalesGrowthEntity : monthlySalesGrowthEntities) {
  265. LinkedHashMap<String, Object> map = new LinkedHashMap<>();
  266. map.put("OrderNumber",count++);
  267. map.put("MerchSn",monthlySalesGrowthEntity.getMerchSn());
  268. map.put("MerchName",monthlySalesGrowthEntity.getMerchName());
  269. map.put("TotalSales",monthlySalesGrowthEntity.getTotalSales());
  270. map.put("TotalNumber",monthlySalesGrowthEntity.getTotalNumber());
  271. map.put("YearAndWeek",monthlySalesGrowthEntity.getYearAndWeek());
  272. list.add(map);
  273. }
  274. }
  275. ee.addSheetByMap("Weekly Sales Summary", list, header);
  276. ee.export(response);
  277. return R.ok();
  278. }
  279. private void calculateDifferentWeek(List<String> weekList, String startWeek, String endWeek) throws ParseException {
  280. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  281. SimpleDateFormat weekSdf = new SimpleDateFormat("yyyy");
  282. Calendar bef = Calendar.getInstance();
  283. Calendar aft = Calendar.getInstance();
  284. bef.setFirstDayOfWeek(Calendar.MONDAY);
  285. aft.setFirstDayOfWeek(Calendar.MONDAY);
  286. bef.setTime(sdf.parse(startWeek));
  287. aft.setTime(sdf.parse(endWeek));
  288. do {
  289. int i = bef.get(Calendar.WEEK_OF_YEAR);
  290. if (i<10){
  291. weekList.add(weekSdf.format(bef.getTime())+"-0"+i);
  292. }else{
  293. weekList.add(weekSdf.format(bef.getTime())+"-"+i);
  294. }
  295. bef.set(Calendar.DAY_OF_MONTH,bef.get(Calendar.DAY_OF_MONTH)+7); //给当前时间增加一周
  296. }
  297. while (bef.compareTo(aft) <= 0);
  298. }
  299. /**
  300. * 每月微信好友图表查询
  301. * @param startMonth
  302. * @param endMonth
  303. * @return
  304. */
  305. @RequestMapping("/queryMonthlyWechatFollowers")
  306. public R queryMonthlyWechatFollowers(@RequestParam("startMonth") String startMonth, @RequestParam("endMonth") String endMonth) {
  307. List<String> dateList = new ArrayList<>();
  308. Map<String, Object> returnMap = new HashMap<>();
  309. try {
  310. calculateDifferentMonth(dateList, startMonth, endMonth);
  311. } catch (ParseException e) {
  312. e.printStackTrace();
  313. }
  314. try {
  315. String merchSn = null;
  316. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  317. if(!"1".equals(sysUser.getRoleType())){
  318. merchSn = sysUser.getMerchSn();
  319. }
  320. Map<String,Object> map = monthlyCustomersService.queryMonthlyWechatFollowers(startMonth,endMonth,merchSn);
  321. returnMap.put("dateList", dateList);
  322. returnMap.putAll(map);
  323. } catch (Exception e) {
  324. e.printStackTrace();
  325. return R.error(e.getMessage());
  326. }
  327. return R.ok(returnMap);
  328. }
  329. /**
  330. * 添加微信好友数据
  331. * @param wechatFollowers
  332. * @return
  333. */
  334. @RequestMapping("/addWechatFollowers")
  335. public R addWechatFollowers( @RequestParam("wechatFollowers") Integer wechatFollowers) {
  336. try {
  337. String merchSn = null;
  338. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  339. if(!"1".equals(sysUser.getRoleType())){
  340. merchSn = sysUser.getMerchSn();
  341. }
  342. WechatFollowersEntity wechatFollowersEntity = new WechatFollowersEntity();
  343. wechatFollowersEntity.setCreaterSn(ShiroUtils.getUserId().toString());
  344. wechatFollowersEntity.setCreateTime(new Date());
  345. wechatFollowersEntity.setWechatFollowers(wechatFollowers);
  346. wechatFollowersEntity.setMerchSn(merchSn);
  347. monthlyCustomersService.addWechatFollowers(wechatFollowersEntity);
  348. } catch (Exception e) {
  349. e.printStackTrace();
  350. return R.error(e.getMessage());
  351. }
  352. return R.ok("添加成功");
  353. }
  354. }