Stat.php 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  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 Carbon\Carbon;
  17. class Stat extends BaseShop
  18. {
  19. /**
  20. * 门店统计数据
  21. */
  22. public function store()
  23. {
  24. $store_list = ( new StoreModel() )->getStoreList([ [ 'site_id', '=', $this->site_id ] ], 'store_id,store_name');
  25. $this->assign('store_list', $store_list[ 'data' ]);
  26. $this->assign('today', Carbon::today()->toDateString());
  27. $this->assign('yesterday', Carbon::yesterday()->toDateString());
  28. return $this->fetch('stat/store');
  29. }
  30. /**
  31. * 统计数据总和
  32. */
  33. public function statTotal()
  34. {
  35. if (request()->isAjax()) {
  36. $store_id = input('store_id', 0);
  37. $start_time = $end_time = input('start_time', strtotime(date('Y-m-d', time())));
  38. $end_time = input('end_time', time());
  39. if ($start_time > $end_time) {
  40. $start_time = input('end_time');
  41. $end_time = input('start_time');
  42. }
  43. $stat_model = new StatModel();
  44. $data = $stat_model->getShopStatSum($this->site_id, $start_time, $end_time, $store_id);
  45. return $data;
  46. }
  47. }
  48. /**
  49. * 获取天统计趋势数据
  50. */
  51. public function dayStatData()
  52. {
  53. if (request()->isAjax()) {
  54. $store_id = input('store_id', 0);
  55. $start_time = input('start_time', strtotime(date('Y-m-d', strtotime('-6 day'))));
  56. $end_time = input('end_time', time());
  57. if ($start_time > $end_time) {
  58. $start_time = input('end_time');
  59. $end_time = input('start_time');
  60. }
  61. $stat_model = new StatModel();
  62. $fields = $stat_model->getStatField();
  63. $fields[] = 'expected_earnings_total_money';
  64. $stat_list = $stat_model->getShopStatList($this->site_id, $start_time, $end_time, $store_id)[ 'data' ];
  65. $stat_list = array_map(function($item) {
  66. $item[ 'day_time' ] = date('Y-m-d', $item[ 'day_time' ]);
  67. return $item;
  68. }, $stat_list);
  69. $stat_list = array_column($stat_list, null, 'day_time');
  70. $day = ceil(( $end_time - $start_time ) / 86400);
  71. foreach ($fields as $field) {
  72. $value = [];
  73. $time = [];
  74. for ($i = 0; $i < $day; $i++) {
  75. $date = date('Y-m-d', $start_time + $i * 86400);
  76. $time[] = $date;
  77. $value[] = isset($stat_list[ $date ]) ? $stat_list[ $date ][ $field ] : 0;
  78. }
  79. $data[ $field ] = $value;
  80. $data[ 'time' ] = $time;
  81. }
  82. return success(0, '', $data);
  83. }
  84. }
  85. /**
  86. * 获取小时统计趋势数据
  87. */
  88. public function hourStatData()
  89. {
  90. if (request()->isAjax()) {
  91. $time = input('start_time', time());
  92. $store_id = input('store_id', 0);
  93. $carbon = Carbon::createFromTimestamp($time);
  94. $stat_model = new StatModel();
  95. $fields = $stat_model->getStatHourField();
  96. $fields[] = 'expected_earnings_total_money';
  97. $stat_list = $stat_model->getShopStatHourList($this->site_id, $carbon->year, $carbon->month, $carbon->day, $store_id)[ 'data' ];
  98. $data = [];
  99. $empty = array_map(function() { return 0; }, range(0, 23, 1));
  100. if (!empty($stat_list)) {
  101. $stat_list = array_column($stat_list, null, 'hour');
  102. foreach ($fields as $field) {
  103. $value = [];
  104. for ($i = 0; $i < 24; $i++) {
  105. $value[ $i ] = isset($stat_list[ $i ]) ? $stat_list[ $i ][ $field ] : 0;
  106. }
  107. $data[ $field ] = $value;
  108. }
  109. } else {
  110. foreach ($fields as $field) {
  111. $data[ $field ] = $empty;
  112. }
  113. }
  114. $data[ 'time' ] = array_map(function($value) { return $value . '时'; }, range(0, 23, 1));
  115. return success(0, '', $data);
  116. }
  117. }
  118. }