mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
MINOR Added sapphire/thirdparty/firebug-lite
git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@92496 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
parent
75d3815d29
commit
f811d9dfd5
8
thirdparty/firebug-lite/.piston.yml
vendored
Normal file
8
thirdparty/firebug-lite/.piston.yml
vendored
Normal file
@ -0,0 +1,8 @@
|
||||
---
|
||||
format: 1
|
||||
handler:
|
||||
piston:remote-revision: 3859
|
||||
piston:uuid: e969d3be-0e28-0410-a27f-dd5c76401a8b
|
||||
lock: false
|
||||
repository_url: http://fbug.googlecode.com/svn/branches/firebug1.2/lite/
|
||||
repository_class: Piston::Svn::Repository
|
BIN
thirdparty/firebug-lite/errorIcon.png
vendored
Normal file
BIN
thirdparty/firebug-lite/errorIcon.png
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 457 B |
209
thirdparty/firebug-lite/firebug.css
vendored
Normal file
209
thirdparty/firebug-lite/firebug.css
vendored
Normal file
@ -0,0 +1,209 @@
|
||||
|
||||
html, body {
|
||||
margin: 0;
|
||||
background: #FFFFFF;
|
||||
font-family: Lucida Grande, Tahoma, sans-serif;
|
||||
font-size: 11px;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
a {
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
a:hover {
|
||||
text-decoration: underline;
|
||||
}
|
||||
|
||||
.toolbar {
|
||||
height: 14px;
|
||||
border-top: 1px solid ThreeDHighlight;
|
||||
border-bottom: 1px solid ThreeDShadow;
|
||||
padding: 2px 6px;
|
||||
background: ThreeDFace;
|
||||
}
|
||||
|
||||
.toolbarRight {
|
||||
position: absolute;
|
||||
top: 4px;
|
||||
right: 6px;
|
||||
}
|
||||
|
||||
#log {
|
||||
overflow: auto;
|
||||
position: absolute;
|
||||
left: 0;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
#commandLine {
|
||||
position: absolute;
|
||||
bottom: 0;
|
||||
left: 0;
|
||||
width: 100%;
|
||||
height: 18px;
|
||||
border: none;
|
||||
border-top: 1px solid ThreeDShadow;
|
||||
}
|
||||
|
||||
/************************************************************************************************/
|
||||
|
||||
.logRow {
|
||||
position: relative;
|
||||
border-bottom: 1px solid #D7D7D7;
|
||||
padding: 2px 4px 1px 6px;
|
||||
background-color: #FFFFFF;
|
||||
}
|
||||
|
||||
.logRow-command {
|
||||
font-family: Monaco, monospace;
|
||||
color: blue;
|
||||
}
|
||||
|
||||
.objectBox-null {
|
||||
padding: 0 2px;
|
||||
border: 1px solid #666666;
|
||||
background-color: #888888;
|
||||
color: #FFFFFF;
|
||||
}
|
||||
|
||||
.objectBox-string {
|
||||
font-family: Monaco, monospace;
|
||||
color: red;
|
||||
white-space: pre;
|
||||
}
|
||||
|
||||
.objectBox-number {
|
||||
color: #000088;
|
||||
}
|
||||
|
||||
.objectBox-function {
|
||||
font-family: Monaco, monospace;
|
||||
color: DarkGreen;
|
||||
}
|
||||
|
||||
.objectBox-object {
|
||||
color: DarkGreen;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
/************************************************************************************************/
|
||||
|
||||
.logRow-info,
|
||||
.logRow-error,
|
||||
.logRow-warning {
|
||||
background: #FFFFFF no-repeat 2px 2px;
|
||||
padding-left: 20px;
|
||||
padding-bottom: 3px;
|
||||
}
|
||||
|
||||
.logRow-info {
|
||||
background-image: url(infoIcon.png);
|
||||
}
|
||||
|
||||
.logRow-warning {
|
||||
background-color: cyan;
|
||||
background-image: url(warningIcon.png);
|
||||
}
|
||||
|
||||
.logRow-error {
|
||||
background-color: LightYellow;
|
||||
background-image: url(errorIcon.png);
|
||||
}
|
||||
|
||||
.errorMessage {
|
||||
vertical-align: top;
|
||||
color: #FF0000;
|
||||
}
|
||||
|
||||
.objectBox-sourceLink {
|
||||
position: absolute;
|
||||
right: 4px;
|
||||
top: 2px;
|
||||
padding-left: 8px;
|
||||
font-family: Lucida Grande, sans-serif;
|
||||
font-weight: bold;
|
||||
color: #0000FF;
|
||||
}
|
||||
|
||||
/************************************************************************************************/
|
||||
|
||||
.logRow-group {
|
||||
background: #EEEEEE;
|
||||
border-bottom: none;
|
||||
}
|
||||
|
||||
.logGroup {
|
||||
background: #EEEEEE;
|
||||
}
|
||||
|
||||
.logGroupBox {
|
||||
margin-left: 24px;
|
||||
border-top: 1px solid #D7D7D7;
|
||||
border-left: 1px solid #D7D7D7;
|
||||
}
|
||||
|
||||
/************************************************************************************************/
|
||||
|
||||
.selectorTag,
|
||||
.selectorId,
|
||||
.selectorClass {
|
||||
font-family: Monaco, monospace;
|
||||
font-weight: normal;
|
||||
}
|
||||
|
||||
.selectorTag {
|
||||
color: #0000FF;
|
||||
}
|
||||
|
||||
.selectorId {
|
||||
color: DarkBlue;
|
||||
}
|
||||
|
||||
.selectorClass {
|
||||
color: red;
|
||||
}
|
||||
|
||||
/************************************************************************************************/
|
||||
|
||||
.objectBox-element {
|
||||
font-family: Monaco, monospace;
|
||||
color: #000088;
|
||||
}
|
||||
|
||||
.nodeChildren {
|
||||
margin-left: 16px;
|
||||
}
|
||||
|
||||
.nodeTag {
|
||||
color: blue;
|
||||
}
|
||||
|
||||
.nodeValue {
|
||||
color: #FF0000;
|
||||
font-weight: normal;
|
||||
}
|
||||
|
||||
.nodeText,
|
||||
.nodeComment {
|
||||
margin: 0 2px;
|
||||
vertical-align: top;
|
||||
}
|
||||
|
||||
.nodeText {
|
||||
color: #333333;
|
||||
}
|
||||
|
||||
.nodeComment {
|
||||
color: DarkGreen;
|
||||
}
|
||||
|
||||
/************************************************************************************************/
|
||||
|
||||
.propertyNameCell {
|
||||
vertical-align: top;
|
||||
}
|
||||
|
||||
.propertyName {
|
||||
font-weight: bold;
|
||||
}
|
23
thirdparty/firebug-lite/firebug.html
vendored
Normal file
23
thirdparty/firebug-lite/firebug.html
vendored
Normal file
@ -0,0 +1,23 @@
|
||||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
|
||||
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
|
||||
|
||||
<html xmlns="http://www.w3.org/1999/xhtml">
|
||||
|
||||
<head>
|
||||
<title>Firebug</title>
|
||||
<link rel="stylesheet" type="text/css" href="firebug.css">
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div id="toolbar" class="toolbar">
|
||||
<a href="#" onclick="parent.console.clear()">Clear</a>
|
||||
<span class="toolbarRight">
|
||||
<a href="#" onclick="parent.console.close()">Close</a>
|
||||
</span>
|
||||
</div>
|
||||
<div id="log"></div>
|
||||
<input type="text" id="commandLine">
|
||||
|
||||
<script>parent.onFirebugReady(document);</script>
|
||||
</body>
|
||||
</html>
|
672
thirdparty/firebug-lite/firebug.js
vendored
Normal file
672
thirdparty/firebug-lite/firebug.js
vendored
Normal file
@ -0,0 +1,672 @@
|
||||
|
||||
if (!window.console || !console.firebug) {
|
||||
(function()
|
||||
{
|
||||
window.console =
|
||||
{
|
||||
log: function()
|
||||
{
|
||||
logFormatted(arguments, "");
|
||||
},
|
||||
|
||||
debug: function()
|
||||
{
|
||||
logFormatted(arguments, "debug");
|
||||
},
|
||||
|
||||
info: function()
|
||||
{
|
||||
logFormatted(arguments, "info");
|
||||
},
|
||||
|
||||
warn: function()
|
||||
{
|
||||
logFormatted(arguments, "warning");
|
||||
},
|
||||
|
||||
error: function()
|
||||
{
|
||||
logFormatted(arguments, "error");
|
||||
},
|
||||
|
||||
assert: function(truth, message)
|
||||
{
|
||||
if (!truth)
|
||||
{
|
||||
var args = [];
|
||||
for (var i = 1; i < arguments.length; ++i)
|
||||
args.push(arguments[i]);
|
||||
|
||||
logFormatted(args.length ? args : ["Assertion Failure"], "error");
|
||||
throw message ? message : "Assertion Failure";
|
||||
}
|
||||
},
|
||||
|
||||
dir: function(object)
|
||||
{
|
||||
var html = [];
|
||||
|
||||
var pairs = [];
|
||||
for (var name in object)
|
||||
{
|
||||
try
|
||||
{
|
||||
pairs.push([name, object[name]]);
|
||||
}
|
||||
catch (exc)
|
||||
{
|
||||
}
|
||||
}
|
||||
|
||||
pairs.sort(function(a, b) { return a[0] < b[0] ? -1 : 1; });
|
||||
|
||||
html.push('<table>');
|
||||
for (var i = 0; i < pairs.length; ++i)
|
||||
{
|
||||
var name = pairs[i][0], value = pairs[i][1];
|
||||
|
||||
html.push('<tr>',
|
||||
'<td class="propertyNameCell"><span class="propertyName">',
|
||||
escapeHTML(name), '</span></td>', '<td><span class="propertyValue">');
|
||||
appendObject(value, html);
|
||||
html.push('</span></td></tr>');
|
||||
}
|
||||
html.push('</table>');
|
||||
|
||||
logRow(html, "dir");
|
||||
},
|
||||
|
||||
dirxml: function(node)
|
||||
{
|
||||
var html = [];
|
||||
|
||||
appendNode(node, html);
|
||||
logRow(html, "dirxml");
|
||||
},
|
||||
|
||||
group: function()
|
||||
{
|
||||
logRow(arguments, "group", pushGroup);
|
||||
},
|
||||
|
||||
groupEnd: function()
|
||||
{
|
||||
logRow(arguments, "", popGroup);
|
||||
},
|
||||
|
||||
time: function(name)
|
||||
{
|
||||
timeMap[name] = (new Date()).getTime();
|
||||
},
|
||||
|
||||
timeEnd: function(name)
|
||||
{
|
||||
if (name in timeMap)
|
||||
{
|
||||
var delta = (new Date()).getTime() - timeMap[name];
|
||||
logFormatted([name+ ":", delta+"ms"]);
|
||||
delete timeMap[name];
|
||||
}
|
||||
},
|
||||
|
||||
count: function()
|
||||
{
|
||||
this.warn(["count() not supported."]);
|
||||
},
|
||||
|
||||
trace: function()
|
||||
{
|
||||
this.warn(["trace() not supported."]);
|
||||
},
|
||||
|
||||
profile: function()
|
||||
{
|
||||
this.warn(["profile() not supported."]);
|
||||
},
|
||||
|
||||
profileEnd: function()
|
||||
{
|
||||
},
|
||||
|
||||
clear: function()
|
||||
{
|
||||
consoleBody.innerHTML = "";
|
||||
},
|
||||
|
||||
open: function()
|
||||
{
|
||||
toggleConsole(true);
|
||||
},
|
||||
|
||||
close: function()
|
||||
{
|
||||
if (frameVisible)
|
||||
toggleConsole();
|
||||
}
|
||||
};
|
||||
|
||||
// ********************************************************************************************
|
||||
|
||||
var consoleFrame = null;
|
||||
var consoleBody = null;
|
||||
var commandLine = null;
|
||||
|
||||
var frameVisible = false;
|
||||
var messageQueue = [];
|
||||
var groupStack = [];
|
||||
var timeMap = {};
|
||||
|
||||
var clPrefix = ">>> ";
|
||||
|
||||
var isFirefox = navigator.userAgent.indexOf("Firefox") != -1;
|
||||
var isIE = navigator.userAgent.indexOf("MSIE") != -1;
|
||||
var isOpera = navigator.userAgent.indexOf("Opera") != -1;
|
||||
var isSafari = navigator.userAgent.indexOf("AppleWebKit") != -1;
|
||||
|
||||
// ********************************************************************************************
|
||||
|
||||
function toggleConsole(forceOpen)
|
||||
{
|
||||
frameVisible = forceOpen || !frameVisible;
|
||||
if (consoleFrame)
|
||||
consoleFrame.style.visibility = frameVisible ? "visible" : "hidden";
|
||||
else
|
||||
waitForBody();
|
||||
}
|
||||
|
||||
function focusCommandLine()
|
||||
{
|
||||
toggleConsole(true);
|
||||
if (commandLine)
|
||||
commandLine.focus();
|
||||
}
|
||||
|
||||
function waitForBody()
|
||||
{
|
||||
if (document.body)
|
||||
createFrame();
|
||||
else
|
||||
setTimeout(waitForBody, 200);
|
||||
}
|
||||
|
||||
function createFrame()
|
||||
{
|
||||
if (consoleFrame)
|
||||
return;
|
||||
|
||||
window.onFirebugReady = function(doc)
|
||||
{
|
||||
window.onFirebugReady = null;
|
||||
|
||||
var toolbar = doc.getElementById("toolbar");
|
||||
toolbar.onmousedown = onSplitterMouseDown;
|
||||
|
||||
commandLine = doc.getElementById("commandLine");
|
||||
addEvent(commandLine, "keydown", onCommandLineKeyDown);
|
||||
|
||||
addEvent(doc, isIE || isSafari ? "keydown" : "keypress", onKeyDown);
|
||||
|
||||
consoleBody = doc.getElementById("log");
|
||||
layout();
|
||||
flush();
|
||||
}
|
||||
|
||||
var baseURL = getFirebugURL();
|
||||
|
||||
consoleFrame = document.createElement("iframe");
|
||||
consoleFrame.setAttribute("src", baseURL+"/firebug.html");
|
||||
consoleFrame.setAttribute("frameBorder", "0");
|
||||
consoleFrame.style.visibility = (frameVisible ? "visible" : "hidden");
|
||||
consoleFrame.style.zIndex = "2147483583";
|
||||
consoleFrame.style.position = document.all ? "absolute" : "fixed";
|
||||
consoleFrame.style.width = "100%";
|
||||
consoleFrame.style.left = "0";
|
||||
consoleFrame.style.bottom = "0";
|
||||
consoleFrame.style.height = "200px";
|
||||
document.body.appendChild(consoleFrame);
|
||||
}
|
||||
|
||||
function getFirebugURL()
|
||||
{
|
||||
var scripts = document.getElementsByTagName("script");
|
||||
for (var i = 0; i < scripts.length; ++i)
|
||||
{
|
||||
if (scripts[i].src.indexOf("firebug.js") != -1)
|
||||
{
|
||||
var lastSlash = scripts[i].src.lastIndexOf("/");
|
||||
return scripts[i].src.substr(0, lastSlash);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function evalCommandLine()
|
||||
{
|
||||
var text = commandLine.value;
|
||||
commandLine.value = "";
|
||||
|
||||
logRow([clPrefix, text], "command");
|
||||
|
||||
var value;
|
||||
try
|
||||
{
|
||||
value = eval(text);
|
||||
}
|
||||
catch (exc)
|
||||
{
|
||||
}
|
||||
|
||||
console.log(value);
|
||||
}
|
||||
|
||||
function layout()
|
||||
{
|
||||
var toolbar = consoleBody.ownerDocument.getElementById("toolbar");
|
||||
var height = consoleFrame.offsetHeight - (toolbar.offsetHeight + commandLine.offsetHeight);
|
||||
consoleBody.style.top = toolbar.offsetHeight + "px";
|
||||
consoleBody.style.height = height + "px";
|
||||
|
||||
commandLine.style.top = (consoleFrame.offsetHeight - commandLine.offsetHeight) + "px";
|
||||
}
|
||||
|
||||
function logRow(message, className, handler)
|
||||
{
|
||||
if (consoleBody)
|
||||
writeMessage(message, className, handler);
|
||||
else
|
||||
{
|
||||
messageQueue.push([message, className, handler]);
|
||||
waitForBody();
|
||||
}
|
||||
}
|
||||
|
||||
function flush()
|
||||
{
|
||||
var queue = messageQueue;
|
||||
messageQueue = [];
|
||||
|
||||
for (var i = 0; i < queue.length; ++i)
|
||||
writeMessage(queue[i][0], queue[i][1], queue[i][2]);
|
||||
}
|
||||
|
||||
function writeMessage(message, className, handler)
|
||||
{
|
||||
var isScrolledToBottom =
|
||||
consoleBody.scrollTop + consoleBody.offsetHeight >= consoleBody.scrollHeight;
|
||||
|
||||
if (!handler)
|
||||
handler = writeRow;
|
||||
|
||||
handler(message, className);
|
||||
|
||||
if (isScrolledToBottom)
|
||||
consoleBody.scrollTop = consoleBody.scrollHeight - consoleBody.offsetHeight;
|
||||
}
|
||||
|
||||
function appendRow(row)
|
||||
{
|
||||
var container = groupStack.length ? groupStack[groupStack.length-1] : consoleBody;
|
||||
container.appendChild(row);
|
||||
}
|
||||
|
||||
function writeRow(message, className)
|
||||
{
|
||||
var row = consoleBody.ownerDocument.createElement("div");
|
||||
row.className = "logRow" + (className ? " logRow-"+className : "");
|
||||
row.innerHTML = message.join("");
|
||||
appendRow(row);
|
||||
}
|
||||
|
||||
function pushGroup(message, className)
|
||||
{
|
||||
logFormatted(message, className);
|
||||
|
||||
var groupRow = consoleBody.ownerDocument.createElement("div");
|
||||
groupRow.className = "logGroup";
|
||||
var groupRowBox = consoleBody.ownerDocument.createElement("div");
|
||||
groupRowBox.className = "logGroupBox";
|
||||
groupRow.appendChild(groupRowBox);
|
||||
appendRow(groupRowBox);
|
||||
groupStack.push(groupRowBox);
|
||||
}
|
||||
|
||||
function popGroup()
|
||||
{
|
||||
groupStack.pop();
|
||||
}
|
||||
|
||||
// ********************************************************************************************
|
||||
|
||||
function logFormatted(objects, className)
|
||||
{
|
||||
var html = [];
|
||||
|
||||
var format = objects[0];
|
||||
var objIndex = 0;
|
||||
|
||||
if (typeof(format) != "string")
|
||||
{
|
||||
format = "";
|
||||
objIndex = -1;
|
||||
}
|
||||
|
||||
var parts = parseFormat(format);
|
||||
for (var i = 0; i < parts.length; ++i)
|
||||
{
|
||||
var part = parts[i];
|
||||
if (part && typeof(part) == "object")
|
||||
{
|
||||
var object = objects[++objIndex];
|
||||
part.appender(object, html);
|
||||
}
|
||||
else
|
||||
appendText(part, html);
|
||||
}
|
||||
|
||||
for (var i = objIndex+1; i < objects.length; ++i)
|
||||
{
|
||||
appendText(" ", html);
|
||||
|
||||
var object = objects[i];
|
||||
if (typeof(object) == "string")
|
||||
appendText(object, html);
|
||||
else
|
||||
appendObject(object, html);
|
||||
}
|
||||
|
||||
logRow(html, className);
|
||||
}
|
||||
|
||||
function parseFormat(format)
|
||||
{
|
||||
var parts = [];
|
||||
|
||||
var reg = /((^%|[^\\]%)(\d+)?(\.)([a-zA-Z]))|((^%|[^\\]%)([a-zA-Z]))/;
|
||||
var appenderMap = {s: appendText, d: appendInteger, i: appendInteger, f: appendFloat};
|
||||
|
||||
for (var m = reg.exec(format); m; m = reg.exec(format))
|
||||
{
|
||||
var type = m[8] ? m[8] : m[5];
|
||||
var appender = type in appenderMap ? appenderMap[type] : appendObject;
|
||||
var precision = m[3] ? parseInt(m[3]) : (m[4] == "." ? -1 : 0);
|
||||
|
||||
parts.push(format.substr(0, m[0][0] == "%" ? m.index : m.index+1));
|
||||
parts.push({appender: appender, precision: precision});
|
||||
|
||||
format = format.substr(m.index+m[0].length);
|
||||
}
|
||||
|
||||
parts.push(format);
|
||||
|
||||
return parts;
|
||||
}
|
||||
|
||||
function escapeHTML(value)
|
||||
{
|
||||
function replaceChars(ch)
|
||||
{
|
||||
switch (ch)
|
||||
{
|
||||
case "<":
|
||||
return "<";
|
||||
case ">":
|
||||
return ">";
|
||||
case "&":
|
||||
return "&";
|
||||
case "'":
|
||||
return "'";
|
||||
case '"':
|
||||
return """;
|
||||
}
|
||||
return "?";
|
||||
};
|
||||
return String(value).replace(/[<>&"']/g, replaceChars);
|
||||
}
|
||||
|
||||
function objectToString(object)
|
||||
{
|
||||
try
|
||||
{
|
||||
return object+"";
|
||||
}
|
||||
catch (exc)
|
||||
{
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
// ********************************************************************************************
|
||||
|
||||
function appendText(object, html)
|
||||
{
|
||||
html.push(escapeHTML(objectToString(object)));
|
||||
}
|
||||
|
||||
function appendNull(object, html)
|
||||
{
|
||||
html.push('<span class="objectBox-null">', escapeHTML(objectToString(object)), '</span>');
|
||||
}
|
||||
|
||||
function appendString(object, html)
|
||||
{
|
||||
html.push('<span class="objectBox-string">"', escapeHTML(objectToString(object)),
|
||||
'"</span>');
|
||||
}
|
||||
|
||||
function appendInteger(object, html)
|
||||
{
|
||||
html.push('<span class="objectBox-number">', escapeHTML(objectToString(object)), '</span>');
|
||||
}
|
||||
|
||||
function appendFloat(object, html)
|
||||
{
|
||||
html.push('<span class="objectBox-number">', escapeHTML(objectToString(object)), '</span>');
|
||||
}
|
||||
|
||||
function appendFunction(object, html)
|
||||
{
|
||||
var reName = /function ?(.*?)\(/;
|
||||
var m = reName.exec(objectToString(object));
|
||||
var name = m ? m[1] : "function";
|
||||
html.push('<span class="objectBox-function">', escapeHTML(name), '()</span>');
|
||||
}
|
||||
|
||||
function appendObject(object, html)
|
||||
{
|
||||
try
|
||||
{
|
||||
if (object == undefined)
|
||||
appendNull("undefined", html);
|
||||
else if (object == null)
|
||||
appendNull("null", html);
|
||||
else if (typeof object == "string")
|
||||
appendString(object, html);
|
||||
else if (typeof object == "number")
|
||||
appendInteger(object, html);
|
||||
else if (typeof object == "function")
|
||||
appendFunction(object, html);
|
||||
else if (object.nodeType == 1)
|
||||
appendSelector(object, html);
|
||||
else if (typeof object == "object")
|
||||
appendObjectFormatted(object, html);
|
||||
else
|
||||
appendText(object, html);
|
||||
}
|
||||
catch (exc)
|
||||
{
|
||||
}
|
||||
}
|
||||
|
||||
function appendObjectFormatted(object, html)
|
||||
{
|
||||
var text = objectToString(object);
|
||||
var reObject = /\[object (.*?)\]/;
|
||||
|
||||
var m = reObject.exec(text);
|
||||
html.push('<span class="objectBox-object">', m ? m[1] : text, '</span>')
|
||||
}
|
||||
|
||||
function appendSelector(object, html)
|
||||
{
|
||||
html.push('<span class="objectBox-selector">');
|
||||
|
||||
html.push('<span class="selectorTag">', escapeHTML(object.nodeName.toLowerCase()), '</span>');
|
||||
if (object.id)
|
||||
html.push('<span class="selectorId">#', escapeHTML(object.id), '</span>');
|
||||
if (object.className)
|
||||
html.push('<span class="selectorClass">.', escapeHTML(object.className), '</span>');
|
||||
|
||||
html.push('</span>');
|
||||
}
|
||||
|
||||
function appendNode(node, html)
|
||||
{
|
||||
if (node.nodeType == 1)
|
||||
{
|
||||
html.push(
|
||||
'<div class="objectBox-element">',
|
||||
'<<span class="nodeTag">', node.nodeName.toLowerCase(), '</span>');
|
||||
|
||||
for (var i = 0; i < node.attributes.length; ++i)
|
||||
{
|
||||
var attr = node.attributes[i];
|
||||
if (!attr.specified)
|
||||
continue;
|
||||
|
||||
html.push(' <span class="nodeName">', attr.nodeName.toLowerCase(),
|
||||
'</span>="<span class="nodeValue">', escapeHTML(attr.nodeValue),
|
||||
'</span>"')
|
||||
}
|
||||
|
||||
if (node.firstChild)
|
||||
{
|
||||
html.push('></div><div class="nodeChildren">');
|
||||
|
||||
for (var child = node.firstChild; child; child = child.nextSibling)
|
||||
appendNode(child, html);
|
||||
|
||||
html.push('</div><div class="objectBox-element"></<span class="nodeTag">',
|
||||
node.nodeName.toLowerCase(), '></span></div>');
|
||||
}
|
||||
else
|
||||
html.push('/></div>');
|
||||
}
|
||||
else if (node.nodeType == 3)
|
||||
{
|
||||
html.push('<div class="nodeText">', escapeHTML(node.nodeValue),
|
||||
'</div>');
|
||||
}
|
||||
}
|
||||
|
||||
// ********************************************************************************************
|
||||
|
||||
function addEvent(object, name, handler)
|
||||
{
|
||||
if (document.all)
|
||||
object.attachEvent("on"+name, handler);
|
||||
else
|
||||
object.addEventListener(name, handler, false);
|
||||
}
|
||||
|
||||
function removeEvent(object, name, handler)
|
||||
{
|
||||
if (document.all)
|
||||
object.detachEvent("on"+name, handler);
|
||||
else
|
||||
object.removeEventListener(name, handler, false);
|
||||
}
|
||||
|
||||
function cancelEvent(event)
|
||||
{
|
||||
if (document.all)
|
||||
event.cancelBubble = true;
|
||||
else
|
||||
event.stopPropagation();
|
||||
}
|
||||
|
||||
function onError(msg, href, lineNo)
|
||||
{
|
||||
var html = [];
|
||||
|
||||
var lastSlash = href.lastIndexOf("/");
|
||||
var fileName = lastSlash == -1 ? href : href.substr(lastSlash+1);
|
||||
|
||||
html.push(
|
||||
'<span class="errorMessage">', msg, '</span>',
|
||||
'<div class="objectBox-sourceLink">', fileName, ' (line ', lineNo, ')</div>'
|
||||
);
|
||||
|
||||
logRow(html, "error");
|
||||
};
|
||||
|
||||
function onKeyDown(event)
|
||||
{
|
||||
if (event.keyCode == 123)
|
||||
toggleConsole();
|
||||
else if ((event.keyCode == 108 || event.keyCode == 76) && event.shiftKey
|
||||
&& (event.metaKey || event.ctrlKey))
|
||||
focusCommandLine();
|
||||
else
|
||||
return;
|
||||
|
||||
cancelEvent(event);
|
||||
}
|
||||
|
||||
function onSplitterMouseDown(event)
|
||||
{
|
||||
if (isSafari || isOpera)
|
||||
return;
|
||||
|
||||
addEvent(document, "mousemove", onSplitterMouseMove);
|
||||
addEvent(document, "mouseup", onSplitterMouseUp);
|
||||
|
||||
for (var i = 0; i < frames.length; ++i)
|
||||
{
|
||||
addEvent(frames[i].document, "mousemove", onSplitterMouseMove);
|
||||
addEvent(frames[i].document, "mouseup", onSplitterMouseUp);
|
||||
}
|
||||
}
|
||||
|
||||
function onSplitterMouseMove(event)
|
||||
{
|
||||
var win = document.all
|
||||
? event.srcElement.ownerDocument.parentWindow
|
||||
: event.target.ownerDocument.defaultView;
|
||||
|
||||
var clientY = event.clientY;
|
||||
if (win != win.parent)
|
||||
clientY += win.frameElement ? win.frameElement.offsetTop : 0;
|
||||
|
||||
var height = consoleFrame.offsetTop + consoleFrame.clientHeight;
|
||||
var y = height - clientY;
|
||||
|
||||
consoleFrame.style.height = y + "px";
|
||||
layout();
|
||||
}
|
||||
|
||||
function onSplitterMouseUp(event)
|
||||
{
|
||||
removeEvent(document, "mousemove", onSplitterMouseMove);
|
||||
removeEvent(document, "mouseup", onSplitterMouseUp);
|
||||
|
||||
for (var i = 0; i < frames.length; ++i)
|
||||
{
|
||||
removeEvent(frames[i].document, "mousemove", onSplitterMouseMove);
|
||||
removeEvent(frames[i].document, "mouseup", onSplitterMouseUp);
|
||||
}
|
||||
}
|
||||
|
||||
function onCommandLineKeyDown(event)
|
||||
{
|
||||
if (event.keyCode == 13)
|
||||
evalCommandLine();
|
||||
else if (event.keyCode == 27)
|
||||
commandLine.value = "";
|
||||
}
|
||||
|
||||
window.onerror = onError;
|
||||
addEvent(document, isIE || isSafari ? "keydown" : "keypress", onKeyDown);
|
||||
|
||||
if (document.documentElement.getAttribute("debug") == "true")
|
||||
toggleConsole(true);
|
||||
})();
|
||||
}
|
10
thirdparty/firebug-lite/firebugx.js
vendored
Normal file
10
thirdparty/firebug-lite/firebugx.js
vendored
Normal file
@ -0,0 +1,10 @@
|
||||
|
||||
if (!window.console || !console.firebug)
|
||||
{
|
||||
var names = ["log", "debug", "info", "warn", "error", "assert", "dir", "dirxml",
|
||||
"group", "groupEnd", "time", "timeEnd", "count", "trace", "profile", "profileEnd"];
|
||||
|
||||
window.console = {};
|
||||
for (var i = 0; i < names.length; ++i)
|
||||
window.console[names[i]] = function() {}
|
||||
}
|
BIN
thirdparty/firebug-lite/infoIcon.png
vendored
Normal file
BIN
thirdparty/firebug-lite/infoIcon.png
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 524 B |
BIN
thirdparty/firebug-lite/warningIcon.png
vendored
Normal file
BIN
thirdparty/firebug-lite/warningIcon.png
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 516 B |
Loading…
x
Reference in New Issue
Block a user