~azzar1/unity/add-show-desktop-key

« back to all changes in this revision

Viewing changes to www/media/browser/editor.js

  • Committer: mattgiuca
  • Date: 2008-02-28 07:52:35 UTC
  • Revision ID: svn-v3-trunk0:2b9c9e99-6f39-0410-b283-7f802c844ae2:trunk:608
browser/listing: REMOVED the generation of all action links to the right
    panel. (Yes, this is the end of an era).
    Split the "Modified" stamp in the right panel to split over 3 lines so it
    takes up less horizontal space.
    Shrunk the right panel from 300px down to 200px, as requested by Steven
    Bird.
We can now rely solely on the top dropdown for doing actions.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
function disable_save_if_safe()
2
 
{
3
 
    /* If this is defined, this engine supports change notification, so is able
4
 
     * to enable the button again. Disable it for them. */
5
 
    if(editbox.editor.addChangeHandler)
6
 
    {
7
 
        var savebutton = document.getElementById("save_button");
8
 
        savebutton.disabled = true;
9
 
        window.onbeforeunload = null;
10
 
    }
11
 
}
 
1
saved_status = null;
12
2
 
13
 
function save_file(filename)
 
3
function save_file()
14
4
{
15
 
    data = editbox.getCode();
 
5
    filename = document.getElementById("save_filename").value;
 
6
    data = editAreaLoader.getValue("editbox");
16
7
    /* Do NOT refresh the page contents (causes problems for editarea and is
17
8
     * unnecessary). */
18
 
    if (current_file.svnstatus != "revision" ||
19
 
        confirm("You are currently viewing an older version of this file. " +
20
 
                "Saving will overwrite the current version. " +
21
 
                "Are you sure you want to continue?"))
22
 
    {
23
 
        do_action("putfile", filename,
24
 
                  {"path":".", "data":data, "overwrite":"true"},
25
 
                  "multipart/form-data", true);
26
 
        disable_save_if_safe();
27
 
    }
28
 
}
29
 
 
30
 
function save_file_as(default_filename)
31
 
{
32
 
    filename = prompt("Path to save to:", default_filename);
33
 
    if (!filename) return;
34
 
 
35
 
    /* The filename will be path_joined with the app name, so needs to not
36
 
     * be absolute, lest it clobber the app name. */
37
 
    if (filename.charAt(0) == "/") filename = filename.substring(1);
38
 
    ajax_call(save_file_as_callback, "fileservice", filename, {}, "POST");
39
 
}
40
 
 
41
 
function save_file_as_callback(response)
42
 
{
43
 
    if (response.status == 404 || confirm("Are you sure you want to overwrite " + filename + "?"))
44
 
        save_file(filename);
45
 
}
46
 
 
47
 
/* Return a warning to be used in window.onbeforeunload. */
48
 
function confirm_beforeunload() {
49
 
    return 'If you continue, any unsaved changes to the current file will be lost.';
 
9
    do_action("putfile", filename, {"path":".", "data":data}, null, true);
 
10
    saved_status.data = "Saved.";
50
11
}
51
12
 
52
13
function edit_text()
53
14
{
54
 
    var savebutton = document.getElementById("save_button");
55
 
    savebutton.disabled = false;
56
 
    window.onbeforeunload = confirm_beforeunload;
 
15
    saved_status.data = "Not saved.";
57
16
}
58
17
 
59
 
/** Presents the "editor heading" inserting it into a given element at
60
 
 *  the front. Note that the save widget is handled by the Python.
 
18
/** Presents the "editor heading" (the part with the save box)
 
19
 * inserting it into a given element at the front.
61
20
 */
62
21
function present_editorhead(elem, path, handler_type)
63
22
{
64
 
    var div = document.getElementById("actions2");
 
23
    var div = document.createElement("div");
 
24
    /* Insert as the head element */
 
25
    elem.insertBefore(div, elem.firstChild)
 
26
    div.setAttribute("id", "editorhead");
 
27
 
 
28
    /* Set up minimal interface */
 
29
    var p = dom_make_text_elem("p", "Path: ");
 
30
    var pathname = document.createElement("input");
 
31
    pathname.setAttribute("type", "text");
 
32
    pathname.setAttribute("size", "30");
 
33
    pathname.setAttribute("id", "save_filename");
 
34
    pathname.setAttribute("value", path);
 
35
    p.appendChild(pathname);
 
36
    var savebutton = document.createElement("input");
 
37
    savebutton.setAttribute("type", "button");
 
38
    savebutton.setAttribute("value", "Save");
 
39
    savebutton.setAttribute("onclick", "save_file()");
 
40
    p.appendChild(savebutton);
 
41
    var t = document.createTextNode(" ");
 
42
    p.appendChild(t);
 
43
    saved_status = document.createTextNode("Saved.");
 
44
    //p.appendChild(saved_status);
 
45
    div.appendChild(p);
65
46
 
66
47
    /* Print a warning message if this is not actually a text file.
67
48
     */
75
56
    }
76
57
}
77
58
 
78
 
function highlighting_changed(select)
79
 
{
80
 
    editbox.edit(editbox.getCode(), select.value);
81
 
}
82
 
 
83
 
function initialise_codepress()
84
 
{
85
 
    editbox.addChangeHandler(edit_text);
86
 
    editbox.addSaveHandler(function() {document.getElementById("save_button").click()});
87
 
     
88
 
    /* We can only safely disable the save button on the first load.
89
 
     * Syntax highlighting changes will also get this function called.
90
 
     * We unfortunately need the change handler added each time.
91
 
     */
92
 
    if (!initialise_codepress.already)
93
 
    {
94
 
        disable_save_if_safe();
95
 
        initialise_codepress.already = true;
96
 
    }
97
 
}
98
 
 
99
59
/** Presents the text editor.
100
60
 */
101
61
function handle_text(path, text, handler_type)
108
68
    present_editorhead(files, path, handler_type);
109
69
 
110
70
    var div = document.createElement("div");
111
 
    div.style.height = '100%';
112
71
    files.appendChild(div);
113
72
    var txt_elem = dom_make_text_elem("textarea",
114
73
        text.toString())
115
74
    div.appendChild(txt_elem);
116
75
    txt_elem.setAttribute("id", "editbox");
117
 
    language = language_from_mime(current_file.type);
118
 
 
119
 
    // Assume plaintext if no type can be determined.
120
 
    language = language ? language : "text";
121
 
    document.getElementById("highlighting_select").value = language;
122
 
 
123
 
    txt_elem.className = "codepress autocomplete-off " + language;
124
76
    txt_elem.setAttribute("onchange", "edit_text()");
125
77
    /* TODO: Make CSS height: 100% work */
126
78
    txt_elem.setAttribute("rows", "35");
127
 
    CodePress.run();
128
 
 
129
 
    window.onbeforeunload = confirm_beforeunload;
130
 
 
131
 
    /* And set a callback so we know that the editor iframe is loaded so we
132
 
     * can set a callback so we know when to enable the save button.
133
 
     * We also take this opportunity to disable the save button, if
134
 
     * the browser is likely to reenable it as needed. */
135
 
    editbox.onload = initialise_codepress
136
 
}
137
 
 
138
 
function language_from_mime(mime)
139
 
{
140
 
    return {'text/x-python': 'python',
141
 
            'application/javascript': 'javascript',
142
 
            'text/css': 'css',
143
 
            'text/plain': 'text',
144
 
            'text/html': 'html',
145
 
            'application/xml': 'html',
146
 
            'application/xhtml+xml': 'html'}[mime];
147
 
}
 
79
 
 
80
    /* Load EditArea into the editbox */
 
81
    editAreaLoader.init({
 
82
        id : "editbox",
 
83
        syntax: "python",
 
84
        toolbar: "search, go_to_line, |, undo, redo, |, select_font, |, syntax_selection, |, highlight, |, help",
 
85
        start_highlight: true,
 
86
        allow_toggle: false,
 
87
        allow_resize: false,
 
88
        replace_tab_by_spaces: 4
 
89
    });
 
90
}
 
91