3f2bc3d0
Administrator
first commit
|
1
2
3
4
5
|
<?php
namespace common\modules\product\models;
use Yii;
|
5ee9ab1f
Karnovsky A
-
|
6
|
use yii\helpers\ArrayHelper;
|
3f2bc3d0
Administrator
first commit
|
7
8
9
10
11
12
13
14
15
16
17
18
19
|
/**
* This is the model class for table "product_variant".
*
* @property integer $product_variant_id
* @property integer $product_id
* @property string $name
* @property string $remote_id
* @property string $sku
* @property double $price
* @property double $price_old
* @property double $stock
* @property integer $product_unit_id
|
3f2bc3d0
Administrator
first commit
|
20
|
* @property integer $product_variant_type_id
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
21
22
23
24
|
* @property ProductImage $image
* @property array $images
*
* @property ProductUnit $productUnit
|
3f2bc3d0
Administrator
first commit
|
25
26
27
|
*/
class ProductVariant extends \yii\db\ActiveRecord
{
|
a8fc4348
Administrator
basket
|
28
29
30
31
32
33
34
35
36
|
/**just for rukzachok**/
public $count;
public $sum_cost;
public $product_name;
//public $image;
public $translit;
public $translit_rubric;
private $data;
|
5ee9ab1f
Karnovsky A
-
|
37
|
public $stocks = [];
|
8df8067a
Administrator
basket
|
38
|
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
39
|
/** @var array $_images */
|
c34b3aa0
Karnovsky A
-
|
40
|
// public $imagesUpload = [];
|
3f2bc3d0
Administrator
first commit
|
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
/**
* @inheritdoc
*/
public static function tableName()
{
return 'product_variant';
}
/**
* @inheritdoc
*/
public function rules()
{
return [
|
c34b3aa0
Karnovsky A
-
|
55
|
[['product_id', 'product_unit_id'], 'required'],
|
3f2bc3d0
Administrator
first commit
|
56
57
58
59
|
[['product_id', 'product_unit_id', 'product_variant_type_id'], 'integer'],
[['price', 'price_old', 'stock'], 'number'],
[['name', 'sku'], 'string', 'max' => 255],
[['remote_id'], 'string', 'max' => 20],
|
c34b3aa0
Karnovsky A
-
|
60
61
|
// [['imagesUpload'], 'safe'],
// [['imagesUpload'], 'file', 'skipOnEmpty' => false, 'extensions' => 'png, jpg, gif', 'maxFiles' => 50],
|
3f2bc3d0
Administrator
first commit
|
62
|
[['product_unit_id'], 'exist', 'skipOnError' => true, 'targetClass' => ProductUnit::className(), 'targetAttribute' => ['product_unit_id' => 'product_unit_id']],
|
3f2bc3d0
Administrator
first commit
|
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
|
];
}
/**
* @inheritdoc
*/
public function attributeLabels()
{
return [
'product_variant_id' => Yii::t('product', 'Product Variant ID'),
'product_id' => Yii::t('product', 'Product ID'),
'name' => Yii::t('product', 'Name'),
'sku' => Yii::t('product', 'Sku'),
'price' => Yii::t('product', 'Price'),
'price_old' => Yii::t('product', 'Price Old'),
'stock' => Yii::t('product', 'Stock'),
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
79
80
81
82
83
|
'product_unit_id' => Yii::t('product', 'Product Unit ID'),
'product_variant_type_id' => Yii::t('product', 'Product Variant Type ID'),
'stock_caption' => Yii::t('product', 'Stock'),
'image' => Yii::t('product', 'Image'),
'images' => Yii::t('product', 'Images'),
|
3f2bc3d0
Administrator
first commit
|
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
];
}
/**
* @return \yii\db\ActiveQuery
*/
public function getProductUnit()
{
return $this->hasOne(ProductUnit::className(), ['product_unit_id' => 'product_unit_id']);
}
/**
* @return \yii\db\ActiveQuery
*/
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
98
|
public function getProductVariantType()
|
3f2bc3d0
Administrator
first commit
|
99
|
{
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
100
|
return $this->hasOne(ProductVariantType::className(), ['product_variant_type_id' => 'product_variant_type_id']);
|
3f2bc3d0
Administrator
first commit
|
101
102
103
104
105
|
}
/**
* @return \yii\db\ActiveQuery
*/
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
106
107
108
109
110
|
public function getProduct()
{
return $this->hasOne(Product::className(), ['product_id' => 'product_id']);
}
|
5ee9ab1f
Karnovsky A
-
|
111
112
113
114
115
116
|
public function getQuantity() {
return ProductStock::find()
->where(['product_variant_id' => $this->product_variant_id])
->sum('quantity');
// return $this->hasMany(Stock::className(), ['stock_id' => 'stock_id'])->viaTable(ProductStock::tableName(), ['product_id' => 'product_id'])->sum(ProductStock::tableName() .'.quantity') > 0;
// return $this->stock !== 0;
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
117
118
119
|
}
public function getStock_caption() {
|
4902c747
Karnovsky A
-
|
120
|
return is_null($this->stock) ? '∞' : ($this->stock > 0 ? Yii::t('product', 'Enable') : Yii::t('product', 'Disable')); // intval($this->stock);
|
3f2bc3d0
Administrator
first commit
|
121
122
123
124
125
|
}
/**
* @return \yii\db\ActiveQuery
*/
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
126
127
128
|
public function getImage()
{
return $this->hasOne(ProductImage::className(), ['product_variant_id' => 'product_variant_id']);
|
3f2bc3d0
Administrator
first commit
|
129
130
131
|
}
/**
|
dc2cd017
Karnovsky A
-
|
132
133
134
135
136
137
138
139
140
|
* fetch stored image url
* @return string
*/
public function getImageUrl()
{
// return a default image placeholder if your source image is not found
return !empty($this->image) ? $this->image->imageUrl : '/images/no_photo.png';
}
|
38828295
Karnovsky A
-
|
141
142
143
144
|
public function getFullname() {
return empty($this->product) ? null : ($this->product->name . (empty($this->name) ? '' : ' '. $this->name));
}
|
dc2cd017
Karnovsky A
-
|
145
|
/**
|
3f2bc3d0
Administrator
first commit
|
146
147
|
* @return \yii\db\ActiveQuery
*/
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
148
149
150
|
public function getImages()
{
return $this->hasMany(ProductImage::className(), ['product_variant_id' => 'product_variant_id']);
|
3f2bc3d0
Administrator
first commit
|
151
152
153
154
155
156
157
158
159
160
|
}
/**
* @inheritdoc
* @return ProductVariantQuery the active query used by this AR class.
*/
public static function find()
{
return new ProductVariantQuery(get_called_class());
}
|
90a6ed1a
Administrator
basket
|
161
162
163
164
|
public function getId(){
return $this->product_variant_id;
}
|
c9d723d7
Karnovsky A
-
|
165
|
|
5ee9ab1f
Karnovsky A
-
|
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
|
public function setStocks($stocks) {
$this->stocks = (array) $stocks;
}
/*public function getStocks() {
return $this->hasMany(Stock::className(), ['stock_id' => 'stock_id'])->viaTable(ProductStock::tableName(), ['product_variant_id' => 'product_variant_id']);
}
public function getStocksIds() {
return ArrayHelper::getColumn($this->hasMany(Stock::className(), ['stock_id' => 'stock_id'])->viaTable(ProductStock::tableName(), ['product_variant_id' => 'product_variant_id'])->all(), 'stock_id');
}*/
public function afterSave($insert, $changedAttributes)
{
if (!empty($this->stocks)) {
ProductStock::deleteAll(['product_variant_id' => $this->product_variant_id]);
$values = [];
foreach ($this->stocks as $id => $quantity) {
$values[] = [$this->product_id, $this->product_variant_id, $id, $quantity];
}
if ($values) {
self::getDb()->createCommand()
->batchInsert(ProductStock::tableName(), ['product_id', 'product_variant_id', 'stock_id', 'quantity'], $values)->execute();
}
}
parent::afterSave($insert, $changedAttributes);
}
|
c9d723d7
Karnovsky A
-
|
194
195
|
public function beforeDelete() {
ProductImage::deleteAll(['product_variant_id' => $this->product_variant_id]);
|
5ee9ab1f
Karnovsky A
-
|
196
|
ProductStock::deleteAll(['product_variant_id' => $this->product_variant_id]);
|
c9d723d7
Karnovsky A
-
|
197
|
}
|
3f2bc3d0
Administrator
first commit
|
198
|
}
|