36d1807a
Yarik
Big commit.
|
1
|
<?php
|
cc658b4c
Yarik
Big commit
|
2
3
4
5
6
7
8
9
10
11
12
|
namespace backend\controllers;
use common\models\ProductToProject;
use common\models\ProductToProjectSearch;
use common\models\Project;
use common\models\ProjectImage;
use common\models\ProjectSearch;
use common\modules\product\models\Product;
use common\modules\product\models\ProductVariant;
use Yii;
|
96410438
Yarik
Project admin com...
|
13
|
use yii\helpers\ArrayHelper;
|
cc658b4c
Yarik
Big commit
|
14
15
16
17
18
19
|
use yii\web\Controller;
use yii\web\NotFoundHttpException;
use yii\filters\VerbFilter;
use developeruz\db_rbac\behaviors\AccessBehavior;
use yii\web\UploadedFile;
|
36d1807a
Yarik
Big commit.
|
20
|
/**
|
cc658b4c
Yarik
Big commit
|
21
|
* ProjectController implements the CRUD actions for Project model.
|
36d1807a
Yarik
Big commit.
|
22
|
*/
|
cc658b4c
Yarik
Big commit
|
23
|
class ProjectController extends Controller
|
36d1807a
Yarik
Big commit.
|
24
|
{
|
cc658b4c
Yarik
Big commit
|
25
26
27
28
29
30
31
32
33
34
35
|
/**
* @inheritdoc
*/
public function behaviors()
{
return [
'access' => [
'class' => AccessBehavior::className(),
'rules' => [
'site' => [
|
36d1807a
Yarik
Big commit.
|
36
|
[
|
cc658b4c
Yarik
Big commit
|
37
38
39
40
41
42
43
44
|
'actions' => [
'login',
'error',
],
'allow' => true,
],
],
],
|
36d1807a
Yarik
Big commit.
|
45
|
],
|
cc658b4c
Yarik
Big commit
|
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
|
'verbs' => [
'class' => VerbFilter::className(),
'actions' => [
'delete' => [ 'POST' ],
],
],
];
}
/**
* Lists all Project models.
* @return mixed
*/
public function actionIndex()
{
$searchModel = new ProjectSearch();
$dataProvider = $searchModel->search(Yii::$app->request->queryParams);
return $this->render('index', [
'searchModel' => $searchModel,
'dataProvider' => $dataProvider,
]);
}
/**
* Displays a single Project model.
*
* @param integer $id
*
* @return mixed
*/
public function actionView($id)
{
return $this->render('view', [
'model' => $this->findModel($id),
]);
}
/**
* Creates a new Project model.
* If creation is successful, the browser will be redirected to the 'view' page.
* @return mixed
*/
public function actionCreate()
{
$model = new Project();
|
72a992f5
Yarik
Import browser v1.0
|
92
|
$model->generateLangs();
|
cc658b4c
Yarik
Big commit
|
93
|
if($model->load(Yii::$app->request->post())) {
|
72a992f5
Yarik
Import browser v1.0
|
94
|
$model->loadLangs(\Yii::$app->request);
|
cc658b4c
Yarik
Big commit
|
95
|
$model->imagesUpload = UploadedFile::getInstances($model, 'imagesUpload');
|
72a992f5
Yarik
Import browser v1.0
|
96
|
if($model->save() && $model->transactionStatus) {
|
cc658b4c
Yarik
Big commit
|
97
98
99
100
101
102
103
|
if($model->imagesUpload && ( ( $images = $model->imagesUpload() ) !== false )) {
foreach($images as $image) {
$imageModel = new ProjectImage();
$imageModel->project_id = $model->project_id;
$imageModel->image = $image;
$imageModel->save();
}
|
36d1807a
Yarik
Big commit.
|
104
|
}
|
72a992f5
Yarik
Import browser v1.0
|
105
106
107
108
|
return $this->redirect([
'view',
'id' => $model->project_id,
]);
|
36d1807a
Yarik
Big commit.
|
109
|
}
|
36d1807a
Yarik
Big commit.
|
110
|
}
|
cc658b4c
Yarik
Big commit
|
111
|
return $this->render('create', [
|
d55d2fe0
Yarik
Multilanguage
|
112
|
'model' => $model,
|
72a992f5
Yarik
Import browser v1.0
|
113
|
'model_langs' => $model->model_langs,
|
cc658b4c
Yarik
Big commit
|
114
|
]);
|
36d1807a
Yarik
Big commit.
|
115
|
}
|
cc658b4c
Yarik
Big commit
|
116
117
118
119
120
121
122
123
124
125
126
127
|
/**
* Updates an existing Project model.
* If update is successful, the browser will be redirected to the 'view' page.
*
* @param integer $id
*
* @return mixed
*/
public function actionUpdate($id)
{
$model = $this->findModel($id);
|
72a992f5
Yarik
Import browser v1.0
|
128
|
$model->generateLangs();
|
cc658b4c
Yarik
Big commit
|
129
|
if($model->load(Yii::$app->request->post())) {
|
72a992f5
Yarik
Import browser v1.0
|
130
|
$model->loadLangs(\Yii::$app->request);
|
cc658b4c
Yarik
Big commit
|
131
|
$model->imagesUpload = UploadedFile::getInstances($model, 'imagesUpload');
|
72a992f5
Yarik
Import browser v1.0
|
132
|
if($model->save() && $model->transactionStatus) {
|
cc658b4c
Yarik
Big commit
|
133
134
135
136
137
138
139
|
if($model->imagesUpload && ( ( $images = $model->imagesUpload() ) !== false )) {
foreach($images as $image) {
$imageModel = new ProjectImage();
$imageModel->project_id = $model->project_id;
$imageModel->image = $image;
$imageModel->save();
}
|
36d1807a
Yarik
Big commit.
|
140
|
}
|
72a992f5
Yarik
Import browser v1.0
|
141
142
143
144
|
return $this->redirect([
'view',
'id' => $model->project_id,
]);
|
36d1807a
Yarik
Big commit.
|
145
|
}
|
36d1807a
Yarik
Big commit.
|
146
|
}
|
cc658b4c
Yarik
Big commit
|
147
|
return $this->render('update', [
|
d55d2fe0
Yarik
Multilanguage
|
148
|
'model' => $model,
|
72a992f5
Yarik
Import browser v1.0
|
149
|
'model_langs' => $model->model_langs,
|
cc658b4c
Yarik
Big commit
|
150
|
]);
|
36d1807a
Yarik
Big commit.
|
151
|
}
|
cc658b4c
Yarik
Big commit
|
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
|
/**
* Deletes an existing Project model.
* If deletion is successful, the browser will be redirected to the 'index' page.
*
* @param integer $id
*
* @return mixed
*/
public function actionDelete($id)
{
$this->findModel($id)
->delete();
return $this->redirect([ 'index' ]);
|
36d1807a
Yarik
Big commit.
|
167
|
}
|
cc658b4c
Yarik
Big commit
|
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
194
195
|
public function actionDelimg($id)
{
$model = ProjectImage::findOne($id);
if(empty( $model )) {
throw new NotFoundHttpException();
}
$model->delete();
return '1';
}
public function actionProduct($id)
{
$model = $this->findModel($id);
$searchModel = new ProductToProjectSearch();
$dataProvider = $searchModel->search(\Yii::$app->request->queryParams);
return $this->render('product', [
'project' => $model,
'searchModel' => $searchModel,
'dataProvider' => $dataProvider,
]);
}
public function actionProductCreate($id)
{
$project = $this->findModel($id);
$model = new ProductToProject();
$products = Product::find()
|
93c267f7
Yarik
Multilanguage big...
|
196
|
->distinct()
|
cc658b4c
Yarik
Big commit
|
197
|
->select([
|
96410438
Yarik
Project admin com...
|
198
|
'product_lang.name',
|
cc658b4c
Yarik
Big commit
|
199
200
201
|
'product.product_id',
])
->joinWith('variants', true, 'INNER JOIN')
|
96410438
Yarik
Project admin com...
|
202
|
->joinWith('lang', true, 'INNER JOIN')
|
cc658b4c
Yarik
Big commit
|
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
|
->indexBy('product_id')
->asArray()
->column();
$variants = [];
if($model->load(\Yii::$app->request->post())) {
$model->project_id = $project->project_id;
if($model->save()) {
return $this->redirect([
'product',
'id' => $id,
]);
} else {
if(!empty( $model->product_id ) && !empty( $products[ $model->product_id ] )) {
$variants = ProductVariant::find()
->select([
|
96410438
Yarik
Project admin com...
|
218
219
|
'product_variant_lang.name',
'product_variant.product_variant_id',
|
cc658b4c
Yarik
Big commit
|
220
|
])
|
96410438
Yarik
Project admin com...
|
221
222
|
->joinWith('lang', true, 'INNER JOIN')
->where([ 'product_variant.product_id' => $model->product_id ])
|
cc658b4c
Yarik
Big commit
|
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
|
->asArray()
->indexBy('product_variant_id')
->column();
}
}
}
return $this->render('product-create', [
'project' => $project,
'model' => $model,
'products' => $products,
'variants' => $variants,
]);
}
public function actionProductUpdate($id, $product_to_project_id)
{
$project = $this->findModel($id);
$model = ProductToProject::find()
->with('product')
->where([ 'product_to_project_id' => $product_to_project_id ])
->one();
if(empty( $model )) {
throw new NotFoundHttpException();
}
$model->product_id = $model->product->product_id;
if($model->load(\Yii::$app->request->post())) {
$model->project_id = $project->project_id;
if($model->save()) {
return $this->redirect([
'product',
'id' => $id,
]);
}
}
$products = Product::find()
->select([
|
96410438
Yarik
Project admin com...
|
259
|
'product_lang.name',
|
cc658b4c
Yarik
Big commit
|
260
261
262
|
'product.product_id',
])
->joinWith('variants', true, 'INNER JOIN')
|
96410438
Yarik
Project admin com...
|
263
|
->joinWith('lang', true, 'INNER JOIN')
|
cc658b4c
Yarik
Big commit
|
264
265
266
267
268
269
270
|
->indexBy('product_id')
->asArray()
->column();
$variants = [];
if(!empty( $model->product_id ) && !empty( $products[ $model->product_id ] )) {
$variants = ProductVariant::find()
->select([
|
96410438
Yarik
Project admin com...
|
271
272
|
'product_variant_lang.name',
'product_variant.product_variant_id',
|
cc658b4c
Yarik
Big commit
|
273
|
])
|
96410438
Yarik
Project admin com...
|
274
275
|
->joinWith('lang', true, 'INNER JOIN')
->where([ 'product_variant.product_id' => $model->product_id ])
|
cc658b4c
Yarik
Big commit
|
276
277
278
279
280
281
282
283
284
285
286
287
288
289
|
->asArray()
->indexBy('product_variant_id')
->column();
}
return $this->render('product-create', [
'project' => $project,
'model' => $model,
'products' => $products,
'variants' => $variants,
]);
}
public function actionProductDelete($product_to_project_id)
{
|
d55d2fe0
Yarik
Multilanguage
|
290
291
292
293
|
$model = ProductToProject::find()
->where([ 'product_to_project_id' => $product_to_project_id ])
->one();
if(empty( $model )) {
|
cc658b4c
Yarik
Big commit
|
294
295
296
297
|
throw new NotFoundHttpException();
}
$project_id = $model->project_id;
$model->delete();
|
d55d2fe0
Yarik
Multilanguage
|
298
299
300
301
|
return $this->redirect([
'project/product',
'id' => $project_id,
]);
|
cc658b4c
Yarik
Big commit
|
302
303
304
305
306
307
308
|
}
public function actionGetVariants($product_id)
{
$response = \Yii::$app->response;
$response->format = $response::FORMAT_JSON;
$product = Product::find()
|
96410438
Yarik
Project admin com...
|
309
310
|
->joinWith('variants.lang', true, 'INNER JOIN')
->where([ 'product.product_id' => $product_id ])
|
cc658b4c
Yarik
Big commit
|
311
312
313
314
|
->one();
if(empty( $product ) || empty( $product->variants )) {
throw new NotFoundHttpException();
}
|
96410438
Yarik
Project admin com...
|
315
316
317
318
319
320
321
|
$variants = ArrayHelper::toArray($product->variants, [
'common\modules\product\models\ProductVariant' => [
'product_variant_id',
'lang',
],
]);
return $variants;
|
cc658b4c
Yarik
Big commit
|
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
|
}
/**
* Finds the Project model based on its primary key value.
* If the model is not found, a 404 HTTP exception will be thrown.
*
* @param integer $id
*
* @return Project the loaded model
* @throws NotFoundHttpException if the model cannot be found
*/
protected function findModel($id)
{
if(( $model = Project::findOne($id) ) !== NULL) {
return $model;
} else {
throw new NotFoundHttpException('The requested page does not exist.');
}
|
36d1807a
Yarik
Big commit.
|
340
341
|
}
}
|