You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
109 lines
3.6 KiB
109 lines
3.6 KiB
//----------------------------------------------------------------------------
|
|
// 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
|
|
//============================================================================
|
|
|
|
var IPython = (function (IPython) {
|
|
|
|
var utils = IPython.utils;
|
|
|
|
var Tooltip = function (notebook) {
|
|
this.tooltip = $('#tooltip');
|
|
this.text = $('<pre/>')
|
|
};
|
|
|
|
|
|
|
|
//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.
|
|
if (this.tooltip_timeout != null){
|
|
clearTimeout(this.tooltip_timeout);
|
|
$('#tooltip').remove();
|
|
this.tooltip_timeout = null;
|
|
}
|
|
}
|
|
Tooltip.prototype.show = function()
|
|
{
|
|
this.tooltip.removeClass('hidden');
|
|
}
|
|
|
|
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);
|
|
}
|
|
|
|
Tooltip.prototype.finish_tooltip = function (reply) {
|
|
|
|
var expandlink=$('<a/>').attr('href',"#");
|
|
expandlink.addClass("ui-corner-all"); //rounded corner
|
|
expandlink.attr('role',"button");
|
|
|
|
var expandspan=$('<span/>').text('Expand');
|
|
expandspan.addClass('ui-icon');
|
|
expandspan.addClass('ui-icon-plus');
|
|
|
|
expandlink.append(expandspan);
|
|
expandlink.attr('id','expanbutton');
|
|
expandlink.click(function(){
|
|
tooltip.removeClass('smalltooltip');
|
|
tooltip.addClass('bigtooltip');
|
|
$('#expanbutton').remove();
|
|
setTimeout(function(){that.code_mirror.focus();}, 50);
|
|
});
|
|
|
|
var morelink=$('<a/>').attr('href',"#");
|
|
morelink.attr('role',"button");
|
|
morelink.addClass('ui-button');
|
|
var morespan=$('<span/>').text('Open in Pager');
|
|
morespan.addClass('ui-icon');
|
|
morespan.addClass('ui-icon-arrowstop-l-n');
|
|
morelink.append(morespan);
|
|
morelink.click(function(){
|
|
this.showInPager();
|
|
});
|
|
|
|
|
|
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.remove_and_cancel_tooltip();
|
|
setTimeout(function(){that.code_mirror.focus();}, 50);
|
|
});
|
|
//construct the tooltip
|
|
tooltip.append(closelink);
|
|
tooltip.append(expandlink);
|
|
tooltip.append(morelink);
|
|
|
|
var pos = this.code_mirror.cursorCoords();
|
|
tooltip.css('left',pos.x+'px');
|
|
tooltip.css('top',pos.yBot+'px');
|
|
|
|
};
|
|
|
|
|
|
IPython.Tooltip = Tooltip;
|
|
|
|
return IPython;
|
|
}(IPython));
|