Blame view

common/modules/product/models/ProductVariantListSearch.php 3.09 KB
d8c1a2e0   Yarik   Big commit artbox
1
  <?php
93c267f7   Yarik   Multilanguage big...
2
3
4
5
6
      
      namespace common\modules\product\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
       * ProductVariantSearch represents the model behind the search form about
       * `backend\models\ProductVariant`.
d8c1a2e0   Yarik   Big commit artbox
11
       */
93c267f7   Yarik   Multilanguage big...
12
      class ProductVariantListSearch extends ProductVariant
d8c1a2e0   Yarik   Big commit artbox
13
      {
93c267f7   Yarik   Multilanguage big...
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
          
          public function behaviors()
          {
              return [];
          }
          
          /**
           * @inheritdoc
           */
          public function rules()
          {
              return [
                  [
                      [
                          'product_variant_id',
                          'product_id',
                          'product_unit_id',
                      ],
                      'integer',
                  ],
                  [
                      [
                          'sku',
                          'remote_id',
                      ],
                      'safe',
                  ],
                  [
                      [
                          'price',
                          'price_old',
                          'stock',
                      ],
                      'number',
                  ],
              ];
d8c1a2e0   Yarik   Big commit artbox
50
          }
93c267f7   Yarik   Multilanguage big...
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
          
          /**
           * @inheritdoc
           */
          public function scenarios()
          {
              // bypass scenarios() implementation in the parent class
              return Model::scenarios();
          }
          
          /**
           * Creates data provider instance with search query applied
           *
           * @param array $params
           *
           * @return ActiveDataProvider
           */
          public function search($params, $product_id = false)
          {
              $query = ProductVariant::find();
              
              // add conditions that should always apply here
              
              $dataProvider = new ActiveDataProvider([
                  'query' => $query,
              ]);
              
              $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;
              }
              
              if($product_id) {
                  $query->andFilterWhere([
                      'product_id' => $product_id,
                  ]);
              }
              
              // grid filtering conditions
d8c1a2e0   Yarik   Big commit artbox
93
              $query->andFilterWhere([
93c267f7   Yarik   Multilanguage big...
94
95
96
97
98
                  'product_variant_id' => $this->product_variant_id,
                  'price'              => $this->price,
                  'price_old'          => $this->price_old,
                  'stock'              => $this->stock,
                  'product_unit_id'    => $this->product_unit_id,
d8c1a2e0   Yarik   Big commit artbox
99
              ]);
93c267f7   Yarik   Multilanguage big...
100
101
102
103
104
105
106
107
108
109
110
111
112
              
              $query->andFilterWhere([
                      'like',
                      'sku',
                      $this->sku,
                  ])
                    ->andFilterWhere([
                        'like',
                        'remote_id',
                        $this->remote_id,
                    ]);
              
              return $dataProvider;
d8c1a2e0   Yarik   Big commit artbox
113
          }
d8c1a2e0   Yarik   Big commit artbox
114
      }