Blame view

models/OrderSearch.php 3.06 KB
8a7e6ecf   Yarik   Namespaces
1
2
3
4
5
6
7
8
9
10
11
12
13
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
50
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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
  <?php

      

      namespace artweb\artbox\ecommerce\models;

      

      use yii\base\Model;

      use yii\data\ActiveDataProvider;

      

      /**

       * OrderSearch represents the model behind the search form about `\artweb\artbox\ecommerce\models\Order`.

       */

      class OrderSearch extends Order

      {

          

          /**

           * @inheritdoc

           */

          public function rules()

          {

              return [

                  [

                      [

                          'id',

                          'user_id',

                          'delivery',

                          'payment',

                          'status',

                      ],

                      'integer',

                  ],

                  [

                      [

                          'name',

                          'email',

                          'phone',

                      ],

                      'safe',

                  ],

              ];

          }

          

          /**

           * @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 = Order::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;

              }

              

              // grid filtering conditions

              $query->andFilterWhere(

                  [

                      'id'       => $this->id,

                      'user_id'  => $this->user_id,

                      'delivery' => $this->delivery,

                      'payment'  => $this->payment,

                      'status'   => $this->status,

                  ]

              );

              

              $query->andFilterWhere(

                  [

                      'like',

                      'name',

                      $this->name,

                  ]

              )

                    ->andFilterWhere(

                        [

                            'like',

                            'email',

                            $this->email,

                        ]

                    )

                    ->andFilterWhere(

                        [

                            'like',

                            'phone',

                            $this->phone,

                        ]

                    );

              

              return $dataProvider;

          }

      }