2017-01-08 13:05:51 +02:00
|
|
|
|
{**
|
2017-01-17 13:09:46 +02:00
|
|
|
|
* Основной лэйаут, который наследуют все остальные лэйауты
|
2017-01-08 13:05:51 +02:00
|
|
|
|
*
|
2017-01-17 13:09:46 +02:00
|
|
|
|
* @param boolean $layoutShowSidebar Показывать сайдбар или нет, сайдбар не будет выводится если он не содержит блоков
|
|
|
|
|
* @param string $layoutNavContent Название навигации
|
|
|
|
|
* @param string $layoutNavContentPath Кастомный путь до навигации контента
|
2017-01-08 13:05:51 +02:00
|
|
|
|
* @param string $layoutShowSystemMessages Показывать системные уведомления или нет
|
|
|
|
|
*}
|
|
|
|
|
|
2017-01-17 13:09:46 +02:00
|
|
|
|
{extends 'component@layout.layout'}
|
2017-01-08 13:05:51 +02:00
|
|
|
|
|
|
|
|
|
{block 'layout_options' append}
|
2017-01-17 13:09:46 +02:00
|
|
|
|
{$layoutShowSidebar = $layoutShowSidebar|default:true}
|
|
|
|
|
{$layoutShowSystemMessages = $layoutShowSystemMessages|default:true}
|
2017-01-08 13:05:51 +02:00
|
|
|
|
{/block}
|
|
|
|
|
|
|
|
|
|
{block 'layout_head_styles' append}
|
2017-10-07 17:03:40 +03:00
|
|
|
|
<link rel="apple-touch-icon" href="{cfg 'path.skin.assets.web'}/images/touchicon.png">
|
|
|
|
|
<link rel="apple-touch-icon" sizes="120x120" href="{cfg 'path.skin.assets.web'}/images/touchicon_120.png">
|
|
|
|
|
<link rel="apple-touch-icon" sizes="152x152" href="{cfg 'path.skin.assets.web'}/images/touchicon_152.png">
|
2017-01-17 13:09:46 +02:00
|
|
|
|
<link rel="search" type="application/opensearchdescription+xml" href="{router page='search'}opensearch/" title="{Config::Get('view.name')}" />
|
2019-02-11 13:11:03 +02:00
|
|
|
|
<link rel="preconnect" href="https://mc.yandex.ru" />
|
|
|
|
|
<link rel="preconnect" href="https://cdn.jsdelivr.net" />
|
|
|
|
|
<link rel="preconnect" href="https://fonts.googleapis.com" />
|
2017-01-08 13:05:51 +02:00
|
|
|
|
{/block}
|
|
|
|
|
|
|
|
|
|
{block 'layout_head' append}
|
2017-01-17 13:09:46 +02:00
|
|
|
|
{* Получаем блоки для вывода в сайдбаре *}
|
|
|
|
|
{if $layoutShowSidebar}
|
|
|
|
|
{show_blocks group='right' assign=layoutSidebarBlocks}
|
|
|
|
|
|
|
|
|
|
{$layoutSidebarBlocks = trim( $layoutSidebarBlocks )}
|
|
|
|
|
{$layoutShowSidebar = !!$layoutSidebarBlocks}
|
|
|
|
|
{/if}
|
2020-02-27 18:30:37 +02:00
|
|
|
|
|
|
|
|
|
{**
|
|
|
|
|
* Тип сетки сайта
|
|
|
|
|
*}
|
|
|
|
|
{if {Config::Get('view.grid.type')} == 'fluid'}
|
|
|
|
|
<style>
|
|
|
|
|
.layout-userbar,
|
|
|
|
|
.layout-nav .ls-nav--main,
|
|
|
|
|
.layout-header .ls-jumbotron-inner,
|
|
|
|
|
.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-userbar,
|
|
|
|
|
.layout-nav .ls-nav--main,
|
|
|
|
|
.layout-header .ls-jumbotron-inner,
|
|
|
|
|
.layout-container,
|
|
|
|
|
.container { width: {Config::Get('view.grid.fixed_width')}; }
|
|
|
|
|
</style>
|
|
|
|
|
{/if}
|
2017-01-08 13:05:51 +02:00
|
|
|
|
{/block}
|
|
|
|
|
|
|
|
|
|
{block 'layout_body'}
|
2017-01-17 13:09:46 +02:00
|
|
|
|
{hook run='layout_body_begin'}
|
|
|
|
|
{**
|
|
|
|
|
* Основная навигация
|
|
|
|
|
*}
|
|
|
|
|
<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}
|
|
|
|
|
{$createMenu = []}
|
|
|
|
|
|
|
|
|
|
{foreach $LS->Topic_GetTopicTypes() as $type}
|
|
|
|
|
{$createMenu[] = [ 'name' => $type->getCode(), 'text' => $type->getName(), 'url' => $type->getUrlForAdd() ]}
|
|
|
|
|
{/foreach}
|
|
|
|
|
|
|
|
|
|
{$createMenu[] = [ 'name' => 'talk', 'text' => {lang 'modal_create.items.talk'}, 'url' => {router page='talk'} ]}
|
|
|
|
|
{$createMenu[] = [ 'name' => 'drafts', 'text' => {lang 'topic.drafts'}, 'url' => "{router page='content'}drafts/", count => $iUserCurrentCountTopicDraft ]}
|
|
|
|
|
|
|
|
|
|
{$items = [
|
|
|
|
|
[
|
|
|
|
|
'text' => "<img src=\"{$oUserCurrent->getProfileAvatarPath(24)}\" alt=\"{$oUserCurrent->getDisplayName()}\" class=\"avatar\" /> {$oUserCurrent->getDisplayName()}",
|
|
|
|
|
'url' => "{$oUserCurrent->getUserWebPath()}",
|
|
|
|
|
'classes' => 'ls-nav-item--userbar-username',
|
|
|
|
|
'menu' => [
|
|
|
|
|
'items' => [
|
|
|
|
|
[ '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, menu => [ hook => 'create', items => $createMenu ] ],
|
|
|
|
|
[ '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}" ]
|
|
|
|
|
]}
|
2017-01-09 15:50:01 +02:00
|
|
|
|
{else}
|
2017-01-17 13:09:46 +02:00
|
|
|
|
{$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'} ]
|
|
|
|
|
]}
|
2017-01-09 15:50:01 +02:00
|
|
|
|
{/if}
|
|
|
|
|
|
2017-01-17 13:09:46 +02:00
|
|
|
|
{component 'nav' hook='userbar_nav' hookParams=[ user => $oUserCurrent ] activeItem=$sMenuHeadItemSelect mods='userbar' items=$items}
|
|
|
|
|
</nav>
|
2017-01-11 15:04:19 +02:00
|
|
|
|
|
2017-01-17 13:09:46 +02:00
|
|
|
|
{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='layout_container_class' action=$sAction} {if $layoutShowSidebar}layout-has-sidebar{else}layout-no-sidebar{/if}">
|
|
|
|
|
{* Вспомогательный контейнер-обертка *}
|
|
|
|
|
<div class="ls-grid-row layout-wrapper {hook run='layout_wrapper_class' action=$sAction}">
|
|
|
|
|
{**
|
|
|
|
|
* Контент
|
|
|
|
|
*}
|
2020-02-27 18:30:37 +02:00
|
|
|
|
<div class="ls-grid-col ls-grid-col-8 layout-content"
|
2017-01-17 13:09:46 +02:00
|
|
|
|
role="main"
|
|
|
|
|
{if $sMenuItemSelect == 'profile'}itemscope itemtype="http://data-vocabulary.org/Person"{/if}>
|
|
|
|
|
|
|
|
|
|
{hook run='layout_content_header_begin' action=$sAction}
|
|
|
|
|
|
|
|
|
|
{* Основной заголовок страницы *}
|
|
|
|
|
{block 'layout_page_title' hide}
|
|
|
|
|
<h2 class="page-header">
|
|
|
|
|
{$smarty.block.child}
|
|
|
|
|
</h2>
|
|
|
|
|
{/block}
|
|
|
|
|
|
|
|
|
|
{block 'layout_content_header'}
|
|
|
|
|
{* Навигация *}
|
|
|
|
|
{if $layoutNav}
|
|
|
|
|
{$_layoutNavContent = ""}
|
|
|
|
|
|
|
|
|
|
{if is_array($layoutNav)}
|
|
|
|
|
{foreach $layoutNav as $layoutNavItem}
|
|
|
|
|
{if is_array($layoutNavItem)}
|
|
|
|
|
{component 'nav' mods='pills' params=$layoutNavItem assign=_layoutNavItemContent}
|
|
|
|
|
{$_layoutNavContent = "$_layoutNavContent $_layoutNavItemContent"}
|
|
|
|
|
{else}
|
|
|
|
|
{$_layoutNavContent = "$_layoutNavContent $layoutNavItem"}
|
|
|
|
|
{/if}
|
|
|
|
|
{/foreach}
|
|
|
|
|
{else}
|
|
|
|
|
{$_layoutNavContent = $layoutNav}
|
|
|
|
|
{/if}
|
|
|
|
|
|
|
|
|
|
{* Проверяем наличие вывода на случай если меню с одним пунктом автоматом скрывается *}
|
|
|
|
|
{if $_layoutNavContent|strip:''}
|
|
|
|
|
<div class="ls-nav-group">
|
|
|
|
|
{$_layoutNavContent}
|
|
|
|
|
</div>
|
|
|
|
|
{/if}
|
|
|
|
|
{/if}
|
2017-01-09 13:38:56 +02:00
|
|
|
|
|
2017-01-17 13:09:46 +02:00
|
|
|
|
{* Системные сообщения *}
|
|
|
|
|
{if $layoutShowSystemMessages}
|
|
|
|
|
{if $aMsgError}
|
|
|
|
|
{component 'alert' text=$aMsgError mods='error' close=true}
|
|
|
|
|
{/if}
|
|
|
|
|
|
|
|
|
|
{if $aMsgNotice}
|
|
|
|
|
{component 'alert' text=$aMsgNotice close=true}
|
|
|
|
|
{/if}
|
|
|
|
|
{/if}
|
|
|
|
|
{/block}
|
|
|
|
|
|
|
|
|
|
{hook run='layout_content_begin' action=$sAction}
|
|
|
|
|
{block 'layout_content'}{/block}
|
2019-12-01 10:57:37 +02:00
|
|
|
|
|
2020-02-27 18:30:37 +02:00
|
|
|
|
{hook run='layout_content_end' action=$sAction}
|
2017-05-16 10:07:41 +03:00
|
|
|
|
{show_blocks group='similar'}
|
2017-01-17 13:09:46 +02:00
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
{**
|
|
|
|
|
* Сайдбар
|
|
|
|
|
* Показываем сайдбар
|
|
|
|
|
*}
|
|
|
|
|
{if $layoutShowSidebar}
|
2020-02-27 18:30:37 +02:00
|
|
|
|
<aside class="ls-grid-col ls-grid-col-4 layout-sidebar" role="complementary">
|
2017-01-17 13:09:46 +02:00
|
|
|
|
{$layoutSidebarBlocks}
|
2017-02-15 17:10:26 +02:00
|
|
|
|
|
|
|
|
|
<div class="ls-block">
|
2017-02-15 17:11:42 +02:00
|
|
|
|
<header class="ls-block-header">
|
|
|
|
|
<h3 class="ls-block-title">Мы в социальных сетях</h3>
|
|
|
|
|
</header>
|
2017-02-15 17:10:26 +02:00
|
|
|
|
<ul class="ls-item-group">
|
|
|
|
|
<li class="ls-item">
|
|
|
|
|
<p><i class="fa fa-twitter"></i> <a href="https://twitter.com/if_hub">Twitter: @if_hub</a></p>
|
|
|
|
|
</li>
|
|
|
|
|
<li class="ls-item">
|
|
|
|
|
<p><i class="fa fa-vk"></i> <a href="https://vk.com/ifhub">ВКонтакте: ifhub</a></p>
|
|
|
|
|
</li>
|
2017-05-16 10:07:41 +03:00
|
|
|
|
<li class="ls-item">
|
|
|
|
|
<p><i class="fa fa-telegram"></i> <a href="https://t.me/ifhub">Telegram: @IFHub</a></p>
|
|
|
|
|
</li>
|
2019-02-20 16:35:06 +02:00
|
|
|
|
<li class="ls-item">
|
2019-02-20 16:37:06 +02:00
|
|
|
|
<p><i class="fa fa-pencil"></i> <a rel="me" href="https://botsin.space/@ifhub">Mastodon: @IFHub@botsin.space</a></p>
|
2019-02-20 16:35:06 +02:00
|
|
|
|
</li>
|
2017-02-15 17:10:26 +02:00
|
|
|
|
</ul>
|
|
|
|
|
</div>
|
2017-01-17 13:09:46 +02:00
|
|
|
|
</aside>
|
2017-01-11 15:04:19 +02:00
|
|
|
|
{/if}
|
2017-01-17 13:09:46 +02:00
|
|
|
|
</div> {* /wrapper *}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
{* Подвал *}
|
|
|
|
|
<footer class="ls-grid-row layout-footer">
|
|
|
|
|
{block 'layout_footer'}
|
|
|
|
|
{hook run='layout_footer_begin'}
|
2019-02-18 20:49:29 +02:00
|
|
|
|
{hook run='copyright'}
|
2017-01-17 13:09:46 +02:00
|
|
|
|
{hook run='layout_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'}}
|
|
|
|
|
|
2017-12-21 15:25:12 +02:00
|
|
|
|
<!-- Yandex.Metrika counter -->
|
2019-02-18 20:47:48 +02:00
|
|
|
|
<noscript><div><img src="https://mc.yandex.ru/watch/42008629" style="position:absolute; left:-9999px;" alt="" /></div></noscript>
|
2017-12-21 15:25:12 +02:00
|
|
|
|
<script type="text/javascript" >
|
|
|
|
|
(function (d, w, c) {
|
|
|
|
|
(w[c] = w[c] || []).push(function() {
|
|
|
|
|
try {
|
|
|
|
|
w.yaCounter42008629 = new Ya.Metrika2({
|
|
|
|
|
id:42008629,
|
|
|
|
|
clickmap:true,
|
|
|
|
|
trackLinks:true,
|
2018-08-13 05:28:18 +03:00
|
|
|
|
accurateTrackBounce:true
|
2017-12-21 15:25:12 +02:00
|
|
|
|
});
|
|
|
|
|
} 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://cdn.jsdelivr.net/npm/yandex-metrica-watch/tag.js";
|
|
|
|
|
|
|
|
|
|
if (w.opera == "[object Opera]") {
|
|
|
|
|
d.addEventListener("DOMContentLoaded", f, false);
|
|
|
|
|
} else { f(); }
|
|
|
|
|
})(document, window, "yandex_metrika_callbacks2");
|
2019-02-18 20:47:48 +02:00
|
|
|
|
// /Yandex.Metrika counter
|
|
|
|
|
// Google webfont loader
|
2019-02-18 21:26:45 +02:00
|
|
|
|
var WebFontConfig = {
|
|
|
|
|
google: {
|
|
|
|
|
families: ['Open Sans:300,400,700:latin,cyrillic']
|
|
|
|
|
}
|
|
|
|
|
};
|
2019-02-11 13:29:14 +02:00
|
|
|
|
(function(d) {
|
|
|
|
|
var wf = d.createElement('script'), s = d.scripts[0];
|
2019-02-18 21:26:45 +02:00
|
|
|
|
wf.src = 'https://cdn.jsdelivr.net/npm/webfontloader@1.6.28/webfontloader.min.js';
|
2019-02-11 13:29:14 +02:00
|
|
|
|
wf.async = true;
|
|
|
|
|
s.parentNode.insertBefore(wf, s);
|
|
|
|
|
})(document);
|
|
|
|
|
</script>
|
2017-12-21 15:25:12 +02:00
|
|
|
|
{hook run='layout_body_end'}
|
2017-01-08 13:51:51 +02:00
|
|
|
|
{/block}
|