[TASK] Prettify Extbase Debugger Utility 90/42790/4
authorBenjamin Kott <benjamin.kott@outlook.com>
Thu, 20 Aug 2015 21:58:22 +0000 (23:58 +0200)
committerAlexander Opitz <opitz.alexander@googlemail.com>
Tue, 25 Aug 2015 06:55:59 +0000 (08:55 +0200)
Releases: master
Resolves: #69299
Change-Id: Ibee145703e1689ca804384b20b9af1b0b586b8d8
Reviewed-on: http://review.typo3.org/42790
Reviewed-by: Helmut Hummel <helmut.hummel@typo3.org>
Tested-by: Helmut Hummel <helmut.hummel@typo3.org>
Reviewed-by: Alexander Opitz <opitz.alexander@googlemail.com>
Tested-by: Alexander Opitz <opitz.alexander@googlemail.com>
typo3/sysext/extbase/Classes/Utility/DebuggerUtility.php

index 05cc91f..e22585d 100644 (file)
@@ -101,7 +101,7 @@ class DebuggerUtility {
                        if ($plainText) {
                                $dump = self::ansiEscapeWrap(('"' . implode((PHP_EOL . str_repeat(self::PLAINTEXT_INDENT, ($level + 1))), str_split($croppedValue, 76)) . '"'), '33', $ansiColors) . ' (' . strlen($value) . ' chars)';
                        } else {
-                               $dump = sprintf('\'<span class="debug-string">%s</span>\' (%s chars)', implode('<br />' . str_repeat(self::HTML_INDENT, ($level + 1)), str_split(htmlspecialchars($croppedValue), 76)), strlen($value));
+                               $dump = sprintf('\'<span class="extbase-debug-string">%s</span>\' (%s chars)', implode('<br />' . str_repeat(self::HTML_INDENT, ($level + 1)), str_split(htmlspecialchars($croppedValue), 76)), strlen($value));
                        }
                } elseif (is_numeric($value)) {
                        $dump = sprintf('%s (%s)', self::ansiEscapeWrap($value, '35', $ansiColors), gettype($value));
@@ -133,23 +133,23 @@ class DebuggerUtility {
                if ($plainText) {
                        $header = self::ansiEscapeWrap('array', '36', $ansiColors);
                } else {
-                       $header = '<span class="debug-type">array</span>';
+                       $header = '<span class="extbase-debug-type">array</span>';
                }
                $header .= $count > 0 ? '(' . $count . ' item' . ($count > 1 ? 's' : '') . ')' : '(empty)';
                if ($level >= self::$maxDepth) {
                        if ($plainText) {
                                $header .= ' ' . self::ansiEscapeWrap('max depth', '47;30', $ansiColors);
                        } else {
-                               $header .= '<span class="debug-filtered">max depth</span>';
+                               $header .= '<span class="extbase-debug-filtered">max depth</span>';
                        }
                } else {
                        $content = self::renderCollection($array, $level, $plainText, $ansiColors);
                        if (!$plainText) {
-                               $header = ($level > 1 && $count > 0 ? '<input type="checkbox" /><span class="debug-header" >' : '<span>') . $header . '</span >';
+                               $header = ($level > 1 && $count > 0 ? '<input type="checkbox" /><span class="extbase-debug-header" >' : '<span>') . $header . '</span >';
                        }
                }
                if ($level > 1 && $count > 0 && !$plainText) {
-                       $dump = '<span class="debug-tree">' . $header . '<span class="debug-content">' . $content . '</span></span>';
+                       $dump = '<span class="extbase-debugger-tree">' . $header . '<span class="extbase-debug-content">' . $content . '</span></span>';
                } else {
                        $dump = $header . $content;
                }
@@ -178,7 +178,7 @@ class DebuggerUtility {
                if ($plainText) {
                        return $header . $content;
                } else {
-                       return '<span class="debug-tree">' . $header . '<span class="debug-content">' . $content . '</span></span>';
+                       return '<span class="extbase-debugger-tree">' . $header . '<span class="extbase-debug-content">' . $content . '</span></span>';
                }
        }
 
@@ -225,7 +225,7 @@ class DebuggerUtility {
                if ($plainText) {
                        $dump .= self::ansiEscapeWrap($className, '36', $ansiColors);
                } else {
-                       $dump .= '<span class="debug-type">' . $className . '</span>';
+                       $dump .= '<span class="extbase-debug-type">' . $className . '</span>';
                }
                if ($object instanceof \TYPO3\CMS\Core\SingletonInterface) {
                        $scope = 'singleton';
@@ -235,7 +235,7 @@ class DebuggerUtility {
                if ($plainText) {
                        $dump .= ' ' . self::ansiEscapeWrap($scope, '44;37', $ansiColors);
                } else {
-                       $dump .= $scope ? '<span class="debug-scope">' . $scope . '</span>' : '';
+                       $dump .= $scope ? '<span class="extbase-debug-scope">' . $scope . '</span>' : '';
                }
                if ($object instanceof \TYPO3\CMS\Extbase\DomainObject\AbstractDomainObject) {
                        if ($object->_isDirty()) {
@@ -259,27 +259,27 @@ class DebuggerUtility {
                if ($plainText) {
                        $dump .= ' ' . self::ansiEscapeWrap(($persistenceType . ' ' . $domainObjectType), '42;30', $ansiColors);
                } else {
-                       $dump .= '<span class="debug-ptype">' . ($persistenceType ? $persistenceType . ' ' : '') . $domainObjectType . '</span>';
+                       $dump .= '<span class="extbase-debug-ptype">' . ($persistenceType ? $persistenceType . ' ' : '') . $domainObjectType . '</span>';
                }
                if (strpos(implode('|', self::$blacklistedClassNames), get_class($object)) > 0) {
                        if ($plainText) {
                                $dump .= ' ' . self::ansiEscapeWrap('filtered', '47;30', $ansiColors);
                        } else {
-                               $dump .= '<span class="debug-filtered">filtered</span>';
+                               $dump .= '<span class="extbase-debug-filtered">filtered</span>';
                        }
                } elseif (self::$renderedObjects->contains($object) && !$plainText) {
-                       $dump = '<a href="javascript:;" onclick="document.location.hash=\'#' . spl_object_hash($object) . '\';" class="debug-seeabove">' . $dump . '<span class="debug-filtered">see above</span></a>';
+                       $dump = '<a href="javascript:;" onclick="document.location.hash=\'#' . spl_object_hash($object) . '\';" class="extbase-debug-seeabove">' . $dump . '<span class="extbase-debug-filtered">see above</span></a>';
                } elseif ($level >= self::$maxDepth && !$object instanceof \DateTime) {
                        if ($plainText) {
                                $dump .= ' ' . self::ansiEscapeWrap('max depth', '47;30', $ansiColors);
                        } else {
-                               $dump .= '<span class="debug-filtered">max depth</span>';
+                               $dump .= '<span class="extbase-debug-filtered">max depth</span>';
                        }
                } elseif ($level > 1 && !$object instanceof \DateTime && !$plainText) {
                        if (($object instanceof \Countable && empty($object)) || empty($classReflection->getProperties())) {
                                $dump = '<span>' . $dump . '</span>';
                        } else {
-                               $dump = '<input type="checkbox" id="' . spl_object_hash($object) . '" /><span class="debug-header">' . $dump . '</span>';
+                               $dump = '<input type="checkbox" id="' . spl_object_hash($object) . '" /><span class="extbase-debug-header">' . $dump . '</span>';
                        }
                }
                if ($object instanceof \Countable) {
@@ -322,14 +322,14 @@ class DebuggerUtility {
                                if (self::isBlacklisted($property)) {
                                        continue;
                                }
-                               $dump .= PHP_EOL . str_repeat(self::PLAINTEXT_INDENT, $level) . ($plainText ? '' : '<span class="debug-property">') . self::ansiEscapeWrap($property->getName(), '37', $ansiColors) . ($plainText ? '' : '</span>') . ' => ';
+                               $dump .= PHP_EOL . str_repeat(self::PLAINTEXT_INDENT, $level) . ($plainText ? '' : '<span class="extbase-debug-property">') . self::ansiEscapeWrap($property->getName(), '37', $ansiColors) . ($plainText ? '' : '</span>') . ' => ';
                                $property->setAccessible(TRUE);
                                $dump .= self::renderDump($property->getValue($object), $level, $plainText, $ansiColors);
                                if ($object instanceof \TYPO3\CMS\Extbase\DomainObject\AbstractDomainObject && !$object->_isNew() && $object->_isDirty($property->getName())) {
                                        if ($plainText) {
                                                $dump .= ' ' . self::ansiEscapeWrap('modified', '43;30', $ansiColors);
                                        } else {
-                                               $dump .= '<span class="debug-dirty">modified</span>';
+                                               $dump .= '<span class="extbase-debug-dirty">modified</span>';
                                        }
                                }
                        }
@@ -347,7 +347,7 @@ class DebuggerUtility {
        static protected function renderCollection($collection, $level, $plainText, $ansiColors) {
                $dump = '';
                foreach ($collection as $key => $value) {
-                       $dump .= PHP_EOL . str_repeat(self::PLAINTEXT_INDENT, $level) . ($plainText ? '' : '<span class="debug-property">') . self::ansiEscapeWrap($key, '37', $ansiColors) . ($plainText ? '' : '</span>') . ' => ';
+                       $dump .= PHP_EOL . str_repeat(self::PLAINTEXT_INDENT, $level) . ($plainText ? '' : '<span class="extbase-debug-property">') . self::ansiEscapeWrap($key, '37', $ansiColors) . ($plainText ? '' : '</span>') . ' => ';
                        $dump .= self::renderDump($value, $level, $plainText, $ansiColors);
                }
                if ($collection instanceof \Iterator) {
@@ -405,28 +405,28 @@ class DebuggerUtility {
                if (!$plainText && self::$stylesheetEchoed === FALSE) {
                        echo '
                                <style type=\'text/css\'>
-                                       .debug-tree{position:relative;}
-                                       .debug-tree input{position:absolute;top:0;left:0;cursor:pointer;opacity:0;z-index:2;}
-                                       .debug-tree input ~ .debug-content{display:none;}
-                                       .debug-tree .debug-header:before{content:"+";padding:0 2px 0 2px;margin:0 3px 0 3px;font-size:1em;font-weight:bold;color:#004fb0;border:1px #004fb0 solid;}
-                                       .debug-tree input:checked ~ .debug-content{display:inline;}
-                                       .debug-tree input:checked ~ .debug-header:before{content:"-";}
-                                       .Extbase-Utility-Debugger-VarDump{display:block;text-align:left;background:#b9b9b9;border:10px solid #b9b9b9;-moz-border-radius:10px;-webkit-border-radius:10px;border-radius:10px;-moz-box-shadow:0 0 20px #333;-webkit-box-shadow:0 0 20px #333;box-shadow:0 0 20px #333;z-index:999;color:#000;margin:20px 0 0;}
-                                       .Extbase-Utility-Debugger-VarDump-Floating{position:relative;width:96%;margin:40px auto;}
-                                       .Extbase-Utility-Debugger-VarDump-Top{background:#eee;font:normal bold 12px \'Lucida Grande\',sans-serif;padding:5px;}
-                                       .Extbase-Utility-Debugger-VarDump-Center{background:#b9b9b9 url() 0 18px repeat;font:normal normal 11px/18px Monospaced,\'Lucida Console\',monospace;padding:18px 10px;}
-                                       .Extbase-Utility-Debugger-VarDump-Center pre{background-color:transparent;margin:0;padding:0;}
-                                       .Extbase-Utility-Debugger-VarDump-Center,.Extbase-Utility-Debugger-VarDump-Center pre,.Extbase-Utility-Debugger-VarDump-Center p,.Extbase-Utility-Debugger-VarDump-Center a,.Extbase-Utility-Debugger-VarDump-Center strong,.Extbase-Utility-Debugger-VarDump-Center .debug-string{font:normal normal 11px/18px Monospaced,\'Lucida Console\',monospace;}
-                                       .Extbase-Utility-Debugger-VarDump-Center .debug-string{color:#000;white-space:normal;}
-                                       .Extbase-Utility-Debugger-VarDump-Center .debug-type{color:#004fb0;padding-right:4px;}
-                                       .Extbase-Utility-Debugger-VarDump-Center .debug-unregistered{background-color:#dce1e8;}
-                                       .Extbase-Utility-Debugger-VarDump-Center .debug-scope,.Extbase-Utility-Debugger-VarDump-Center .debug-ptype,.Extbase-Utility-Debugger-VarDump-Center .debug-proxy,.Extbase-Utility-Debugger-VarDump-Center .debug-filtered{color:#FFF;font-size:10px;line-height:16px;padding:1px 4px;margin-right:2px;}
-                                       .Extbase-Utility-Debugger-VarDump-Center .debug-scope{background-color:#3e7fe1;}
-                                       .Extbase-Utility-Debugger-VarDump-Center .debug-ptype{background-color:#6FBC16;}
-                                       .Extbase-Utility-Debugger-VarDump-Center .debug-dirty{background-color:#FFFF00;}
-                                       .Extbase-Utility-Debugger-VarDump-Center .debug-filtered{background-color:#8c8c8c;}
-                                       .Extbase-Utility-Debugger-VarDump-Center .debug-seeabove{text-decoration:none;font-style:italic;font-weight:400;}
-                                       .Extbase-Utility-Debugger-VarDump-Center .debug-property{color:#555;line-height:16px;padding:1px 2px;}
+                                       .extbase-debugger-tree{position:relative}
+                                       .extbase-debugger-tree input{position:absolute;top:0;left:0;height:14px;width:14px;margin:0;cursor:pointer;opacity:0;z-index:2}
+                                       .extbase-debugger-tree input~.extbase-debug-content{display:none}
+                                       .extbase-debugger-tree .extbase-debug-header:before{position:relative;top:3px;content:"";padding:0;line-height:10px;height:12px;width:12px;text-align:center;margin:0 3px 0 0;background-image:url();display:inline-block}
+                                       .extbase-debugger-tree input:checked~.extbase-debug-content{display:inline}
+                                       .extbase-debugger-tree input:checked~.extbase-debug-header:before{background-image:url()}
+                                       .extbase-debugger{display:block;text-align:left;background:#2a2a2a;border:1px solid #2a2a2a;box-shadow:0 3px 0 rgba(0,0,0,.5);color:#000;margin:20px;overflow:hidden;border-radius:4px}
+                                       .extbase-debugger-floating{position:relative;z-index:999}
+                                       .extbase-debugger-top{background:#444;font-size:12px;font-family:monospace;color:#f1f1f1;padding:6px 15px}
+                                       .extbase-debugger-center{padding:0 15px;margin:15px 0;background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 20px,#252525 20px,#252525 40px)}
+                                       .extbase-debugger-center,.extbase-debugger-center .extbase-debug-string,.extbase-debugger-center a,.extbase-debugger-center p,.extbase-debugger-center pre,.extbase-debugger-center strong{font-size:12px;font-weight:400;font-family:monospace;line-height:20px;color:#f1f1f1}
+                                       .extbase-debugger-center pre{background-color:transparent;margin:0;padding:0;border:0;word-wrap:break-word;color:#999}
+                                       .extbase-debugger-center .extbase-debug-string{color:#ce9178;white-space:normal}
+                                       .extbase-debugger-center .extbase-debug-type{color:#569CD6;padding-right:4px}
+                                       .extbase-debugger-center .extbase-debug-unregistered{background-color:#dce1e8}
+                                       .extbase-debugger-center .extbase-debug-filtered,.extbase-debugger-center .extbase-debug-proxy,.extbase-debugger-center .extbase-debug-ptype,.extbase-debugger-center .extbase-debug-scope{color:#fff;font-size:10px;line-height:12px;padding:2px 4px;margin-right:2px;position:relative;top:-1px}
+                                       .extbase-debugger-center .extbase-debug-scope{background-color:#497AA2}
+                                       .extbase-debugger-center .extbase-debug-ptype{background-color:#698747}
+                                       .extbase-debugger-center .extbase-debug-dirty{background-color:#FFFFB6}
+                                       .extbase-debugger-center .extbase-debug-filtered{background-color:#4F4F4F}
+                                       .extbase-debugger-center .extbase-debug-seeabove{text-decoration:none;font-style:italic}
+                                       .extbase-debugger-center .extbase-debug-property{color:#f1f1f1}
                                </style>';
                        self::$stylesheetEchoed = TRUE;
                }
@@ -434,9 +434,9 @@ class DebuggerUtility {
                        $output = $title . PHP_EOL . self::renderDump($variable, 0, TRUE, $ansiColors) . PHP_EOL . PHP_EOL;
                } else {
                        $output = '
-                               <div class="Extbase-Utility-Debugger-VarDump ' . ($return ? 'Extbase-Utility-Debugger-VarDump-Inline' : 'Extbase-Utility-Debugger-VarDump-Floating') . '">
-                               <div class="Extbase-Utility-Debugger-VarDump-Top">' . htmlspecialchars($title) . '</div>
-                               <div class="Extbase-Utility-Debugger-VarDump-Center">
+                               <div class="extbase-debugger ' . ($return ? 'extbase-debugger-inline' : 'extbase-debugger-floating') . '">
+                               <div class="extbase-debugger-top">' . htmlspecialchars($title) . '</div>
+                               <div class="extbase-debugger-center">
                                        <pre dir="ltr">' . self::renderDump($variable, 0, FALSE, FALSE) . '</pre>
                                </div>
                        </div>