Merge branch 'develop' of http://git.general-servers.com/expomap/expomap
@ -1,649 +0,0 @@ |
||||
/* http://www.positioniseverything.net/easyclearing.html */ |
||||
#djDebug .clearfix:after { |
||||
content: "."; |
||||
display: block; |
||||
height: 0; |
||||
clear: both; |
||||
visibility: hidden; |
||||
} |
||||
#djDebug .clearfix {display: inline-block;} |
||||
/* Hides from IE-mac \*/ |
||||
#djDebug .clearfix {display: block;} |
||||
* html #djDebug .clearfix {height: 1%;} |
||||
/* end hide from IE-mac */ |
||||
|
||||
/* Debug Toolbar CSS Reset, adapted from Eric Meyer's CSS Reset */ |
||||
#djDebug {color:#000;background:#FFF;} |
||||
#djDebug, #djDebug div, #djDebug span, #djDebug applet, #djDebug object, #djDebug iframe, |
||||
#djDebug h1, #djDebug h2, #djDebug h3, #djDebug h4, #djDebug h5, #djDebug h6, #djDebug p, #djDebug blockquote, #djDebug pre, |
||||
#djDebug a, #djDebug abbr, #djDebug acronym, #djDebug address, #djDebug big, #djDebug cite, #djDebug code, |
||||
#djDebug del, #djDebug dfn, #djDebug em, #djDebug font, #djDebug img, #djDebug ins, #djDebug kbd, #djDebug q, #djDebug s, #djDebug samp, |
||||
#djDebug small, #djDebug strike, #djDebug strong, #djDebug sub, #djDebug sup, #djDebug tt, #djDebug var, |
||||
#djDebug b, #djDebug u, #djDebug i, #djDebug center, |
||||
#djDebug dl, #djDebug dt, #djDebug dd, #djDebug ol, #djDebug ul, #djDebug li, |
||||
#djDebug fieldset, #djDebug form, #djDebug label, #djDebug legend, |
||||
#djDebug table, #djDebug caption, #djDebug tbody, #djDebug tfoot, #djDebug thead, #djDebug tr, #djDebug th, #djDebug td, |
||||
#djDebug button { |
||||
margin:0; |
||||
padding:0; |
||||
min-width:0; |
||||
width:auto; |
||||
border:0; |
||||
outline:0; |
||||
font-size:12px; |
||||
line-height:1.5em; |
||||
color:#000; |
||||
vertical-align:baseline; |
||||
background-color:transparent; |
||||
font-family:sans-serif; |
||||
text-align:left; |
||||
text-shadow: none; |
||||
-webkit-transition: none; |
||||
-moz-transition: none; |
||||
-o-transition: none; |
||||
transition: none; |
||||
} |
||||
|
||||
#djDebug button { |
||||
background-color: #eee; |
||||
background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #eee), color-stop(100%, #cccccc)); |
||||
background-image: -webkit-linear-gradient(top, #eee, #cccccc); |
||||
background-image: -moz-linear-gradient(top, #eee, #cccccc); |
||||
background-image: -ms-linear-gradient(top, #eee, #cccccc); |
||||
background-image: -o-linear-gradient(top, #eee, #cccccc); |
||||
background-image: linear-gradient(top, #eee, #cccccc); |
||||
border: 1px solid #ccc; |
||||
border-bottom: 1px solid #bbb; |
||||
-webkit-border-radius: 3px; |
||||
-moz-border-radius: 3px; |
||||
border-radius: 3px; |
||||
color: #333; |
||||
line-height: 1; |
||||
padding: 0 8px; |
||||
text-align: center; |
||||
text-shadow: 0 1px 0 #eee; |
||||
} |
||||
|
||||
#djDebug button:hover { |
||||
background-color: #ddd; |
||||
background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #ddd), color-stop(100%, #bbb)); |
||||
background-image: -webkit-linear-gradient(top, #ddd, #bbb); |
||||
background-image: -moz-linear-gradient(top, #ddd, #bbb); |
||||
background-image: -ms-linear-gradient(top, #ddd, #bbb); |
||||
background-image: -o-linear-gradient(top, #ddd, #bbb); |
||||
background-image: linear-gradient(top, #ddd, #bbb); |
||||
border-color: #bbb; |
||||
border-bottom-color: #999; |
||||
cursor: pointer; |
||||
text-shadow: 0 1px 0 #ddd; |
||||
} |
||||
|
||||
#djDebug button:active { |
||||
border: 1px solid #aaa; |
||||
border-bottom: 1px solid #888; |
||||
-webkit-box-shadow: inset 0 0 5px 2px #aaa, 0 1px 0 0 #eee; |
||||
-moz-box-shadow: inset 0 0 5px 2px #aaa, 0 1px 0 0 #eee; |
||||
box-shadow: inset 0 0 5px 2px #aaa, 0 1px 0 0 #eee; |
||||
} |
||||
|
||||
#djDebug #djDebugToolbar { |
||||
background-color:#111; |
||||
width:200px; |
||||
z-index:100000000; |
||||
position:fixed; |
||||
top:0; |
||||
bottom:0; |
||||
right:0; |
||||
opacity:0.9; |
||||
overflow-y: auto; |
||||
} |
||||
|
||||
#djDebug #djDebugToolbar small { |
||||
color:#999; |
||||
} |
||||
|
||||
#djDebug #djDebugToolbar ul { |
||||
margin:0; |
||||
padding:0; |
||||
list-style:none; |
||||
} |
||||
|
||||
#djDebug #djDebugToolbar li { |
||||
border-bottom:1px solid #222; |
||||
color:#fff; |
||||
display:block; |
||||
font-weight:bold; |
||||
float:none; |
||||
margin:0; |
||||
padding:0; |
||||
position:relative; |
||||
width:auto; |
||||
} |
||||
|
||||
#djDebug #djDebugToolbar input[type=checkbox] { |
||||
float: right; |
||||
margin: 10px; |
||||
} |
||||
|
||||
#djDebug #djDebugToolbar li>a, |
||||
#djDebug #djDebugToolbar li>div.contentless { |
||||
font-weight:normal; |
||||
font-style:normal; |
||||
text-decoration:none; |
||||
display:block; |
||||
font-size:16px; |
||||
padding:10px 10px 5px 25px; |
||||
color:#fff; |
||||
} |
||||
#djDebug #djDebugToolbar li>div.disabled { |
||||
font-style: italic; |
||||
color: #999; |
||||
} |
||||
|
||||
#djDebug #djDebugToolbar li a:hover { |
||||
color:#111; |
||||
background-color:#ffc; |
||||
} |
||||
|
||||
#djDebug #djDebugToolbar li.active { |
||||
background: #333 no-repeat left center; |
||||
background-image: url(""); |
||||
padding-left:10px; |
||||
} |
||||
|
||||
#djDebug #djDebugToolbar li.active a:hover { |
||||
color:#b36a60; |
||||
background-color:transparent; |
||||
} |
||||
|
||||
#djDebug #djDebugToolbar li small { |
||||
font-size:12px; |
||||
color:#999; |
||||
font-style:normal; |
||||
text-decoration:none; |
||||
font-variant:small-caps; |
||||
} |
||||
|
||||
#djDebug #djDebugToolbarHandle { |
||||
position:fixed; |
||||
background-color:#fff; |
||||
border:1px solid #111; |
||||
top:30px; |
||||
right:0; |
||||
z-index:100000000; |
||||
opacity:0.75; |
||||
} |
||||
|
||||
#djDebug #djShowToolBarButton { |
||||
display:block; |
||||
height:75px; |
||||
width:30px; |
||||
border-right:none; |
||||
border-bottom:4px solid #fff; |
||||
border-top:4px solid #fff; |
||||
border-left:4px solid #fff; |
||||
color:#fff; |
||||
font-size:10px; |
||||
font-weight:bold; |
||||
text-decoration:none; |
||||
text-align:center; |
||||
text-indent:-999999px; |
||||
background: #000 no-repeat left center; |
||||
background-image: url(""); |
||||
opacity:0.5; |
||||
} |
||||
|
||||
#djDebug #djShowToolBarButton:hover { |
||||
background-color:#111; |
||||
border-top-color:#FFE761; |
||||
border-left-color:#FFE761; |
||||
border-bottom-color:#FFE761; |
||||
cursor:move; |
||||
opacity:1.0; |
||||
} |
||||
|
||||
#djDebug code { |
||||
display:block; |
||||
font-family:Consolas, Monaco, "Bitstream Vera Sans Mono", "Lucida Console", monospace; |
||||
font-size: 12px; |
||||
white-space:pre; |
||||
overflow:auto; |
||||
} |
||||
|
||||
#djDebug .djDebugOdd { |
||||
background-color:#f5f5f5; |
||||
} |
||||
|
||||
#djDebug .panelContent { |
||||
display:none; |
||||
position:fixed; |
||||
margin:0; |
||||
top:0; |
||||
right:200px; |
||||
bottom:0; |
||||
left:0px; |
||||
background-color:#eee; |
||||
color:#666; |
||||
z-index:100000000; |
||||
} |
||||
|
||||
#djDebug .panelContent > div { |
||||
border-bottom:1px solid #ddd; |
||||
} |
||||
|
||||
#djDebug .djDebugPanelTitle { |
||||
position:absolute; |
||||
background-color:#ffc; |
||||
color:#666; |
||||
padding-left:20px; |
||||
top:0; |
||||
right:0; |
||||
left:0; |
||||
height:50px; |
||||
} |
||||
|
||||
#djDebug .djDebugPanelTitle code { |
||||
display:inline; |
||||
font-size:inherit; |
||||
} |
||||
|
||||
#djDebug .djDebugPanelContent { |
||||
position:absolute; |
||||
top:50px; |
||||
right:0; |
||||
bottom:0; |
||||
left:0; |
||||
height:auto; |
||||
padding:5px 0 0 20px; |
||||
} |
||||
|
||||
#djDebug .djDebugPanelContent .loader { |
||||
display:block; |
||||
margin:80px auto; |
||||
} |
||||
|
||||
#djDebug .djDebugPanelContent .scroll { |
||||
height:100%; |
||||
overflow:auto; |
||||
display:block; |
||||
padding:0 10px 0 0; |
||||
} |
||||
|
||||
#djDebug h3 { |
||||
font-size:24px; |
||||
font-weight:normal; |
||||
line-height:50px; |
||||
} |
||||
|
||||
#djDebug h4 { |
||||
font-size:20px; |
||||
font-weight:bold; |
||||
margin-top:0.8em; |
||||
} |
||||
|
||||
#djDebug .panelContent table { |
||||
border:1px solid #ccc; |
||||
border-collapse:collapse; |
||||
width:100%; |
||||
background-color:#fff; |
||||
display:block; |
||||
margin-top:0.8em; |
||||
overflow: auto; |
||||
} |
||||
#djDebug .panelContent tbody td, |
||||
#djDebug .panelContent tbody th { |
||||
vertical-align:top; |
||||
padding:2px 3px; |
||||
} |
||||
#djDebug .panelContent tbody td.time { |
||||
text-align: center; |
||||
} |
||||
|
||||
#djDebug .panelContent thead th { |
||||
padding:1px 6px 1px 3px; |
||||
text-align:left; |
||||
font-weight:bold; |
||||
font-size:14px; |
||||
white-space: nowrap; |
||||
} |
||||
#djDebug .panelContent tbody th { |
||||
width:12em; |
||||
text-align:right; |
||||
color:#666; |
||||
padding-right:.5em; |
||||
} |
||||
|
||||
#djDebug .djTemplateHideContextDiv { |
||||
background-color:#fff; |
||||
} |
||||
|
||||
/* |
||||
#djDebug .panelContent p a:hover, #djDebug .panelContent dd a:hover { |
||||
color:#111; |
||||
background-color:#ffc; |
||||
} |
||||
|
||||
#djDebug .panelContent p { |
||||
padding:0 5px; |
||||
} |
||||
|
||||
#djDebug .panelContent p, #djDebug .panelContent table, #djDebug .panelContent ol, #djDebug .panelContent ul, #djDebug .panelContent dl { |
||||
margin:5px 0 15px; |
||||
background-color:#fff; |
||||
} |
||||
#djDebug .panelContent table { |
||||
clear:both; |
||||
border:0; |
||||
padding:0; |
||||
margin:0; |
||||
border-collapse:collapse; |
||||
border-spacing:0; |
||||
} |
||||
|
||||
#djDebug .panelContent table a { |
||||
color:#000; |
||||
padding:2px 4px; |
||||
} |
||||
#djDebug .panelContent table a:hover { |
||||
background-color:#ffc; |
||||
} |
||||
|
||||
#djDebug .panelContent table th { |
||||
background-color:#333; |
||||
font-weight:bold; |
||||
color:#fff; |
||||
padding:3px 7px 3px; |
||||
text-align:left; |
||||
cursor:pointer; |
||||
} |
||||
#djDebug .panelContent table td { |
||||
padding:5px 10px; |
||||
font-size:14px; |
||||
background-color:#fff; |
||||
color:#000; |
||||
vertical-align:top; |
||||
border:0; |
||||
} |
||||
#djDebug .panelContent table tr.djDebugOdd td { |
||||
background-color:#eee; |
||||
} |
||||
*/ |
||||
|
||||
#djDebug .panelContent .djDebugClose { |
||||
text-indent:-9999999px; |
||||
display:block; |
||||
position:absolute; |
||||
top:4px; |
||||
right:15px; |
||||
height:40px; |
||||
width:40px; |
||||
background: no-repeat center center; |
||||
background-image: url(""); |
||||
} |
||||
|
||||
#djDebug .panelContent .djDebugClose:hover { |
||||
background-image: url(""); |
||||
} |
||||
|
||||
#djDebug .panelContent .djDebugClose.djDebugBack { |
||||
background-image: url(""); |
||||
} |
||||
|
||||
#djDebug .panelContent .djDebugClose.djDebugBack:hover { |
||||
background-image: url(""); |
||||
} |
||||
|
||||
#djDebug .panelContent dt, #djDebug .panelContent dd { |
||||
display:block; |
||||
} |
||||
|
||||
#djDebug .panelContent dt { |
||||
margin-top:0.75em; |
||||
} |
||||
|
||||
#djDebug .panelContent dd { |
||||
margin-left:10px; |
||||
} |
||||
|
||||
#djDebug a.toggleTemplate { |
||||
padding:4px; |
||||
background-color:#bbb; |
||||
-webkit-border-radius:3px; |
||||
-moz-border-radius:3px; |
||||
border-radius:3px; |
||||
} |
||||
|
||||
#djDebug a.toggleTemplate:hover { |
||||
padding:4px; |
||||
background-color:#444; |
||||
color:#ffe761; |
||||
-webkit-border-radius:3px; |
||||
-moz-border-radius:3px; |
||||
border-radius:3px; |
||||
} |
||||
|
||||
|
||||
#djDebug a.djTemplateShowContext, #djDebug a.djTemplateShowContext span.toggleArrow { |
||||
color:#999; |
||||
} |
||||
|
||||
#djDebug a.djTemplateShowContext:hover, #djDebug a.djTemplateShowContext:hover span.toggleArrow { |
||||
color:#000; |
||||
cursor:pointer; |
||||
} |
||||
|
||||
#djDebug .djDebugSqlWrap { |
||||
position:relative; |
||||
} |
||||
|
||||
#djDebug .djDebugCollapsed { |
||||
display: none; |
||||
text-decoration: none; |
||||
color: #333; |
||||
} |
||||
|
||||
#djDebug .djDebugUncollapsed { |
||||
color: #333; |
||||
text-decoration: none; |
||||
} |
||||
|
||||
#djDebug .djUnselected { |
||||
display: none; |
||||
} |
||||
#djDebug tr.djHiddenByDefault { |
||||
display: none; |
||||
} |
||||
#djDebug tr.djSelected { |
||||
display: table-row; |
||||
} |
||||
|
||||
#djDebug .djDebugSql { |
||||
z-index:100000002; |
||||
} |
||||
|
||||
#djDebug .djSQLDetailsDiv tbody th { |
||||
text-align: left; |
||||
} |
||||
|
||||
#djDebug .djSqlExplain td { |
||||
white-space: pre; |
||||
} |
||||
|
||||
#djDebug span.djDebugLineChart { |
||||
background-color:#777; |
||||
height:3px; |
||||
position:absolute; |
||||
bottom:0; |
||||
top:0; |
||||
left:0; |
||||
display:block; |
||||
z-index:1000000001; |
||||
} |
||||
#djDebug span.djDebugLineChartWarning { |
||||
background-color:#900; |
||||
} |
||||
|
||||
#djDebug .highlight { color:#000; } |
||||
#djDebug .highlight .err { color:#000; } /* Error */ |
||||
#djDebug .highlight .g { color:#000; } /* Generic */ |
||||
#djDebug .highlight .k { color:#000; font-weight:bold } /* Keyword */ |
||||
#djDebug .highlight .o { color:#000; } /* Operator */ |
||||
#djDebug .highlight .n { color:#000; } /* Name */ |
||||
#djDebug .highlight .mi { color:#000; font-weight:bold } /* Literal.Number.Integer */ |
||||
#djDebug .highlight .l { color:#000; } /* Literal */ |
||||
#djDebug .highlight .x { color:#000; } /* Other */ |
||||
#djDebug .highlight .p { color:#000; } /* Punctuation */ |
||||
#djDebug .highlight .m { color:#000; font-weight:bold } /* Literal.Number */ |
||||
#djDebug .highlight .s { color:#333 } /* Literal.String */ |
||||
#djDebug .highlight .w { color:#888888 } /* Text.Whitespace */ |
||||
#djDebug .highlight .il { color:#000; font-weight:bold } /* Literal.Number.Integer.Long */ |
||||
#djDebug .highlight .na { color:#333 } /* Name.Attribute */ |
||||
#djDebug .highlight .nt { color:#000; font-weight:bold } /* Name.Tag */ |
||||
#djDebug .highlight .nv { color:#333 } /* Name.Variable */ |
||||
#djDebug .highlight .s2 { color:#333 } /* Literal.String.Double */ |
||||
#djDebug .highlight .cp { color:#333 } /* Comment.Preproc */ |
||||
|
||||
#djDebug .timeline { |
||||
width: 30%; |
||||
} |
||||
#djDebug .djDebugTimeline { |
||||
position: relative; |
||||
height: 100%; |
||||
min-height: 100%; |
||||
} |
||||
#djDebug div.djDebugLineChart { |
||||
position: absolute; |
||||
left: 0; |
||||
right: 0; |
||||
top: 0; |
||||
bottom: 0; |
||||
vertical-align: middle; |
||||
} |
||||
#djDebug div.djDebugLineChart strong { |
||||
text-indent: -10000em; |
||||
display: block; |
||||
font-weight: normal; |
||||
vertical-align: middle; |
||||
background-color:#ccc; |
||||
} |
||||
|
||||
#djDebug div.djDebugLineChartWarning strong { |
||||
background-color:#900; |
||||
} |
||||
|
||||
#djDebug .djDebugInTransaction div.djDebugLineChart strong { |
||||
background-color: #d3ff82; |
||||
} |
||||
#djDebug .djDebugStartTransaction div.djDebugLineChart strong { |
||||
border-left: 1px solid #94b24d; |
||||
} |
||||
#djDebug .djDebugEndTransaction div.djDebugLineChart strong { |
||||
border-right: 1px solid #94b24d; |
||||
} |
||||
#djDebug .djDebugHover div.djDebugLineChart strong { |
||||
background-color: #000; |
||||
} |
||||
#djDebug .djDebugInTransaction.djDebugHover div.djDebugLineChart strong { |
||||
background-color: #94b24d; |
||||
} |
||||
|
||||
|
||||
#djDebug .panelContent ul.stats { |
||||
position: relative; |
||||
list-style-type: none; |
||||
} |
||||
#djDebug .panelContent ul.stats li { |
||||
width: 30%; |
||||
float: left; |
||||
} |
||||
#djDebug .panelContent ul.stats li strong.label { |
||||
display: block; |
||||
} |
||||
#djDebug .panelContent ul.stats li span.color { |
||||
height: 12px; |
||||
width: 3px; |
||||
display: inline-block; |
||||
} |
||||
#djDebug .panelContent ul.stats li span.info { |
||||
display: block; |
||||
padding-left: 5px; |
||||
} |
||||
|
||||
#djDebug .panelcontent thead th { |
||||
white-space: nowrap; |
||||
} |
||||
#djDebug .djDebugRowWarning .time { |
||||
color: red; |
||||
} |
||||
#djdebug .panelcontent table .toggle { |
||||
width: 14px; |
||||
padding-top: 3px; |
||||
} |
||||
#djDebug .panelContent table .actions { |
||||
min-width: 70px; |
||||
white-space: nowrap; |
||||
} |
||||
#djdebug .panelcontent table .color { |
||||
width: 3px; |
||||
} |
||||
#djdebug .panelcontent table .color span { |
||||
width: 3px; |
||||
height: 12px; |
||||
overflow: hidden; |
||||
padding: 0; |
||||
} |
||||
#djDebug .djToggleSwitch { |
||||
text-decoration: none; |
||||
border: 1px solid #999; |
||||
height: 12px; |
||||
width: 12px; |
||||
line-height: 12px; |
||||
text-align: center; |
||||
color: #777; |
||||
display: inline-block; |
||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#FFF', endColorstr='#DCDCDC'); /* for IE */ |
||||
background: -webkit-gradient(linear, left top, left bottom, from(#FFF), to(#DCDCDC)); /* for webkit browsers */ |
||||
background:-moz-linear-gradient(center top , #FFFFFF 0pt, #DCDCDC 100%) repeat scroll 0 0 transparent; |
||||
} |
||||
#djDebug .djNoToggleSwitch { |
||||
height: 14px; |
||||
width: 14px; |
||||
display: inline-block; |
||||
} |
||||
|
||||
#djDebug .djSQLDetailsDiv { |
||||
margin-top:0.8em; |
||||
} |
||||
#djDebug pre { |
||||
white-space: -moz-pre-wrap; /* Mozilla, since 1999 */ |
||||
white-space: -pre-wrap; /* Opera 4-6 */ |
||||
white-space: -o-pre-wrap; /* Opera 7 */ |
||||
white-space: pre-wrap; /* CSS-3 */ |
||||
word-wrap: break-word; /* Internet Explorer 5.5+ */ |
||||
color: #555; |
||||
border:1px solid #ccc; |
||||
border-collapse:collapse; |
||||
background-color:#fff; |
||||
display:block; |
||||
overflow: auto; |
||||
padding:2px 3px; |
||||
margin-bottom: 3px; |
||||
font-family:Consolas, Monaco, "Bitstream Vera Sans Mono", "Lucida Console", monospace; |
||||
} |
||||
#djDebug .stack span { |
||||
color: #000; |
||||
font-weight: bold; |
||||
} |
||||
#djDebug .stack span.path { |
||||
color: #777; |
||||
font-weight: normal; |
||||
} |
||||
#djDebug .stack span.code { |
||||
font-weight: normal; |
||||
} |
||||
|
||||
@media print { |
||||
#djDebug { |
||||
display: none; |
||||
} |
||||
} |
||||
|
Before Width: | Height: | Size: 404 B |
|
Before Width: | Height: | Size: 574 B |
|
Before Width: | Height: | Size: 613 B |
|
Before Width: | Height: | Size: 498 B |
|
Before Width: | Height: | Size: 706 B |
|
Before Width: | Height: | Size: 882 B |
|
Before Width: | Height: | Size: 436 B |
@ -1,284 +0,0 @@ |
||||
(function ($) { |
||||
var djdt = { |
||||
handleDragged: false, |
||||
events: { |
||||
ready: [] |
||||
}, |
||||
isReady: false, |
||||
init: function() { |
||||
$('#djDebug').show(); |
||||
var current = null; |
||||
$(document).on('click', '#djDebugPanelList li a', function() { |
||||
if (!this.className) { |
||||
return false; |
||||
} |
||||
current = $('#djDebug #' + this.className); |
||||
if (current.is(':visible')) { |
||||
$(document).trigger('close.djDebug'); |
||||
$(this).parent().removeClass('active'); |
||||
} else { |
||||
$('.panelContent').hide(); // Hide any that are already open
|
||||
var inner = current.find('.djDebugPanelContent .scroll'), |
||||
store_id = $('#djDebug').data('store-id'), |
||||
render_panel_url = $('#djDebug').data('render-panel-url'); |
||||
if (store_id !== '' && inner.children().length === 0) { |
||||
var ajax_data = { |
||||
data: { |
||||
store_id: store_id, |
||||
panel_id: this.className |
||||
}, |
||||
type: 'GET', |
||||
url: render_panel_url |
||||
}; |
||||
$.ajax(ajax_data).done(function(data){ |
||||
inner.prev().remove(); // Remove AJAX loader
|
||||
inner.html(data); |
||||
}).fail(function(xhr){ |
||||
var message = '<div class="djDebugPanelTitle"><a class="djDebugClose djDebugBack" href="">Back</a><h3>'+xhr.status+': '+xhr.statusText+'</h3></div>'; |
||||
$('#djDebugWindow').html(message).show(); |
||||
}); |
||||
} |
||||
current.show(); |
||||
$('#djDebugToolbar li').removeClass('active'); |
||||
$(this).parent().addClass('active'); |
||||
} |
||||
return false; |
||||
}); |
||||
$(document).on('click', '#djDebug a.djDebugClose', function() { |
||||
$(document).trigger('close.djDebug'); |
||||
$('#djDebugToolbar li').removeClass('active'); |
||||
return false; |
||||
}); |
||||
$(document).on('click', '#djDebug .djDebugPanelButton input[type=checkbox]', function() { |
||||
djdt.cookie.set($(this).attr('data-cookie'), $(this).prop('checked') ? 'on' : 'off', { |
||||
path: '/', |
||||
expires: 10 |
||||
}); |
||||
}); |
||||
|
||||
// Used by the SQL and template panels
|
||||
$(document).on('click', '#djDebug .remoteCall', function() { |
||||
var self = $(this); |
||||
var name = self[0].tagName.toLowerCase(); |
||||
var ajax_data = {}; |
||||
|
||||
if (name == 'button') { |
||||
var form = self.parents('form:eq(0)'); |
||||
ajax_data['url'] = self.attr('formaction'); |
||||
|
||||
if (form.length) { |
||||
ajax_data['data'] = form.serialize(); |
||||
ajax_data['type'] = form.attr('method') || 'POST'; |
||||
} |
||||
} |
||||
|
||||
if (name == 'a') { |
||||
ajax_data['url'] = self.attr('href'); |
||||
} |
||||
|
||||
$.ajax(ajax_data).done(function(data){ |
||||
$('#djDebugWindow').html(data).show(); |
||||
}).fail(function(xhr){ |
||||
var message = '<div class="djDebugPanelTitle"><a class="djDebugClose djDebugBack" href="">Back</a><h3>'+xhr.status+': '+xhr.statusText+'</h3></div>'; |
||||
$('#djDebugWindow').html(message).show(); |
||||
}); |
||||
|
||||
$(document).on('click', '#djDebugWindow a.djDebugBack', function() { |
||||
$(this).parent().parent().hide(); |
||||
return false; |
||||
}); |
||||
|
||||
return false; |
||||
}); |
||||
|
||||
// Used by the cache, profiling and SQL panels
|
||||
$(document).on('click', '#djDebug a.djToggleSwitch', function(e) { |
||||
e.preventDefault(); |
||||
var btn = $(this); |
||||
var id = btn.attr('data-toggle-id'); |
||||
var open_me = btn.text() == btn.attr('data-toggle-open'); |
||||
if (id === '' || !id) { |
||||
return; |
||||
} |
||||
var name = btn.attr('data-toggle-name'); |
||||
btn.parents('.djDebugPanelContent').find('#' + name + '_' + id).find('.djDebugCollapsed').toggle(open_me); |
||||
btn.parents('.djDebugPanelContent').find('#' + name + '_' + id).find('.djDebugUncollapsed').toggle(!open_me); |
||||
$(this).parents('.djDebugPanelContent').find('.djToggleDetails_' + id).each(function(){ |
||||
var $this = $(this); |
||||
if (open_me) { |
||||
$this.addClass('djSelected'); |
||||
$this.removeClass('djUnselected'); |
||||
btn.text(btn.attr('data-toggle-close')); |
||||
$this.find('.djToggleSwitch').text(btn.text()); |
||||
} else { |
||||
$this.removeClass('djSelected'); |
||||
$this.addClass('djUnselected'); |
||||
btn.text(btn.attr('data-toggle-open')); |
||||
$this.find('.djToggleSwitch').text(btn.text()); |
||||
} |
||||
}); |
||||
return; |
||||
}); |
||||
|
||||
$('#djHideToolBarButton').click(function() { |
||||
djdt.hide_toolbar(true); |
||||
return false; |
||||
}); |
||||
$('#djShowToolBarButton').click(function() { |
||||
if (!djdt.handleDragged) { |
||||
djdt.show_toolbar(); |
||||
} |
||||
return false; |
||||
}); |
||||
var handle = $('#djDebugToolbarHandle'); |
||||
$('#djShowToolBarButton').on('mousedown', function (event) { |
||||
var startPageY = event.pageY; |
||||
var baseY = handle.offset().top - startPageY; |
||||
$(document).on('mousemove.djDebug', function (event) { |
||||
// Chrome can send spurious mousemove events, so don't do anything unless the
|
||||
// cursor really moved. Otherwise, it will be impossible to expand the toolbar
|
||||
// due to djdt.handleDragged being set to true.
|
||||
if (djdt.handleDragged || event.pageY != startPageY) { |
||||
var offset = handle.offset(); |
||||
offset.top = baseY + event.pageY; |
||||
handle.offset(offset); |
||||
djdt.handleDragged = true; |
||||
} |
||||
}); |
||||
return false; |
||||
}); |
||||
$(document).on('mouseup', function () { |
||||
$(document).off('mousemove.djDebug'); |
||||
if (djdt.handleDragged) { |
||||
var top = handle.offset().top; |
||||
djdt.cookie.set('djdttop', top, { |
||||
path: '/', |
||||
expires: 10 |
||||
}); |
||||
setTimeout(function () { |
||||
djdt.handleDragged = false; |
||||
}, 10); |
||||
return false; |
||||
} |
||||
}); |
||||
$(document).bind('close.djDebug', function() { |
||||
// If a sub-panel is open, close that
|
||||
if ($('#djDebugWindow').is(':visible')) { |
||||
$('#djDebugWindow').hide(); |
||||
return; |
||||
} |
||||
// If a panel is open, close that
|
||||
if ($('.panelContent').is(':visible')) { |
||||
$('.panelContent').hide(); |
||||
$('#djDebugToolbar li').removeClass('active'); |
||||
return; |
||||
} |
||||
// Otherwise, just minimize the toolbar
|
||||
if ($('#djDebugToolbar').is(':visible')) { |
||||
djdt.hide_toolbar(true); |
||||
return; |
||||
} |
||||
}); |
||||
if (djdt.cookie.get('djdt') == 'hide') { |
||||
djdt.hide_toolbar(false); |
||||
} else { |
||||
djdt.show_toolbar(false); |
||||
} |
||||
$('#djDebug .djDebugHoverable').hover(function(){ |
||||
$(this).addClass('djDebugHover'); |
||||
}, function(){ |
||||
$(this).removeClass('djDebugHover'); |
||||
}); |
||||
djdt.isReady = true; |
||||
$.each(djdt.events.ready, function(_, callback){ |
||||
callback(djdt); |
||||
}); |
||||
}, |
||||
close: function() { |
||||
$(document).trigger('close.djDebug'); |
||||
return false; |
||||
}, |
||||
hide_toolbar: function(setCookie) { |
||||
// close any sub panels
|
||||
$('#djDebugWindow').hide(); |
||||
// close all panels
|
||||
$('.panelContent').hide(); |
||||
$('#djDebugToolbar li').removeClass('active'); |
||||
// finally close toolbar
|
||||
$('#djDebugToolbar').hide('fast'); |
||||
$('#djDebugToolbarHandle').show(); |
||||
// set handle position
|
||||
var handleTop = djdt.cookie.get('djdttop'); |
||||
if (handleTop) { |
||||
$('#djDebugToolbarHandle').css({top: handleTop + 'px'}); |
||||
} |
||||
// Unbind keydown
|
||||
$(document).unbind('keydown.djDebug'); |
||||
if (setCookie) { |
||||
djdt.cookie.set('djdt', 'hide', { |
||||
path: '/', |
||||
expires: 10 |
||||
}); |
||||
} |
||||
}, |
||||
show_toolbar: function(animate) { |
||||
// Set up keybindings
|
||||
$(document).bind('keydown.djDebug', function(e) { |
||||
if (e.keyCode == 27) { |
||||
djdt.close(); |
||||
} |
||||
}); |
||||
$('#djDebugToolbarHandle').hide(); |
||||
if (animate) { |
||||
$('#djDebugToolbar').show('fast'); |
||||
} else { |
||||
$('#djDebugToolbar').show(); |
||||
} |
||||
djdt.cookie.set('djdt', 'show', { |
||||
path: '/', |
||||
expires: 10 |
||||
}); |
||||
}, |
||||
ready: function(callback){ |
||||
if (djdt.isReady) { |
||||
callback(djdt); |
||||
} else { |
||||
djdt.events.ready.push(callback); |
||||
} |
||||
}, |
||||
cookie: { |
||||
get: function(key){ |
||||
if (document.cookie.indexOf(key) === -1) return null; |
||||
|
||||
var cookieArray = document.cookie.split('; '), |
||||
cookies = {}; |
||||
|
||||
cookieArray.forEach(function(e){ |
||||
var parts = e.split('='); |
||||
cookies[ parts[0] ] = parts[1]; |
||||
}); |
||||
|
||||
return cookies[ key ]; |
||||
}, |
||||
set: function(key, value, options){ |
||||
options = options || {}; |
||||
|
||||
if (typeof options.expires === 'number') { |
||||
var days = options.expires, t = options.expires = new Date(); |
||||
t.setDate(t.getDate() + days); |
||||
} |
||||
|
||||
document.cookie = [ |
||||
encodeURIComponent(key) + '=' + String(value), |
||||
options.expires ? '; expires=' + options.expires.toUTCString() : '', |
||||
options.path ? '; path=' + options.path : '', |
||||
options.domain ? '; domain=' + options.domain : '', |
||||
options.secure ? '; secure' : '' |
||||
].join(''); |
||||
|
||||
return value; |
||||
} |
||||
} |
||||
}; |
||||
$(document).ready(djdt.init); |
||||
})(djdt.jQuery); |
||||
@ -1,20 +0,0 @@ |
||||
(function ($) { |
||||
function getSubcalls(row) { |
||||
var id = row.attr('id'); |
||||
return $('.djDebugProfileRow[id^="'+id+'_"]'); |
||||
} |
||||
function getDirectSubcalls(row) { |
||||
var subcalls = getSubcalls(row); |
||||
var depth = parseInt(row.attr('depth'), 10) + 1; |
||||
return subcalls.filter('[depth='+depth+']'); |
||||
} |
||||
$('.djDebugProfileRow .djDebugProfileToggle').on('click', function(){ |
||||
var row = $(this).closest('.djDebugProfileRow'); |
||||
var subcalls = getSubcalls(row); |
||||
if (subcalls.css('display') == 'none') { |
||||
getDirectSubcalls(row).show(); |
||||
} else { |
||||
subcalls.hide(); |
||||
} |
||||
}); |
||||
})(djdt.jQuery); |
||||
@ -1,7 +0,0 @@ |
||||
(function ($) { |
||||
$('#djDebug a.djDebugToggle').on('click', function(e) { |
||||
e.preventDefault(); |
||||
$(this).parent().find('.djDebugCollapsed').toggle(); |
||||
$(this).parent().find('.djDebugUncollapsed').toggle(); |
||||
}); |
||||
})(djdt.jQuery); |
||||
@ -1,11 +0,0 @@ |
||||
(function ($) { |
||||
var uarr = String.fromCharCode(0x25b6), |
||||
darr = String.fromCharCode(0x25bc); |
||||
|
||||
$('a.djTemplateShowContext').on('click', function() { |
||||
var arrow = $(this).children('.toggleArrow'); |
||||
arrow.html(arrow.html() == uarr ? darr : uarr); |
||||
$(this).parent().next().toggle(); |
||||
return false; |
||||
}); |
||||
})(djdt.jQuery); |
||||
@ -1,48 +0,0 @@ |
||||
(function ($) { |
||||
// Browser timing remains hidden unless we can successfully access the performance object
|
||||
var perf = window.performance || window.msPerformance || |
||||
window.webkitPerformance || window.mozPerformance; |
||||
if (!perf) |
||||
return; |
||||
|
||||
var rowCount = 0, |
||||
timingOffset = perf.timing.navigationStart, |
||||
timingEnd = perf.timing.loadEventEnd, |
||||
totalTime = timingEnd - timingOffset; |
||||
function getLeft(stat) { |
||||
return ((perf.timing[stat] - timingOffset) / (totalTime)) * 100.0; |
||||
} |
||||
function getCSSWidth(stat, endStat) { |
||||
var width = ((perf.timing[endStat] - perf.timing[stat]) / (totalTime)) * 100.0; |
||||
// Calculate relative percent (same as sql panel logic)
|
||||
width = 100.0 * width / (100.0 - getLeft(stat)); |
||||
return (width < 1) ? "2px" : width + "%"; |
||||
} |
||||
function addRow(stat, endStat) { |
||||
rowCount++; |
||||
var $row = $('<tr class="' + ((rowCount % 2) ? 'djDebugOdd' : 'djDebugEven') + '"></tr>'); |
||||
if (endStat) { |
||||
// Render a start through end bar
|
||||
$row.html('<td>' + stat.replace('Start', '') + '</td>' + |
||||
'<td class="timeline"><div class="djDebugTimeline"><div class="djDebugLineChart" style="left:' + getLeft(stat) + '%;"><strong style="width:' + getCSSWidth(stat, endStat) + ';"> </strong></div></div></td>' + |
||||
'<td>' + (perf.timing[stat] - timingOffset) + ' (+' + (perf.timing[endStat] - perf.timing[stat]) + ')</td>'); |
||||
} else { |
||||
// Render a point in time
|
||||
$row.html('<td>' + stat + '</td>' + |
||||
'<td class="timeline"><div class="djDebugTimeline"><div class="djDebugLineChart" style="left:' + getLeft(stat) + '%;"><strong style="width:2px;"> </strong></div></div></td>' + |
||||
'<td>' + (perf.timing[stat] - timingOffset) + '</td>'); |
||||
} |
||||
$('#djDebugBrowserTimingTableBody').append($row); |
||||
} |
||||
|
||||
// This is a reasonably complete and ordered set of timing periods (2 params) and events (1 param)
|
||||
addRow('domainLookupStart', 'domainLookupEnd'); |
||||
addRow('connectStart', 'connectEnd'); |
||||
addRow('requestStart', 'responseEnd'); // There is no requestEnd
|
||||
addRow('responseStart', 'responseEnd'); |
||||
addRow('domLoading', 'domComplete'); // Spans the events below
|
||||
addRow('domInteractive'); |
||||
addRow('domContentLoadedEventStart', 'domContentLoadedEventEnd'); |
||||
addRow('loadEventStart', 'loadEventEnd'); |
||||
$('#djDebugBrowserTiming').css("display", "block"); |
||||
})(djdt.jQuery); |
||||
@ -1,70 +0,0 @@ |
||||
{% load i18n %}{% load static from staticfiles %}{% load url from future %} |
||||
<style type="text/css"> |
||||
@media print { #djDebug {display:none;}} |
||||
</style> |
||||
<link rel="stylesheet" href="{% static 'debug_toolbar/css/toolbar.css' %}" type="text/css" /> |
||||
{% if toolbar.config.JQUERY_URL %} |
||||
<!-- Prevent our copy of jQuery from registering as an AMD module on sites that use RequireJS. --> |
||||
<script>var _djdt_define_backup = window.define; window.define = undefined;</script> |
||||
<script src="{{ toolbar.config.JQUERY_URL }}"></script> |
||||
<script>var djdt = {jQuery: jQuery.noConflict(true)}; window.define = _djdt_define_backup;</script> |
||||
{% else %} |
||||
<script>var djdt = {jQuery: jQuery};</script> |
||||
{% endif %} |
||||
<script src="{% static 'debug_toolbar/js/toolbar.js' %}"></script> |
||||
<div id="djDebug" style="display:none;" dir="ltr" |
||||
data-store-id="{{ toolbar.store_id }}" data-render-panel-url="{% url 'djdt:render_panel' %}" |
||||
{{ toolbar.config.ROOT_TAG_EXTRA_ATTRS|safe }}> |
||||
<div style="display:none;" id="djDebugToolbar"> |
||||
<ul id="djDebugPanelList"> |
||||
{% if toolbar.panels %} |
||||
<li><a id="djHideToolBarButton" href="#" title="{% trans "Hide toolbar" %}">{% trans "Hide" %} »</a></li> |
||||
{% else %} |
||||
<li id="djDebugButton">DEBUG</li> |
||||
{% endif %} |
||||
{% for panel in toolbar.panels %} |
||||
<li class="djDebugPanelButton"> |
||||
<input type="checkbox" data-cookie="djdt{{ panel.panel_id }}" {% if panel.enabled %}checked="checked" title="{% trans "Disable for next and successive requests" %}"{% else %}title="{% trans "Enable for next and successive requests" %}"{% endif %} /> |
||||
{% if panel.has_content and panel.enabled %} |
||||
<a href="#" title="{{ panel.title }}" class="{{ panel.panel_id }}"> |
||||
{% else %} |
||||
<div class="djdt-contentless{% if not panel.enabled %} djdt-disabled{% endif %}"> |
||||
{% endif %} |
||||
{{ panel.nav_title }} |
||||
{% if panel.enabled %} |
||||
{% with panel.nav_subtitle as subtitle %} |
||||
{% if subtitle %}<br /><small>{{ subtitle }}</small>{% endif %} |
||||
{% endwith %} |
||||
{% endif %} |
||||
{% if panel.has_content and panel.enabled %} |
||||
</a> |
||||
{% else %} |
||||
</div> |
||||
{% endif %} |
||||
</li> |
||||
{% endfor %} |
||||
</ul> |
||||
</div> |
||||
<div style="display:none;" id="djDebugToolbarHandle"> |
||||
<span title="{% trans "Show toolbar" %}" id="djShowToolBarButton">«</span> |
||||
</div> |
||||
{% for panel in toolbar.panels %} |
||||
{% if panel.has_content and panel.enabled %} |
||||
<div id="{{ panel.panel_id }}" class="djdt-panelContent"> |
||||
<div class="djDebugPanelTitle"> |
||||
<a href="" class="djDebugClose"></a> |
||||
<h3>{{ panel.title|safe }}</h3> |
||||
</div> |
||||
<div class="djDebugPanelContent"> |
||||
{% if toolbar.store_id %} |
||||
<img src="{% static 'debug_toolbar/img/ajax-loader.gif' %}" alt="loading" class="djdt-loader" /> |
||||
<div class="djdt-scroll"></div> |
||||
{% else %} |
||||
<div class="djdt-scroll">{{ panel.content }}</div> |
||||
{% endif %} |
||||
</div> |
||||
</div> |
||||
{% endif %} |
||||
{% endfor %} |
||||
<div id="djDebugWindow" class="djdt-panelContent"></div> |
||||
</div> |
||||
@ -1,69 +0,0 @@ |
||||
{% load i18n %} |
||||
<h4>{% trans "Summary" %}</h4> |
||||
<table> |
||||
<thead> |
||||
<tr> |
||||
<th>{% trans "Total calls" %}</th> |
||||
<th>{% trans "Total time" %}</th> |
||||
<th>{% trans "Cache hits" %}</th> |
||||
<th>{% trans "Cache misses" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
<tr> |
||||
<td>{{ total_calls }}</td> |
||||
<td>{{ total_time }} ms</td> |
||||
<td>{{ hits }}</td> |
||||
<td>{{ misses }}</td> |
||||
</tr> |
||||
</tbody> |
||||
</table> |
||||
<h4>{% trans "Commands" %}</h4> |
||||
<table> |
||||
<thead> |
||||
<tr> |
||||
{% for name in counts.keys %} |
||||
<th>{{ name }}</th> |
||||
{% endfor %} |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
<tr> |
||||
{% for value in counts.values %} |
||||
<td>{{ value }}</td> |
||||
{% endfor %} |
||||
</tr> |
||||
</tbody> |
||||
</table> |
||||
{% if calls %} |
||||
<h4>{% trans "Calls" %}</h4> |
||||
<table> |
||||
<thead> |
||||
<tr> |
||||
<th colspan="2">{% trans "Time (ms)" %}</th> |
||||
<th>{% trans "Type" %}</th> |
||||
<th>{% trans "Arguments" %}</th> |
||||
<th>{% trans "Keyword arguments" %}</th> |
||||
<th>{% trans "Backend" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for call in calls %} |
||||
<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}" id="cacheMain_{{ forloop.counter }}"> |
||||
<td class="djdt-toggle"> |
||||
<a class="djToggleSwitch" data-toggle-name="cacheMain" data-toggle-id="{{ forloop.counter }}" data-toggle-open="+" data-toggle-close="-" href="javascript:void(0)">+</a> |
||||
</td> |
||||
<td>{{ call.time|floatformat:"4" }}</td> |
||||
<td>{{ call.name|escape }}</td> |
||||
<td>{{ call.args|escape }}</td> |
||||
<td>{{ call.kwargs|escape }}</td> |
||||
<td>{{ call.backend }}</td> |
||||
</tr> |
||||
<tr class="djUnselected djDebugHoverable {% cycle 'djDebugOdd' 'djDebugEven' %} djToggleDetails_{{ forloop.counter }}" id="cacheDetails_{{ forloop.counter }}"> |
||||
<td colspan="1"></td> |
||||
<td colspan="5"><pre class="djdt-stack">{{ call.trace }}</pre></td> |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
{% endif %} |
||||
@ -1,60 +0,0 @@ |
||||
{% load i18n %} |
||||
|
||||
<h4>{% trans "Request headers" %}</h4> |
||||
|
||||
<table> |
||||
<thead> |
||||
<tr> |
||||
<th>{% trans "Key" %}</th> |
||||
<th>{% trans "Value" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for key, value in request_headers.items %} |
||||
<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}"> |
||||
<td>{{ key|escape }}</td> |
||||
<td>{{ value|escape }}</td> |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
|
||||
<h4>{% trans "Response headers" %}</h4> |
||||
|
||||
<table> |
||||
<thead> |
||||
<tr> |
||||
<th>{% trans "Key" %}</th> |
||||
<th>{% trans "Value" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for key, value in response_headers.items %} |
||||
<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}"> |
||||
<td>{{ key|escape }}</td> |
||||
<td>{{ value|escape }}</td> |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
|
||||
<h4>{% trans "WSGI environ" %}</h4> |
||||
|
||||
<p>{% trans "Since the WSGI environ inherits the environment of the server, only a significant subset is shown below." %}</p> |
||||
|
||||
<table> |
||||
<thead> |
||||
<tr> |
||||
<th>{% trans "Key" %}</th> |
||||
<th>{% trans "Value" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for key, value in environ.items %} |
||||
<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}"> |
||||
<td>{{ key|escape }}</td> |
||||
<td>{{ value|escape }}</td> |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
@ -1,28 +0,0 @@ |
||||
{% load i18n %} |
||||
{% if records %} |
||||
<table> |
||||
<thead> |
||||
<tr> |
||||
<th>{% trans "Level" %}</th> |
||||
<th>{% trans "Time" %}</th> |
||||
<th>{% trans "Channel" %}</th> |
||||
<th>{% trans "Message" %}</th> |
||||
<th>{% trans "Location" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for record in records %} |
||||
<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}"> |
||||
<td>{{ record.level }}</td> |
||||
<td>{{ record.time|date:"h:i:s m/d/Y" }}</td> |
||||
<td>{{ record.channel|default:"-" }}</td> |
||||
<td>{{ record.message|linebreaksbr }}</td> |
||||
<td>{{ record.file }}:{{ record.line }}</td> |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
{% else %} |
||||
<p>{% trans "No messages logged" %}.</p> |
||||
{% endif %} |
||||
|
||||
@ -1,37 +0,0 @@ |
||||
{% load i18n %}{% load static from staticfiles %} |
||||
<table width="100%"> |
||||
<thead> |
||||
<tr> |
||||
<th>{% trans "Call" %}</th> |
||||
<th>{% trans "CumTime" %}</th> |
||||
<th>{% trans "Per" %}</th> |
||||
<th>{% trans "TotTime" %}</th> |
||||
<th>{% trans "Per" %}</th> |
||||
<th>{% trans "Count" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for call in func_list %} |
||||
<!-- style="background:{{ call.background }}" --> |
||||
<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %} djDebugProfileRow{% for parent_id in call.parent_ids %} djToggleDetails_{{ parent_id }}{% endfor %}" depth="{{ call.depth }}"> |
||||
<td> |
||||
<div style="padding-left: {{ call.indent }}px;"> |
||||
{% if call.has_subfuncs %} |
||||
<a class="djProfileToggleDetails djToggleSwitch" data-toggle-id="{{ call.id }}" data-toggle-open="+" data-toggle-close="-" href="javascript:void(0)">-</a> |
||||
{% else %} |
||||
<span class="djNoToggleSwitch"></span> |
||||
{% endif %} |
||||
<span class="djdt-stack">{{ call.func_std_string }}</span> |
||||
</div> |
||||
</td> |
||||
<td>{{ call.cumtime|floatformat:3 }}</td> |
||||
<td>{{ call.cumtime_per_call|floatformat:3 }}</td> |
||||
<td>{{ call.tottime|floatformat:3 }}</td> |
||||
<td>{{ call.tottime_per_call|floatformat:3 }}</td> |
||||
<td>{{ call.count }}</td> |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
|
||||
<script src="{% static 'debug_toolbar/js/toolbar.profiling.js' %}"></script> |
||||
@ -1,124 +0,0 @@ |
||||
{% load i18n %} |
||||
|
||||
<h4>{% trans "View information" %}</h4> |
||||
<table> |
||||
<thead> |
||||
<tr> |
||||
<th>{% trans "View function" %}</th> |
||||
<th>{% trans "Arguments" %}</th> |
||||
<th>{% trans "Keyword arguments" %}</th> |
||||
<th>{% trans "URL name" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
<tr> |
||||
<td class="djDebugOdd"><code>{{ view_func }}</code></td> |
||||
<td class="djDebugEven"><code>{{ view_args|pprint }}</code></td> |
||||
<td class="djDebugOdd"><code>{{ view_kwargs|pprint }}</code></td> |
||||
<td class="djDebugEven"><code>{{ view_urlname }}</code></td> |
||||
</tr> |
||||
</tbody> |
||||
</table> |
||||
|
||||
{% if cookies %} |
||||
<h4>{% trans "Cookies" %}</h4> |
||||
<table> |
||||
<colgroup> |
||||
<col style="width:20%"/> |
||||
<col/> |
||||
</colgroup> |
||||
<thead> |
||||
<tr> |
||||
<th>{% trans "Variable" %}</th> |
||||
<th>{% trans "Value" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for key, value in cookies %} |
||||
<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}"> |
||||
<td><code>{{ key|pprint }}</code></td> |
||||
<td><code>{{ value|pprint }}</code></td> |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
{% else %} |
||||
<h4>{% trans "No cookies" %}</h4> |
||||
{% endif %} |
||||
|
||||
{% if session %} |
||||
<h4>{% trans "Session data" %}</h4> |
||||
<table> |
||||
<colgroup> |
||||
<col style="width:20%"/> |
||||
<col/> |
||||
</colgroup> |
||||
<thead> |
||||
<tr> |
||||
<th>{% trans "Variable" %}</th> |
||||
<th>{% trans "Value" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for key, value in session %} |
||||
<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}"> |
||||
<td><code>{{ key|pprint }}</code></td> |
||||
<td><code>{{ value|pprint }}</code></td> |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
{% else %} |
||||
<h4>{% trans "No session data" %}</h4> |
||||
{% endif %} |
||||
|
||||
{% if get %} |
||||
<h4>{% trans "GET data" %}</h4> |
||||
<table> |
||||
<colgroup> |
||||
<col style="width:20%"/> |
||||
<col/> |
||||
</colgroup> |
||||
<thead> |
||||
<tr> |
||||
<th>{% trans "Variable" %}</th> |
||||
<th>{% trans "Value" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for key, value in get %} |
||||
<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}"> |
||||
<td><code>{{ key|pprint }}</code></td> |
||||
<td><code>{{ value|pprint }}</code></td> |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
{% else %} |
||||
<h4>{% trans "No GET data" %}</h4> |
||||
{% endif %} |
||||
|
||||
{% if post %} |
||||
<h4>{% trans "POST data" %}</h4> |
||||
<table> |
||||
<colgroup> |
||||
<col style="width:20%"/> |
||||
<col/> |
||||
</colgr |
||||
<tr> |
||||
<th>{% trans "Variable" %}</th> |
||||
<th>{% trans "Value" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for key, value in post %} |
||||
<tr class="{% cycle 'row1' 'row2' %}"> |
||||
<td><code>{{ key|pprint }}</code></td> |
||||
<td><code>{{ value|pprint }}</code></td> |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
{% else %} |
||||
<h4>{% trans "No POST data" %}</h4> |
||||
{% endif %} |
||||
@ -1,17 +0,0 @@ |
||||
{% load i18n %} |
||||
<table> |
||||
<thead> |
||||
<tr> |
||||
<th>{% trans "Setting" %}</th> |
||||
<th>{% trans "Value" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for name, value in settings.items %} |
||||
<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}"> |
||||
<td>{{ name }}</td> |
||||
<td><code>{{ value|pprint }}</code></td> |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
@ -1,19 +0,0 @@ |
||||
{% load i18n %} |
||||
<table> |
||||
<thead> |
||||
<tr> |
||||
<th>{% trans "Signal" %}</th> |
||||
<th>{% trans "Providing" %}</th> |
||||
<th>{% trans "Receivers" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for name, signal, receivers in signals %} |
||||
<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}"> |
||||
<td>{{ name|escape }}</td> |
||||
<td>{{ signal.providing_args|join:", " }}</td> |
||||
<td>{{ receivers|join:", " }}</td> |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
@ -1,95 +0,0 @@ |
||||
{% load i18n l10n %}{% load static from staticfiles %}{% load url from future %} |
||||
<div class="djdt-clearfix"> |
||||
<ul class="djdt-stats"> |
||||
{% for alias, info in databases %} |
||||
<li> |
||||
<strong class="djdt-label"><span style="background-color: rgb({{ info.rgb_color|join:", " }})" class="djdt-color"> </span> {{ alias }}</strong> |
||||
<span class="djdt-info">{{ info.time_spent|floatformat:"2" }} ms ({% blocktrans count info.num_queries as num %}{{ num }} query{% plural %}{{ num }} queries{% endblocktrans %})</span> |
||||
</li> |
||||
{% endfor %} |
||||
</ul> |
||||
</div> |
||||
|
||||
{% if queries %} |
||||
<table> |
||||
<thead> |
||||
<tr> |
||||
<th class="djdt-color"> </th> |
||||
<th class="query" colspan="2">{% trans "Query" %}</th> |
||||
<th class="timeline">{% trans "Timeline" %}</th> |
||||
<th class="djdt-time">{% trans "Time (ms)" %}</th> |
||||
<th class="djdt-actions">{% trans "Action" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for query in queries %} |
||||
<tr class="djDebugHoverable {% cycle 'djDebugOdd' 'djDebugEven' %}{% if query.is_slow %} djDebugRowWarning{% endif %}{% if query.starts_trans %} djDebugStartTransaction{% endif %}{% if query.ends_trans %} djDebugEndTransaction{% endif %}{% if query.in_trans %} djDebugInTransaction{% endif %}" id="sqlMain_{{ forloop.counter }}"> |
||||
<td class="djdt-color"><span style="background-color: rgb({{ query.rgb_color|join:", " }});"> </span></td> |
||||
<td class="djdt-toggle"> |
||||
<a class="djToggleSwitch" data-toggle-name="sqlMain" data-toggle-id="{{ forloop.counter }}" data-toggle-open="+" data-toggle-close="-" href="javascript:void(0)">+</a> |
||||
</td> |
||||
<td class="query"> |
||||
<div class="djDebugSqlWrap"> |
||||
<div class="djDebugSql">{{ query.sql|safe }}</div> |
||||
</div> |
||||
</td> |
||||
<td class="timeline"> |
||||
<div class="djDebugTimeline"><div class="djDebugLineChart{% if query.is_slow %} djDebugLineChartWarning{% endif %}" style="left:{{ query.start_offset|unlocalize }}%;"><strong style="width:{{ query.width_ratio_relative|unlocalize }}%; background-color:{{ query.trace_color }};">{{ query.width_ratio }}%</strong></div></div> |
||||
</td> |
||||
<td class="djdt-time"> |
||||
{{ query.duration|floatformat:"2" }} |
||||
</td> |
||||
<td class="djdt-actions"> |
||||
|
||||
{% if query.params %} |
||||
{% if query.is_select %} |
||||
<form method="post"> |
||||
{{ query.form }} |
||||
|
||||
<button formaction="{% url 'djdt:sql_select' %}" class="remoteCall">Sel</button> |
||||
<button formaction="{% url 'djdt:sql_explain' %}" class="remoteCall">Expl</button> |
||||
|
||||
{% if query.vendor == 'mysql' %} |
||||
<button formaction="{% url 'djdt:sql_profile' %}" class="remoteCall">Prof</button> |
||||
{% endif %} |
||||
</form> |
||||
{% endif %} |
||||
{% endif %} |
||||
</td> |
||||
</tr> |
||||
<tr class="djUnselected djDebugHoverable {% cycle 'djDebugOdd' 'djDebugEven' %}{% if query.is_slow %} djDebugRowWarning{% endif %} djToggleDetails_{{ forloop.counter }}" id="sqlDetails_{{ forloop.counter }}"> |
||||
<td colspan="2"></td> |
||||
<td colspan="4"> |
||||
<div class="djSQLDetailsDiv"> |
||||
<p><strong>{% trans "Connection:" %}</strong> {{ query.alias }}</p> |
||||
{% if query.iso_level %} |
||||
<p><strong>{% trans "Isolation level:" %}</strong> {{ query.iso_level }}</p> |
||||
{% endif %} |
||||
{% if query.trans_status %} |
||||
<p><strong>{% trans "Transaction status:" %}</strong> {{ query.trans_status }}</p> |
||||
{% endif %} |
||||
{% if query.stacktrace %} |
||||
<pre class="djdt-stack">{{ query.stacktrace }}</pre> |
||||
{% endif %} |
||||
{% if query.template_info %} |
||||
<table> |
||||
{% for line in query.template_info.context %} |
||||
<tr> |
||||
<td>{{ line.num }}</td> |
||||
<td><code style="font-family: monospace;{% if line.highlight %}background-color: lightgrey{% endif %}">{{ line.content }}</code></td> |
||||
</tr> |
||||
{% endfor %} |
||||
</table> |
||||
<p><strong>{{ query.template_info.name|default:_("(unknown)") }}</strong></p> |
||||
{% endif %} |
||||
</div> |
||||
</td> |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
{% else %} |
||||
<p>{% trans "No SQL queries were recorded during this request." %}</p> |
||||
{% endif %} |
||||
|
||||
<script src="{% static 'debug_toolbar/js/toolbar.sql.js' %}"></script> |
||||
@ -1,37 +0,0 @@ |
||||
{% load i18n %}{% load static from staticfiles %} |
||||
<div class="djDebugPanelTitle"> |
||||
<a class="djDebugClose djDebugBack" href=""></a> |
||||
<h3>{% trans "SQL explained" %}</h3> |
||||
</div> |
||||
<div class="djDebugPanelContent"> |
||||
<div class="djdt-scroll"> |
||||
<dl> |
||||
<dt>{% trans "Executed SQL" %}</dt> |
||||
<dd>{{ sql|safe }}</dd> |
||||
<dt>{% trans "Time" %}</dt> |
||||
<dd>{{ duration }} ms</dd> |
||||
<dt>{% trans "Database" %}</dt> |
||||
<dd>{{ alias }}</dd> |
||||
</dl> |
||||
<table class="djSqlExplain"> |
||||
<thead> |
||||
<tr> |
||||
{% for h in headers %} |
||||
<th>{{ h|upper }}</th> |
||||
{% endfor %} |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for row in result %} |
||||
<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}"> |
||||
{% for column in row %} |
||||
<td>{{ column|escape }}</td> |
||||
{% endfor %} |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
</div> |
||||
</div> |
||||
|
||||
<script src="{% static 'debug_toolbar/js/toolbar.sql.js' %}"></script> |
||||
@ -1,44 +0,0 @@ |
||||
{% load i18n %}{% load static from staticfiles %} |
||||
<div class="djDebugPanelTitle"> |
||||
<a class="djDebugClose djDebugBack" href=""></a> |
||||
<h3>{% trans "SQL profiled" %}</h3> |
||||
</div> |
||||
<div class="djDebugPanelContent"> |
||||
<div class="djdt-scroll"> |
||||
{% if result %} |
||||
<dl> |
||||
<dt>{% trans "Executed SQL" %}</dt> |
||||
<dd>{{ sql|safe }}</dd> |
||||
<dt>{% trans "Time" %}</dt> |
||||
<dd>{{ duration }} ms</dd> |
||||
<dt>{% trans "Database" %}</dt> |
||||
<dd>{{ alias }}</dd> |
||||
</dl> |
||||
<table class="djSqlProfile"> |
||||
<thead> |
||||
<tr> |
||||
{% for h in headers %} |
||||
<th>{{ h|upper }}</th> |
||||
{% endfor %} |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for row in result %} |
||||
<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}"> |
||||
{% for column in row %} |
||||
<td>{{ column|escape }}</td> |
||||
{% endfor %} |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
{% else %} |
||||
<dl> |
||||
<dt>{% trans "Error" %}</dt> |
||||
<dd>{{ result_error }}</dd> |
||||
</dl> |
||||
{% endif %} |
||||
</div> |
||||
</div> |
||||
|
||||
<script src="{% static 'debug_toolbar/js/toolbar.sql.js' %}"></script> |
||||
@ -1,41 +0,0 @@ |
||||
{% load i18n %}{% load static from staticfiles %} |
||||
<div class="djDebugPanelTitle"> |
||||
<a class="djDebugClose djDebugBack" href=""></a> |
||||
<h3>{% trans "SQL selected" %}</h3> |
||||
</div> |
||||
<div class="djDebugPanelContent"> |
||||
<div class="djdt-scroll"> |
||||
<dl> |
||||
<dt>{% trans "Executed SQL" %}</dt> |
||||
<dd>{{ sql|safe }}</dd> |
||||
<dt>{% trans "Time" %}</dt> |
||||
<dd>{{ duration }} ms</dd> |
||||
<dt>{% trans "Database" %}</dt> |
||||
<dd>{{ alias }}</dd> |
||||
</dl> |
||||
{% if result %} |
||||
<table class="djSqlSelect"> |
||||
<thead> |
||||
<tr> |
||||
{% for h in headers %} |
||||
<th>{{ h|upper }}</th> |
||||
{% endfor %} |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for row in result %} |
||||
<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}"> |
||||
{% for column in row %} |
||||
<td>{{ column|escape }}</td> |
||||
{% endfor %} |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
{% else %} |
||||
<p>{% trans "Empty set" %}</p> |
||||
{% endif %} |
||||
</div> |
||||
</div> |
||||
|
||||
<script src="{% static 'debug_toolbar/js/toolbar.sql.js' %}"></script> |
||||
@ -1,57 +0,0 @@ |
||||
{% load i18n %} |
||||
{% load static from staticfiles%} |
||||
|
||||
<h4>{% blocktrans count staticfiles_dirs|length as dirs_count %}Static file path{% plural %}Static file paths{% endblocktrans %}</h4> |
||||
{% if staticfiles_dirs %} |
||||
<ol> |
||||
{% for prefix, staticfiles_dir in staticfiles_dirs %} |
||||
<li>{{ staticfiles_dir }}{% if prefix %} {% blocktrans %}(prefix {{ prefix }}){% endblocktrans %}{% endif %}</li> |
||||
{% endfor %} |
||||
</ol> |
||||
{% else %} |
||||
<p>{% trans "None" %}</p> |
||||
{% endif %} |
||||
|
||||
<h4>{% blocktrans count staticfiles_apps|length as apps_count %}Static file app{% plural %}Static file apps{% endblocktrans %}</h4> |
||||
{% if staticfiles_apps %} |
||||
<ol> |
||||
{% for static_app in staticfiles_apps %} |
||||
<li>{{ static_app }}</li> |
||||
{% endfor %} |
||||
</ol> |
||||
{% else %} |
||||
<p>{% trans "None" %}</p> |
||||
{% endif %} |
||||
|
||||
<h4>{% blocktrans count staticfiles|length as staticfiles_count %}Static file{% plural %}Static files{% endblocktrans %}</h4> |
||||
{% if staticfiles %} |
||||
<dl> |
||||
{% for staticfile in staticfiles %} |
||||
<dt><strong><a class="toggleTemplate" href="{{ staticfile.url }}">{{ staticfile }}</a></strong></dt> |
||||
<dd><samp>{{ staticfile.real_path }}</samp></dd> |
||||
{% endfor %} |
||||
</dl> |
||||
{% else %} |
||||
<p>{% trans "None" %}</p> |
||||
{% endif %} |
||||
|
||||
|
||||
{% for finder, payload in staticfiles_finders.items %} |
||||
<h4>{{ finder }} ({% blocktrans count payload|length as payload_count %}{{ payload_count }} file{% plural %}{{ payload_count }} files{% endblocktrans %})</h4> |
||||
<table> |
||||
<thead> |
||||
<tr> |
||||
<th>{% trans 'Path' %}</th> |
||||
<th>{% trans 'Location' %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for path, real_path in payload %} |
||||
<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}"> |
||||
<td>{{ path }}</td> |
||||
<td>{{ real_path }}</td> |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
{% endfor %} |
||||
@ -1,14 +0,0 @@ |
||||
{% load i18n %} |
||||
<div class="djDebugPanelTitle"> |
||||
<a class="djDebugClose djDebugBack" href=""></a> |
||||
<h3>{% trans "Template source:" %} <code>{{ template_name }}</code></h3> |
||||
</div> |
||||
<div class="djDebugPanelContent"> |
||||
<div class="djdt-scroll"> |
||||
{% if not source.pygmentized %} |
||||
<code>{{ source }}</code> |
||||
{% else %} |
||||
{{ source }} |
||||
{% endif %} |
||||
</div> |
||||
</div> |
||||
@ -1,46 +0,0 @@ |
||||
{% load i18n %}{% load static from staticfiles %}{% load url from future %} |
||||
<h4>{% blocktrans count template_dirs|length as template_count %}Template path{% plural %}Template paths{% endblocktrans %}</h4> |
||||
{% if template_dirs %} |
||||
<ol> |
||||
{% for template in template_dirs %} |
||||
<li>{{ template }}</li> |
||||
{% endfor %} |
||||
</ol> |
||||
{% else %} |
||||
<p>{% trans "None" %}</p> |
||||
{% endif %} |
||||
|
||||
<h4>{% blocktrans count templates|length as template_count %}Template{% plural %}Templates{% endblocktrans %}</h4> |
||||
{% if templates %} |
||||
<dl> |
||||
{% for template in templates %} |
||||
<dt><strong><a class="remoteCall toggleTemplate" href="{% url 'djdt:template_source' %}?template={{ template.template.name }}">{{ template.template.name|addslashes }}</a></strong></dt> |
||||
<dd><samp>{{ template.template.origin_name|addslashes }}</samp></dd> |
||||
{% if template.context %} |
||||
<dd> |
||||
<div class="djTemplateShowContextDiv"><a class="djTemplateShowContext"><span class="toggleArrow">▶</span> {% trans "Toggle context" %}</a></div> |
||||
<div class="djTemplateHideContextDiv" style="display:none;"><code>{{ template.context }}</code></div> |
||||
</dd> |
||||
{% endif %} |
||||
{% endfor %} |
||||
</dl> |
||||
{% else %} |
||||
<p>{% trans "None" %}</p> |
||||
{% endif %} |
||||
|
||||
<h4>{% blocktrans count context_processors|length as context_processors_count %}Context processor{% plural %}Context processors{% endblocktrans %}</h4> |
||||
{% if context_processors %} |
||||
<dl> |
||||
{% for key, value in context_processors.items %} |
||||
<dt><strong>{{ key|escape }}</strong></dt> |
||||
<dd> |
||||
<div class="djTemplateShowContextDiv"><a class="djTemplateShowContext"><span class="toggleArrow">▶</span> {% trans "Toggle context" %}</a></div> |
||||
<div class="djTemplateHideContextDiv" style="display:none;"><code>{{ value|escape }}</code></div> |
||||
</dd> |
||||
{% endfor %} |
||||
</dl> |
||||
{% else %} |
||||
<p>{% trans "None" %}</p> |
||||
{% endif %} |
||||
|
||||
<script src="{% static 'debug_toolbar/js/toolbar.template.js' %}"></script> |
||||
@ -1,44 +0,0 @@ |
||||
{% load i18n %}{% load static from staticfiles %} |
||||
<h4>{% trans "Resource usage" %}</h4> |
||||
<table> |
||||
<colgroup> |
||||
<col style="width:20%"/> |
||||
<col/> |
||||
</colgroup> |
||||
<thead> |
||||
<tr> |
||||
<th>{% trans "Resource" %}</th> |
||||
<th>{% trans "Value" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for key, value in rows %} |
||||
<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}"> |
||||
<td>{{ key|escape }}</td> |
||||
<td>{{ value|escape }}</td> |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
|
||||
<!-- This hidden div is populated and displayed by code in toolbar.timer.js --> |
||||
<div id="djDebugBrowserTiming" style="display:none"> |
||||
<h4>{% trans "Browser timing" %}</h4> |
||||
<table> |
||||
<colgroup> |
||||
<col style="width:20%"/> |
||||
<col style="width:60%"/> |
||||
<col style="width:20%"/> |
||||
</colgroup> |
||||
<thead> |
||||
<tr> |
||||
<th>{% trans "Timing attribute" %}</th> |
||||
<th class="timeline">{% trans "Timeline" %}</th> |
||||
<th class="djdt-time">{% trans "Milliseconds since navigation start (+length)" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody id="djDebugBrowserTimingTableBody"> |
||||
</tbody> |
||||
</table> |
||||
</div> |
||||
<script src="{% static 'debug_toolbar/js/toolbar.timer.js' %}"></script> |
||||
@ -1,17 +0,0 @@ |
||||
{% load i18n %} |
||||
<table> |
||||
<thead> |
||||
<tr> |
||||
<th>{% trans "Name" %}</th> |
||||
<th>{% trans "Version" %}</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{% for package, version in versions.items %} |
||||
<tr class="{% cycle 'djDebugOdd' 'djDebugEven' %}"> |
||||
<td>{{ package }}</td> |
||||
<td>{{ version }}</td> |
||||
</tr> |
||||
{% endfor %} |
||||
</tbody> |
||||
</table> |
||||
@ -1,16 +0,0 @@ |
||||
{% load i18n %} |
||||
<!DOCTYPE html> |
||||
<html> |
||||
<head> |
||||
</head> |
||||
<body> |
||||
<h1>{{ status_line }}</h1> |
||||
<h2>{% trans "Location:" %} <a id="redirect_to" href="{{ redirect_to }}">{{ redirect_to }}</a></h2> |
||||
<p class="notice"> |
||||
{% trans "The Django Debug Toolbar has intercepted a redirect to the above URL for debug viewing purposes. You can click the above link to continue with the redirect as normal." %} |
||||
</p> |
||||
<script type="text/javascript"> |
||||
document.getElementById('redirect_to').focus(); |
||||
</script> |
||||
</body> |
||||
</html> |
||||