Dashboard.php 4.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. <?php
  2. namespace app\admin\controller;
  3. use app\admin\model\Admin;
  4. use app\admin\model\User;
  5. use app\common\model\OfflineRechargeRecordModel;
  6. use app\common\model\OfflineWithdrawRecordModel;
  7. use app\admin\model\LedgerTokenChange;
  8. use app\common\controller\Backend;
  9. use app\common\model\Attachment;
  10. use fast\Date;
  11. use Google\Service\Books\Offers;
  12. use think\Db;
  13. /**
  14. * 控制台
  15. *
  16. * @icon fa fa-dashboard
  17. * @remark 用于展示当前系统中的统计数据、统计报表及重要实时数据
  18. */
  19. class Dashboard extends Backend
  20. {
  21. /**
  22. * 查看
  23. */
  24. public function index()
  25. {
  26. try {
  27. \think\Db::execute("SET @@sql_mode='';");
  28. } catch (\Exception $e) {
  29. }
  30. $column = [];
  31. $starttime = Date::unixtime('day', -6);
  32. $endtime = Date::unixtime('day', 0, 'end');
  33. $today_time = strtotime(date('Y-m-d'));
  34. $yestoday_date = [$today_time - 86400, $today_time];
  35. $joinlist = Db("user")->where('create_time', 'between time', [$starttime, $endtime])
  36. ->field('create_time, COUNT(*) AS nums, DATE_FORMAT(FROM_UNIXTIME(create_time), "%Y-%m-%d") AS join_date')
  37. ->group('join_date')
  38. ->select();
  39. for ($time = $starttime; $time <= $endtime;) {
  40. $column[] = date("Y-m-d", $time);
  41. $time += 86400;
  42. }
  43. $userlist = array_fill_keys($column, 0);
  44. foreach ($joinlist as $k => $v) {
  45. $userlist[$v['join_date']] = $v['nums'];
  46. }
  47. $month_date = date('Y-m-') . '1';
  48. $this->view->assign([
  49. 'totaluser' => User::count(),
  50. 'validuser' => User::where('effective_time', '>', 0)->count(),
  51. 'totaladmin' => Admin::count(),
  52. 'totalcategory' => \app\common\model\Category::count(),
  53. 'todayusersignup' => User::whereTime('create_time', 'today')->count(),
  54. 'threednu' => User::whereTime('create_time', '-3 days')->count(),
  55. 'sevendnu' => User::whereTime('create_time', '-7 days')->count(),
  56. 'yestoday_usdt' => OfflineRechargeRecordModel::whereBetween('create_time', $yestoday_date)->where('status', OfflineRechargeRecordModel::StatusSuccess)->sum('amount'),
  57. 'yestoday_usdt_num' => OfflineRechargeRecordModel::whereBetween('create_time', $yestoday_date)->where('status', OfflineRechargeRecordModel::StatusSuccess)->count(),
  58. 'yestoday_out' => OfflineWithdrawRecordModel::whereBetween('create_time', $yestoday_date)->sum('amount'),
  59. 'yestoday_out_num' => OfflineWithdrawRecordModel::whereBetween('create_time', $yestoday_date)->count(),
  60. 'pending_num' => OfflineWithdrawRecordModel::where('status', OfflineRechargeRecordModel::StatusDefault)->count(), //待处理
  61. 'all_in_usdt' => OfflineRechargeRecordModel::where('status', OfflineRechargeRecordModel::StatusSuccess)->sum('amount'),
  62. 'all_in_usdt_num' => OfflineRechargeRecordModel::where('status', OfflineRechargeRecordModel::StatusSuccess)->count(),
  63. 'all_out_usdt' => OfflineWithdrawRecordModel::where('status', 'in', [2,4])->sum('real_amount'),
  64. //'all_in-out' => OfflineRechargeRecord::where('status', 'in', [2,4])->count(),
  65. 'month_in_usdt' => OfflineRechargeRecordModel::where('create_time', '>', strtotime($month_date))->where('status', OfflineRechargeRecordModel::StatusSuccess)->sum('amount'),
  66. 'attachmentsize' => 0,
  67. 'picturenums' => 0,
  68. 'picturesize' => 0,
  69. // 'attachmentnums' => Attachment::count(),
  70. // 'attachmentsize' => Attachment::sum('filesize'),
  71. // 'picturenums' => Attachment::where('mimetype', 'like', 'image/%')->count(),
  72. // 'picturesize' => Attachment::where('mimetype', 'like', 'image/%')->sum('filesize'),
  73. ]);
  74. $this->assignconfig('column', array_keys($userlist));
  75. $this->assignconfig('userdata', array_values($userlist));
  76. return $this->view->fetch();
  77. }
  78. }