Przejdź do głównej zawartości

Zmienne szablonu

XOOPS automatycznie dostarcza wiele zmiennych do szablonów Smarty. Ta referenca dokumentuje dostępne zmienne do tworzenia motywów i szablonów modułów.

  • Smarty-Basics - Fundamenty Smarty w XOOPS
  • Theme-Development - Tworzenie motywów XOOPS
  • Smarty-4-Migration - Aktualizacja z Smarty 3 na 4

Te zmienne są dostępne w szablonach motywu (theme.tpl):

ZmiennaOpisPrzykład
$xoops_sitenameNazwa witryny z preferencji"My XOOPS Site"
$xoops_pagetitleTytuł bieżącej strony"Welcome"
$xoops_sloganSlogan witryny"Just Use It!"
$xoops_urlPełny URL XOOPS"https://example.com"
$xoops_langcodeKod języka"en"
$xoops_charsetZestaw znaków"UTF-8"
ZmiennaOpis
$xoops_meta_keywordsMeta słowa kluczowe
$xoops_meta_descriptionMeta opis
$xoops_meta_robotsMeta tag robots
$xoops_meta_ratingOcena zawartości
$xoops_meta_authorMeta tag autor
$xoops_meta_copyrightPowiadomienie o prawach autorskich
ZmiennaOpis
$xoops_themeNazwa bieżącego motywu
$xoops_imageurlURL katalogu obrazów motywu
$xoops_themecssURL głównego pliku CSS motywu
$xoops_icons32_urlURL ikon 32x32
$xoops_icons16_urlURL ikon 16x16
ZmiennaOpis
$xoops_contentsGłówna zawartość strony
$xoops_module_headerZawartość nagłówka specyficzna dla modułu
$xoops_footerZawartość stopki
$xoops_jsJavaScript do dołączenia
ZmiennaOpis
$xoops_mainmenuMenu nawigacyjne główne
$xoops_usermenuMenu użytkownika
ZmiennaOpis
$xoops_lblocksTablica bloków lewych
$xoops_rblocksTablica bloków prawych
$xoops_cblocksTablica bloków centralnych
$xoops_showlblockPokaż bloki lewe (boolean)
$xoops_showrblockPokaż bloki prawe (boolean)
$xoops_showcblockPokaż bloki centralne (boolean)

Gdy użytkownik jest zalogowany:

ZmiennaOpis
$xoops_isuserUżytkownik jest zalogowany (boolean)
$xoops_isadminUżytkownik jest administratorem (boolean)
$xoops_useridID użytkownika
$xoops_unameNazwa użytkownika
$xoops_isownerUżytkownik jest właścicielem bieżącej zawartości (boolean)
<{if $xoops_isuser}>
<p>Welcome, <{$xoops_uname}>!</p>
<p>Your email: <{$xoopsUser->getVar('email')}>}</p>
<p>Joined: <{$xoopsUser->getVar('user_regdate')|date_format:"%Y-%m-%d"}>}</p>
<{else}>
<p>Welcome, Guest!</p>
<{/if}>

W szablonach modułu:

ZmiennaOpis
$xoops_dirnameNazwa katalogu modułu
$xoops_modulenameNazwa wyświetlania modułu
$mod_urlURL modułu (gdy przypisany)
// W PHP
$helper = \XoopsModules\MyModule\Helper::getInstance();
$GLOBALS['xoopsTpl']->assign('mod_url', $helper->url());
$GLOBALS['xoopsTpl']->assign('mod_name', $helper->getModule()->getVar('name'));
{* W szablonie *}
<a href="<{$mod_url}>">Back to <{$mod_name}></a>

Każdy blok w $xoops_lblocks, $xoops_rblocks i $xoops_cblocks ma:

WłaściwośćOpis
$block.idID bloku
$block.titleTytuł bloku
$block.contentZawartość HTML bloku
$block.templateNazwa szablonu bloku
$block.moduleNazwa modułu
$block.weightWaga/kolejność bloku
<{foreach item=block from=$xoops_lblocks}>
<div class="block block-<{$block.module}>">
<{if $block.title}>
<h3 class="block-title"><{$block.title}></h3>
<{/if}>
<div class="block-content">
<{$block.content}>
</div>
</div>
<{/foreach}>

Gdy używasz klasy XoopsForm:

// PHP
$form = new XoopsThemeForm('Edit Item', 'edit_form', 'save.php');
$form->addElement(new XoopsFormText('Title', 'title', 50, 255, $title));
$GLOBALS['xoopsTpl']->assign('form', $form->render());
{* Szablon *}
<div class="form-container">
<{$form}>
</div>
// PHP
include_once XOOPS_ROOT_PATH . '/class/pagenav.php';
$pagenav = new XoopsPageNav($total, $limit, $start, 'start');
$GLOBALS['xoopsTpl']->assign('page_nav', $pagenav->renderNav());
{* Szablon *}
<{if $page_nav}>
<div class="pagination">
<{$page_nav}>
</div>
<{/if}>
$GLOBALS['xoopsTpl']->assign('my_title', 'Custom Title');
$GLOBALS['xoopsTpl']->assign('item_count', 42);
$GLOBALS['xoopsTpl']->assign('is_featured', true);
<h1><{$my_title}></h1>
<p><{$item_count}> items found</p>
<{if $is_featured}>Featured!<{/if}>
$items = [
['id' => 1, 'name' => 'Item One', 'price' => 10.99],
['id' => 2, 'name' => 'Item Two', 'price' => 20.50],
];
$GLOBALS['xoopsTpl']->assign('items', $items);
<ul>
<{foreach $items as $item}>
<li>
<{$item.name}> - $<{$item.price|string_format:"%.2f"}>
</li>
<{/foreach}>
</ul>
$item = $itemHandler->get($itemId);
$GLOBALS['xoopsTpl']->assign('item', $item->toArray());
// Lub dla XoopsObject
$GLOBALS['xoopsTpl']->assign('item_obj', $item);
{* Dostęp do tablicy *}
<h2><{$item.title}></h2>
<p><{$item.content}></p>
{* Dostęp do metody obiektu *}
<h2><{$item_obj->getVar('title')}></h2>
$category = [
'id' => 1,
'name' => 'Technology',
'items' => [
['id' => 1, 'title' => 'Article 1'],
['id' => 2, 'title' => 'Article 2'],
]
];
$GLOBALS['xoopsTpl']->assign('category', $category);
<h2><{$category.name}></h2>
<ul>
<{foreach $category.items as $item}>
<li><{$item.title}></li>
<{/foreach}>
</ul>

Bieżący timestamp:

<p>Current year: <{$smarty.now|date_format:"%Y"}></p>
<p>Current date: <{$smarty.now|date_format:"%Y-%m-%d"}></p>
<p>Current time: <{$smarty.now|date_format:"%H:%M:%S"}></p>

Dostęp do stałych PHP:

<p>XOOPS URL: <{$smarty.const.XOOPS_URL}></p>
<p>Root Path: <{$smarty.const.XOOPS_ROOT_PATH}></p>
<p>Upload Path: <{$smarty.const.XOOPS_UPLOAD_PATH}></p>

Dostęp do zmiennych żądania (używaj z ostrożnością):

{* Tylko do odczytu, zawsze zescapuj wyjście! *}
<{if $smarty.get.page}>
Page: <{$smarty.get.page|escape}>
<{/if}>

Zmienne serwera:

<p>Server: <{$smarty.server.SERVER_NAME}></p>
<p>Request URI: <{$smarty.server.REQUEST_URI|escape}></p>

Informacje pętli:

<{foreach $items as $item name=itemloop}>
<{* Indeks (0-based) *}>
Index: <{$smarty.foreach.itemloop.index}>
<{* Iteracja (1-based) *}>
Number: <{$smarty.foreach.itemloop.iteration}>
<{* Pierwszy element *}>
<{if $smarty.foreach.itemloop.first}>First Item!<{/if}>
<{{* Ostatni element *}>
<{if $smarty.foreach.itemloop.last}>Last Item!<{/if}>
<{* Całkowita liczba *}>
Total: <{$smarty.foreach.itemloop.total}>
<{/foreach}>

Gdy używasz XMF, dostępni są dodatkowi pomocnicy:

// W PHP
use Xmf\Module\Helper;
$helper = Helper::getInstance();
$GLOBALS['xoopsTpl']->assign('mod_config', $helper->getConfig());
$GLOBALS['xoopsTpl']->assign('mod_url', $helper->url());
$GLOBALS['xoopsTpl']->assign('mod_path', $helper->path());
{* W szablonie *}
<a href="<{$mod_url}>">Module Home</a>
<{if $mod_config.show_breadcrumb}>
{* HTML breadcrumb *}
<{/if}>
{* Obrazy motywu *}
<img src="<{$xoops_imageurl}>images/logo.png" alt="Logo">
{* Obrazy modułu *}
<img src="<{$xoops_url}>/modules/<{$xoops_dirname}>/assets/images/icon.png">
{* Katalog wgrywania *}
<img src="<{$xoops_url}>/uploads/mymodule/<{$item.image}>">
{* Używanie ikon *}
<img src="<{$xoops_icons32_url}>edit.png" alt="Edit">
<img src="<{$xoops_icons16_url}>delete.png" alt="Delete">
{* Pokaż tylko zalogowanym użytkownikom *}
<{if $xoops_isuser}>
<a href="<{$xoops_url}>/modules/profile/">My Profile</a>
<a href="<{$xoops_url}>/user.php?op=logout">Logout</a>
<{{else}>
<a href="<{$xoops_url}>/user.php">Login</a>
<a href="<{$xoops_url}>/register.php">Register</a>
<{/if}>
{* Pokaż tylko administratorom *}
<{if $xoops_isadmin}>
<a href="<{$xoops_url}>/admin.php">Admin Panel</a>
<{/if}>
{* Pokaż tylko właścicielowi zawartości *}
<{if $xoops_isowner || $xoops_isadmin}>
<a href="edit.php?id=<{$item.id}>">Edit</a>
<a href="delete.php?id=<{$item.id}>">Delete</a>
<{/if}>
// W PHP - załaduj plik języka
xoops_loadLanguage('main', 'mymodule');
// Przypisz stałe języka
$GLOBALS['xoopsTpl']->assign('lang_title', _MD_MYMODULE_TITLE);
$GLOBALS['xoopsTpl']->assign('lang_submit', _SUBMIT);
{* W szablonie *}
<h1><{$lang_title}></h1>
<button type="submit"><{$lang_submit}></button>

Lub używaj stałych bezpośrednio:

<h1><{$smarty.const._MD_MYMODULE_TITLE}></h1>

Aby zobaczyć wszystkie dostępne zmienne:

{* Wyświetl konsole debugowania *}
<{debug}>
{* Wypisz określoną zmienną *}
<pre><{$myvar|@print_r}></pre>
{* Eksportuj zmienną *}
<pre><{$myvar|@var_export}></pre>

#smarty #szablony #zmienne #xoops #referenca