12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
- <?php
- namespace app\models;
- use yii\base\Model;
- use yii\data\ActiveDataProvider;
- use app\models\Authors;
- /**
- * AuthorsSearch represents the model behind the search form of `app\models\Authors`.
- */
- class AuthorsSearch extends Authors
- {
- /**
- * {@inheritdoc}
- */
- public function rules()
- {
- return [
- [['id'], 'integer'],
- [['uid', 'name', 'url', 'jobTitle', 'phone', 'active'], 'safe'],
- ];
- }
- /**
- * {@inheritdoc}
- */
- public function scenarios()
- {
- // bypass scenarios() implementation in the parent class
- return Model::scenarios();
- }
- /**
- * Creates data provider instance with search query applied
- *
- * @param array $params
- *
- * @return ActiveDataProvider
- */
- public function search($params)
- {
- $query = Authors::find();
- // add conditions that should always apply here
- $dataProvider = new ActiveDataProvider([
- 'query' => $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;
- }
- // grid filtering conditions
- $query->andFilterWhere([
- 'id' => $this->id,
- ]);
- $query->andFilterWhere(['like', 'uid', $this->uid])
- ->andFilterWhere(['like', 'name', $this->name])
- ->andFilterWhere(['like', 'url', $this->url])
- ->andFilterWhere(['like', 'jobTitle', $this->jobTitle])
- ->andFilterWhere(['like', 'phone', $this->phone])
- ->andFilterWhere(['like', 'active', $this->active]);
- return $dataProvider;
- }
- }
|