|
|
<?php
|
|
|
|
|
|
|
|
|
namespace app\admin\controller;
|
|
|
|
|
|
use app\admin\model\AuthGroupAccess;
|
|
|
use app\admin\model\User;
|
|
|
use app\common\controller\Backend;
|
|
|
use think\Db;
|
|
|
use think\Session;
|
|
|
|
|
|
/**
|
|
|
* 统计
|
|
|
*
|
|
|
* @icon fa fa-circle-o
|
|
|
*/
|
|
|
class Statistics extends Backend
|
|
|
{
|
|
|
|
|
|
protected $model = null;
|
|
|
|
|
|
public function _initialize()
|
|
|
{
|
|
|
parent::_initialize();
|
|
|
$this->model = new \app\admin\model\Admin;
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
|
|
|
* 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
|
|
|
* 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
|
|
|
*/
|
|
|
|
|
|
|
|
|
/**
|
|
|
* 查看
|
|
|
*/
|
|
|
public function index()
|
|
|
{
|
|
|
$admin = Session::get('admin');
|
|
|
$auth_group_access = new AuthGroupAccess();
|
|
|
$group_id = $auth_group_access->where('uid',$admin['id'])->value('group_id');
|
|
|
//当前是否为关联查询
|
|
|
$this->relationSearch = true;
|
|
|
//设置过滤方法
|
|
|
$this->request->filter(['strip_tags']);
|
|
|
if ($this->request->isAjax())
|
|
|
{
|
|
|
//如果发送的来源是Selectpage,则转发到Selectpage
|
|
|
if ($this->request->request('keyField'))
|
|
|
{
|
|
|
return $this->selectpage();
|
|
|
}
|
|
|
$map = [
|
|
|
'AuthGroupAccess.group_id' => 2
|
|
|
];
|
|
|
if($group_id == 2) {
|
|
|
$map['admin.id'] = $admin['id'];
|
|
|
}
|
|
|
list($where, $sort, $order, $offset, $limit) = $this->buildparams();
|
|
|
$total = $this->model
|
|
|
->with(['auth_group_access'])
|
|
|
->where($map)
|
|
|
->order($sort, $order)
|
|
|
->count();
|
|
|
|
|
|
$list = $this->model
|
|
|
->with(['auth_group_access'])
|
|
|
->where($map)
|
|
|
->order($sort, $order)
|
|
|
->limit($offset, $limit)
|
|
|
->select();
|
|
|
|
|
|
$list = collection($list)->toArray();
|
|
|
// 查询时间处理
|
|
|
$filter = $this->request->get("filter", '');
|
|
|
$filter = (array)json_decode($filter, true);
|
|
|
$filter = $filter ? $filter : [];
|
|
|
$array = [];
|
|
|
if($filter) {
|
|
|
$array = explode(' - ',$filter['time']);
|
|
|
foreach ($array as $k=>$v) {
|
|
|
$array[$k] = strtotime($v);
|
|
|
}
|
|
|
}
|
|
|
foreach ($list as $k=>$v) {
|
|
|
// 查询应用
|
|
|
$api_names = Db::name('api')->where('customer_id',$v['id'])->column('name');
|
|
|
$list[$k]['api_name'] = $api_names ? implode(',',$api_names) : '-';
|
|
|
// 查询设备数
|
|
|
$equipment_where = [
|
|
|
'customer_id' => $v['id']
|
|
|
];
|
|
|
if($array) {
|
|
|
$equipment_where['createtime'] = ['between',$array];
|
|
|
}
|
|
|
$list[$k]['equipment'] = Db::name('equipment')->where($equipment_where)->count();
|
|
|
// 查询数板次数
|
|
|
$equipment_count_where = [
|
|
|
'customer_id' => $v['id']
|
|
|
];
|
|
|
if($array) {
|
|
|
$equipment_count_where['createtime'] = ['between',$array];
|
|
|
}
|
|
|
$list[$k]['equipment_count'] = Db::name('equipment_log')->where($equipment_count_where)->count();
|
|
|
// 查询数管次数
|
|
|
$shuguan_count_where = [
|
|
|
's.customer_id' => $v['id']
|
|
|
];
|
|
|
if($array) {
|
|
|
$shuguan_count_where['s.createtime'] = ['between',$array];
|
|
|
}
|
|
|
$list[$k]['shuguan_count'] = Db::name('shuguan')->alias('s')
|
|
|
->join('__SHUGUAN_LOG__ sl','s.id=sl.shuguan_id')
|
|
|
->where($shuguan_count_where)->count();
|
|
|
}
|
|
|
$result = array("total" => $total, "rows" => $list);
|
|
|
|
|
|
return json($result);
|
|
|
}
|
|
|
return $this->view->fetch();
|
|
|
}
|
|
|
} |
|
|
\ No newline at end of file |
...
|
...
|
|