@jay-js/system
Version:
A powerful and flexible TypeScript library for UI, state management, lazy loading, routing and managing draggable elements in modern web applications.
71 lines (70 loc) • 2.34 kB
JavaScript
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
try {
var info = gen[key](arg);
var value = info.value;
} catch (error) {
reject(error);
return;
}
if (info.done) {
resolve(value);
} else {
Promise.resolve(value).then(_next, _throw);
}
}
function _async_to_generator(fn) {
return function() {
var self = this, args = arguments;
return new Promise(function(resolve, reject) {
var gen = fn.apply(self, args);
function _next(value) {
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
}
function _throw(err) {
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
}
_next(undefined);
});
};
}
import { routerOptions } from "./routerDefineOptions.js";
export function getElement(route) {
return _getElement.apply(this, arguments);
}
function _getElement() {
_getElement = _async_to_generator(function*(route) {
try {
if (route && route.element) {
if (typeof route.element === "function" && route.element instanceof Promise) {
const element = yield route.element();
if (route.layout) {
element.dataset.layoutId = route.id;
}
return element;
}
if (typeof route.element === "function") {
const element = route.element();
if (route.layout) {
element.dataset.layoutId = route.id;
}
return element;
}
const element = route.element;
if (route.layout) {
element.dataset.layoutId = route.id;
}
return element;
}
} catch (error) {
if (routerOptions.onError) {
console.error(error);
routerOptions.onError(new Error("Error rendering route", {
cause: "render-route"
}));
return;
}
throw error;
}
});
return _getElement.apply(this, arguments);
}