2
0
mirror of https://github.com/jupyter/notebook.git synced 2025-01-24 12:05:22 +08:00

use inline raw_input instead of a dialog

This commit is contained in:
MinRK 2013-03-19 11:49:04 -07:00
parent f38f2b7ac4
commit 5b434b705f
5 changed files with 85 additions and 34 deletions
IPython/frontend/html/notebook/static

View File

@ -245,7 +245,8 @@ var IPython = (function (IPython) {
'execute_reply': $.proxy(this._handle_execute_reply, this),
'output': $.proxy(this.output_area.handle_output, this.output_area),
'clear_output': $.proxy(this.output_area.handle_clear_output, this.output_area),
'set_next_input': $.proxy(this._handle_set_next_input, this)
'set_next_input': $.proxy(this._handle_set_next_input, this),
'input_request': $.proxy(this._handle_input_request, this)
};
var msg_id = this.kernel.execute(this.get_text(), callbacks, {silent: false});
};
@ -260,11 +261,24 @@ var IPython = (function (IPython) {
$([IPython.events]).trigger('set_dirty.Notebook', {'value': true});
}
/**
* @method _handle_set_next_input
* @private
*/
CodeCell.prototype._handle_set_next_input = function (text) {
var data = {'cell': this, 'text': text}
$([IPython.events]).trigger('set_next_input.Notebook', data);
}
/**
* @method _handle_input_request
* @private
*/
CodeCell.prototype._handle_input_request = function (content) {
this.output_area.append_raw_input(content);
}
// Basic cell manipulation.
CodeCell.prototype.select = function () {

View File

@ -168,6 +168,10 @@ var IPython = (function (IPython) {
this.shell_channel.onmessage = $.proxy(this._handle_shell_reply, this);
this.iopub_channel.onmessage = $.proxy(this._handle_iopub_reply, this);
this.stdin_channel.onmessage = $.proxy(this._handle_input_request, this);
$([IPython.events]).on('send_input_reply.Kernel', function(evt, data) {
that.send_input_reply(data);
});
};
/**
@ -283,8 +287,11 @@ var IPython = (function (IPython) {
silent : true,
user_variables : [],
user_expressions : {},
allow_stdin : true
allow_stdin : false
};
if (callbacks.input_request !== undefined) {
content.allow_stdin = true;
}
$.extend(true, content, options)
$([IPython.events]).trigger('execution_request.Kernel', {kernel: this, content:content});
var msg = this._get_msg("execute_request", content);
@ -344,8 +351,7 @@ var IPython = (function (IPython) {
};
};
Kernel.prototype.send_input_reply = function (input, header) {
Kernel.prototype.send_input_reply = function (input) {
var content = {
value : input,
};
@ -447,7 +453,6 @@ var IPython = (function (IPython) {
Kernel.prototype._handle_input_request = function (e) {
var request = $.parseJSON(e.data);
console.log("input", request);
var header = request.header;
var content = request.content;
var metadata = request.metadata;
@ -456,7 +461,13 @@ var IPython = (function (IPython) {
console.log("Invalid input request!", request);
return;
}
$([IPython.events]).trigger('input_request.Kernel', {kernel: this, request:request});
var callbacks = this.get_callbacks_for_msg(request.parent_header.msg_id);
if (callbacks !== undefined) {
var cb = callbacks[msg_type];
if (cb !== undefined) {
cb(content, metadata);
}
};
};

View File

@ -115,34 +115,6 @@ var IPython = (function (IPython) {
var index = that.find_cell_index(data.cell);
that.select(index);
});
$([IPython.events]).on('input_request.Kernel', function (event, data) {
var dialog = $('<div/>').attr('id','input_form').append(
$('<form/>')
.attr("action", "javascript:$('#input_form').parent().find('button').click();")
.append(
$('<input/>')
.attr('id', 'input_prompt_dialog')
.attr('type', 'text')
.attr('name', 'input')
));
$(document).append(dialog);
dialog.dialog({
resizable: false,
modal: true,
title: data.request.content.prompt,
closeText: '',
buttons : {
"Okay": function () {
IPython.notebook.kernel.send_input_reply(
$("input#input_prompt_dialog").attr('value'),
data.request.header
);
$(this).dialog('close');
dialog.remove();
}
}
});
});
$(document).keydown(function (event) {

View File

@ -74,6 +74,7 @@ var IPython = (function (IPython) {
OutputArea.prototype.bind_events = function () {
var that = this;
this._submit_raw_input_proxy = $.proxy(this._submit_raw_input, this);
this.prompt_overlay.dblclick(function () { that.toggle_output(); });
this.prompt_overlay.click(function () { that.toggle_scroll(); });
@ -449,6 +450,51 @@ var IPython = (function (IPython) {
element.append(toinsert);
};
OutputArea.prototype.append_raw_input = function (content) {
this.expand();
this.flush_clear_timeout();
var area = this.create_output_area();
area.append(
$("<div/>")
.addClass("box-flex1 output_subarea raw_input")
.append(
$("<form/>")
.attr("action", "javascript:$([IPython.events]).trigger('submit_raw_input.OutputArea');")
.append(
$("<span/>")
.addClass("input_prompt")
.text(content.prompt)
).append(
$("<input/>")
.attr("size", 80)
.addClass("raw_input")
)
)
)
// clear events first
$([IPython.events]).off('submit_raw_input.OutputArea');
$([IPython.events]).on('submit_raw_input.OutputArea', this._submit_raw_input_proxy);
this.element.append(area);
area.find("input.raw_input").focus();
}
OutputArea.prototype._submit_raw_input = function (evt) {
var container = this.element.find("div.raw_input");
var theprompt = container.find("span.input_prompt");
var theinput = container.find("input.raw_input");
var value = theinput.attr("value");
var content = {
output_type : 'stream',
name : 'stdout',
text : theprompt.text() + value + '\n'
}
// remove form container
container.parent().remove();
// replace with plaintext version in stdout
this.append_output(content, false);
$([IPython.events]).off('submit_raw_input.OutputArea', this._submit_raw_input_proxy);
$([IPython.events]).trigger('send_input_reply.Kernel', value);
}
OutputArea.prototype.handle_clear_output = function (content) {
this.clear_output(content.stdout, content.stderr, content.other);

View File

@ -476,4 +476,12 @@ margin-bottom:0;
a.heading-anchor:link, a.heading-anchor:visited {
text-decoration: none;
color: inherit;
/* raw_input styles */
span.input_prompt {
font-family: monospace;
}
input.raw_input {
width: auto;
}