Browse Source

feat: add empty state placeholder to page(#30)

* added "Empty folder" text to the page

* added text for nonexistent directory and no search results
pull/32/head
Joe Koop 3 years ago committed by GitHub
parent
commit
0e236b61f6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 7
      assets/index.css
  2. 17
      assets/index.js
  3. 7
      src/server.rs

7
assets/index.css

@ -97,6 +97,11 @@ body {
padding: 0 1em; padding: 0 1em;
} }
.empty-folder {
display: block;
padding-top: 1rem;
}
.uploaders-table th, .uploaders-table th,
.paths-table th { .paths-table th {
text-align: left; text-align: left;
@ -208,4 +213,4 @@ body {
.path a { .path a {
color: #3191ff; color: #3191ff;
} }
} }

17
assets/index.js

@ -7,6 +7,12 @@
* @property {number} size * @property {number} size
*/ */
// https://stackoverflow.com/a/901144/3642588
const params = new Proxy(new URLSearchParams(window.location.search), {
get: (searchParams, prop) => searchParams.get(prop),
});
const dirEmptyNote = params.q ? 'No results' : DATA.dir_exists ? 'Empty folder' : 'Folder will be created when a file is uploaded';
/** /**
* @type Element * @type Element
@ -54,6 +60,7 @@ class Uploader {
</tr>`); </tr>`);
$uploadersTable.classList.remove("hidden"); $uploadersTable.classList.remove("hidden");
this.$uploadStatus = document.getElementById(`uploadStatus${idx}`); this.$uploadStatus = document.getElementById(`uploadStatus${idx}`);
document.querySelector('.main i.empty-folder').remove();
const ajax = new XMLHttpRequest(); const ajax = new XMLHttpRequest();
ajax.upload.addEventListener("progress", e => this.progress(e), false); ajax.upload.addEventListener("progress", e => this.progress(e), false);
@ -180,6 +187,8 @@ async function deletePath(index) {
DATA.paths[index] = null; DATA.paths[index] = null;
if (!DATA.paths.find(v => !!v)) { if (!DATA.paths.find(v => !!v)) {
$pathsTable.classList.add("hidden"); $pathsTable.classList.add("hidden");
document.querySelector('.main').insertAdjacentHTML("afterbegin", '<i class="empty-folder"></i>');
document.querySelector('.main .empty-folder').textContent = dirEmptyNote;
} }
} else { } else {
throw new Error(await res.text()) throw new Error(await res.text())
@ -275,6 +284,10 @@ function ready() {
$pathsTableBody = document.querySelector(".paths-table tbody"); $pathsTableBody = document.querySelector(".paths-table tbody");
$uploadersTable = document.querySelector(".uploaders-table"); $uploadersTable = document.querySelector(".uploaders-table");
if (params.q) {
document.getElementById('search').value = params.q;
}
addBreadcrumb(DATA.breadcrumb); addBreadcrumb(DATA.breadcrumb);
if (Array.isArray(DATA.paths)) { if (Array.isArray(DATA.paths)) {
const len = DATA.paths.length; const len = DATA.paths.length;
@ -284,6 +297,10 @@ function ready() {
for (let i = 0; i < len; i++) { for (let i = 0; i < len; i++) {
addPath(DATA.paths[i], i); addPath(DATA.paths[i], i);
} }
if (len == 0) {
document.querySelector('.main').insertAdjacentHTML("afterbegin", '<i class="empty-folder"></i>');
document.querySelector('.main .empty-folder').textContent = dirEmptyNote;
}
} }
if (DATA.allow_upload) { if (DATA.allow_upload) {
dropzone(); dropzone();

7
src/server.rs

@ -325,7 +325,7 @@ impl InnerService {
} }
} }
}; };
self.send_index(path, paths, res) self.send_index(path, paths, res, exist)
} }
async fn handle_query_dir( async fn handle_query_dir(
@ -354,7 +354,7 @@ impl InnerService {
} }
} }
} }
self.send_index(path, paths, res) self.send_index(path, paths, res, true)
} }
async fn handle_zip_dir(&self, path: &Path, res: &mut Response) -> BoxResult<()> { async fn handle_zip_dir(&self, path: &Path, res: &mut Response) -> BoxResult<()> {
@ -645,6 +645,7 @@ impl InnerService {
path: &Path, path: &Path,
mut paths: Vec<PathItem>, mut paths: Vec<PathItem>,
res: &mut Response, res: &mut Response,
exist: bool,
) -> BoxResult<()> { ) -> BoxResult<()> {
paths.sort_unstable(); paths.sort_unstable();
let rel_path = match self.args.path.parent() { let rel_path = match self.args.path.parent() {
@ -656,6 +657,7 @@ impl InnerService {
paths, paths,
allow_upload: self.args.allow_upload, allow_upload: self.args.allow_upload,
allow_delete: self.args.allow_delete, allow_delete: self.args.allow_delete,
dir_exists: exist,
}; };
let data = serde_json::to_string(&data).unwrap(); let data = serde_json::to_string(&data).unwrap();
let output = INDEX_HTML.replace( let output = INDEX_HTML.replace(
@ -802,6 +804,7 @@ struct IndexData {
paths: Vec<PathItem>, paths: Vec<PathItem>,
allow_upload: bool, allow_upload: bool,
allow_delete: bool, allow_delete: bool,
dir_exists: bool,
} }
#[derive(Debug, Serialize, Eq, PartialEq, Ord, PartialOrd)] #[derive(Debug, Serialize, Eq, PartialEq, Ord, PartialOrd)]

Loading…
Cancel
Save