Commit 464ede30f0e40192535f4062ad72295b68e6630e
1 parent
b433e560
-Global comments
Showing
8 changed files
with
757 additions
and
313 deletions
Show diff stats
frontend/controllers/SiteController.php
| 1 | 1 | <?php |
| 2 | 2 | namespace frontend\controllers; |
| 3 | - | |
| 3 | + | |
| 4 | 4 | use artbox\core\models\Feedback; |
| 5 | 5 | use artbox\core\models\Page; |
| 6 | + use artbox\webcomment\models\CommentModel; | |
| 6 | 7 | use common\models\Settings; |
| 7 | 8 | use Yii; |
| 8 | 9 | use yii\filters\VerbFilter; |
| ... | ... | @@ -10,7 +11,7 @@ |
| 10 | 11 | use yii\web\BadRequestHttpException; |
| 11 | 12 | use yii\web\Controller; |
| 12 | 13 | use yii\web\Response; |
| 13 | - | |
| 14 | + | |
| 14 | 15 | /** |
| 15 | 16 | * Site controller |
| 16 | 17 | */ |
| ... | ... | @@ -27,7 +28,7 @@ |
| 27 | 28 | ], |
| 28 | 29 | ]; |
| 29 | 30 | } |
| 30 | - | |
| 31 | + | |
| 31 | 32 | /** |
| 32 | 33 | * @inheritdoc |
| 33 | 34 | */ |
| ... | ... | @@ -42,7 +43,7 @@ |
| 42 | 43 | ], |
| 43 | 44 | ]; |
| 44 | 45 | } |
| 45 | - | |
| 46 | + | |
| 46 | 47 | /** |
| 47 | 48 | * Displays homepage. |
| 48 | 49 | * |
| ... | ... | @@ -52,7 +53,7 @@ |
| 52 | 53 | { |
| 53 | 54 | return $this->render('index'); |
| 54 | 55 | } |
| 55 | - | |
| 56 | + | |
| 56 | 57 | /** |
| 57 | 58 | * Displays contact page. |
| 58 | 59 | * |
| ... | ... | @@ -68,7 +69,7 @@ |
| 68 | 69 | ] |
| 69 | 70 | ); |
| 70 | 71 | } |
| 71 | - | |
| 72 | + | |
| 72 | 73 | /** |
| 73 | 74 | * Displays about page. |
| 74 | 75 | * |
| ... | ... | @@ -78,7 +79,7 @@ |
| 78 | 79 | { |
| 79 | 80 | return $this->render('about'); |
| 80 | 81 | } |
| 81 | - | |
| 82 | + | |
| 82 | 83 | /** |
| 83 | 84 | * Action to view robots.txt file dinamycli |
| 84 | 85 | * |
| ... | ... | @@ -99,23 +100,23 @@ |
| 99 | 100 | $response->headers->set('Content-Type', 'text/plain'); |
| 100 | 101 | return $this->renderFile($meta[ 'uri' ]); |
| 101 | 102 | } |
| 102 | - | |
| 103 | + | |
| 103 | 104 | public function actionFeedback() |
| 104 | 105 | { |
| 105 | 106 | Yii::$app->response->format = Response::FORMAT_JSON; |
| 106 | - | |
| 107 | + | |
| 107 | 108 | /** |
| 108 | 109 | * @var Mailer $mailer |
| 109 | 110 | */ |
| 110 | 111 | $mailer = \Yii::$app->get('smtpmailer'); |
| 111 | 112 | $settings = Settings::getInstance(); |
| 112 | - | |
| 113 | + | |
| 113 | 114 | if (empty(Yii::$app->request->post())) { |
| 114 | 115 | throw new BadRequestHttpException(); |
| 115 | 116 | } else { |
| 116 | 117 | $model = new Feedback(); |
| 117 | 118 | if ($model->load(Yii::$app->request->post()) && $model->save()) { |
| 118 | - | |
| 119 | + | |
| 119 | 120 | $mailer->compose( |
| 120 | 121 | 'feedback', |
| 121 | 122 | [ |
| ... | ... | @@ -126,7 +127,7 @@ |
| 126 | 127 | ->setTo($settings->email) |
| 127 | 128 | ->setSubject(\Yii::t('app', 'Feedback')) |
| 128 | 129 | ->send(); |
| 129 | - | |
| 130 | + | |
| 130 | 131 | return [ |
| 131 | 132 | 'success' => true, |
| 132 | 133 | 'message' => 'Success message', |
| ... | ... | @@ -145,18 +146,47 @@ |
| 145 | 146 | } |
| 146 | 147 | } |
| 147 | 148 | } |
| 148 | - | |
| 149 | - public function actionAppment(){ | |
| 149 | + | |
| 150 | + public function actionAppment() | |
| 151 | + { | |
| 150 | 152 | return $this->render('appment'); |
| 151 | 153 | } |
| 152 | - | |
| 153 | - public function actionPrice(){ | |
| 154 | - $page_stom = Page::find()->with('lang')->where(['id' => 3])->one(); | |
| 155 | - $page_cosm = Page::find()->with('lang')->where(['id' => 4])->one(); | |
| 156 | - | |
| 157 | - return $this->render('price',[ | |
| 158 | - 'page_stom' => $page_stom, | |
| 159 | - 'page_cosm' => $page_cosm, | |
| 160 | - ]); | |
| 154 | + | |
| 155 | + public function actionPrice() | |
| 156 | + { | |
| 157 | + $page_stom = Page::find() | |
| 158 | + ->with('lang') | |
| 159 | + ->where([ 'id' => 3 ]) | |
| 160 | + ->one(); | |
| 161 | + $page_cosm = Page::find() | |
| 162 | + ->with('lang') | |
| 163 | + ->where([ 'id' => 4 ]) | |
| 164 | + ->one(); | |
| 165 | + | |
| 166 | + return $this->render( | |
| 167 | + 'price', | |
| 168 | + [ | |
| 169 | + 'page_stom' => $page_stom, | |
| 170 | + 'page_cosm' => $page_cosm, | |
| 171 | + ] | |
| 172 | + ); | |
| 173 | + } | |
| 174 | + | |
| 175 | + public function actionComments() | |
| 176 | + { | |
| 177 | + $model = new CommentModel( | |
| 178 | + [ | |
| 179 | + 'id' => 1, | |
| 180 | + ] | |
| 181 | + ); | |
| 182 | + | |
| 183 | + $this->view->params[ 'breadcrumbs' ][] = \Yii::t('app', 'Комментарии'); | |
| 184 | + | |
| 185 | + return $this->render( | |
| 186 | + 'comments', | |
| 187 | + [ | |
| 188 | + 'model' => $model, | |
| 189 | + ] | |
| 190 | + ); | |
| 161 | 191 | } |
| 162 | 192 | } | ... | ... |
frontend/views/layouts/main.php
| ... | ... | @@ -39,7 +39,7 @@ |
| 39 | 39 | 'lang', |
| 40 | 40 | 'pages' => function (ActiveQuery $query) { |
| 41 | 41 | $query->with('lang.alias') |
| 42 | - ->where(['in_menu' => true]) | |
| 42 | + ->where([ 'in_menu' => true ]) | |
| 43 | 43 | ->orderBy([ 'sort' => SORT_ASC ]); |
| 44 | 44 | }, |
| 45 | 45 | ] |
| ... | ... | @@ -78,171 +78,171 @@ |
| 78 | 78 | <body> |
| 79 | 79 | <?php $this->beginBody() ?> |
| 80 | 80 | <!-- Google Analytics --> |
| 81 | - <?php if (!empty($settings->ga_code)) { ?> | |
| 82 | - <script> | |
| 83 | - (function(i, s, o, g, r, a, m) { | |
| 84 | - i[ 'GoogleAnalyticsObject' ] = r; | |
| 85 | - i[ r ] = i[ r ] || function() { | |
| 86 | - (i[ r ].q = i[ r ].q || []).push(arguments) | |
| 87 | - }, i[ r ].l = 1 * new Date(); | |
| 88 | - a = s.createElement(o), m = s.getElementsByTagName(o)[ 0 ]; | |
| 89 | - a.async = 1; | |
| 90 | - a.src = g; | |
| 91 | - m.parentNode.insertBefore(a, m) | |
| 92 | - })(window, document, 'script', 'https://www.google-analytics.com/analytics.js', 'ga'); | |
| 81 | + <?php if (!empty($settings->ga_code)) { ?> | |
| 82 | + <script> | |
| 83 | + (function(i, s, o, g, r, a, m) { | |
| 84 | + i[ 'GoogleAnalyticsObject' ] = r; | |
| 85 | + i[ r ] = i[ r ] || function() { | |
| 86 | + (i[ r ].q = i[ r ].q || []).push(arguments) | |
| 87 | + }, i[ r ].l = 1 * new Date(); | |
| 88 | + a = s.createElement(o), m = s.getElementsByTagName(o)[ 0 ]; | |
| 89 | + a.async = 1; | |
| 90 | + a.src = g; | |
| 91 | + m.parentNode.insertBefore(a, m) | |
| 92 | + })(window, document, 'script', 'https://www.google-analytics.com/analytics.js', 'ga'); | |
| 93 | 93 | |
| 94 | - ga('create', '<?=$settings->ga_code?>', 'auto'); | |
| 95 | - ga('send', 'pageview'); | |
| 96 | - | |
| 97 | - </script> | |
| 98 | - <?php } ?> | |
| 94 | + ga('create', '<?=$settings->ga_code?>', 'auto'); | |
| 95 | + ga('send', 'pageview'); | |
| 96 | + | |
| 97 | + </script> | |
| 98 | + <?php } ?> | |
| 99 | 99 | <div id="all"> |
| 100 | 100 | <header> |
| 101 | - <!-- *** TOP *** | |
| 102 | - _________________________________________________________ --> | |
| 103 | - <div id="top"> | |
| 104 | - <div class="container"> | |
| 105 | - <div class="row"> | |
| 106 | - <div class="col-xs-5 contact"> | |
| 107 | - <p class="hidden-sm hidden-xs"> | |
| 108 | - <?php | |
| 109 | - if (!empty($settings->phone)) { | |
| 110 | - echo \Yii::t('app', 'Связаться с нами '); | |
| 111 | - echo Html::a($settings->phone, "тел.: {$settings->phone}"); | |
| 112 | - if (!empty($settings->email)) { | |
| 113 | - echo \Yii::t('app', ' или '); | |
| 114 | - echo Html::a($settings->email, "mailto:$settings->email"); | |
| 115 | - } | |
| 116 | - } | |
| 117 | - ?> | |
| 118 | - </p> | |
| 119 | - <p class="hidden-md hidden-lg"> | |
| 120 | - <a href="#" data-animate-hover="pulse"><i class="fa fa-phone"></i></a> | |
| 121 | - <a href="#" data-animate-hover="pulse"><i class="fa fa-envelope"></i></a> | |
| 122 | - </p> | |
| 123 | - </div> | |
| 124 | - <div class="col-xs-7"> | |
| 125 | - <div class="social"> | |
| 126 | - <?php | |
| 127 | - if (!empty($settings->facebook)) { | |
| 128 | - echo Html::a( | |
| 129 | - Html::icon( | |
| 130 | - 'facebook', | |
| 131 | - [ | |
| 132 | - 'prefix' => 'fa fa-', | |
| 133 | - ] | |
| 134 | - ), | |
| 135 | - $settings->facebook, | |
| 136 | - [ | |
| 137 | - 'class' => 'external facebook', | |
| 138 | - 'data' => [ | |
| 139 | - 'animate-hover' => 'pulse', | |
| 140 | - ], | |
| 141 | - ] | |
| 142 | - ); | |
| 143 | - } | |
| 144 | - ?> | |
| 145 | - <?php | |
| 146 | - if (!empty($settings->vk)) { | |
| 147 | - echo Html::a( | |
| 148 | - Html::icon( | |
| 149 | - 'vk', | |
| 150 | - [ | |
| 151 | - 'prefix' => 'fa fa-', | |
| 152 | - ] | |
| 153 | - ), | |
| 154 | - $settings->vk, | |
| 155 | - [ | |
| 156 | - 'class' => 'external vk', | |
| 157 | - 'data' => [ | |
| 158 | - 'animate-hover' => 'pulse', | |
| 159 | - ], | |
| 160 | - ] | |
| 161 | - ); | |
| 162 | - } | |
| 163 | - ?> | |
| 164 | - <?php | |
| 165 | - if (!empty($settings->google)) { | |
| 166 | - echo Html::a( | |
| 167 | - Html::icon( | |
| 168 | - 'google-plus', | |
| 169 | - [ | |
| 170 | - 'prefix' => 'fa fa-', | |
| 171 | - ] | |
| 172 | - ), | |
| 173 | - $settings->google, | |
| 174 | - [ | |
| 175 | - 'class' => 'external gplus', | |
| 176 | - 'data' => [ | |
| 177 | - 'animate-hover' => 'pulse', | |
| 178 | - ], | |
| 179 | - ] | |
| 180 | - ); | |
| 181 | - } | |
| 182 | - ?> | |
| 183 | - <?php | |
| 184 | - if (!empty($settings->twitter)) { | |
| 185 | - echo Html::a( | |
| 186 | - Html::icon( | |
| 187 | - 'twitter', | |
| 188 | - [ | |
| 189 | - 'prefix' => 'fa fa-', | |
| 190 | - ] | |
| 191 | - ), | |
| 192 | - $settings->twitter, | |
| 193 | - [ | |
| 194 | - 'class' => 'external twitter', | |
| 195 | - 'data' => [ | |
| 196 | - 'animate-hover' => 'pulse', | |
| 197 | - ], | |
| 198 | - ] | |
| 199 | - ); | |
| 200 | - } | |
| 201 | - ?> | |
| 202 | - <?php | |
| 203 | - if (!empty($settings->ok)) { | |
| 204 | - echo Html::a( | |
| 205 | - Html::icon( | |
| 206 | - 'odnoklassniki', | |
| 207 | - [ | |
| 208 | - 'prefix' => 'fa fa-', | |
| 209 | - ] | |
| 210 | - ), | |
| 211 | - $settings->ok, | |
| 212 | - [ | |
| 213 | - 'class' => 'external odnoklassniki', | |
| 214 | - 'data' => [ | |
| 215 | - 'animate-hover' => 'pulse', | |
| 216 | - ], | |
| 217 | - ] | |
| 218 | - ); | |
| 219 | - } | |
| 220 | - ?> | |
| 221 | - <?php | |
| 222 | - if (!empty($settings->email)) { | |
| 223 | - echo Html::a( | |
| 224 | - Html::icon( | |
| 225 | - 'envelope', | |
| 226 | - [ | |
| 227 | - 'prefix' => 'fa fa-', | |
| 228 | - ] | |
| 229 | - ), | |
| 230 | - "mailto:$settings->email", | |
| 231 | - [ | |
| 232 | - 'class' => 'email', | |
| 233 | - 'data' => [ | |
| 234 | - 'animate-hover' => 'pulse', | |
| 235 | - ], | |
| 236 | - ] | |
| 237 | - ); | |
| 238 | - } | |
| 239 | - ?> | |
| 240 | - </div> | |
| 241 | - </div> | |
| 242 | - </div> | |
| 101 | + <!-- *** TOP *** | |
| 102 | +_________________________________________________________ --> | |
| 103 | + <div id="top"> | |
| 104 | + <div class="container"> | |
| 105 | + <div class="row"> | |
| 106 | + <div class="col-xs-5 contact"> | |
| 107 | + <p class="hidden-sm hidden-xs"> | |
| 108 | + <?php | |
| 109 | + if (!empty($settings->phone)) { | |
| 110 | + echo \Yii::t('app', 'Связаться с нами '); | |
| 111 | + echo Html::a($settings->phone, "тел.: {$settings->phone}"); | |
| 112 | + if (!empty($settings->email)) { | |
| 113 | + echo \Yii::t('app', ' или '); | |
| 114 | + echo Html::a($settings->email, "mailto:$settings->email"); | |
| 115 | + } | |
| 116 | + } | |
| 117 | + ?> | |
| 118 | + </p> | |
| 119 | + <p class="hidden-md hidden-lg"> | |
| 120 | + <a href="#" data-animate-hover="pulse"><i class="fa fa-phone"></i></a> | |
| 121 | + <a href="#" data-animate-hover="pulse"><i class="fa fa-envelope"></i></a> | |
| 122 | + </p> | |
| 123 | + </div> | |
| 124 | + <div class="col-xs-7"> | |
| 125 | + <div class="social"> | |
| 126 | + <?php | |
| 127 | + if (!empty($settings->facebook)) { | |
| 128 | + echo Html::a( | |
| 129 | + Html::icon( | |
| 130 | + 'facebook', | |
| 131 | + [ | |
| 132 | + 'prefix' => 'fa fa-', | |
| 133 | + ] | |
| 134 | + ), | |
| 135 | + $settings->facebook, | |
| 136 | + [ | |
| 137 | + 'class' => 'external facebook', | |
| 138 | + 'data' => [ | |
| 139 | + 'animate-hover' => 'pulse', | |
| 140 | + ], | |
| 141 | + ] | |
| 142 | + ); | |
| 143 | + } | |
| 144 | + ?> | |
| 145 | + <?php | |
| 146 | + if (!empty($settings->vk)) { | |
| 147 | + echo Html::a( | |
| 148 | + Html::icon( | |
| 149 | + 'vk', | |
| 150 | + [ | |
| 151 | + 'prefix' => 'fa fa-', | |
| 152 | + ] | |
| 153 | + ), | |
| 154 | + $settings->vk, | |
| 155 | + [ | |
| 156 | + 'class' => 'external vk', | |
| 157 | + 'data' => [ | |
| 158 | + 'animate-hover' => 'pulse', | |
| 159 | + ], | |
| 160 | + ] | |
| 161 | + ); | |
| 162 | + } | |
| 163 | + ?> | |
| 164 | + <?php | |
| 165 | + if (!empty($settings->google)) { | |
| 166 | + echo Html::a( | |
| 167 | + Html::icon( | |
| 168 | + 'google-plus', | |
| 169 | + [ | |
| 170 | + 'prefix' => 'fa fa-', | |
| 171 | + ] | |
| 172 | + ), | |
| 173 | + $settings->google, | |
| 174 | + [ | |
| 175 | + 'class' => 'external gplus', | |
| 176 | + 'data' => [ | |
| 177 | + 'animate-hover' => 'pulse', | |
| 178 | + ], | |
| 179 | + ] | |
| 180 | + ); | |
| 181 | + } | |
| 182 | + ?> | |
| 183 | + <?php | |
| 184 | + if (!empty($settings->twitter)) { | |
| 185 | + echo Html::a( | |
| 186 | + Html::icon( | |
| 187 | + 'twitter', | |
| 188 | + [ | |
| 189 | + 'prefix' => 'fa fa-', | |
| 190 | + ] | |
| 191 | + ), | |
| 192 | + $settings->twitter, | |
| 193 | + [ | |
| 194 | + 'class' => 'external twitter', | |
| 195 | + 'data' => [ | |
| 196 | + 'animate-hover' => 'pulse', | |
| 197 | + ], | |
| 198 | + ] | |
| 199 | + ); | |
| 200 | + } | |
| 201 | + ?> | |
| 202 | + <?php | |
| 203 | + if (!empty($settings->ok)) { | |
| 204 | + echo Html::a( | |
| 205 | + Html::icon( | |
| 206 | + 'odnoklassniki', | |
| 207 | + [ | |
| 208 | + 'prefix' => 'fa fa-', | |
| 209 | + ] | |
| 210 | + ), | |
| 211 | + $settings->ok, | |
| 212 | + [ | |
| 213 | + 'class' => 'external odnoklassniki', | |
| 214 | + 'data' => [ | |
| 215 | + 'animate-hover' => 'pulse', | |
| 216 | + ], | |
| 217 | + ] | |
| 218 | + ); | |
| 219 | + } | |
| 220 | + ?> | |
| 221 | + <?php | |
| 222 | + if (!empty($settings->email)) { | |
| 223 | + echo Html::a( | |
| 224 | + Html::icon( | |
| 225 | + 'envelope', | |
| 226 | + [ | |
| 227 | + 'prefix' => 'fa fa-', | |
| 228 | + ] | |
| 229 | + ), | |
| 230 | + "mailto:$settings->email", | |
| 231 | + [ | |
| 232 | + 'class' => 'email', | |
| 233 | + 'data' => [ | |
| 234 | + 'animate-hover' => 'pulse', | |
| 235 | + ], | |
| 236 | + ] | |
| 237 | + ); | |
| 238 | + } | |
| 239 | + ?> | |
| 240 | + </div> | |
| 243 | 241 | </div> |
| 242 | + </div> | |
| 244 | 243 | </div> |
| 245 | - <!-- *** TOP END *** --> | |
| 244 | + </div> | |
| 245 | + <!-- *** TOP END *** --> | |
| 246 | 246 | <!-- *** NAVBAR *** |
| 247 | 247 | _________________________________________________________ --> |
| 248 | 248 | <div class="navbar-affixed-top" data-spy="affix" data-offset-top="200"> |
| ... | ... | @@ -280,18 +280,23 @@ |
| 280 | 280 | ]; |
| 281 | 281 | foreach ($pageCategories as $category) { |
| 282 | 282 | if (empty($category->pages)) { |
| 283 | - continue; | |
| 283 | + continue; | |
| 284 | 284 | } |
| 285 | 285 | $pages = []; |
| 286 | 286 | foreach ($category->pages as $page) { |
| 287 | - $pages[] = [ | |
| 288 | - 'label' => $page->lang->title, | |
| 289 | - 'url' => Url::to(['page/view','alias' => $page->lang->alias]), | |
| 290 | - ]; | |
| 287 | + $pages[] = [ | |
| 288 | + 'label' => $page->lang->title, | |
| 289 | + 'url' => Url::to( | |
| 290 | + [ | |
| 291 | + 'page/view', | |
| 292 | + 'alias' => $page->lang->alias, | |
| 293 | + ] | |
| 294 | + ), | |
| 295 | + ]; | |
| 291 | 296 | } |
| 292 | 297 | $items[] = [ |
| 293 | - 'label' => $category->lang->title, | |
| 294 | - 'items' => $pages, | |
| 298 | + 'label' => $category->lang->title, | |
| 299 | + 'items' => $pages, | |
| 295 | 300 | ]; |
| 296 | 301 | } |
| 297 | 302 | $items[] = [ |
| ... | ... | @@ -306,10 +311,14 @@ |
| 306 | 311 | 'label' => \Yii::t('app', 'Контакты'), |
| 307 | 312 | 'url' => [ 'site/contact' ], |
| 308 | 313 | ]; |
| 309 | - $items[] = [ | |
| 314 | + $items[] = [ | |
| 310 | 315 | 'label' => \Yii::t('app', 'О клинике'), |
| 311 | 316 | 'url' => [ 'site/about' ], |
| 312 | 317 | ]; |
| 318 | + $items[] = [ | |
| 319 | + 'label' => \Yii::t('app', 'Отзывы'), | |
| 320 | + 'url' => [ 'site/comments' ], | |
| 321 | + ]; | |
| 313 | 322 | echo Nav::widget( |
| 314 | 323 | [ |
| 315 | 324 | 'items' => $items, |
| ... | ... | @@ -349,119 +358,118 @@ |
| 349 | 358 | <!-- *** NAVBAR END *** --> |
| 350 | 359 | |
| 351 | 360 | </header> |
| 352 | - | |
| 353 | - | |
| 354 | - | |
| 355 | - <!-- *** appointment MODAL *** | |
| 356 | - _________________________________________________________ --> | |
| 357 | - <div class="forms_" id="appointment-modal" aria-labelledby="Login" style="display:none;" aria-hidden="true"> | |
| 358 | - <div class="forms_wr_"> | |
| 359 | - <div class="modal-header"> | |
| 360 | - <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button> | |
| 361 | - <h3 class="modal-title" id="Login">Обратная связь</h3> | |
| 362 | - </div> | |
| 363 | - <div class="modal-body"> | |
| 364 | - | |
| 365 | - <form id="appointment-form" action="/site/appointment" method="POST" role="form"> | |
| 366 | - <div class="form-group field-appointment-name"> | |
| 367 | - <div class="on_input_"></div> | |
| 368 | - <label class="control-label" for="appointment-name">Имя</label> | |
| 369 | - <input type="text" id="appointment-name" class="form-control" name="Appointment[name]" aria-invalid="false"> | |
| 370 | - | |
| 371 | - <p class="help-block help-block-error"></p> | |
| 372 | - </div> | |
| 373 | - <div class="form-group field-appointment-name required"> | |
| 374 | - <div class="on_input_"></div> | |
| 375 | - <label class="control-label" for="appointment-name">Номер телефона</label> | |
| 376 | - <input type="text" id="appointment-phone" class="form-control" name="Appointment[phone]"> | |
| 377 | - | |
| 378 | - <p class="help-block help-block-error"></p> | |
| 379 | - </div> | |
| 380 | - <div class="form-group field-appointment-date required has-datepicker"> | |
| 381 | - <div class="on_input_"></div> | |
| 382 | - <label class="control-label" for="appointment-date">Дата</label> | |
| 383 | - <input type="text" id="appointment-date" class="form-control" name="Appointment[date]"> | |
| 384 | - | |
| 385 | - <p class="help-block help-block-error"></p> | |
| 386 | - </div> | |
| 387 | - <div class="datepicker-wr"> | |
| 388 | - <div id="datepicker"></div> | |
| 389 | - </div> | |
| 390 | - <div class="form-group field-appointment-time"> | |
| 391 | - <div class="on_input_"></div> | |
| 392 | - <label class="control-label" for="appointment-service">Время</label> | |
| 393 | - <input type="text" id="appointment-time" class="form-control" name="Appointment[time]"> | |
| 394 | - | |
| 395 | - <p class="help-block help-block-error"></p> | |
| 396 | - </div> | |
| 397 | - <div class="form-group field-appointment-service"> | |
| 398 | - <div class="on_input_"></div> | |
| 399 | - <label class="control-label" for="appointment-service">Услуга</label> | |
| 400 | - <input type="text" id="appointment-service" class="form-control" name="Appointment[service]"> | |
| 401 | - | |
| 402 | - <p class="help-block help-block-error"></p> | |
| 403 | - </div> | |
| 404 | - <p class="text-center"> | |
| 405 | - <button type="submit" class="send-form btn btn-lg btn-template-primary">Отправить</button> | |
| 406 | - </p> | |
| 407 | - </form> | |
| 408 | - | |
| 409 | - </div> | |
| 410 | - </div> | |
| 411 | - <div class="overlay-new"></div> | |
| 361 | + | |
| 362 | + | |
| 363 | + <!-- *** appointment MODAL *** | |
| 364 | +_________________________________________________________ --> | |
| 365 | + <div class="forms_" id="appointment-modal" aria-labelledby="Login" style="display:none;" aria-hidden="true"> | |
| 366 | + <div class="forms_wr_"> | |
| 367 | + <div class="modal-header"> | |
| 368 | + <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button> | |
| 369 | + <h3 class="modal-title" id="Login">Обратная связь</h3> | |
| 370 | + </div> | |
| 371 | + <div class="modal-body"> | |
| 372 | + | |
| 373 | + <form id="appointment-form" action="/site/appointment" method="POST" role="form"> | |
| 374 | + <div class="form-group field-appointment-name"> | |
| 375 | + <div class="on_input_"></div> | |
| 376 | + <label class="control-label" for="appointment-name">Имя</label> | |
| 377 | + <input type="text" id="appointment-name" class="form-control" name="Appointment[name]" aria-invalid="false"> | |
| 378 | + | |
| 379 | + <p class="help-block help-block-error"></p> | |
| 380 | + </div> | |
| 381 | + <div class="form-group field-appointment-name required"> | |
| 382 | + <div class="on_input_"></div> | |
| 383 | + <label class="control-label" for="appointment-name">Номер телефона</label> | |
| 384 | + <input type="text" id="appointment-phone" class="form-control" name="Appointment[phone]"> | |
| 385 | + | |
| 386 | + <p class="help-block help-block-error"></p> | |
| 387 | + </div> | |
| 388 | + <div class="form-group field-appointment-date required has-datepicker"> | |
| 389 | + <div class="on_input_"></div> | |
| 390 | + <label class="control-label" for="appointment-date">Дата</label> | |
| 391 | + <input type="text" id="appointment-date" class="form-control" name="Appointment[date]"> | |
| 392 | + | |
| 393 | + <p class="help-block help-block-error"></p> | |
| 394 | + </div> | |
| 395 | + <div class="datepicker-wr"> | |
| 396 | + <div id="datepicker"></div> | |
| 397 | + </div> | |
| 398 | + <div class="form-group field-appointment-time"> | |
| 399 | + <div class="on_input_"></div> | |
| 400 | + <label class="control-label" for="appointment-service">Время</label> | |
| 401 | + <input type="text" id="appointment-time" class="form-control" name="Appointment[time]"> | |
| 402 | + | |
| 403 | + <p class="help-block help-block-error"></p> | |
| 404 | + </div> | |
| 405 | + <div class="form-group field-appointment-service"> | |
| 406 | + <div class="on_input_"></div> | |
| 407 | + <label class="control-label" for="appointment-service">Услуга</label> | |
| 408 | + <input type="text" id="appointment-service" class="form-control" name="Appointment[service]"> | |
| 409 | + | |
| 410 | + <p class="help-block help-block-error"></p> | |
| 411 | + </div> | |
| 412 | + <p class="text-center"> | |
| 413 | + <button type="submit" class="send-form btn btn-lg btn-template-primary">Отправить</button> | |
| 414 | + </p> | |
| 415 | + </form> | |
| 416 | + | |
| 417 | + </div> | |
| 412 | 418 | </div> |
| 413 | - | |
| 414 | - <!-- *** appointment MODAL END *** --> | |
| 415 | - | |
| 416 | - | |
| 419 | + <div class="overlay-new"></div> | |
| 420 | + </div> | |
| 421 | + | |
| 422 | + <!-- *** appointment MODAL END *** --> | |
| 423 | + | |
| 424 | + | |
| 417 | 425 | <!-- *** FeedBack MODAL *** |
| 418 | 426 | _________________________________________________________ --> |
| 419 | 427 | <div class="forms_" id="feedback-modal" aria-labelledby="Login" style="display:none;" aria-hidden="true"> |
| 420 | - <div class="forms_wr_"> | |
| 421 | - <div class="modal-header"> | |
| 422 | - <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button> | |
| 423 | - <h3 class="modal-title" id="Login">Обратная связь</h3> | |
| 424 | - </div> | |
| 425 | - <div class="modal-body"> | |
| 426 | - | |
| 427 | - <?php $form = ActiveForm::begin( | |
| 428 | - [ | |
| 429 | - 'id' => 'feedback-form', | |
| 430 | - 'method' => 'POST', | |
| 431 | - 'action' => '/site/feedback', | |
| 432 | - ] | |
| 433 | - ); ?> | |
| 434 | - | |
| 435 | - <?= $form->field($feedback, 'name') | |
| 436 | - ->textInput(); ?> | |
| 437 | - | |
| 438 | - <?= $form->field($feedback, 'email') | |
| 439 | - ->textInput(); ?> | |
| 440 | - | |
| 441 | - <?= $form->field($feedback, 'phone') | |
| 442 | - ->textInput(); ?> | |
| 443 | - | |
| 444 | - <?= $form->field($feedback, 'message') | |
| 445 | - ->textarea( | |
| 446 | - [ | |
| 447 | - 'rows' => 4, | |
| 448 | - ] | |
| 449 | - ); ?> | |
| 450 | - | |
| 451 | - <p class="text-center"> | |
| 452 | - <?= Html::submitButton( | |
| 453 | - 'Отправить', | |
| 454 | - [ | |
| 455 | - 'class' => 'send-form btn btn-lg btn-template-primary', | |
| 456 | - ] | |
| 457 | - ) ?> | |
| 458 | - </p> | |
| 459 | - | |
| 460 | - <?php ActiveForm::end(); ?> | |
| 461 | - | |
| 462 | - </div> | |
| 428 | + <div class="forms_wr_"> | |
| 429 | + <div class="modal-header"> | |
| 430 | + <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button> | |
| 431 | + <h3 class="modal-title" id="Login">Обратная связь</h3> | |
| 432 | + </div> | |
| 433 | + <div class="modal-body"> | |
| 434 | + | |
| 435 | + <?php $form = ActiveForm::begin( | |
| 436 | + [ | |
| 437 | + 'id' => 'feedback-form', | |
| 438 | + 'method' => 'POST', | |
| 439 | + 'action' => '/site/feedback', | |
| 440 | + ] | |
| 441 | + ); ?> | |
| 442 | + | |
| 443 | + <?= $form->field($feedback, 'name') | |
| 444 | + ->textInput(); ?> | |
| 445 | + | |
| 446 | + <?= $form->field($feedback, 'email') | |
| 447 | + ->textInput(); ?> | |
| 448 | + | |
| 449 | + <?= $form->field($feedback, 'phone') | |
| 450 | + ->textInput(); ?> | |
| 451 | + | |
| 452 | + <?= $form->field($feedback, 'message') | |
| 453 | + ->textarea( | |
| 454 | + [ | |
| 455 | + 'rows' => 4, | |
| 456 | + ] | |
| 457 | + ); ?> | |
| 458 | + | |
| 459 | + <p class="text-center"> | |
| 460 | + <?= Html::submitButton( | |
| 461 | + 'Отправить', | |
| 462 | + [ | |
| 463 | + 'class' => 'send-form btn btn-lg btn-template-primary', | |
| 464 | + ] | |
| 465 | + ) ?> | |
| 466 | + </p> | |
| 467 | + | |
| 468 | + <?php ActiveForm::end(); ?> | |
| 469 | + | |
| 463 | 470 | </div> |
| 464 | - <div class="overlay-new"></div> | |
| 471 | + </div> | |
| 472 | + <div class="overlay-new"></div> | |
| 465 | 473 | </div> |
| 466 | 474 | |
| 467 | 475 | <!-- *** FeedBack MODAL END *** --> |
| ... | ... | @@ -469,19 +477,19 @@ _________________________________________________________ --> |
| 469 | 477 | <!-- *** FeedBack MODAL *** |
| 470 | 478 | _________________________________________________________ --> |
| 471 | 479 | <div class="success_" id="success-modal" aria-labelledby="Success" aria-hidden="true"> |
| 472 | - <div class="forms_wr_"> | |
| 473 | - <div class="modal-header"> | |
| 474 | - <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button> | |
| 475 | - <h3 class="modal-title" id="Success">Отправлено</h3> | |
| 476 | - </div> | |
| 477 | - <div class="modal-body"> | |
| 478 | - | |
| 479 | - <p>Thank for your reply, we will call you, maybe.</p> | |
| 480 | - <p class="text-center"> | |
| 481 | - <button type="button" class="btn btn-template-primary" data-dismiss="modal">Закрыть</button> | |
| 482 | - </p> | |
| 483 | - </div> | |
| 480 | + <div class="forms_wr_"> | |
| 481 | + <div class="modal-header"> | |
| 482 | + <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button> | |
| 483 | + <h3 class="modal-title" id="Success">Отправлено</h3> | |
| 484 | 484 | </div> |
| 485 | + <div class="modal-body"> | |
| 486 | + | |
| 487 | + <p>Thank for your reply, we will call you, maybe.</p> | |
| 488 | + <p class="text-center"> | |
| 489 | + <button type="button" class="btn btn-template-primary" data-dismiss="modal">Закрыть</button> | |
| 490 | + </p> | |
| 491 | + </div> | |
| 492 | + </div> | |
| 485 | 493 | </div> |
| 486 | 494 | |
| 487 | 495 | <!-- *** FeedBack MODAL END *** --> |
| ... | ... | @@ -584,7 +592,7 @@ _________________________________________________________ --> |
| 584 | 592 | <!-- /#footer --> |
| 585 | 593 | |
| 586 | 594 | <!-- *** FOOTER END *** --> |
| 587 | - | |
| 595 | + | |
| 588 | 596 | <span id="back-to-top" title="Back to top"><i class="fa fa-arrow-up"></i></span> |
| 589 | 597 | |
| 590 | 598 | </div> | ... | ... |
frontend/views/site/comment/artbox_comment_form.php
0 → 100755
| 1 | +<?php | |
| 2 | + use artbox\webcomment\models\CommentModel; | |
| 3 | + use artbox\webcomment\models\RatingModel; | |
| 4 | + use yii\base\Model; | |
| 5 | + use yii\helpers\Html; | |
| 6 | + use yii\helpers\Url; | |
| 7 | + use yii\web\View; | |
| 8 | + use yii\widgets\ActiveForm; | |
| 9 | + | |
| 10 | + /** | |
| 11 | + * @var CommentModel $comment_model | |
| 12 | + * @var array $form_params | |
| 13 | + * @var Model $model | |
| 14 | + * @var string $formId | |
| 15 | + * @var View $this | |
| 16 | + * @var RatingModel|NULL $rating_model | |
| 17 | + */ | |
| 18 | + $form = ActiveForm::begin( | |
| 19 | + [ | |
| 20 | + 'id' => $formId, | |
| 21 | + 'action' => Url::to( | |
| 22 | + [ | |
| 23 | + 'artbox-comment/default/create', | |
| 24 | + 'entity' => $comment_model->encryptedEntity, | |
| 25 | + ] | |
| 26 | + ), | |
| 27 | + ] | |
| 28 | + ); | |
| 29 | +?> | |
| 30 | + <div class="form-comm-wr"> | |
| 31 | + <?php | |
| 32 | + if (!empty($rating_model)) { | |
| 33 | + ?> | |
| 34 | + <div class="input_bl stars-wr_"> | |
| 35 | + <?php | |
| 36 | + echo $form->field($rating_model, 'value', [ 'enableClientValidation' => false ]) | |
| 37 | + ->hiddenInput() | |
| 38 | + ->label(false); | |
| 39 | + echo Html::tag( | |
| 40 | + 'div', | |
| 41 | + '', | |
| 42 | + [ | |
| 43 | + 'class' => 'rateit', | |
| 44 | + 'data-rateit-backingfld' => '#' . Html::getInputId($rating_model, 'value'), | |
| 45 | + ] | |
| 46 | + ); | |
| 47 | + ?> | |
| 48 | + </div> | |
| 49 | + <?php | |
| 50 | + } | |
| 51 | + if (\Yii::$app->user->isGuest) { | |
| 52 | + echo $form->field($comment_model, 'username', [ 'options' => [ 'class' => 'form-group input_bl' ] ]) | |
| 53 | + ->textInput(); | |
| 54 | + echo $form->field($comment_model, 'email', [ 'options' => [ 'class' => 'form-group input_bl' ] ]) | |
| 55 | + ->textInput(); | |
| 56 | + } | |
| 57 | + echo $form->field($comment_model, 'text', [ 'options' => [ 'class' => 'form-group input_bl area_bl' ] ]) | |
| 58 | + ->textarea(); | |
| 59 | + echo Html::tag( | |
| 60 | + 'div', | |
| 61 | + Html::submitButton( | |
| 62 | + Yii::t('app', 'Submit comment') | |
| 63 | + ), | |
| 64 | + [ 'class' => 'input_bl submit_btn' ] | |
| 65 | + ); | |
| 66 | + ?> | |
| 67 | + </div> | |
| 68 | +<?php | |
| 69 | + ActiveForm::end(); | |
| 70 | +?> | |
| 0 | 71 | \ No newline at end of file | ... | ... |
frontend/views/site/comment/artbox_comment_item.php
0 → 100755
| 1 | +<?php | |
| 2 | + use artbox\webcomment\models\CommentModel; | |
| 3 | + use yii\helpers\Html; | |
| 4 | + use yii\helpers\Url; | |
| 5 | + use yii\widgets\ListView; | |
| 6 | + | |
| 7 | + /** | |
| 8 | + * @var CommentModel $model | |
| 9 | + * @var mixed $key | |
| 10 | + * @var int $index | |
| 11 | + * @var ListView $widget | |
| 12 | + * @var string $display_name | |
| 13 | + * @var array $more | |
| 14 | + */ | |
| 15 | + | |
| 16 | +?> | |
| 17 | + | |
| 18 | +<div class="comments-wr"> | |
| 19 | + <div class="artbox_item_info"> | |
| 20 | + <div class="user-ico"> | |
| 21 | + <?php | |
| 22 | + echo mb_substr($model->username, 0,1); | |
| 23 | + ?> | |
| 24 | + </div> | |
| 25 | + <div class="user_data" itemprop="datePublished"> | |
| 26 | + <?php | |
| 27 | + echo date('d.m.Y', $model->created_at); | |
| 28 | + ?> | |
| 29 | + </div> | |
| 30 | + <div class="user_name" itemprop="author"> | |
| 31 | + <?php | |
| 32 | + $nameField = $display_name; | |
| 33 | + echo $model->username . ' (' . Yii::t('artbox-comment', 'Guest') . ')'; | |
| 34 | + ?> | |
| 35 | + </div> | |
| 36 | + <?php | |
| 37 | + if (!empty($model->rating)) { | |
| 38 | + ?> | |
| 39 | + <div class="user_rating" itemprop="reviewRating" itemscope itemtype="http://schema.org/Rating"> | |
| 40 | + <span itemprop="worstRating" style="display: none">1</span> | |
| 41 | + <span itemprop="ratingValue" style="display: none"><?php echo $model->rating->value; ?></span> | |
| 42 | + <span itemprop="bestRating" style="display: none">5</span> | |
| 43 | + <div class="rateit" data-rateit-value="<?php echo $model->rating->value; ?>" data-rateit-ispreset="true" data-rateit-readonly="true"></div> | |
| 44 | + </div> | |
| 45 | + <?php | |
| 46 | + } | |
| 47 | + ?> | |
| 48 | + <div class="user_txt" itemprop="description"> | |
| 49 | + <?php | |
| 50 | + echo $model->text; | |
| 51 | + ?> | |
| 52 | + </div> | |
| 53 | + </div> | |
| 54 | + <div class="artbox_item_tools comment-panel"> | |
| 55 | + <?php | |
| 56 | + if (!\Yii::$app->user->isGuest && $reply && \Yii::$app->user->id != $model->customer_id) { | |
| 57 | + ?> | |
| 58 | + <a href="" class="btn-comm-answer" data-action="reply"><?php echo \Yii::t( | |
| 59 | + 'artbox-comment', | |
| 60 | + 'Ответить' | |
| 61 | + ); ?></a> | |
| 62 | + <?php | |
| 63 | + } | |
| 64 | + if (!\Yii::$app->user->isGuest && \Yii::$app->user->id == $model->customer_id && $delete) { | |
| 65 | + ?> | |
| 66 | + <a href="" class="btn-comm-delete" data-action="delete" data-url="<?php echo Url::to( | |
| 67 | + [ | |
| 68 | + 'artbox-comment/default/delete', | |
| 69 | + 'id' => $model->id, | |
| 70 | + ] | |
| 71 | + ); ?>"><?php echo \Yii::t('artbox-comment', 'Удалить'); ?></a> | |
| 72 | + <?php | |
| 73 | + } | |
| 74 | + // Like / dislike to be done | |
| 75 | + /* | |
| 76 | + ?> | |
| 77 | + <a href="" class="btn-comm-like" data-action="like" data-url="<?php echo Url::to([ | |
| 78 | + 'artbox-comment/default/like', | |
| 79 | + 'id' => $model->artbox_comment_id, | |
| 80 | + ]); ?>">Like</a> | |
| 81 | + <a href="" class="btn-comm-dislike" data-action="dislike" data-url="<?php echo Url::to([ | |
| 82 | + 'artbox-comment/default/dislike', | |
| 83 | + 'id' => $model->artbox_comment_id, | |
| 84 | + ]); ?>">Dislike</a> | |
| 85 | + <?php | |
| 86 | + */ | |
| 87 | + ?> | |
| 88 | + <div class="artbox_item_reply"></div> | |
| 89 | + </div> | |
| 90 | +</div> | |
| 91 | +<div class="artbox_children_container"> | |
| 92 | + <?php | |
| 93 | + if (!empty($model->children)) { | |
| 94 | + foreach ($model->children as $index => $child) { | |
| 95 | + ?> | |
| 96 | + <div class="artbox_child_container comment-answer" data-key="<?php echo $child->id; ?>"> | |
| 97 | + <div class="artbox_child_info"> | |
| 98 | + <div class="user-ico"> | |
| 99 | + <?php | |
| 100 | + echo Html::img('/img/no-image.png'); | |
| 101 | + ?> | |
| 102 | + </div> | |
| 103 | + <div class="user_data"> | |
| 104 | + <?php | |
| 105 | + echo date('d.m.Y', $child->created_at); | |
| 106 | + ?> | |
| 107 | + </div> | |
| 108 | + <div class="user_name"> | |
| 109 | + <?php | |
| 110 | + $nameField = $display_name; | |
| 111 | + if (!empty($child->customer)) { | |
| 112 | + echo $child->customer->$nameField; | |
| 113 | + } else { | |
| 114 | + echo $child->username . ' (' . Yii::t('artbox-comment', 'Guest') . ')'; | |
| 115 | + } | |
| 116 | + ?> | |
| 117 | + </div> | |
| 118 | + <div class="user_txt"> | |
| 119 | + <?php | |
| 120 | + echo $child->text; | |
| 121 | + ?> | |
| 122 | + </div> | |
| 123 | + </div> | |
| 124 | + <div class="artbox_child_tools comment-panel"> | |
| 125 | + <?php | |
| 126 | + if (!\Yii::$app->user->isGuest && $reply && \Yii::$app->user->id != $child->customer_id) { | |
| 127 | + ?> | |
| 128 | + <a href="" class="btn-comm-answer" data-action="reply"><?php echo \Yii::t( | |
| 129 | + 'artbox-comment', | |
| 130 | + 'Ответить' | |
| 131 | + ); ?></a> | |
| 132 | + <?php | |
| 133 | + } | |
| 134 | + if (!\Yii::$app->user->isGuest && \Yii::$app->user->id == $child->customer_id && $delete) { | |
| 135 | + ?> | |
| 136 | + <a href="" class="btn-comm-delete" data-action="delete" data-url="<?php echo Url::to( | |
| 137 | + [ | |
| 138 | + 'artbox-comment/default/delete', | |
| 139 | + 'id' => $child->id, | |
| 140 | + ] | |
| 141 | + ); ?>"><?php echo \Yii::t('artbox-comment', 'Удалить'); ?></a> | |
| 142 | + <?php | |
| 143 | + } | |
| 144 | + /* Like /dislike to be done | |
| 145 | + ?> | |
| 146 | + <a href="" class="btn-comm-like" data-action="like" data-url="<?php echo Url::to([ | |
| 147 | + 'artbox-comment/default/like', | |
| 148 | + 'id' => $child->artbox_comment_id, | |
| 149 | + ]); ?>">Like</a> | |
| 150 | + <a href="" class="btn-comm-dislike" data-action="dislike" data-url="<?php echo Url::to([ | |
| 151 | + 'artbox-comment/default/dislike', | |
| 152 | + 'id' => $child->artbox_comment_id, | |
| 153 | + ]); ?>">Dislike</a> | |
| 154 | + <?php | |
| 155 | + */ | |
| 156 | + ?> | |
| 157 | + <div class="artbox_child_reply"></div> | |
| 158 | + </div> | |
| 159 | + </div> | |
| 160 | + <?php | |
| 161 | + } | |
| 162 | + } | |
| 163 | + ?> | |
| 164 | +</div> | |
| 165 | + | |
| 166 | + | ... | ... |
frontend/views/site/comment/artbox_comment_list.php
0 → 100755
| 1 | +<?php | |
| 2 | + use artbox\webcomment\models\CommentModel; | |
| 3 | + use yii\base\Model; | |
| 4 | + use yii\data\ActiveDataProvider; | |
| 5 | + use yii\helpers\Html; | |
| 6 | + use yii\web\View; | |
| 7 | + use yii\widgets\ListView; | |
| 8 | + use yii\widgets\Pjax; | |
| 9 | + | |
| 10 | + /** | |
| 11 | + * @var CommentModel $comment_model | |
| 12 | + * @var array $list_params | |
| 13 | + * @var array $item_options | |
| 14 | + * @var string $item_view | |
| 15 | + * @var Model $model | |
| 16 | + * @var ActiveDataProvider $comments | |
| 17 | + * @var View $this | |
| 18 | + * @var string $display_name | |
| 19 | + * @var boolean $reply , | |
| 20 | + * @var boolean $delete | |
| 21 | + */ | |
| 22 | + Pjax::begin(); | |
| 23 | + if(( $success = \Yii::$app->session->getFlash('artbox_comment_success') ) != NULL) { | |
| 24 | + echo Html::tag('p', $success); | |
| 25 | + } | |
| 26 | + echo ListView::widget([ | |
| 27 | + 'dataProvider' => $comments, | |
| 28 | + 'itemOptions' => $item_options, | |
| 29 | + 'itemView' => $item_view, | |
| 30 | + 'emptyText' => false, | |
| 31 | + 'summary' => '', | |
| 32 | + 'viewParams' => [ | |
| 33 | + 'display_name' => $display_name, | |
| 34 | + 'reply' => $reply, | |
| 35 | + 'delete' => $delete, | |
| 36 | + 'more' => $more, | |
| 37 | + 'last' => $comments->count, | |
| 38 | + ], | |
| 39 | + 'beforeItem' => function ($model, $key, $index, $widget) use ($more, $comments) { | |
| 40 | + if ($more['key'] == $index and $more['show_'] ){ | |
| 41 | + | |
| 42 | + return "<a id='show_more_link' style='cursor:pointer'>Показать еще</a> | |
| 43 | + <div id='show_more' style='display: none'>"; | |
| 44 | + } | |
| 45 | + }, | |
| 46 | + 'afterItem' => function ($model, $key, $index, $widget) use ($more, $comments) { | |
| 47 | + if ($index == ($comments->count-1) and $more['show_'] and $more['key'] < $comments->count){ | |
| 48 | + | |
| 49 | + return "<a id='hide_more_link' style='cursor:pointer'>Скрыть комментарии</a></div>"; | |
| 50 | + } | |
| 51 | +} | |
| 52 | + | |
| 53 | + | |
| 54 | + ]); | |
| 55 | + Pjax::end(); | |
| 56 | + | |
| 0 | 57 | \ No newline at end of file | ... | ... |
frontend/views/site/comment/artbox_comment_reply.php
0 → 100755
| 1 | +<?php | |
| 2 | + use artbox\webcomment\models\CommentModel; | |
| 3 | + use yii\base\Model; | |
| 4 | + use yii\helpers\Html; | |
| 5 | + use yii\helpers\Url; | |
| 6 | + use yii\web\View; | |
| 7 | + use yii\widgets\ActiveForm; | |
| 8 | + | |
| 9 | + /** | |
| 10 | + * @var CommentModel $comment_model | |
| 11 | + * @var array $form_params | |
| 12 | + * @var Model $model | |
| 13 | + * @var string $formId | |
| 14 | + * @var View $this | |
| 15 | + */ | |
| 16 | + $text_input_id = Html::getInputId($comment_model, 'text') . '-reply'; | |
| 17 | + $parent_id_input_id = Html::getInputId($comment_model, 'parent_id') . '-reply'; | |
| 18 | + $text_input_selectors = [ | |
| 19 | + 'container' => '.field-' . $text_input_id, | |
| 20 | + 'input' => '#' . $text_input_id, | |
| 21 | + ]; | |
| 22 | + $parent_id_input_selectors = [ | |
| 23 | + 'container' => '.field-' . $parent_id_input_id, | |
| 24 | + 'input' => '#' . $parent_id_input_id, | |
| 25 | + ]; | |
| 26 | + $form = ActiveForm::begin([ | |
| 27 | + 'id' => $formId . '-reply', | |
| 28 | + 'action' => Url::to([ | |
| 29 | + 'artbox-comment/default/create', | |
| 30 | + 'entity' => $comment_model->encryptedEntity, | |
| 31 | + ]), | |
| 32 | + ]); | |
| 33 | +?> | |
| 34 | + <div class="answer-form"> | |
| 35 | + <?php | |
| 36 | + echo $form->field( | |
| 37 | + $comment_model, | |
| 38 | + 'parent_id', | |
| 39 | + [ | |
| 40 | + 'selectors' => $parent_id_input_selectors, | |
| 41 | + 'inputOptions' => [ | |
| 42 | + 'id' => $parent_id_input_id, | |
| 43 | + 'class' => 'form-control', | |
| 44 | + ], | |
| 45 | + ]) | |
| 46 | + ->hiddenInput() | |
| 47 | + ->label(false); | |
| 48 | + echo $form->field($comment_model, 'text', [ | |
| 49 | + 'selectors' => $text_input_selectors, | |
| 50 | + 'inputOptions' => [ | |
| 51 | + 'id' => $text_input_id, | |
| 52 | + 'class' => 'form-control', | |
| 53 | + 'cols' => 30, | |
| 54 | + 'rows' => 10, | |
| 55 | + ], | |
| 56 | + ]) | |
| 57 | + ->textarea(); | |
| 58 | + echo Html::submitButton(Yii::t('artbox-comment', 'Submit')); | |
| 59 | + echo Html::button(Yii::t('artbox-comment', 'Cancel'), [ 'data-action' => 'reply-cancel' ]); | |
| 60 | + ?> | |
| 61 | + </div> | |
| 62 | +<?php | |
| 63 | + ActiveForm::end(); | |
| 64 | +?> | |
| 0 | 65 | \ No newline at end of file | ... | ... |
| 1 | +<?php | |
| 2 | + | |
| 3 | + use artbox\webcomment\models\CommentModel; | |
| 4 | + use artbox\webcomment\widgets\CommentWidget; | |
| 5 | + use yii\web\View; | |
| 6 | + | |
| 7 | + /** | |
| 8 | + * @var View $this | |
| 9 | + * @var CommentModel $model | |
| 10 | + */ | |
| 11 | + | |
| 12 | +?> | |
| 13 | + | |
| 14 | +<div> | |
| 15 | + | |
| 16 | + <?php | |
| 17 | + echo CommentWidget::widget( | |
| 18 | + [ | |
| 19 | + 'model' => $model, | |
| 20 | + 'display_name' => 'name', | |
| 21 | + 'reply' => true, | |
| 22 | + 'delete' => false, | |
| 23 | + 'more' => [ | |
| 24 | + 'show_' => true, | |
| 25 | + 'key' => 2, | |
| 26 | + ], | |
| 27 | + 'formView' => '@frontend/views/site/comment/artbox_comment_form', | |
| 28 | + 'listView' => '@frontend/views/site/comment/artbox_comment_list', | |
| 29 | + 'replyView' => '@frontend/views/site/comment/artbox_comment_reply', | |
| 30 | + 'itemView' => '@frontend/views/site/comment/artbox_comment_item', | |
| 31 | + ] | |
| 32 | + ); | |
| 33 | + ?> | |
| 34 | + | |
| 35 | +</div> | ... | ... |