filestash/public/assets/components/dropdown.js
2025-01-15 01:29:59 +11:00

92 lines
3.5 KiB
JavaScript

import { createFragment } from "../lib/skeleton/index.js";
import { animate, slideYIn } from "../lib/animate.js";
import assert from "../lib/assert.js";
import { loadCSS } from "../helpers/loader.js";
export default class ComponentDropdown extends HTMLElement {
constructor() {
super();
this.render();
}
async connectedCallback() {
await loadCSS(import.meta.url, "./dropdown.css");
}
static get observedAttributes() {
return ["options"];
}
render() {
this.classList.add("component_dropdown", "view", "sort");
this.appendChild(createFragment(`
<div class="dropdown_button">
<img class="component_icon" draggable="false" src="" alt="download_white">
</div>`));
this.appendChild(createFragment(`
<div class="dropdown_container">
<ul>
<li>
<div>
<a download="README.org" href="/api/files/cat?path=%2FREADME.org">Save current file</a>
</div>
</li>
<li>
<div>
<a target="_blank" href="/api/export/private/text/html/README.org">Export as HTML</a>
</div>
</li>
<li>
<div>
<a target="_blank" href="/api/export/private/application/pdf/README.org">Export as PDF</a>
</div>
</li>
<li>
<div>
<a target="_blank" href="/api/export/private/text/markdown/README.org">Export as Markdown</a>
</div>
</li>
<li>
<div>
<a target="_blank" href="/api/export/private/text/plain/README.org">Export as TXT</a>
</div>
</li>
<li>
<div>
<a target="_blank" download="README.tex" href="/api/export/private/text/x-latex/README.org">Export as Latex</a>
</div>
</li>
<li>
<div>
<a target="_blank" download="README.ics" href="/api/export/private/text/calendar/README.org">Export as ical</a>
</div>
</li>
<li>
<div>
<a target="_blank" download="README.odt" href="/api/export/private/application/vnd.oasis.opendocument.text/README.org">Export as Open office</a>
</div>
</li>
<li>
<div>
<a target="_blank" download="README.pdf" href="/api/export/private/application/pdf/README.org?mode=beamer">Export as Beamer</a>
</div>
</li>
</ul>
</div>
</div>
`));
const setActive = () => this.classList.toggle("active");
assert.type(this.querySelector(".dropdown_button"), HTMLElement).onclick = () => {
setActive();
animate(assert.type(this.querySelector(".dropdown_container"), HTMLElement), {
time: 100,
keyframes: slideYIn(2),
});
};
}
}
if (!customElements.get("component-dropdown"))
customElements.define("component-dropdown", ComponentDropdown);