Blame view

common/modules/product/models/ProductSearch.php 3.36 KB
d8c1a2e0   Yarik   Big commit artbox
1
2
3
4
  <?php

  

  namespace common\modules\product\models;

  

d8c1a2e0   Yarik   Big commit artbox
5
6
  use yii\base\Model;

  use yii\data\ActiveDataProvider;

d8c1a2e0   Yarik   Big commit artbox
7
8
9
10
11
12
13
14
15
16
17
18
  

  /**

   * ProductSearch represents the model behind the search form about `common\modules\product\models\Product`.

   */

  class ProductSearch extends Product

  {

      public $brand_name;

      public $brand_id;

      public $category_id;

      public $category_name;

      public $variant_sku;

  

d55d2fe0   Yarik   Multilanguage
19
20
21
22
23
24
25
26
27
      public function behaviors()

      {

          $behaviors = parent::behaviors();

          if(isset($behaviors['language'])) {

              unset($behaviors['language']);

          }

          return $behaviors;

      }

      

d8c1a2e0   Yarik   Big commit artbox
28
29
30
31
32
33
      /**

       * @inheritdoc

       */

      public function rules()

      {

          return [

93c267f7   Yarik   Multilanguage big...
34
              [['brand_name', 'brand_id', 'category_id', 'category_name', 'variant_sku'], 'safe'],

d8c1a2e0   Yarik   Big commit artbox
35
36
37
38
              [['brand_id', 'product_id'], 'integer'],

              [['is_top', 'is_new', 'akciya'], 'boolean'],

          ];

      }

36d1807a   Yarik   Big commit.
39
      

d8c1a2e0   Yarik   Big commit artbox
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
      /**

       * @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)

      {

  

          $query = Product::find();

  

93c267f7   Yarik   Multilanguage big...
61
  //        $query->joinWith(['brand', 'categories', 'variant']);

d8c1a2e0   Yarik   Big commit artbox
62
63
64
65
66
67
68
69
70
71
72
  

          $query->groupBy(['product.product_id']);

  

          $dataProvider = new ActiveDataProvider([

              'query' => $query,

          ]);

  

          if ( !($this->load($params) && $this->validate()) ) {

              return $dataProvider;

          }

  

93c267f7   Yarik   Multilanguage big...
73
74
75
76
77
78
79
80
81
82
83
84
  //        $dataProvider->setSort([

  //            'attributes' => [

  //                'brand_name' => [

  //                    'asc' => ['brand.name' => SORT_ASC],

  //                    'desc' => ['brand.name' => SORT_DESC],

  //                    'default' => SORT_DESC,

  //                    'label' => 'Brand name',

  //                ],

  //                'category_name',

  //                'variant_sku',

  //            ]

  //        ]);

d8c1a2e0   Yarik   Big commit artbox
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
  

          if (isset($this->is_top)) {

              $query->andFilterWhere([

                  'is_top' => (bool)$this->is_top,

              ]);

          }

          if (isset($this->is_new)) {

              $query->andFilterWhere([

                  'is_new' => (bool)$this->is_new,

              ]);

          }

          if (isset($this->akciya)) {

              $query->andFilterWhere([

                  'akciya' => (bool)$this->akciya,

              ]);

          }

          $query->andFilterWhere([

              'product.brand_id' => $this->brand_id,

              'product.product_id' => $this->product_id,

93c267f7   Yarik   Multilanguage big...
104
  //            'product_category.category_id' => $this->category_id

d8c1a2e0   Yarik   Big commit artbox
105
106
          ]);

  

93c267f7   Yarik   Multilanguage big...
107
108
109
  //        $query->andFilterWhere(['ilike', 'brand.name', $this->brand_name]);

  //        $query->andFilterWhere(['ilike', 'category.name', $this->category_name]);

  //        $query->andFilterWhere(['ilike', 'product_variant.sku', $this->variant_sku]);

d8c1a2e0   Yarik   Big commit artbox
110
111
112
113
  

          return $dataProvider;

      }

  

d8c1a2e0   Yarik   Big commit artbox
114
115
116
117
118
119
120
121
122
123
      public static function findByRemoteID($id) {

          /** @var CategoryQuery $query */

          $query = Product::find()

              ->andFilterWhere(['remote_id' => $id]);

          if (($model = $query->one()) !== null) {

              return $model;

          }

          return null;

      }

  }