Show More
@@ -259,7 +259,7 b' var IPython = (function (IPython) {' | |||
|
259 | 259 | help : 'insert cell above', |
|
260 | 260 | help_index : 'ec', |
|
261 | 261 | handler : function (event) { |
|
262 |
IPython.notebook.insert_cell_above( |
|
|
262 | IPython.notebook.insert_cell_above(); | |
|
263 | 263 | IPython.notebook.select_prev(); |
|
264 | 264 | IPython.notebook.focus_cell(); |
|
265 | 265 | return false; |
@@ -269,7 +269,7 b' var IPython = (function (IPython) {' | |||
|
269 | 269 | help : 'insert cell below', |
|
270 | 270 | help_index : 'ed', |
|
271 | 271 | handler : function (event) { |
|
272 |
IPython.notebook.insert_cell_below( |
|
|
272 | IPython.notebook.insert_cell_below(); | |
|
273 | 273 | IPython.notebook.select_next(); |
|
274 | 274 | IPython.notebook.focus_cell(); |
|
275 | 275 | return false; |
@@ -731,13 +731,16 b' var IPython = (function (IPython) {' | |||
|
731 | 731 | /** |
|
732 | 732 | * Insert a cell so that after insertion the cell is at given index. |
|
733 | 733 | * |
|
734 | * If cell type is not provided, it will default to the type of the | |
|
735 | * currently active cell. | |
|
736 | * | |
|
734 | 737 | * Similar to insert_above, but index parameter is mandatory |
|
735 | 738 | * |
|
736 |
* Index will be brought back into the acc |
|
|
739 | * Index will be brought back into the accessible range [0,n] | |
|
737 | 740 | * |
|
738 | 741 | * @method insert_cell_at_index |
|
739 | * @param type {string} in ['code','markdown','heading'] | |
|
740 | * @param [index] {int} a valid index where to inser cell | |
|
742 | * @param [type] {string} in ['code','markdown','heading'], defaults to 'code' | |
|
743 | * @param [index] {int} a valid index where to insert cell | |
|
741 | 744 | * |
|
742 | 745 | * @return cell {cell|null} created cell or null |
|
743 | 746 | **/ |
@@ -747,6 +750,7 b' var IPython = (function (IPython) {' | |||
|
747 | 750 | index = Math.min(index,ncells); |
|
748 | 751 | index = Math.max(index,0); |
|
749 | 752 | var cell = null; |
|
753 | type = type || this.get_selected_cell().cell_type; | |
|
750 | 754 | |
|
751 | 755 | if (ncells === 0 || this.is_valid_cell_index(index) || index === ncells) { |
|
752 | 756 | if (type === 'code') { |
@@ -819,7 +823,7 b' var IPython = (function (IPython) {' | |||
|
819 | 823 | * default index value is the one of currently selected cell |
|
820 | 824 | * |
|
821 | 825 | * @method insert_cell_above |
|
822 | * @param type {string} cell type | |
|
826 | * @param [type] {string} cell type | |
|
823 | 827 | * @param [index] {integer} |
|
824 | 828 | * |
|
825 | 829 | * @return handle to created cell or null |
@@ -831,12 +835,12 b' var IPython = (function (IPython) {' | |||
|
831 | 835 | |
|
832 | 836 | /** |
|
833 | 837 | * Insert a cell of given type below given index, or at bottom |
|
834 |
* of notebook if index greater tha |
|
|
838 | * of notebook if index greater than number of cells | |
|
835 | 839 | * |
|
836 | 840 | * default index value is the one of currently selected cell |
|
837 | 841 | * |
|
838 | 842 | * @method insert_cell_below |
|
839 | * @param type {string} cell type | |
|
843 | * @param [type] {string} cell type | |
|
840 | 844 | * @param [index] {integer} |
|
841 | 845 | * |
|
842 | 846 | * @return handle to created cell or null |
@@ -1474,7 +1478,7 b' var IPython = (function (IPython) {' | |||
|
1474 | 1478 | // If we are at the end always insert a new cell and return |
|
1475 | 1479 | if (cell_index === (this.ncells()-1)) { |
|
1476 | 1480 | this.command_mode(); |
|
1477 |
this.insert_cell_below( |
|
|
1481 | this.insert_cell_below(); | |
|
1478 | 1482 | this.select(cell_index+1); |
|
1479 | 1483 | this.edit_mode(); |
|
1480 | 1484 | this.scroll_to_bottom(); |
@@ -1483,7 +1487,7 b' var IPython = (function (IPython) {' | |||
|
1483 | 1487 | } |
|
1484 | 1488 | |
|
1485 | 1489 | this.command_mode(); |
|
1486 |
this.insert_cell_below( |
|
|
1490 | this.insert_cell_below(); | |
|
1487 | 1491 | this.select(cell_index+1); |
|
1488 | 1492 | this.edit_mode(); |
|
1489 | 1493 | this.set_dirty(true); |
@@ -1504,7 +1508,7 b' var IPython = (function (IPython) {' | |||
|
1504 | 1508 | // If we are at the end always insert a new cell and return |
|
1505 | 1509 | if (cell_index === (this.ncells()-1)) { |
|
1506 | 1510 | this.command_mode(); |
|
1507 |
this.insert_cell_below( |
|
|
1511 | this.insert_cell_below(); | |
|
1508 | 1512 | this.select(cell_index+1); |
|
1509 | 1513 | this.edit_mode(); |
|
1510 | 1514 | this.scroll_to_bottom(); |
@@ -18,10 +18,25 b' casper.notebook_test(function () {' | |||
|
18 | 18 | this.select_cell(2); |
|
19 | 19 | this.trigger_keydown('a'); // Creates one cell |
|
20 | 20 | this.test.assertEquals(this.get_cell_text(2), '', 'a; New cell 2 text is empty'); |
|
21 | this.test.assertEquals(this.get_cell(2).cell_type, 'code', 'a; inserts a code cell when on code cell'); | |
|
21 | 22 | this.validate_notebook_state('a', 'command', 2); |
|
22 | 23 | this.trigger_keydown('b'); // Creates one cell |
|
23 | 24 | this.test.assertEquals(this.get_cell_text(2), '', 'b; Cell 2 text is still empty'); |
|
24 | 25 | this.test.assertEquals(this.get_cell_text(3), '', 'b; New cell 3 text is empty'); |
|
26 | this.test.assertEquals(this.get_cell(3).cell_type, 'code', 'b; inserts a code cell when on code cell'); | |
|
27 | this.validate_notebook_state('b', 'command', 3); | |
|
28 | }); | |
|
29 | this.then(function () { | |
|
30 | // Cell insertion | |
|
31 | this.select_cell(2); | |
|
32 | this.trigger_keydown('m'); // switch it to markdown for the next test | |
|
33 | this.trigger_keydown('a'); // Creates one cell | |
|
34 | this.test.assertEquals(this.get_cell_text(2), '', 'a; New cell 2 text is empty'); | |
|
35 | this.test.assertEquals(this.get_cell(2).cell_type, 'markdown', 'a; inserts a markdown cell when on markdown cell'); | |
|
36 | this.validate_notebook_state('a', 'command', 2); | |
|
37 | this.trigger_keydown('b'); // Creates one cell | |
|
38 | this.test.assertEquals(this.get_cell_text(2), '', 'b; Cell 2 text is still empty'); | |
|
39 | this.test.assertEquals(this.get_cell(3).cell_type, 'markdown', 'b; inserts a markdown cell when on markdown cell'); | |
|
25 | 40 | this.validate_notebook_state('b', 'command', 3); |
|
26 | 41 | }); |
|
27 | 42 | }); |
@@ -167,8 +167,6 b' casper.get_cell_text = function(index){' | |||
|
167 | 167 | casper.insert_cell_at_bottom = function(cell_type){ |
|
168 | 168 | // Inserts a cell at the bottom of the notebook |
|
169 | 169 | // Returns the new cell's index. |
|
170 | cell_type = cell_type || 'code'; | |
|
171 | ||
|
172 | 170 | return this.evaluate(function (cell_type) { |
|
173 | 171 | var cell = IPython.notebook.insert_cell_at_bottom(cell_type); |
|
174 | 172 | return IPython.notebook.find_cell_index(cell); |
General Comments 0
You need to be logged in to leave comments.
Login now