Moushe.ru

Блог обо всём

OcStore 1.5.5.1.2 переделываем корзину



Здравствуйте уважаемые читатели блога, недавно мне пришлось поработать с интернет магазином на 1С Битрикс и мне понравилась реализация корзины шаблона, в этой статье мы будем видоизменять корзину в шапке стандартного шаблона OcStore 1.5.5.1.2.

12

После изменения нашей корзины она будет отображать количество добавленных в корзину товаров, а по нажатию на иконку корзины мы будем попадать на страницу корзины, с помощью css мы зададим корзине фиксированное положение и при прокрутке страницы вниз покупатель всегда будет видеть корзину.

Приступим:

1. Откроем файл ../catalog/view/theme/default/template/module/cart.tpl и вместо этих строк (1-50):

<div id="cart">
<div class="heading">
<a title="<?php echo $heading_title; ?>"><span id="cart-total"><?php echo $text_items; ?></span></a></div>
<div class="content">
<?php if ($products || $vouchers) { ?>
<div class="mini-cart-info">
<table>
<?php foreach ($products as $product) { ?>
<tr>
<td class="image"><?php if ($product['thumb']) { ?>
<a href="<?php echo $product['href']; ?>"><img src="<?php echo $product['thumb']; ?>" alt="<?php echo $product['name']; ?>" title="<?php echo $product['name']; ?>" /></a>
<?php } ?></td>
<td class="name"><a href="<?php echo $product['href']; ?>"><?php echo $product['name']; ?></a>
<div>
<?php foreach ($product['option'] as $option) { ?>
- <small><?php echo $option['name']; ?> <?php echo $option['value']; ?></small><br />
<?php } ?>
</div></td>
<td class="quantity">x&nbsp;<?php echo $product['quantity']; ?></td>
<td class="total"><?php echo $product['total']; ?></td>
<td class="remove"><img src="catalog/view/theme/default/image/remove-small.png" alt="<?php echo $button_remove; ?>" title="<?php echo $button_remove; ?>" onclick="(getURLVar('route') == 'checkout/cart' || getURLVar('route') == 'checkout/checkout') ? location = 'index.php?route=checkout/cart&remove=<?php echo $product['key']; ?>' : $('#cart').load('index.php?route=module/cart&remove=<?php echo $product['key']; ?>' + ' #cart > *');" /></td>
</tr>
<?php } ?>
<?php foreach ($vouchers as $voucher) { ?>
<tr>
<td class="image"></td>
<td class="name"><?php echo $voucher['description']; ?></td>
<td class="quantity">x&nbsp;1</td>
<td class="total"><?php echo $voucher['amount']; ?></td>
<td class="remove"><img src="catalog/view/theme/default/image/remove-small.png" alt="<?php echo $button_remove; ?>" title="<?php echo $button_remove; ?>" onclick="(getURLVar('route') == 'checkout/cart' || getURLVar('route') == 'checkout/checkout') ? location = 'index.php?route=checkout/cart&remove=<?php echo $voucher['key']; ?>' : $('#cart').load('index.php?route=module/cart&remove=<?php echo $voucher['key']; ?>' + ' #cart > *');" /></td>
</tr>
<?php } ?>
</table>
</div>
<div class="mini-cart-total">
<table>
<?php foreach ($totals as $total) { ?>
<tr>
<td class="right"><b><?php echo $total['title']; ?>:</b></td>
<td class="right"><?php echo $total['text']; ?></td>
</tr>
<?php } ?>
</table>
</div>
<div class="checkout"><a href="<?php echo $cart; ?>"><?php echo $text_cart; ?></a> | <a href="<?php echo $checkout; ?>"><?php echo $text_checkout; ?></a></div>
<?php } else { ?>
<div class="empty"><?php echo $text_empty; ?></div>
<?php } ?>
</div>
</div>

вставим эти:

<div id="cart">
<a href="?route=checkout/cart"><img src="catalog/view/theme/default/image/cart.png"></a>
<div class="heading"><span id="cart-total"><?php echo $text_items; ?></span></div>
</div>

2. Откроем файл ../catalog/language/russian/module/cart.php и вместо этой строки (6):

$_['text_items']    = 'Товаров: %s (%s)';

вставим эту:

$_['text_items']    = '%s';

3. Откроем файл ../catalog/language/russian/checkout/cart.php и вместо этой строки (14):

$_['text_items']             = 'Товаров: %s (%s)';

вставим эту:

$_['text_items']    = '%s';

4. Откроем файл ../catalog/view/theme/default/stylesheet/stylesheet.css и вместо этих строк (144-257):

#header #cart {
position: absolute;
top: 0px;
right: 0px;
z-index: 9;
min-width: 300px;
}
#header #cart .heading {
float: right;
margin-right: 2px;
height: 30px;
padding-left: 14px;
padding-right: 14px;
background: url('../image/cart.png') 0% 50% no-repeat;
position: relative;
z-index: 1;
}
#header #cart .heading h4 {
color: #333333;
font-size: 15px;
font-weight: bold;
margin-top: 0px;
margin-bottom: 3px;
}
#header #cart .heading a {
color: #000;
text-decoration: none;
display: block;
}
#header #cart .heading a span {
background: url('../image/arrow-down.png') 100% 50% no-repeat;
padding-right: 15px;
margin-left:30px;
line-height: 30px;
}
#header #cart .content {
clear: both;
display: none;
position: relative;
top: 2px;
padding: 8px;
min-height: 150px;
border-top: 1px solid #EEEEEE;
border-left: 1px solid #EEEEEE;
border-right: 1px solid #EEEEEE;
border-bottom: 1px solid #EEEEEE;
-webkit-border-radius: 0px 0px 7px 7px;
-moz-border-radius: 0px 0px 7px 7px;
-khtml-border-radius: 0px 0px 7px 7px;
border-radius: 0px 0px 7px 7px;
-webkit-box-shadow: 0px 2px 2px #DDDDDD;
-moz-box-shadow: 0px 2px 2px #DDDDDD;
box-shadow: 0px 2px 2px #DDDDDD;
background: #FFF;
}
#header #cart.active .heading {
font-weight:700;
}
#header #cart.active .content {
display: block;
}
.mini-cart-info table {
border-collapse: collapse;
width: 100%;
margin-bottom: 5px;
}
.mini-cart-info td {
color: #000;
vertical-align: top;
padding: 10px 5px;
border-bottom: 1px solid #EEEEEE;
}
.mini-cart-info .image {
width: 1px;
}
.mini-cart-info .image img {
border: 1px solid #EEEEEE;
text-align: left;
}
.mini-cart-info .name small {
color: #666;
}
.mini-cart-info .quantity {
text-align: right;
}
.mini-cart-info td.total {
text-align: right;
}
.mini-cart-info .remove {
text-align: right;
}
.mini-cart-info .remove img {
cursor: pointer;
}
.mini-cart-total {
text-align: right;
}
.mini-cart-total table {
border-collapse: collapse;
display: inline-block;
margin-bottom: 5px;
}
.mini-cart-total td {
color: #000;
padding: 4px;
}
#header #cart .checkout {
text-align: right;
clear: both;
}
#header #cart .empty {
padding-top: 50px;
text-align: center;
}

вставим эти:

#cart {
position: fixed;
background: #fff;
top: 40px;
right: 0px;
z-index: 9;
width: 50px;
padding: 5px;
border-top: 2px solid #ddd;
border-left: 2px solid #ddd;
border-bottom: 2px solid #ddd;
border-radius: 5px 0 0 5px;
}
#cart .heading {
padding-left: 20px;
position: relative;
z-index: 1;
}

Теперь восхищаемся проделанной работой и результатом:

2

Следите за нашими новостями, до новых встреч.

8 Комментариев

  1. Подскажите пожалуйста, где находится element.style который определяет размер изображения категорий, ато ни как не могу увеличит, element.style перекрывает. И если можно как увеличить изображения товара в сетке, чтобы их в категории было не 5 в ряд а 4. Через админку не получается, изображения налазят друг на друга.

    • Владислав Храмцов
      vkontakte.ru Владислав Храмцов

      31.07.2014 at 20:30

      Здравствуйте, по вопросам не связанным с материалами блога обращайтесь ко мне в контакте, в комментарии код не вставляется и общение замедленно. Ссылку на мою анкету в контакте вы можете увидеть в правой колонке моего блога.

  2. Наталья

    15.07.2015 at 16:51

    Огромное спасибо! Статья супер! Переделала под свой стиль. Все работает 🙂

  3. Дмитрий

    20.02.2016 at 02:34

    С нетерпением ждём обновление статьи для Opencart 2.0 🙂

    • Владислав Храмцов
      vkontakte.ru Владислав Храмцов

      20.02.2016 at 12:59

      В принципе можно и написать

  4. Дмитрий

    03.03.2016 at 13:32

    Пока не вышла статья под opencart 2, своими кривыми руками копаю модуль сам:) расскажите, как корзину разместить не справа а слева?

  5. Здравствуйте, у меня данных действий корзина появилась но при переходе в нее появляется сообщение. «Подтвердите действия на pero.kg not found….»

Добавить комментарий

Your email address will not be published.

*

CAPTCHA image
*

© 2016 Moushe.ru При копировании материалов, ссылка на нас обязательна!

Вверх ↑



Яндекс.Метрика