##// END OF EJS Templates
Backport PR #8203: autosave & reload on kernelspec switch...
Backport PR #8203: autosave & reload on kernelspec switch when a custom kernel.js was defined, in which case reload is needed to ensure clean js state. closes #7783

File last commit:

r20702:f029025f
r21106:c00d848f
Show More
textcell.js
374 lines | 11.7 KiB | application/javascript | JavascriptLexer
Jonathan Frederic
Progress...
r17196 // Copyright (c) IPython Development Team.
// Distributed under the terms of the Modified BSD License.
define([
'base/js/namespace',
MinRK
move mergeopt to utils...
r17764 'base/js/utils',
Jonathan Frederic
MWE,...
r17200 'jquery',
Jonathan Frederic
Progress...
r17196 'notebook/js/cell',
'base/js/security',
Thomas Kluyver
Remove user_config js module
r19529 'services/config',
Jonathan Frederic
MWE,...
r17200 'notebook/js/mathjaxutils',
'notebook/js/celltoolbar',
Jonathan Frederic
nbconvert api tests fixes
r17205 'components/marked/lib/marked',
Matthias BUSSONNIER
Update to codemirror 4...
r18280 'codemirror/lib/codemirror',
'codemirror/mode/gfm/gfm',
'notebook/js/codemirror-ipythongfm'
Thomas Kluyver
Remove user_config js module
r19529 ], function(IPython,
utils,
$,
cell,
security,
configmod,
mathjaxutils,
celltoolbar,
marked,
CodeMirror,
gfm,
ipgfm
) {
Matthias BUSSONNIER
patch header-cell and use-strict
r11526 "use strict";
Jonathan Frederic
Fix all the bugs!
r17203 var Cell = cell.Cell;
Brian E. Granger
Splitting notebook.js into muliple files for development ease.
r4349
jon
In person review with @ellisonbg
r17210 var TextCell = function (options) {
Jonathan Frederic
Ran function comment conversion tool
r19176 /**
* Constructor
*
* Construct a new TextCell, codemirror mode is by default 'htmlmixed',
* and cell type is 'text' cell start as not redered.
*
* Parameters:
* options: dictionary
* Dictionary of keyword arguments.
* events: $(Events) instance
* config: dictionary
* keyboard_manager: KeyboardManager instance
* notebook: Notebook instance
*/
jon
In person review with @ellisonbg
r17210 options = options || {};
jon
Added some nice comments,...
r17211
Matthias BUSSONNIER
JS Configurablity Take 2...
r10165 // in all TextCell/Cell subclasses
// do not assign most of members here, just pass it down
// in the options dict potentially overwriting what you wish.
// they will be assigned in the base class.
jon
In person review with @ellisonbg
r17210 this.notebook = options.notebook;
this.events = options.events;
this.config = options.config;
Jonathan Frederic
MWE,...
r17200
Matthias BUSSONNIER
JS Configurablity Take 2...
r10165 // we cannot put this as a class key as it has handle to "this".
foogunlana
Fixed code mirror skipping Markdown cell bug
r19098 var config = utils.mergeopt(TextCell, this.config);
jon
In person review with @ellisonbg
r17210 Cell.apply(this, [{
config: config,
keyboard_manager: options.keyboard_manager,
Jonathan Frederic
Some JS test fixes
r17212 events: this.events}]);
Matthias BUSSONNIER
Make CodeMirror configurable...
r9537
MinRK
give Raw Cells a placeholder...
r13668 this.cell_type = this.cell_type || 'text';
Jonathan Frederic
MWE,...
r17200 mathjaxutils = mathjaxutils;
Brian E. Granger
Implemented module and namespace pattern in js notebook.
r4352 this.rendered = false;
};
Matthias Bussonnier
Use low overhead object heritence in Js (Object.create vs new)...
r18377 TextCell.prototype = Object.create(Cell.prototype);
Matthias BUSSONNIER
JS Configurablity Take 2...
r10165
TextCell.options_default = {
cm_config : {
extraKeys: {"Tab": "indentMore","Shift-Tab" : "indentLess"},
mode: 'htmlmixed',
Matthias BUSSONNIER
Make CodeMirror configurable...
r9537 lineWrapping : true,
}
Matthias BUSSONNIER
JS Configurablity Take 2...
r10165 };
Matthias BUSSONNIER
Make CodeMirror configurable...
r9537
Matthias BUSSONNIER
Document more function....
r8711 /**
* Create the DOM element of the TextCell
Matthias BUSSONNIER
start to document js
r8709 * @method create_element
* @private
*/
Brian Granger
Refactoring of text/markdown/rst/html cells.
r4508 TextCell.prototype.create_element = function () {
Jonathan Frederic
Fix all the bugs!
r17203 Cell.prototype.create_element.apply(this, arguments);
Min RK
enable keyboard manager when codemirror is focused...
r20118 var that = this;
Brian E. Granger
Adding prompt area to non-CodeCells to indent content....
r13776
Matthias BUSSONNIER
Transfer of border-box-sizing from js to css...
r17422 var cell = $("<div>").addClass('cell text_cell');
Brian E. Granger
Better tabindex support.
r4629 cell.attr('tabindex','2');
Brian Granger
Further cleanup for celltoolbars.
r9144
Brian E. Granger
Adding prompt area to non-CodeCells to indent content....
r13776 var prompt = $('<div/>').addClass('prompt input_prompt');
cell.append(prompt);
var inner_cell = $('<div/>').addClass('inner_cell');
Jonathan Frederic
More review changes
r17214 this.celltoolbar = new celltoolbar.CellToolbar({
cell: this,
notebook: this.notebook});
Brian E. Granger
Adding prompt area to non-CodeCells to indent content....
r13776 inner_cell.append(this.celltoolbar.element);
MinRK
make input_area css generic to cells...
r15552 var input_area = $('<div/>').addClass('input_area');
Jonathan Frederic
Post in person review...
r15497 this.code_mirror = new CodeMirror(input_area.get(0), this.cm_config);
Min RK
enable keyboard manager when codemirror is focused...
r20118 // In case of bugs that put the keyboard manager into an inconsistent state,
// ensure KM is enabled when CodeMirror is focused:
this.code_mirror.on('focus', function () {
if (that.keyboard_manager) {
that.keyboard_manager.enable();
}
});
foogunlana
Fixed code mirror skipping Markdown cell bug
r19098 this.code_mirror.on('keydown', $.proxy(this.handle_keyevent,this))
Brian E. Granger
New HTMl cell working with CodeMirror editing.
r4499 // The tabindex=-1 makes this div focusable.
Matthias BUSSONNIER
move styling from js to css
r17426 var render_area = $('<div/>').addClass('text_cell_render rendered_html')
.attr('tabindex','-1');
Brian E. Granger
Adding prompt area to non-CodeCells to indent content....
r13776 inner_cell.append(input_area).append(render_area);
cell.append(inner_cell);
Brian E. Granger
Implemented module and namespace pattern in js notebook.
r4352 this.element = cell;
};
Brian E. Granger
Adding new logic to cells.
r14014 // Cell level actions
Brian Granger
Refactoring of text/markdown/rst/html cells.
r4508 TextCell.prototype.select = function () {
Jonathan Frederic
Fix all the bugs!
r17203 var cont = Cell.prototype.select.apply(this);
Brian E. Granger
More work on the dual mode UX.
r14015 if (cont) {
Brian E. Granger
Adding new logic to cells.
r14014 if (this.mode === 'edit') {
this.code_mirror.refresh();
}
Jonathan Frederic
Post in person review...
r15497 }
Brian E. Granger
More work on the dual mode UX.
r14015 return cont;
MinRK
trigger textcell render on unselect instead of focusout
r5833 };
Brian E. Granger
Adding new logic to cells.
r14014 TextCell.prototype.unrender = function () {
Jonathan Frederic
Fix all the bugs!
r17203 var cont = Cell.prototype.unrender.apply(this);
Brian E. Granger
More work on the dual mode UX.
r14015 if (cont) {
Brian Granger
Refactoring of text/markdown/rst/html cells.
r4508 var text_cell = this.element;
Brian Granger
Work on the base Cell API....
r5943 if (this.get_text() === this.placeholder) {
this.set_text('');
Stefan van der Walt
Clean up javascript based on js2-mode feedback.
r5479 }
Brian E. Granger
Always refresh the CM editor upon TextCell unrender.
r15502 this.refresh();
Jonathan Frederic
Post in person review...
r15497 }
Brian E. Granger
More work on the dual mode UX.
r14015 return cont;
};
TextCell.prototype.execute = function () {
this.render();
Brian E. Granger
Adding new logic to cells.
r14014 };
Brian E. Granger
Splitting notebook.js into muliple files for development ease.
r4349
Matthias BUSSONNIER
start to document js
r8709 /**
* setter: {{#crossLink "TextCell/set_text"}}{{/crossLink}}
* @method get_text
* @retrun {string} CodeMirror current text value
*/
Brian Granger
Work on the base Cell API....
r5943 TextCell.prototype.get_text = function() {
Brian E. Granger
New HTMl cell working with CodeMirror editing.
r4499 return this.code_mirror.getValue();
Brian E. Granger
Implemented module and namespace pattern in js notebook.
r4352 };
Brian E. Granger
Splitting notebook.js into muliple files for development ease.
r4349
Matthias BUSSONNIER
start to document js
r8709 /**
* @param {string} text - Codemiror text value
* @see TextCell#get_text
* @method set_text
* */
Brian Granger
Work on the base Cell API....
r5943 TextCell.prototype.set_text = function(text) {
Brian E. Granger
New HTMl cell working with CodeMirror editing.
r4499 this.code_mirror.setValue(text);
Paul Ivanov
call unrender() when setting text of cells
r17464 this.unrender();
Brian E. Granger
New HTMl cell working with CodeMirror editing.
r4499 this.code_mirror.refresh();
Brian E. Granger
Implemented module and namespace pattern in js notebook.
r4352 };
Brian E. Granger
Splitting notebook.js into muliple files for development ease.
r4349
Matthias BUSSONNIER
start to document js
r8709 /**
* setter :{{#crossLink "TextCell/set_rendered"}}{{/crossLink}}
* @method get_rendered
* */
Brian E. Granger
Fixed text cell rendering bug.
r4513 TextCell.prototype.get_rendered = function() {
Brian Granger
Refactoring of text/markdown/rst/html cells.
r4508 return this.element.find('div.text_cell_render').html();
};
Matthias BUSSONNIER
start to document js
r8709 /**
* @method set_rendered
*/
Brian Granger
Refactoring of text/markdown/rst/html cells.
r4508 TextCell.prototype.set_rendered = function(text) {
this.element.find('div.text_cell_render').html(text);
Brian E. Granger
Implemented module and namespace pattern in js notebook.
r4352 };
Brian E. Granger
Splitting notebook.js into muliple files for development ease.
r4349
Matthias BUSSONNIER
Document more function....
r8711 /**
* Create Text cell from JSON
Matthias BUSSONNIER
start to document js
r8709 * @param {json} data - JSON serialized text-cell
Matthias BUSSONNIER
Document more function....
r8711 * @method fromJSON
Matthias BUSSONNIER
start to document js
r8709 */
Brian Granger
Refactoring of text/markdown/rst/html cells.
r4508 TextCell.prototype.fromJSON = function (data) {
Jonathan Frederic
Fix all the bugs!
r17203 Cell.prototype.fromJSON.apply(this, arguments);
Brian Granger
Refactoring of text/markdown/rst/html cells.
r4508 if (data.cell_type === this.cell_type) {
Brian E. Granger
New HTMl cell working with CodeMirror editing.
r4499 if (data.source !== undefined) {
Brian Granger
Work on the base Cell API....
r5943 this.set_text(data.source);
Paul Ivanov
fix for #1678, undo no longer clears cells...
r7587 // make this value the starting point, so that we can only undo
// to this state, instead of a blank cell
this.code_mirror.clearHistory();
Jonathan Frederic
Treat set_rendered as unsafe.
r15407 // TODO: This HTML needs to be treated as potentially dangerous
// user input and should be handled before set_rendered.
Brian E. Granger
Fixed text cell rendering bug.
r4513 this.set_rendered(data.rendered || '');
this.rendered = false;
this.render();
Stefan van der Walt
Clean up javascript based on js2-mode feedback.
r5479 }
}
Brian E. Granger
Fixed text cell rendering bug.
r4513 };
Brian E. Granger
Splitting notebook.js into muliple files for development ease.
r4349
Matthias BUSSONNIER
Document more function....
r8711 /** Generate JSON from cell
* @return {object} cell data serialised to json
*/
Brian Granger
Refactoring of text/markdown/rst/html cells.
r4508 TextCell.prototype.toJSON = function () {
Jonathan Frederic
Fix all the bugs!
r17203 var data = Cell.prototype.toJSON.apply(this);
Brian Granger
Work on the base Cell API....
r5943 data.source = this.get_text();
MinRK
give Raw Cells a placeholder...
r13668 if (data.source == this.placeholder) {
data.source = "";
}
Brian E. Granger
Massive work on the notebook document format....
r4484 return data;
Brian E. Granger
Splitting notebook.js into muliple files for development ease.
r4349 };
Brian Granger
Refactoring of text/markdown/rst/html cells.
r4508
jon
In person review with @ellisonbg
r17210 var MarkdownCell = function (options) {
Jonathan Frederic
Ran function comment conversion tool
r19176 /**
* Constructor
*
* Parameters:
* options: dictionary
* Dictionary of keyword arguments.
* events: $(Events) instance
Thomas Kluyver
Remove user_config js module
r19529 * config: ConfigSection instance
Jonathan Frederic
Ran function comment conversion tool
r19176 * keyboard_manager: KeyboardManager instance
* notebook: Notebook instance
*/
jon
In person review with @ellisonbg
r17210 options = options || {};
Thomas Kluyver
Remove user_config js module
r19529 var config = utils.mergeopt(MarkdownCell, {});
this.class_config = new configmod.ConfigWithDefaults(options.config,
{}, 'MarkdownCell');
Matthias Bussonnier
Merge codemirror config with user config....
r20702 TextCell.apply(this, [$.extend({}, options, {config: config})]);
Brian Granger
Refactoring of text/markdown/rst/html cells.
r4508 this.cell_type = 'markdown';
};
Matthias BUSSONNIER
JS Configurablity Take 2...
r10165 MarkdownCell.options_default = {
cm_config: {
Jonathan Frederic
Create ipythongfm mode
r16787 mode: 'ipythongfm'
Matthias BUSSONNIER
JS Configurablity Take 2...
r10165 },
placeholder: "Type *Markdown* and LaTeX: $\\alpha^2$"
Jonathan Frederic
Post in person review...
r15497 };
Matthias BUSSONNIER
JS Configurablity Take 2...
r10165
Matthias Bussonnier
Use low overhead object heritence in Js (Object.create vs new)...
r18377 MarkdownCell.prototype = Object.create(TextCell.prototype);
Brian Granger
Refactoring of text/markdown/rst/html cells.
r4508
MinRK
remove heading cells in v4
r18596 MarkdownCell.prototype.set_heading_level = function (level) {
Jonathan Frederic
Ran function comment conversion tool
r19176 /**
* make a markdown cell a heading
*/
MinRK
remove heading cells in v4
r18596 level = level || 1;
var source = this.get_text();
MinRK
better regex replacement for MarkdownCell.set_heading_level...
r18597 source = source.replace(/^(#*)\s?/,
new Array(level + 1).join('#') + ' ');
this.set_text(source);
MinRK
remove heading cells in v4
r18596 this.refresh();
if (this.rendered) {
this.render();
}
};
Matthias BUSSONNIER
Document more function....
r8711 /**
* @method render
*/
Brian Granger
Refactoring of text/markdown/rst/html cells.
r4508 MarkdownCell.prototype.render = function () {
Jonathan Frederic
Progress...
r17196 var cont = TextCell.prototype.render.apply(this);
Brian E. Granger
More work on the dual mode UX.
r14015 if (cont) {
MinRK
use CodeMirror.runMode to highlight in markdown...
r18864 var that = this;
Brian Granger
Work on the base Cell API....
r5943 var text = this.get_text();
Jessica B. Hamrick
Parse markdown correctly when mathjax is disabled
r11843 var math = null;
Stefan van der Walt
Clean up javascript based on js2-mode feedback.
r5479 if (text === "") { text = this.placeholder; }
Jonathan Frederic
MWE,...
r17200 var text_and_math = mathjaxutils.remove_math(text);
Jessica B. Hamrick
Parse markdown correctly when mathjax is disabled
r11843 text = text_and_math[0];
math = text_and_math[1];
MinRK
use CodeMirror.runMode to highlight in markdown...
r18864 marked(text, function (err, html) {
html = mathjaxutils.replace_math(html, math);
html = security.sanitize_html(html);
html = $($.parseHTML(html));
// add anchors to headings
html.find(":header").addBack(":header").each(function (i, h) {
h = $(h);
var hash = h.text().replace(/ /g, '-');
h.attr('id', hash);
h.append(
$('<a/>')
.addClass('anchor-link')
.attr('href', '#' + hash)
.text('¶')
);
});
// links in markdown cells should open in new tabs
html.find("a[href]").not('[href^="#"]').attr("target", "_blank");
that.set_rendered(html);
that.typeset();
that.events.trigger("rendered.MarkdownCell", {cell: that});
});
Jonathan Frederic
Post in person review...
r15497 }
Brian E. Granger
More work on the dual mode UX.
r14015 return cont;
Brian Granger
Refactoring of text/markdown/rst/html cells.
r4508 };
jon
In person review with @ellisonbg
r17210 var RawCell = function (options) {
Jonathan Frederic
Ran function comment conversion tool
r19176 /**
* Constructor
*
* Parameters:
* options: dictionary
* Dictionary of keyword arguments.
* events: $(Events) instance
Thomas Kluyver
Remove user_config js module
r19529 * config: ConfigSection instance
Jonathan Frederic
Ran function comment conversion tool
r19176 * keyboard_manager: KeyboardManager instance
* notebook: Notebook instance
*/
jon
In person review with @ellisonbg
r17210 options = options || {};
Thomas Kluyver
Remove user_config js module
r19529 var config = utils.mergeopt(RawCell, {});
jon
In person review with @ellisonbg
r17210 TextCell.apply(this, [$.extend({}, options, {config: config})]);
Brian E. Granger
Semi working version of basic dual mode UX....
r14016
Thomas Kluyver
Remove user_config js module
r19529 this.class_config = new configmod.ConfigWithDefaults(options.config,
RawCell.config_defaults, 'RawCell');
jon
In person review with @ellisonbg
r17210 this.cell_type = 'raw';
Brian Granger
Refactoring of text/markdown/rst/html cells.
r4508 };
Matthias BUSSONNIER
JS Configurablity Take 2...
r10165 RawCell.options_default = {
Paul Ivanov
raw cell placeholder text as one line
r15859 placeholder : "Write raw LaTeX or other formats here, for use with nbconvert. " +
"It will not be rendered in the notebook. " +
MinRK
give Raw Cells a placeholder...
r13668 "When passing through nbconvert, a Raw Cell's content is added to the output unmodified."
Matthias BUSSONNIER
JS Configurablity Take 2...
r10165 };
Thomas Kluyver
Remove user_config js module
r19529
RawCell.config_defaults = {
highlight_modes : {
'diff' :{'reg':[/^diff/]}
},
};
Matthias BUSSONNIER
JS Configurablity Take 2...
r10165
Matthias Bussonnier
Use low overhead object heritence in Js (Object.create vs new)...
r18377 RawCell.prototype = Object.create(TextCell.prototype);
Brian Granger
Refactoring of text/markdown/rst/html cells.
r4508
Brian E. Granger
More work on the dual mode UX.
r14015 /** @method bind_events **/
RawCell.prototype.bind_events = function () {
TextCell.prototype.bind_events.apply(this);
Jonathan Frederic
Post in person review...
r15497 var that = this;
Brian E. Granger
More work on the dual mode UX.
r14015 this.element.focusout(function() {
that.auto_highlight();
Paul Ivanov
render on focus out, always pad raw cells
r15858 that.render();
Brian E. Granger
More work on the dual mode UX.
r14015 });
Paul Ivanov
remove raw cell placeholder on focus, closes #5238
r15768
this.code_mirror.on('focus', function() { that.unrender(); });
Brian E. Granger
More work on the dual mode UX.
r14015 };
Matthias BUSSONNIER
Document more function....
r8711 /** @method render **/
MinRK
rename plaintext cell -> raw cell
r6248 RawCell.prototype.render = function () {
Jonathan Frederic
Progress...
r17196 var cont = TextCell.prototype.render.apply(this);
Paul Ivanov
remove raw cell placeholder on focus, closes #5238
r15768 if (cont){
var text = this.get_text();
if (text === "") { text = this.placeholder; }
this.set_text(text);
Paul Ivanov
render on focus out, always pad raw cells
r15858 this.element.removeClass('rendered');
Min RK
move auto_highlight to Cell...
r19894 this.auto_highlight();
Brian E. Granger
More work on the dual mode UX.
r14015 }
Paul Ivanov
remove raw cell placeholder on focus, closes #5238
r15768 return cont;
Brian Granger
A first go at RST cell support in the notebook.
r6017 };
Jonathan Frederic
Progress...
r17196 // Backwards compatability.
Brian Granger
Refactoring of text/markdown/rst/html cells.
r4508 IPython.TextCell = TextCell;
IPython.MarkdownCell = MarkdownCell;
MinRK
rename plaintext cell -> raw cell
r6248 IPython.RawCell = RawCell;
Brian Granger
Refactoring of text/markdown/rst/html cells.
r4508
Jonathan Frederic
More review changes
r17214 var textcell = {
MinRK
remove heading cells in v4
r18596 TextCell: TextCell,
MarkdownCell: MarkdownCell,
Min RK
Handle unrecognized outputs and cells from the future
r18999 RawCell: RawCell
Jonathan Frederic
Progress...
r17196 };
Jonathan Frederic
More review changes
r17214 return textcell;
Jonathan Frederic
Progress...
r17196 });