123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402 |
- <?php
- namespace app\admin\controller\cms;
- use addons\cms\model\SearchLog;
- use app\admin\model\User;
- use app\common\controller\Backend;
- class Statistics extends Backend
- {
-
- protected $model = null;
- protected $noNeedRight = [];
- protected $isSuperAdmin = false;
- protected $searchFields = 'id,title';
-
- public function index()
- {
- try {
- \think\Db::execute("SET @@sql_mode='';");
- } catch (\Exception $e) {
- }
- $config = get_addon_config('cms');
- if ($this->request->isPost()) {
- $date = $this->request->post('date', '');
- $type = $this->request->post('type', '');
- if ($type == 'sale') {
- list($orderSaleCategory, $orderSaleAmount, $orderSaleNums) = $this->getSaleStatisticsData($date);
- $statistics = ['orderSaleCategory' => $orderSaleCategory, 'orderSaleAmount' => $orderSaleAmount, 'orderSaleNums' => $orderSaleNums];
- } elseif ($type == 'percent') {
- list($orderPercentCategory, $orderPercentAmount, $orderPercentNums) = $this->getPercentStatisticsData($date);
- $statistics = ['orderPercentCategory' => $orderPercentCategory, 'orderPercentAmount' => $orderPercentAmount, 'orderPercentNums' => $orderPercentNums];
- } elseif ($type == 'order') {
- list($category, $data) = $this->getOrderStatisticsData($date);
- $statistics = ['category' => $category, 'data' => $data];
- } elseif ($type == 'archives') {
- list($category, $data) = $this->getArchivesStatisticsData($date);
- $statistics = ['category' => $category, 'data' => $data];
- }
- $this->success('', '', $statistics);
- }
-
- list($category, $data) = $this->getArchivesStatisticsData('');
- $this->assignconfig('adminArchivesListCategory', $category);
- $this->assignconfig('adminArchivesListData', $data);
-
- $totalOrderAmount = round(\app\admin\model\cms\Order::where('status', 'paid')->sum('payamount'), 2);
- $yesterdayOrderAmount = round(\app\admin\model\cms\Order::where('status', 'paid')->whereTime('paytime', 'yesterday')->sum('payamount'), 2);
- $todayOrderAmount = round(\app\admin\model\cms\Order::where('status', 'paid')->whereTime('paytime', 'today')->sum('payamount'), 2);
- $todayOrderRatio = $yesterdayOrderAmount > 0 ? ceil((($todayOrderAmount - $yesterdayOrderAmount) / $yesterdayOrderAmount) * 100) : ($todayOrderAmount > 0 ? 100 : 0);
- $totalUser = User::count();
- $yesterdayUser = User::whereTime('jointime', 'yesterday')->count();
- $todayUser = User::whereTime('jointime', 'today')->count();
- $todayUserRatio = $yesterdayUser > 0 ? ceil((($todayUser - $yesterdayUser) / $yesterdayUser) * 100) : ($todayUser > 0 ? 100 : 0);
-
- $totalArchives = \app\admin\model\cms\Archives::count();
- $unsettleArchives = \app\admin\model\cms\Archives::where('status', 'hidden')->count();
- $totalComment = \app\admin\model\cms\Comment::count();
- $unsettleComment = \app\admin\model\cms\Comment::where('status', 'hidden')->count();
- $diyformList = \app\admin\model\cms\Diyform::all();
- foreach ($diyformList as $index => $item) {
- $item->nums = \think\Db::name($item['table'])->count();
- }
-
- list($orderSaleCategory, $orderSaleAmount, $orderSaleNums) = $this->getSaleStatisticsData();
- $this->assignconfig('orderSaleCategory', $orderSaleCategory);
- $this->assignconfig('orderSaleAmount', $orderSaleAmount);
- $this->assignconfig('orderSaleNums', $orderSaleNums);
-
- list($orderPercentCategory, $orderPercentAmount, $orderPercentNums) = $this->getPercentStatisticsData();
- $this->assignconfig('orderPercentCategory', $orderPercentCategory);
- $this->assignconfig('orderPercentAmount', $orderPercentAmount);
- $this->assignconfig('orderPercentNums', $orderPercentNums);
-
- $tagList = \app\admin\model\cms\Tag::order('nums', 'desc')->limit(10)->select();
- $tagsTotal = 0;
- foreach ($tagList as $index => $item) {
- $tagsTotal += $item['nums'];
- }
- foreach ($tagList as $index => $item) {
- $item['percent'] = $tagsTotal > 0 ? round($item['nums'] / $tagsTotal * 100, 2) : 0;
- }
-
- $hotSearchList = SearchLog::order('nums', 'desc')->cache(3600)->limit(10)->select();
- $hotTagList = \addons\cms\model\Tag::order('nums', 'desc')->cache(3600)->limit(10)->select();
- $hotArchivesList = \addons\cms\model\Archives::order('views', 'desc')->cache(3600)->limit(10)->select();
-
- $todayPaidTotal = \app\admin\model\cms\Order::whereTime('paytime', 'today')->sum("payamount");
- $todayPaidList = \app\admin\model\cms\Order::with(['archives'])->whereTime('paytime', 'today')->group('archives_id')->field("COUNT(*) as nums,SUM(payamount) as amount,archives_id")->order("amount", "desc")->limit(10)->select();
- foreach ($todayPaidList as $index => $item) {
- $item->percent = $todayPaidTotal > 0 ? round(($item['amount'] / $todayPaidTotal) * 100, 2) : 0;
- }
- $weekPaidTotal = \app\admin\model\cms\Order::whereTime('paytime', 'week')->sum("payamount");
- $weekPaidList = \app\admin\model\cms\Order::with(['archives'])->whereTime('paytime', 'week')->group('archives_id')->field("COUNT(*) as nums,SUM(payamount) as amount,archives_id")->order("amount", "desc")->limit(10)->select();
- foreach ($weekPaidList as $index => $item) {
- $item->percent = $weekPaidTotal > 0 ? round(($item['amount'] / $weekPaidTotal) * 100, 2) : 0;
- }
- $monthPaidTotal = \app\admin\model\cms\Order::whereTime('paytime', 'month')->sum("payamount");
- $monthPaidList = \app\admin\model\cms\Order::with(['archives'])->whereTime('paytime', 'month')->group('archives_id')->field("COUNT(*) as nums,SUM(payamount) as amount,archives_id")->order("amount", "desc")->limit(10)->select();
- foreach ($monthPaidList as $index => $item) {
- $item->percent = $monthPaidTotal > 0 ? round(($item['amount'] / $monthPaidTotal) * 100, 2) : 0;
- }
-
- $todayContributeTotal = \app\admin\model\cms\Archives::whereTime('createtime', 'today')->count();
- $todayContributeList = \app\admin\model\cms\Archives::with(['user'])->where('user_id', '>', 0)->whereTime('createtime', 'today')->group('user_id')->field("COUNT(*) as nums,user_id")->order("nums", "desc")->limit(10)->select();
- foreach ($todayContributeList as $index => $item) {
- $item->percent = $todayContributeTotal > 0 ? round(($item['nums'] / $todayContributeTotal) * 100, 2) : 0;
- }
- $weekContributeTotal = \app\admin\model\cms\Archives::whereTime('createtime', 'week')->count();
- $weekContributeList = \app\admin\model\cms\Archives::with(['user'])->where('user_id', '>', 0)->whereTime('createtime', 'week')->group('user_id')->field("COUNT(*) as nums,user_id")->order("nums", "desc")->limit(10)->select();
- foreach ($weekContributeList as $index => $item) {
- $item->percent = $weekContributeTotal > 0 ? round(($item['nums'] / $weekContributeTotal) * 100, 2) : 0;
- }
- $monthContributeTotal = \app\admin\model\cms\Archives::whereTime('createtime', 'month')->count();
- $monthContributeList = \app\admin\model\cms\Archives::with(['user'])->where('user_id', '>', 0)->whereTime('createtime', 'month')->group('user_id')->field("COUNT(*) as nums,user_id")->order("nums", "desc")->limit(10)->select();
- foreach ($monthContributeList as $index => $item) {
- $item->percent = $monthContributeTotal > 0 ? round(($item['nums'] / $monthContributeTotal) * 100, 2) : 0;
- }
- $this->view->assign("totalOrderAmount", $totalOrderAmount);
- $this->view->assign("yesterdayOrderAmount", $yesterdayOrderAmount);
- $this->view->assign("todayOrderAmount", $todayOrderAmount);
- $this->view->assign("todayOrderRatio", $todayOrderRatio);
- $this->view->assign("totalUser", $totalUser);
- $this->view->assign("yesterdayUser", $yesterdayUser);
- $this->view->assign("todayUser", $todayUser);
- $this->view->assign("todayUserRatio", $todayUserRatio);
- $this->view->assign("totalArchives", $totalArchives);
- $this->view->assign("unsettleArchives", $unsettleArchives);
- $this->view->assign("totalComment", $totalComment);
- $this->view->assign("unsettleComment", $unsettleComment);
- $this->view->assign("tagsList", $tagList);
- $this->view->assign("hotTagList", $hotTagList);
- $this->view->assign("hotArchivesList", $hotArchivesList);
- $this->view->assign("hotSearchList", $hotSearchList);
- $this->view->assign("todayPaidList", $todayPaidList);
- $this->view->assign("weekPaidList", $weekPaidList);
- $this->view->assign("monthPaidList", $monthPaidList);
- $this->view->assign("todayContributeList", $todayContributeList);
- $this->view->assign("weekContributeList", $weekContributeList);
- $this->view->assign("monthContributeList", $monthContributeList);
- $this->view->assign("modelList", \app\admin\model\cms\Modelx::order('id asc')->select());
- return $this->view->fetch();
- }
-
- protected function getSaleStatisticsData($date = '')
- {
- $starttime = \fast\Date::unixtime();
- $endtime = \fast\Date::unixtime('day', 0, 'end');
- $format = '%H:00';
- $orderList = \app\admin\model\cms\Order::where('paytime', 'between time', [$starttime, $endtime])
- ->field('paytime, status, COUNT(*) AS nums, SUM(payamount) AS amount, MIN(paytime) AS min_paytime, MAX(paytime) AS max_paytime,
- DATE_FORMAT(FROM_UNIXTIME(paytime), "' . $format . '") AS paydate')
- ->group('paydate')
- ->select();
- $column = [];
- for ($time = $starttime; $time <= $endtime;) {
- $column[] = date("H:00", $time);
- $time += 3600;
- }
- $orderSaleNums = $orderSaleAmount = array_fill_keys($column, 0);
- foreach ($orderList as $k => $v) {
- $orderSaleNums[$v['paydate']] = $v['nums'];
- $orderSaleAmount[$v['paydate']] = round($v['amount'], 2);
- }
- $orderSaleCategory = array_keys($orderSaleAmount);
- $orderSaleAmount = array_values($orderSaleAmount);
- $orderSaleNums = array_values($orderSaleNums);
- return [$orderSaleCategory, $orderSaleAmount, $orderSaleNums];
- }
-
- protected function getPercentStatisticsData($date = '')
- {
- $starttime = \fast\Date::unixtime();
- $endtime = \fast\Date::unixtime('day', 0, 'end');
- $modelList = [];
- $orderPercentCategory = $orderPercentAmount = $orderPercentNums = [];
- $list = \app\admin\model\cms\Order::with('archives')
- ->where('order.createtime', 'between time', [$starttime, $endtime])
- ->where('order.status', 'paid')
- ->field("archives.model_id,SUM(payamount) as amount,COUNT(*) as nums")
- ->group('archives.model_id')
- ->select();
- foreach ($list as $index => $item) {
- $modelList[$item['archives']['model']['name']] = $item['amount'];
- $name = $item['archives']['model']['name'];
- $name = $name ? $name : "其它";
- $orderPercentCategory[] = $name;
- $orderPercentAmount[] = ['value' => round($item['amount'], 2), 'name' => $name];
- $orderPercentNums[] = ['value' => $item['nums'], 'name' => $name];
- }
- if (!$orderPercentCategory) {
- $orderPercentCategory = [""];
- $orderPercentNums = [['value' => 0, 'name' => '订单数']];
- $orderPercentAmount = [['value' => 0, 'name' => '订单额']];
- }
- return [$orderPercentCategory, $orderPercentAmount, $orderPercentNums];
- }
-
- protected function getOrderStatisticsData($date = '')
- {
- if ($date) {
- list($start, $end) = explode(' - ', $date);
- $starttime = strtotime($start);
- $endtime = strtotime($end);
- } else {
- $starttime = \fast\Date::unixtime('day', 0, 'begin');
- $endtime = \fast\Date::unixtime('day', 0, 'end');
- }
- $totalseconds = $endtime - $starttime;
- $format = '%Y-%m-%d';
- if ($totalseconds > 86400 * 30 * 2) {
- $format = '%Y-%m';
- } else {
- if ($totalseconds > 86400) {
- $format = '%Y-%m-%d';
- } else {
- $format = '%H:00';
- }
- }
- $model_id = $this->request->post("model_id");
- $orderList = \app\admin\model\cms\Order::where('paytime', 'between time', [$starttime, $endtime])
- ->where(function ($query) use ($model_id, $starttime, $endtime) {
- if ($model_id) {
-
- $query->where('archives_id', 'in', function ($query) use ($model_id, $starttime, $endtime) {
- $query->name("cms_archives")->where('model_id', $model_id)->where('id', 'in', function ($query) use ($starttime, $endtime) {
- $query->name('cms_order')->where('paytime', 'between time', [$starttime, $endtime])->field('archives_id');
- })->field('id');
- });
- }
- })
- ->field('paytime, status, SUM(payamount) AS amount, MIN(paytime) AS min_paytime, MAX(paytime) AS max_paytime,
- DATE_FORMAT(FROM_UNIXTIME(createtime), "' . $format . '") AS pay_date')
- ->group('pay_date')
- ->select();
- if ($totalseconds > 84600 * 30 * 2) {
- $starttime = strtotime('last month', $starttime);
- while (($starttime = strtotime('next month', $starttime)) <= $endtime) {
- $column[] = date('Y-m', $starttime);
- }
- } else {
- if ($totalseconds > 86400) {
- for ($time = $starttime; $time <= $endtime;) {
- $column[] = date("Y-m-d", $time);
- $time += 86400;
- }
- } else {
- for ($time = $starttime; $time <= $endtime;) {
- $column[] = date("H:00", $time);
- $time += 3600;
- }
- }
- }
- $list = array_fill_keys($column, 0);
- foreach ($orderList as $k => $v) {
- $list[$v['pay_date']] = round($v['amount'], 2);
- }
- $category = array_keys($list);
- $data = array_values($list);
- return [$category, $data];
- }
-
- protected function getArchivesStatisticsData($date = '')
- {
- if ($date) {
- list($start, $end) = explode(' - ', $date);
- $starttime = strtotime($start);
- $endtime = strtotime($end);
- } else {
- $starttime = \fast\Date::unixtime('day', 0, 'begin');
- $endtime = \fast\Date::unixtime('day', 0, 'end');
- }
- $totalseconds = $endtime - $starttime;
- $format = '%Y-%m-%d';
- if ($totalseconds > 86400 * 30 * 2) {
- $format = '%Y-%m';
- } else {
- if ($totalseconds > 86400) {
- $format = '%Y-%m-%d';
- } else {
- $format = '%H:00';
- }
- }
- $model_id = $this->request->post("model_id", "");
- $archivesList = \app\admin\model\cms\Archives::with(["admin"])
- ->where('createtime', 'between time', [$starttime, $endtime])
- ->where(function ($query) use ($model_id) {
- if ($model_id) {
- $query->where('model_id', $model_id);
- }
- })
- ->field('admin_id, createtime, status, COUNT(*) AS nums, MIN(createtime) AS min_createtime, MAX(createtime) AS max_createtime,
- DATE_FORMAT(FROM_UNIXTIME(createtime), "' . $format . '") AS create_date')
- ->group('admin_id,create_date')
- ->select();
- if ($totalseconds > 84600 * 30 * 2) {
- $starttime = strtotime('last month', $starttime);
- while (($starttime = strtotime('next month', $starttime)) <= $endtime) {
- $column[] = date('Y-m', $starttime);
- }
- } else {
- if ($totalseconds > 86400) {
- for ($time = $starttime; $time <= $endtime;) {
- $column[] = date("Y-m-d", $time);
- $time += 86400;
- }
- } else {
- for ($time = $starttime; $time <= $endtime;) {
- $column[] = date("H:00", $time);
- $time += 3600;
- }
- }
- }
- $list = [];
- $dataList = [];
- $columnList = array_fill_keys($column, 0);
- foreach ($archivesList as $k => $v) {
- $nickname = $v->admin ? $v->admin->nickname : "未知";
- if (!isset($list[$nickname])) {
- $list[$nickname] = $columnList;
- }
- $list[$nickname][$v['create_date']] = $v['nums'];
- }
- foreach ($list as $index => $item) {
- $dataList[] = [
- 'name' => $index,
- 'type' => 'line',
- 'smooth' => true,
- 'areaStyle' => [],
- 'data' => array_values($item)
- ];
- }
- $columnList = array_keys($columnList);
- return [$columnList, $dataList];
- }
- }
|