140 lines
3.7 KiB
PHP
140 lines
3.7 KiB
PHP
<?php
|
||
|
||
namespace app\admin\controller\oa;
|
||
|
||
use app\common\controller\Backend;
|
||
use think\Db;
|
||
|
||
/**
|
||
* 排班
|
||
*
|
||
* @icon fa fa-circle-o
|
||
*/
|
||
class Schedule extends Backend
|
||
{
|
||
|
||
/**
|
||
* Schedule模型对象
|
||
* @var \app\admin\model\oa\Schedule
|
||
*/
|
||
protected $model = null;
|
||
|
||
public function _initialize()
|
||
{
|
||
parent::_initialize();
|
||
$this->model = new \app\admin\model\oa\Schedule;
|
||
$this->view->assign("typeList", $this->model->getTypeList());
|
||
}
|
||
|
||
|
||
|
||
/**
|
||
* 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
|
||
* 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
|
||
* 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
|
||
*/
|
||
|
||
|
||
/**
|
||
* 查看
|
||
*/
|
||
public function index()
|
||
{
|
||
//当前是否为关联查询
|
||
$this->relationSearch = true;
|
||
//设置过滤方法
|
||
$this->request->filter(['strip_tags', 'trim']);
|
||
if ($this->request->isAjax()) {
|
||
//如果发送的来源是Selectpage,则转发到Selectpage
|
||
if ($this->request->request('keyField')) {
|
||
return $this->selectpage();
|
||
}
|
||
list($where, $sort, $order, $offset, $limit) = $this->buildparams();
|
||
|
||
$list = $this->model
|
||
->with(['admin'])
|
||
->where($where)
|
||
->order($sort, $order)
|
||
->paginate($limit);
|
||
|
||
foreach ($list as $row) {
|
||
|
||
|
||
}
|
||
|
||
$result = array("total" => $list->total(), "rows" => $list->items());
|
||
|
||
return json($result);
|
||
}
|
||
return $this->view->fetch();
|
||
}
|
||
|
||
public function custom_index()
|
||
{
|
||
//当前是否为关联查询
|
||
$this->relationSearch = true;
|
||
//设置过滤方法
|
||
$this->request->filter(['strip_tags', 'trim']);
|
||
if ($this->request->isAjax()) {
|
||
|
||
|
||
$startDate = '2025-02-22';
|
||
$endDate = '2025-03-22';
|
||
|
||
$res = [];
|
||
$admins = Db::name('admin')->field('id,nickname')->select();
|
||
$admins = array_column($admins, NULL, 'id');
|
||
$adminIds = array_keys($admins);
|
||
|
||
$adminNames = array_column($admins, 'nickname', 'id');
|
||
|
||
$tmpDate = $startDate;
|
||
$dates = [];
|
||
while(true) {
|
||
|
||
if ($tmpDate > $endDate) {
|
||
break;
|
||
}
|
||
|
||
foreach ($adminIds as $adminId) {
|
||
$res[$adminId][$tmpDate] = '无';
|
||
$res[$adminId]['name'] = $adminNames[$adminId];
|
||
}
|
||
|
||
$dates[] = $tmpDate;
|
||
$tmpDate = date('Y-m-d', strtotime($tmpDate) + 86400);
|
||
}
|
||
|
||
$queryData = $this->model
|
||
->with([
|
||
'admin'
|
||
])
|
||
->where('date', '>=', $startDate)
|
||
->where('date', '<=', $endDate)
|
||
->select();
|
||
foreach ($queryData as $queryDatum) {
|
||
$queryDatum = $queryDatum->toArray();
|
||
|
||
$adminId = $queryDatum['admin']['id'];
|
||
$date = $queryDatum['date'];
|
||
$type = $queryDatum['type'];
|
||
|
||
if (isset($res[$adminId][$date])) {
|
||
$res[$adminId][$date] = $this->model->getTypeList()[$type];
|
||
}
|
||
}
|
||
|
||
|
||
$res = array_values($res);
|
||
|
||
|
||
$result = array("total" => count($res), "rows" => $res);
|
||
|
||
return json($result);
|
||
}
|
||
|
||
return $this->view->fetch();
|
||
}
|
||
|
||
}
|