cell.js
91 lines
| 2.7 KiB
| application/javascript
|
JavascriptLexer
Brian E. Granger
|
r4349 | |||
//============================================================================ | ||||
// Cell | ||||
//============================================================================ | ||||
Brian E. Granger
|
r4352 | var IPython = (function (IPython) { | ||
Brian E. Granger
|
r4349 | |||
Brian E. Granger
|
r4352 | var utils = IPython.utils; | ||
Brian E. Granger
|
r4349 | |||
Brian E. Granger
|
r4352 | var Cell = function (notebook) { | ||
this.notebook = notebook; | ||||
this.selected = false; | ||||
Brian E. Granger
|
r4529 | this.element = null; | ||
Brian E. Granger
|
r4352 | this.create_element(); | ||
Brian E. Granger
|
r4529 | if (this.element !== null) { | ||
this.set_autoindent(true); | ||||
Brian E. Granger
|
r4352 | this.element.data("cell", this); | ||
this.bind_events(); | ||||
} | ||||
this.cell_id = utils.uuid(); | ||||
}; | ||||
Cell.prototype.select = function () { | ||||
this.element.addClass('ui-widget-content ui-corner-all'); | ||||
this.selected = true; | ||||
Brian Granger
|
r4508 | // TODO: we need to test across browsers to see if both of these are needed. | ||
Brian E. Granger
|
r4352 | // In the meantime, there should not be any harm in having them both. | ||
this.element.find('textarea').trigger('focusin'); | ||||
this.element.find('textarea').trigger('focus'); | ||||
}; | ||||
Cell.prototype.unselect = function () { | ||||
this.element.removeClass('ui-widget-content ui-corner-all'); | ||||
this.selected = false; | ||||
}; | ||||
Cell.prototype.bind_events = function () { | ||||
var that = this; | ||||
var nb = that.notebook | ||||
that.element.click(function (event) { | ||||
if (that.selected === false) { | ||||
nb.select(nb.find_cell_index(that)); | ||||
}; | ||||
}); | ||||
that.element.focusin(function (event) { | ||||
if (that.selected === false) { | ||||
nb.select(nb.find_cell_index(that)); | ||||
}; | ||||
}); | ||||
}; | ||||
Brian E. Granger
|
r4400 | Cell.prototype.grow = function(element) { | ||
// Grow the cell by hand. This is used upon reloading from JSON, when the | ||||
// autogrow handler is not called. | ||||
var dom = element.get(0); | ||||
var lines_count = 0; | ||||
// modified split rule from | ||||
// http://stackoverflow.com/questions/2035910/how-to-get-the-number-of-lines-in-a-textarea/2036424#2036424 | ||||
var lines = dom.value.split(/\r|\r\n|\n/); | ||||
lines_count = lines.length; | ||||
if (lines_count >= 1) { | ||||
dom.rows = lines_count; | ||||
} else { | ||||
dom.rows = 1; | ||||
} | ||||
}; | ||||
Brian E. Granger
|
r4352 | |||
Brian E. Granger
|
r4512 | Cell.prototype.set_autoindent = function (state) { | ||
if (state) { | ||||
this.code_mirror.setOption('tabMode', 'indent'); | ||||
this.code_mirror.setOption('enterMode', 'indent'); | ||||
} else { | ||||
this.code_mirror.setOption('tabMode', 'shift'); | ||||
this.code_mirror.setOption('enterMode', 'flat'); | ||||
} | ||||
}; | ||||
Brian E. Granger
|
r4352 | // Subclasses must implement create_element. | ||
Cell.prototype.create_element = function () {}; | ||||
IPython.Cell = Cell; | ||||
return IPython; | ||||
}(IPython)); | ||||
Brian E. Granger
|
r4349 | |||