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; } } $today = [ (new Carbon())->now()->startOfDay(), (new Carbon())->now()->endOfDay(), ]; $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'), 'new_order_count' => model('order') ->whereBetween('create_time',$today) ->where('admin_id',$this->auth->id)->count(), 'dispatch_order_count' => model('order_dispatch') ->whereBetween('create_time',$today) ->where('admin_id',$this->auth->id) ->count(), 'doing_order_count' => model('order_dispatch') ->whereBetween('create_time',$today) ->where('status','>=',\app\admin\model\Order::STATUS_DRAFT) ->where('admin_id',$this->auth->id)->count(), 'ending_order_count' => model('order_dispatch') ->whereBetween('create_time',$today) ->where('status','=',\app\admin\model\Order::STATUS_FINISHED) ->where('admin_id',$this->auth->id)->count(), ]); $this->assignconfig('column', array_keys($userlist)); $this->assignconfig('userdata', array_values($userlist)); return $this->view->fetch(); } public function task() { $dayTasks = (new Task()) ->where('exec_admin_id','=',$this->auth->id) ->where('type','=',1) ->select(); $weekTasks = (new Task()) ->where('exec_admin_id','=',$this->auth->id) ->where('type','=',2) ->select(); $monthTasks = (new Task()) ->where('exec_admin_id','=',$this->auth->id) ->where('type','=',3) ->select(); $this->view->assign('day', $dayTasks); $this->view->assign('week', $weekTasks); $this->view->assign('month', $monthTasks); return $this->view->fetch(); } public function kpi() { $groupIds = $this->auth->getGroupIds(); $groupId = $groupIds[0] ?? 0; $kpiTemplate = (new Template()) ->where('group_id','=', 6) ->with('kpiitem') ->find(); $kpiItems = $kpiTemplate['kpiitem']; $this->view->assign('kpi_template', $kpiTemplate); $this->view->assign('kpi_items', $kpiItems); return $this->view->fetch(); } public function task_complete($ids = null) { $row = (new Task())->get($ids); if (!$row) { $this->error(__('No Results were found')); } if (false === $this->request->isPost()) { $this->view->assign('row', $row); return $this->view->fetch(); } $params = $this->request->post('row/a'); $task = (new Task())->where('id', '=', $ids)->where('status', 1)->find(); if (!$task) { $this->error('任务状态已变更,请刷新后操作'); } $task->save(['status' => 3, 'prove_file_path' => $params['prove_file_path']]); $this->success(); } }