YII gridview фильтр не работает - PullRequest
0 голосов
/ 16 мая 2018

Я полностью потерял в фильтре Yii gridview. На странице просмотра есть сетка, которая является студентом / представлением.

Вот контроллер от StudentController:

/**
 * Displays a particular model.
 * @param integer $id the ID of the model to be displayed
 */
public function actionView($id) {
    $this->layout = "//layouts/column1";
    $this->render('view', array(
        'model' => $this->loadModel($id),
    ));
}

Но! Я хочу показать и отфильтровать часы данного учащегося в виде сетки из модели ЧАС (а не модели учащегося). Итак, вот часть файла представления:

<?php
$hour = new Hour();
$hour->student_id = $model->id;
$hour->time_start = $startDate;

$hour->time_end = $endDate;
?>
<?php
$this->widget('bootstrap.widgets.BsGridView', array(
    'id' => 'hour-grid',
//  'dataProvider' => $hourModel->StudentHoursSearch($model->id),
    'dataProvider' => $hour->search(),
    'filter'=>$hour,
    'columns' => array(
        //'student_id',
        array(
            'name' => 'instructor_id',
            'value' => '$data->instructor->name',
            'filter'=>CHtml::listData(Instructor::model()->findAll(), 'id', 'name'),
        ),
        array(
            'name' => 'time_start',
            'value' => 'date("Y-m-d", strtotime($data->time_start))."<br />".date("H:i", strtotime($data->time_start))',
            'type' => 'html',
        ),
        'hour_topic',
        array(
            'name' => 'type',
            'type' => 'html',
            'value' => '$data->ticket_lease == "lease" ? $data->getTypeLabel() : ($data->ticket_lease == "ticket" ? $data->getTypeLabel() . " (jegy)" : ($data->cancel_type == 3 ? $data->getTypeLabel() . "<br />DK lemondás" : (date("Y-m-d", strtotime($data->time_start)) == date("Y-m-d") ? $data->getTypeLabel() : $data->getTypeLabel() . " <br/>Nincs lezárva")))',
            'filter' => Hour::$type_labels
        ),
    /* array(
      'name' => 'hour_topic',
      'value'=>'$data->hour_topic'
      ), */
    ),
    'rowCssClassExpression' => '                    
        $data->cancel_type == 3 ? "drumkiller_cancel" : ($data->type === "presenter" ? "student_presenter" : ($data->type === "training" ? "student_training" : "student_practice"))                    
    ',
));
?>

Это показывает все часы ученика очень хорошо, но функции фильтрации не работают.

введите описание изображения здесь

Я хочу использовать два раскрывающихся фильтра, но ни один из них не работает.

Вот модель часов:

/**
 * Retrieves a list of models based on the current search/filter conditions.
 * @return CActiveDataProvider the data provider that can return the models based on the search/filter conditions.
 */
public function search() {
    // Warning: Please modify the following code to remove attributes that
    // should not be searched.

    $criteria = new CDbCriteria;

    $criteria->with = array(
        'instructor',
        'student',
        // 'drumKit',
        'leaseOrder',
    );

    $criteria->compare('t.id', $this->id);
    $criteria->compare('t.instructor_id', $this->instructor_id);
    $criteria->compare('t.student_id', $this->student_id, true);
    // $criteria->compare('t.drum_kit_id', $this->drum_kit_id);
    $criteria->compare('t.lease_order_id', $this->lease_order_id);
    $criteria->compare('t.price', $this->price);
    $criteria->compare('t.type', $this->type, true);
    $criteria->compare('t.create_time', $this->create_time, true);
    $criteria->compare('t.hour_topic', $this->hour_topic, true);
    if (isset($_GET['time_start']) || isset($_GET['time_end'])) {
        $criteria->compare('t.time_start', '>=' . date('Y-m-d', strtotime($_GET['time_strat'])));
        $criteria->compare('t.time_end', '<=' . date('Y-m-d', strtotime($_GET['time_end'])));
    } else {

        if ($this->time_start && $this->time_end) {
            $criteria->compare('t.time_start', '>=' . $this->time_start);
            $criteria->compare('t.time_end', '<=' . $this->time_end);
        } else {
            $criteria->compare('t.time_start', $this->time_start, true);
            $criteria->compare('t.time_end', $this->time_end, true);
        }
    }
//  $criteria->compare('cancel_type', array(0,3));
    $criteria->compare('cancel_type', $this->cancel_type, true);
    $criteria->addInCondition('cancel_type',array(0,3)); 


    return new CActiveDataProvider($this, array(
        'criteria' => $criteria,
        'sort' => array(
            'defaultOrder' => 't.time_start DESC',
        ),
    ));
}

Кто-нибудь может мне помочь, пожалуйста?

1 Ответ

0 голосов
/ 16 мая 2018

Возможно, вам нужно передать класс Hour из контроллера вместо представления, а затем обязательно установить атрибуты из параметров GET, которые будет запускать gridview.

Может быть, что-то вроде этого:

public function actionView($id) {
    $this->layout = "//layouts/column1";

    $hour = new Hour('search');
    $hour->unsetAttributes();  // clear any default values
    if (isset($_GET['Hour'])) {
        $hour->attributes = $_GET['Hour'];
    }

    $this->render('view', array(
        'model' => $this->loadModel($id),
        'hour' => $hour,
    ));
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...