filestash/public/assets/pages/filespage/thing.js
2023-12-05 00:38:15 +11:00

64 lines
3.9 KiB
JavaScript

import { createElement } from "../../lib/skeleton/index.js";
import { CSS } from "../../helpers/loader.js";
const $tmpl = createElement(`
<div class="component_thing view-grid not-selected" draggable="true">
<a href="/view/README.org" data-link>
<div class="box">
<div class="component_checkbox"><input type="checkbox"><span class="indicator"></span></div>
<span>
<img class="component_icon" draggable="false" src="" alt="directory">
</span>
<span class="component_filename">
<span class="file-details">
<span>Videos<span class="extension"></span></span>
</span>
</span>
<span class="component_datetime"><span>06/06/2020</span></span>
<div class="component_action"></div>
<div class="selectionOverlay"></div>
</div>
</a>
</div>
`);
export const css = CSS(import.meta.url, "thing.css");
// a filesystem "thing" is typically either a file or folder which have a lot of behavior builtin.
// Probably one day we can rename that to something more clear but the gist is a thing can be
// displayed in list mode / grid mode, have some substate to enable loading state for upload,
// can toggle links, potentially includes a thumbnail, can be used as a source and target for
// drag and drop on other folders and many other non obvious stuff
export function createThing({
name = null,
// type = "N/A",
// size = 0,
// time = null,
link = "",
// permissions = {}
}) {
const $thing = $get();
if ($thing instanceof HTMLElement) {
const $label = $thing.querySelector(".component_filename .file-details > span");
if ($label instanceof HTMLElement) $label.textContent = name;
$thing?.querySelector("a")?.setAttribute("href", link);
}
return $thing;
}
function $get() {
// the very first implementation was:
return $tmpl.cloneNode(true);
// the major issue was cloneNode is slow and would often make us miss an animationFrame. A much more
// efficient approach is to use a ring buffer of node we reuse as we scroll around
if (bufferIdx >= $tmplBuffer.length) bufferIdx = 0;
const $node = $tmplBuffer[bufferIdx];
bufferIdx += 1;
// console.log($node);
return $node;
}
let $tmplBuffer = [];
let bufferIdx = 0;
export function allocateMemory(size) {
$tmplBuffer = Array.apply(null, {length: size}).map(() => $tmpl.cloneNode(true))
}