Blame view

frontend/views/catalog/product.php 18.3 KB
055ecc3b   Karnovsky A   Karnovsky 11052016
1
  <?php
01905ec6   Yarik   Filter fixing
2
3
4
      /**
       * @var Category $category
       */
eed13986   Alex Savenko   base
5
  
e608c5f7   Yarik   Comment added
6
      use common\modules\comment\widgets\CommentWidget;
01905ec6   Yarik   Filter fixing
7
      use common\modules\product\models\Category;
eed13986   Alex Savenko   base
8
9
      use yii\helpers\Html;
      use yii\web\View;
85040b57   Yarik   Comment added
10
11
      use yii\helpers\Url;
      use frontend\widgets\Seo;
eed13986   Alex Savenko   base
12
13
14
      use frontend\assets\FlipclockAsset;
  
      FlipclockAsset::register($this);
01905ec6   Yarik   Filter fixing
15
      $this->params[ 'seo' ][ 'key' ] = $category->categoryName->value;
85040b57   Yarik   Comment added
16
      $this->params[ 'seo' ][ 'fields' ][ 'name' ] = $product->fullname;
cfc5b583   Administrator   14.09.16
17
      $this->params[ 'seo' ][ 'h1' ] = !empty( Seo::widget([ 'row' => 'h1' ]) ) ? Seo::widget([ 'row' => 'h1' ]) : $product->fullnamewithcategory;
85040b57   Yarik   Comment added
18
      
85040b57   Yarik   Comment added
19
      $this->title = $product->fullname;
eed13986   Alex Savenko   base
20
  
85040b57   Yarik   Comment added
21
22
23
24
25
      $this->params[ 'breadcrumbs' ][] = [
          'label' => 'Каталог',
          'url'   => [ 'catalog/category' ],
      ];
      $this->params[ 'breadcrumbs' ][] = [
01905ec6   Yarik   Filter fixing
26
          'label' => $category->categoryName->value,
85040b57   Yarik   Comment added
27
28
          'url'   => [
              'catalog/category',
01905ec6   Yarik   Filter fixing
29
              'category' => $category,
85040b57   Yarik   Comment added
30
31
          ],
      ];
3ce8e503   Alex Savenko   хлебные крошки
32
33
34
      $this->params[ 'breadcrumbs' ][] = [
          'label' => $category->name.' '.$product->brand->name,
          'url'   => [
fcbb31d1   Alex Savenko   фикс хлебных крош...
35
36
37
38
39
              'catalog/category',
              'category' => $category,
              'filters' => [
                  'brands' => [$product->brand->alias]
              ]
3ce8e503   Alex Savenko   хлебные крошки
40
41
          ],
      ];
e4cea6a9   Administrator   rm node nodule
42
      $this->params[ 'breadcrumbs' ][] = $product->fullname . ' #' . $product->variant->sku;
85040b57   Yarik   Comment added
43
44
      
      $this->registerJs('
055ecc3b   Karnovsky A   Karnovsky 11052016
45
  
ccc7a9d3   Karnovsky A   Karnovsky 12052016
46
47
          var checkData = function($index)
          {
f307b0a8   Karnovsky A   -
48
49
50
51
              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
52
              var $target = $(".productLeftBar .cost_box");
055ecc3b   Karnovsky A   Karnovsky 11052016
53
  
ccc7a9d3   Karnovsky A   Karnovsky 12052016
54
55
              $("#cost").text($source.data("cost"));
              $("#old_cost").text($source.data("old_cost"));
055ecc3b   Karnovsky A   Karnovsky 11052016
56
  
ccc7a9d3   Karnovsky A   Karnovsky 12052016
57
58
59
60
61
62
63
64
              if (parseInt ($source.data("old_cost")) == 0)
              {
                  $target.find("strike").hide();
              }
              else
              {
                  $target.find("strike").show();
              }
055ecc3b   Karnovsky A   Karnovsky 11052016
65
  
ccc7a9d3   Karnovsky A   Karnovsky 12052016
66
67
68
69
70
71
              $("#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
72
  
e4cea6a9   Administrator   rm node nodule
73
74
75
76
          $("body").on("click", ".link_buy_out_stock", function(e){
              e.preventDefault();
          });
          
ccc7a9d3   Karnovsky A   Karnovsky 12052016
77
78
79
          $(".product_mod > li").click(function()
          {
              checkData($(this).index());
055ecc3b   Karnovsky A   Karnovsky 11052016
80
  
ccc7a9d3   Karnovsky A   Karnovsky 12052016
81
              Shadowbox.setup($("#picoriginal"));
055ecc3b   Karnovsky A   Karnovsky 11052016
82
  
ccc7a9d3   Karnovsky A   Karnovsky 12052016
83
84
              return false;
          });
055ecc3b   Karnovsky A   Karnovsky 11052016
85
  
ccc7a9d3   Karnovsky A   Karnovsky 12052016
86
87
88
          checkData(0);
  
      ', View::POS_READY, 'fasovka');
85040b57   Yarik   Comment added
89
90
      
      $this->registerJs("
ccc7a9d3   Karnovsky A   Karnovsky 12052016
91
92
93
94
95
96
97
98
99
100
101
102
          $('#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
103
104
105
106
107
108
109
      
      $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
110
111
112
113
114
          Shadowbox.init({
  
      });
      ", View::POS_READY, 'Shadowbox');
  ?>
af7fb26a   Administrator   20.07.16
115
  
85040b57   Yarik   Comment added
116
  <?php if($flash = Yii::$app->session->getFlash('success')): ?>
ccc7a9d3   Karnovsky A   Karnovsky 12052016
117
118
      <div class="alert-success"><?= $flash ?></div>
  <?php endif; ?>
85040b57   Yarik   Comment added
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
      <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
136
137
                                          'alt'   => $category->categoryName->value . ' ' . $product->fullname,
                                          'title' => $category->categoryName->value . ' ' . $product->fullname,
85040b57   Yarik   Comment added
138
139
140
141
142
143
144
145
146
147
148
149
150
151
                                      ]) ?>
                                  </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">
e4cea6a9   Administrator   rm node nodule
152
153
                                  <strike><span><span id='old_cost'><?= $product->variant->price_old >0 ? $product->variant->price_old : 0?></span></span> грн.</strike>
                                  <span class="cost"><span itemprop="price"><span id='cost'><?= $product->variant->price ?></span></span> <span class="valute">грн.</span></span>
85040b57   Yarik   Comment added
154
155
156
                                  <meta itemprop="priceCurrency" content="UAH">
                              </div>
                              <input type='hidden' id='product_id'/>
e4cea6a9   Administrator   rm node nodule
157
                              <a href="#" rel='<?= $product->variant->price > 0 ? "product" : ""?>' class="<?= $product->variant->price > 0 ? "link_buy" : "link_buy_out_stock"?>"><?= $product->variant->price > 0 ? "Купить" : "Нет в наличии"?></a>
85040b57   Yarik   Comment added
158
159
160
                              <div class="both"></div>
                          </div>
                      </div>
20ef43de   Yarik   Avarage rating st...
161
162
163
164
165
                      <div class="check_price">
                          <span>
                              Наличие и цены уточняйте на момент покупки.
                          </span>
                      </div>
85040b57   Yarik   Comment added
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
                      <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...
189
190
191
                          <?php
                              if(!empty( $product->averageRating ) && $product->averageRating->value) {
                                  ?>
20ef43de   Yarik   Avarage rating st...
192
                                  <div itemprop="aggregateRating" class="product_rating_block" itemscope itemtype="http://schema.org/AggregateRating">
14009e7f   Yarik   Structure data fix
193
194
195
196
                                      <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...
197
198
199
                                  <?php
                              }
                          ?>
20ef43de   Yarik   Avarage rating st...
200
                          <p class="product_review_block"><a href="#artbox-comment" itemprop="interactionCount">
8f36efb7   Yarik   Added comments to...
201
202
203
204
205
                                  <?php
                                      $comment_count = count($product->comments);
                                      if($comment_count) {
                                          echo "Отзывов: " . $comment_count;
                                      } else {
bf6045a8   Yarik   Rating styling fix.
206
                                          echo "Оставить отзыв";
8f36efb7   Yarik   Added comments to...
207
208
209
                                      }
                                  ?>
                              </a></p>
85040b57   Yarik   Comment added
210
211
                      </div>
                      <br>
34587997   Yarik   Commented share b...
212
213
214
215
216
217
218
                      <?php
                          /* Share buttons
                          ?>
                          <div class="ya-share2" data-services="vkontakte,facebook,odnoklassniki,gplus,twitter" data-size="s"></div>
                          <?php
                          */
                      ?>
85040b57   Yarik   Comment added
219
                  </div>
8f36efb7   Yarik   Added comments to...
220
221
222
223
224
225
226
227
                  <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
228
                  <?php /*
ccc7a9d3   Karnovsky A   Karnovsky 12052016
229
230
231
232
233
234
235
236
237
          <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
238
239
240
241
          </div>*/ ?>
              </div>
              
              <div class="productRightBar">
873e3d80   Administrator   14.09.16
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
276
277
278
279
280
                  <?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
281
282
283
284
                  <ul id="nav_product">
                      <li><a href="#">Характеристики</a>
                          <div class="info">
                              <p>Бренд: <?= $product->brand->name ?></p>
01905ec6   Yarik   Filter fixing
285
                              <?php foreach($product->getActiveProperties($category->category_id) as $group): ?>
85040b57   Yarik   Comment added
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
                                  <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
313
314
315
              <div class="content">
                  <div class="pic">
                      <center>
e4cea6a9   Administrator   rm node nodule
316
                          <a href="#" rel="shadowbox[gal]" id="picoriginal"><?= \common\components\artboximage\ArtboxImageHelper::getImage($product->variant->imageUrl, 'product_view', [
14009e7f   Yarik   Structure data fix
317
                                  'id'    => 'pic',
01905ec6   Yarik   Filter fixing
318
319
                                  'alt'   => $category->categoryName->value . ' ' . $product->fullname,
                                  'title' => $category->categoryName->value . ' ' . $product->fullname,
14009e7f   Yarik   Structure data fix
320
321
322
323
324
325
326
327
328
329
330
331
332
333
                              ]) ?></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
334
335
336
337
338
339
340
341
              <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
342
343
344
345
346
347
348
349
350
              <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...
351
              <div class="both"></div>
85040b57   Yarik   Comment added
352
          </div>
85040b57   Yarik   Comment added
353
354
355
356
357
          <?= \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
358
      </div>
85235ea6   Виталий   Веталь
359
  <?php
85040b57   Yarik   Comment added
360
      $this->registerJs("
2fcc30a0   Виталий   Веталь
361
362
363
364
365
366
367
368
369
370
371
372
373
374
        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');
  ?>