Вход Регистрация
Файл: framework/web/widgets/CContentDecorator.php
Строк: 127
<?php
/**
 * CContentDecorator class file.
 *
 * @author Qiang Xue <qiang.xue@gmail.com>
 * @link http://www.yiiframework.com/
 * @copyright Copyright &copy; 2008-2011 Yii Software LLC
 * @license http://www.yiiframework.com/license/
 */

/**
 * CContentDecorator decorates the content it encloses with the specified view.
 *
 * CContentDecorator is mostly used to implement nested layouts, i.e., a layout
 * is embedded within another layout. {@link CBaseController} defines a pair of
 * convenient methods to use CContentDecorator:
 * <pre>
 * $this->beginContent('path/to/view');
 * // ... content to be decorated
 * $this->endContent();
 * </pre>
 *
 * The property {@link view} specifies the name of the view that is used to
 * decorate the content. In the view, the content being decorated may be
 * accessed with variable <code>$content</code>.
 *
 * @author Qiang Xue <qiang.xue@gmail.com>
 * @version $Id: CContentDecorator.php 2799 2011-01-01 19:31:13Z qiang.xue $
 * @package system.web.widgets
 * @since 1.0
 */
class CContentDecorator extends COutputProcessor
{
    
/**
     * @var mixed the name of the view that will be used to decorate the captured content.
     * If this property is null (default value), the default layout will be used as
     * the decorative view. Note that if the current controller does not belong to
     * any module, the default layout refers to the application's {@link CWebApplication::layout default layout};
     * If the controller belongs to a module, the default layout refers to the module's
     * {@link CWebModule::layout default layout}.
     */
    
public $view;
    
/**
     * @var array the variables (name=>value) to be extracted and made available in the decorative view.
     * @since 1.0.4
     */
    
public $data=array();

    
/**
     * Processes the captured output.
     * This method decorates the output with the specified {@link view}.
     * @param string $output the captured output to be processed
     */
    
public function processOutput($output)
    {
        
$output=$this->decorate($output);
        
parent::processOutput($output);
    }

    
/**
     * Decorates the content by rendering a view and embedding the content in it.
     * The content being embedded can be accessed in the view using variable <code>$content</code>
     * The decorated content will be displayed directly.
     * @param string $content the content to be decorated
     * @return string the decorated content
     */
    
protected function decorate($content)
    {
        
$owner=$this->getOwner();
        if(
$this->view===null)
            
$viewFile=Yii::app()->getController()->getLayoutFile(null);
        else
            
$viewFile=$owner->getViewFile($this->view);
        if(
$viewFile!==false)
        {
            
$data=$this->data;
            
$data['content']=$content;
            return 
$owner->renderFile($viewFile,$data,true);
        }
        else
            return 
$content;
    }
}
Онлайн: 2
Реклама