// Copyright (c) IPython Development Team.
// Distributed under the terms of the Modified BSD License.
define([
'base/js/namespace',
'components/jquery/jquery.min',
], function(IPython, $) {
"use strict";
var modal = function (options, keyboard_manager, notebook) {
var modal = $("
")
.addClass("modal")
.addClass("fade")
.attr("role", "dialog");
var dialog = $("
")
.addClass("modal-dialog")
.appendTo(modal);
var dialog_content = $("
")
.addClass("modal-content")
.appendTo(dialog);
dialog_content.append(
$("
")
.addClass("modal-header")
.append($("")
.attr("type", "button")
.addClass("close")
.attr("data-dismiss", "modal")
.attr("aria-hidden", "true")
.html("×")
).append(
$(" ")
.addClass('modal-title')
.text(options.title || "")
)
).append(
$("
").addClass("modal-body").append(
options.body || $("
")
)
);
var footer = $("
").addClass("modal-footer");
for (var label in options.buttons) {
var btn_opts = options.buttons[label];
var button = $(" ")
.addClass("btn btn-default btn-sm")
.attr("data-dismiss", "modal")
.text(label);
if (btn_opts.click) {
button.click($.proxy(btn_opts.click, dialog_content));
}
if (btn_opts.class) {
button.addClass(btn_opts.class);
}
footer.append(button);
}
dialog_content.append(footer);
// hook up on-open event
modal.on("shown.bs.modal", function() {
setTimeout(function() {
footer.find("button").last().focus();
if (options.open) {
$.proxy(options.open, modal)();
}
}, 0);
});
// destroy modal on hide, unless explicitly asked not to
if (options.destroy === undefined || options.destroy) {
modal.on("hidden.bs.modal", function () {
modal.remove();
});
}
modal.on("hidden.bs.modal", function () {
if (notebook) {
var cell = notebook.get_selected_cell();
if (cell) cell.select();
keyboard_manager.enable();
keyboard_manager.command_mode();
}
});
if (keyboard_manager) {
keyboard_manager.disable();
}
return modal.modal(options);
};
var edit_metadata = function (md, callback, name, keyboard_manager, notebook) {
name = name || "Cell";
var error_div = $('
').css('color', 'red');
var message =
"Manually edit the JSON below to manipulate the metadata for this " + name + "." +
" We recommend putting custom metadata attributes in an appropriately named sub-structure," +
" so they don't conflict with those of others.";
var textarea = $('')
.attr('rows', '13')
.attr('cols', '80')
.attr('name', 'metadata')
.text(JSON.stringify(md || {}, null, 2));
var dialogform = $('
').attr('title', 'Edit the metadata')
.append(
$('').append(
$(' ').append(
$(' ')
.attr('for','metadata')
.text(message)
)
.append(error_div)
.append($(' '))
.append(textarea)
)
);
var editor = CodeMirror.fromTextArea(textarea[0], {
lineNumbers: true,
matchBrackets: true,
indentUnit: 2,
autoIndent: true,
mode: 'application/json',
});
var modal = modal({
title: "Edit " + name + " Metadata",
body: dialogform,
buttons: {
OK: { class : "btn-primary",
click: function() {
// validate json and set it
var new_md;
try {
new_md = JSON.parse(editor.getValue());
} catch(e) {
console.log(e);
error_div.text('WARNING: Could not save invalid JSON.');
return false;
}
callback(new_md);
}
},
Cancel: {}
}
}, keyboard_manager, notebook);
modal.on('shown.bs.modal', function(){ editor.refresh(); });
};
Dialog = {
modal : modal,
edit_metadata : edit_metadata,
};
// Backwards compatability.
IPython.Dialog = Dialog;
return Dialog;
});