$query, ]); $this->load($params); if (!$this->validate()) { // uncomment the following line if you do not want to return any records when validation fails // $query->where('0=1'); return $dataProvider; } if ($this->department_id) { $m = new Department(); $departmentChild = $m->departmentChilds($this->department_id); $query->andFilterWhere(["IN", "department_id", $departmentChild]); } // grid filtering conditions $query->andFilterWhere([ 'id' => $this->id, 'card_number' => $this->card_number, 'birthday' => $this->birthday, 'date_in' => $this->date_in, 'created_at' => $this->created_at, 'modified_at' => $this->modified_at, ]); $query->andFilterWhere(['like', 'name', $this->name]) ->andFilterWhere(['like', 'gender', $this->gender]) ->andFilterWhere(['like', 'email', $this->email]) ->andFilterWhere(['like', 'phone', $this->phone]) ->andFilterWhere(['like', 'code', $this->code]) ->andFilterWhere(['like', 'address', $this->address]); return $dataProvider; } }