filestash/public/assets/index.js
MickaelK 71b14e6eaf feature (3d): embed 3d viewer anywhere
This contains a bunch of things packaged in 1:

1) UI improvements for the 3D viewer to support all sort of file types
   and create a nice rendering in a clean way with all sort of options

2) enable people to use Filestash as an SDK so we can embed the 3d viewer
   elsewhere
2024-12-23 18:50:23 +11:00

54 lines
2 KiB
JavaScript

// Want to integrate Filestash as a SDK in your application? You are in the right place!
//
// How it works you may ask? it's simple:
// 1) pick a component to render. Filestash components look like this:
// function(render, opts = {}) {
// // ...
// }
// 2) similarly to every framework out there, call the framework bootstrap procedure:
// render(Component, $node, args = {});
//
//
// /***********************************************/
// /* example to render the 3D viewer application */
// /***********************************************/
// import { render } from "https://demo.filestash.app/assets/index.js";
// import * as Component from "https://demo.filestash.app/assets/pages/viewerpage/application_3d.js";
//
// render(Component, document.getElementById("app"), {});
//
//
//
import { createRender, createElement } from "./lib/skeleton/index.js";
import { loadCSS } from "./helpers/loader.js";
export function render(module, $app, opts = {}) {
assertArgs(module, $app);
execute(module, $app, opts);
}
function assertArgs(module, $app) {
if (typeof module.default !== "function") throw new TypeError("Unsupported module - see documentation on how to use Filestash");
else if (!($app instanceof Node)) throw new TypeError("Invalid node - see documentation on how to use Filestash");
}
function execute(module, $app, opts) {
const priors = [
import("./boot/ctrl_boot_frontoffice.js"),
loadCSS(import.meta.url, "./css/designsystem.css"),
];
if (typeof module.init === "function") priors.push(module.init($app));
return Promise.all(priors)
.then(async() => await module.default(createRender($app), opts))
.then(() => $app.appendChild(poweredBy()))
.catch((err) => console.error(err));
}
function poweredBy($app) {
return createElement(`
<div style="position: absolute; bottom: 0; left: 0; font-size: 0.9rem; display: inline-block;">
Powered By <a href="https://www.filestash.app" style="text-decoration:underline;">Filestash</a>
</div>
`);
}