1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
function save_file()
{
var savebutton = document.getElementById("save_button");
var filename = document.getElementById("save_filename").value;
data = editAreaLoader.getValue("editbox");
/* Do NOT refresh the page contents (causes problems for editarea and is
* unnecessary). */
do_action("putfile", filename,
{"path":".", "data":data, "overwrite":"true"},
"multipart/form-data", true);
savebutton.setAttribute("value", "Saved");
// XXX Do not disable for now; there is a problem getting the callback
// to edit_text.
//savebutton.setAttribute("disabled", "disabled");
}
function edit_text()
{
var savebutton = document.getElementById("save_button");
savebutton.setAttribute("value", "Save");
savebutton.removeAttribute("disabled");
}
/** Presents the "editor heading" (the part with the save box)
* inserting it into a given element at the front.
*/
function present_editorhead(elem, path, handler_type)
{
var div = document.getElementById("actions2");
/* Set up minimal interface */
var p = dom_make_text_elem("p", "Save as: ");
var pathname = document.createElement("input");
pathname.setAttribute("type", "text");
pathname.setAttribute("size", "30");
pathname.setAttribute("id", "save_filename");
pathname.setAttribute("value", path);
p.appendChild(pathname);
var savebutton = document.createElement("input");
savebutton.setAttribute("id", "save_button");
savebutton.setAttribute("type", "button");
savebutton.setAttribute("value", "Saved");
// XXX Do not disable for now; there is a problem getting the callback
// to edit_text.
//savebutton.setAttribute("disabled", "disabled");
savebutton.setAttribute("onclick", "save_file()");
p.appendChild(savebutton);
var t = document.createTextNode(" ");
p.appendChild(t);
div.appendChild(p);
/* Print a warning message if this is not actually a text file.
*/
if (handler_type != "text")
{
var warn = dom_make_text_elem("p",
"Warning: You are editing a binary " +
"file, which explains any strange characters you may see. If " +
"you save this file, you could corrupt it.");
div.appendChild(warn);
}
}
/** Presents the text editor.
*/
function handle_text(path, text, handler_type)
{
/* Create a textarea with the text in it
* (The makings of a primitive editor).
*/
var files = document.getElementById("filesbody");
/* Put our UI at the top */
present_editorhead(files, path, handler_type);
var div = document.createElement("div");
files.appendChild(div);
var txt_elem = dom_make_text_elem("textarea",
text.toString())
div.appendChild(txt_elem);
txt_elem.setAttribute("id", "editbox");
txt_elem.setAttribute("onchange", "edit_text()");
/* TODO: Make CSS height: 100% work */
txt_elem.setAttribute("rows", "35");
/* Load EditArea into the editbox */
editAreaLoader.init({
id : "editbox",
syntax: "python",
toolbar: "search, go_to_line, |, undo, redo, |, select_font, |, syntax_selection, |, highlight, |, help",
start_highlight: true,
allow_toggle: false,
allow_resize: false,
replace_tab_by_spaces: 4,
change_callback: "edit_text"
});
}
|