Blame view

common/models/SeoDynamicSearch.php 3.89 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
          public function behaviors()
          {
              return [];
          }
          
          /**
           * @inheritdoc
           */
          public function rules()
          {
              return [
                  [
                      [
4428da8c   Yarik   Almost all databa...
30
                          'id',
93c267f7   Yarik   Multilanguage big...
31
32
33
34
35
36
37
38
                          'status',
                      ],
                      'integer',
                  ],
                  [
                      [
                          'action',
                          'fields',
8af13427   Yarik   For leha commit.
39
                          'title',
21aedefe   Yarik   Another one admin...
40
                          '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
              
              // add conditions that should always apply here
              
4428da8c   Yarik   Almost all databa...
71
72
73
74
75
76
77
78
79
80
81
82
83
84
              $dataProvider = new ActiveDataProvider(
                  [
                      'query' => $query,
                      'sort'  => [
                          'attributes' => [
                              'id',
                              'action',
                              'fields',
                              'status',
                              'param',
                              'title' => [
                                  'asc'  => [ 'seo_dynamic_lang.title' => SORT_ASC ],
                                  'desc' => [ 'seo_dynamic_lang.title' => SORT_DESC ],
                              ],
21aedefe   Yarik   Another one admin...
85
86
                          ],
                      ],
4428da8c   Yarik   Almost all databa...
87
88
                  ]
              );
93c267f7   Yarik   Multilanguage big...
89
90
91
              
              $this->load($params);
              
4428da8c   Yarik   Almost all databa...
92
              if (!$this->validate()) {
93c267f7   Yarik   Multilanguage big...
93
94
95
96
97
98
                  // 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
4428da8c   Yarik   Almost all databa...
99
100
101
102
103
104
105
106
107
108
109
              $query->andWhere(
                  [
                      'seo_category_id' => $seo_category_id,
                  ]
              )
                    ->andFilterWhere(
                        [
                            'id'     => $this->id,
                            'status' => $this->status,
                        ]
                    );
93c267f7   Yarik   Multilanguage big...
110
              
4428da8c   Yarik   Almost all databa...
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
              $query->andFilterWhere(
                  [
                      'ilike',
                      'action',
                      $this->action,
                  ]
              )
                    ->andFilterWhere(
                        [
                            'ilike',
                            'fields',
                            $this->fields,
                        ]
                    )
                    ->andFilterWhere(
                        [
                            'ilike',
                            'param',
                            $this->param,
                        ]
                    )
                    ->andFilterWhere(
                        [
                            'ilike',
                            'seo_dynamic_lang.title',
                            $this->title,
                        ]
                    );
93c267f7   Yarik   Multilanguage big...
139
              
d8c1a2e0   Yarik   Big commit artbox
140
141
              return $dataProvider;
          }
d8c1a2e0   Yarik   Big commit artbox
142
      }