Commit 713ccea42a2a0618753db6f55cf5d6b3fa95fc15
1 parent
8f1a5501
test
Showing
8 changed files
with
170 additions
and
12 deletions
Show diff stats
common/models/FeedbackCompany.php
common/models/FeedbackCompanySearch.php
... | ... | @@ -12,6 +12,10 @@ |
12 | 12 | class FeedbackCompanySearch extends FeedbackCompany |
13 | 13 | { |
14 | 14 | |
15 | + public $date_add_from; | |
16 | + | |
17 | + public $date_add_to; | |
18 | + | |
15 | 19 | /** |
16 | 20 | * @inheritdoc |
17 | 21 | */ |
... | ... | @@ -23,10 +27,21 @@ |
23 | 27 | 'name', |
24 | 28 | 'date_add', |
25 | 29 | 'phone', |
26 | - 'status', | |
30 | + 'date_add_from', | |
31 | + 'date_add_to', | |
27 | 32 | ], |
28 | 33 | 'safe', |
29 | 34 | ], |
35 | + [ | |
36 | + [ 'status' ], | |
37 | + 'integer', | |
38 | + ], | |
39 | + [ | |
40 | + 'date_add_to', | |
41 | + 'compare', | |
42 | + 'compareAttribute' => 'date_add_from', | |
43 | + 'operator' => '>=', | |
44 | + ], | |
30 | 45 | ]; |
31 | 46 | } |
32 | 47 | |
... | ... | @@ -55,7 +70,37 @@ |
55 | 70 | 'like', |
56 | 71 | 'LOWER(phone)', |
57 | 72 | mb_strtolower($this->phone), |
58 | - ]); | |
73 | + ]) | |
74 | + ->andFilterWhere([ 'status' => $this->status ]); | |
75 | + | |
76 | + $date_add_from = $this->date_add_from; | |
77 | + $date_add_to = $this->date_add_to; | |
78 | + if(!empty( $date_add_from )) { | |
79 | + $date_add_from = strtotime($date_add_from); | |
80 | + } | |
81 | + if(!empty( $date_add_to )) { | |
82 | + $date_add_to = strtotime($date_add_to) + 86400; | |
83 | + } | |
84 | + if(!empty( $date_add_from ) && !empty( $date_add_to )) { | |
85 | + $query->andWhere([ | |
86 | + 'between', | |
87 | + 'date_add', | |
88 | + $date_add_from, | |
89 | + $date_add_to, | |
90 | + ]); | |
91 | + } elseif(!empty( $date_add_from )) { | |
92 | + $query->andWhere([ | |
93 | + '>=', | |
94 | + 'date_add', | |
95 | + $date_add_from, | |
96 | + ]); | |
97 | + } elseif(!empty( $date_add_to )) { | |
98 | + $query->andWhere([ | |
99 | + '<=', | |
100 | + 'date_add', | |
101 | + $date_add_to, | |
102 | + ]); | |
103 | + } | |
59 | 104 | |
60 | 105 | return $dataProvider; |
61 | 106 | ... | ... |
common/modules/fileloader/models/Fileloader.php
common/modules/fileloader/resources/handler.js
frontend/controllers/AccountsController.php
... | ... | @@ -42,6 +42,7 @@ |
42 | 42 | use yii\filters\VerbFilter; |
43 | 43 | use yii\web\Controller; |
44 | 44 | use yii\web\NotFoundHttpException; |
45 | + use yii\web\Response; | |
45 | 46 | use yii\web\UploadedFile; |
46 | 47 | |
47 | 48 | /** |
... | ... | @@ -76,6 +77,7 @@ |
76 | 77 | 'blog-delete' => [ 'POST' ], |
77 | 78 | 'gallery-cover' => [ 'POST' ], |
78 | 79 | 'feedback-delete' => [ 'POST' ], |
80 | + 'feedback-read' => [ 'POST' ], | |
79 | 81 | ], |
80 | 82 | ], |
81 | 83 | ]; |
... | ... | @@ -89,7 +91,14 @@ |
89 | 91 | 'status' => 2, |
90 | 92 | ]) |
91 | 93 | ->count(); |
94 | + $feedback_company_count = FeedbackCompany::find() | |
95 | + ->where([ | |
96 | + 'user_id' => \Yii::$app->user->id, | |
97 | + 'status' => FeedbackCompany::STATUS_NEW, | |
98 | + ]) | |
99 | + ->count(); | |
92 | 100 | $this->view->params[ 'portfolio_user_count' ] = $portfolio_user_count; |
101 | + $this->view->params[ 'feedback_company_count' ] = $feedback_company_count; | |
93 | 102 | return parent::beforeAction($action); // TODO: Change the autogenerated stub |
94 | 103 | } |
95 | 104 | |
... | ... | @@ -297,6 +306,15 @@ |
297 | 306 | { |
298 | 307 | $searchModel = new FeedbackCompanySearch(); |
299 | 308 | $dataProvider = $searchModel->search(Yii::$app->request->queryParams); |
309 | + $dataProvider->pagination = [ | |
310 | + 'pageSize' => 20, | |
311 | + ]; | |
312 | + $dataProvider->sort = new Sort([ | |
313 | + 'defaultOrder' => [ | |
314 | + 'status' => SORT_ASC, | |
315 | + 'date_add' => SORT_DESC, | |
316 | + ], | |
317 | + ]); | |
300 | 318 | |
301 | 319 | return $this->render('feedback-company', [ |
302 | 320 | 'searchModel' => $searchModel, |
... | ... | @@ -306,7 +324,12 @@ |
306 | 324 | |
307 | 325 | /** |
308 | 326 | * Delete company feedback |
309 | - * @return string | |
327 | + * | |
328 | + * @param int $id | |
329 | + * | |
330 | + * @return Response | |
331 | + * @throws NotFoundHttpException | |
332 | + * @throws \Exception | |
310 | 333 | */ |
311 | 334 | public function actionFeedbackDelete($id) |
312 | 335 | { |
... | ... | @@ -317,11 +340,41 @@ |
317 | 340 | ]) |
318 | 341 | ->one(); |
319 | 342 | |
320 | - if(empty($model)) { | |
343 | + if(empty( $model )) { | |
321 | 344 | throw new NotFoundHttpException('Заявка не найдена'); |
322 | 345 | } else { |
323 | 346 | $model->delete(); |
324 | - return $this->redirect(['accounts/feedback-company']); | |
347 | + return $this->redirect([ 'accounts/feedback-company' ]); | |
348 | + } | |
349 | + } | |
350 | + | |
351 | + /** | |
352 | + * Mark feedback as read | |
353 | + * | |
354 | + * @param int $id | |
355 | + * | |
356 | + * @return Response | |
357 | + * @throws NotFoundHttpException | |
358 | + */ | |
359 | + public function actionFeedbackRead($id) | |
360 | + { | |
361 | + $model = FeedbackCompany::find() | |
362 | + ->where([ | |
363 | + 'feedback_company_id' => $id, | |
364 | + 'user_id' => \Yii::$app->user->id, | |
365 | + ]) | |
366 | + ->andWhere([ | |
367 | + 'not', | |
368 | + [ 'status' => FeedbackCompany::STATUS_READ ], | |
369 | + ]) | |
370 | + ->one(); | |
371 | + | |
372 | + if(empty( $model )) { | |
373 | + throw new NotFoundHttpException('Заявка не найдена'); | |
374 | + } else { | |
375 | + $model->status = FeedbackCompany::STATUS_READ; | |
376 | + $model->save(false); | |
377 | + return $this->redirect([ 'accounts/feedback-company' ]); | |
325 | 378 | } |
326 | 379 | } |
327 | 380 | ... | ... |
frontend/views/accounts/feedback-company.php
... | ... | @@ -5,6 +5,7 @@ |
5 | 5 | use yii\grid\GridView; |
6 | 6 | use yii\grid\SerialColumn; |
7 | 7 | use yii\helpers\Html; |
8 | + use yii\jui\DatePicker; | |
8 | 9 | use yii\web\View; |
9 | 10 | |
10 | 11 | /** |
... | ... | @@ -25,17 +26,52 @@ |
25 | 26 | [ 'class' => SerialColumn::className() ], |
26 | 27 | [ |
27 | 28 | 'attribute' => 'date_add', |
28 | - 'value' => function($model, $key) { | |
29 | + 'filter' => "<div class=\"input-group input-group-xs input-daterange\"> | |
30 | +<span class='field-teamsearch-experience_from_from'>" . DatePicker::widget([ | |
31 | + 'model' => $searchModel, | |
32 | + 'attribute' => 'date_add_from', | |
33 | + 'language' => 'ru', | |
34 | + 'dateFormat' => 'yyyy-MM-dd', | |
35 | + 'clientOptions' => [ | |
36 | + 'changeYear' => true, | |
37 | + 'changeMonth' => true, | |
38 | + 'maxDate' => ($searchModel->date_add_to?:date('Y-m-d')), | |
39 | + ], | |
40 | + ]) . "</span> | |
41 | +<span class=\"input-group-addon kv-field-separator\"> | |
42 | +<i class=\"glyphicon glyphicon-resize-horizontal\"></i> | |
43 | +</span> | |
44 | +<span class='field-teamsearch-experience_from_to'>" . DatePicker::widget([ | |
45 | + 'model' => $searchModel, | |
46 | + 'attribute' => 'date_add_to', | |
47 | + 'language' => 'ru', | |
48 | + 'dateFormat' => 'yyyy-MM-dd', | |
49 | + 'clientOptions' => [ | |
50 | + 'changeYear' => true, | |
51 | + 'changeMonth' => true, | |
52 | + 'minDate' => $searchModel->date_add_from, | |
53 | + 'maxDate' => date('Y-m-d'), | |
54 | + ], | |
55 | + ]) . "</span> | |
56 | +</div>", | |
57 | + 'value' => function($model, $key) { | |
29 | 58 | return date('Y-m-d H:i:s', $model->date_add); |
30 | - } | |
59 | + }, | |
31 | 60 | ], |
32 | 61 | [ |
33 | 62 | 'attribute' => 'name', |
34 | - 'label' => 'Имя и фамилия', | |
63 | + 'label' => 'Имя и фамилия', | |
35 | 64 | ], |
36 | 65 | 'phone', |
37 | 66 | [ |
38 | 67 | 'attribute' => 'status', |
68 | + 'filter' => [ | |
69 | + 1 => 'Только непрочитанные', | |
70 | + ], | |
71 | + 'filterInputOptions' => [ | |
72 | + 'prompt' => 'Все записи', | |
73 | + 'class' => 'form-control', | |
74 | + ], | |
39 | 75 | ], |
40 | 76 | [ |
41 | 77 | 'class' => ActionColumn::className(), |
... | ... | @@ -54,8 +90,26 @@ |
54 | 90 | 'data-pjax' => 0, |
55 | 91 | ]); |
56 | 92 | }, |
93 | + 'read' => function($url, $model, $key) { | |
94 | + if($model->status == $model::STATUS_NEW) { | |
95 | + return Html::a(Html::tag('span', '', [ | |
96 | + 'class' => 'glyphicon glyphicon-ok', | |
97 | + ]), [ | |
98 | + 'accounts/feedback-read', | |
99 | + 'id' => $model->feedback_company_id, | |
100 | + ], [ | |
101 | + 'title' => 'Прочесть', | |
102 | + 'aria-label' => 'Прочесть', | |
103 | + 'data-confirm' => 'Вы уверены, что хотите отметить заявку прочтенной?', | |
104 | + 'data-method' => 'post', | |
105 | + 'data-pjax' => 0, | |
106 | + ]); | |
107 | + } else { | |
108 | + return false; | |
109 | + } | |
110 | + }, | |
57 | 111 | ], |
58 | - 'template' => '{delete}', | |
112 | + 'template' => '{read}{delete}', | |
59 | 113 | ], |
60 | 114 | ], |
61 | 115 | ]); ?> | ... | ... |
frontend/views/company/portfolio-view.php
... | ... | @@ -121,7 +121,9 @@ |
121 | 121 | <?php |
122 | 122 | foreach($portfolio->ShowGallery($portfolio->gallery->photo) as $one_photo) { |
123 | 123 | ?> |
124 | - <li><img src="<?= $one_photo ?>" alt=""/></li> | |
124 | + <li> | |
125 | + <img src="<?= $portfolio->minImg($one_photo, 210, 150) ?>" alt=""/> | |
126 | + </li> | |
125 | 127 | <?php |
126 | 128 | } |
127 | 129 | ?> | ... | ... |
frontend/views/layouts/admin.php
... | ... | @@ -111,8 +111,9 @@ |
111 | 111 | 'url' => [ 'accounts/vacancy' ], |
112 | 112 | 'active' => preg_match('/^vacancy.*$/', $this->context->action->id) ? true : false, |
113 | 113 | ], [ |
114 | - 'label' => 'Заявки', | |
114 | + 'label' => "Заявки <span class='ico_num'>{$this->params['feedback_company_count']}</span>", | |
115 | 115 | 'url' => [ 'accounts/feedback-company' ], |
116 | + 'encode' => false, | |
116 | 117 | ]); |
117 | 118 | |
118 | 119 | } | ... | ... |