Blame view

frontend/views/catalog/product.php 18.9 KB
055ecc3b   Karnovsky A   Karnovsky 11052016
1
  <?php
01905ec6   Yarik   Filter fixing
2
3
4
      /**
       * @var Category $category
       */
3cd9d528   Yarik   Added icons to ba...
5
6
7
      //    use common\modules\comment\models\Comment;
      //    use common\modules\comment\models\Rating;
      //    use common\modules\comment\widgets\CommentWidget;
e608c5f7   Yarik   Comment added
8
      use common\modules\comment\widgets\CommentWidget;
01905ec6   Yarik   Filter fixing
9
      use common\modules\product\models\Category;
873e3d80   Administrator   14.09.16
10
11
  use yii\helpers\Html;
  use yii\web\View;
85040b57   Yarik   Comment added
12
13
      use yii\helpers\Url;
      use frontend\widgets\Seo;
873e3d80   Administrator   14.09.16
14
15
  use frontend\assets\FlipclockAsset;
  FlipclockAsset::register($this);
01905ec6   Yarik   Filter fixing
16
      $this->params[ 'seo' ][ 'key' ] = $category->categoryName->value;
85040b57   Yarik   Comment added
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
      $this->params[ 'seo' ][ 'fields' ][ 'name' ] = $product->fullname;
      $this->params[ 'seo' ][ 'h1' ] = !empty( Seo::widget([ 'row' => 'h1' ]) ) ? Seo::widget([ 'row' => 'h1' ]) : $product->fullname;
      
      //$this->params['seo']['title'] =  "Купить " . substr($product->category->categoryName->value, 0, -2) . " " . $product->fullname . " в Киеве, Харькове, Украине: цены, отзывы - Rukzachok.com.ua";
      //$this->params['seo']['description'] = "Заказать " . substr($product->category->categoryName->value, 0, -2) . " " . $product->fullname . " - самые модные и стильные рюкзаки в Украине по лучшим ценам. Интернет магазин рюкзаков Rukzachok.com.ua";
      $this->title = $product->fullname;
      //$this->title = (! empty($product->meta_title)) ? $product->meta_title : $product->fullname;
      //$this->registerMetaTag (['name' => 'description', 'content' => ((! empty($product->meta_description)) ? $product->meta_description : $product->fullname)]);
      //$this->registerMetaTag (['name' => 'keywords', 'content' => $product->meta_keywords]);
      
      //foreach($product->category->getParents()->all() as $parent) {
      //    $this->params['breadcrumbs'][] = ['label' => $parent->categoryName->value, 'url' => ['catalog/category', 'category' => $parent]];
      //}
      $this->params[ 'breadcrumbs' ][] = [
          'label' => 'Каталог',
          'url'   => [ 'catalog/category' ],
      ];
      $this->params[ 'breadcrumbs' ][] = [
01905ec6   Yarik   Filter fixing
35
          'label' => $category->categoryName->value,
85040b57   Yarik   Comment added
36
37
          'url'   => [
              'catalog/category',
01905ec6   Yarik   Filter fixing
38
              'category' => $category,
85040b57   Yarik   Comment added
39
40
41
42
43
          ],
      ];
      $this->params[ 'breadcrumbs' ][] = $product->fullname . ' #' . $product->enabledVariants[ 0 ]->sku;
      
      $this->registerJs('
055ecc3b   Karnovsky A   Karnovsky 11052016
44
  
ccc7a9d3   Karnovsky A   Karnovsky 12052016
45
46
          var checkData = function($index)
          {
f307b0a8   Karnovsky A   -
47
48
49
50
              var sourceNew = $(".productLeftBar .product_mod > li").eq($index);
              $(".productLeftBar .product_mod > li").removeClass("active")
              sourceNew.addClass("active");
              var $source = sourceNew.find("a");
ccc7a9d3   Karnovsky A   Karnovsky 12052016
51
              var $target = $(".productLeftBar .cost_box");
055ecc3b   Karnovsky A   Karnovsky 11052016
52
  
ccc7a9d3   Karnovsky A   Karnovsky 12052016
53
54
              $("#cost").text($source.data("cost"));
              $("#old_cost").text($source.data("old_cost"));
055ecc3b   Karnovsky A   Karnovsky 11052016
55
  
ccc7a9d3   Karnovsky A   Karnovsky 12052016
56
57
58
59
60
61
62
63
              if (parseInt ($source.data("old_cost")) == 0)
              {
                  $target.find("strike").hide();
              }
              else
              {
                  $target.find("strike").show();
              }
055ecc3b   Karnovsky A   Karnovsky 11052016
64
  
ccc7a9d3   Karnovsky A   Karnovsky 12052016
65
66
67
68
69
70
              $("#product_id").val($source.data("id"));
              $("#art").text($source.data("art"));
              $("#color").text($source.data("color"));
              $("#pic").attr("src",$source.data("image"));
              $("#picoriginal").attr("href",$source.data("imageoriginal"));
          }
055ecc3b   Karnovsky A   Karnovsky 11052016
71
  
ccc7a9d3   Karnovsky A   Karnovsky 12052016
72
73
74
          $(".product_mod > li").click(function()
          {
              checkData($(this).index());
055ecc3b   Karnovsky A   Karnovsky 11052016
75
  
ccc7a9d3   Karnovsky A   Karnovsky 12052016
76
              Shadowbox.setup($("#picoriginal"));
055ecc3b   Karnovsky A   Karnovsky 11052016
77
  
ccc7a9d3   Karnovsky A   Karnovsky 12052016
78
79
              return false;
          });
055ecc3b   Karnovsky A   Karnovsky 11052016
80
  
ccc7a9d3   Karnovsky A   Karnovsky 12052016
81
82
83
          checkData(0);
  
      ', View::POS_READY, 'fasovka');
85040b57   Yarik   Comment added
84
85
      
      $this->registerJs("
ccc7a9d3   Karnovsky A   Karnovsky 12052016
86
87
88
89
90
91
92
93
94
95
96
97
          $('#nav_product li a').addClass('active');
          $('#nav_product li').find('.info').toggle();
  
          $('#nav_product li a').bind('click',function()
          {
              if($(this).parent().find('.info').css('display')=='none')$(this).addClass('active');
              else $(this).removeClass('active');
              $(this).parent().find('.info').toggle();
  
              return false;
          });
      ", View::POS_READY, 'nav_product');
85040b57   Yarik   Comment added
98
99
100
101
102
103
104
      
      $this->registerCssFile(Yii::$app->request->BaseUrl . '/js/shadowbox-3.0.3/shadowbox.css');
      $this->registerJsFile(Yii::$app->request->baseUrl . '/js/shadowbox-3.0.3/shadowbox.js', [
          'position' => View::POS_END,
          'depends'  => [ 'yii\web\JqueryAsset' ],
      ]);
      $this->registerJs("
ccc7a9d3   Karnovsky A   Karnovsky 12052016
105
106
107
108
109
          Shadowbox.init({
  
      });
      ", View::POS_READY, 'Shadowbox');
  ?>
af7fb26a   Administrator   20.07.16
110
  
85040b57   Yarik   Comment added
111
  <?php if($flash = Yii::$app->session->getFlash('success')): ?>
ccc7a9d3   Karnovsky A   Karnovsky 12052016
112
113
      <div class="alert-success"><?= $flash ?></div>
  <?php endif; ?>
85040b57   Yarik   Comment added
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
      <div class="loyout">
          <div itemscope itemtype="http://schema.org/Product">
              <div class="productLeftBar">
                  <div itemprop="name"><h1><?= Seo::widget([ 'row' => 'h1' ]) ?></h1></div>
                  <?php foreach($product->enabledVariantsGrouped as $variantGroup) : ?>
                      <div class="begin"><?= $variantGroup->name2 ?></div>
                      <ul class="product_mod">
                          <?php foreach($variantGroup->_variants as $variant): ?>
                              <li>
                                  <a id='m<?= $variant->product_variant_id ?>' href="#<?= $variant->product_variant_id ?>"
                                      data-cost="<?= $variant->price ?>"
                                      data-old_cost="<?= $variant->price_old ?>" data-id="<?= $variant->product_variant_id ?>" data-art="<?= $variant->sku ?>"
                                      data-color="<?= $variant->name ?>"
                                      data-image="<?= \common\components\artboximage\ArtboxImageHelper::getImageSrc($variant->imageUrl, 'product_view') ?>"
                                      data-imageoriginal="<?= $variant->imageUrl ?>"
                                      title="<?= $product->fullname ?>">
                                      <?= \common\components\artboximage\ArtboxImageHelper::getImage($variant->imageUrl, 'product_variant', [
01905ec6   Yarik   Filter fixing
131
132
                                          'alt'   => $category->categoryName->value . ' ' . $product->fullname,
                                          'title' => $category->categoryName->value . ' ' . $product->fullname,
85040b57   Yarik   Comment added
133
134
135
136
137
138
139
140
141
142
143
144
145
146
                                      ]) ?>
                                  </a>
                              </li>
                          <?php endforeach; ?>
                      </ul>
                      <div class="both"></div>
                  <?php endforeach; ?>
                  
                  <div class="cost_box product_read_">
                      <div itemprop="offers" itemscope itemtype="http://schema.org/Offer">
                          <div class='params'>код: <span id='art'></span><br/> цвет:
                              <span id='color'></span></div>
                          <div class="product_read_price">
                              <div class="w">
34587997   Yarik   Commented share b...
147
                                  <strike><span><span id='old_cost'><?= $variant->price_old ?></span></span> грн.</strike>
af7fb26a   Administrator   20.07.16
148
                                  <span class="cost"><span itemprop="price"><span id='cost'><?= $variant->price ?></span></span> <span class="valute">грн.</span></span>
85040b57   Yarik   Comment added
149
150
151
152
153
154
155
                                  <meta itemprop="priceCurrency" content="UAH">
                              </div>
                              <input type='hidden' id='product_id'/>
                              <a href="#" rel='product' class="link_buy fl">Купить</a>
                              <div class="both"></div>
                          </div>
                      </div>
20ef43de   Yarik   Avarage rating st...
156
157
158
159
160
                      <div class="check_price">
                          <span>
                              Наличие и цены уточняйте на момент покупки.
                          </span>
                      </div>
85040b57   Yarik   Comment added
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
                      <div class="product_service">
                          <ul>
                              <?php if(Yii::$app->user->id) : ?>
                                  <li class="item1"><a href="<?= Url::to([
                                          'iam/share',
                                          'id' => $product->product_id,
                                      ]) ?>">Добавить в закладки</a></li>
                              <?php endif ?>
                              <?php if(false && Yii::$app->user->id) : ?>
                                  <li class="item2"><a href="<?= Url::to([
                                          'iam/price',
                                          'id' => $product->product_id,
                                      ]) ?>">Узнать о снижение цены</a></li>
                              <?php endif ?>
                              <?php if(false) : ?>
                                  <li class="item3"><a href="<?= Url::to([
                                          'products/compare',
                                          'id' => $product->product_id,
                                      ]) ?>">Добавить в сравнение</a></li>
                              <?php endif ?>
                          </ul>
                      </div>
                      <div class="artbox_comment_description">
8f36efb7   Yarik   Added comments to...
184
185
186
                          <?php
                              if(!empty( $product->averageRating ) && $product->averageRating->value) {
                                  ?>
20ef43de   Yarik   Avarage rating st...
187
                                  <div itemprop="aggregateRating" class="product_rating_block" itemscope itemtype="http://schema.org/AggregateRating">
14009e7f   Yarik   Structure data fix
188
189
190
191
                                      <span itemprop="ratingValue" style="display: none"><?php echo $product->averageRating->value; ?></span>
                                      <span itemprop="ratingCount" style="display: none"><?php echo count($product->comments); ?></span>
                                      <div class="rateit" data-rateit-value="<?php echo $product->averageRating->value; ?>" data-rateit-readonly="true" data-rateit-ispreset="true"></div>
                                  </div>
8f36efb7   Yarik   Added comments to...
192
193
194
                                  <?php
                              }
                          ?>
20ef43de   Yarik   Avarage rating st...
195
                          <p class="product_review_block"><a href="#artbox-comment" itemprop="interactionCount">
8f36efb7   Yarik   Added comments to...
196
197
198
199
200
                                  <?php
                                      $comment_count = count($product->comments);
                                      if($comment_count) {
                                          echo "Отзывов: " . $comment_count;
                                      } else {
bf6045a8   Yarik   Rating styling fix.
201
                                          echo "Оставить отзыв";
8f36efb7   Yarik   Added comments to...
202
203
204
                                      }
                                  ?>
                              </a></p>
85040b57   Yarik   Comment added
205
206
                      </div>
                      <br>
34587997   Yarik   Commented share b...
207
208
209
210
211
212
213
                      <?php
                          /* Share buttons
                          ?>
                          <div class="ya-share2" data-services="vkontakte,facebook,odnoklassniki,gplus,twitter" data-size="s"></div>
                          <?php
                          */
                      ?>
85040b57   Yarik   Comment added
214
                  </div>
8f36efb7   Yarik   Added comments to...
215
216
217
218
219
220
221
222
                  <div class="labels_block">
                      <div class="labels_item">
                          <img src="/img/icon_100_original_01.png" alt="">
                      </div>
                      <div class="labels_item">
                          <img src="/img/icon_100_quaranty_01.png" alt="">
                      </div>
                  </div>
85040b57   Yarik   Comment added
223
                  <?php /*
ccc7a9d3   Karnovsky A   Karnovsky 12052016
224
225
226
227
228
229
230
231
232
          <div class="product_service">
              <ul>
                  <li class="item1"><a href="<?= Url::to (['iam/share', 'id' => $product->product_id]) ?>">Добавить в закладки</a>
                  </li>
                  <li class="item2"><a href="<?= Url::to (['iam/price', 'id' => $product->product_id]) ?>">Узнать о снижение
                          цены</a></li>
                  <li class="item3"><a href="<?= Url::to (['products/compare', 'id' => $product->product_id]) ?>">Добавить в
                          сравнение</a></li>
              </ul>
85040b57   Yarik   Comment added
233
234
235
236
          </div>*/ ?>
              </div>
              
              <div class="productRightBar">
873e3d80   Administrator   14.09.16
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
                  <?php foreach($product->events as $event):?>
                      <?php if(!empty($event->end_at) && $event->isActive()):?>
                          <div class="event_block">
  
                              <div class="event_title"> <?=  Html::a('Акция!!! '.$event->name,Url::to(['event/show','alias'=>$event->alias,'id'=>$event->primaryKey]))?></div>
                              <div class="event_time">До конца осталось:</div>
                              <div class="clock_<?= $event->primaryKey ?> clock_product_first "></div>
                              <script type="text/javascript">
                                  var clock;
  
                                  $(document).ready(function() {
                                      var clock;
  
                                      clock = $('.clock_<?= $event->primaryKey ?>').FlipClock({
                                          clockFace: 'DailyCounter',
                                          language: 'ru',
                                          classes: {
                                              active: 'flip-clock-active',
                                              before: 'flip-clock-before',
                                              divider: 'flip-clock-divider',
                                              dot: 'flip-clock-dot',
                                              label: 'flip-clock-label',
                                              flip: 'flip',
                                              play: 'play',
                                              wrapper: 'flip-clock-wrapper'
                                          },
                                      });
  
                                      clock.setTime(<?= strtotime($event->end_at) - strtotime(date("Y-m-d H:i:s"))?>);
                                      clock.setCountdown(true);
                                      clock.start();
  
                                  });
                              </script>
  
                          </div>
                      <?php endif; ?>
                  <?php endforeach; ?>
  
85040b57   Yarik   Comment added
276
277
278
279
                  <ul id="nav_product">
                      <li><a href="#">Характеристики</a>
                          <div class="info">
                              <p>Бренд: <?= $product->brand->name ?></p>
01905ec6   Yarik   Filter fixing
280
                              <?php foreach($product->getActiveProperties($category->category_id) as $group): ?>
85040b57   Yarik   Comment added
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
                                  <p><?= $group->name ?> <?php foreach($group->_options as $option) : ?>&nbsp;<?= $option->ValueRenderHTML ?><?php endforeach ?></p>
                              <?php endforeach; ?>
                          </div>
                      </li>
                      <li><a href="#">Описание</a>
                          <div itemprop="description">
                              <div class="info">
                                  <?= $product->description ?>
                              </div>
                          </div>
                      </li>
                      <?php if(!empty( $product->video ) && strpos($product->video, '.jpg') === false && strpos($product->video, '.png') === false) : ?>
                          <li><a href="#">Видео</a>
                              <div class="info product-thumb-video">
                                  <?php if(strpos($product->video, '<iframe') !== false || strpos($product->video, '<object') !== false) : ?>
                                      <?= $product->video ?>
                                  <?php else : ?>
                                      <?= \cics\widgets\VideoEmbed::widget([
                                          'responsive' => false,
                                          'url'        => $product->video,
                                      ]) ?>
                                  <?php endif ?>
                              </div>
                          </li>
                      <?php endif ?>
                  </ul>
              </div>
14009e7f   Yarik   Structure data fix
308
309
310
311
312
              <div class="content">
                  <div class="pic">
                      <center>
                          <a href="#" rel="shadowbox[gal]" id="picoriginal"><?= \common\components\artboximage\ArtboxImageHelper::getImage($product->enabledVariants[ 0 ]->imageUrl, 'product_view', [
                                  'id'    => 'pic',
01905ec6   Yarik   Filter fixing
313
314
                                  'alt'   => $category->categoryName->value . ' ' . $product->fullname,
                                  'title' => $category->categoryName->value . ' ' . $product->fullname,
14009e7f   Yarik   Structure data fix
315
316
317
318
319
320
321
322
323
324
325
326
327
328
                              ]) ?></a>
                      </center>
                  </div>
                  <ul class="product_colors">
                      <?php foreach($product->images as $image): ?>
                          <li><a href="<?= $image->imageUrl ?>" rel="shadowbox[gal]">
                                  <?= \common\components\artboximage\ArtboxImageHelper::getImage($image->imageUrl, 'product_trumb2', [
                                      'alt'   => $category->categoryName->value . ' ' . $product->fullname,
                                      'title' => $category->categoryName->value . ' ' . $product->fullname,
                                  ]) ?>
                              </a></li>
                      <?php endforeach; ?>
                  </ul>
              </div>
873e3d80   Administrator   14.09.16
329
330
331
332
333
334
335
336
              <div class="events">
                  <?php foreach($product->events as $event):?>
                      <?php if(!empty($event->banner) && $event->isActive()):?>
                          <?=  Html::a(\common\components\artboximage\ArtboxImageHelper::getImage($event->bannerUrl, 'event_in_product'),Url::to(['event/show','alias'=>$event->alias,'id'=>$event->primaryKey]))?>
                      <?php endif; ?>
                  <?php endforeach; ?>
              </div>
  
14009e7f   Yarik   Structure data fix
337
338
339
340
341
342
343
344
345
              <div class="both"></div>
              <div class="comment-wrapper" style="padding-bottom:25px">
                  <?php
                      echo CommentWidget::widget([
                          'model' => $product,
                      ]);
                  ?>
                  <div class="both"></div>
              </div>
17ca60dd   Yarik   Added comments to...
346
              <div class="both"></div>
85040b57   Yarik   Comment added
347
          </div>
85040b57   Yarik   Comment added
348
349
350
351
352
          <?= \common\modules\product\widgets\similarProducts::widget([ 'product' => $product ]) ?>
          <?= \common\modules\product\widgets\specialProducts::widget([ 'type' => 'promo' ]) ?>
          <?= \common\modules\product\widgets\specialProducts::widget([ 'type' => 'new' ]) ?>
          <?= \common\modules\product\widgets\specialProducts::widget([ 'type' => 'top' ]) ?>
          <?= \common\modules\product\widgets\lastProducts::widget() ?>
e608c5f7   Yarik   Comment added
353
      </div>
85235ea6   Виталий   Веталь
354
  <?php
85040b57   Yarik   Comment added
355
      $this->registerJs("
2fcc30a0   Виталий   Веталь
356
357
358
359
360
361
362
363
364
365
366
367
368
369
        var productHash = window.location.hash;
              productHash = productHash.replace('#','')
  
              var productUl = $('ul.product_mod li')
              var productA = productUl.find('a#'+productHash)
              productUl.removeClass('active')
              productA.parent().addClass('active')
              var dataLink = productA.attr('data-imageoriginal')
              var dataImg = productA.attr('data-image')
  
              $('#pic').attr('src',dataImg)
              $('#pic').parent().attr('href',dataLink)
      ", View::POS_READY, 'new_script');
  ?>