1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- <?php
- namespace app\admin\controller;
- use app\admin\model\Admin;
- use app\admin\model\User;
- use app\common\controller\Backend;
- use app\common\model\Attachment;
- use fast\Date;
- use think\Db;
- /**
- * 控制台
- *
- * @icon fa fa-dashboard
- * @remark 用于展示当前系统中的统计数据、统计报表及重要实时数据
- */
- class Dashboard extends Backend
- {
- /**
- * 查看
- */
- public function index()
- {
- try {
- \think\Db::execute("SET @@sql_mode='';");
- } catch (\Exception $e) {
- }
- $column = [];
- $starttime = Date::unixtime('day', -6);
- $endtime = Date::unixtime('day', 0, 'end');
- $joinlist = Db("user")->where('jointime', 'between time', [$starttime, $endtime])
- ->field('jointime, status, COUNT(*) AS nums, DATE_FORMAT(FROM_UNIXTIME(jointime), "%Y-%m-%d") AS join_date')
- ->group('join_date')
- ->select();
- for ($time = $starttime; $time <= $endtime;) {
- $column[] = date("Y-m-d", $time);
- $time += 86400;
- }
- $userlist = array_fill_keys($column, 0);
- foreach ($joinlist as $k => $v) {
- $userlist[$v['join_date']] = $v['nums'];
- }
- $this->view->assign([
- 'totaluser' => User::count(),
- 'yijidaili' => Db::name('user')->where('group_id',3)->count(),
- 'erjidaili' => Db::name('user')->where('group_id',2)->count(),
- 'totaladmin' => Admin::count(),
- 'todayusersignup' => User::whereTime('jointime', 'today')->count(),
- 'todayuserlogin' => User::whereTime('logintime', 'today')->count(),
- 'sevendau' => User::whereTime('jointime|logintime', '-7 days')->count(),
- 'thirtydau' => User::whereTime('jointime|logintime', '-30 days')->count(),
- 'threednu' => User::whereTime('jointime', '-3 days')->count(),
- 'sevendnu' => User::whereTime('jointime', '-7 days')->count(),
- //今日充值
- 'today' => Db::name('pay_order')->where('order_status',1)->where('table_name','gold_recharge')->whereTime('createtime','today')->sum('order_amount'),
- //月充值
- 'month' => Db::name('pay_order')->where('order_status',1)->where('table_name','gold_recharge')->whereTime('createtime','month')->sum('order_amount'),
- //月VIP
- 'viptoday' => Db::name('pay_order')->where('order_status',1)->where('table_name','vip_recharge')->whereTime('createtime','today')->sum('order_amount'),
- //总共VIP
- 'vipmonth' => Db::name('pay_order')->where('order_status',1)->where('table_name','vip_recharge')->whereTime('createtime','month')->sum('order_amount'),
- ]);
- $this->assignconfig('column', array_keys($userlist));
- $this->assignconfig('userdata', array_values($userlist));
- return $this->view->fetch();
- }
- }
|