Show More
@@ -560,27 +560,7 var IPython = (function (IPython) { | |||||
560 | }; |
|
560 | }; | |
561 |
|
561 | |||
562 |
|
562 | |||
563 | Notebook.prototype.insert_cell_at_bottom = function (type){ |
|
|||
564 | var len = this.ncells(); |
|
|||
565 | return this.insert_cell_below(type,len-1); |
|
|||
566 | } |
|
|||
567 |
|
563 | |||
568 | /** |
|
|||
569 | * Insert a cell of given type below given index, or at bottom |
|
|||
570 | * of notebook if index greater thatn number of cell |
|
|||
571 | * |
|
|||
572 | * default index value is the one of currently selected cell |
|
|||
573 | * |
|
|||
574 | * @param type {string} cell type |
|
|||
575 | * @param [index] {integer} |
|
|||
576 | * |
|
|||
577 | * @return handle to created cell or null |
|
|||
578 | * |
|
|||
579 | **/ |
|
|||
580 | Notebook.prototype.insert_cell_below = function (type, index) { |
|
|||
581 | index = this.index_or_selected(index); |
|
|||
582 | return this.insert_cell_at_index(type, index+1); |
|
|||
583 | }; |
|
|||
584 |
|
564 | |||
585 | /** |
|
565 | /** | |
586 | * Insert a cell so that after insertion the cell is at given index. |
|
566 | * Insert a cell so that after insertion the cell is at given index. | |
@@ -590,26 +570,18 var IPython = (function (IPython) { | |||||
590 | * Index will be brought back into the accissible range [0,n] |
|
570 | * Index will be brought back into the accissible range [0,n] | |
591 | * |
|
571 | * | |
592 | * @param type {string} in ['code','html','markdown','heading'] |
|
572 | * @param type {string} in ['code','html','markdown','heading'] | |
593 | * @param index {int} a valid index where to inser cell |
|
573 | * @param [index] {int} a valid index where to inser cell | |
594 | * |
|
574 | * | |
595 | * return created cell or null |
|
575 | * @return cell {cell|null} created cell or null | |
596 | **/ |
|
576 | **/ | |
597 | Notebook.prototype.insert_cell_at_index = function(type, index){ |
|
577 | Notebook.prototype.insert_cell_at_index = function(type, index){ | |
598 | var ncell = this.ncells() |
|
578 | ||
|
579 | var ncells = this.ncells(); | |||
599 | var index = Math.min(index,ncells); |
|
580 | var index = Math.min(index,ncells); | |
600 | index = Math.max(index,0); |
|
581 | index = Math.max(index,0); | |
|
582 | var cell = null; | |||
601 |
|
583 | |||
602 | var cell = null |
|
584 | if (ncells === 0 || this.is_valid_cell_index(index) || index== ncells) { | |
603 |
|
||||
604 |
|
||||
605 | /// this use to be index < this.undelete_index in some case |
|
|||
606 | if (this.undelete_index !== null && index <= this.undelete_index) { |
|
|||
607 | this.undelete_index = this.undelete_index + 1; |
|
|||
608 | this.dirty = true; |
|
|||
609 | } |
|
|||
610 |
|
||||
611 | // this should be alway true now |
|
|||
612 | if (ncells === 0 || this.is_valid_cell_index(index) || index== ncell) { |
|
|||
613 | if (type === 'code') { |
|
585 | if (type === 'code') { | |
614 | cell = new IPython.CodeCell(this.kernel); |
|
586 | cell = new IPython.CodeCell(this.kernel); | |
615 | cell.set_input_prompt(); |
|
587 | cell.set_input_prompt(); | |
@@ -621,27 +593,53 var IPython = (function (IPython) { | |||||
621 | cell = new IPython.RawCell(); |
|
593 | cell = new IPython.RawCell(); | |
622 | } else if (type === 'heading') { |
|
594 | } else if (type === 'heading') { | |
623 | cell = new IPython.HeadingCell(); |
|
595 | cell = new IPython.HeadingCell(); | |
624 |
} |
|
596 | } | |
625 | if (cell !== null) { |
|
597 | ||
626 | if (ncells === 0) { |
|
598 | if(this._insert_element_at_index(cell.element,index)){ | |
627 | // special case append if empty |
|
|||
628 | this.element.find('div.end_space').before(cell.element); |
|
|||
629 | } else if ( ncell == index ) { |
|
|||
630 | // special case append it the end, but not empty |
|
|||
631 | this.get_cell_element(index-1).after(cell.element); |
|
|||
632 | } else if (this.is_valid_cell_index(index)) { |
|
|||
633 | // otherwise always somewhere to append to |
|
|||
634 | this.get_cell_element(index).before(cell.element); |
|
|||
635 | }; |
|
|||
636 | cell.render(); |
|
599 | cell.render(); | |
637 | this.select(this.find_cell_index(cell)); |
|
600 | this.select(this.find_cell_index(cell)); | |
638 | this.dirty = true; |
|
601 | this.dirty = true; | |
|
602 | } | |||
|
603 | } | |||
639 |
|
|
604 | return cell; | |
|
605 | ||||
640 |
|
|
606 | }; | |
641 | }; |
|
|||
642 | return cell; |
|
|||
643 |
|
607 | |||
|
608 | /** | |||
|
609 | * Insert an element at given cell index. | |||
|
610 | * | |||
|
611 | * @param element {dom element} a cell element | |||
|
612 | * @param [index] {int} a valid index where to inser cell | |||
|
613 | * @private | |||
|
614 | * | |||
|
615 | * return true if everything whent fine. | |||
|
616 | **/ | |||
|
617 | Notebook.prototype._insert_element_at_index = function(element, index){ | |||
|
618 | var ncells = this.ncells(); | |||
|
619 | ||||
|
620 | /// this use to be index < this.undelete_index in some case | |||
|
621 | if (this.undelete_index !== null && index <= this.undelete_index) { | |||
|
622 | this.undelete_index = this.undelete_index + 1; | |||
|
623 | this.dirty = true; | |||
|
624 | } | |||
644 |
|
625 | |||
|
626 | // this should be alway true now | |||
|
627 | if (ncells === 0 || this.is_valid_cell_index(index) || index== ncells) { | |||
|
628 | if (element !== null) { | |||
|
629 | if (ncells === 0) { | |||
|
630 | // special case append if empty | |||
|
631 | this.element.find('div.end_space').before(element); | |||
|
632 | } else if ( ncells == index ) { | |||
|
633 | // special case append it the end, but not empty | |||
|
634 | this.get_cell_element(index-1).after(element); | |||
|
635 | } else if (this.is_valid_cell_index(index)) { | |||
|
636 | // otherwise always somewhere to append to | |||
|
637 | this.get_cell_element(index).before(element); | |||
|
638 | } | |||
|
639 | return true; | |||
|
640 | } | |||
|
641 | } | |||
|
642 | return false; | |||
645 | }; |
|
643 | }; | |
646 |
|
644 | |||
647 | /** |
|
645 | /** | |
@@ -660,6 +658,39 var IPython = (function (IPython) { | |||||
660 | return this.insert_cell_at_index(type, index); |
|
658 | return this.insert_cell_at_index(type, index); | |
661 | }; |
|
659 | }; | |
662 |
|
660 | |||
|
661 | /** | |||
|
662 | * Insert a cell of given type below given index, or at bottom | |||
|
663 | * of notebook if index greater thatn number of cell | |||
|
664 | * | |||
|
665 | * default index value is the one of currently selected cell | |||
|
666 | * | |||
|
667 | * @method insert_cell_below | |||
|
668 | * @param type {string} cell type | |||
|
669 | * @param [index] {integer} | |||
|
670 | * | |||
|
671 | * @return handle to created cell or null | |||
|
672 | * | |||
|
673 | **/ | |||
|
674 | Notebook.prototype.insert_cell_below = function (type, index) { | |||
|
675 | index = this.index_or_selected(index); | |||
|
676 | return this.insert_cell_at_index(type, index+1); | |||
|
677 | }; | |||
|
678 | ||||
|
679 | ||||
|
680 | /** | |||
|
681 | * Insert cell at end of notebook | |||
|
682 | * | |||
|
683 | * @method insert_cell_at_bottom | |||
|
684 | * @param type {String} cell type | |||
|
685 | * | |||
|
686 | * @return the added cell; or null | |||
|
687 | **/ | |||
|
688 | Notebook.prototype.insert_cell_at_bottom = function (type){ | |||
|
689 | var len = this.ncells(); | |||
|
690 | return this.insert_cell_below(type,len-1); | |||
|
691 | }; | |||
|
692 | ||||
|
693 | ||||
663 |
|
694 | |||
664 | Notebook.prototype.to_code = function (index) { |
|
695 | Notebook.prototype.to_code = function (index) { | |
665 | var i = this.index_or_selected(index); |
|
696 | var i = this.index_or_selected(index); |
General Comments 0
You need to be logged in to leave comments.
Login now