|
|
//----------------------------------------------------------------------------
|
|
|
// Copyright (C) 2008-2011 The IPython Development Team
|
|
|
//
|
|
|
// Distributed under the terms of the BSD License. The full license is in
|
|
|
// the file COPYING, distributed as part of this software.
|
|
|
//----------------------------------------------------------------------------
|
|
|
|
|
|
//============================================================================
|
|
|
// Tooltip
|
|
|
//============================================================================
|
|
|
|
|
|
// Todo :
|
|
|
// use codemirror highlight example to
|
|
|
// highlight the introspection request and introspect on mouse hove ...
|
|
|
//
|
|
|
//
|
|
|
var IPython = (function (IPython) {
|
|
|
|
|
|
var utils = IPython.utils;
|
|
|
|
|
|
var Tooltip = function (notebook) {
|
|
|
this.tooltip = $('#tooltip');
|
|
|
var that = this;
|
|
|
this._hidden = true;
|
|
|
|
|
|
// contain the button in the upper right corner
|
|
|
this.buttons = $('<div/>')
|
|
|
.addClass('tooltipbuttons');
|
|
|
|
|
|
// will contain the docstring
|
|
|
this.text = $('<div/>')
|
|
|
.addClass('tooltiptext')
|
|
|
.addClass('smalltooltip');
|
|
|
|
|
|
var tooltip = this.tooltip;
|
|
|
var text = this.text;
|
|
|
|
|
|
// build the buttons menu on the upper right
|
|
|
|
|
|
// expand the tooltip to see more
|
|
|
var expandlink=$('<a/>').attr('href',"#")
|
|
|
.addClass("ui-corner-all") //rounded corner
|
|
|
.attr('role',"button")
|
|
|
.attr('id','expanbutton')
|
|
|
.click(function(){
|
|
|
text.removeClass('smalltooltip');
|
|
|
text.addClass('bigtooltip');
|
|
|
$('#expanbutton').addClass('hidden');
|
|
|
//setTimeout(function(){that.code_mirror.focus();}, 50);
|
|
|
})
|
|
|
.append(
|
|
|
$('<span/>').text('Expand')
|
|
|
.addClass('ui-icon')
|
|
|
.addClass('ui-icon-plus')
|
|
|
);
|
|
|
|
|
|
// open in pager
|
|
|
var morelink=$('<a/>').attr('href',"#")
|
|
|
.attr('role',"button")
|
|
|
.addClass('ui-button');
|
|
|
var morespan=$('<span/>').text('Open in Pager')
|
|
|
.addClass('ui-icon')
|
|
|
.addClass('ui-icon-arrowstop-l-n');
|
|
|
morelink.append(morespan);
|
|
|
morelink.click(function(){
|
|
|
var msg_id = IPython.notebook.kernel.execute(name+"?");
|
|
|
IPython.notebook.msg_cell_map[msg_id] = IPython.notebook.get_selected_cell().cell_id;
|
|
|
that.remove_and_cancel_tooltip();
|
|
|
setTimeout(function(){that.code_mirror.focus();}, 50);
|
|
|
});
|
|
|
|
|
|
// close the tooltip
|
|
|
var closelink=$('<a/>').attr('href',"#");
|
|
|
closelink.attr('role',"button");
|
|
|
closelink.addClass('ui-button');
|
|
|
var closespan=$('<span/>').text('Close');
|
|
|
closespan.addClass('ui-icon');
|
|
|
closespan.addClass('ui-icon-close');
|
|
|
closelink.append(closespan);
|
|
|
closelink.click(function(){
|
|
|
that.hide();
|
|
|
});
|
|
|
|
|
|
//construct the tooltip
|
|
|
// add in the reverse order you want them to appear
|
|
|
this.buttons.append(closelink);
|
|
|
this.buttons.append(expandlink);
|
|
|
this.buttons.append(morelink);
|
|
|
|
|
|
// we need a phony element to make the small arrow
|
|
|
// of the tooltip in css
|
|
|
// we could try to move the arrow later
|
|
|
arrow = $('<div/>').addClass('pretooltiparrow');
|
|
|
this.tooltip.append(arrow);
|
|
|
this.tooltip.append(this.buttons);
|
|
|
this.tooltip.append(this.text);
|
|
|
};
|
|
|
|
|
|
// deal with all the logic of hiding the tooltip
|
|
|
// and reset it's status
|
|
|
Tooltip.prototype.hide = function()
|
|
|
{
|
|
|
this.tooltip.addClass('hide');
|
|
|
$('#expanbutton').removeClass('hidden');
|
|
|
this.text.removeClass('bigtooltip');
|
|
|
this.text.addClass('smalltooltip');
|
|
|
// keep scroll top to be sure to always see the first line
|
|
|
this.text.scrollTop(0);
|
|
|
this._hidden = true;
|
|
|
}
|
|
|
|
|
|
//TODO, try to diminish the number of parameters.
|
|
|
Tooltip.prototype.request_tooltip_after_time = function (pre_cursor,time){
|
|
|
};
|
|
|
|
|
|
|
|
|
Tooltip.prototype.remove_and_cancel_tooltip = function() {
|
|
|
// note that we don't handle closing directly inside the calltip
|
|
|
// as in the completer, because it is not focusable, so won't
|
|
|
// get the event.
|
|
|
this.hide();
|
|
|
if (this.tooltip_timeout != null){
|
|
|
clearTimeout(this.tooltip_timeout);
|
|
|
this.tooltip_timeout = null;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
Tooltip.prototype.show = function(reply,pos)
|
|
|
{
|
|
|
// move the bubble if it is not hidden
|
|
|
// otherwise fade it
|
|
|
if( this._hidden == false)
|
|
|
{
|
|
|
this.tooltip.animate({'left' : pos.x-30+'px','top' :(pos.yBot+10)+'px'});
|
|
|
} else
|
|
|
{
|
|
|
this.tooltip.css({'left' : pos.x-30+'px'});
|
|
|
this.tooltip.css({'top' :(pos.yBot+10)+'px'});
|
|
|
}
|
|
|
this.tooltip.removeClass('hidden')
|
|
|
this.tooltip.removeClass('hide');
|
|
|
this._hidden = false;
|
|
|
|
|
|
// build docstring
|
|
|
defstring = reply.call_def;
|
|
|
if (defstring == null) { defstring = reply.init_definition; }
|
|
|
if (defstring == null) { defstring = reply.definition; }
|
|
|
|
|
|
docstring = reply.call_docstring;
|
|
|
if (docstring == null) { docstring = reply.init_docstring; }
|
|
|
if (docstring == null) { docstring = reply.docstring; }
|
|
|
if (docstring == null) { docstring = "<empty docstring>"; }
|
|
|
|
|
|
this.text.children().remove();
|
|
|
|
|
|
var pre=$('<pre/>').html(utils.fixConsole(docstring));
|
|
|
if(defstring){
|
|
|
var defstring_html = $('<pre/>').html(utils.fixConsole(defstring));
|
|
|
this.text.append(defstring_html);
|
|
|
}
|
|
|
this.text.append(pre);
|
|
|
// keep scroll top to be sure to always see the first line
|
|
|
this.text.scrollTop(0);
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
Tooltip.prototype.showInPager = function(){
|
|
|
var msg_id = IPython.notebook.kernel.execute(name+"?");
|
|
|
IPython.notebook.msg_cell_map[msg_id] = IPython.notebook.get_selected_cell().cell_id;
|
|
|
that.remove_and_cancel_tooltip();
|
|
|
setTimeout(function(){that.code_mirror.focus();}, 50);
|
|
|
}
|
|
|
|
|
|
|
|
|
IPython.Tooltip = Tooltip;
|
|
|
|
|
|
return IPython;
|
|
|
}(IPython));
|
|
|
|