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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
|
/* IVLE
* Copyright (C) 2007-2008 The University of Melbourne
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
/* Module: SpecialHome (File Browser, client)
* Author: David Coles
* Date: 23/7/2008
*/
/* This module implements the functionality to lay out a special home directory
* view on top of the normal listing
*/
/* The name of the personal file directory */
PERSONALDIR="mywork"
/* LAYOUT FUNCTIONS */
/** Present special home directory. This is only called if in the top level.
* Subjects must not be null.
*/
function special_home_listing(listing, subjects, path)
{
/* Nav through the top-level of the JSON to the actual listing object. */
var listing = listing.listing;
var filetablediv = document.getElementById("filetablediv");
var specialhomediv;
var h2;
var h3;
var ul;
var li;
var div;
/* Wrap all this "special" stuff in a div, for styling purposes */
specialhomediv = document.createElement("div");
specialhomediv.setAttribute("id", "specialhome");
filetablediv.appendChild(specialhomediv);
/* SUBJECTS Section
/* Create the header row */
if (subjects.length > 0)
{
h2 = dom_make_text_elem("h2", "Subjects");
specialhomediv.appendChild(h2);
}
/* Create the contents */
for (var i=0; i<subjects.length; i++)
{
var subject = subjects[i];
var subjpath = subject.subj_short_name;
// Header, with link to offering home page.
h3 = $('<h3><span></span> <span style="font-weight: normal">– <a class="subjectaction">Subject home</a></span>');
h3.find('span:first-child').text(subject.subj_name);
h3.find('a').attr('href', subject.url);
$(specialhomediv).append(h3);
/* Print the file listing */
ul = document.createElement("ul");
// Stuff
ul.appendChild(make_subject_item(subjpath,
path_join("users", username, subjpath), PERSONALDIR,
"Your own files in this subject"));
// Groups
var groups = subject.groups;
for (var j=0; j<subject.groups.length; j++)
{
var group = subject.groups[j];
ul.appendChild(make_subject_item(subjpath,
path_join("groups", subject.subj_short_name + "_" +
subject.year + "_" + subject.semester + "_" +
group.name),
group.name,
"This group's files in this subject"));
}
specialhomediv.appendChild(ul);
/* Remove it from listing */
if (subject.subj_short_name in listing)
delete listing[subject.subj_short_name];
}
/* FIXME: Old Subjects? */
/* STUFF Section -- For the stuff directory */
/* Create the header */
h2 = dom_make_text_elem("h2", "Stuff");
specialhomediv.appendChild(h2);
/* Create the contents */
ul = document.createElement("ul");
ul.appendChild(make_subject_item("",
path_join("users", username, "stuff"), "stuff",
"Your own files not related to a subject"));
specialhomediv.appendChild(ul);
/* Remove stuff from the listing */
if ("stuff" in listing)
delete listing["stuff"];
/* JUNK Section -- All the rest */
/* Create the header row */
if (obj_length(listing) > 0)
{
h2 = dom_make_text_elem("h2", "Junk");
specialhomediv.appendChild(h2);
handle_dir_listing(path, listing);
}
}
/* Does an series of AJAX requests to find out the properties of this folder
* and then updates the folder view
*/
function make_subject_item(path, repopath, name, description)
{
// Create the temporary item
var li = document.createElement("li");
var span;
li.setAttribute("class", "listing-loading");
li.appendChild(dom_make_text_elem("span", name, description));
span = dom_make_text_elem("loading...");
span.setAttribute("class","status");
li.appendChild(span);
// Set the callback function to update when we get the real details
var callback = function(response)
{
var sublisting = decode_response(response);
dom_removechildren(li);
li.setAttribute("class", "listing-dir");
// If we could find the file status...
if (sublisting != null)
{
var thisdir = sublisting.listing['.'];
var versioned = ("svnstatus" in thisdir) && (thisdir.svnstatus != "unversioned");
if (versioned)
{
// Default: Just offer a link to the directory
li.appendChild(dom_make_link_elem("span", name, description,
app_path(this_app, username, path, name)));
}
else
{
// Blocked: Offer to rename the directory
li.appendChild(dom_make_text_elem("span", name, description));
span = dom_make_text_elem("span", " (blocked) ",
"Another file or directory is in the way of this directory.");
span.setAttribute("class", "status");
li.appendChild(span);
var button = document.createElement("input");
$(button).click(function(event)
{
action_rename(path_join(path, name));
});
button.setAttribute("type", "button");
button.setAttribute("value", "Rename");
span.appendChild(button);
}
}
else if (response.status == 404)
{
// Missing: Try to check out or create the repository
li.appendChild(dom_make_text_elem("span", name, description));
span = dom_make_text_elem("span", " (missing) ",
"This directory does not yet exist.");
span.setAttribute("class", "status");
li.appendChild(span);
var button = document.createElement("input");
$(button).click(function(event)
{
li.setAttribute("class", "listing-loading");
var localpath = path_join(path, name);
if (create_if_needed(repopath))
{
// Try a checkout
do_act("svncheckout", {"path": [repopath, localpath]});
}
else
{
li.setAttribute("class", "listing-dir");
}
});
button.setAttribute("type", "button");
button.setAttribute("value", "Checkout");
span.appendChild(button);
}
else
{
// Error: The directory listing could not be retrieved
// Make a link in case the user wants to investigate
li.appendChild(dom_make_link_elem("span", name, description,
app_path(this_app, username, path, name)));
span = dom_make_text_elem("span",
" (error \u2013 contact system administrator)",
"There was an error retrieving information about this "
+ "directory.");
span.setAttribute("class", "status");
li.appendChild(span);
}
}
/* Are we working in a subdirectory or parent? */
ajax_call(callback, service_app, path_join(username, path, name), {}, "GET");
return li;
}
function create_if_needed(path)
{
response = ajax_call(null, service_app, current_path,
{
"action": "svnrepostat",
"path": path
}, "POST");
if (response.status == 200)
{
return true;
}
else if (response.status == 404)
{
// Try a mkdir
r2 = ajax_call(null, service_app, current_path,
{
"action": "svnrepomkdir",
"path": path,
"logmsg": "Automated creation of '" + path + "' work directory"
}, "POST");
if (r2.status == 200)
{
return true;
}
}
alert("Error: Could not create Subversion directory");
return false;
}
/** Finds the length (number of user defined properties) of an object
*/
function obj_length(obj)
{
len = 0;
for (prop in obj)
len++;
return len;
}
|