mirror of
https://github.com/pyscript/pyscript.git
synced 2025-12-20 10:47:35 -05:00
110 lines
3.5 KiB
JavaScript
110 lines
3.5 KiB
JavaScript
import { assign } from "polyscript/exports";
|
|
|
|
const CLOSEBUTTON =
|
|
"<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='currentColor' width='12px'><path d='M.293.293a1 1 0 011.414 0L8 6.586 14.293.293a1 1 0 111.414 1.414L9.414 8l6.293 6.293a1 1 0 01-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 01-1.414-1.414L6.586 8 .293 1.707a1 1 0 010-1.414z'/></svg>";
|
|
|
|
/**
|
|
* These error codes are used to identify the type of error that occurred.
|
|
* @see https://pyscript.github.io/docs/latest/reference/exceptions.html?highlight=errors
|
|
*/
|
|
export const ErrorCode = {
|
|
GENERIC: "PY0000", // Use this only for development then change to a more specific error code
|
|
CONFLICTING_CODE: "PY0409",
|
|
BAD_CONFIG: "PY1000",
|
|
MICROPIP_INSTALL_ERROR: "PY1001",
|
|
BAD_PLUGIN_FILE_EXTENSION: "PY2000",
|
|
NO_DEFAULT_EXPORT: "PY2001",
|
|
TOP_LEVEL_AWAIT: "PY9000",
|
|
// Currently these are created depending on error code received from fetching
|
|
FETCH_ERROR: "PY0001",
|
|
FETCH_NAME_ERROR: "PY0002",
|
|
FETCH_UNAUTHORIZED_ERROR: "PY0401",
|
|
FETCH_FORBIDDEN_ERROR: "PY0403",
|
|
FETCH_NOT_FOUND_ERROR: "PY0404",
|
|
FETCH_SERVER_ERROR: "PY0500",
|
|
FETCH_UNAVAILABLE_ERROR: "PY0503",
|
|
};
|
|
|
|
/**
|
|
* Keys of the ErrorCode object
|
|
* @typedef {keyof ErrorCode} ErrorCodes
|
|
* */
|
|
|
|
export class UserError extends Error {
|
|
/**
|
|
* @param {ErrorCodes} errorCode
|
|
* @param {string} message
|
|
* @param {string} messageType
|
|
* */
|
|
constructor(errorCode, message = "", messageType = "text") {
|
|
super(`(${errorCode}): ${message}`);
|
|
this.errorCode = errorCode;
|
|
this.messageType = messageType;
|
|
this.name = "UserError";
|
|
}
|
|
}
|
|
|
|
export class FetchError extends UserError {
|
|
/**
|
|
* @param {ErrorCodes} errorCode
|
|
* @param {string} message
|
|
* */
|
|
constructor(errorCode, message) {
|
|
super(errorCode, message);
|
|
this.name = "FetchError";
|
|
}
|
|
}
|
|
|
|
export class InstallError extends UserError {
|
|
/**
|
|
* @param {ErrorCodes} errorCode
|
|
* @param {string} message
|
|
* */
|
|
constructor(errorCode, message) {
|
|
super(errorCode, message);
|
|
this.name = "InstallError";
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Internal function for creating alert banners on the page
|
|
* @param {string} message The message to be displayed to the user
|
|
* @param {string} level The alert level of the message. Can be any string; 'error' or 'warning' cause matching messages to be emitted to the console
|
|
* @param {string} [messageType="text"] If set to "html", the message content will be assigned to the banner's innerHTML directly, instead of its textContent
|
|
* @param {any} [logMessage=true] An additional flag for whether the message should be sent to the console log.
|
|
*/
|
|
export function _createAlertBanner(
|
|
message,
|
|
level,
|
|
messageType = "text",
|
|
logMessage = true,
|
|
) {
|
|
switch (`log-${level}-${logMessage}`) {
|
|
case "log-error-true":
|
|
console.error(message);
|
|
break;
|
|
case "log-warning-true":
|
|
console.warn(message);
|
|
break;
|
|
}
|
|
|
|
const content = messageType === "html" ? "innerHTML" : "textContent";
|
|
const banner = assign(document.createElement("div"), {
|
|
className: `alert-banner py-${level}`,
|
|
[content]: message,
|
|
});
|
|
|
|
if (level === "warning") {
|
|
const closeButton = assign(document.createElement("button"), {
|
|
id: "alert-close-button",
|
|
innerHTML: CLOSEBUTTON,
|
|
});
|
|
|
|
banner.appendChild(closeButton).addEventListener("click", () => {
|
|
banner.remove();
|
|
});
|
|
}
|
|
|
|
document.body.prepend(banner);
|
|
}
|