Block.php 886 Bytes
Newer Older
Qiang Xue committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
<?php
/**
 * @link http://www.yiiframework.com/
 * @copyright Copyright (c) 2008 Yii Software LLC
 * @license http://www.yiiframework.com/license/
 */

namespace yii\widgets;

use yii\base\Widget;

/**
 * @author Qiang Xue <qiang.xue@gmail.com>
 * @since 2.0
 */
Qiang Xue committed
16
class Block extends Widget
Qiang Xue committed
17 18
{
	/**
Qiang Xue committed
19 20
	 * @var boolean whether to render the block content in place. Defaults to false,
	 * meaning the captured block content will not be displayed.
Qiang Xue committed
21 22 23 24
	 */
	public $renderInPlace = false;

	/**
Qiang Xue committed
25
	 * Starts recording a block.
Qiang Xue committed
26 27 28 29 30 31 32 33
	 */
	public function init()
	{
		ob_start();
		ob_implicit_flush(false);
	}

	/**
Qiang Xue committed
34
	 * Ends recording a block.
35
	 * This method stops output buffering and saves the rendering result as a named block in the view.
Qiang Xue committed
36 37 38
	 */
	public function run()
	{
Qiang Xue committed
39 40 41
		$block = ob_get_clean();
		if ($this->renderInPlace) {
			echo $block;
Qiang Xue committed
42
		}
43
		$this->view->blocks[$this->getId()] = $block;
Qiang Xue committed
44
	}
Zander Baldwin committed
45
}