Commit 8eab7c9f6394e860a333e2434f34f12d8c9d4925
1 parent
b5becf98
test
Showing
7 changed files
with
202 additions
and
36 deletions
Show diff stats
common/modules/comment/Controller.php
... | ... | @@ -100,7 +100,7 @@ |
100 | 100 | if(!empty( $post[ 'comment_id' ] )) { |
101 | 101 | $model = \common\modules\comment\models\Comment::find() |
102 | 102 | ->where([ 'comment_id' => $post[ 'comment_id' ] ]) |
103 | - ->with('parent', 'author') | |
103 | + ->with('parent', 'user') | |
104 | 104 | ->one(); |
105 | 105 | if($model) { |
106 | 106 | /** |
... | ... | @@ -125,5 +125,85 @@ |
125 | 125 | return [ 'error' => 'Missing comment_id' ]; |
126 | 126 | } |
127 | 127 | } |
128 | + | |
129 | + public function actionUpdateAnswer() | |
130 | + { | |
131 | + \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON; | |
132 | + $post = \Yii::$app->request->post(); | |
133 | + if(!empty( $post[ 'CommentProjectAnswer' ][ 'comment_id' ] )) { | |
134 | + if($model = \common\modules\comment\models\CommentProjectAnswer::findOne($post[ 'CommentProjectAnswer' ][ 'comment_id' ])) { | |
135 | + /** | |
136 | + * @var \common\modules\comment\models\CommentProjectAnswer $model | |
137 | + */ | |
138 | + $model->scenario = is_int(\Yii::$app->user->getId()) ? \common\modules\comment\models\CommentProjectAnswer::SCENARIO_USER : \common\modules\comment\models\CommentProjectAnswer::SCENARIO_GUEST; | |
139 | + $model->load($post); | |
140 | + if(empty( $post[ 'CommentProjectAnswer' ][ 'comment_pid' ] )) { | |
141 | + $model->comment_pid = NULL; | |
142 | + } | |
143 | + if($model->updateComment()) { | |
144 | + $model->rating->load($post); | |
145 | + if($model->rating->save()) { | |
146 | + return [ | |
147 | + 'result' => [ | |
148 | + 'text' => 'Comment successfully updated', | |
149 | + 'html' => $this->renderAjax('@common/modules/comment/widgets/views/_question_comment_view', [ 'model' => $model ]), | |
150 | + ], | |
151 | + ]; | |
152 | + } else { | |
153 | + return [ | |
154 | + 'error' => $model->hasErrors() ? $model->getFirstErrors() : 'Cannot update message', | |
155 | + 'form' => $this->renderAjax('@common/modules/comment/widgets/views/form-comment-answer', [ | |
156 | + 'model' => $model, | |
157 | + ]), | |
158 | + ]; | |
159 | + } | |
160 | + } else { | |
161 | + return [ | |
162 | + 'error' => $model->hasErrors() ? $model->getFirstErrors() : 'Cannot update message', | |
163 | + 'form' => $this->renderAjax('@common/modules/comment/widgets/views/form-comment-answer', [ | |
164 | + 'model' => $model, | |
165 | + ]), | |
166 | + ]; | |
167 | + } | |
168 | + } else { | |
169 | + return [ 'error' => 'Comment not found' ]; | |
170 | + } | |
171 | + } else { | |
172 | + return [ 'error' => 'Missing comment_id' ]; | |
173 | + } | |
174 | + } | |
175 | + | |
176 | + public function actionFormAnswer() | |
177 | + { | |
178 | + \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON; | |
179 | + $post = \Yii::$app->request->post('CommentProjectAnswer'); | |
180 | + if(!empty( $post[ 'comment_id' ] )) { | |
181 | + $model = \common\modules\comment\models\CommentProjectAnswer::find() | |
182 | + ->where([ 'comment_id' => $post[ 'comment_id' ] ]) | |
183 | + ->with('parent', 'user') | |
184 | + ->one(); | |
185 | + if($model) { | |
186 | + /** | |
187 | + * @var \common\modules\comment\models\CommentProjectAnswer $model | |
188 | + */ | |
189 | + $model->scenario = is_int(\Yii::$app->user->getId()) ? \common\modules\comment\models\CommentProjectAnswer::SCENARIO_USER : \common\modules\comment\models\CommentProjectAnswer::SCENARIO_GUEST; | |
190 | + if($model->checkUpdate()) { | |
191 | + return [ | |
192 | + 'result' => [ | |
193 | + 'form' => $this->renderAjax('@common/modules/comment/widgets/views/form-comment-answer', [ | |
194 | + 'model' => $model, | |
195 | + ]), | |
196 | + ], | |
197 | + ]; | |
198 | + } else { | |
199 | + return [ 'error' => 'You are not able to update this comment' ]; | |
200 | + } | |
201 | + } else { | |
202 | + return [ 'error' => 'Comment not found' ]; | |
203 | + } | |
204 | + } else { | |
205 | + return [ 'error' => 'Missing comment_id' ]; | |
206 | + } | |
207 | + } | |
128 | 208 | |
129 | 209 | } |
130 | 210 | \ No newline at end of file | ... | ... |
common/modules/comment/models/Comment.php
... | ... | @@ -176,27 +176,30 @@ |
176 | 176 | public static function getComments($model, $model_id) |
177 | 177 | { |
178 | 178 | return self::find() |
179 | - ->where([ | |
180 | - 'comment.model' => $model, | |
181 | - 'comment.model_id' => $model_id, | |
182 | - 'comment.status' => 1, | |
183 | - ]) | |
184 | - ->with('rating'); | |
179 | + ->where([ | |
180 | + 'comment.model' => $model, | |
181 | + 'comment.model_id' => $model_id, | |
182 | + 'comment.status' => 1, | |
183 | + ]) | |
184 | + ->with('rating'); | |
185 | 185 | } |
186 | 186 | |
187 | 187 | public function postComment() |
188 | 188 | { |
189 | 189 | if($this->checkCreate()) { |
190 | + if(!empty($this->comment_pid) && !$this->checkReply()) { | |
191 | + $this->addError('comment_id', 'You can`t reply to this message'); | |
192 | + return false; | |
193 | + } | |
190 | 194 | if($this->insert()) { |
191 | 195 | $this->clearSafe(); |
192 | 196 | return true; |
193 | 197 | } else { |
194 | 198 | return false; |
195 | 199 | } |
196 | - } else { | |
197 | - $this->addError('comment_id', 'You can`t post comment here'); | |
198 | - return false; | |
199 | 200 | } |
201 | + $this->addError('comment_id', 'You can`t post comment here'); | |
202 | + return false; | |
200 | 203 | } |
201 | 204 | |
202 | 205 | public function updateComment() | ... | ... |
common/modules/comment/models/CommentProjectAnswer.php
... | ... | @@ -106,6 +106,16 @@ |
106 | 106 | return $query; |
107 | 107 | } |
108 | 108 | |
109 | + public function beforeDelete() | |
110 | + { | |
111 | + if(parent::beforeDelete()) { | |
112 | + | |
113 | + return false; | |
114 | + } else { | |
115 | + return false; | |
116 | + } | |
117 | + } | |
118 | + | |
109 | 119 | public function checkCreate() |
110 | 120 | { |
111 | 121 | if($this->getGuestComment()) { |
... | ... | @@ -124,16 +134,11 @@ |
124 | 134 | if($this->scenario == self::SCENARIO_GUEST) { |
125 | 135 | return false; |
126 | 136 | } else { |
127 | - return \Yii::$app->user->can(\common\modules\comment\Permissions::UPDATE, [ | |
128 | - 'model' => $this->model, | |
129 | - 'model_id' => $this->model_id, | |
130 | - 'comment' => $this, | |
131 | - ]) || \Yii::$app->user->can(\common\modules\comment\Permissions::UPDATE_OWN, [ | |
132 | - 'model' => $this->model, | |
133 | - 'model_id' => $this->model_id, | |
134 | - 'comment' => $this, | |
135 | - ]); | |
137 | + if(!empty($this->comment_pid) && $this->user_id == \Yii::$app->user->id) { | |
138 | + return true; | |
139 | + } | |
136 | 140 | } |
141 | + return false; | |
137 | 142 | } |
138 | 143 | |
139 | 144 | public function checkDelete() |
... | ... | @@ -158,7 +163,12 @@ |
158 | 163 | if($this->scenario != self::SCENARIO_GUEST) { |
159 | 164 | if(!$this->isNewRecord && empty( $this->comment_pid )) { |
160 | 165 | $project = Project::findOne($this->model_id); |
161 | - if($project->user_id == \Yii::$app->user->id) { | |
166 | + if($project->user_id == \Yii::$app->user->id && empty($this->child)) { | |
167 | + return true; | |
168 | + } | |
169 | + } elseif($this->isNewRecord && !empty($this->comment_pid)) { | |
170 | + $parent = self::findOne($this->comment_pid); | |
171 | + if(!empty($parent) && $parent->checkReply()) { | |
162 | 172 | return true; |
163 | 173 | } |
164 | 174 | } | ... | ... |
common/modules/comment/resources/comment.js
... | ... | @@ -112,4 +112,44 @@ $(function() { |
112 | 112 | ) |
113 | 113 | } |
114 | 114 | ); |
115 | + | |
116 | + $(document).on( | |
117 | + 'click', '.artbox_comment_update_answer', function(e) | |
118 | + { | |
119 | + e.preventDefault(); | |
120 | + var container = $(this).parents('.artbox_comment_container').first(); | |
121 | + var comment_id = $(container).data('key'); | |
122 | + var form_name = $(container).data('form'); | |
123 | + var object = {}; | |
124 | + object[form_name] = {comment_id : comment_id}; | |
125 | + $.post( | |
126 | + '/artbox-comment/form-answer', object, function(data, textStatus, jqXHR) | |
127 | + { | |
128 | + $(container).empty(); | |
129 | + $(container).append(data.result.form); | |
130 | + } | |
131 | + ); | |
132 | + } | |
133 | + ); | |
134 | + | |
135 | + $(document).on( | |
136 | + 'click', '.artbox_comment_update_answer_submit', function(e) | |
137 | + { | |
138 | + e.preventDefault(); | |
139 | + var container = $(this).parents('.artbox_comment_container').first(); | |
140 | + $.post( | |
141 | + '/artbox-comment/update-answer', $(container).find('form').serialize(), function(data) | |
142 | + { | |
143 | + $(container).empty(); | |
144 | + if(!data.error) | |
145 | + { | |
146 | + $(container).append('<p>'+data.result.text+'</p>'); | |
147 | + $(container).append(data.result.html); | |
148 | + } else { | |
149 | + $(container).append(data.form); | |
150 | + } | |
151 | + } | |
152 | + ) | |
153 | + } | |
154 | + ); | |
115 | 155 | }); | ... | ... |
common/modules/comment/widgets/views/_question_comment_view.php
... | ... | @@ -14,7 +14,9 @@ |
14 | 14 | * @var User $user |
15 | 15 | */ |
16 | 16 | $user = $model->user; |
17 | - $model->buildButtons(['reply']); | |
17 | + if(empty($model->comment_pid)) { | |
18 | + $model->buildButtons([ 'reply', 'delete' ]); | |
19 | + } | |
18 | 20 | ?> |
19 | 21 | <div class="comments-name <?= CommentWidget::$baseClass[ 'comment_author' ] ?>"> |
20 | 22 | <?= $model->getAuthor(' (Гость)') ?> |
... | ... | @@ -30,13 +32,29 @@ |
30 | 32 | <div class="comments-content"> |
31 | 33 | <?= $model->text ?> |
32 | 34 | </div> |
35 | +<?php | |
36 | + if(!empty( $model->child )) { | |
37 | + echo Html::tag('div', $this->render('@common/modules/comment/widgets/views/_question_comment_view', [ | |
38 | + 'model' => $model->child, | |
39 | + 'key' => $key, | |
40 | + 'index' => $index, | |
41 | + 'widget' => $widget, | |
42 | + ]), [ | |
43 | + 'class' => CommentWidget::$baseClass[ 'comment_container' ], | |
44 | + 'data' => [ | |
45 | + 'key' => $model->child->comment_id, | |
46 | + 'form' => $model->formName(), | |
47 | + ], | |
48 | + ]); | |
49 | + } | |
50 | +?> | |
33 | 51 | <div> |
34 | 52 | <?php |
35 | 53 | if(!empty( $model->buttons[ 'delete' ] )) { |
36 | - echo Html::a(($model->user_id != NULL && $model->user_id == \Yii::$app->user->id)?'Удалить':'Пожаловаться ', $model->buttons[ 'delete' ], [ 'class' => CommentWidget::$baseClass[ 'comment_delete' ] ]); | |
54 | + echo Html::a(( $model->user_id != NULL && $model->user_id == \Yii::$app->user->id ) ? 'Удалить' : 'Пожаловаться ', $model->buttons[ 'delete' ], [ 'class' => CommentWidget::$baseClass[ 'comment_delete' ] ]); | |
37 | 55 | } |
38 | 56 | if(!empty( $model->buttons[ 'update' ] )) { |
39 | - echo Html::a('Редактировать', $model->buttons[ 'update' ], [ 'class' => CommentWidget::$baseClass[ 'comment_update' ] ]); | |
57 | + echo Html::a('Редактировать', $model->buttons[ 'update' ], [ 'class' => 'artbox_comment_update_answer' ]); | |
40 | 58 | } |
41 | 59 | if(!empty( $model->buttons[ 'reply' ] )) { |
42 | 60 | echo Html::a('Ответить', $model->buttons[ 'reply' ], [ 'class' => CommentWidget::$baseClass[ 'comment_reply' ] ]); |
... | ... | @@ -44,15 +62,6 @@ |
44 | 62 | ?> |
45 | 63 | </div> |
46 | 64 | <?php |
47 | - if(!$model->isNewRecord) { | |
48 | - $this->registerJs("$('div.rating').rating( | |
49 | - { | |
50 | - fx : 'full', readOnly : 'true', url : 'rating.php' | |
51 | - } | |
52 | - );"); | |
53 | - } | |
54 | -?> | |
55 | -<?php | |
56 | 65 | /* == PROJECT INFO == |
57 | 66 | ?> |
58 | 67 | <div class="comments-project-link">Проект: <a href="#">Ремонт спальни</a></div> | ... | ... |
common/modules/comment/widgets/views/form-comment-answer.php
... | ... | @@ -9,12 +9,30 @@ |
9 | 9 | use yii\helpers\Html; |
10 | 10 | |
11 | 11 | ?> |
12 | -<div class="new-portf-comm-count">Вопросов: <?= $dataProvider->totalCount ?></div> | |
12 | +<?php | |
13 | + if(!empty( $dataProvider )) { | |
14 | + ?> | |
15 | + <div class="new-portf-comm-count">Вопросов: <?= $dataProvider->totalCount ?></div> | |
16 | + <?php | |
17 | + } | |
18 | +?> | |
13 | 19 | |
14 | 20 | <div class="new-portf-add-comm style"> |
15 | 21 | |
16 | 22 | <?php |
17 | 23 | $form = ActiveForm::begin(); |
24 | + if(!$model->isNewRecord) { | |
25 | + echo $form->field($model, 'comment_id') | |
26 | + ->hiddenInput() | |
27 | + ->label(false) | |
28 | + ->error(false); | |
29 | + } | |
30 | + if(!empty($model->comment_pid)) { | |
31 | + echo $form->field($model, 'comment_pid') | |
32 | + ->hiddenInput() | |
33 | + ->label(false) | |
34 | + ->error(false); | |
35 | + } | |
18 | 36 | if($model->scenario == $model::SCENARIO_GUEST) { |
19 | 37 | echo $form->field($model, 'user_name', [ |
20 | 38 | 'options' => [ |
... | ... | @@ -48,11 +66,17 @@ |
48 | 66 | 'class' => 'custom-area-4', |
49 | 67 | ], |
50 | 68 | ]) |
51 | - ->label('Вопрос') | |
69 | + ->label($model->isNewRecord?'Вопрос':'Ответ') | |
52 | 70 | ->textarea(); |
53 | 71 | ?> |
54 | 72 | <div class="input-blocks-comm-button style"> |
55 | - <?= Html::submitButton('Задать вопрос') ?> | |
73 | + <?php | |
74 | + if($model->isNewRecord) { | |
75 | + echo Html::submitButton('Добавить комментарий'); | |
76 | + } else { | |
77 | + echo Html::submitButton('Обновить комментарий', [ 'class' => 'artbox_comment_update_answer_submit' ]); | |
78 | + } | |
79 | + ?> | |
56 | 80 | </div> |
57 | 81 | <?php |
58 | 82 | $form->end(); | ... | ... |
common/modules/comment/widgets/views/form-comment-review.php
... | ... | @@ -70,7 +70,7 @@ |
70 | 70 | ->textInput(); |
71 | 71 | } |
72 | 72 | if(!empty( $model->comment_pid )) { |
73 | - echo Html::tag('div', Html::activeHiddenInput($model, 'comment_pid') . Html::tag('p', $model->parent->authorName, [ 'class' => 'artbox_comment_reply_author' ]), [ 'class' => CommentWidget::$baseClass[ 'reply_block' ] ]); | |
73 | + echo Html::tag('div', Html::activeHiddenInput($model, 'comment_pid') . Html::tag('p', $model->parent->author, [ 'class' => 'artbox_comment_reply_author' ]), [ 'class' => CommentWidget::$baseClass[ 'reply_block' ] ]); | |
74 | 74 | } else { |
75 | 75 | echo Html::tag('div', '', [ 'class' => CommentWidget::$baseClass[ 'reply_block' ].' test_class' ]); |
76 | 76 | } | ... | ... |