##// END OF EJS Templates
Autocompletion working with CTRL-SPACE.
Brian E. Granger -
Show More
@@ -3,7 +3,7 b' span.py-special {color: #666666;}'
3
3
4 span.py-operator {color: #AA22FF; font-weight: bold;}
4 span.py-operator {color: #AA22FF; font-weight: bold;}
5
5
6 span.py-error {background-color: #000000; color: #FF0000;}
6 /*span.py-error {background-color: #000000; color: #FF0000;}*/
7
7
8 span.py-keyword {color: #008000; font-weight: bold;}
8 span.py-keyword {color: #008000; font-weight: bold;}
9
9
@@ -353,6 +353,19 b' div.text_cell_render ol ol ol ol ol {list-style:lower-roman;}'
353 .ansigrey {color: grey;}
353 .ansigrey {color: grey;}
354 .ansibold {font-weight: bold;}
354 .ansibold {font-weight: bold;}
355
355
356 .completions {
357 position: absolute;
358 z-index: 10;
359 overflow: auto;
360 border: 1px solid black;
361 }
356
362
357
363 .completions select {
364 background: white;
365 outline: none;
366 border: none;
367 padding: 0px;
368 margin: 0px;
369 font-family: monospace;
358 }
370 }
371
@@ -10,6 +10,8 b' var IPython = (function (IPython) {'
10 var CodeCell = function (notebook) {
10 var CodeCell = function (notebook) {
11 this.code_mirror = null;
11 this.code_mirror = null;
12 this.input_prompt_number = ' ';
12 this.input_prompt_number = ' ';
13 this.is_completing = false;
14 this.completion_cursor = null;
13 IPython.Cell.apply(this, arguments);
15 IPython.Cell.apply(this, arguments);
14 };
16 };
15
17
@@ -43,11 +45,93 b' var IPython = (function (IPython) {'
43 if (event.keyCode === 13 && event.shiftKey) {
45 if (event.keyCode === 13 && event.shiftKey) {
44 // Always ignore shift-enter in CodeMirror as we handle it.
46 // Always ignore shift-enter in CodeMirror as we handle it.
45 return true;
47 return true;
48 } else if (event.keyCode == 32 && (event.ctrlKey || event.metaKey) && !event.altKey) {
49 event.stop();
50 var cur = editor.getCursor();
51 var line = editor.getLine(cur.line);
52 this.is_completing = true;
53 this.completion_cursor = cur;
54 IPython.notebook.complete_cell(this, line, cur.ch);
46 } else {
55 } else {
56 if (this.is_completing && this.completion_cursor !== editor.getCursor()) {
57 this.is_completing = false;
58 this.completion_cursor = null;
59 console.log("Stopped completing early");
60 }
47 return false;
61 return false;
48 };
62 };
49 };
63 };
50
64
65
66 CodeCell.prototype.finish_completing = function (matched_text, matches) {
67 if (!this.is_completing || matches.length === 0) {return;}
68 // console.log("Got matches", matched_text, matches);
69
70 var that = this;
71 var cur = this.completion_cursor;
72 var complete = $('<div/>').addClass('completions');
73 var select = $('<select/>').attr('multiple','true');
74 for (var i=0; i<matches.length; ++i) {
75 select.append($('<option/>').text(matches[i]));
76 }
77 select.children().first().attr('selected','true');
78 select.attr('size',Math.min(10,matches.length));
79 var pos = this.code_mirror.cursorCoords();
80 complete.css('left',pos.x+'px');
81 complete.css('top',pos.yBot+'px');
82 complete.append(select);
83
84 $('body').append(complete);
85 var done = false;
86
87 var insert = function (selected_text) {
88 that.code_mirror.replaceRange(
89 selected_text,
90 {line: cur.line, ch: (cur.ch-matched_text.length)},
91 {line: cur.line, ch: cur.ch}
92 );
93 };
94
95 var close = function () {
96 if (done) return;
97 done = true;
98 complete.remove();
99 that.is_completing = false;
100 that.completion_cursor = null;
101 };
102
103 var pick = function () {
104 insert(select.val()[0]);
105 close();
106 setTimeout(function(){that.code_mirror.focus();}, 50);
107 };
108
109 select.blur(close);
110 select.keydown(function (event) {
111 var code = event.which;
112 if (code === 13 || code === 32) {
113 // Pressing SPACE or ENTER will cause a pick
114 event.stopPropagation();
115 event.preventDefault();
116 pick();
117 } else if (code === 38 || code === 40) {
118 // We don't want the document keydown handler to handle UP/DOWN,
119 // but we want the default action.
120 event.stopPropagation();
121 } else {
122 // All other key presses simple exit completion.
123 event.stopPropagation();
124 event.preventDefault();
125 close();
126 that.code_mirror.focus();
127 }
128 });
129 // Double click also causes a pick.
130 select.dblclick(pick);
131 select.focus();
132 };
133
134
51 CodeCell.prototype.select = function () {
135 CodeCell.prototype.select = function () {
52 IPython.Cell.prototype.select.apply(this);
136 IPython.Cell.prototype.select.apply(this);
53 this.code_mirror.focus();
137 this.code_mirror.focus();
@@ -18,7 +18,7 b' var IPython = (function (IPython) {'
18 var msg = {
18 var msg = {
19 header : {
19 header : {
20 msg_id : utils.uuid(),
20 msg_id : utils.uuid(),
21 username : "bgranger",
21 username : "username",
22 session: this.session_id,
22 session: this.session_id,
23 msg_type : msg_type
23 msg_type : msg_type
24 },
24 },
@@ -403,7 +403,7 b' var IPython = (function (IPython) {'
403 if (msg_type === "execute_reply") {
403 if (msg_type === "execute_reply") {
404 cell.set_input_prompt(content.execution_count);
404 cell.set_input_prompt(content.execution_count);
405 } else if (msg_type === "complete_reply") {
405 } else if (msg_type === "complete_reply") {
406 console.log(content);
406 cell.finish_completing(content.matched_text, content.matches);
407 };
407 };
408 var payload = content.payload || [];
408 var payload = content.payload || [];
409 this.handle_payload(payload);
409 this.handle_payload(payload);
@@ -505,6 +505,12 b' var IPython = (function (IPython) {'
505 this.scroll_to_bottom();
505 this.scroll_to_bottom();
506 };
506 };
507
507
508
509 Notebook.prototype.complete_cell = function (cell, line, cursor_pos) {
510 var msg_id = this.kernel.complete(line, cursor_pos);
511 this.msg_cell_map[msg_id] = cell.cell_id;
512 };
513
508 // Persistance and loading
514 // Persistance and loading
509
515
510
516
General Comments 0
You need to be logged in to leave comments. Login now