user_info; $user_id = $user_info['uid']; $uwhere['uid'] = $user_id; $UgObj = new UserGroup(); $user_store_list =$UgObj->getUserList($uwhere,'uid,store_id'); $store_id_arr = array_column($user_store_list['data'],'store_id'); $store_list = ( new StoreModel() )->getStoreList([ [ 'site_id', '=', $this->site_id ],['store_id','in',$store_id_arr] ], 'store_id,store_name'); // $store_list = ( new StoreModel() )->getStoreList([ [ 'site_id', '=', $this->site_id ] ], 'store_id,store_name'); $this->assign('store_list', $store_list[ 'data' ]); $this->assign('today', Carbon::today()->toDateString()); $this->assign('yesterday', Carbon::yesterday()->toDateString()); return $this->fetch('stat/store'); } /** * 统计数据总和 */ public function statTotal() { if (request()->isAjax()) { $store_id = input('store_id', 0); $start_time = $end_time = input('start_time', strtotime(date('Y-m-d', time()))); $end_time = input('end_time', time()); if ($start_time > $end_time) { $start_time = input('end_time'); $end_time = input('start_time'); } $user_info = $this->user_info; $user_id = $user_info['uid']; $uwhere['uid'] = $user_id; $UgObj = new UserGroup(); $user_store_list =$UgObj->getUserList($uwhere,'uid,store_id'); $store_id_arr = array_column($user_store_list['data'],'store_id'); $stat_model = new StatModel(); $data = $stat_model->getShopStatSum($this->site_id, $start_time, $end_time, $store_id,$store_id_arr); return $data; } } /** * 获取天统计趋势数据 */ public function dayStatData() { if (request()->isAjax()) { $store_id = input('store_id', 0); $start_time = input('start_time', strtotime(date('Y-m-d', strtotime('-6 day')))); $end_time = input('end_time', time()); if ($start_time > $end_time) { $start_time = input('end_time'); $end_time = input('start_time'); } $stat_model = new StatModel(); $fields = $stat_model->getStatField(); $fields[] = 'expected_earnings_total_money'; $stat_list = $stat_model->getShopStatList($this->site_id, $start_time, $end_time, $store_id)[ 'data' ]; $stat_list = array_map(function($item) { $item[ 'day_time' ] = date('Y-m-d', $item[ 'day_time' ]); return $item; }, $stat_list); $stat_list = array_column($stat_list, null, 'day_time'); $day = ceil(( $end_time - $start_time ) / 86400); foreach ($fields as $field) { $value = []; $time = []; for ($i = 0; $i < $day; $i++) { $date = date('Y-m-d', $start_time + $i * 86400); $time[] = $date; $value[] = isset($stat_list[ $date ]) ? $stat_list[ $date ][ $field ] : 0; } $data[ $field ] = $value; $data[ 'time' ] = $time; } return success(0, '', $data); } } /** * 获取小时统计趋势数据 */ public function hourStatData() { if (request()->isAjax()) { $time = input('start_time', time()); $store_id = input('store_id', 0); $carbon = Carbon::createFromTimestamp($time); $stat_model = new StatModel(); $fields = $stat_model->getStatHourField(); $fields[] = 'expected_earnings_total_money'; $stat_list = $stat_model->getShopStatHourList($this->site_id, $carbon->year, $carbon->month, $carbon->day, $store_id)[ 'data' ]; $data = []; $empty = array_map(function() { return 0; }, range(0, 23, 1)); if (!empty($stat_list)) { $stat_list = array_column($stat_list, null, 'hour'); foreach ($fields as $field) { $value = []; for ($i = 0; $i < 24; $i++) { $value[ $i ] = isset($stat_list[ $i ]) ? $stat_list[ $i ][ $field ] : 0; } $data[ $field ] = $value; } } else { foreach ($fields as $field) { $data[ $field ] = $empty; } } $data[ 'time' ] = array_map(function($value) { return $value . '时'; }, range(0, 23, 1)); return success(0, '', $data); } } }