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