123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188 |
- <?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'];
- }
- $dbTableList = Db::query("SHOW TABLE STATUS");
- $addonList = get_addon_list();
- $totalworkingaddon = 0;
- $totaladdon = count($addonList);
- foreach ($addonList as $index => $item) {
- if ($item['state']) {
- $totalworkingaddon += 1;
- }
- }
- $this->view->assign([
- 'totaluser' => User::count(),
- 'totaladdon' => $totaladdon,
- 'totaladmin' => Admin::count(),
- 'totalcategory' => \app\common\model\Category::count(),
- 'todayusersignup' => User::whereTime('jointime', 'today')->count(),
- 'todayuserlogin' => User::whereTime('logintime', 'today')->count(),
- 'sevendau' => User::whereTime('jointime|logintime|prevtime', '-7 days')->count(),
- 'thirtydau' => User::whereTime('jointime|logintime|prevtime', '-30 days')->count(),
- 'threednu' => User::whereTime('jointime', '-3 days')->count(),
- 'sevendnu' => User::whereTime('jointime', '-7 days')->count(),
- 'dbtablenums' => count($dbTableList),
- 'dbsize' => array_sum(array_map(function ($item) {
- return $item['Data_length'] + $item['Index_length'];
- }, $dbTableList)),
- 'totalworkingaddon' => $totalworkingaddon,
- 'attachmentnums' => Attachment::count(),
- 'attachmentsize' => Attachment::sum('filesize'),
- 'picturenums' => Attachment::where('mimetype', 'like', 'image/%')->count(),
- 'picturesize' => Attachment::where('mimetype', 'like', 'image/%')->sum('filesize'),
- ]);
- $this->assignconfig('column', array_keys($userlist));
- $this->assignconfig('userdata', array_values($userlist));
- return $this->view->fetch();
- }
- /**
- * 报表统计
- */
- public function tongji(){
- $starttime = strtotime(date('Y-m-d',strtotime("-7 day"))); //默认7天前
- $endtime = strtotime(date('Y-m-d')) - 1;
- //接收
- $choicedatetime = input('choicedatetime','');
- if(!empty($choicedatetime)){
- $choicedatetime = explode(' - ',$choicedatetime);
- $starttime = strtotime($choicedatetime[0]);
- $endtime = strtotime($choicedatetime[1]) + 86399;
- }
- $this->view->assign('defaultdatetime',date('Y-m-d',$starttime).' - '.date('Y-m-d',$endtime));
- //dump($starttime);
- //dump($endtime);
- //所有应该参加考试的人
- $exam_paper = Db::name('exam_paper')->where('start_time','BETWEEN',[$starttime,$endtime])->where('deletetime',NULL)->column('id,user_ids');
- // dump($exam_paper);
- $new_exam_paper = [];
- foreach($exam_paper as $key => $val){
- $new_exam_paper = array_merge($new_exam_paper,explode(',',$val));
- }
- // dump($new_exam_paper);
- $new_exam_paper = array_count_values($new_exam_paper);
- // dump($new_exam_paper);
- //未通过考试的人
- $nopass = Db::name('exam_grade')->where('paper_id','IN',array_keys($exam_paper))->where('is_pass',0)->column('user_id');
- // dump($nopass);
- $nopass = array_count_values($nopass);
- // dump($nopass);
- //参加考试的人
- $exam_grade = Db::name('exam_grade')->where('paper_id','IN',array_keys($exam_paper))->column('user_id');
- // dump($exam_grade);
- $exam_grade = array_count_values($exam_grade);
- // dump($exam_grade);
- //应该参加培训的人
- $train_active = Db::name('train_active')->where('sign_endtime','BETWEEN',[$starttime,$endtime])->where('deletetime',NULL)->column('id,user_ids');
- // dump($train_active);
- $new_train_active = [];
- foreach($train_active as $key => $val){
- $new_train_active = array_merge($new_train_active,explode(',',$val));
- }
- // dump($new_train_active);
- $new_train_active = array_count_values($new_train_active);
- // dump($new_train_active);
- //参加签到的人
- $user_train = Db::name('user_train')->where('train_id','IN',array_keys($train_active))->column('user_id');
- // dump($user_train);
- $user_train = array_count_values($user_train);
- // dump($user_train);
- //所有用户
- $userlist = Db::name('user')->order('idcard_status desc')->select();
- foreach($userlist as $key => $user){
- $user['realname'] = '';
- if($user['idcard_status'] == 1){
- $user['realname'] = $user['nickname'];
- }
- //应参加考试次数
- $user['paper_count'] = isset($new_exam_paper[$user['id']]) ? $new_exam_paper[$user['id']] : 0;
- //不及格次数
- $user['no_pass'] = isset($nopass[$user['id']]) ? $nopass[$user['id']] : 0;
- //考试次数
- $user['grade_count'] = isset($exam_grade[$user['id']]) ? $exam_grade[$user['id']] : 0;
- //缺考次数
- $user['no_grade'] = $user['paper_count'] - $user['grade_count'];
- if($user['no_grade'] < 0){ $user['no_grade'] = 0;}
- //应该签到的次数
- $user['train_count'] = isset($new_train_active[$user['id']]) ? $new_train_active[$user['id']] : 0;
- //签到的次数
- $user['sign_count'] = isset($user_train[$user['id']]) ? $user_train[$user['id']] : 0;
- //未到的次数
- $user['no_sign'] = $user['train_count'] - $user['sign_count'];
- if($user['no_sign'] < 0){ $user['no_sign'] = 0;}
- //匿名用户
- if($user['idcard_status'] != 1){
- $user['no_pass'] = 0;
- $user['grade_count'] = 0;
- $user['no_grade'] = 0;
- $user['sign_count'] = 0;
- $user['no_sign'] = 0;
- }
- //
- $userlist[$key] = $user;
- }
- $this->assign('datalist',$userlist);
- $this->view->engine->layout(false);
- return $this->view->fetch();
- }
- }
|