1
// Open simple dialogs on top of an editor. Relies on dialog.css.
4
function dialogDiv(cm, template) {
5
var wrap = cm.getWrapperElement();
6
var dialog = wrap.insertBefore(document.createElement("div"), wrap.firstChild);
7
dialog.className = "CodeMirror-dialog";
8
dialog.innerHTML = '<div>' + template + '</div>';
12
CodeMirror.defineExtension("openDialog", function(template, callback) {
13
var dialog = dialogDiv(this, template);
14
var closed = false, me = this;
18
dialog.parentNode.removeChild(dialog);
20
var inp = dialog.getElementsByTagName("input")[0], button;
22
CodeMirror.connect(inp, "keydown", function(e) {
23
if (e.keyCode == 13 || e.keyCode == 27) {
27
if (e.keyCode == 13) callback(inp.value);
31
CodeMirror.connect(inp, "blur", close);
32
} else if (button = dialog.getElementsByTagName("button")[0]) {
33
CodeMirror.connect(button, "click", function() {
38
CodeMirror.connect(button, "blur", close);
43
CodeMirror.defineExtension("openConfirm", function(template, callbacks) {
44
var dialog = dialogDiv(this, template);
45
var buttons = dialog.getElementsByTagName("button");
46
var closed = false, me = this, blurring = 1;
50
dialog.parentNode.removeChild(dialog);
54
for (var i = 0; i < buttons.length; ++i) {
57
CodeMirror.connect(b, "click", function(e) {
58
CodeMirror.e_preventDefault(e);
60
if (callback) callback(me);
63
CodeMirror.connect(b, "blur", function() {
65
setTimeout(function() { if (blurring <= 0) close(); }, 200);
67
CodeMirror.connect(b, "focus", function() { ++blurring; });