Всем привет, давненько я не делал статьи по OcStore 1.5.5.1.2, но вот недавно меня попросили написать статью о создании зафиксированной нижней панели с ссылкой на контакты, кнопками закладок, сравнений товаров и корзины, раз просите – делаю.

OcStore15512

Список задач на сегодня:

1. Подключим иконочный шрифт

2. Поработаем с файлами

3. Поработаем со стилями

4. Поработаем с корзиной

5. Подберём иконки

Приступим:

1. Чаще всего я использую этот набор иконок: http://fortawesome.github.io/Font-Awesome/icons/

Откроем файл ../catalog/view/theme/default/template/common/header.tpl (вместо default папка вашего шаблона, если вы используете альтернативный шаблон) и после этой строки (28):

<link rel="stylesheet" type="text/css" href="catalog/view/theme/default/stylesheet/stylesheet.css" />

вставим эту:

<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.4.0/css/font-awesome.min.css">

2. Откроем файл ../catalog/view/theme/default/template/common/header.tpl и после этой строки (61):

<body>

вставим эти строки:

<div id="bottom_panel">
<a href="?route=information/contact">Контакты</a>
<a href="<?php echo $wishlist; ?>" id="wishlist-total"><?php echo $text_wishlist; ?></a>
<a href="<?php echo $compare; ?>" id="compare-total"><?php echo $text_compare; ?></a>
<?php echo $cart; ?>
</div>

удалим эту строку (83):

<?php echo $cart; ?>

вместо этой строки (94):

<div class="links"><a href="<?php echo $home; ?>"><?php echo $text_home; ?></a><a href="<?php echo $wishlist; ?>" id="wishlist-total"><?php echo $text_wishlist; ?></a><a href="<?php echo $shopping_cart; ?>"><?php echo $text_shopping_cart; ?></a><a href="<?php echo $checkout; ?>"><?php echo $text_checkout; ?></a></div>

вставим эту:

<div class="links"><a href="<?php echo $home; ?>"><?php echo $text_home; ?></a><<a href="<?php echo $shopping_cart; ?>"><?php echo $text_shopping_cart; ?></a><a href="<?php echo $checkout; ?>"><?php echo $text_checkout; ?></a></div>

2.1. Откроем файл ../catalog/controller/common/header.php и после этой строки (41):

$this->data['text_wishlist'] = sprintf($this->language->get('text_wishlist'), (isset($this->session->data['wishlist']) ? count($this->session->data['wishlist']) : 0));

вставим эту:

$this->data['text_compare'] = sprintf($this->language->get('text_compare'), (isset($this->session->data['compare']) ? count($this->session->data['compare']) : 0));

после этой строки (52):

$this->data['wishlist'] = $this->url->link('account/wishlist', '', 'SSL');

вставим эту:

$this->data['compare'] = $this->url->link('product/compare', '', 'SSL');

2.2. Откроем файл ../catalog/language/russian/common/header.php и после этой строки (4):

$_['text_wishlist']       = 'Закладки (%s)';

вставим эту:

$_['text_compare']        = 'Сравнение (%s)';

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

#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;
}

вставим эти:

#cart {
position: absolute;
top: 0px;
right: 0px;
z-index: 9;
min-width: 300px;
}
#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;
}
#cart .heading h4 {
color: #333333;
font-size: 15px;
font-weight: bold;
margin-top: 0px;
margin-bottom: 3px;
}
#cart .heading a {
color: #000;
text-decoration: none;
display: block;
}
#cart .heading a span {
background: url('../image/arrow-down.png') 100% 50% no-repeat;
padding-right: 15px;
margin-left:30px;
line-height: 30px;
}
#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;
}
#cart.active .heading {
font-weight:700;
}
#cart.active .content {
display: block;
}

попозже стили подкорректируем, сначала оформим саму панель, в конец файла добавим эти строки:

#bottom_panel {
position: fixed;
bottom: 0;
border-top: 1px solid #999;
background: #ddd;
height: 35px;
width: 100%;
z-index: 1;
}
#bottom_panel a {
color: #000;
font: normal 14px Arial;
padding: 10px;
border: 1px solid #dedede;
text-decoration: none;
display: inline-block;
}
#bottom_panel a:hover {
background: #d1d1d1;
}

вновь вернёмся к оформлению корзины, удалим эти строки (144-204):

#cart {
position: absolute;
top: 0px;
right: 0px;
z-index: 9;
min-width: 300px;
}
#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;
}
#cart .heading h4 {
color: #333333;
font-size: 15px;
font-weight: bold;
margin-top: 0px;
margin-bottom: 3px;
}
#cart .heading a {
color: #000;
text-decoration: none;
display: block;
}
#cart .heading a span {
background: url('../image/arrow-down.png') 100% 50% no-repeat;
padding-right: 15px;
margin-left:30px;
line-height: 30px;
}
#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;
}
#cart.active .heading {
font-weight:700;
}
#cart.active .content {
display: block;
}

и в конец файла вставим новые стили корзины:

#cart {
float: right;
padding-left: 14px;
padding-right: 14px;
}

немного, не так-ли? Улыбка

теперь нам осталось приподнять немного футер – сейчас наша панелька его немного перекрывает, вместо этих строк (1625-1629):

#powered {
margin-top: 5px;
text-align: right;
clear: both;
}

вставим эти:

#powered {
margin-top: 5px;
text-align: right;
clear: both;
padding-bottom: 35px;
}

4. Теперь поработаем с корзиной, откроем файл ../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">
<div class="heading">
<a href="?route=checkout/cart" title="<?php echo $heading_title; ?>"><span id="cart-total"><?php echo $text_items; ?></span></a></div>
</div>

отлично, нижняя панель готова, но без иконок выглядит скучно:

ocstore_bottom_panel_1

5. Переходим на сайт иконок: http://fortawesome.github.io/Font-Awesome/icons/ выбираем иконки, в моём случае это:

Для контактов: <i class="fa fa-phone-square"></i>

Для закладок: <i class="fa fa-star"></i>

Для сравнений: <i class="fa fa-cog"></i>

Для корзины: <i class="fa fa-shopping-cart"></i>

вы можете взять и другие иконки, выбирайте на свой вкус.

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

<a href="?route=checkout/cart" title="<?php echo $heading_title; ?>"><span id="cart-total"><?php echo $text_items; ?></span></a></div>

вставим эту:

<a href="?route=checkout/cart" title="<?php echo $heading_title; ?>"><i class="fa fa-shopping-cart"></i><span id="cart-total"><?php echo $text_items; ?></span></a></div>

мне не нравится что в корзине написано слово товаров, я хочу его убрать, вы со мной? Для этого откроем файл ../catalog/language/russian/module/cart.php и вместо этой строки (6):

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

вставим эту:

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

5.2. Откроем файл ../catalog/view/theme/default/template/common/header.tpl и вместо этих строк (63-65):

<a href="?route=information/contact">Контакты</a>
<a href="<?php echo $wishlist; ?>" id="wishlist-total"><?php echo $text_wishlist; ?></a>
<a href="<?php echo $compare; ?>" id="compare-total"><?php echo $text_compare; ?></a>

вставим эти:

<a href="?route=information/contact"><i class="fa fa-phone-square"></i>Контакты</a>
<a href="<?php echo $wishlist; ?>" id="wishlist-total"><i class="fa fa-star"></i><?php echo $text_wishlist; ?></a>
<a href="<?php echo $compare; ?>" id="compare-total"><i class="fa fa-cog"></i><?php echo $text_compare; ?></a>

неплохо, но иконки не выделяются (чёрные, а нужны яркие, заметные) и прижаты к надписям:

ocstore_bottom_panel_2

что-же делать? Как всегда, не знаешь что делать — ковыряй стили! Откроем файл ../catalog/view/theme/default/stylesheet/stylesheet.css и в конец файла добавим эти строки:

.fa {
color: #cc0000;
padding-right: 3px;
}

Результат:

ocstore_bottom_panel_3

По моему неплохо? Конечно оформить можно и посимпатичнее – но тема урока была о создании, а не о красивом оформлении панели, думаю я посвящу этому отдельный урок – статья и так получилась довольно длинной.

До встречи, всем удачи.