Stat.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. <?php
  2. /**
  3. * Niushop商城系统 - 团队十年电商经验汇集巨献!
  4. * =========================================================
  5. * Copy right 2019-2029 上海牛之云网络科技有限公司, 保留所有权利。
  6. * ----------------------------------------------
  7. * 官方网址: https://www.niushop.com
  8. * 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用。
  9. * 任何企业和个人不允许对程序代码以任何形式任何目的再发布。
  10. * =========================================================
  11. */
  12. namespace addon\store\shop\controller;
  13. use app\model\store\Stat as StatModel;
  14. use app\model\store\Store as StoreModel;
  15. use app\shop\controller\BaseShop;
  16. use app\model\system\UserGroup;
  17. use Carbon\Carbon;
  18. use think\validate\ValidateRule;
  19. class Stat extends BaseShop
  20. {
  21. /**
  22. * 门店统计数据
  23. */
  24. public function store()
  25. {
  26. $user_info = $this->user_info;
  27. $user_id = $user_info['uid'];
  28. $uwhere['uid'] = $user_id;
  29. $UgObj = new UserGroup();
  30. $user_store_list =$UgObj->getUserList($uwhere,'uid,store_id');
  31. $store_id_arr = array_column($user_store_list['data'],'store_id');
  32. $store_list = ( new StoreModel() )->getStoreList([ [ 'site_id', '=', $this->site_id ],['store_id','in',$store_id_arr] ], 'store_id,store_name');
  33. $this->assign('store_list', $store_list[ 'data' ]);
  34. $this->assign('today', Carbon::today()->toDateString());
  35. $this->assign('yesterday', Carbon::yesterday()->toDateString());
  36. return $this->fetch('stat/store');
  37. }
  38. /**
  39. * 统计数据总和
  40. */
  41. public function statTotal()
  42. {
  43. if (request()->isAjax()) {
  44. $store_id = input('store_id', 0);
  45. $start_time = $end_time = input('start_time', strtotime(date('Y-m-d', time())));
  46. $end_time = input('end_time', time());
  47. if ($start_time > $end_time) {
  48. $start_time = input('end_time');
  49. $end_time = input('start_time');
  50. }
  51. $user_info = $this->user_info;
  52. $user_id = $user_info['uid'];
  53. $uwhere['uid'] = $user_id;
  54. $UgObj = new UserGroup();
  55. $user_store_list =$UgObj->getUserList($uwhere,'uid,store_id');
  56. $store_id_arr = array_column($user_store_list['data'],'store_id');
  57. $stat_model = new StatModel();
  58. $data = $stat_model->getShopStatSum($this->site_id, $start_time, $end_time, $store_id,$store_id_arr);
  59. return $data;
  60. }
  61. }
  62. /**
  63. * 获取天统计趋势数据
  64. */
  65. public function dayStatData()
  66. {
  67. if (request()->isAjax()) {
  68. $store_id = input('store_id', 0);
  69. $start_time = input('start_time', strtotime(date('Y-m-d', strtotime('-6 day'))));
  70. $end_time = input('end_time', time());
  71. if ($start_time > $end_time) {
  72. $start_time = input('end_time');
  73. $end_time = input('start_time');
  74. }
  75. $stat_model = new StatModel();
  76. $fields = $stat_model->getStatField();
  77. $fields[] = 'expected_earnings_total_money';
  78. $stat_list = $stat_model->getShopStatList($this->site_id, $start_time, $end_time, $store_id)[ 'data' ];
  79. $stat_list = array_map(function($item) {
  80. $item[ 'day_time' ] = date('Y-m-d', $item[ 'day_time' ]);
  81. return $item;
  82. }, $stat_list);
  83. $stat_list = array_column($stat_list, null, 'day_time');
  84. $day = ceil(( $end_time - $start_time ) / 86400);
  85. foreach ($fields as $field) {
  86. $value = [];
  87. $time = [];
  88. for ($i = 0; $i < $day; $i++) {
  89. $date = date('Y-m-d', $start_time + $i * 86400);
  90. $time[] = $date;
  91. $value[] = isset($stat_list[ $date ]) ? $stat_list[ $date ][ $field ] : 0;
  92. }
  93. $data[ $field ] = $value;
  94. $data[ 'time' ] = $time;
  95. }
  96. return success(0, '', $data);
  97. }
  98. }
  99. /**
  100. * 获取小时统计趋势数据
  101. */
  102. public function hourStatData()
  103. {
  104. if (request()->isAjax()) {
  105. $time = input('start_time', time());
  106. $store_id = input('store_id', 0);
  107. $carbon = Carbon::createFromTimestamp($time);
  108. $stat_model = new StatModel();
  109. $fields = $stat_model->getStatHourField();
  110. $fields[] = 'expected_earnings_total_money';
  111. $stat_list = $stat_model->getShopStatHourList($this->site_id, $carbon->year, $carbon->month, $carbon->day, $store_id)[ 'data' ];
  112. $data = [];
  113. $empty = array_map(function() { return 0; }, range(0, 23, 1));
  114. if (!empty($stat_list)) {
  115. $stat_list = array_column($stat_list, null, 'hour');
  116. foreach ($fields as $field) {
  117. $value = [];
  118. for ($i = 0; $i < 24; $i++) {
  119. $value[ $i ] = isset($stat_list[ $i ]) ? $stat_list[ $i ][ $field ] : 0;
  120. }
  121. $data[ $field ] = $value;
  122. }
  123. } else {
  124. foreach ($fields as $field) {
  125. $data[ $field ] = $empty;
  126. }
  127. }
  128. $data[ 'time' ] = array_map(function($value) { return $value . '时'; }, range(0, 23, 1));
  129. return success(0, '', $data);
  130. }
  131. }
  132. }