init
This commit is contained in:
181
vendor/yiisoft/yii2-debug/Panel.php
vendored
Normal file
181
vendor/yiisoft/yii2-debug/Panel.php
vendored
Normal file
@@ -0,0 +1,181 @@
|
||||
<?php
|
||||
/**
|
||||
* @link http://www.yiiframework.com/
|
||||
* @copyright Copyright (c) 2008 Yii Software LLC
|
||||
* @license http://www.yiiframework.com/license/
|
||||
*/
|
||||
|
||||
namespace yii\debug;
|
||||
|
||||
use Yii;
|
||||
use yii\base\Component;
|
||||
use yii\helpers\ArrayHelper;
|
||||
use yii\helpers\Url;
|
||||
|
||||
/**
|
||||
* Panel is a base class for debugger panel classes. It defines how data should be collected,
|
||||
* what should be displayed at debug toolbar and on debugger details view.
|
||||
*
|
||||
* @property string $detail Content that is displayed in debugger detail view. This property is read-only.
|
||||
* @property string $name Name of the panel. This property is read-only.
|
||||
* @property string $summary Content that is displayed at debug toolbar. This property is read-only.
|
||||
* @property string $url URL pointing to panel detail view. This property is read-only.
|
||||
*
|
||||
* @author Qiang Xue <qiang.xue@gmail.com>
|
||||
* @since 2.0
|
||||
*/
|
||||
class Panel extends Component
|
||||
{
|
||||
/**
|
||||
* @var string panel unique identifier.
|
||||
* It is set automatically by the container module.
|
||||
*/
|
||||
public $id;
|
||||
/**
|
||||
* @var string request data set identifier.
|
||||
*/
|
||||
public $tag;
|
||||
/**
|
||||
* @var Module
|
||||
*/
|
||||
public $module;
|
||||
/**
|
||||
* @var mixed data associated with panel
|
||||
*/
|
||||
public $data;
|
||||
/**
|
||||
* @var array array of actions to add to the debug modules default controller.
|
||||
* This array will be merged with all other panels actions property.
|
||||
* See [[\yii\base\Controller::actions()]] for the format.
|
||||
*/
|
||||
public $actions = [];
|
||||
|
||||
/**
|
||||
* @var FlattenException|null Error while saving the panel
|
||||
* @since 2.0.10
|
||||
*/
|
||||
protected $error;
|
||||
|
||||
|
||||
/**
|
||||
* @return string name of the panel
|
||||
*/
|
||||
public function getName()
|
||||
{
|
||||
return '';
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string content that is displayed at debug toolbar
|
||||
*/
|
||||
public function getSummary()
|
||||
{
|
||||
return '';
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string content that is displayed in debugger detail view
|
||||
*/
|
||||
public function getDetail()
|
||||
{
|
||||
return '';
|
||||
}
|
||||
|
||||
/**
|
||||
* Saves data to be later used in debugger detail view.
|
||||
* This method is called on every page where debugger is enabled.
|
||||
*
|
||||
* @return mixed data to be saved
|
||||
*/
|
||||
public function save()
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Loads data into the panel
|
||||
*
|
||||
* @param mixed $data
|
||||
*/
|
||||
public function load($data)
|
||||
{
|
||||
$this->data = $data;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param null|array $additionalParams Optional additional parameters to add to the route
|
||||
* @return string URL pointing to panel detail view
|
||||
*/
|
||||
public function getUrl($additionalParams = null)
|
||||
{
|
||||
$route = [
|
||||
'/' . $this->module->id . '/default/view',
|
||||
'panel' => $this->id,
|
||||
'tag' => $this->tag,
|
||||
];
|
||||
|
||||
if (is_array($additionalParams)){
|
||||
$route = ArrayHelper::merge($route, $additionalParams);
|
||||
}
|
||||
|
||||
return Url::toRoute($route);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns a trace line
|
||||
* @param array $options The array with trace
|
||||
* @return string the trace line
|
||||
* @since 2.0.7
|
||||
*/
|
||||
public function getTraceLine($options)
|
||||
{
|
||||
if (!isset($options['text'])) {
|
||||
$options['text'] = "{$options['file']}:{$options['line']}";
|
||||
}
|
||||
$traceLine = $this->module->traceLine;
|
||||
if ($traceLine === false) {
|
||||
return $options['text'];
|
||||
}
|
||||
|
||||
$options['file'] = str_replace('\\', '/', $options['file']);
|
||||
$rawLink = $traceLine instanceof \Closure ? $traceLine($options, $this) : $traceLine;
|
||||
return strtr($rawLink, ['{file}' => $options['file'], '{line}' => $options['line'], '{text}' => $options['text']]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param FlattenException $error
|
||||
* @since 2.0.10
|
||||
*/
|
||||
public function setError(FlattenException $error)
|
||||
{
|
||||
$this->error = $error;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return FlattenException|null
|
||||
* @since 2.0.10
|
||||
*/
|
||||
public function getError()
|
||||
{
|
||||
return $this->error;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return bool
|
||||
* @since 2.0.10
|
||||
*/
|
||||
public function hasError()
|
||||
{
|
||||
return $this->error !== null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Is the panel enabled?
|
||||
* @return bool
|
||||
* @since 2.0.10
|
||||
*/
|
||||
public function isEnabled()
|
||||
{
|
||||
return true;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user