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
|
|
5014e10b
Yarik
test
|
107
|
public function actionPortfolio($company_id, $type = 'implementer')
|
fa284ab0
Yarik
test
|
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
|
{
$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
|
140
141
|
}
|
5014e10b
Yarik
test
|
142
|
public function actionPortfolioFilter($performer_id, $filter, $type = 'implementer')
|
fa284ab0
Yarik
test
|
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
|
{
$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
|
184
|
|
5014e10b
Yarik
test
|
185
|
public function actionPortfolioView($company_id, $portfolio_id, $type = 'implementer')
|
fa284ab0
Yarik
test
|
186
187
188
189
190
191
192
193
194
195
196
|
{
$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
|
197
|
|
5014e10b
Yarik
test
|
198
|
public function actionTeam($company_id, $type = 'implementer')
|
fa284ab0
Yarik
test
|
199
200
|
{
$company = User::findOne($company_id);
|
fa284ab0
Yarik
test
|
201
202
203
|
if(!$company instanceof User) {
throw new BadRequestHttpException('Пользователь не найден');
}
|
a020aad3
Yarik
test
|
204
|
$comments = new ActiveDataProvider([
|
225c5168
Yarik
test
|
205
|
'query' => $company->getComments(),
|
a020aad3
Yarik
test
|
206
|
'pagination' => [
|
225c5168
Yarik
test
|
207
|
'pageSize' => 4,
|
a020aad3
Yarik
test
|
208
209
|
],
]);
|
fa284ab0
Yarik
test
|
210
211
|
$query = Team::find()
->where([ 'user_id' => $company_id ]);
|
a020aad3
Yarik
test
|
212
213
214
215
216
|
$team = new ActiveDataProvider([
'query' => $query,
'pagination' => [
'pageSize' => 9,
],
|
fa284ab0
Yarik
test
|
217
|
]);
|
fa284ab0
Yarik
test
|
218
|
return $this->render('team', [
|
a020aad3
Yarik
test
|
219
220
221
|
'company' => $company,
'team' => $team,
'comments' => $comments,
|
fa284ab0
Yarik
test
|
222
|
]);
|
d36bdac6
Administrator
17.02.16
|
223
224
|
}
|
5014e10b
Yarik
test
|
225
|
public function actionBlogList($company_id, $type = 'implementer')
|
fa284ab0
Yarik
test
|
226
227
|
{
$company = User::findOne($company_id);
|
d36bdac6
Administrator
17.02.16
|
228
|
|
fa284ab0
Yarik
test
|
229
230
231
|
if(!$company instanceof User) {
throw new BadRequestHttpException('Пользователь не найден');
}
|
d36bdac6
Administrator
17.02.16
|
232
|
|
fa284ab0
Yarik
test
|
233
234
|
$query = Blog::find()
->where([ 'user_id' => $company_id ]);
|
d36bdac6
Administrator
17.02.16
|
235
|
|
fa284ab0
Yarik
test
|
236
|
$countQuery = clone $query;
|
d36bdac6
Administrator
17.02.16
|
237
|
|
fa284ab0
Yarik
test
|
238
239
240
241
|
$pagination = new Pagination([
'totalCount' => $countQuery->count(),
'pageSize' => 5,
]);
|
d36bdac6
Administrator
17.02.16
|
242
|
|
fa284ab0
Yarik
test
|
243
244
|
$article = $query->offset($pagination->offset)
->limit($pagination->limit)
|
4ff3ca88
Yarik
test
|
245
|
->with('comments')
|
fa284ab0
Yarik
test
|
246
|
->all();
|
d36bdac6
Administrator
17.02.16
|
247
|
|
fa284ab0
Yarik
test
|
248
249
250
|
$blog = new ArrayDataProvider([
'allModels' => $article,
]);
|
f6ea8941
Administrator
09.02.16
|
251
|
|
fa284ab0
Yarik
test
|
252
253
254
255
256
|
return $this->render('blog-list', [
'company' => $company,
'blog' => $blog,
'pagination' => $pagination,
]);
|
d36bdac6
Administrator
17.02.16
|
257
258
|
}
|
5014e10b
Yarik
test
|
259
|
public function actionBlogView($company_id, $link, $type = 'implementer')
|
fa284ab0
Yarik
test
|
260
261
|
{
$company = User::findOne($company_id);
|
d36bdac6
Administrator
17.02.16
|
262
|
|
fa284ab0
Yarik
test
|
263
264
265
|
if(!$company instanceof User) {
throw new BadRequestHttpException('Пользователь не найден');
}
|
d36bdac6
Administrator
17.02.16
|
266
|
|
4ff3ca88
Yarik
test
|
267
268
269
270
271
272
273
274
|
$article = Blog::find()
->where([
'link' => $link,
'user_id' => $company_id,
])
->with('comments')
->one();
$article->updateCounters([ 'view_count' => 1 ]);
|
d36bdac6
Administrator
17.02.16
|
275
|
|
fa284ab0
Yarik
test
|
276
277
278
|
return $this->render('blog-view', [
'company' => $company,
'article' => $article,
|
d36bdac6
Administrator
17.02.16
|
279
|
|
fa284ab0
Yarik
test
|
280
281
|
]);
}
|
eb7e82fb
Administrator
29.02.16
|
282
|
|
5014e10b
Yarik
test
|
283
|
public function actionReview($company_id, $type = 'implementer')
|
fa284ab0
Yarik
test
|
284
285
|
{
$company = User::findOne($company_id);
|
eb7e82fb
Administrator
29.02.16
|
286
|
|
fa284ab0
Yarik
test
|
287
288
289
|
return $this->render('review', [
'company' => $company,
]);
|
eb7e82fb
Administrator
29.02.16
|
290
291
|
}
|
5014e10b
Yarik
test
|
292
|
public function actionVacancyList($company_id, $type = 'implementer')
|
fa284ab0
Yarik
test
|
293
|
{
|
eb7e82fb
Administrator
29.02.16
|
294
|
|
fa284ab0
Yarik
test
|
295
|
$company = User::findOne($company_id);
|
eb7e82fb
Administrator
29.02.16
|
296
|
|
fa284ab0
Yarik
test
|
297
298
299
|
if(!$company instanceof User) {
throw new BadRequestHttpException('Пользователь не найден');
}
|
eb7e82fb
Administrator
29.02.16
|
300
|
|
fa284ab0
Yarik
test
|
301
|
$query = $company->getVacancies();
|
eb7e82fb
Administrator
29.02.16
|
302
|
|
fa284ab0
Yarik
test
|
303
|
$provider = new ActiveDataProvider([
|
a020aad3
Yarik
test
|
304
305
306
307
|
'query' => $query,
'pagination' => [
'pageSize' => 5,
],
|
fa284ab0
Yarik
test
|
308
309
310
311
312
313
314
|
'sort' => [
'defaultOrder' => [
'date_add' => SORT_DESC,
'name' => SORT_ASC,
],
],
]);
|
eb7e82fb
Administrator
29.02.16
|
315
|
|
fa284ab0
Yarik
test
|
316
|
return $this->render('vacancy-list', [
|
a020aad3
Yarik
test
|
317
318
|
'company' => $company,
'provider' => $provider,
|
fa284ab0
Yarik
test
|
319
|
]);
|
eb7e82fb
Administrator
29.02.16
|
320
|
|
fa284ab0
Yarik
test
|
321
|
}
|
eb7e82fb
Administrator
29.02.16
|
322
|
|
5014e10b
Yarik
test
|
323
|
public function actionVacancyView($company_id, $link, $type = 'implementer')
|
fa284ab0
Yarik
test
|
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
|
{
$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
|
363
|
|
5014e10b
Yarik
test
|
364
|
public function actionGallery($company_id, $type = 'implementer')
|
fa284ab0
Yarik
test
|
365
366
|
{
$company = User::findOne($company_id);
|
f6ea8941
Administrator
09.02.16
|
367
|
|
fa284ab0
Yarik
test
|
368
369
370
|
if(!$company instanceof User) {
throw new BadRequestHttpException('Пользователь не найден');
}
|
cda2c1c9
Administrator
add yii jquery
|
371
|
|
fa284ab0
Yarik
test
|
372
373
|
$query = Gallery::find()
->where([ 'user_id' => $company_id ]);
|
cda2c1c9
Administrator
add yii jquery
|
374
|
|
fa284ab0
Yarik
test
|
375
|
$countQuery = clone $query;
|
cda2c1c9
Administrator
add yii jquery
|
376
|
|
fa284ab0
Yarik
test
|
377
378
379
380
|
$pagination = new Pagination([
'totalCount' => $countQuery->count(),
'pageSize' => 5,
]);
|
cda2c1c9
Administrator
add yii jquery
|
381
|
|
fa284ab0
Yarik
test
|
382
383
384
|
$gallery = $query->offset($pagination->offset)
->limit($pagination->limit)
->all();
|
cda2c1c9
Administrator
add yii jquery
|
385
|
|
fa284ab0
Yarik
test
|
386
387
388
|
$gallery = new ArrayDataProvider([
'allModels' => $gallery,
]);
|
fbdb1f1c
Yarik
test
|
389
|
|
fa284ab0
Yarik
test
|
390
|
$videos = Fields::getData($company->id, Gallery::className(), 'youtube');
|
d36bdac6
Administrator
17.02.16
|
391
|
|
fa284ab0
Yarik
test
|
392
|
$this->layout = 'gallery-company';
|
f6ea8941
Administrator
09.02.16
|
393
|
|
fa284ab0
Yarik
test
|
394
395
396
397
398
399
|
return $this->render('gallery', [
'company' => $company,
'gallery' => $gallery,
'pagination' => $pagination,
'videos' => $videos,
]);
|
d36bdac6
Administrator
17.02.16
|
400
|
}
|
fbdb1f1c
Yarik
test
|
401
|
}
|