123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425 |
- <?php
- /**
- * Niushop商城系统 - 团队十年电商经验汇集巨献!
- * =========================================================
- * Copy right 2019-2029 山西牛酷信息科技有限公司, 保留所有权利。
- * ----------------------------------------------
- * 官方网址: https://www.niushop.com.cn
- * 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用。
- * 任何企业和个人不允许对程序代码以任何形式任何目的再发布。
- * =========================================================
- */
- namespace app\admin\controller;
- use app\model\order\OrderCommon as OrderCommonModel;
- use app\model\system\Stat as StatModel;
- /**
- * 统计管理 控制器
- */
- class Stat extends BaseAdmin
- {
- /**
- * 统计概况
- */
- public function index()
- {
- if (request()->isAjax()) {
- $date_type = input('date_type', 0);
- if($date_type == 0){
- $start_time = strtotime("today");
- $time_range = date('Y-m-d',$start_time);
- }else if($date_type == 1){
- $start_time = strtotime(date('Y-m-d', strtotime("-6 day")));
- $time_range = date('Y-m-d',$start_time).' 至 '.date('Y-m-d',strtotime("today"));
- }else if($date_type == 2){
- $start_time = strtotime(date('Y-m-d', strtotime("-29 day")));
- $time_range = date('Y-m-d',$start_time).' 至 '.date('Y-m-d',strtotime("today"));
- }
- $order_common_model = new OrderCommonModel();
- $shop_stat_sum = $order_common_model->getShopStatSum(0, $start_time);
- $shop_stat_sum['data']['time_range'] = $time_range;
- return $shop_stat_sum;
- }else{
- return $this->fetch("stat/index");
- }
- }
- /**
- * 店铺统计报表
- * */
- public function getStatList()
- {
- if (request()->isAjax()) {
- $date_type = input('date_type', 1);
- if($date_type == 1){
- $start_time = strtotime(date('Y-m-d', strtotime("-6 day")));
- $time_range = date('Y-m-d',$start_time).' 至 '.date('Y-m-d',strtotime("today"));
- $day = 6;
- }else if($date_type == 2){
- $start_time = strtotime(date('Y-m-d', strtotime("-29 day")));
- $time_range = date('Y-m-d',$start_time).' 至 '.date('Y-m-d',strtotime("today"));
- $day = 29;
- }
- $stat_model = new StatModel();
- $stat_list = $stat_model->getShopStatList(0, $start_time);
- //将时间戳作为列表的主键
- $shop_stat_list = array_column($stat_list['data'], null, 'day_time');
- $data = array();
- for ($i = 0;$i <= $day;$i++){
- $time = strtotime(date('Y-m-d',strtotime("-".($day-$i)." day")));
- $data['time'][$i] = date('Y-m-d',$time);
- if(array_key_exists($time, $shop_stat_list)){
- $data['order_total'][$i] = $shop_stat_list[$time]['order_total'];
- $data['shipping_total'][$i] = $shop_stat_list[$time]['shipping_total'];
- $data['refund_total'][$i] = $shop_stat_list[$time]['refund_total'];
- $data['order_pay_count'][$i] = $shop_stat_list[$time]['order_pay_count'];
- $data['goods_pay_count'][$i] = $shop_stat_list[$time]['goods_pay_count'];
- $data['shop_money'][$i] = $shop_stat_list[$time]['shop_money'];
- $data['platform_money'][$i] = $shop_stat_list[$time]['platform_money'];
- $data['collect_shop'][$i] = $shop_stat_list[$time]['collect_shop'];
- $data['collect_goods'][$i] = $shop_stat_list[$time]['collect_goods'];
- $data['visit_count'][$i] = $shop_stat_list[$time]['visit_count'];
- $data['order_count'][$i] = $shop_stat_list[$time]['order_count'];
- $data['goods_count'][$i] = $shop_stat_list[$time]['goods_count'];
- $data['add_goods_count'][$i] = $shop_stat_list[$time]['add_goods_count'];
- $data['member_count'][$i] = $shop_stat_list[$time]['member_count'];
- }else{
- $data['order_total'][$i] = 0.00;
- $data['shipping_total'][$i] = 0.00;
- $data['refund_total'][$i] = 0.00;
- $data['order_pay_count'][$i] = 0;
- $data['goods_pay_count'][$i] = 0;
- $data['shop_money'][$i] = 0.00;
- $data['platform_money'][$i] = 0.00;
- $data['collect_shop'][$i] = 0;
- $data['collect_goods'][$i] = 0;
- $data['visit_count'][$i] = 0;
- $data['order_count'][$i] = 0;
- $data['goods_count'][$i] = 0;
- $data['add_goods_count'][$i] = 0;
- $data['member_count'][$i] = 0;
- }
- }
- $data['time_range'] = $time_range;
- return $data;
- }
- }
- /**
- * 交易分析
- */
- public function order()
- {
- if (request()->isAjax()) {
- $date_type = input('date_type', 0);
- if($date_type == 0){
- $start_time = strtotime("today");
- $time_range = date('Y-m-d',$start_time);
- }else if($date_type == 1){
- $start_time = strtotime(date('Y-m-d', strtotime("-6 day")));
- $time_range = date('Y-m-d',$start_time).' 至 '.date('Y-m-d',strtotime("today"));
- }else if($date_type == 2){
- $start_time = strtotime(date('Y-m-d', strtotime("-29 day")));
- $time_range = date('Y-m-d',$start_time).' 至 '.date('Y-m-d',strtotime("today"));
- }
- $stat_model = new StatModel();
- $shop_stat_sum = $stat_model->getShopStatSum(0, $start_time);
- $shop_stat_sum['data']['time_range'] = $time_range;
- return $shop_stat_sum;
- }else{
- return $this->fetch("stat/order");
- }
- }
- /**
- * 交易统计报表
- * */
- public function getOrderStatList()
- {
- if (request()->isAjax()) {
- $date_type = input('date_type', 1);
- if($date_type == 1){
- $start_time = strtotime(date('Y-m-d', strtotime("-6 day")));
- $time_range = date('Y-m-d',$start_time).' 至 '.date('Y-m-d',strtotime("today"));
- $day = 6;
- }else if($date_type == 2){
- $start_time = strtotime(date('Y-m-d', strtotime("-29 day")));
- $time_range = date('Y-m-d',$start_time).' 至 '.date('Y-m-d',strtotime("today"));
- $day = 29;
- }
- $stat_model = new StatModel();
- $stat_list = $stat_model->getShopStatList(0, $start_time);
- //将时间戳作为列表的主键
- $shop_stat_list = array_column($stat_list['data'], null, 'day_time');
- $data = array();
- for ($i = 0;$i <= $day;$i++){
- $time = strtotime(date('Y-m-d',strtotime("-".($day-$i)." day")));
- $data['time'][$i] = date('Y-m-d',$time);
- if(array_key_exists($time, $shop_stat_list)){
- $data['order_total'][$i] = $shop_stat_list[$time]['order_total'];
- $data['shipping_total'][$i] = $shop_stat_list[$time]['shipping_total'];
- $data['refund_total'][$i] = $shop_stat_list[$time]['refund_total'];
- $data['order_pay_count'][$i] = $shop_stat_list[$time]['order_pay_count'];
- $data['goods_pay_count'][$i] = $shop_stat_list[$time]['goods_pay_count'];
- $data['shop_money'][$i] = $shop_stat_list[$time]['shop_money'];
- $data['platform_money'][$i] = $shop_stat_list[$time]['platform_money'];
- $data['collect_shop'][$i] = $shop_stat_list[$time]['collect_shop'];
- $data['collect_goods'][$i] = $shop_stat_list[$time]['collect_goods'];
- $data['visit_count'][$i] = $shop_stat_list[$time]['visit_count'];
- $data['order_count'][$i] = $shop_stat_list[$time]['order_count'];
- $data['goods_count'][$i] = $shop_stat_list[$time]['goods_count'];
- $data['add_goods_count'][$i] = $shop_stat_list[$time]['add_goods_count'];
- $data['member_count'][$i] = $shop_stat_list[$time]['member_count'];
- }else{
- $data['order_total'][$i] = 0.00;
- $data['shipping_total'][$i] = 0.00;
- $data['refund_total'][$i] = 0.00;
- $data['order_pay_count'][$i] = 0;
- $data['goods_pay_count'][$i] = 0;
- $data['shop_money'][$i] = 0.00;
- $data['platform_money'][$i] = 0.00;
- $data['collect_shop'][$i] = 0;
- $data['collect_goods'][$i] = 0;
- $data['visit_count'][$i] = 0;
- $data['order_count'][$i] = 0;
- $data['goods_count'][$i] = 0;
- $data['add_goods_count'][$i] = 0;
- $data['member_count'][$i] = 0;
- }
- }
- $data['time_range'] = $time_range;
- return $data;
- }
- }
- /**
- * 商品统计
- * @return mixed
- */
- public function goods()
- {
- if (request()->isAjax()) {
- $date_type = input('date_type', 0);
- if($date_type == 0){
- $start_time = strtotime("today");
- $time_range = date('Y-m-d',$start_time);
- }else if($date_type == 1){
- $start_time = strtotime(date('Y-m-d', strtotime("-6 day")));
- $time_range = date('Y-m-d',$start_time).' 至 '.date('Y-m-d',strtotime("today"));
- }else if($date_type == 2){
- $start_time = strtotime(date('Y-m-d', strtotime("-29 day")));
- $time_range = date('Y-m-d',$start_time).' 至 '.date('Y-m-d',strtotime("today"));
- }
- $stat_model = new StatModel();
- $shop_stat_sum = $stat_model->getShopStatSum(0, $start_time);
- $shop_stat_sum['data']['time_range'] = $time_range;
- return $shop_stat_sum;
- }else{
- return $this->fetch("stat/goods");
- }
- }
- /**
- * 商品统计报表
- * */
- public function getGoodsStatList()
- {
- if (request()->isAjax()) {
- $date_type = input('date_type', 1);
- if($date_type == 1){
- $start_time = strtotime(date('Y-m-d', strtotime("-6 day")));
- $time_range = date('Y-m-d',$start_time).' 至 '.date('Y-m-d',strtotime("today"));
- $day = 6;
- }else if($date_type == 2){
- $start_time = strtotime(date('Y-m-d', strtotime("-29 day")));
- $time_range = date('Y-m-d',$start_time).' 至 '.date('Y-m-d',strtotime("today"));
- $day = 29;
- }
- $stat_model = new StatModel();
- $stat_list = $stat_model->getShopStatList(0, $start_time);
- //将时间戳作为列表的主键
- $shop_stat_list = array_column($stat_list['data'], null, 'day_time');
- $data = array();
- for ($i = 0;$i <= $day;$i++){
- $time = strtotime(date('Y-m-d',strtotime("-".($day-$i)." day")));
- $data['time'][$i] = date('Y-m-d',$time);
- if(array_key_exists($time, $shop_stat_list)){
- $data['order_total'][$i] = $shop_stat_list[$time]['order_total'];
- $data['shipping_total'][$i] = $shop_stat_list[$time]['shipping_total'];
- $data['refund_total'][$i] = $shop_stat_list[$time]['refund_total'];
- $data['order_pay_count'][$i] = $shop_stat_list[$time]['order_pay_count'];
- $data['goods_pay_count'][$i] = $shop_stat_list[$time]['goods_pay_count'];
- $data['shop_money'][$i] = $shop_stat_list[$time]['shop_money'];
- $data['platform_money'][$i] = $shop_stat_list[$time]['platform_money'];
- $data['collect_shop'][$i] = $shop_stat_list[$time]['collect_shop'];
- $data['collect_goods'][$i] = $shop_stat_list[$time]['collect_goods'];
- $data['visit_count'][$i] = $shop_stat_list[$time]['visit_count'];
- $data['order_count'][$i] = $shop_stat_list[$time]['order_count'];
- $data['goods_count'][$i] = $shop_stat_list[$time]['goods_count'];
- $data['add_goods_count'][$i] = $shop_stat_list[$time]['add_goods_count'];
- $data['member_count'][$i] = $shop_stat_list[$time]['member_count'];
- }else{
- $data['order_total'][$i] = 0.00;
- $data['shipping_total'][$i] = 0.00;
- $data['refund_total'][$i] = 0.00;
- $data['order_pay_count'][$i] = 0;
- $data['goods_pay_count'][$i] = 0;
- $data['shop_money'][$i] = 0.00;
- $data['platform_money'][$i] = 0.00;
- $data['collect_shop'][$i] = 0;
- $data['collect_goods'][$i] = 0;
- $data['visit_count'][$i] = 0;
- $data['order_count'][$i] = 0;
- $data['goods_count'][$i] = 0;
- $data['add_goods_count'][$i] = 0;
- $data['member_count'][$i] = 0;
- }
- }
- $data['time_range'] = $time_range;
- return $data;
- }
- }
- /**
- * 会员统计
- * @return mixed
- */
- public function member()
- {
- if (request()->isAjax()) {
- $date_type = input('date_type', 0);
- if($date_type == 0){
- $start_time = strtotime("today");
- $time_range = date('Y-m-d',$start_time);
- }else if($date_type == 1){
- $start_time = strtotime(date('Y-m-d', strtotime("-6 day")));
- $time_range = date('Y-m-d',$start_time).' 至 '.date('Y-m-d',strtotime("today"));
- }else if($date_type == 2){
- $start_time = strtotime(date('Y-m-d', strtotime("-29 day")));
- $time_range = date('Y-m-d',$start_time).' 至 '.date('Y-m-d',strtotime("today"));
- }
- $stat_model = new StatModel();
- $shop_stat_sum = $stat_model->getShopStatSum(0, $start_time);
- $shop_stat_sum['data']['time_range'] = $time_range;
- return $shop_stat_sum;
- }else{
- return $this->fetch("stat/member");
- }
- }
- /**
- * 会员统计报表
- * */
- public function getMemberStatList()
- {
- if (request()->isAjax()) {
- $date_type = input('date_type', 1);
- if($date_type == 1){
- $start_time = strtotime(date('Y-m-d', strtotime("-6 day")));
- $time_range = date('Y-m-d',$start_time).' 至 '.date('Y-m-d',strtotime("today"));
- $day = 6;
- }else if($date_type == 2){
- $start_time = strtotime(date('Y-m-d', strtotime("-29 day")));
- $time_range = date('Y-m-d',$start_time).' 至 '.date('Y-m-d',strtotime("today"));
- $day = 29;
- }
- $stat_model = new StatModel();
- $stat_list = $stat_model->getShopStatList(0, $start_time);
- //将时间戳作为列表的主键
- $shop_stat_list = array_column($stat_list['data'], null, 'day_time');
- $data = array();
- for ($i = 0;$i <= $day;$i++){
- $time = strtotime(date('Y-m-d',strtotime("-".($day-$i)." day")));
- $data['time'][$i] = date('Y-m-d',$time);
- if(array_key_exists($time, $shop_stat_list)){
- $data['order_total'][$i] = $shop_stat_list[$time]['order_total'];
- $data['shipping_total'][$i] = $shop_stat_list[$time]['shipping_total'];
- $data['refund_total'][$i] = $shop_stat_list[$time]['refund_total'];
- $data['order_pay_count'][$i] = $shop_stat_list[$time]['order_pay_count'];
- $data['goods_pay_count'][$i] = $shop_stat_list[$time]['goods_pay_count'];
- $data['shop_money'][$i] = $shop_stat_list[$time]['shop_money'];
- $data['platform_money'][$i] = $shop_stat_list[$time]['platform_money'];
- $data['collect_shop'][$i] = $shop_stat_list[$time]['collect_shop'];
- $data['collect_goods'][$i] = $shop_stat_list[$time]['collect_goods'];
- $data['visit_count'][$i] = $shop_stat_list[$time]['visit_count'];
- $data['order_count'][$i] = $shop_stat_list[$time]['order_count'];
- $data['goods_count'][$i] = $shop_stat_list[$time]['goods_count'];
- $data['add_goods_count'][$i] = $shop_stat_list[$time]['add_goods_count'];
- $data['member_count'][$i] = $shop_stat_list[$time]['member_count'];
- }else{
- $data['order_total'][$i] = 0.00;
- $data['shipping_total'][$i] = 0.00;
- $data['refund_total'][$i] = 0.00;
- $data['order_pay_count'][$i] = 0;
- $data['goods_pay_count'][$i] = 0;
- $data['shop_money'][$i] = 0.00;
- $data['platform_money'][$i] = 0.00;
- $data['collect_shop'][$i] = 0;
- $data['collect_goods'][$i] = 0;
- $data['visit_count'][$i] = 0;
- $data['order_count'][$i] = 0;
- $data['goods_count'][$i] = 0;
- $data['add_goods_count'][$i] = 0;
- $data['member_count'][$i] = 0;
- }
- }
- $data['time_range'] = $time_range;
- return $data;
- }
- }
-
- }
|