model = new \app\admin\model\institution\Depart(); } /** * 模板列表 */ public function index() { //设置过滤方法 $this->request->filter(['strip_tags']); return $this->view->fetch(); } /** * 机构列表 * @return string|\think\response\Json * @throws \think\Exception * @author matielong */ public function institutionIndex() { //设置过滤方法 $this->request->filter(['strip_tags']); if ($this->request->isAjax()) { list($where, $sort, $order, $offset, $limit) = $this->buildparams(['name']); // 过滤机构 $childInsIds = $this->auth->getMyInsId(); if($childInsIds == false){ $more = false; } else { $more = ['id' => ['in', $childInsIds]]; } $field = ['id', 'name', 'createdAt']; $myWhere = ['status' => '1']; $total = model('Institution','model\institution') ->where($more) ->where($where) ->where($myWhere) ->order($sort, $order) ->count(); $list = model('Institution','model\institution') ->where($more) ->where($where) ->where($myWhere) ->order($sort, $order) ->limit($offset, $limit) ->field($field) ->select(); $list = collection($list)->toArray(); $result = array("total" => $total, "rows" => $list); return json($result); } return $this->view->fetch(); } /** * 科室列表 * @return string|\think\response\Json * @throws Exception * @author matielong */ public function departmentIndex() { $ins_id = $this->request->param('ins_id'); //设置过滤方法 $this->request->filter(['strip_tags']); if ($this->request->isAjax()) { list($where, $sort, $order, $offset, $limit) = $this->buildparams($this->searchFields, true); $myWhere = ['institution_id' => $ins_id,]; $total = $this->model ->where($where) ->where($myWhere) ->order($sort, $order) ->count(); $list = $this->model ->where($where) ->where($myWhere) ->order($sort, $order) ->limit($offset, $limit) ->select(); $list = collection($list)->toArray(); $result = array("total" => $total, "rows" => $list); return json($result); } return $this->view->fetch(); } /** * 添加 * @return string * @throws Exception * @author matielong */ public function add() { $ins_id = $this->request->param('ids'); if ($this->request->isPost()) { $params = $this->request->post("row/a"); if ($params) { $params = $this->preExcludeFields($params); if ($this->dataLimit && $this->dataLimitFieldAutoFill) { $params[$this->dataLimitField] = $this->auth->id; } $result = false; Db::startTrans(); try { //是否采用模型验证 if ($this->modelValidate) { $name = str_replace("\\model\\", "\\validate\\", get_class($this->model)); $validate = is_bool($this->modelValidate) ? ($this->modelSceneValidate ? $name . '.add' : $name) : $this->modelValidate; $this->model->validateFailException(true)->validate($validate); } $params['id'] = makeNew16Uid(); $params['institution_id'] = $ins_id; $params['parent_id'] = 'root'; $result = $this->model->allowField(true)->save($params); Db::commit(); } catch (ValidateException $e) { Db::rollback(); $this->error($e->getMessage()); } catch (PDOException $e) { Db::rollback(); $this->error($e->getMessage()); } catch (Exception $e) { Db::rollback(); $this->error($e->getMessage()); } if ($result !== false) { $this->success(); } else { $this->error(__('No rows were inserted')); } } $this->error(__('Parameter %s can not be empty', '')); } return $this->view->fetch(); } }