diff options
Diffstat (limited to 'framework/zii/widgets/CBreadcrumbs.php')
| -rw-r--r-- | framework/zii/widgets/CBreadcrumbs.php | 116 |
1 files changed, 116 insertions, 0 deletions
diff --git a/framework/zii/widgets/CBreadcrumbs.php b/framework/zii/widgets/CBreadcrumbs.php new file mode 100644 index 0000000..3d4b7be --- /dev/null +++ b/framework/zii/widgets/CBreadcrumbs.php @@ -0,0 +1,116 @@ +<?php +/** + * CBreadcrumbs class file. + * + * @author Qiang Xue <qiang.xue@gmail.com> + * @link http://www.yiiframework.com/ + * @copyright Copyright © 2008-2011 Yii Software LLC + * @license http://www.yiiframework.com/license/ + */ + +/** + * CBreadcrumbs displays a list of links indicating the position of the current page in the whole website. + * + * For example, breadcrumbs like "Home > Sample Post > Edit" means the user is viewing an edit page + * for the "Sample Post". He can click on "Sample Post" to view that page, or he can click on "Home" + * to return to the homepage. + * + * To use CBreadcrumbs, one usually needs to configure its {@link links} property, which specifies + * the links to be displayed. For example, + * + * <pre> + * $this->widget('zii.widgets.CBreadcrumbs', array( + * 'links'=>array( + * 'Sample post'=>array('post/view', 'id'=>12), + * 'Edit', + * ), + * )); + * </pre> + * + * Because breadcrumbs usually appears in nearly every page of a website, the widget is better to be placed + * in a layout view. One can define a property "breadcrumbs" in the base controller class and assign it to the widget + * in the layout, like the following: + * + * <pre> + * $this->widget('zii.widgets.CBreadcrumbs', array( + * 'links'=>$this->breadcrumbs, + * )); + * </pre> + * + * Then, in each view script, one only needs to assign the "breadcrumbs" property as needed. + * + * @author Qiang Xue <qiang.xue@gmail.com> + * @version $Id: CBreadcrumbs.php 2799 2011-01-01 19:31:13Z qiang.xue $ + * @package zii.widgets + * @since 1.1 + */ +class CBreadcrumbs extends CWidget +{ + /** + * @var string the tag name for the breadcrumbs container tag. Defaults to 'div'. + */ + public $tagName='div'; + /** + * @var array the HTML attributes for the breadcrumbs container tag. + */ + public $htmlOptions=array('class'=>'breadcrumbs'); + /** + * @var boolean whether to HTML encode the link labels. Defaults to true. + */ + public $encodeLabel=true; + /** + * @var string the first hyperlink in the breadcrumbs (called home link). + * If this property is not set, it defaults to a link pointing to {@link CWebApplication::homeUrl} with label 'Home'. + * If this property is false, the home link will not be rendered. + */ + public $homeLink; + /** + * @var array list of hyperlinks to appear in the breadcrumbs. If this property is empty, + * the widget will not render anything. Each key-value pair in the array + * will be used to generate a hyperlink by calling CHtml::link(key, value). For this reason, the key + * refers to the label of the link while the value can be a string or an array (used to + * create a URL). For more details, please refer to {@link CHtml::link}. + * If an element's key is an integer, it means the element will be rendered as a label only (meaning the current page). + * + * The following example will generate breadcrumbs as "Home > Sample post > Edit", where "Home" points to the homepage, + * "Sample post" points to the "index.php?r=post/view&id=12" page, and "Edit" is a label. Note that the "Home" link + * is specified via {@link homeLink} separately. + * + * <pre> + * array( + * 'Sample post'=>array('post/view', 'id'=>12), + * 'Edit', + * ) + * </pre> + */ + public $links=array(); + /** + * @var string the separator between links in the breadcrumbs. Defaults to ' » '. + */ + public $separator=' » '; + + /** + * Renders the content of the portlet. + */ + public function run() + { + if(empty($this->links)) + return; + + echo CHtml::openTag($this->tagName,$this->htmlOptions)."\n"; + $links=array(); + if($this->homeLink===null) + $links[]=CHtml::link(Yii::t('zii','Home'),Yii::app()->homeUrl); + else if($this->homeLink!==false) + $links[]=$this->homeLink; + foreach($this->links as $label=>$url) + { + if(is_string($label) || is_array($url)) + $links[]=CHtml::link($this->encodeLabel ? CHtml::encode($label) : $label, $url); + else + $links[]='<span>'.($this->encodeLabel ? CHtml::encode($url) : $url).'</span>'; + } + echo implode($this->separator,$links); + echo CHtml::closeTag($this->tagName); + } +}
\ No newline at end of file |
