Browse Source

feat: ui hidden root dirname

pull/58/head
sigoden 3 years ago
parent
commit
8d845196d0
  1. 3
      assets/index.css
  2. 22
      assets/index.js
  3. 14
      src/server.rs

3
assets/index.css

@ -21,6 +21,7 @@ body { @@ -21,6 +21,7 @@ body {
.breadcrumb {
font-size: 1.25em;
padding-right: 0.6em;
}
.breadcrumb > a {
@ -45,8 +46,6 @@ body { @@ -45,8 +46,6 @@ body {
.breadcrumb svg {
height: 100%;
fill: rgba(3,47,98,0.5);
padding-right: 0.5em;
padding-left: 0.5em;
}
.toolbox {

22
assets/index.js

@ -29,10 +29,6 @@ let $uploadersTable; @@ -29,10 +29,6 @@ let $uploadersTable;
* @type Element
*/
let $emptyFolder;
/**
* @type string
*/
let baseDir;
class Uploader {
/**
@ -126,7 +122,12 @@ class Uploader { @@ -126,7 +122,12 @@ class Uploader {
*/
function addBreadcrumb(value) {
const $breadcrumb = document.querySelector(".breadcrumb");
const parts = value.split("/").filter(v => !!v);
let parts = [];
if (value === "/") {
parts = [""];
} else {
parts = value.split("/");
}
const len = parts.length;
let path = "";
for (let i = 0; i < len; i++) {
@ -134,15 +135,16 @@ function addBreadcrumb(value) { @@ -134,15 +135,16 @@ function addBreadcrumb(value) {
if (i > 0) {
path += "/" + name;
}
if (i === len - 1) {
if (i === 0) {
$breadcrumb.insertAdjacentHTML("beforeend", `<a href="/"><svg width="16" height="16" viewBox="0 0 16 16"><path d="M6.5 14.5v-3.505c0-.245.25-.495.5-.495h2c.25 0 .5.25.5.5v3.5a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5v-7a.5.5 0 0 0-.146-.354L13 5.793V2.5a.5.5 0 0 0-.5-.5h-1a.5.5 0 0 0-.5.5v1.293L8.354 1.146a.5.5 0 0 0-.708 0l-6 6A.5.5 0 0 0 1.5 7.5v7a.5.5 0 0 0 .5.5h4a.5.5 0 0 0 .5-.5z"/></svg></a>`);
} else if (i === len - 1) {
$breadcrumb.insertAdjacentHTML("beforeend", `<b>${name}</b>`);
baseDir = name;
} else if (i === 0) {
$breadcrumb.insertAdjacentHTML("beforeend", `<a href="/"><b>${name}</b></a>`);
} else {
$breadcrumb.insertAdjacentHTML("beforeend", `<a href="${encodeURI(path)}">${name}</a>`);
}
$breadcrumb.insertAdjacentHTML("beforeend", `<span class="separator">/</span>`);
if (i !== len - 1) {
$breadcrumb.insertAdjacentHTML("beforeend", `<span class="separator">/</span>`);
}
}
}

14
src/server.rs

@ -684,12 +684,9 @@ impl Server { @@ -684,12 +684,9 @@ impl Server {
res: &mut Response,
) -> BoxResult<()> {
paths.sort_unstable();
let rel_path = match self.args.path.parent() {
Some(p) => path.strip_prefix(p).unwrap(),
None => path,
};
let breadcrumb = format!("/{}", normalize_path(path.strip_prefix(&self.args.path)?));
let data = IndexData {
breadcrumb: normalize_path(rel_path),
breadcrumb: breadcrumb.clone(),
paths,
allow_upload: self.args.allow_upload,
allow_delete: self.args.allow_delete,
@ -700,17 +697,14 @@ impl Server { @@ -700,17 +697,14 @@ impl Server {
"__SLOT__",
&format!(
r#"
<title>Files in {}/ - Duf</title>
<title>Index of {} - Duf</title>
<style>{}</style>
<script>
const DATA =
{}
{}</script>
"#,
rel_path.display(),
INDEX_CSS,
data,
INDEX_JS
breadcrumb, INDEX_CSS, data, INDEX_JS
),
);
res.headers_mut()

Loading…
Cancel
Save