Blame view

common/models/SeoDynamicSearch.php 3.55 KB
d8c1a2e0   Yarik   Big commit artbox
1
  <?php
d55d2fe0   Yarik   Multilanguage
2
      
93c267f7   Yarik   Multilanguage big...
3
4
5
6
      namespace common\models;
      
      use yii\base\Model;
      use yii\data\ActiveDataProvider;
d55d2fe0   Yarik   Multilanguage
7
      
d8c1a2e0   Yarik   Big commit artbox
8
      /**
93c267f7   Yarik   Multilanguage big...
9
10
       * SeoDynamicSearch represents the model behind the search form about
       * `common\models\SeoDynamic`.
d8c1a2e0   Yarik   Big commit artbox
11
       */
93c267f7   Yarik   Multilanguage big...
12
      class SeoDynamicSearch extends SeoDynamic
d8c1a2e0   Yarik   Big commit artbox
13
      {
93c267f7   Yarik   Multilanguage big...
14
          
21aedefe   Yarik   Another one admin...
15
16
          public $name;
          
93c267f7   Yarik   Multilanguage big...
17
18
19
20
21
22
23
24
25
26
27
28
29
30
          public function behaviors()
          {
              return [];
          }
          
          /**
           * @inheritdoc
           */
          public function rules()
          {
              return [
                  [
                      [
                          'seo_dynamic_id',
93c267f7   Yarik   Multilanguage big...
31
32
33
34
35
36
37
38
                          'status',
                      ],
                      'integer',
                  ],
                  [
                      [
                          'action',
                          'fields',
21aedefe   Yarik   Another one admin...
39
40
                          'name',
                          'param',
93c267f7   Yarik   Multilanguage big...
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
                      ],
                      'safe',
                  ],
              ];
          }
          
          /**
           * @inheritdoc
           */
          public function scenarios()
          {
              // bypass scenarios() implementation in the parent class
              return Model::scenarios();
          }
          
          /**
           * Creates data provider instance with search query applied
           *
21aedefe   Yarik   Another one admin...
59
60
           * @param integer $seo_category_id
           * @param array   $params
93c267f7   Yarik   Multilanguage big...
61
62
63
64
65
           *
           * @return ActiveDataProvider
           */
          public function search($seo_category_id, $params)
          {
21aedefe   Yarik   Another one admin...
66
67
              $query = SeoDynamic::find()
                                 ->joinWith('lang');
93c267f7   Yarik   Multilanguage big...
68
69
70
71
72
              
              // add conditions that should always apply here
              
              $dataProvider = new ActiveDataProvider([
                  'query' => $query,
21aedefe   Yarik   Another one admin...
73
74
75
76
77
78
79
80
81
82
83
84
85
                  'sort'  => [
                      'attributes' => [
                          'seo_dynamic_id',
                          'action',
                          'fields',
                          'status',
                          'param',
                          'name' => [
                              'asc'  => [ 'seo_dynamic_lang.name' => SORT_ASC ],
                              'desc' => [ 'seo_dynamic_lang.name' => SORT_DESC ],
                          ],
                      ],
                  ],
93c267f7   Yarik   Multilanguage big...
86
87
88
89
90
91
92
93
94
95
96
              ]);
              
              $this->load($params);
              
              if(!$this->validate()) {
                  // uncomment the following line if you do not want to return any records when validation fails
                  // $query->where('0=1');
                  return $dataProvider;
              }
              
              // grid filtering conditions
21aedefe   Yarik   Another one admin...
97
              $query->andWhere([
93c267f7   Yarik   Multilanguage big...
98
                  'seo_category_id' => $seo_category_id,
21aedefe   Yarik   Another one admin...
99
100
101
102
103
              ])
                    ->andFilterWhere([
                        'seo_dynamic_id' => $this->seo_dynamic_id,
                        'status'         => $this->status,
                    ]);
93c267f7   Yarik   Multilanguage big...
104
105
              
              $query->andFilterWhere([
21aedefe   Yarik   Another one admin...
106
107
108
109
                  'ilike',
                  'action',
                  $this->action,
              ])
93c267f7   Yarik   Multilanguage big...
110
                    ->andFilterWhere([
21aedefe   Yarik   Another one admin...
111
                        'ilike',
93c267f7   Yarik   Multilanguage big...
112
113
                        'fields',
                        $this->fields,
21aedefe   Yarik   Another one admin...
114
115
116
117
118
119
120
121
122
123
                    ])
                    ->andFilterWhere([
                        'ilike',
                        'param',
                        $this->param,
                    ])
                    ->andFilterWhere([
                        'ilike',
                        'seo_dynamic_lang.name',
                        $this->name,
93c267f7   Yarik   Multilanguage big...
124
125
                    ]);
              
d8c1a2e0   Yarik   Big commit artbox
126
127
              return $dataProvider;
          }
d8c1a2e0   Yarik   Big commit artbox
128
      }