params['device_id'])) { $allowSearch[] = 'device_id'; } return array_intersect(array_keys($this->params), $allowSearch); } public function userSearch(): array { $userWhere['user_id'] = 0; // 超级管理员数据 if ($this->adminInfo['root'] && !$this->adminInfo['user_id']) { unset($userWhere['user_id']); } // 普通用户数据 if (!$this->adminInfo['root'] && $this->adminInfo['user_id']) { $userWhere['user_id'] = $this->adminInfo['user_id']; } return $userWhere; } /** * @notes 获取列表 * @return array * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\DbException * @throws \think\db\exception\ModelNotFoundException * @author likeadmin * @date 2023/11/24 17:02 */ public function lists(): array { return SoilMonitor::withSearch($this->setSearch(), $this->params)->where($this->userSearch())->with('device') ->field(['id', 'device_id', 'temperature', 'moisture', 'conductivity', 'ph', 'n_content', 'p_content', 'k_content', 'create_time']) ->limit($this->limitOffset, $this->limitLength) ->order(['id' => 'desc']) ->select() ->toArray(); } /** * @notes 获取数量 * @return int * @author likeadmin * @date 2023/11/24 17:02 */ public function count(): int { return SoilMonitor::withSearch($this->setSearch(), $this->params)->where($this->userSearch())->count(); } }