blob: 763ec30ce028f10d1fdb50625d6bf93f072671dd [file] [log] [blame]
David Ghandehari9e5b5872016-07-28 09:50:04 -07001<!DOCTYPE html>
2
Andrew Top0d1858f2019-05-15 22:01:47 -07003<html dir="$i18n{textdirection}" lang="$i18n{language}">
David Ghandehari9e5b5872016-07-28 09:50:04 -07004
5<head>
Andrew Top0d1858f2019-05-15 22:01:47 -07006<meta charset="utf-8">
7<meta name="google" value="notranslate">
David Ghandehari9e5b5872016-07-28 09:50:04 -07008
9<script>
Andrew Top0d1858f2019-05-15 22:01:47 -070010function addRow(name, url, isdir,
11 size, size_string, date_modified, date_modified_string) {
12 if (name == "." || name == "..")
David Ghandehari9e5b5872016-07-28 09:50:04 -070013 return;
14
Andrew Top0d1858f2019-05-15 22:01:47 -070015 var root = document.location.pathname;
David Ghandehari9e5b5872016-07-28 09:50:04 -070016 if (root.substr(-1) !== "/")
17 root += "/";
18
Andrew Top0d1858f2019-05-15 22:01:47 -070019 var tbody = document.getElementById("tbody");
David Ghandehari9e5b5872016-07-28 09:50:04 -070020 var row = document.createElement("tr");
21 var file_cell = document.createElement("td");
22 var link = document.createElement("a");
23
24 link.className = isdir ? "icon dir" : "icon file";
25
Andrew Top0d1858f2019-05-15 22:01:47 -070026 if (isdir) {
27 name = name + "/";
28 url = url + "/";
29 size = 0;
30 size_string = "";
David Ghandehari9e5b5872016-07-28 09:50:04 -070031 } else {
Andrew Top0d1858f2019-05-15 22:01:47 -070032 link.draggable = "true";
33 link.addEventListener("dragstart", onDragStart, false);
David Ghandehari9e5b5872016-07-28 09:50:04 -070034 }
Andrew Top0d1858f2019-05-15 22:01:47 -070035 link.innerText = name;
36 link.href = root + url;
37
38 file_cell.dataset.value = name;
David Ghandehari9e5b5872016-07-28 09:50:04 -070039 file_cell.appendChild(link);
40
41 row.appendChild(file_cell);
Andrew Top0d1858f2019-05-15 22:01:47 -070042 row.appendChild(createCell(size, size_string));
43 row.appendChild(createCell(date_modified, date_modified_string));
David Ghandehari9e5b5872016-07-28 09:50:04 -070044
Andrew Top0d1858f2019-05-15 22:01:47 -070045 tbody.appendChild(row);
David Ghandehari9e5b5872016-07-28 09:50:04 -070046}
47
48function onDragStart(e) {
49 var el = e.srcElement;
50 var name = el.innerText.replace(":", "");
51 var download_url_data = "application/octet-stream:" + name + ":" + el.href;
52 e.dataTransfer.setData("DownloadURL", download_url_data);
53 e.dataTransfer.effectAllowed = "copy";
54}
55
Andrew Top0d1858f2019-05-15 22:01:47 -070056function createCell(value, text) {
David Ghandehari9e5b5872016-07-28 09:50:04 -070057 var cell = document.createElement("td");
58 cell.setAttribute("class", "detailsColumn");
Andrew Top0d1858f2019-05-15 22:01:47 -070059 cell.dataset.value = value;
David Ghandehari9e5b5872016-07-28 09:50:04 -070060 cell.innerText = text;
61 return cell;
62}
63
64function start(location) {
65 var header = document.getElementById("header");
66 header.innerText = header.innerText.replace("LOCATION", location);
67
68 document.getElementById("title").innerText = header.innerText;
69}
70
Andrew Top0d1858f2019-05-15 22:01:47 -070071function onHasParentDirectory() {
72 var box = document.getElementById("parentDirLinkBox");
73 box.style.display = "block";
74
75 var root = document.location.pathname;
76 if (!root.endsWith("/"))
77 root += "/";
78
79 var link = document.getElementById("parentDirLink");
80 link.href = root + "..";
81}
82
David Ghandehari9e5b5872016-07-28 09:50:04 -070083function onListingParsingError() {
84 var box = document.getElementById("listingParsingErrorBox");
85 box.innerHTML = box.innerHTML.replace("LOCATION", encodeURI(document.location)
86 + "?raw");
87 box.style.display = "block";
88}
Andrew Top0d1858f2019-05-15 22:01:47 -070089
90function sortTable(column) {
91 var theader = document.getElementById("theader");
92 var oldOrder = theader.cells[column].dataset.order || '1';
93 oldOrder = parseInt(oldOrder, 10)
94 var newOrder = 0 - oldOrder;
95 theader.cells[column].dataset.order = newOrder;
96
97 var tbody = document.getElementById("tbody");
98 var rows = tbody.rows;
99 var list = [], i;
100 for (i = 0; i < rows.length; i++) {
101 list.push(rows[i]);
102 }
103
104 list.sort(function(row1, row2) {
105 var a = row1.cells[column].dataset.value;
106 var b = row2.cells[column].dataset.value;
107 if (column) {
108 a = parseInt(a, 10);
109 b = parseInt(b, 10);
110 return a > b ? newOrder : a < b ? oldOrder : 0;
111 }
112
113 // Column 0 is text.
114 if (a > b)
115 return newOrder;
116 if (a < b)
117 return oldOrder;
118 return 0;
119 });
120
121 // Appending an existing child again just moves it.
122 for (i = 0; i < list.length; i++) {
123 tbody.appendChild(list[i]);
124 }
125}
David Ghandehari9e5b5872016-07-28 09:50:04 -0700126</script>
127
128<style>
129
130 h1 {
131 border-bottom: 1px solid #c0c0c0;
132 margin-bottom: 10px;
133 padding-bottom: 10px;
134 white-space: nowrap;
135 }
136
137 table {
138 border-collapse: collapse;
139 }
140
Andrew Top0d1858f2019-05-15 22:01:47 -0700141 th {
142 cursor: pointer;
David Ghandehari9e5b5872016-07-28 09:50:04 -0700143 }
144
145 td.detailsColumn {
Andrew Top0d1858f2019-05-15 22:01:47 -0700146 -webkit-padding-start: 2em;
147 text-align: end;
David Ghandehari9e5b5872016-07-28 09:50:04 -0700148 white-space: nowrap;
149 }
150
151 a.icon {
Andrew Top0d1858f2019-05-15 22:01:47 -0700152 -webkit-padding-start: 1.5em;
David Ghandehari9e5b5872016-07-28 09:50:04 -0700153 text-decoration: none;
154 }
155
156 a.icon:hover {
157 text-decoration: underline;
158 }
159
160 a.file {
161 background : url(" ") left top no-repeat;
162 }
163
164 a.dir {
165 background : url(" ") left top no-repeat;
166 }
167
168 a.up {
169 background : url(" ") left top no-repeat;
170 }
171
Andrew Top0d1858f2019-05-15 22:01:47 -0700172 html[dir=rtl] a {
173 background-position-x: right;
174 }
175
176 #parentDirLinkBox {
177 margin-bottom: 10px;
178 padding-bottom: 10px;
179 }
180
David Ghandehari9e5b5872016-07-28 09:50:04 -0700181 #listingParsingErrorBox {
182 border: 1px solid black;
183 background: #fae691;
184 padding: 10px;
185 display: none;
186 }
187</style>
188
189<title id="title"></title>
190
191</head>
192
193<body>
194
Andrew Top0d1858f2019-05-15 22:01:47 -0700195<div id="listingParsingErrorBox">$i18nRaw{listingParsingErrorBoxText}</div>
David Ghandehari9e5b5872016-07-28 09:50:04 -0700196
Andrew Top0d1858f2019-05-15 22:01:47 -0700197<h1 id="header">$i18n{header}</h1>
David Ghandehari9e5b5872016-07-28 09:50:04 -0700198
Andrew Top0d1858f2019-05-15 22:01:47 -0700199<div id="parentDirLinkBox" style="display:none">
200 <a id="parentDirLink" class="icon up">
201 <span id="parentDirText">$i18n{parentDirText}</span>
202 </a>
203</div>
David Ghandehari9e5b5872016-07-28 09:50:04 -0700204
Andrew Top0d1858f2019-05-15 22:01:47 -0700205<table>
206 <thead>
207 <tr class="header" id="theader">
208 <th onclick="javascript:sortTable(0);">$i18n{headerName}</th>
209 <th class="detailsColumn" onclick="javascript:sortTable(1);">
210 $i18n{headerSize}
211 </th>
212 <th class="detailsColumn" onclick="javascript:sortTable(2);">
213 $i18n{headerDateModified}
214 </th>
215 </tr>
216 </thead>
217 <tbody id="tbody">
218 </tbody>
David Ghandehari9e5b5872016-07-28 09:50:04 -0700219</table>
220
221</body>
222
223</html>