import { createElement } from "../../lib/skeleton/index.js"; import { addSelection } from "./model_files.js"; const IMAGE = { FILE: "", FOLDER: "" }; const $tmpl = createElement(`
directory __TEMPLATE__ 06/06/2020
`); // 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 = $tmpl.cloneNode(true); if (!($thing instanceof window.HTMLElement)) throw new Error("assertion failed: $thing must be an HTMLELement"); const $label = $thing.querySelector(".component_filename .file-details > span"); if (!($label instanceof window.HTMLElement)) throw new Error("assertion failed: $label must be an HTMLELement"); $label.textContent = name; $thing.querySelector("a").setAttribute("href", link); $thing.querySelector("img").setAttribute("src", (type === "file" ? IMAGE.FILE : IMAGE.FOLDER)); if (type === "hidden") $thing.classList.add("hidden"); $thing.querySelector(".component_checkbox").onclick = function(e) { e.preventDefault(); e.stopPropagation(); addSelection(name, type); }; return $thing; }