Blame view

frontend/controllers/CompanyController.php 15.3 KB
fbdb1f1c   Yarik   test
1
  <?php
fa284ab0   Yarik   test
2
3
4
5
6
7
8
9
10
11
12
13
14
15
      namespace frontend\controllers;
  
      use common\models\Blog;
      use common\models\Fields;
      use common\models\Gallery;
      use common\models\Portfolio;
      use common\models\PortfolioSpecialization;
      use common\models\Team;
      use common\models\Vacancy;
      use common\models\VacancySpecialization;
      use Yii;
      use yii\data\ActiveDataProvider;
      use yii\data\ArrayDataProvider;
      use yii\data\Pagination;
225c5168   Yarik   test
16
      use yii\data\Sort;
fa284ab0   Yarik   test
17
18
19
20
      use yii\helpers\ArrayHelper;
      use yii\web\BadRequestHttpException;
      use yii\web\Controller;
      use common\models\User;
225c5168   Yarik   test
21
      use yii\web\NotFoundHttpException;
fbdb1f1c   Yarik   test
22
23
  
      /**
fa284ab0   Yarik   test
24
       * Site controller
fbdb1f1c   Yarik   test
25
       */
fa284ab0   Yarik   test
26
      class CompanyController extends Controller
fbdb1f1c   Yarik   test
27
      {
fbdb1f1c   Yarik   test
28
  
fa284ab0   Yarik   test
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
          public $layout = 'company';
  
          public $defaultAction = 'common';
  
          /**
           * @inheritdoc
           */
          public function actions()
          {
              return [
                  'error'   => [
                      'class' => 'yii\web\ErrorAction',
                  ],
                  'captcha' => [
                      'class'           => 'yii\captcha\CaptchaAction',
                      'fixedVerifyCode' => YII_ENV_TEST ? 'testme' : NULL,
                  ],
              ];
d36bdac6   Administrator   17.02.16
47
          }
d36bdac6   Administrator   17.02.16
48
  
5014e10b   Yarik   test
49
          public function actionCommon($company_id, $type = 'implementer')
fa284ab0   Yarik   test
50
          {
225c5168   Yarik   test
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
              /**
               * @var User $company
               */
              if(!$company = User::find()
                                 ->where([ 'id' => $company_id ])
                                 ->with('teams')
                                 ->with('teams.department')
                                 ->with('userInfo')
                                 ->with('companyInfo')
                                 ->one()
              ) {
                  throw new NotFoundHttpException('Компания не найдена');
              }
  
              $projectProvider = new ActiveDataProvider([
                  'query' => $company->getProjects(),
              ]);
fa284ab0   Yarik   test
68
  
225c5168   Yarik   test
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
              $blogProvider = new ActiveDataProvider([
                  'query'      => $company->getBlog()
                                          ->with('comments'),
                  'sort'       => new Sort([
                      'defaultOrder' => [
                          'date_add' => SORT_DESC,
                          'name'     => SORT_ASC,
                      ],
                  ]),
                  'pagination' => new Pagination([
                      'pageSize'  => 2,
                      'pageParam' => '',
                  ]),
              ]);
  
              $commentProvider = new ActiveDataProvider([
110087c2   Yarik   test
85
86
87
                  'query'      => $company->getComments()
                                          ->with('rating')
                                          ->with('author'),
225c5168   Yarik   test
88
89
90
91
92
93
94
95
96
97
                  'sort'       => new Sort([
                      'defaultOrder' => [
                          'date_add' => SORT_DESC,
                      ],
                  ]),
                  'pagination' => new Pagination([
                      'pageSize'  => 4,
                      'pageParam' => '',
                  ]),
              ]);
fa284ab0   Yarik   test
98
99
  
              return $this->render('common', [
225c5168   Yarik   test
100
101
102
103
                  'company'         => $company,
                  'projectProvider' => $projectProvider,
                  'blogProvider'    => $blogProvider,
                  'commentProvider' => $commentProvider,
fa284ab0   Yarik   test
104
105
              ]);
          }
d36bdac6   Administrator   17.02.16
106
  
76f36646   Yarik   test
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
          public function actionProjects($company_id, $type = 'implementer')
          {
              $company = User::findOne($company_id);
  
              if(!$company instanceof User) {
                  throw new BadRequestHttpException('Пользователь не найден');
              }
  
              $dataProvider = new ActiveDataProvider([
                  'query'      => $company->getProjects(),
                  'pagination' => [
                      'pageSize' => 10,
                  ],
              ]);
  
              return $this->render('project-list', [
                  'company'         => $company,
                  'dataProvider' => $dataProvider,
              ]);
          }
  
5014e10b   Yarik   test
128
          public function actionPortfolio($company_id, $type = 'implementer')
fa284ab0   Yarik   test
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
          {
              $company = User::findOne($company_id);
  
              if(!$company instanceof User) {
                  throw new BadRequestHttpException('Пользователь не найден');
              }
              $projects = ArrayHelper::getColumn($company->portfolios, 'portfolio_id');
  
              $filters = PortfolioSpecialization::find()
                                                ->select([
                                                    "specialization_id",
                                                    "COUNT('specialization_id') AS count",
                                                ])
                                                ->where([ "portfolio_id" => $projects ])
                                                ->groupBy("specialization_id")
                                                ->all();
  
              $portfolio = new ArrayDataProvider([
                  'allModels'  => $company->getPortfolios()
                                          ->orderBy('portfolio_id')
                                          ->all(),
                  'pagination' => [
                      'pageSize' => 9,
                  ],
              ]);
  
              return $this->render('portfolio', [
                  'company'   => $company,
                  'filters'   => $filters,
                  'portfolio' => $portfolio,
                  'count'     => count($company->portfolios),
              ]);
d36bdac6   Administrator   17.02.16
161
162
          }
  
5014e10b   Yarik   test
163
          public function actionPortfolioFilter($performer_id, $filter, $type = 'implementer')
fa284ab0   Yarik   test
164
165
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
194
195
196
197
198
199
200
201
202
203
204
          {
              $company = User::findOne($performer_id);
  
              if(!$company instanceof User) {
                  throw new BadRequestHttpException('Пользователь не найден');
              }
              $portfolios = ArrayHelper::getColumn($company->portfolios, 'portfolio_id');
  
              $filters = PortfolioSpecialization::find()
                                                ->select([
                                                    "specialization_id",
                                                    "COUNT('specialization_id') AS count",
                                                ])
                                                ->where([ "portfolio_id" => $portfolios ])
                                                ->groupBy("specialization_id")
                                                ->all();
  
              $filter_result = PortfolioSpecialization::find()
                                                      ->where([
                                                          'specialization_id' => $filter,
                                                          'portfolio_id'      => $portfolios,
                                                      ])
                                                      ->all();
  
              $portfolio = new ArrayDataProvider([
                  'allModels'  => Portfolio::find()
                                           ->where([ 'portfolio_id' => ArrayHelper::getColumn($filter_result, 'portfolio_id') ])
                                           ->all(),
                  'pagination' => [
                      'pageSize' => 9,
                  ],
              ]);
  
              return $this->render('portfolio', [
                  'company'   => $company,
                  'filters'   => $filters,
                  'portfolio' => $portfolio,
                  'filter_id' => $filter,
                  'count'     => count($company->portfolios),
              ]);
          }
d36bdac6   Administrator   17.02.16
205
  
5014e10b   Yarik   test
206
          public function actionPortfolioView($company_id, $portfolio_id, $type = 'implementer')
fa284ab0   Yarik   test
207
208
209
210
211
212
213
214
215
216
217
          {
              $user = User::findOne($company_id);
              $portfolio = $user->getPortfolios()
                                ->where([ 'portfolio_id' => $portfolio_id ])
                                ->one();
              $portfolio->updateCounters([ 'view_count' => 1 ]);
              return $this->render('portfolio-view', [
                  'user'      => $user,
                  'portfolio' => $portfolio,
              ]);
          }
d36bdac6   Administrator   17.02.16
218
  
5014e10b   Yarik   test
219
          public function actionTeam($company_id, $type = 'implementer')
fa284ab0   Yarik   test
220
221
          {
              $company = User::findOne($company_id);
fa284ab0   Yarik   test
222
223
224
              if(!$company instanceof User) {
                  throw new BadRequestHttpException('Пользователь не найден');
              }
a020aad3   Yarik   test
225
              $comments = new ActiveDataProvider([
225c5168   Yarik   test
226
                  'query'      => $company->getComments(),
a020aad3   Yarik   test
227
                  'pagination' => [
225c5168   Yarik   test
228
                      'pageSize' => 4,
a020aad3   Yarik   test
229
230
                  ],
              ]);
fa284ab0   Yarik   test
231
232
              $query = Team::find()
                           ->where([ 'user_id' => $company_id ]);
a020aad3   Yarik   test
233
234
235
236
237
              $team = new ActiveDataProvider([
                  'query'      => $query,
                  'pagination' => [
                      'pageSize' => 9,
                  ],
fa284ab0   Yarik   test
238
              ]);
fa284ab0   Yarik   test
239
              return $this->render('team', [
a020aad3   Yarik   test
240
241
242
                  'company'  => $company,
                  'team'     => $team,
                  'comments' => $comments,
fa284ab0   Yarik   test
243
              ]);
d36bdac6   Administrator   17.02.16
244
245
          }
  
5014e10b   Yarik   test
246
          public function actionBlogList($company_id, $type = 'implementer')
fa284ab0   Yarik   test
247
248
          {
              $company = User::findOne($company_id);
d36bdac6   Administrator   17.02.16
249
  
fa284ab0   Yarik   test
250
251
252
              if(!$company instanceof User) {
                  throw new BadRequestHttpException('Пользователь не найден');
              }
d36bdac6   Administrator   17.02.16
253
  
fa284ab0   Yarik   test
254
255
              $query = Blog::find()
                           ->where([ 'user_id' => $company_id ]);
d36bdac6   Administrator   17.02.16
256
  
fa284ab0   Yarik   test
257
              $countQuery = clone $query;
d36bdac6   Administrator   17.02.16
258
  
fa284ab0   Yarik   test
259
260
261
262
              $pagination = new Pagination([
                  'totalCount' => $countQuery->count(),
                  'pageSize'   => 5,
              ]);
d36bdac6   Administrator   17.02.16
263
  
fa284ab0   Yarik   test
264
265
              $article = $query->offset($pagination->offset)
                               ->limit($pagination->limit)
4ff3ca88   Yarik   test
266
                               ->with('comments')
fa284ab0   Yarik   test
267
                               ->all();
d36bdac6   Administrator   17.02.16
268
  
fa284ab0   Yarik   test
269
270
271
              $blog = new ArrayDataProvider([
                  'allModels' => $article,
              ]);
f6ea8941   Administrator   09.02.16
272
  
fa284ab0   Yarik   test
273
274
275
276
277
              return $this->render('blog-list', [
                  'company'    => $company,
                  'blog'       => $blog,
                  'pagination' => $pagination,
              ]);
d36bdac6   Administrator   17.02.16
278
279
          }
  
5014e10b   Yarik   test
280
          public function actionBlogView($company_id, $link, $type = 'implementer')
fa284ab0   Yarik   test
281
282
          {
              $company = User::findOne($company_id);
d36bdac6   Administrator   17.02.16
283
  
fa284ab0   Yarik   test
284
285
286
              if(!$company instanceof User) {
                  throw new BadRequestHttpException('Пользователь не найден');
              }
d36bdac6   Administrator   17.02.16
287
  
4ff3ca88   Yarik   test
288
289
290
291
292
293
294
295
              $article = Blog::find()
                             ->where([
                                 'link'    => $link,
                                 'user_id' => $company_id,
                             ])
                             ->with('comments')
                             ->one();
              $article->updateCounters([ 'view_count' => 1 ]);
d36bdac6   Administrator   17.02.16
296
  
fa284ab0   Yarik   test
297
298
299
              return $this->render('blog-view', [
                  'company' => $company,
                  'article' => $article,
d36bdac6   Administrator   17.02.16
300
  
fa284ab0   Yarik   test
301
302
              ]);
          }
eb7e82fb   Administrator   29.02.16
303
  
5014e10b   Yarik   test
304
          public function actionReview($company_id, $type = 'implementer')
fa284ab0   Yarik   test
305
306
          {
              $company = User::findOne($company_id);
eb7e82fb   Administrator   29.02.16
307
  
fa284ab0   Yarik   test
308
309
310
              return $this->render('review', [
                  'company' => $company,
              ]);
eb7e82fb   Administrator   29.02.16
311
312
          }
  
5014e10b   Yarik   test
313
          public function actionVacancyList($company_id, $type = 'implementer')
fa284ab0   Yarik   test
314
          {
eb7e82fb   Administrator   29.02.16
315
  
fa284ab0   Yarik   test
316
              $company = User::findOne($company_id);
eb7e82fb   Administrator   29.02.16
317
  
fa284ab0   Yarik   test
318
319
320
              if(!$company instanceof User) {
                  throw new BadRequestHttpException('Пользователь не найден');
              }
eb7e82fb   Administrator   29.02.16
321
  
fa284ab0   Yarik   test
322
              $query = $company->getVacancies();
eb7e82fb   Administrator   29.02.16
323
  
fa284ab0   Yarik   test
324
              $provider = new ActiveDataProvider([
a020aad3   Yarik   test
325
326
327
328
                  'query'      => $query,
                  'pagination' => [
                      'pageSize' => 5,
                  ],
fa284ab0   Yarik   test
329
330
331
332
333
334
335
                  'sort'       => [
                      'defaultOrder' => [
                          'date_add' => SORT_DESC,
                          'name'     => SORT_ASC,
                      ],
                  ],
              ]);
eb7e82fb   Administrator   29.02.16
336
  
fa284ab0   Yarik   test
337
              return $this->render('vacancy-list', [
a020aad3   Yarik   test
338
339
                  'company'  => $company,
                  'provider' => $provider,
fa284ab0   Yarik   test
340
              ]);
eb7e82fb   Administrator   29.02.16
341
  
fa284ab0   Yarik   test
342
          }
eb7e82fb   Administrator   29.02.16
343
  
5014e10b   Yarik   test
344
          public function actionVacancyView($company_id, $link, $type = 'implementer')
fa284ab0   Yarik   test
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
          {
              $company = User::findOne($company_id);
              $vacancy = $company->getVacancies()
                                 ->where([ 'link' => $link ])
                                 ->with([
                                     'employments',
                                     'specializations',
                                 ])
                                 ->one();
  
              $specialization_id = $vacancy->getSpecializations()
                                           ->select('specialization_id')
                                           ->column();
  
              $vacancy_id = VacancySpecialization::find()
                                                 ->where([ 'specialization_id' => $specialization_id ])
                                                 ->select('vacancy_id')
                                                 ->column();
  
              $similar_vacancies = Vacancy::find()
                                          ->where([
                                              'city'       => $vacancy->city,
                                              'vacancy_id' => $vacancy_id,
                                          ])
                                          ->andFilterWhere([
                                              '<>',
                                              'vacancy_id',
                                              $vacancy->vacancy_id,
                                          ])
                                          ->orderBy([ 'vacancy_id' => SORT_DESC ])
                                          ->limit(3)
                                          ->all();
  
              return $this->render('vacancy-view', [
                  'company'           => $company,
                  'vacancy'           => $vacancy,
                  'similar_vacancies' => $similar_vacancies,
              ]);
          }
fbdb1f1c   Yarik   test
384
  
5014e10b   Yarik   test
385
          public function actionGallery($company_id, $type = 'implementer')
fa284ab0   Yarik   test
386
387
          {
              $company = User::findOne($company_id);
f6ea8941   Administrator   09.02.16
388
  
fa284ab0   Yarik   test
389
390
391
              if(!$company instanceof User) {
                  throw new BadRequestHttpException('Пользователь не найден');
              }
cda2c1c9   Administrator   add yii jquery
392
  
fa284ab0   Yarik   test
393
394
              $query = Gallery::find()
                              ->where([ 'user_id' => $company_id ]);
cda2c1c9   Administrator   add yii jquery
395
  
fa284ab0   Yarik   test
396
              $countQuery = clone $query;
cda2c1c9   Administrator   add yii jquery
397
  
fa284ab0   Yarik   test
398
399
400
401
              $pagination = new Pagination([
                  'totalCount' => $countQuery->count(),
                  'pageSize'   => 5,
              ]);
cda2c1c9   Administrator   add yii jquery
402
  
fa284ab0   Yarik   test
403
404
405
              $gallery = $query->offset($pagination->offset)
                               ->limit($pagination->limit)
                               ->all();
cda2c1c9   Administrator   add yii jquery
406
  
fa284ab0   Yarik   test
407
408
409
              $gallery = new ArrayDataProvider([
                  'allModels' => $gallery,
              ]);
fbdb1f1c   Yarik   test
410
  
fa284ab0   Yarik   test
411
              $videos = Fields::getData($company->id, Gallery::className(), 'youtube');
d36bdac6   Administrator   17.02.16
412
  
fa284ab0   Yarik   test
413
              $this->layout = 'gallery-company';
f6ea8941   Administrator   09.02.16
414
  
fa284ab0   Yarik   test
415
416
417
418
419
420
              return $this->render('gallery', [
                  'company'    => $company,
                  'gallery'    => $gallery,
                  'pagination' => $pagination,
                  'videos'     => $videos,
              ]);
d36bdac6   Administrator   17.02.16
421
          }
76f36646   Yarik   test
422
423
424
425
426
427
428
429
  
          public function beforeAction($action)
          {
              if(!empty(\Yii::$app->request->get('type'))) {
                  $action->controller->view->params['type'] = \Yii::$app->request->get('type');
              }
              return parent::beforeAction($action);
          }
fbdb1f1c   Yarik   test
430
      }