1
0
Fork 0
mirror of https://github.com/Oreolek/ifhub-skin.git synced 2024-05-14 23:18:24 +03:00
ifhub-skin/layouts/layout.base.tpl

282 lines
9.6 KiB
Smarty
Raw Normal View History

2017-01-08 13:05:51 +02:00
{**
* Основной лэйаут
*
* @param boolean $layoutShowSidebar Показывать сайдбар или нет, сайдбар не будет выводится если он не содержит блоков
* @param string $layoutNavContent Название навигации
* @param string $layoutNavContentPath Кастомный путь до навигации контента
2017-01-08 13:05:51 +02:00
* @param string $layoutShowSystemMessages Показывать системные уведомления или нет
*}
{extends 'Component@layout.layout'}
{block 'layout_options' append}
{$layoutShowSidebar = $layoutShowSidebar|default:true}
{$layoutShowSystemMessages = $layoutShowSystemMessages|default:true}
2017-01-08 13:05:51 +02:00
{/block}
{*
2017-01-08 13:05:51 +02:00
{block 'layout_head_styles' append}
{/block}
*}
2017-01-08 13:05:51 +02:00
{block 'layout_head' append}
{* Получаем блоки для вывода в сайдбаре *}
{if $layoutShowSidebar}
{show_blocks group='right' assign=layoutSidebarBlocks}
{$layoutSidebarBlocks = trim( $layoutSidebarBlocks )}
{$layoutShowSidebar = !!$layoutSidebarBlocks}
{/if}
{**
* Тип сетки сайта
*}
{if {Config::Get('view.grid.type')} == 'fluid'}
<style>
.layout-nav .ls-nav--main,
.layout-container,
.container {
min-width: {Config::Get('view.grid.fluid_min_width')};
max-width: {Config::Get('view.grid.fluid_max_width')};
}
</style>
{else}
<style>
.layout-nav .ls-nav--main,
.layout-container,
.container { width: {Config::Get('view.grid.fixed_width')}; }
</style>
{/if}
2017-01-08 13:05:51 +02:00
{/block}
{block 'layout_body'}
{**
* Основная навигация
*}
<div class="layout-container">
<nav class="ls-grid-row layout-nav">
<h1 class="ls-userbar-logo">
<a href="{router page='/'}"><img src="/application/frontend/skin/ifhub/assets/images/logo.png" height="60px"></a>
</h1>
<nav class="ls-userbar-nav">
{if $oUserCurrent}
{$items = [
[
'text' => "<img src=\"{$oUserCurrent->getProfileAvatarPath(24)}\" alt=\"{$oUserCurrent->getDisplayName()}\" class=\"avatar\" /> {$oUserCurrent->getDisplayName()}",
'url' => "{$oUserCurrent->getUserWebPath()}",
'classes' => 'ls-nav-item--userbar-username',
'show' => true,
'menu' => [
[
'name' => 'whois',
'text' => {lang name='user.profile.nav.info'},
'url' => "{$oUserCurrent->getUserWebPath()}"
],
[
'name' => 'wall',
'text' => {lang name='user.profile.nav.wall'},
'url' => "{$oUserCurrent->getUserWebPath()}wall/",
'count' => $iUserCurrentCountWall
],
[
'name' => 'created',
'text' => {lang name='user.profile.nav.publications'},
'url' => "{$oUserCurrent->getUserWebPath()}created/topics/",
'count' => $iUserCurrentCountCreated
],
[
'name' => 'favourites',
'text' => {lang name='user.profile.nav.favourite'},
'url' => "{$oUserCurrent->getUserWebPath()}favourites/topics/",
'count' => $iUserCurrentCountFavourite
],
[
'name' => 'friends',
'text' => {lang name='user.profile.nav.friends'},
'url' => "{$oUserCurrent->getUserWebPath()}friends/",
'count' => $iUserCurrentCountFriends
],
[
'name' => 'activity',
'text' => {lang name='user.profile.nav.activity'},
'url' => "{$oUserCurrent->getUserWebPath()}stream/"
],
[
'name' => 'talk',
'text' => {lang name='user.profile.nav.messages'},
'url' => "{router page='talk'}",
'count' => $iUserCurrentCountTalkNew
],
[
'name' => 'settings',
'text' => {lang name='user.profile.nav.settings'},
'url' => "{router page='settings'}"
],
[
'name' => 'admin',
'text' => {lang name='admin.title'},
'url' => "{router page='admin'}",
'is_enabled' => $oUserCurrent && $oUserCurrent->isAdministrator()
]
]
],
[ 'text' => $aLang.common.create, 'url' => "{router page='content'}add/topic", 'classes' => 'js-modal-toggle-default', 'attributes' => [ 'data-lsmodaltoggle-modal' => 'modal-write' ] ],
[ 'text' => $aLang.talk.title, 'url' => "{router page='talk'}", 'title' => $aLang.talk.new_messages, 'is_enabled' => $iUserCurrentCountTalkNew, 'count' => $iUserCurrentCountTalkNew ],
[ 'text' => $aLang.auth.logout, 'url' => "{router page='auth'}logout/?security_ls_key={$LIVESTREET_SECURITY_KEY}" ]
]}
{else}
{$items = [
[
'text' => $aLang.auth.login.title,
'classes' => 'js-modal-toggle-login',
'url' => {router page='auth/login'}
],
[
'text' => $aLang.auth.registration.title,
'classes' => 'js-modal-toggle-registration',
'url' => {router page='auth/register'}
]
]}
{/if}
{component 'nav' name='userbar' activeItem=$sMenuHeadItemSelect mods='userbar' items=$items}
</nav>
{include 'navs/nav.main.tpl'}
{component 'search' template='main' mods='light'}
</nav></div>
{if $oUserCurrent}
{component 'modal-create'}
{/if}
{**
* Основной контэйнер
*}
<div id="container" class="ls-grid-row layout-container {hook run='container_class'} {if $layoutShowSidebar}layout-has-sidebar{else}layout-no-sidebar{/if}">
{* Вспомогательный контейнер-обертка *}
<div class="ls-grid-row layout-wrapper" class="{hook run='wrapper_class'}">
{**
* Контент
*}
<div class="ls-grid-col ls-grid-col-8 layout-content"
role="main"
{if $sMenuItemSelect == 'profile'}itemscope itemtype="http://data-vocabulary.org/Person"{/if}>
{hook run='content_begin'}
{* Основной заголовок страницы *}
{block 'layout_page_title' hide}
<h2 class="page-header">
{$smarty.block.child}
</h2>
{/block}
{block 'layout_content_header'}
{* Навигация *}
{if $sNav}
{if in_array($sNav, $aMenuContainers)}
{$_navContent = $aMenuFetch.$sNav}
2017-01-09 15:50:01 +02:00
{else}
{include "{$sNavPath}navs/nav.$sNav.tpl" assign=_navContent}
2017-01-09 15:50:01 +02:00
{/if}
{* Проверяем наличие вывода на случай если меню с одним пунктом автоматом скрывается *}
{if $_navContent|strip:''}
<div class="ls-nav-group">
{$_navContent}
</div>
{/if}
{/if}
{* Системные сообщения *}
{if $layoutShowSystemMessages}
{if $aMsgError}
{component 'alert' text=$aMsgError mods='error' close=true}
2017-01-08 13:05:51 +02:00
{/if}
2017-01-09 13:38:56 +02:00
{if $aMsgNotice}
{component 'alert' text=$aMsgNotice close=true}
{/if}
{/if}
{/block}
{block 'layout_content'}{/block}
{hook run='content_end'}
</div>
{**
* Сайдбар
* Показываем сайдбар
*}
{if $layoutShowSidebar}
<aside class="ls-grid-col ls-grid-col-4 layout-sidebar" role="complementary">
{$layoutSidebarBlocks}
</aside>
{/if}
</div> {* /wrapper *}
{* Подвал *}
<footer class="ls-grid-row layout-footer">
{block 'layout_footer'}
{hook run='footer_begin'}
{hook run='copyright'}
{hook run='footer_end'}
{/block}
</footer>
</div> {* /container *}
{* Подключение модальных окон *}
{if $oUserCurrent}
{component 'tags-personal' template='modal'}
{else}
{component 'auth' template='modal'}
{/if}
{**
* Тулбар
* Добавление кнопок в тулбар
*}
{add_block group='toolbar' name='component@admin.toolbar.admin' priority=100}
{add_block group='toolbar' name='component@toolbar-scrollup.toolbar.scrollup' priority=-100}
{* Подключение тулбара *}
{component 'toolbar' classes='js-toolbar-default' items={show_blocks group='toolbar'}}
<!-- Yandex.Metrika counter -->
<script type="text/javascript">
(function (d, w, c) {
(w[c] = w[c] || []).push(function() {
try {
w.yaCounter42008629 = new Ya.Metrika({
id:42008629,
clickmap:true,
trackLinks:true,
accurateTrackBounce:true,
webvisor:true
});
} catch(e) { }
});
var n = d.getElementsByTagName("script")[0],
s = d.createElement("script"),
f = function () { n.parentNode.insertBefore(s, n); };
s.type = "text/javascript";
s.async = true;
s.src = "https://mc.yandex.ru/metrika/watch.js";
if (w.opera == "[object Opera]") {
d.addEventListener("DOMContentLoaded", f, false);
} else { f(); }
})(document, window, "yandex_metrika_callbacks");
2017-01-09 13:38:56 +02:00
</script>
<noscript><div><img src="https://mc.yandex.ru/watch/42008629" style="position:absolute; left:-9999px;" alt="" /></div></noscript>
<!-- /Yandex.Metrika counter -->
2017-01-16 14:40:13 +02:00
{hook run='layout_body_end'}
2017-01-08 13:51:51 +02:00
{/block}