filestash/public/components/breadcrumb.js
2023-08-14 01:07:53 +10:00

72 lines
4.1 KiB
JavaScript

import { CSS } from "../helpers/loader.js";
const isRunningFromAnIframe = window.self !== window.top;
class ComponentBreadcrumb extends HTMLDivElement {
constructor() {
super();
if (new window.URL(location.href).searchParams.get("nav") === "false") return null;
const htmlLogout = isRunningFromAnIframe ? "":`
<a href="/logout" data-link>
<img class="component_icon" draggable="false" src="" alt="power">
</a>
`;
const paths = (this.getAttribute("path") || "").split("/");
console.log(this.getAttribute("path"), paths);
const htmlPathChunks = paths.slice(0, -1).map((chunk, idx) => {
const label = idx === 0 ? "Filestash" : chunk;
const link = paths.slice(0, idx).join("/") + "/";
const minify = () => {
if (idx === 0) return false;
else if (paths.length <= (document.body.clientWidth > 800 ? 5 : 4)) return false;
else if (idx > paths.length - (document.body.clientWidth > 1000? 4 : 3)) return false;
return true;
};
const limitSize = (word) => { // TODO
return word;
};
const isLast = idx === paths.length - 1;
if (isLast) return `
<div class="component_path-element n${idx}">
<div class="li component_path-element-wrapper">
<div class="label">
<div>${label}</div>
<span></span>
</div>
</div>
</div>`;
return `
<div class="component_path-element n${idx}">
<div class="li component_path-element-wrapper">
<div>
<a class="label" href="/files${link}" data-link>
<div>${limitSize(label)}</div>
</a>
<div class="component_separator">
<img alt="path_separator" width="16" height="16" src="">
</div>
</div>
</div>
</div>`
}).join("");
this.innerHTML = `
<div class="component_breadcrumb" role="navigation">
<style>${css}</style>
<div class="breadcrumb no-select">
<div class="ul">
<div class="li component_logout">
${htmlLogout}
</div>
<span>${htmlPathChunks}</span>
</div>
</div>
</div>
`;
}
}
const css = await CSS(import.meta, "breadcrumb.css");
customElements.define("component-breadcrumb", ComponentBreadcrumb, { extends: "div" });