##// END OF EJS Templates
Merge pull request #1325 from Carreau/fix-tooltip-showpager...
Merge pull request #1325 from Carreau/fix-tooltip-showpager forgotten selected_cell -> get_selected_cell

File last commit:

r5950:5caff73c
r5968:bf552392 merge
Show More
fulleditwidget.js
119 lines | 4.4 KiB | application/javascript | JavascriptLexer
Brian Granger
Add Ace editing mode for code cells.
r5904 //----------------------------------------------------------------------------
// 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.
//----------------------------------------------------------------------------
//============================================================================
// MenuBar
//============================================================================
var IPython = (function (IPython) {
var FullEditWidget = function (selector) {
this.selector = selector;
this.opened = false;
if (this.selector !== undefined) {
this.element = $(selector);
this.style();
this.bind_events();
}
};
FullEditWidget.prototype.style = function () {
var that = this;
this.element.find('#close_fulledit').button().on('click', function (){
that.close();
})
this.element.find('#fulledit_header').addClass('ui-widget ui-widget-header');
this.element.find('#fulledit_editor').addClass('ui-widget ui-widget-content');
this.ace_editor = ace.edit("fulledit_editor");
this.ace_editor.setTheme("ace/theme/textmate");
var PythonMode = require("ace/mode/python").Mode;
this.ace_editor.getSession().setMode(new PythonMode());
this.ace_editor.getSession().setTabSize(4);
this.ace_editor.getSession().setUseSoftTabs(true);
this.ace_editor.setHighlightActiveLine(false);
Brian Granger
Minor changes to Ace widget....
r5906 // Ace sets its css dynamically, so we need to do this here. These
// values are chosen to match those of our CodeMirror editors.
$('.ace_editor').css({fontFamily: 'monospace', fontSize: '110%',
lineHeight: '1.231'});
Brian Granger
Add Ace editing mode for code cells.
r5904 };
FullEditWidget.prototype.bind_events = function () {
};
FullEditWidget.prototype.open = function () {
Brian Granger
Refactoring of the notebooks cell management....
r5945 var cell = IPython.notebook.get_selected_cell();
Brian Granger
Ace editor now works with Markdown and HTML cells with proper modes.
r5947 if (!this.opened) {
Brian Granger
Add Ace editing mode for code cells.
r5904 $('#fulledit_widget').show();
$('#main_app').hide();
$('#menubar').hide();
$('body').css({overflow : 'auto'});
Brian Granger
Work on the base Cell API....
r5943 var code = cell.get_text();
Brian Granger
Add Ace editing mode for code cells.
r5904 this.ace_editor.getSession().setValue(code);
Brian Granger
Ace editor now works with Markdown and HTML cells with proper modes.
r5947 if (cell instanceof IPython.CodeCell) {
var PythonMode = require("ace/mode/python").Mode;
this.ace_editor.getSession().setMode(new PythonMode());
} else if (cell instanceof IPython.MarkdownCell) {
var MarkdownMode = require("ace/mode/markdown").Mode;
this.ace_editor.getSession().setMode(new MarkdownMode());
} else if (cell instanceof IPython.HTMLCell) {
var HTMLMode = require("ace/mode/html").Mode;
this.ace_editor.getSession().setMode(new HTMLMode());
};
Brian Granger
Add Ace editing mode for code cells.
r5904 this.ace_editor.focus();
Brian Granger
Updating Ace to dev master to fix bug....
r5905 // On Safari (and Chrome/FF on Linux) the editor doesn't get
// focus unless there is a window resize. For now, we trigger it
// by hand until the bug is fixed upstream.
window.resizeBy(0,1);
window.resizeBy(0,-1);
Brian Granger
Add Ace editing mode for code cells.
r5904 this.opened = true;
};
};
FullEditWidget.prototype.close = function () {
if (this.opened) {
$('#fulledit_widget').hide();
$('#main_app').show();
Brian Granger
Fixing bugs in CodeMirror refreshing.
r5950 // We may need to add a refresh to all CM based cells after
// showing them.
Brian Granger
Add Ace editing mode for code cells.
r5904 $('#menubar').show();
$('body').css({overflow : 'hidden'});
var code = this.ace_editor.getSession().getValue();
Brian Granger
Refactoring of the notebooks cell management....
r5945 var cell = IPython.notebook.get_selected_cell();
Brian Granger
Ace editor now works with Markdown and HTML cells with proper modes.
r5947 if (cell instanceof IPython.CodeCell) {
Brian Granger
Fixing bugs in CodeMirror refreshing.
r5950 cell.code_mirror.refresh();
Brian Granger
Ace editor now works with Markdown and HTML cells with proper modes.
r5947 cell.set_text(code);
} else if (cell instanceof IPython.MarkdownCell || cell instanceof IPython.HTMLCell) {
cell.edit();
Brian Granger
Fixing bugs in CodeMirror refreshing.
r5950 // If the cell was already in edit mode, we need to refresh/focus.
cell.code_mirror.refresh();
Brian Granger
Ace editor now works with Markdown and HTML cells with proper modes.
r5947 cell.code_mirror.focus();
cell.set_text(code);
};
Brian Granger
Add Ace editing mode for code cells.
r5904 this.opened = false;
};
};
FullEditWidget.prototype.toggle = function () {
if (this.opened) {
this.close();
} else {
this.open();
};
};
IPython.FullEditWidget = FullEditWidget;
return IPython;
}(IPython));