J'ai fait ce petit outil en octobre 2008, ça date un peu... mais même s'il ne vous sert pas en tant que tel, son code et la manière dont il a été réalisé peut vous intéresser.
Ca sert à loguer des choses et checker le timing d'exécution de vos fonctions javascript.
Vous pouvez utiliser des raccourcis claviers comme F2, ALT+F2,... pour animer les fonctionnalités de la boîte de dialogue jLog.
En mode "standard", la boîte est invisible. Il faut faire F2 pour la faire apparaître. Ce n'est pas le cas dans l'exemple ci-dessous.
Le plugin
Vous avez juste à intégrer jQuery (si ce n'est pas déjà le cas), jLog avec le css qui va avec (customizable par vous bien sûr...). Et il reste plus qu'à utiliser :)
<script type="text/javascript" src="jQuery.js" ></script>
<script type="text/javascript" src="jLog.js" ></script>
<link rel="stylesheet" type="text/css" href="jLog.css" />
jLog.css
/*********************************************************************************
# jLog - Open Source Javascript script based on jQuery Javascript Library
#
# Author : Arnaud BUATHIER
# Web : http://arnapou.net
# Version : 1.0 (2008-10-23)
#
# Copyright (c) 2008 Arnaud BUATHIER
#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included in
# all copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
# THE SOFTWARE.
*********************************************************************************/
#jLog {
position: fixed;
_position: absolute; /* IE hack */
z-index: 99;
width: 270px;
height: 250px;
border: 1px solid #cccccc;
background-color: transparent;
padding: 21px 0px 0px 0px;
margin: 0px;
overflow: hidden;
cursor: default;
}
#jLog * {
color: white;
font-size: 11px;
font-family: Consolas, 'Lucida Console', Monaco, monospace, Courier New;
}
/********** Resize **********/
#jLog.large {
width: 500px;
height: 580px;
}
/********** Positions **********/
#jLog.top_left {
top: 5px;
left: 5px;
}
#jLog.top_right {
top: 5px;
right: 5px;
}
#jLog.bottom_left {
bottom: 5px;
left: 5px;
}
#jLog.bottom_right {
bottom: 5px;
right: 5px;
}
/********** Blocks **********/
#jLog .jLogHeader,
#jLog .jLogBody,
#jLog .jLogBgBody {
position: absolute;
top: 0px;
left: 0px;
width: 100%;
height: 100%;
border: 0px;
padding: 0px;
margin: 0px;
}
#jLog .jLogHeader {
height: 20px;
border-bottom: 1px dotted #555555;
background-color: #111111;
z-index: 5;
}
#jLog .jLogHeaderLeft {
float: left;
padding: 3px 0px 0px 3px;
}
#jLog .jLogHeaderRight {
float: right;
padding: 3px 3px 0px 0px;
}
#jLog .jLogBody {
top: 21px;
background-color: transparent;
overflow: scroll;
overflow-y: auto;
overflow-x: hidden;
z-index: 2;
}
#jLog .jLogBgBody {
background-color: #111111;
z-index: 1;
}
#jLog .jLogBody ul {
border: 0px;
padding: 3px 3px;
margin: 0px;
list-style-type: none;
list-style-image: none;
}
#jLog .jLogBody ul.jLog_Debug li.jLog_Debug {
display: none;
}
#jLog .jLogBody ul.jLog_Info li.jLog_Info {
display: none;
}
#jLog .jLogBody ul.jLog_Warn li.jLog_Warn {
display: none;
}
#jLog .jLogBody ul.jLog_Error li.jLog_Error {
display: none;
}
#jLog .jLogBody ul.jLog_Timer li.jLog_Timer {
display: none;
}
#jLog .jLogBody ul.jLog_ShowTimes span.jLog_Time {
display: block;
}
#jLog .jLogBody ul li {
border: 0px;
padding: 1px 0px;
margin: 0px;
list-style-type: none;
list-style-image: none;
overflow: hidden;
}
/********** Buttons **********/
#jLog span.jLog_Close,
#jLog span.jLog_ShowTimes,
#jLog span.jLog_Resize,
#jLog span.jLog_Clear,
#jLog span.jLog_Move,
#jLog span.jLog_Debug,
#jLog span.jLog_Info,
#jLog span.jLog_Warn,
#jLog span.jLog_Error,
#jLog span.jLog_Timer {
display: block;
float: left;
padding: 0px 1px;
width: 12px;
text-align: center;
margin: 0px 2px 0px 0px;
}
/********** Close **********/
#jLog span.jLog_Close {
background-color: #993333;
margin: 0px 10px 0px 0px;
}
#jLog span.jLog_Close_Over {
color: #993333;
background-color: #ffffff;
}
/********** ShowTimes **********/
#jLog span.jLog_ShowTimes {
background-color: #777799;
}
#jLog span.jLog_ShowTimes_Over {
color: #777799;
background-color: #ffffff;
}
/********** Resize **********/
#jLog span.jLog_Resize {
background-color: #777799;
}
#jLog span.jLog_Resize_Over {
color: #777799;
background-color: #ffffff;
}
/********** Clear **********/
#jLog span.jLog_Clear {
background-color: #777799;
}
#jLog span.jLog_Clear_Over {
color: #777799;
background-color: #ffffff;
}
/********** Move **********/
#jLog span.jLog_Move {
background-color: #777799;
}
#jLog span.jLog_Move_Over {
color: #777799;
background-color: #ffffff;
}
/********** Debug **********/
#jLog span.jLog_Debug {
background-color: #4f8600;
}
#jLog span.jLog_Debug_Over {
color: #4f8600;
background-color: #ffffff;
}
/********** Info **********/
#jLog span.jLog_Info {
background-color: #0056cc;
}
#jLog span.jLog_Info_Over {
color: #0056cc;
background-color: #ffffff;
}
/********** Warn **********/
#jLog span.jLog_Warn {
background-color: #c08000;
}
#jLog span.jLog_Warn_Over {
color: #c08000;
background-color: #ffffff;
}
/********** Error **********/
#jLog span.jLog_Error {
background-color: #cc0000;
}
#jLog span.jLog_Error_Over {
color: #cc0000;
background-color: #ffffff;
}
/********** Timer **********/
#jLog span.jLog_Timer {
background-color: #666666;
}
#jLog span.jLog_Timer_Over {
color: #666666;
background-color: #ffffff;
}
/********** Filters Selected **********/
#jLog span.jLog_Filter_Selected {
color: #000000;
background-color: #bbbbbb;
}
/********** Time **********/
#jLog span.jLog_Time {
display: block;
float: left;
padding: 0px 1px;
text-align: center;
color: #666666;
margin: 0px 2px 0px 0px;
display: none;
}
jLog.js
/*********************************************************************************
# jLog - Open Source Javascript script based on jQuery Javascript Library
#
# Author : Arnaud BUATHIER
# Web : http://arnapou.net
# Version : 1.0 (2008-10-23)
#
# Copyright (c) 2008 Arnaud BUATHIER
#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included in
# all copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
# THE SOFTWARE.
*********************************************************************************/
var jLog = {
obj: null,
body: null,
header: null,
log: null,
start_time: null,
position: 0,
times: [],
filters: [],
large: false,
add: function(cl, ch, msg) {
var i, t, m, f, s, li;
t = ((new Date()).getTime() - jLog.start_time)/1000;
i = Math.floor(t);
m = Math.floor(i/60);
s = i%60;
f = Math.floor(1000*(t - i));
if(m < 10) { m = '0'+m; }
if(s < 10) { s = '0'+s; }
if(f < 10) { f = '00'+f; } else if(f < 100) { f = '0'+f; }
li = document.createElement('li');
li.className = cl;
li.innerHTML = '<span class="'+cl+'">'+ch+'</span><span class="jLog_Time">'+m+':'+s+'.'+f+'</span>'+msg;
jLog.log.appendChild(li);
jLog.body.scrollTop = jLog.body.scrollHeight;
},
toggle: function() {
if(jLog.obj.css('display') == 'block') {
jLog.hide();
}
else {
jLog.show();
}
},
onresize: function() {
jLog.obj.find('.jLogBody').height(jLog.obj.height());
},
show: function() {
jLog.obj.css('display', 'block');
jLog.onresize();
},
hide: function() {
jLog.obj.css('display', 'none');
},
move: function(position) {
if(typeof(position) != 'number') {
jLog.position = (jLog.position + 1)%4;
}
else {
jLog.position = position%4;
}
var large = '';
if(jLog.large) {
large = ' large';
}
switch(jLog.position) {
case 1:
jLog.obj.attr('className', 'top_right'+large);
jLog.header.find('span.jLog_Move').html('↓');
break;
case 2:
jLog.obj.attr('className', 'bottom_right'+large);
jLog.header.find('span.jLog_Move').html('←');
break;
case 3:
jLog.obj.attr('className', 'bottom_left'+large);
jLog.header.find('span.jLog_Move').html('↑');
break;
default:
jLog.obj.attr('className', 'top_left'+large);
jLog.header.find('span.jLog_Move').html('→');
jLog.position = 0;
break;
}
},
resize: function() {
if(jLog.large) {
jLog.obj.removeClass('large');
jLog.header.find('span.jLog_Resize').html('∨');
}
else {
jLog.obj.addClass('large');
jLog.header.find('span.jLog_Resize').html('∧');
}
jLog.large = !jLog.large;
jLog.onresize();
},
onkeyup: function(e) {
if(!e) {
e = window.event;
}
if(e && e.keyCode == 113) { // F2 key
if(e.shiftKey && !e.ctrlKey && !e.altKey) {
jLog.move();
}
else if(!e.shiftKey && e.ctrlKey && !e.altKey) {
if(jLog.large) {
jLog.resize();
jLog.hide_times();
}
else {
jLog.resize();
jLog.show_times();
}
}
else if(e.shiftKey && e.ctrlKey && !e.altKey) {
jLog.clear();
}
else {
jLog.toggle();
}
}
},
init: function() {
if(jLog.obj) {
return false;
}
jQuery('body').append('<div id="jLog" style="display:none" class="top_left"><div class="jLogBgBody"></div><div class="jLogHeader"><div class="jLogHeaderLeft"><span class="jLog_Debug jLog_Filter" title="Debug">√</span><span class="jLog_Info jLog_Filter" title="Info">i</span><span class="jLog_Warn jLog_Filter" title="Warning">w</span><span class="jLog_Error jLog_Filter" title="Error">!</span><span class="jLog_Timer jLog_Filter" title="Timer">t</span></div><div class="jLogHeaderRight"><span class="jLog_Close" title="Hide (F2 key)">X</span><span class="jLog_ShowTimes jLog_Filter" title="Show/Hide Times">@</span><span class="jLog_Clear" title="Clear (Alt+F2 Key)">Ø</span><span class="jLog_Move" title="Move (Shift+F2 key)">→</span><span class="jLog_Resize" title="Resize">∨</span></div></div><div class="jLogBody"><ul></ul></div></div>');
jLog.obj = jQuery('#jLog');
jLog.obj.find('.jLogBgBody').css('opacity', 0.9);
jLog.log = jLog.obj.find('ul').get(0);
jLog.body = jLog.obj.find('.jLogBody').get(0);
jLog.header = jLog.obj.find('.jLogHeader').eq(0);
jLog.header.find('span').css('cursor', 'pointer').hover(jLog.button_over,jLog.button_out);
jLog.header.find('span.jLog_Filter').click(jLog.filter_click);
jLog.header.find('span.jLog_Move').click(jLog.move);
jLog.header.find('span.jLog_Clear').click(jLog.clear);
jLog.header.find('span.jLog_Resize').click(jLog.resize);
jLog.header.find('span.jLog_Close').click(jLog.hide);
jLog.onresize();
jLog.start_time = (new Date()).getTime();
jQuery(document).keyup(jLog.onkeyup);
return true;
},
show_times: function() {
var obj = jLog.header.find('span.jLog_ShowTimes').get(0);
obj.className = 'jLog_ShowTimes';
jLog.apply_filter(obj);
},
hide_times: function() {
var obj = jLog.header.find('span.jLog_ShowTimes').get(0);
obj.className = 'jLog_ShowTimes jLog_Filter_Selected';
jLog.apply_filter(obj);
},
toggle_times: function() {
jLog.apply_filter(jLog.header.find('span.jLog_ShowTimes').get(0));
},
button_over: function() {
var cl = (this.className.split(' '))[0];
jQuery(this).addClass(cl+'_Over');
},
button_out: function() {
var cl = (this.className.split(' '))[0];
jQuery(this).removeClass(cl+'_Over');
},
filter_click: function() {
jLog.apply_filter(this);
},
toggle_filter: function(type) {
var cl = null;
switch(type) {
case 'debug': cl = 'jLog_Debug'; break;
case 'info': cl = 'jLog_Info'; break;
case 'warn': cl = 'jLog_Warn'; break;
case 'error': cl = 'jLog_Error'; break;
case 'timer': cl = 'jLog_Timer'; break;
}
if(cl) {
var obj = jLog.header.find('span.'+cl).get(0);
jLog.apply_filter(obj);
}
},
filter: function(type, val) {
var cl = null;
switch(type) {
case 'debug': cl = 'jLog_Debug'; break;
case 'info': cl = 'jLog_Info'; break;
case 'warn': cl = 'jLog_Warn'; break;
case 'error': cl = 'jLog_Error'; break;
case 'timer': cl = 'jLog_Timer'; break;
}
if(cl) {
var obj = jLog.header.find('span.'+cl).get(0);
if(val) {
obj.className = cl;
}
else {
obj.className = cl+' jLog_Filter_Selected';
}
jLog.apply_filter(obj);
}
},
apply_filter: function(obj) {
var cl = (obj.className.split(' '))[0];
var filters = [], i;
if(obj.className.match(/jLog_Filter_Selected/i)) {
for(i in jLog.filters) {
if(jLog.filters[i] != cl) {
filters.push(jLog.filters[i]);
}
}
jLog.filters = filters;
jQuery(obj).removeClass('jLog_Filter_Selected');
}
else {
jLog.filters.push(cl);
jQuery(obj).addClass('jLog_Filter_Selected');
}
jLog.log.className = jLog.filters.join(' ');
},
clear: function(msg) {
jLog.log.innerHTML = '';
},
debug: function(msg) {
jLog.add('jLog_Debug', '√', msg);
},
info: function(msg) {
jLog.add('jLog_Info', 'i', msg);
},
warn: function(msg) {
jLog.add('jLog_Warn', 'w', msg);
},
error: function(msg) {
jLog.add('jLog_Error', '!', msg);
},
timer: function(key, msg) {
if(jLog.times[key]) {
var duree = (new Date()).getTime() - jLog.times[key];
jLog.times[key] = 0;
if(msg) {
jLog.add('jLog_Timer', 't', msg+' ('+duree+' ms)');
}
else {
jLog.add('jLog_Timer', 't', key+' ('+duree+' ms)');
}
}
else {
jLog.times[key] = (new Date()).getTime();
}
}
};
jQuery(document).ready(function() {
jLog.init();
});