common/models/search/PostType.php
<?php
/**
* @link http://www.writesdown.com/
* @copyright Copyright (c) 2015 WritesDown
* @license http://www.writesdown.com/license/
*/
namespace common\models\search;
use common\models\PostType as PostTypeModel;
use Yii;
use yii\base\Model;
use yii\data\ActiveDataProvider;
/**
* PostType represents the model behind the search form about `common\models\PostType`.
*
* @author Agiel K. Saputra <13nightevil@gmail.com>
* @since 0.1.0
*/
class PostType extends PostTypeModel
{
/**
* @inheritdoc
*/
public function rules()
{
return [
[['id', 'menu_builder'], 'integer'],
[['name', 'slug', 'description', 'icon', 'singular_name', 'plural_name', 'permission'], '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 = PostTypeModel::find();
$dataProvider = new ActiveDataProvider([
'query' => $query,
'sort' => ['defaultOrder' => ['id' => SORT_DESC]],
]);
$this->load($params);
if (!$this->validate()) {
return $dataProvider;
}
$query->andFilterWhere([
'id' => $this->id,
'menu_builder' => $this->menu_builder,
]);
$query->andFilterWhere(['like', 'name', $this->name])
->andFilterWhere(['like', 'slug', $this->slug])
->andFilterWhere(['like', 'description', $this->description])
->andFilterWhere(['like', 'icon', $this->icon])
->andFilterWhere(['like', 'singular_name', $this->singular_name])
->andFilterWhere(['like', 'plural_name', $this->plural_name])
->andFilterWhere(['like', 'permission', $this->permission]);
return $dataProvider;
}
}