Skip to content
linzongshu edited this page Mar 5, 2013 · 9 revisions

Theme View Helpers

Contents

  • asset
  • assetLocale
  • assetModule
  • assetTheme
  • backbone
  • basePath
  • blocks
  • css
  • doctype
  • escape
  • footScript
  • ga
  • headLink
  • headMeta
  • headScript
  • headStyle
  • headTitle
  • I18n
  • I18nModule
  • I18nTheme
  • jQuery
  • js
  • meta
  • navigation
  • nav
  • navMenu
  • paginationControl
  • template
  • templateComponent
  • templateModule
  • templateTheme
  • url
  • widget

asset

asset -- getting URI of an asset folder of module or theme.

Description

Object asset(string $component, string $file)

Parameters

component

Component including asset file, such as theme/default, module/demo.

file

File name to build asset URI.

Example

echo $this->asset('theme/default', 'css/style.css');	
echo $this->asset('module/demo', 'js/demo.js');

Output:

'http://localhost/Pi/www/asset/theme-default/css/style.css'
'http://localhost/Pi/www/asset/module-demo/js/demo.js'

assetLocale

This helper is used to build locale asset URI inside current theme. It takes three parameters: the first one indicates the file name, the second one indicates the locale file to choose, if it is not set, the system locale will be used, and the third one decides whether to append version for file path.

echo $this->assetLocale('style.css');
echo $this->assetLocale('js1.js', 'Zh-CN', false);

If the system locale is gray:'en', and current theme is 'default', the code above will output:

'http://localhost/pi/www/asset/theme-default/locale/en/style.css?1355197213'
'http://localhost/pi/www/asset/theme-default/locale/Zh-CN/js1.js'

NOTE: users should check the Append version checkbox in general configuration page to enable versioning.

assetModule

assetModule -- building module asset URI.

Description

string assetModule(string $file, string $module = null)

Parameters

file

File name for building module asset URI.

module

Module name.

Example

echo $this->assetModule('css/style.css');
echo $this->assetModule('js/file1.css', 'demo');

Output:

'http://localhost/Pi/www/asset/module-system/css/style.css'
'http://localhost/Pi/www/asset/module-demo/js/file1.js'

assetTheme

assetTheme -- building theme asset URI.

Description

string assetTheme(string $file, string $theme = null)

Parameters

file

File name for building theme asset URI.

module

Theme name.

Example

echo $this->assetTheme('css/style.css');	
echo $this->assetTheme('image/logo.png', 'dev');

Output:

'http://localhost/Pi/www/asset/theme-default/css/style.css'
'http://localhost/Pi/www/asset/theme-dev/image/logo.png'

backbone

This helper is used to load javascript files of backbone. The helper will autoload backbone.min.js and underscore-min.js files, and other static files can also be load if their file name is passed.

$this->backbone();
$this->backbone('js1.js');
$this->backbone(array(
    'backbone.min.js', 'style.css'
));

basePath

basePath -- building a base path.

Description

string basePath(string $file)

Parameters

file

File name for building base path.

Example

echo $this->basePath('index.php');
echo $this->basePath('asset');

Output:

'http://localhost/Pi/www/index.php'
'http://localhost/Pi/www/asset'

blocks

blocks -- loading blocks of a specified zone.

Description

array|Blocks blocks(string $zone)

Parameters

zone

Zone to load blocks. The value can be 0-8, or null.

Example

$blocks = $this->blocks();

$blocks = $this->blocks(1);
if (isset($blocks[1])) {
    foreach ($blocks as $key => $block) {
        include $this->template('block.phtml');
    }
}

bootstrap

Pi allows users to use bootstrap to achieve div+css, users only need to include the bootstrap file name and then insert the class name into their HTML tags, the whole front style will come true automatically.

This helper takes two parameters, the first one decides the static files to load, and the second parameter decide whether to load bootstrap.min.css, and the default value is true.

$this->bootstrap();
$this->bootstrap('css/bootstrap.responsive.min.css');
$this->bootstrap(array(
    'css/bootstrap.responsive.css',
    'js/bootstrap.js',
));

css

css -- loading CSS files.

Description

Object css(string|array $file)

Parameters

file

File name of CSS file or array include file name of CSS files.

Example

$this->css('file.css');	
$this->css(array('file1.js', 'file2.js'));
echo $this->headLink();

Output:

'<link href="file.css" media="screen" rel="stylesheet" type="text/css" >'
'<link href="file1.js" media="screen" rel="stylesheet" type="text/css" >'
'<link href="file2.js" media="screen" rel="stylesheet" type="text/css" >'

doctype

doctype -- creating a doctype of HTML and XHTML document.

Description

Object doctype(string $doctype)

Parameters

doctype

The doctype allows you to specify one of the following types:

XHTML11

XHTML1_STRICT

XHTML1_TRANSITIONAL

XHTML1_FRAMESET

XHTML1_RDFA

XHTML_BASIC1

HTML4_STRICT

HTML4_LOOSE

HTML4_FRAMESET

HTML5

Example

echo $this->doctype('XHTML1_STRICT');

Output:

'<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">'

escape

It is strongly recommended to add escape for output variables, the escape helper helps user to escape easily.

echo $this->escape($value);

footScript

footScript -- has the same function as headScript. Generally used in block template.

Description

Object footScript(string $mode = HeadScript::FILE, string $spec = null, string $placement = 'APPEND', array $attrs = array(), string $type = 'text/javascript')

Parameters

mode

May be specified as FILE or SCRIPT.

spec

Url of script.

placement

Can be SET, APPEND or PREPEND.

attrs

Attributes of script.

type

Type of script or array of script attributes.

Example

$this->footScript()->appendFile('/js/scriptaculous.js');

.. _ga:

ga

This helper is used to add GA code for users to get statistical data of their site. It takes only one parameter which is the GA account. And the default account from configuration will be used if it is not set.

$this->ga();
$this->ga('UA-XXXXX-X');

headLink

headLink -- creating and aggregating HTML <link> element for later retrieval and output in your layout script.

Description

Object headLink(array $attributes = null, $placement = Placeholder\Container\AbstractContainer::APPEND)

Parameters

attributes

Attributes to create link.

Example

echo $this->headLink();
echo $this->headLink(array(
        'rel'   => 'icon',
        'href'  => '/img/favicon.ico'),
        'PREPEND');

Output of second line:

'<link href="/img/favicon.ico" rel="icon" >'

headMeta

headMeta -- creating HTML <meta> element for later retrieval and output.

Description

Object headMeta(string $content = null, string $keyValue = null, string $keyType = 'name', array $modifiers = array(), string $placement = Placeholder\Container\AbstractContainer::APPEND)

Parameters

content

Content of meta.

keyValue

Content for the key specified in $keyType.

keyType

May be specified as property if the doctype has been set to XHTML1_RDFA.

placement

Can be SET, APPEND or PREPEND.

Example

echo $this->headMeta();
echo $this->headMeta()->appendName('keywords', 'framework, PHP, productivity');

Output of second line:

'<meta name="keywords" content="framework, PHP, productivity" >'

headScript

headScript -- creating HTML <script> element for later retrieval and output.

Description

Object headScript(string $mode = HeadScript::FILE, string $spec = null, string $placement = 'APPEND', array $attrs = array(), string $type = 'text/javascript')

Parameters

mode

May be specified as FILE or SCRIPT.

spec

Url of script.

placement

Can be SET, APPEND or PREPEND.

attrs

Attributes of script.

type

Type of script or array of script attributes.

Example

$this->headScript()->appendFile('/js/scriptaculous.js');

headStyle

headStyle -- The HTML <style> element is used to include CSS stylesheets inline in the HTML <head> element.

Description

Object headStyle(string $content = null, string $placement = 'APPEND', string|array $attributes = array())

Parameters

content

Stylesheet content.

placement

Decide whether to append, prepend or set the stylesheet content.

attributes

Optional attributes.

Examples

$this->headStyle('style.css', 'APPEND', array('conditional' => 'lt IE 7'));
$this->headStyle()->appendStyle($styles, array('conditional' => 'lt IE 7'));

headTitle

headTitle -- creating and storing a HTML <title> element for later retrieval and output programmatically.

Description

Object headTitle(string $title = null, string $setType = null)

Parameters

title

Name of title.

setType

Type of title, the value can be APPEND, PREPEND or SET.

Example

echo $this->headTitle();
echo $this->headTitle('Zend Framework');

Output of second line:

'<title>Zend Framework</title>'

I18n

I18n -- loading global locale file for application.

Description

object I18n(string $component, string $file)

Parameters

component

Indicating the component or file name data of the translation file.

file

Indicating the locale folder name.

Examples

$this->i18n(array('theme/default', 'main'), 'en');
$this->i18n('usr:date', 'en');

Therefore the following locale files will be loaded:

'D:/wamp/www/pi/usr/theme/default/locale/en/main.csv'
'D:/wamp/www/pi/usr/locale/en/date.csv'

i18nModule

I18nModule -- loading a module i18n locale file.

Description

Object i18nModule(string $domain, string|null $module = null, string|null $locale = null)

Parameters

domain

Domain name.

module

Module name.

locale

Language name to use.

Examples

$this->i18nModule('block', 'demo', 'en');

Then the following locale file will be loaded:

'D:/wamp/www/pi/usr/demo/locale/en/block.csv'

I18nTheme

I18nTheme -- loading a theme i18n resource.

Description

Object I18nTheme(string $domain, string $theme = null, string $locale = null)

Parameters

domain

Domain name.

theme

Theme name to use.

locale

Language name to use.

Example

$this->i18nTheme('main');
$this->i18nTheme('main', 'default');
$this->i18nTheme('main', null, 'en');

jQuery

jQuery -- loading jQuery files or css files, if there is no parameter assigned, it will load jquery.min.js file as default.

Description

void jQuery(string|array $filename)

Parameters

filename

Name of jQuery file want to load.

Example

$this->jQuery();
$this->jQuery('extension.js');
$this->jQuery(array('example.js', 'jQuery.min.js'));
echo $this->headScript();

Output:

<script type="text/javascript" src="http://localhost/Pi/www/static/js/jquery/jquery.min.js"></script>
<script type="text/javascript" src="http://localhost/Pi/www/static/js/jquery/extension.js"></script>
<script type="text/javascript" src="http://localhost/Pi/www/static/js/jquery/example.js"></script>
<script type="text/javascript" src="http://localhost/Pi/www/static/js/jquery/jQuery.min.js"></script>

js

js -- loading JavaScript files.

Description

Object js(string|array $file)

Parameters

file

File name of JavaScript file or array include file name of CSS files.

Example

$this->js('file.js');
$this->js(array('file1.js', 'file2.js'));
echo $this->headScript();

Output:

'<script type="text/javascript" src="file.js"></script>'
'<script type="text/javascript" src="file1.js"></script>'
'<script type="text/javascript" src="file2.js"></script>'

meta

meta -- getting meta data from application's config table.

Description

string|Meta meta(string $name)

Parameters

name

Field name of meta array.

Example

echo $this->meta('sitename');
echo $this->meta('keywords');

Output as default:

'Pi'
'Pi, Web application'

navigation

The navigation helper is used to load a navigation for current module of Pi application.

This helper takes two parameters, the first one is name of navigation to load, it can also be comprehended as section in general. In Pi, it can be set to front or admin to load a front navigation or admin navigation, or name indicate custom navigation defined by users. A front navigation will be used if this parameter is not set. The second parameter is an array and its fields will be used to configure cache.

NOTE: the data used to generate navigation are fetched from core_navigation_node table, these data are first define in the config/navigation.php file.

// load a front navigation
$this->navigation('front');
// load a admin navigation and set cache ttl, level and key
$this->navigation('admin', array(
    'cache_ttl'   => 86400,
    'cache_level' => none,
    'cache_id'    => 'nav_system'));
// render a custom navigation 'cms' if current module is demo
$this->navigation('demo-cms')->render();

Menu

This class is used to operate menu and can be call by $this->navigation()->menu().

this setUIClass(string $ulClass);
this setOnlyActiveBranch(bool $flag = true);
this escapeLabels(bool $flag = true);
this setRenderParent(bool $flag = true);
this setPartial(string|array $partial);
string renderMenu(AbstractContainer $container = null, array $options = array());
array renderPair(AbstractContainer $container = null, array $options = array());
string render($AbstractContainer $container = null);
  • setUIClass()

Set css class to use for the first 'ul' element when rendering.

$this->navigation('front')->menu()->setUIClass('jd_menu');
  • setOnlyActiveBranch()

This method decides whether to render active branch only, the application will only render active branch if set to true.

$this->navigation('front')->menu()->setOnlyActiveBranch();
  • escapeLabels()

Indicating whether to escape labels. Its default value is true.

$this->navigation('front')->menu()->escapeLabels();
  • setRenderParents()

    $this->navigation('front')->menu()->setRenderParents();

  • setPartial()

  • render()

Rendering menu.

$this->navigation('front')->menu()->render();

Breadcrumbs

This class is used to operate breadcrumbs and can be call by $this->navigation()->breadcrumbs().

this setSeparator(string $sepatator);
this setLinkLast(bool $linkLast);
string render(AbstractContainer $container = null);
  • setSepatator()

Set breadcrumb separator.

$this->navigation('front')->breadcrumbs()->setSeparator('<span class="divider">&gt;</span>');
  • setLinkLast()

Deciding whether last page in breadcrumbs should be hyperlinked.

$this->navigation('front')->breadcrumbs()->setLinkLast(true);
  • render()

Rendering breadcrumb.

$this->navigation('front')->breadcrumbs()->render();

nav

This class is used to load a global navigation, it will read navigation name from core_config table, and then render the navigation by calling navigation helper. Therefore by using this helper in template, users can install custom navigation in admin section and then the custom navigation will be displayed.

The value passed to this method can only be front and admin to indicate load front global navigation or administration global navigation, respectively.

Its second parameter is an optional array for setting cache.

$this->nav('front');
$this->nav('admin', array(
    'cache_ttl'   => 84600,
    'cache_id'    => 'system_nav',
));

template

template -- getting a path of template file if the path is exists.

Description

string template(string $template)

Parameters

template

Template name.

Example

echo $this->template('block.phtml');

Output such as:

'D:/wamp/www/Pi/usr/theme/default/template/block.phtml'

templateModule

templateModule -- getting full path of a module template if it exists.

Description

string templateModule(string $template, string $module = null)

Parameters

template

Template name.

module

Module name, if set to null, the current module will be used.

Example

echo $this->templateModule('admin/block-add.phtml', 'system'); 
echo $this->templateModule('front/login.phtml');

Output such as:

'D:/wamp/www/Pi/usr/module/system/template/admin/block-add.phtml'
'D:/wamp/www/Pi/usr/module/login/template/front/login.phtml' 

templateTheme

templateTheme -- getting full path of a theme template if it exists.

Description

string templateTheme(string $template)

Parameters

template

Template name.

Example

$this->templateTheme('block.phtml');

Output such as:

'D:/wamp/www/Pi/usr/theme/default/template/block.phtml'

url

url -- generating an url by given name and route .

Description

Object url(string $name = null, array $params = array(), array $options = array(), boolean $reuseMatchedParams = false)

Parameters

name

Name of the route, can set to default for front-end, admin for admin-end, home for homepage and feed for feed section.

params

Parameters for generating url.

options

Options for the route.

attrs

Attributes of script.

reuseMatchedParams

Whether to reuse matched parameters.

Example

$this->url('', array(    
    'module'     => 'system',
    'controller' => 'index',
    'action'     => 'index',
));

$this->url('home');

$this->url('default', array(
    'controller'  => 'index',
    'action'      => 'index',
));

You can also add your parameters to the second parameter of url helper. These parameters will post by GET method, for example:

$this->url('' array(
    'controller'  => 'login',
    'action'      => 'login',
    'param'       => 'hello',
));

The url will be:

'path/to/www/login/login/param-hello'