allocatr/application/admin/controller/Dashboard.php
2025-05-27 11:11:06 +08:00

184 lines
6.1 KiB
PHP
Executable File

<?php
namespace app\admin\controller;
use app\admin\model\Admin;
use app\admin\model\kpi\Template;
use app\admin\model\oa\Task;
use app\admin\model\User;
use app\common\controller\Backend;
use app\common\model\Attachment;
use Carbon\Carbon;
use fast\Date;
use think\Db;
use function Symfony\Component\Clock\now;
/**
* 控制台
*
* @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;
}
}
$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','=', $groupId)
->with('kpiitem')
->find();
if (!$kpiTemplate) {
$this->error('kpi模板未找到');
}
$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)->whereIn('status', [1, 5])->find();
if (!$task) {
$this->error('任务状态已变更,请刷新后操作');
}
$task->save(['status' => 3, 'prove_desc' => $params['prove_desc'], 'prove_file_path' => $params['prove_file_path']]);
$this->success();
}
}