コード例 #1
0
ファイル: Menu.php プロジェクト: hornetalcala/yii2-admin
 /**
  * Searching menu
  * @param  array $params
  * @return \yii\data\ActiveDataProvider
  */
 public function search($params)
 {
     $query = MenuModel::find()->from(MenuModel::tableName() . ' t')->joinWith(['menuParent' => function ($q) {
         $q->from(MenuModel::tableName() . ' parent');
     }]);
     $dataProvider = new ActiveDataProvider(['query' => $query]);
     $sort = $dataProvider->getSort();
     $sort->attributes['menuParent.name'] = ['asc' => ['parent.name' => SORT_ASC], 'desc' => ['parent.name' => SORT_DESC], 'label' => 'parent'];
     $sort->attributes['order'] = ['asc' => ['parent.order' => SORT_ASC, 't.order' => SORT_ASC], 'desc' => ['parent.order' => SORT_DESC, 't.order' => SORT_DESC], 'label' => 'order'];
     $sort->defaultOrder = ['menuParent.name' => SORT_ASC];
     if (!($this->load($params) && $this->validate())) {
         return $dataProvider;
     }
     $query->andFilterWhere(['t.id' => $this->id, 't.parent' => $this->parent]);
     $query->andFilterWhere(['like', 'lower(t.name)', strtolower($this->name)])->andFilterWhere(['like', 't.route', $this->route])->andFilterWhere(['like', 'lower(parent.name)', strtolower($this->parent_name)]);
     return $dataProvider;
 }