Dashboard.php 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. <?php
  2. namespace app\admin\controller;
  3. use app\admin\model\Admin;
  4. use app\admin\model\User;
  5. use app\common\controller\Backend;
  6. use app\common\model\Attachment;
  7. use fast\Date;
  8. use think\Db;
  9. /**
  10. * 控制台
  11. *
  12. * @icon fa fa-dashboard
  13. * @remark 用于展示当前系统中的统计数据、统计报表及重要实时数据
  14. */
  15. class Dashboard extends Backend
  16. {
  17. /**
  18. * 查看
  19. */
  20. public function index()
  21. {
  22. try {
  23. \think\Db::execute("SET @@sql_mode='';");
  24. } catch (\Exception $e) {
  25. }
  26. $column = [];
  27. $starttime = Date::unixtime('day', -6);
  28. $endtime = Date::unixtime('day', 0, 'end');
  29. $joinlist = Db("user")->where('jointime', 'between time', [$starttime, $endtime])
  30. ->field('jointime, status, COUNT(*) AS nums, DATE_FORMAT(FROM_UNIXTIME(jointime), "%Y-%m-%d") AS join_date')
  31. ->group('join_date')
  32. ->select();
  33. for ($time = $starttime; $time <= $endtime;) {
  34. $column[] = date("Y-m-d", $time);
  35. $time += 86400;
  36. }
  37. $userlist = array_fill_keys($column, 0);
  38. foreach ($joinlist as $k => $v) {
  39. $userlist[$v['join_date']] = $v['nums'];
  40. }
  41. $this->view->assign([
  42. 'totaluser' => User::count(),
  43. 'yijidaili' => Db::name('user')->where('group_id',3)->count(),
  44. 'erjidaili' => Db::name('user')->where('group_id',2)->count(),
  45. 'totaladmin' => Admin::count(),
  46. 'todayusersignup' => User::whereTime('jointime', 'today')->count(),
  47. 'todayuserlogin' => User::whereTime('logintime', 'today')->count(),
  48. 'sevendau' => User::whereTime('jointime|logintime', '-7 days')->count(),
  49. 'thirtydau' => User::whereTime('jointime|logintime', '-30 days')->count(),
  50. 'threednu' => User::whereTime('jointime', '-3 days')->count(),
  51. 'sevendnu' => User::whereTime('jointime', '-7 days')->count(),
  52. //今日充值
  53. 'today' => Db::name('pay_order')->where('order_status',1)->where('table_name','gold_recharge')->whereTime('createtime','today')->sum('order_amount'),
  54. //月充值
  55. 'month' => Db::name('pay_order')->where('order_status',1)->where('table_name','gold_recharge')->whereTime('createtime','month')->sum('order_amount'),
  56. //月VIP
  57. 'viptoday' => Db::name('pay_order')->where('order_status',1)->where('table_name','vip_recharge')->whereTime('createtime','today')->sum('order_amount'),
  58. //总共VIP
  59. 'vipmonth' => Db::name('pay_order')->where('order_status',1)->where('table_name','vip_recharge')->whereTime('createtime','month')->sum('order_amount'),
  60. ]);
  61. $this->assignconfig('column', array_keys($userlist));
  62. $this->assignconfig('userdata', array_values($userlist));
  63. return $this->view->fetch();
  64. }
  65. }