* @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 = []; /** * @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']; } else { $options['file'] = str_replace('\\', '/', $options['file']); $rawLink = $traceLine instanceof \Closure ? call_user_func($traceLine, $options, $this) : $traceLine; return strtr($rawLink, ['{file}' => $options['file'], '{line}' => $options['line'], '{text}' => $options['text']]); } } }