Виджеты данных, фильтрующие данные Yii2

Я использую виджет данных с pjux и мне нужно отсортировать дату. Я пытался использовать это http://www.yiiframework.com/doc-2.0/guide-output-data-widgets.html. Но есть проблемы с фильтрацией.
Мой сайтКонтроллер

$PostView = Posts::findOne($id);
$model = new Comments();

if ($model->load(Yii::$app->request->post()) && $model->validate()) {
$model->user_id = Yii::$app->user->getId();
$model->post_id = $id;

if ($model->save()):
$model = new Comments();
Yii::$app->session->setFlash('success', "OK");
else: Yii::$app->session->setFlash('error', "NOT");
Yii::error('Some error');
return $this->refresh();
endif;

} else {
$searchModel = new CommentsSearch();
$dataProvider = $searchModel->search(Yii::$app->request->queryParams);
return $this->render('view', [
'PostView' => $PostView,
'searchModel' => $searchModel,
'dataProvider' => $dataProvider,
'model' => $model,
]);
}

В моем контроллере поиска

$query->andFilterWhere([
'id' => $this->id,
'post_id' => $this->post_id,
'user_id' => $this->user_id,
'created_at' => $this->created_at,
'updated_at' => $this->updated_at,
]);

$query->andFilterWhere(['like', 'comment', $this->comment]);

return $dataProvider;

Ввиду:

<?php Pjax::begin(['id' => 'comments']) ?>
<?= GridView::widget([
'dataProvider' => $dataProvider,
'filterModel' => $searchModel,
'columns' => [
['class' => 'yii\grid\SerialColumn'],
'post_id',
'comment:ntext',
],
]); ?>
<?php Pjax::end() ?>

Кроме того, если я изменю 'post_id' => $this->post_id, на 'post_id' => '1', фильтрация работает. Помогите, пожалуйста.

0

Решение

Возможно, вы забыли включить ваши атрибуты в «безопасный» массив в методе $ model-> rules ().

[['post_id'], 'safe'],

Пробовать

var_dump($this->post_id);

после «$ this-> load ($ params)» в вашей поисковой модели, чтобы увидеть, что там.

0

Другие решения

Других решений пока нет …

По вопросам рекламы ammmcru@yandex.ru
Adblock
detector