Db.php 1.92 KB
Newer Older
1
<?php
2 3 4 5 6
/**
 * @link http://www.yiiframework.com/
 * @copyright Copyright (c) 2008 Yii Software LLC
 * @license http://www.yiiframework.com/license/
 */
7 8 9 10 11 12 13

namespace yii\debug\models\search;

use yii\data\ArrayDataProvider;
use yii\debug\components\search\Filter;

/**
14 15 16 17 18
 * Search model for current request database queries.
 *
 * @author Qiang Xue <qiang.xue@gmail.com>
 * @author Mark Jebri <mark.github@yandex.ru>
 * @since 2.0
19 20 21
 */
class Db extends Base
{
22 23 24 25 26 27 28 29
    /**
     * @var string type of the input search value
     */
    public $type;
    /**
     * @var integer query attribute input search value
     */
    public $query;
30

31

32 33 34 35 36 37 38 39 40
    /**
     * @inheritdoc
     */
    public function rules()
    {
        return [
            [['type', 'query'], 'safe'],
        ];
    }
41

42 43 44 45 46 47 48 49 50 51
    /**
     * @inheritdoc
     */
    public function attributeLabels()
    {
        return [
            'type' => 'Type',
            'query' => 'Query',
        ];
    }
52

53 54 55
    /**
     * Returns data provider with filled models. Filter applied if needed.
     *
56 57
     * @param array $params an array of parameter values indexed by parameter names
     * @param array $models data to return provider for
58 59 60 61 62 63 64 65 66 67 68 69 70 71
     * @return \yii\data\ArrayDataProvider
     */
    public function search($params, $models)
    {
        $dataProvider = new ArrayDataProvider([
            'allModels' => $models,
            'pagination' => false,
            'sort' => [
                'attributes' => ['duration', 'seq', 'type', 'query'],
                'defaultOrder' => [
                    'duration' => SORT_DESC,
                ],
            ],
        ]);
72

73 74 75
        if (!($this->load($params) && $this->validate())) {
            return $dataProvider;
        }
76

77 78 79 80
        $filter = new Filter();
        $this->addCondition($filter, 'type', true);
        $this->addCondition($filter, 'query', true);
        $dataProvider->allModels = $filter->filter($models);
81

82 83
        return $dataProvider;
    }
84
}