mirror of
https://github.com/jupyter/notebook.git
synced 2025-01-24 12:05:22 +08:00
Minor, but important fixes to cut/copy/paste.
When enabling paste, I was adding the click callback multiple times causing paste to overwrite multiple cells. I also found a bug that was doing paste above instead of paste below.
This commit is contained in:
parent
43c82a2b80
commit
e93d4a9308
@ -21,6 +21,7 @@ var IPython = (function (IPython) {
|
||||
this.next_prompt_number = 1;
|
||||
this.kernel = null;
|
||||
this.clipboard = null;
|
||||
this.paste_enabled = false;
|
||||
this.dirty = false;
|
||||
this.msg_cell_map = {};
|
||||
this.metadata = {};
|
||||
@ -583,23 +584,30 @@ var IPython = (function (IPython) {
|
||||
|
||||
Notebook.prototype.enable_paste = function () {
|
||||
var that = this;
|
||||
$('#paste_cell').removeClass('ui-state-disabled')
|
||||
.on('click', function () {that.paste_cell();});
|
||||
$('#paste_cell_above').removeClass('ui-state-disabled')
|
||||
.on('click', function () {that.paste_cell_above();});
|
||||
$('#paste_cell_below').removeClass('ui-state-disabled')
|
||||
.on('click', function () {that.paste_cell_below();});
|
||||
if (!this.paste_enabled) {
|
||||
$('#paste_cell').removeClass('ui-state-disabled')
|
||||
.on('click', function () {that.paste_cell();});
|
||||
$('#paste_cell_above').removeClass('ui-state-disabled')
|
||||
.on('click', function () {that.paste_cell_above();});
|
||||
$('#paste_cell_below').removeClass('ui-state-disabled')
|
||||
.on('click', function () {that.paste_cell_below();});
|
||||
this.paste_enabled = true;
|
||||
};
|
||||
};
|
||||
|
||||
|
||||
Notebook.prototype.disable_paste = function () {
|
||||
$('#paste_cell').addClass('ui-state-disabled').off('click');
|
||||
$('#paste_cell_above').addClass('ui-state-disabled').off('click');
|
||||
$('#paste_cell_below').addClass('ui-state-disabled').off('click');
|
||||
if (this.paste_enabled) {
|
||||
$('#paste_cell').addClass('ui-state-disabled').off('click');
|
||||
$('#paste_cell_above').addClass('ui-state-disabled').off('click');
|
||||
$('#paste_cell_below').addClass('ui-state-disabled').off('click');
|
||||
this.paste_enabled = false;
|
||||
};
|
||||
};
|
||||
|
||||
|
||||
Notebook.prototype.cut_cell = function () {
|
||||
console.log('cut_cell');
|
||||
this.copy_cell();
|
||||
this.delete_cell();
|
||||
}
|
||||
@ -612,7 +620,8 @@ var IPython = (function (IPython) {
|
||||
|
||||
|
||||
Notebook.prototype.paste_cell = function () {
|
||||
if (this.clipboard !== null) {
|
||||
console.log('paste_cell');
|
||||
if (this.clipboard !== null && this.paste_enabled) {
|
||||
var cell_data = this.clipboard;
|
||||
if (cell_data.cell_type == 'code') {
|
||||
new_cell = this.insert_code_cell_above();
|
||||
@ -624,14 +633,14 @@ var IPython = (function (IPython) {
|
||||
new_cell = this.insert_markdown_cell_above();
|
||||
new_cell.fromJSON(cell_data);
|
||||
};
|
||||
this.select_next();
|
||||
this.delete_cell();
|
||||
};
|
||||
this.select_next();
|
||||
this.delete_cell();
|
||||
};
|
||||
|
||||
|
||||
Notebook.prototype.paste_cell_above = function () {
|
||||
if (this.clipboard !== null) {
|
||||
if (this.clipboard !== null && this.paste_enabled) {
|
||||
var cell_data = this.clipboard;
|
||||
if (cell_data.cell_type == 'code') {
|
||||
new_cell = this.insert_code_cell_above();
|
||||
@ -648,16 +657,16 @@ var IPython = (function (IPython) {
|
||||
|
||||
|
||||
Notebook.prototype.paste_cell_below = function () {
|
||||
if (this.clipboard !== null) {
|
||||
if (this.clipboard !== null && this.paste_enabled) {
|
||||
var cell_data = this.clipboard;
|
||||
if (cell_data.cell_type == 'code') {
|
||||
new_cell = this.insert_code_cell_above();
|
||||
new_cell = this.insert_code_cell_below();
|
||||
new_cell.fromJSON(cell_data);
|
||||
} else if (cell_data.cell_type === 'html') {
|
||||
new_cell = this.insert_html_cell_above();
|
||||
new_cell = this.insert_html_cell_below();
|
||||
new_cell.fromJSON(cell_data);
|
||||
} else if (cell_data.cell_type === 'markdown') {
|
||||
new_cell = this.insert_markdown_cell_above();
|
||||
new_cell = this.insert_markdown_cell_below();
|
||||
new_cell.fromJSON(cell_data);
|
||||
};
|
||||
};
|
||||
|
Loading…
Reference in New Issue
Block a user