diff --git a/framework/yii/assets.php b/framework/yii/assets.php index 63f7560..0e0d2e6 100644 --- a/framework/yii/assets.php +++ b/framework/yii/assets.php @@ -35,13 +35,6 @@ return array( ), 'depends' => array('yii'), ), - 'yii/debug' => array( - 'sourcePath' => __DIR__ . '/assets', - 'js' => array( - 'yii.debug.js', - ), - 'depends' => array('yii'), - ), 'yii/punycode' => array( 'sourcePath' => __DIR__ . '/assets', 'js' => array( @@ -55,4 +48,17 @@ return array( ), 'depends' => array('yii/jquery'), ), + 'yii/debug' => array( + 'sourcePath' => __DIR__ . '/debug/assets', + 'css' => array( + 'main.css', + ), + 'js' => array( + 'yii.debug.js', + ), + 'depends' => array( + 'yii', + 'yii/bootstrap/responsive', + ), + ), ); diff --git a/framework/yii/bootstrap/assets.php b/framework/yii/bootstrap/assets.php index 95b8d40..0c4a6bc 100644 --- a/framework/yii/bootstrap/assets.php +++ b/framework/yii/bootstrap/assets.php @@ -1,4 +1,9 @@ array( diff --git a/framework/yii/debug/Module.php b/framework/yii/debug/Module.php index cc877eb..07ff330 100644 --- a/framework/yii/debug/Module.php +++ b/framework/yii/debug/Module.php @@ -39,7 +39,7 @@ class Module extends \yii\base\Module * @var string the directory storing the debugger data files. This can be specified using a path alias. */ public $dataPath = '@runtime/debug'; - public $historySize = 5; + public $historySize = 50; public function init() { @@ -90,6 +90,9 @@ class Module extends \yii\base\Module protected function corePanels() { return array( + 'config' => array( + 'class' => 'yii\debug\panels\ConfigPanel', + ), 'request' => array( 'class' => 'yii\debug\panels\RequestPanel', ), @@ -102,9 +105,6 @@ class Module extends \yii\base\Module 'db' => array( 'class' => 'yii\debug\panels\DbPanel', ), - 'config' => array( - 'class' => 'yii\debug\panels\ConfigPanel', - ), ); } } diff --git a/framework/yii/debug/assets/main.css b/framework/yii/debug/assets/main.css new file mode 100644 index 0000000..10c64df --- /dev/null +++ b/framework/yii/debug/assets/main.css @@ -0,0 +1,46 @@ +#yii-debug-toolbar { + position: fixed; + left: 0; + right: 0; + bottom: 0; + margin: 0; + padding: 0; + z-index: 1000000; + font: 11px Verdana, Arial, sans-serif; + text-align: left; + height: 38px; + border-top: 1px solid #ccc; + background: rgb(237,237,237); + background: url(); + background: -moz-linear-gradient(top, rgba(237,237,237,1) 0%, rgba(246,246,246,1) 53%, rgba(255,255,255,1) 100%); + background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(237,237,237,1)), color-stop(53%,rgba(246,246,246,1)), color-stop(100%,rgba(255,255,255,1))); + background: -webkit-linear-gradient(top, rgba(237,237,237,1) 0%,rgba(246,246,246,1) 53%,rgba(255,255,255,1) 100%); + background: -o-linear-gradient(top, rgba(237,237,237,1) 0%,rgba(246,246,246,1) 53%,rgba(255,255,255,1) 100%); + background: -ms-linear-gradient(top, rgba(237,237,237,1) 0%,rgba(246,246,246,1) 53%,rgba(255,255,255,1) 100%); + background: linear-gradient(to bottom, rgba(237,237,237,1) 0%,rgba(246,246,246,1) 53%,rgba(255,255,255,1) 100%); + filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ededed', endColorstr='#ffffff',GradientType=0 ); +} + +.yii-debug-toolbar-block { + float: left; + margin: 0; + border-right: 1px solid #e4e4e4; + padding: 4px 8px; + line-height: 32px; +} + +.yii-debug-toolbar-block a { + text-decoration: none; + color: black !important; +} + +.yii-debug-toolbar-block span { +} + +.yii-debug-toolbar-block img { + vertical-align: middle; +} + +span.indent { + color: #ccc; +} diff --git a/framework/yii/assets/yii.debug.js b/framework/yii/debug/assets/yii.debug.js similarity index 100% rename from framework/yii/assets/yii.debug.js rename to framework/yii/debug/assets/yii.debug.js diff --git a/framework/yii/debug/controllers/DefaultController.php b/framework/yii/debug/controllers/DefaultController.php index 4662d78..80be184 100644 --- a/framework/yii/debug/controllers/DefaultController.php +++ b/framework/yii/debug/controllers/DefaultController.php @@ -21,13 +21,17 @@ class DefaultController extends Controller public $module; public $layout = 'main'; - public function actionIndex($tag, $panel = null) + public function actionIndex($tag = null, $panel = null) { + if ($tag === null) { + $tags = array_keys($this->getManifest()); + $tag = end($tags); + } $meta = $this->loadData($tag); if (isset($this->module->panels[$panel])) { $activePanel = $this->module->panels[$panel]; } else { - $activePanel = reset($this->module->panels); + $activePanel = $this->module->panels['request']; } return $this->render('index', array( 'tag' => $tag, @@ -47,6 +51,11 @@ class DefaultController extends Controller )); } + public function actionPhpinfo() + { + phpinfo(); + } + private $_manifest; protected function getManifest() diff --git a/framework/yii/debug/panels/ConfigPanel.php b/framework/yii/debug/panels/ConfigPanel.php index 03f0bdd..695856c 100644 --- a/framework/yii/debug/panels/ConfigPanel.php +++ b/framework/yii/debug/panels/ConfigPanel.php @@ -9,6 +9,7 @@ namespace yii\debug\panels; use Yii; use yii\debug\Panel; +use yii\helpers\Html; /** * @author Qiang Xue @@ -18,22 +19,64 @@ class ConfigPanel extends Panel { public function getName() { - return 'Config'; + return 'Configuration'; } public function getSummary() { + $yiiLogo = ''; return << - PHP: {$this->data['phpVersion']}, - Yii: {$this->data['yiiVersion']} + + + {$this->data['application']['yii']} + + +
+ PHP {$this->data['php']['version']}
EOD; } public function getDetail() { - return '

Config

'; + $app = array( + 'Yii Version' => $this->data['application']['yii'], + 'Application Name' => $this->data['application']['name'], + 'Environment' => $this->data['application']['env'], + 'Debug Mode' => $this->data['application']['debug'] ? 'Yes' : 'No', + ); + $php = array( + 'PHP Version' => $this->data['php']['version'], + 'Xdebug' => $this->data['php']['xdebug'] ? 'Enabled' : 'Disabled', + 'APC' => $this->data['php']['apc'] ? 'Enabled' : 'Disabled', + 'Memcache' => $this->data['php']['memcache'] ? 'Enabled' : 'Disabled', + ); + return "

Configuration

\n" + . $this->renderData('Application Configuration', $app) . "\n" + . $this->renderData('PHP Configuration', $php) . "\n" + . '
' . Html::a('Complete phpinfo()', array('phpinfo'), array('class' => 'btn btn-info')) . "
\n"; + } + + protected function renderData($caption, $values) + { + if (empty($values)) { + return "

$caption

\n

Empty.

"; + } + $rows = array(); + foreach ($values as $name => $value) { + $rows[] = '' . Html::encode($name) . '
' . Html::encode($value) . '
'; + } + $rows = implode("\n", $rows); + return <<$caption + + + +$rows + +
NameValue
+EOD; } public function save() @@ -41,6 +84,18 @@ EOD; return array( 'phpVersion' => PHP_VERSION, 'yiiVersion' => Yii::getVersion(), + 'application' => array( + 'yii' => Yii::getVersion(), + 'name' => Yii::$app->name, + 'env' => YII_ENV, + 'debug' => YII_DEBUG, + ), + 'php' => array( + 'version' => PHP_VERSION, + 'xdebug' => extension_loaded('xdebug'), + 'apc' => extension_loaded('apc'), + 'memcache' => extension_loaded('memcache'), + ), ); } } diff --git a/framework/yii/debug/panels/ProfilingPanel.php b/framework/yii/debug/panels/ProfilingPanel.php index 643ca5f..c09108e 100644 --- a/framework/yii/debug/panels/ProfilingPanel.php +++ b/framework/yii/debug/panels/ProfilingPanel.php @@ -49,10 +49,10 @@ class ProfilingPanel extends Panel $rows = array(); foreach ($timings as $timing) { - $time = sprintf('%0.5f', $timing[3]); - $procedure = str_repeat(' ', $timing[0] * 4) . Html::encode($timing[1]); + $time = sprintf('%.1f ms', $timing[3] * 1000); + $procedure = str_repeat('', $timing[0]) . Html::encode($timing[1]); $category = Html::encode($timing[2]); - $rows[] = "$category$procedure{$time}s"; + $rows[] = "$time$category$procedure"; } $rows = implode("\n", $rows); @@ -62,9 +62,9 @@ class ProfilingPanel extends Panel - + + - diff --git a/framework/yii/debug/panels/RequestPanel.php b/framework/yii/debug/panels/RequestPanel.php index 905a375..2727a3a 100644 --- a/framework/yii/debug/panels/RequestPanel.php +++ b/framework/yii/debug/panels/RequestPanel.php @@ -25,8 +25,8 @@ class RequestPanel extends Panel public function getSummary() { - $memory = sprintf('%.2fMB', $this->data['memory'] / 1048576); - $time = sprintf('%.3fs', $this->data['time']); + $memory = sprintf('%.1f MB', $this->data['memory'] / 1048576); + $time = number_format($this->data['time'] * 1000) . ' ms'; return << diff --git a/framework/yii/debug/views/default/index.php b/framework/yii/debug/views/default/index.php index dcb6bac..ead7fb3 100644 --- a/framework/yii/debug/views/default/index.php +++ b/framework/yii/debug/views/default/index.php @@ -12,12 +12,15 @@ use yii\helpers\Html; */ $this->registerAssetBundle('yii/bootstrap/dropdown'); +$this->title = 'Yii Debugger'; ?>
diff --git a/framework/yii/debug/views/default/toolbar.php b/framework/yii/debug/views/default/toolbar.php index b81efcc..05b03f6 100644 --- a/framework/yii/debug/views/default/toolbar.php +++ b/framework/yii/debug/views/default/toolbar.php @@ -12,24 +12,46 @@ use yii\helpers\Html; left: 0; right: 0; bottom: 0; - background-color: #eee; - border-top: 1px solid #ccc; margin: 0; - padding: 5px 10px; + padding: 0; z-index: 1000000; font: 11px Verdana, Arial, sans-serif; text-align: left; + height: 38px; + border-top: 1px solid #ccc; + background: rgb(237,237,237); + background: url(); + background: -moz-linear-gradient(top, rgba(237,237,237,1) 0%, rgba(246,246,246,1) 53%, rgba(255,255,255,1) 100%); + background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(237,237,237,1)), color-stop(53%,rgba(246,246,246,1)), color-stop(100%,rgba(255,255,255,1))); + background: -webkit-linear-gradient(top, rgba(237,237,237,1) 0%,rgba(246,246,246,1) 53%,rgba(255,255,255,1) 100%); + background: -o-linear-gradient(top, rgba(237,237,237,1) 0%,rgba(246,246,246,1) 53%,rgba(255,255,255,1) 100%); + background: -ms-linear-gradient(top, rgba(237,237,237,1) 0%,rgba(246,246,246,1) 53%,rgba(255,255,255,1) 100%); + background: linear-gradient(to bottom, rgba(237,237,237,1) 0%,rgba(246,246,246,1) 53%,rgba(255,255,255,1) 100%); + filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ededed', endColorstr='#ffffff',GradientType=0 ); } + .yii-debug-toolbar-block { float: left; - margin: 0 10px; + margin: 0; + border-right: 1px solid #e4e4e4; + padding: 4px 8px; + line-height: 32px; +} + +.yii-debug-toolbar-block a { + text-decoration: none; + color: black !important; +} + +.yii-debug-toolbar-block span { +} + +.yii-debug-toolbar-block img { + vertical-align: middle; }
-
- $tag)); ?> -
getSummary(); ?> diff --git a/framework/yii/debug/views/layouts/main.php b/framework/yii/debug/views/layouts/main.php index 11eeb2d..5c8a735 100644 --- a/framework/yii/debug/views/layouts/main.php +++ b/framework/yii/debug/views/layouts/main.php @@ -5,7 +5,7 @@ */ use yii\helpers\Html; -Yii::$app->getView()->registerAssetBundle('yii/bootstrap/responsive'); +Yii::$app->getView()->registerAssetBundle('yii/debug'); ?>
CategoryTimeCategory ProcedureTime