New new button

This commit is contained in:
Jonathan Frederic 2014-12-19 14:10:50 -08:00 committed by Jonathan Frederic
parent 849c96ae61
commit e0adde46f3
5 changed files with 123 additions and 52 deletions

View File

@ -71,7 +71,7 @@ require([
var login_widget = new loginwidget.LoginWidget('#login_widget', common_options);
var nnw = new newnotebook.NewNotebookWidget("#new-notebook-buttons",
var new_buttons = new newnotebook.NewNotebookWidget("#new-buttons",
$.extend(
{contents: contents},
common_options
@ -130,7 +130,7 @@ require([
IPython.session_list = session_list;
IPython.kernel_list = kernel_list;
IPython.login_widget = login_widget;
IPython.new_notebook_widget = nnw;
IPython.new_notebook_widget = new_buttons;
events.trigger('app_initialized.DashboardApp');

View File

@ -15,7 +15,6 @@ define([
this.notebook_path = options.notebook_path;
this.contents = options.contents;
this.default_kernel = null;
this.config = options.config;
this.kernelspecs = {};
if (this.selector !== undefined) {
this.element = $(selector);
@ -41,7 +40,7 @@ define([
/** load kernelspec list */
var that = this;
this.kernelspecs = data.kernelspecs;
var menu = this.element.find("#new-notebook-menu");
var menu = this.element.find("#notebook-kernels");
var keys = Object.keys(data.kernelspecs).sort(function (a, b) {
var da = data.kernelspecs[a].display_name;
var db = data.kernelspecs[b].display_name;
@ -64,45 +63,8 @@ define([
.text(ks.display_name)
.attr('title', 'Create a new notebook with ' + ks.display_name)
);
menu.append(li);
menu.after(li);
}
this.config.loaded.then(function () {
that._load_default_kernelspec(data['default']);
});
};
NewNotebookWidget.prototype._load_default_kernelspec = function (default_name) {
/** load default kernelspec name from config, if defined */
if (this.config.data.NewNotebookWidget &&
this.config.data.NewNotebookWidget.default_kernel &&
this.kernelspecs[this.config.data.NewNotebookWidget.default_kernel] !== undefined
) {
default_name = this.config.data.NewNotebookWidget.default_kernel;
}
this.set_default_kernel(default_name);
};
NewNotebookWidget.prototype.set_default_kernel = function (kernel_name) {
/** select the current default kernel */
this.default_kernel = kernel_name;
this.config.update({
NewNotebookWidget: {
default_kernel: kernel_name
}
});
var spec = this.kernelspecs[kernel_name];
var display_name;
if (spec) {
display_name = spec.display_name;
this.element.find("#current-kernel")
.text(display_name)
.attr('title', display_name + " is the default kernel for new notebooks");
} else {
display_name = 'default kernel';
}
this.element.find("#new_notebook").attr('title',
'Create a new notebook with ' + display_name
);
};
NewNotebookWidget.prototype.new_notebook = function (kernel_name) {

View File

@ -7,7 +7,8 @@ define([
'base/js/utils',
'base/js/dialog',
'base/js/events',
], function(IPython, $, utils, dialog, events) {
'base/js/keyboard',
], function(IPython, $, utils, dialog, events, keyboard) {
"use strict";
var NotebookList = function (selector, options) {
@ -54,7 +55,6 @@ define([
this.element.addClass("list_container");
};
NotebookList.prototype.bind_events = function () {
var that = this;
$('#refresh_' + this.element_name + '_list').click(function () {
@ -67,6 +67,25 @@ define([
that.handleFilesUpload(event,'drop');
return false;
});
// Bind events for singleton controls.
if (!NotebookList._bound_singletons) {
NotebookList._bound_singletons = true;
$('#new-file').click(function(e) {
that._prompt_name('File').then(function(name) {
that._create('file', name).then(function() {
that.load_sessions();
});
});
});
$('#new-folder').click(function(e) {
that._prompt_name('Folder').then(function(name) {
that._create('directory', name).then(function() {
that.load_sessions();
});
});
});
}
};
NotebookList.prototype.handleFilesUpload = function(event, dropOrForm) {
@ -519,6 +538,90 @@ define([
.append(cancel_button);
};
/**
* Prompt the user for a name.
* @param {string} what - What you want a name for.
* @return {Promise} Promise that resolve with a string name
*/
NotebookList.prototype._prompt_name = function(what) {
var that = this;
var dialog_body = $('<div/>').append(
$("<p/>").addClass("rename-message")
.text(what + ' name:')
).append(
$("<br/>")
).append(
$('<input/>').attr('type','text').attr('size','25').addClass('form-control')
.val('') // Default to empty
);
return new Promise(function(resolve, reject) {
var dialog_inst = dialog.modal({
title: "Rename Notebook",
body: dialog_body,
buttons: {
"OK": {
class: "btn-primary",
click: function () {
resolve(dialog_inst.find('input').val());
}
},
"Cancel": {
click: function () {
reject();
}
}
}, open: function () {
/**
* Upon ENTER, click the OK button.
*/
dialog_inst.find('input[type="text"]').keydown(function (event) {
if (event.which === keyboard.keycodes.enter) {
dialog_inst.find('.btn-primary').first().click();
return false;
}
});
dialog_inst.find('input[type="text"]').focus().select();
}
});
});
};
/**
* Creates a `file` or `directory`
* @param {string} type - "file" or "directory"
* @param {string} name - name of the thing to create
* @return {Promise} success
*/
NotebookList.prototype._create = function(type, name) {
var that = this;
return new Promise(function(resolve, reject) {
var settings = {
processData : false,
cache : false,
type : "PUT",
data: JSON.stringify({
type: type,
format: 'text',
content: '',
}),
dataType: "json",
success: function () {
resolve();
},
error: function() {
reject();
utils.log_ajax_error.apply(this, arguments);
},
};
var url = utils.url_join_encode(
that.base_url,
'api/contents/' + name
);
$.ajax(url, settings);
});
};
// Backwards compatability.
IPython.NotebookList = NotebookList;

View File

@ -156,7 +156,7 @@ input.engine_num_input {
.icon(@fa-var-file-o)
}
ul#new-notebook-menu {
ul#new-menu {
// align right instead of left
left: auto;
right: 0;

View File

@ -42,16 +42,22 @@ data-terminals-available="{{terminals_available}}"
</span>
</span>
</form>
<div id="notebook_buttons" class="pull-right btn-toolbar">
<div id="new-notebook-buttons" class="btn-group">
<button id="new_notebook" class="btn btn-default btn-xs">
New Notebook
</button>
<div class="pull-right">
<div id="new-buttons" class="btn-group">
<button class="dropdown-toggle btn btn-default btn-xs" data-toggle="dropdown">
<span id="current-kernel">Loading...</span>
<span>New</span>
<span class="caret"></span>
</button>
<ul id="new-notebook-menu" class="dropdown-menu"></ul>
<ul id="new-menu" class="dropdown-menu">
<li role="presentation" class="dropdown-header" id="notebook-kernels">Notebooks</li>
<li role="presentation" class="divider"></li>
<li role="presentation" id="new-file">
<a role="menuitem" tabindex="-1" href="#">File</a>
</li>
<li role="presentation" id="new-folder">
<a role="menuitem" tabindex="-1" href="#">Folder</a>
</li>
</ul>
</div>
<div class="btn-group">
<button id="refresh_notebook_list" title="Refresh notebook list" class="btn btn-default btn-xs"><i class="fa fa-refresh"></i></button>