MonthlyCustomersController.java 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429
  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. String merchSn = null;
  168. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  169. if(!"1".equals(sysUser.getRoleType())){
  170. merchSn = sysUser.getMerchSn();
  171. }
  172. Map<String,Object> map = monthlyCustomersService.top10ForProduct(month,week,merchSn);
  173. return R.ok(map);
  174. }
  175. @RequestMapping("/top10ByBrandAndSupplier")
  176. public R top10ByBrandAndSupplier(@RequestParam("startDate") String startDate,
  177. @RequestParam("endDate") String endDate){
  178. String merchSn = null;
  179. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  180. if(!"1".equals(sysUser.getRoleType())){
  181. merchSn = sysUser.getMerchSn();
  182. }
  183. Map<String,Object> map = monthlyCustomersService.top10ByBrandAndSupplier(startDate,endDate,merchSn);
  184. return R.ok(map);
  185. }
  186. /**
  187. * 每周销售额销售量图表查询
  188. * @param startWeek
  189. * @param endWeek
  190. * @return
  191. * @throws ParseException
  192. */
  193. @RequestMapping("/customersQueryByWeek")
  194. public R queryWeeklyCustomers(@RequestParam("startWeek") String startWeek, @RequestParam("endWeek") String endWeek) throws ParseException {
  195. List<String> dateList = new ArrayList<>();
  196. try {
  197. calculateDifferentWeek(dateList, startWeek, endWeek);
  198. } catch (ParseException e) {
  199. e.printStackTrace();
  200. }
  201. String merchSn = null;
  202. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  203. if(!"1".equals(sysUser.getRoleType())){
  204. merchSn = sysUser.getMerchSn();
  205. }
  206. SimpleDateFormat weekSdf = new SimpleDateFormat("yyyy");
  207. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  208. Calendar bef = Calendar.getInstance();
  209. Calendar aft = Calendar.getInstance();
  210. bef.setFirstDayOfWeek(Calendar.MONDAY);
  211. aft.setFirstDayOfWeek(Calendar.MONDAY);
  212. bef.setTime(sdf.parse(startWeek));
  213. aft.setTime(sdf.parse(endWeek));
  214. int befWeek = bef.get(Calendar.WEEK_OF_YEAR);
  215. int aftWeek = aft.get(Calendar.WEEK_OF_YEAR);
  216. if(befWeek<10){
  217. startWeek =weekSdf.format(bef.getTime())+"-0"+befWeek;
  218. }else{
  219. startWeek =weekSdf.format(bef.getTime())+"-"+befWeek;
  220. }
  221. if(aftWeek<10){
  222. endWeek =weekSdf.format(aft.getTime())+"-0"+aftWeek;
  223. }else{
  224. endWeek =weekSdf.format(aft.getTime())+"-"+aftWeek;
  225. }
  226. Map<String,Object> map = monthlyCustomersService.queryWeeklyCustomers(startWeek,endWeek,merchSn);
  227. Map<String, Object> returnMap = new HashMap<>();
  228. returnMap.put("dateList", dateList);
  229. returnMap.putAll(map);
  230. return R.ok(returnMap);
  231. }
  232. @RequestMapping("/weeklySalesSummaryExport")
  233. public R weeklySalesSummaryExport(@RequestParam Map<String, Object> params, HttpServletResponse response, HttpServletRequest request) throws ParseException {
  234. ParamUtils.setQueryPowerByRoleType(params, "storeId", "merchSn", "thirdPartyMerchCode");
  235. if (Objects.isNull(params.get("startWeek"))){
  236. return R.error("请先选择开始时间");
  237. }
  238. if (Objects.isNull(params.get("endWeek"))){
  239. return R.error("请先选择结束时间");
  240. }
  241. String startWeek = (String) params.get("startWeek");
  242. String endWeek = (String) params.get("endWeek");
  243. String merchSn = null;
  244. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  245. if(!"1".equals(sysUser.getRoleType())){
  246. merchSn = sysUser.getMerchSn();
  247. }
  248. SimpleDateFormat weekSdf = new SimpleDateFormat("yyyy");
  249. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  250. Calendar bef = Calendar.getInstance();
  251. Calendar aft = Calendar.getInstance();
  252. bef.setFirstDayOfWeek(Calendar.MONDAY);
  253. aft.setFirstDayOfWeek(Calendar.MONDAY);
  254. bef.setTime(sdf.parse(startWeek));
  255. aft.setTime(sdf.parse(endWeek));
  256. int befWeek = bef.get(Calendar.WEEK_OF_YEAR);
  257. int aftWeek = aft.get(Calendar.WEEK_OF_YEAR);
  258. if(befWeek<10){
  259. startWeek =weekSdf.format(bef.getTime())+"-0"+befWeek;
  260. }else{
  261. startWeek =weekSdf.format(bef.getTime())+"-"+befWeek;
  262. }
  263. if(aftWeek<10){
  264. endWeek =weekSdf.format(aft.getTime())+"-0"+aftWeek;
  265. }else{
  266. endWeek =weekSdf.format(aft.getTime())+"-"+aftWeek;
  267. }
  268. List<MonthlySalesGrowthEntity> monthlySalesGrowthEntities = monthlyCustomersDao.queryWeeklyCustomers(startWeek, endWeek, merchSn);
  269. ExcelExport ee = new ExcelExport("Weekly Sales Summary");
  270. String[] header = new String[]{"序号","商户编号","商户名称","销售额","销售数量","年-周"};
  271. List<Map<String, Object>> list = new ArrayList<>();
  272. int count = 1;
  273. if (monthlySalesGrowthEntities!=null && monthlySalesGrowthEntities.size()>0) {
  274. for (MonthlySalesGrowthEntity monthlySalesGrowthEntity : monthlySalesGrowthEntities) {
  275. LinkedHashMap<String, Object> map = new LinkedHashMap<>();
  276. map.put("OrderNumber",count++);
  277. map.put("MerchSn",monthlySalesGrowthEntity.getMerchSn());
  278. map.put("MerchName",monthlySalesGrowthEntity.getMerchName());
  279. map.put("TotalSales",monthlySalesGrowthEntity.getTotalSales());
  280. map.put("TotalNumber",monthlySalesGrowthEntity.getTotalNumber());
  281. map.put("YearAndWeek",monthlySalesGrowthEntity.getYearAndWeek());
  282. list.add(map);
  283. }
  284. }
  285. ee.addSheetByMap("Weekly Sales Summary", list, header);
  286. ee.export(response);
  287. return R.ok();
  288. }
  289. private void calculateDifferentWeek(List<String> weekList, String startWeek, String endWeek) throws ParseException {
  290. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
  291. SimpleDateFormat weekSdf = new SimpleDateFormat("yyyy");
  292. Calendar bef = Calendar.getInstance();
  293. Calendar aft = Calendar.getInstance();
  294. bef.setFirstDayOfWeek(Calendar.MONDAY);
  295. aft.setFirstDayOfWeek(Calendar.MONDAY);
  296. bef.setTime(sdf.parse(startWeek));
  297. aft.setTime(sdf.parse(endWeek));
  298. do {
  299. int i = bef.get(Calendar.WEEK_OF_YEAR);
  300. if (i<10){
  301. weekList.add(weekSdf.format(bef.getTime())+"-0"+i);
  302. }else{
  303. weekList.add(weekSdf.format(bef.getTime())+"-"+i);
  304. }
  305. bef.set(Calendar.DAY_OF_MONTH,bef.get(Calendar.DAY_OF_MONTH)+7); //给当前时间增加一周
  306. }
  307. while (bef.compareTo(aft) <= 0);
  308. }
  309. /**
  310. * 每月微信好友图表查询
  311. * @param startMonth
  312. * @param endMonth
  313. * @return
  314. */
  315. @RequestMapping("/queryMonthlyWechatFollowers")
  316. public R queryMonthlyWechatFollowers(@RequestParam("startMonth") String startMonth, @RequestParam("endMonth") String endMonth) {
  317. List<String> dateList = new ArrayList<>();
  318. Map<String, Object> returnMap = new HashMap<>();
  319. try {
  320. calculateDifferentMonth(dateList, startMonth, endMonth);
  321. } catch (ParseException e) {
  322. e.printStackTrace();
  323. }
  324. try {
  325. String merchSn = null;
  326. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  327. if(!"1".equals(sysUser.getRoleType())){
  328. merchSn = sysUser.getMerchSn();
  329. }
  330. Map<String,Object> map = monthlyCustomersService.queryMonthlyWechatFollowers(startMonth,endMonth,merchSn);
  331. returnMap.put("dateList", dateList);
  332. returnMap.putAll(map);
  333. } catch (Exception e) {
  334. e.printStackTrace();
  335. return R.error(e.getMessage());
  336. }
  337. return R.ok(returnMap);
  338. }
  339. /**
  340. * 添加微信好友数据
  341. * @param wechatFollowers
  342. * @return
  343. */
  344. @RequestMapping("/addWechatFollowers")
  345. public R addWechatFollowers( @RequestParam("wechatFollowers") Integer wechatFollowers) {
  346. try {
  347. String merchSn = null;
  348. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  349. if(!"1".equals(sysUser.getRoleType())){
  350. merchSn = sysUser.getMerchSn();
  351. }
  352. WechatFollowersEntity wechatFollowersEntity = new WechatFollowersEntity();
  353. wechatFollowersEntity.setCreaterSn(ShiroUtils.getUserId().toString());
  354. wechatFollowersEntity.setCreateTime(new Date());
  355. wechatFollowersEntity.setWechatFollowers(wechatFollowers);
  356. wechatFollowersEntity.setMerchSn(merchSn);
  357. monthlyCustomersService.addWechatFollowers(wechatFollowersEntity);
  358. } catch (Exception e) {
  359. e.printStackTrace();
  360. return R.error(e.getMessage());
  361. }
  362. return R.ok("添加成功");
  363. }
  364. @RequestMapping("/salesByCategory")
  365. public R salesByCategory(@RequestParam("startDate") String startDate, @RequestParam("endDate") String endDate){
  366. String merchSn = null;
  367. SysUserEntity sysUser = (SysUserEntity) SecurityUtils.getSubject().getPrincipal();
  368. if(!"1".equals(sysUser.getRoleType())){
  369. merchSn = sysUser.getMerchSn();
  370. }
  371. return R.ok().put("list",monthlyCustomersService.salesByCategory(startDate,endDate,merchSn));
  372. }
  373. }