3f2bc3d0
Administrator
first commit
|
1
2
3
4
5
|
<?php
namespace common\modules\product\models;
use common\behaviors\Slug;
|
c7852657
Karnovsky A
-
|
6
|
use common\modules\rubrication\models\TaxGroup;
|
3f2bc3d0
Administrator
first commit
|
7
8
9
10
|
use common\modules\rubrication\models\TaxOption;
use Yii;
use common\modules\relation\relationBehavior;
use yii\db\ActiveQuery;
|
868680ca
Karnovsky A
-
|
11
|
use yii\db\ActiveRecord;
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
12
13
|
use yii\helpers\Html;
use yii\web\UploadedFile;
|
3f2bc3d0
Administrator
first commit
|
14
15
16
17
|
/**
* This is the model class for table "{{%product}}".
*
|
3f2bc3d0
Administrator
first commit
|
18
|
* @property string $name
|
3f2bc3d0
Administrator
first commit
|
19
|
* @property integer $brand_id
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
20
|
* @property integer $product_id
|
3f2bc3d0
Administrator
first commit
|
21
22
|
* @property Category $category
* @property array $categories
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
23
|
* @property array of ProductVariant $variants
|
3f2bc3d0
Administrator
first commit
|
24
|
* @property ProductVariant $variant
|
3f2bc3d0
Administrator
first commit
|
25
26
|
* @property ProductImage $image
* @property array $images
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
27
28
|
* @property boolean $is_top
* @property boolean $is_new
|
dc2cd017
Karnovsky A
-
|
29
|
* @property boolean $akciya
|
e9f291a5
Karnovsky A
Similar products ...
|
30
31
32
|
* @property array $properties
* @property ProductVariant $enabledVariant
* @property array $enabledVariants
|
3f2bc3d0
Administrator
first commit
|
33
34
35
36
37
38
39
40
|
*/
class Product extends \yii\db\ActiveRecord
{
/** @var array $_variants */
public $_variants = [];
/** @var array $_images */
public $imagesUpload = [];
|
83be3cfb
Karnovsky A
-
|
41
|
public $variantImagesUpload = [];
|
3f2bc3d0
Administrator
first commit
|
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
|
/**
* @inheritdoc
*/
public function behaviors()
{
return [
[
'class' => relationBehavior::className(),
'relations' => [
'product_categories' => 'entity1', // Product category
'product_option' => 'entity1' // Product category
]
],
[
'class' => Slug::className(),
'in_attribute' => 'name',
'out_attribute' => 'alias',
'translit' => true
]
];
}
/**
* @inheritdoc
*/
public static function tableName()
{
return '{{%product}}';
}
/**
* @inheritdoc
*/
public function rules()
{
return [
|
067092f7
Karnovsky A
-
|
78
|
// [['categories'], 'required'],
|
3f2bc3d0
Administrator
first commit
|
79
80
81
|
[['brand_id'], 'integer'],
[['name'], 'string', 'max' => 150],
[['alias'], 'string', 'max' => 250],
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
82
|
[['categories', 'variants', 'options', 'imagesUpload'], 'safe'],
|
dc2cd017
Karnovsky A
-
|
83
|
// [['imagesUpload'], 'file', 'skipOnEmpty' => false, 'extensions' => 'png, jpg, gif', 'maxFiles' => 50],
|
3f2bc3d0
Administrator
first commit
|
84
|
[['description', 'video'], 'safe'],
|
dc2cd017
Karnovsky A
-
|
85
|
[['is_top', 'is_new', 'akciya'], 'boolean'],
|
3f2bc3d0
Administrator
first commit
|
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
// [['product_id'], 'exist', 'skipOnError' => true, 'targetClass' => Product::className(), 'targetAttribute' => ['product_id' => 'product_id']],
];
}
/**
* @inheritdoc
*/
public function attributeLabels()
{
return [
'product_id' => Yii::t('product', 'ID'),
'name' => Yii::t('product', 'Name'),
'brand_id' => Yii::t('product', 'Brand'),
'categories' => Yii::t('product', 'Categories'), // relation behavior field
'category' => Yii::t('product', 'Category'), // relation behavior field
'image' => Yii::t('product', 'Image'),
'images' => Yii::t('product', 'Images'),
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
103
104
105
106
107
|
'description' => Yii::t('product', 'Description'),
'video' => Yii::t('product', 'Video embeded'),
'variants' => Yii::t('product', 'Variants'),
'is_top' => Yii::t('product', 'Is top'),
'is_new' => Yii::t('product', 'Is new'),
|
dc2cd017
Karnovsky A
-
|
108
|
'akciya' => Yii::t('product', 'Is promo'),
|
3f2bc3d0
Administrator
first commit
|
109
110
111
|
];
}
|
02e6c2ba
Karnovsky A
-
|
112
113
114
115
|
public function getUrl() {
return '/product/'. $this->alias;
}
|
3f2bc3d0
Administrator
first commit
|
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
|
/**
* @return \yii\db\ActiveQuery
*/
public function getBrand()
{
return $this->hasOne(Brand::className(), ['brand_id' => 'brand_id']);
}
/**
* @return \yii\db\ActiveQuery
*/
public function getImage()
{
return $this->hasOne(ProductImage::className(), ['product_id' => 'product_id']);
}
/**
|
dc2cd017
Karnovsky A
-
|
133
134
135
136
137
|
* fetch stored image url
* @return string
*/
public function getImageUrl()
{
|
4902c747
Karnovsky A
-
|
138
139
|
$image = empty($this->variant) ? null : $this->variant->image;
return !empty($image) ? $image->imageUrl : '/images/no_photo.png';
|
dc2cd017
Karnovsky A
-
|
140
141
142
|
}
/**
|
3f2bc3d0
Administrator
first commit
|
143
144
145
146
|
* @return \yii\db\ActiveQuery
*/
public function getImages()
{
|
1e55b4b8
Karnovsky A
-
|
147
|
return $this->hasMany(ProductImage::className(), ['product_id' => 'product_id'])->where(['product_variant_id' => null]);
|
3f2bc3d0
Administrator
first commit
|
148
149
|
}
|
3f2bc3d0
Administrator
first commit
|
150
151
152
153
154
|
/**
* @return \yii\db\ActiveQuery
*/
public function getVariant()
{
|
0a93b48a
Karnovsky A
-
|
155
|
return $this->hasOne(ProductVariant::className(), ['product_id' => 'product_id']);
|
3f2bc3d0
Administrator
first commit
|
156
157
|
}
|
d48d8bc0
Karnovsky A
-
|
158
159
160
161
162
163
164
|
/**
* @return \yii\db\ActiveQuery
*/
public function getEnabledVariant()
{
return $this->hasOne(ProductVariant::className(), ['product_id' => 'product_id'])->andOnCondition(['!=', ProductVariant::tableName() .'.stock', 0]);
}
|
e9f291a5
Karnovsky A
Similar products ...
|
165
|
|
3f2bc3d0
Administrator
first commit
|
166
167
168
|
public function getVariantPrice() {
return $this->variant->price;
}
|
1e55b4b8
Karnovsky A
-
|
169
|
|
d48d8bc0
Karnovsky A
-
|
170
|
public function getEnabledVariantPrice() {
|
c7852657
Karnovsky A
-
|
171
|
return $this->enabledVariants[0]->price;
|
d48d8bc0
Karnovsky A
-
|
172
173
|
}
|
3f2bc3d0
Administrator
first commit
|
174
175
176
177
178
|
/**
* @return \yii\db\ActiveQuery
*/
public function getVariants()
{
|
0a93b48a
Karnovsky A
-
|
179
|
return $this->hasMany(ProductVariant::className(), ['product_id' => 'product_id']);
|
3f2bc3d0
Administrator
first commit
|
180
181
|
}
|
1e55b4b8
Karnovsky A
-
|
182
183
|
public function getEnabledVariants()
{
|
d48d8bc0
Karnovsky A
-
|
184
|
return $this->hasMany(ProductVariant::className(), ['product_id' => 'product_id'])->andOnCondition(['!=', ProductVariant::tableName() .'.stock', 0]);
|
1e55b4b8
Karnovsky A
-
|
185
186
|
}
|
c7852657
Karnovsky A
-
|
187
188
189
190
191
192
193
|
/*
* Get variants grouped by type
*/
public function getEnabledVariantsGrouped()
{
$variants = [];
foreach ($this->enabledVariants as $variant) {
|
a57c9f4d
Karnovsky A
-
|
194
|
$variants[$variant->product_variant_type_id ? $variant->product_variant_type_id : 1][] = $variant;
|
c7852657
Karnovsky A
-
|
195
196
197
198
|
}
if (empty($variants)) {
return [];
}
|
a57c9f4d
Karnovsky A
-
|
199
|
$ids = array_keys($variants);
|
c7852657
Karnovsky A
-
|
200
|
$variants_type = [];
|
a57c9f4d
Karnovsky A
-
|
201
|
foreach(ProductVariantType::find()->select(['product_variant_type_id', 'name2'])->where(['product_variant_type_id' => $ids])->all() as $variant_type) {
|
c7852657
Karnovsky A
-
|
202
203
204
205
206
207
|
$variant_type->_variants = $variants[$variant_type->product_variant_type_id];
$variants_type[] = $variant_type;
}
return $variants_type;
}
|
3f2bc3d0
Administrator
first commit
|
208
209
210
211
212
213
214
215
216
217
|
public function setVariants($variants) {
$this->_variants = $variants;
}
public function getFullName()
{
return empty($this->brand) ? $this->name : $this->brand->name .' '. $this->name;
}
public function getCategories() {
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
218
219
|
return $this->hasMany(Category::className(), ['category_id' => 'category_id'])->viaTable('product_category', ['product_id' => 'product_id']);
// return $this->getRelations('product_categories');
|
3f2bc3d0
Administrator
first commit
|
220
221
222
223
224
225
226
227
228
229
230
|
}
public function getCategoriesNames() {
$result = [];
foreach($this->categories as $category) {
$result[] = $category->name;
}
return $result;
}
public function getCategory() {
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
231
|
return $this->hasOne(Category::className(), ['category_id' => 'category_id'])->viaTable('product_category', ['product_id' => 'product_id']);
|
3f2bc3d0
Administrator
first commit
|
232
233
234
|
}
public function getOptions() {
|
c7852657
Karnovsky A
-
|
235
|
return $this->hasMany(TaxOption::className(), ['tax_option_id' => 'option_id'])->viaTable('product_option', ['product_id' => 'product_id']);
|
2e3229c3
Karnovsky A
Import check
|
236
237
238
239
240
241
242
243
244
245
246
247
248
249
|
}
public function getProperties() {
$groups = $options = [];
foreach ($this->options as $option) {
$options[$option->tax_group_id][] = $option;
}
foreach (TaxGroup::find()->where(['tax_group_id' => array_keys($options)])->all() as $group) {
if (!empty($options[$group->tax_group_id])) {
$group->_options = $options[$group->tax_group_id];
$groups[] = $group;
}
}
return $groups;
|
3f2bc3d0
Administrator
first commit
|
250
251
|
}
|
5ee9ab1f
Karnovsky A
-
|
252
253
254
255
|
public function getStocks() {
return $this->hasMany(Stock::className(), ['stock_id' => 'stock_id'])->viaTable(ProductStock::tableName(), ['product_id' => 'product_id']);
}
|
3f2bc3d0
Administrator
first commit
|
256
257
258
259
260
261
262
263
264
|
/**
* @inheritdoc
* @return ProductQuery the active query used by this AR class.
*/
public static function find()
{
return new ProductQuery(get_called_class());
}
|
1e55b4b8
Karnovsky A
-
|
265
266
267
268
269
270
|
public function getQuantity() {
return ProductStock::find()
->where(['product_id' => $this->product_id])
->sum('quantity');
}
|
3f2bc3d0
Administrator
first commit
|
271
272
273
274
|
public function afterSave($insert, $changedAttributes)
{
parent::afterSave($insert, $changedAttributes);
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
275
276
277
278
279
280
281
282
283
284
285
286
|
// $images = UploadedFile::getInstance($this, 'imagesUpload');
// var_dump($images);exit;
// if (!empty($this->imagesUpload)) {
// if (!is_array($this->imagesUpload)) {
// $this->imagesUpload = [$this->imagesUpload];
// }
// foreach($this->imagesUpload as $image) {
// $image->saveAs((Yii::getAlias('@frontend/web/storage/products/original/' . $image->baseName .'_'. uniqid() . '.' . $image->extension)));
// }
//
//
|
3f2bc3d0
Administrator
first commit
|
287
288
|
// }
|
4902c747
Karnovsky A
-
|
289
290
291
292
|
if (!empty($this->_variants)) {
$todel = [];
foreach ($this->variants ?: [] as $_variant) {
$todel[$_variant->product_variant_id] = $_variant->product_variant_id;
|
3f2bc3d0
Administrator
first commit
|
293
|
}
|
4902c747
Karnovsky A
-
|
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
|
foreach ($this->_variants as $_variant) {
if (!is_array($_variant)) {
return;
}
if (!empty($_variant['product_variant_id'])) {
unset($todel[$_variant['product_variant_id']]);
$model = ProductVariant::findOne($_variant['product_variant_id']);
} else {
$model = new ProductVariant();
}
$_variant['product_id'] = $this->product_id;
$model->load(['ProductVariant' => $_variant]);
$model->product_id = $this->product_id;
$model->save();
}
if (!empty($todel)) {
ProductVariant::deleteAll(['product_variant_id' => $todel]);
|
3f2bc3d0
Administrator
first commit
|
311
|
}
|
c9d723d7
Karnovsky A
-
|
312
|
}
|
3f2bc3d0
Administrator
first commit
|
313
|
}
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
314
|
|
868680ca
Karnovsky A
-
|
315
316
317
318
319
320
|
public function beforeDelete() {
ProductImage::deleteAll(['product_id' => $this->product_id]);
ProductCategory::deleteAll(['product_id' => $this->product_id]);
ProductVariant::deleteAll(['product_id' => $this->product_id]);
}
|
83be3cfb
Karnovsky A
-
|
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
|
public function variantImagesUpload()
{
if ($this->validate()) {
$images = [];
foreach ($this->variantImagesUpload as $product_variant_id => $image) {
$imageName = $image->baseName .'.'. $image->extension;
$i = 0;
while(file_exists(Yii::getAlias('@imagesDir/products/' . $imageName))) {
$i++;
$imageName = $image->baseName .'_'. $i .'.'. $image->extension;
}
$image->saveAs(Yii::getAlias('@imagesDir/products/' .$imageName));
$images[$product_variant_id] = $imageName;
}
return $images;
} else {
return false;
}
}
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
342
343
344
345
346
347
348
|
public function imagesUpload()
{
if ($this->validate()) {
$images = [];
foreach ($this->imagesUpload as $image) {
$imageName = $image->baseName .'.'. $image->extension;
$i = 0;
|
83be3cfb
Karnovsky A
-
|
349
|
while(file_exists(Yii::getAlias('@imagesDir/products/' . $imageName))) {
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
350
351
352
353
|
$i++;
$imageName = $image->baseName .'_'. $i .'.'. $image->extension;
}
|
83be3cfb
Karnovsky A
-
|
354
|
$image->saveAs(Yii::getAlias('@imagesDir/products/' .$imageName));
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
355
356
357
358
359
360
361
362
363
364
365
366
|
$images[] = $imageName;
}
return $images;
} else {
return false;
}
}
public function getImagesHTML() {
$op = [];
if ($this->images) {
foreach ($this->images as $image) {
|
83be3cfb
Karnovsky A
-
|
367
|
$op[] = \common\components\artboximage\ArtboxImageHelper::getImage($image->imageUrl, 'admin_thumb');
|
ccc7a9d3
Karnovsky A
Karnovsky 12052016
|
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
|
}
}
return $op;
}
public function getImagesConfig() {
$op = [];
if ($this->images) {
foreach ($this->images as $image) {
$op[] = [
'caption' => $image->image,
'width' => '120px',
'url' => \yii\helpers\Url::to(['/product/manage/delimg', 'id' => $image->product_image_id]),
'key' => $image->product_image_id,
'extra' => [
'id' => $image->product_image_id,
],
];
}
}
return $op;
}
|
3f2bc3d0
Administrator
first commit
|
390
|
}
|