Opencart 1.5.x - Ocstore 1.5.x - Переделываем Корзину

Тема в разделе "Шаблоны, дизайн и оформление магазина", создана пользователем admin, 8 июл 2016.

  1. TopicStarter Overlay
    Offline

    admin Команда форума Администратор

    Сообщения:
    2.141
    Симпатии:
    62.365
    Репутация:
    154
    Недавно мне пришлось поработать с интернет магазином на OcStore 1.5.x и мне понравилась реализация корзины шаблона которую сделал, в этой статье мы будем видоизменять корзину в шапке стандартного шаблона OcStore 1.5.x.

    2016-07-08_095722.png


    После изменения нашей корзины она будет отображать количество добавленных в корзину товаров, а по нажатию на иконку корзины мы будем попадать на страницу корзины, с помощью 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;
    }
    Теперь восхищаемся проделанной работой и результатом:

    2016-07-08_095722.png

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