diff --git a/artifacts/src/mosip-plugins/sign-in-button-plugin.js b/artifacts/src/mosip-plugins/sign-in-button-plugin.js
new file mode 100644
index 00000000..9d61e22d
--- /dev/null
+++ b/artifacts/src/mosip-plugins/sign-in-button-plugin.js
@@ -0,0 +1,687 @@
+/******************************************************************************
+Thu Aug 28 2025 10:39:44 GMT+0000 (Coordinated Universal Time)
+sign-in-with-esignet v0.9.0
+A vanilla javascript component for rendering “Sign in with..” button on mosip client’s web page for oidc integration.
+Copyright 2025
+MPL-2.0 license
+******************************************************************************/
+var SignInWithEsignetButton = (function (exports) {
+ 'use strict';
+
+ /******************************************************************************
+ Copyright (c) Microsoft Corporation.
+
+ Permission to use, copy, modify, and/or distribute this software for any
+ purpose with or without fee is hereby granted.
+
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
+ REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
+ AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
+ INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
+ LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
+ OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
+ PERFORMANCE OF THIS SOFTWARE.
+ ***************************************************************************** */
+
+ function __rest(s, e) {
+ var t = {};
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
+ t[p] = s[p];
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
+ t[p[i]] = s[p[i]];
+ }
+ return t;
+ }
+
+ function __awaiter(thisArg, _arguments, P, generator) {
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
+ return new (P || (P = Promise))(function (resolve, reject) {
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
+ });
+ }
+
+ function __generator(thisArg, body) {
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
+ function verb(n) { return function (v) { return step([n, v]); }; }
+ function step(op) {
+ if (f) throw new TypeError("Generator is already executing.");
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
+ if (y = 0, t) op = [op[0] & 2, t.value];
+ switch (op[0]) {
+ case 0: case 1: t = op; break;
+ case 4: _.label++; return { value: op[1], done: false };
+ case 5: _.label++; y = op[1]; op = [0]; continue;
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
+ default:
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
+ if (t[2]) _.ops.pop();
+ _.trys.pop(); continue;
+ }
+ op = body.call(thisArg, _);
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
+ }
+ }
+
+ typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
+ var e = new Error(message);
+ return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
+ };
+
+ var img = "";
+
+ var validResponseTypes = ["code"];
+ var validDisplays = ["page", "popup", "touch", "wap"];
+ var validPrompt = ["none", "login", "consent", "select_account"];
+ var defaultThemes = {
+ outline: "outline",
+ filledOrange: "filled_orange",
+ filledBlack: "filled_black",
+ custom: "custom",
+ };
+ var defaultShapes = {
+ sharpEdges: "sharp_edges",
+ softEdges: "soft_edges",
+ roundedEdges: "rounded_edges",
+ };
+ var buttonTypes = {
+ standard: "standard",
+ icon: "icon",
+ };
+ var errorMessage = {
+ requestUriTimeout: "Request timed out while fetching Request URI. Please try again later.",
+ requestUriFailed: "Failed to get Request URI. Please try again later.",
+ clientIdMissing: "Client ID missing.",
+ generic: "An unexpected error occurred. Please try again.",
+ dpopFailed: "DPoP callback failed. Please try again."
+ };
+ var defaultButtonLabel = "Sign in with e-Signet";
+
+ function styleInject(css, ref) {
+ if ( ref === void 0 ) ref = {};
+ var insertAt = ref.insertAt;
+
+ if (!css || typeof document === 'undefined') { return; }
+
+ var head = document.head || document.getElementsByTagName('head')[0];
+ var style = document.createElement('style');
+ style.type = 'text/css';
+
+ if (insertAt === 'top') {
+ if (head.firstChild) {
+ head.insertBefore(style, head.firstChild);
+ } else {
+ head.appendChild(style);
+ }
+ } else {
+ head.appendChild(style);
+ }
+
+ if (style.styleSheet) {
+ style.styleSheet.cssText = css;
+ } else {
+ style.appendChild(document.createTextNode(css));
+ }
+ }
+
+ var css_248z = "/* Theme specific css */\n.SignInWithEsignet-module_standardOutline__la5Rh {\n border: 2px solid #d8d8d8;\n background: #ffffff 0% 0% no-repeat padding-box;\n color: black;\n font: normal normal 600 14px/17px arial;\n}\n\n.SignInWithEsignet-module_filledOrange__0uQsC {\n border: 2px solid #eb6f2d;\n background: #eb6f2d 0% 0% no-repeat padding-box;\n color: white;\n font: normal normal 600 14px/17px arial;\n}\n\n.SignInWithEsignet-module_filledBlack__fo-0k {\n border: 2px solid #333333;\n background: #333333 0% 0% no-repeat padding-box;\n color: white;\n font: normal normal 600 14px/17px arial;\n}\n\n/* Common css */\n.SignInWithEsignet-module_sharpRectBox__jYEvo {\n width: 400px;\n height: 48px;\n display: flex;\n align-items: center;\n padding-left: 2px;\n padding-right: 2px;\n}\n\n.SignInWithEsignet-module_softRectBox__hXT5v {\n width: 400px;\n height: 48px;\n display: flex;\n align-items: center;\n border-radius: 8px;\n padding-left: 2px;\n padding-right: 2px;\n}\n\n.SignInWithEsignet-module_roundedRectBox__Gxr6n {\n width: 400px;\n height: 48px;\n display: flex;\n align-items: center;\n border-radius: 46px;\n padding-left: 3px;\n padding-right: 3px;\n}\n\n.SignInWithEsignet-module_sharpRectIcon__ux3fm {\n display: inline-block;\n}\n\n.SignInWithEsignet-module_softRectIcon__3TVEe {\n display: inline-block;\n border-radius: 8px;\n}\n\n.SignInWithEsignet-module_roundedRectIcon__dfq2Q {\n display: inline-block;\n border-radius: 46px;\n}\n\n.SignInWithEsignet-module_sharpLogoBox__DYo-n {\n display: flex;\n justify-content: center;\n align-items: center;\n width: 44px;\n height: 44px;\n background: #ffffff 0% 0% no-repeat padding-box;\n}\n\n.SignInWithEsignet-module_softLogoBox__jj7aZ {\n display: flex;\n justify-content: center;\n align-items: center;\n width: 44px;\n height: 44px;\n background: #ffffff 0% 0% no-repeat padding-box;\n border-radius: 6px;\n}\n\n.SignInWithEsignet-module_roundedLogoBox__KiQM1 {\n display: flex;\n justify-content: center;\n align-items: center;\n width: 38px;\n height: 38px;\n background: #ffffff 0% 0% no-repeat padding-box;\n border-radius: 36px;\n}\n\n.SignInWithEsignet-module_sharpLogo__wyaBH {\n width: 38px;\n height: 38px;\n object-fit: contain;\n}\n\n.SignInWithEsignet-module_softLogo__Gk5mu {\n width: 38px;\n height: 38px;\n object-fit: contain;\n}\n\n.SignInWithEsignet-module_roundedLogo__cwx4t {\n width: 28px;\n height: 28px;\n object-fit: contain;\n}\n\n.SignInWithEsignet-module_textbox__k2CkO {\n text-align: left;\n padding-left: 16px;\n padding-right: 16px;\n letter-spacing: 0px;\n}\n";
+ var styles = {"standardOutline":"SignInWithEsignet-module_standardOutline__la5Rh","filledOrange":"SignInWithEsignet-module_filledOrange__0uQsC","filledBlack":"SignInWithEsignet-module_filledBlack__fo-0k","sharpRectBox":"SignInWithEsignet-module_sharpRectBox__jYEvo","softRectBox":"SignInWithEsignet-module_softRectBox__hXT5v","roundedRectBox":"SignInWithEsignet-module_roundedRectBox__Gxr6n","sharpRectIcon":"SignInWithEsignet-module_sharpRectIcon__ux3fm","softRectIcon":"SignInWithEsignet-module_softRectIcon__3TVEe","roundedRectIcon":"SignInWithEsignet-module_roundedRectIcon__dfq2Q","sharpLogoBox":"SignInWithEsignet-module_sharpLogoBox__DYo-n","softLogoBox":"SignInWithEsignet-module_softLogoBox__jj7aZ","roundedLogoBox":"SignInWithEsignet-module_roundedLogoBox__KiQM1","sharpLogo":"SignInWithEsignet-module_sharpLogo__wyaBH","softLogo":"SignInWithEsignet-module_softLogo__Gk5mu","roundedLogo":"SignInWithEsignet-module_roundedLogo__cwx4t","textbox":"SignInWithEsignet-module_textbox__k2CkO"};
+ styleInject(css_248z);
+
+ var defaultResponseType = "code";
+ /**
+ * Validates oidc configuration for required params and valid values
+ * @param oidcConfig oidc configuration prop
+ * @returns Error object with error code and error msg.
+ */
+ function validateInput(oidcConfig) {
+ //Required parameters
+ if (!oidcConfig ||
+ !oidcConfig.authorizeUri ||
+ !oidcConfig.redirect_uri ||
+ !oidcConfig.client_id ||
+ !oidcConfig.scope) {
+ return "Required parameter is missing";
+ }
+ //if the param is not null and has and an invalid value return error msg.
+ if (oidcConfig.response_type &&
+ !validResponseTypes.includes(oidcConfig.response_type)) {
+ return "Invalid Response Type";
+ }
+ if (oidcConfig.display && !validDisplays.includes(oidcConfig.display)) {
+ return "Invalid display value";
+ }
+ if (oidcConfig.prompt && !validPrompt.includes(oidcConfig.prompt)) {
+ return "Invalid prompt value";
+ }
+ return "";
+ }
+ /**
+ * Builds redirect URL to navigate to id provider's portal.
+ * @param oidcConfig
+ * @returns URL
+ */
+ function buildRedirectURL(oidcConfig, dpop_jkt) {
+ var urlToNavigate = (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.authorizeUri) + "?";
+ if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.nonce)
+ urlToNavigate += "nonce=" + oidcConfig.nonce + "&";
+ //Generating random state if not provided
+ if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.state) {
+ urlToNavigate += "state=" + oidcConfig.state;
+ }
+ else {
+ var randomNum = window.crypto.getRandomValues(new Uint32Array(1));
+ var randomState = randomNum[0].toString(36).substring(5);
+ urlToNavigate += "state=" + randomState;
+ }
+ if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.client_id)
+ urlToNavigate += "&client_id=" + oidcConfig.client_id;
+ if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.redirect_uri)
+ urlToNavigate += "&redirect_uri=" + oidcConfig.redirect_uri;
+ if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.scope)
+ urlToNavigate += "&scope=" + oidcConfig.scope;
+ if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.response_type) {
+ urlToNavigate += "&response_type=" + oidcConfig.response_type;
+ }
+ else {
+ urlToNavigate += "&response_type=" + defaultResponseType;
+ }
+ if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.acr_values)
+ urlToNavigate += "&acr_values=" + (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.acr_values);
+ if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.claims)
+ urlToNavigate += "&claims=" + encodeURI(JSON.stringify(oidcConfig.claims));
+ if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.claims_locales)
+ urlToNavigate += "&claims_locales=" + oidcConfig.claims_locales;
+ if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.display)
+ urlToNavigate += "&display=" + oidcConfig.display;
+ if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.prompt)
+ urlToNavigate += "&prompt=" + oidcConfig.prompt;
+ if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.max_age)
+ urlToNavigate += "&max_age=" + oidcConfig.max_age;
+ if (oidcConfig === null || oidcConfig === void 0 ? void 0 : oidcConfig.ui_locales)
+ urlToNavigate += "&ui_locales=" + oidcConfig.ui_locales;
+ if (dpop_jkt) {
+ urlToNavigate += "&dpop_jkt=" + dpop_jkt;
+ }
+ return urlToNavigate;
+ }
+ /**
+ * builds classes based on input shape, theme and button type.
+ *
+ * if theme is 'custom' then standard classes are applied and these clases
+ * are expected to be added by the button implementer.
+ *
+ * @param buttonConfig
+ * @returns classes
+ */
+ function buildButtonClasses(buttonConfig) {
+ var outerDivClasses = "";
+ var logoDivClasses = "";
+ var logoImgClasses = "";
+ var labelSpanClasses = styles.textbox;
+ if (buttonConfig.theme == defaultThemes.custom) {
+ return {
+ outerDivClasses: (outerDivClasses =
+ buttonConfig.type == buttonTypes.icon
+ ? "sign-in-outer-div-container-icon"
+ : "sign-in-outer-div-container-standard"),
+ logoDivClasses: "sign-in-logo-div-container",
+ logoImgClasses: "sign-in-logo-img",
+ labelSpanClasses: "sign-in-label-span",
+ };
+ }
+ //theme based styling
+ switch (buttonConfig.theme) {
+ case defaultThemes.outline:
+ outerDivClasses = styles.standardOutline;
+ break;
+ case defaultThemes.filledOrange:
+ outerDivClasses = styles.filledOrange;
+ break;
+ case defaultThemes.filledBlack:
+ outerDivClasses = styles.filledBlack;
+ break;
+ default: //default theme outline
+ outerDivClasses = styles.standardOutline;
+ }
+ //shaped based styling
+ switch (buttonConfig.shape) {
+ case defaultShapes.sharpEdges:
+ //default button type is standard. Setting shape based on button type
+ outerDivClasses +=
+ " " +
+ (buttonConfig.type == buttonTypes.icon
+ ? styles.sharpRectIcon
+ : styles.sharpRectBox);
+ logoDivClasses = styles.sharpLogoBox;
+ logoImgClasses = styles.sharpLogo;
+ break;
+ case defaultShapes.softEdges:
+ outerDivClasses +=
+ " " +
+ (buttonConfig.type == buttonTypes.icon
+ ? styles.softRectIcon
+ : styles.softRectBox);
+ logoDivClasses = styles.softLogoBox;
+ logoImgClasses = styles.softLogo;
+ break;
+ case defaultShapes.roundedEdges:
+ outerDivClasses +=
+ " " +
+ (buttonConfig.type == buttonTypes.icon
+ ? styles.roundedRectIcon
+ : styles.roundedRectBox);
+ logoDivClasses = styles.roundedLogoBox;
+ logoImgClasses = styles.roundedLogo;
+ break;
+ default: //default shaped SharpEdges
+ outerDivClasses +=
+ " " +
+ (buttonConfig.type == buttonTypes.icon
+ ? styles.sharpRectIcon
+ : styles.sharpRectBox);
+ logoDivClasses = styles.sharpLogoBox;
+ logoImgClasses = styles.sharpLogo;
+ }
+ return {
+ outerDivClasses: outerDivClasses,
+ logoDivClasses: logoDivClasses,
+ logoImgClasses: logoImgClasses,
+ labelSpanClasses: labelSpanClasses,
+ };
+ }
+ /**
+ * builds style for the outer div by updating baseStyle by adding/overriding
+ * button config styling parameters.
+ * @param baseStyle
+ * @param buttonConfig
+ * @returns style
+ */
+ function buildButtonStyles(baseStyle, buttonConfig) {
+ if (buttonConfig === null || buttonConfig === void 0 ? void 0 : buttonConfig.width)
+ baseStyle["width"] = buttonConfig.width;
+ if (buttonConfig === null || buttonConfig === void 0 ? void 0 : buttonConfig.background)
+ baseStyle["background"] = buttonConfig.background;
+ if (buttonConfig === null || buttonConfig === void 0 ? void 0 : buttonConfig.textColor)
+ baseStyle["color"] = buttonConfig.textColor;
+ if (buttonConfig === null || buttonConfig === void 0 ? void 0 : buttonConfig.borderWidth)
+ baseStyle["border-width"] = buttonConfig.borderWidth;
+ if (buttonConfig === null || buttonConfig === void 0 ? void 0 : buttonConfig.borderColor)
+ baseStyle["border-color"] = buttonConfig.borderColor;
+ if (buttonConfig === null || buttonConfig === void 0 ? void 0 : buttonConfig.font)
+ baseStyle["font"] = buttonConfig.font;
+ if (buttonConfig === null || buttonConfig === void 0 ? void 0 : buttonConfig.fontFamily) {
+ baseStyle["font-family"] = buttonConfig.fontFamily;
+ }
+ else {
+ //default font-family
+ baseStyle["font-family"] =
+ "-apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen','Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue',sans-serif";
+ }
+ return baseStyle;
+ }
+ /**
+ * builds style based on button type and custom style.
+ *
+ * if theme is 'custom' then standard classes are applied and these clases
+ * are expected to be added by the button implementer.
+ * @param baseStyle
+ * @param buttonConfig
+ * @returns
+ */
+ function buildButtonCustomStyles(baseStyle, buttonConfig) {
+ if (!buttonConfig.customStyle) {
+ return {};
+ }
+ var outerDiv = buttonConfig.type == buttonTypes.icon
+ ? buttonConfig.customStyle.outerDivStyleIcon
+ : buttonConfig.customStyle.outerDivStyleStandard;
+ Object.assign(baseStyle, outerDiv);
+ return {
+ outerDivStyle: buildButtonStyles(baseStyle, buttonConfig),
+ logoDivStyle: buttonConfig.customStyle.logoDivStyle,
+ logoImgStyle: buttonConfig.customStyle.logoImgStyle,
+ labelSpanStyle: buttonConfig.customStyle.labelSpanStyle,
+ };
+ }
+ /**
+ * style attrs applied on the element
+ * @param element
+ * @param attrs
+ */
+ var setStyleAttribute = function (element, attrs) {
+ if (attrs !== undefined) {
+ Object.keys(attrs).forEach(function (key) {
+ element.style.setProperty(key, attrs[key]);
+ });
+ }
+ };
+ /**
+ *
+ * Builds button while adding styles and classes on individual element
+ *
+ * In case of buttonClasses, the button should render like this.
+ * --conditional
+ * {errorObj + ". Please report to site admin"}
+ *
+ *
+ *
+ *
+ *

+ *
+ *
{buttonLabel} --conditional
+ *
+ *
+ * @param buttonLabel
+ * @param urlToNavigate
+ * @param buttonCustomStyle
+ * @param buttonClasses
+ * @param buttonStyle
+ * @param logoPath
+ * @param errorMsg
+ * @param type
+ * @returns
+ */
+ var createButton = function (buttonLabel, urlToNavigate, buttonCustomStyle, buttonClasses, buttonStyle, logoPath, errorMsg, type, onClickHandler) {
+ var _a, _b, _c, _d;
+ //Button
+ var anchor;
+ if (onClickHandler) {
+ anchor = document.createElement("button");
+ anchor.type = "button";
+ anchor.addEventListener("click", onClickHandler);
+ }
+ else {
+ anchor = document.createElement("a");
+ anchor.href = urlToNavigate;
+ anchor.style.textDecoration = "none";
+ }
+ var outerDiv = document.createElement("div");
+ var logoDiv = document.createElement("div");
+ var logoImg = document.createElement("img");
+ logoImg.src = logoPath;
+ var labelSpan = document.createElement("span");
+ labelSpan.innerHTML = buttonLabel;
+ if (buttonCustomStyle) {
+ //apply custom style
+ if (buttonCustomStyle.outerDivStyle)
+ anchor.style.width = buttonCustomStyle.outerDivStyle["width"];
+ setStyleAttribute(outerDiv, buttonCustomStyle.outerDivStyle);
+ setStyleAttribute(logoDiv, buttonCustomStyle.logoDivStyle);
+ setStyleAttribute(logoImg, buttonCustomStyle.logoImgStyle);
+ setStyleAttribute(labelSpan, buttonCustomStyle.labelSpanStyle);
+ }
+ else if (buttonClasses) {
+ //or apply classes
+ if (buttonStyle)
+ anchor.style.width = buttonStyle["width"];
+ setStyleAttribute(outerDiv, buttonStyle);
+ (_a = outerDiv.classList).add.apply(_a, buttonClasses.outerDivClasses.split(" "));
+ (_b = logoDiv.classList).add.apply(_b, buttonClasses.logoDivClasses.split(" "));
+ (_c = logoImg.classList).add.apply(_c, buttonClasses.logoImgClasses.split(" "));
+ (_d = labelSpan.classList).add.apply(_d, buttonClasses.labelSpanClasses.split(" "));
+ }
+ logoDiv.appendChild(logoImg);
+ outerDiv.appendChild(logoDiv);
+ //Do not add label span for icon button
+ if (type != buttonTypes.icon) {
+ outerDiv.appendChild(labelSpan);
+ }
+ if (errorMsg) {
+ //adding error span
+ var errorSpan = document.createElement("span");
+ errorSpan.style.color = "red";
+ errorSpan.style.color = "14px";
+ errorSpan.innerHTML = errorMsg + ". Please report to site admin";
+ anchor.appendChild(errorSpan);
+ }
+ anchor.appendChild(outerDiv);
+ return anchor;
+ };
+ function rerenderButton(signInElement, label, buttonCustomStyle, buttonClasses, buttonStyle, logoPath, errorMsg, buttonType) {
+ signInElement.innerHTML = "";
+ signInElement.appendChild(createButton(label, "", buttonCustomStyle, buttonClasses, buttonStyle, logoPath, errorMsg, buttonType));
+ }
+ function buildErrorRedirectUrl(errorDescription, errorCode, oidcConfig) {
+ if (!oidcConfig.redirect_uri)
+ return false;
+ var params = new URLSearchParams();
+ if (errorDescription)
+ params.set("error_description", errorDescription);
+ params.set("error", errorCode);
+ window.location.replace("".concat(oidcConfig.redirect_uri, "?").concat(params.toString()));
+ return true;
+ }
+ function promiseWithTimeout(promise, ms) {
+ return Promise.race([
+ promise,
+ new Promise(function (resolve) {
+ return setTimeout(function () { return resolve("timeout"); }, ms);
+ }),
+ ]);
+ }
+ function par_callback(callbackFunction, oidcConfig, dpop_jkt) {
+ return __awaiter(this, void 0, void 0, function () {
+ return __generator(this, function (_a) {
+ switch (_a.label) {
+ case 0:
+ if (!oidcConfig.client_id) {
+ return [2 /*return*/, errorMessage.clientIdMissing];
+ }
+ _a.label = 1;
+ case 1:
+ _a.trys.push([1, 3, , 4]);
+ return [4 /*yield*/, callbackFunction(oidcConfig.client_id, oidcConfig.state, oidcConfig.ui_locales, dpop_jkt)];
+ case 2: return [2 /*return*/, _a.sent()];
+ case 3:
+ _a.sent();
+ return [2 /*return*/, errorMessage.requestUriFailed];
+ case 4: return [2 /*return*/];
+ }
+ });
+ });
+ }
+ function dpop_callback(callbackFunction, oidcConfig) {
+ return __awaiter(this, void 0, void 0, function () {
+ return __generator(this, function (_a) {
+ switch (_a.label) {
+ case 0:
+ if (!oidcConfig.client_id) {
+ return [2 /*return*/, errorMessage.clientIdMissing];
+ }
+ _a.label = 1;
+ case 1:
+ _a.trys.push([1, 3, , 4]);
+ return [4 /*yield*/, callbackFunction(oidcConfig.client_id, oidcConfig.state)];
+ case 2: return [2 /*return*/, _a.sent()];
+ case 3:
+ _a.sent();
+ return [2 /*return*/, errorMessage.dpopFailed];
+ case 4: return [2 /*return*/];
+ }
+ });
+ });
+ }
+ function getTimeoutMs(timeout, fallback) {
+ if (fallback === void 0) { fallback = 5000; }
+ var parsed = typeof timeout === "string" ? parseInt(timeout, 10) : timeout;
+ return typeof parsed === "number" && Number.isFinite(parsed) && parsed > 0
+ ? parsed
+ : fallback;
+ }
+ var SignInWithEsignet = function (_a) { return __awaiter(void 0, void 0, void 0, function () {
+ var oidcConfig, buttonConfig, signInElement, style, hasFunction, hasDpopCallback, hasParCallback, errorMsg, urlToNavigate, handleParCallback, handleDPopCallback, onClickHandler, label, logoPath, baseStyle, buttonCustomStyle, buttonClasses, buttonStyle, button;
+ var _b, _c;
+ var props = __rest(_a, []);
+ return __generator(this, function (_d) {
+ oidcConfig = props.oidcConfig, buttonConfig = props.buttonConfig, signInElement = props.signInElement, style = props.style;
+ hasFunction = function (fn) { return typeof fn === "function"; };
+ hasDpopCallback = oidcConfig && hasFunction(oidcConfig.dpop_callback);
+ hasParCallback = oidcConfig && hasFunction(oidcConfig.par_callback);
+ if (signInElement == null) {
+ return [2 /*return*/, signInElement];
+ }
+ errorMsg = validateInput(oidcConfig);
+ urlToNavigate = "#";
+ handleParCallback = function (event, dpop_jkt) { return __awaiter(void 0, void 0, void 0, function () {
+ var timeoutMs, result, redirected_1, redirected;
+ return __generator(this, function (_a) {
+ switch (_a.label) {
+ case 0:
+ event.preventDefault();
+ timeoutMs = getTimeoutMs(oidcConfig.par_callback_timeout, 5000);
+ return [4 /*yield*/, promiseWithTimeout(par_callback(oidcConfig.par_callback, oidcConfig, dpop_jkt), timeoutMs)];
+ case 1:
+ result = _a.sent();
+ if (result === "timeout") {
+ redirected_1 = buildErrorRedirectUrl(errorMessage.requestUriTimeout, "request_uri_timeout", oidcConfig);
+ if (!redirected_1) {
+ errorMsg = errorMessage.requestUriTimeout;
+ rerenderButton(signInElement, label, buttonCustomStyle, buttonClasses, buttonStyle, logoPath, errorMsg, buttonConfig.type);
+ }
+ return [2 /*return*/];
+ }
+ if (typeof result === "string" &&
+ result.startsWith("urn:ietf:params:oauth:request_uri:")) {
+ urlToNavigate = "".concat(oidcConfig.authorizeUri, "?client_id=").concat(encodeURIComponent(oidcConfig.client_id), "&request_uri=").concat(encodeURIComponent(result));
+ window.location.href = urlToNavigate;
+ return [2 /*return*/];
+ }
+ redirected = buildErrorRedirectUrl(errorMessage.requestUriFailed, "request_uri_error", oidcConfig);
+ if (!redirected) {
+ errorMsg = errorMessage.requestUriFailed;
+ rerenderButton(signInElement, label, buttonCustomStyle, buttonClasses, buttonStyle, logoPath, errorMsg, buttonConfig.type);
+ }
+ return [2 /*return*/];
+ }
+ });
+ }); };
+ handleDPopCallback = function (event) { return __awaiter(void 0, void 0, void 0, function () {
+ return __generator(this, function (_a) {
+ switch (_a.label) {
+ case 0:
+ event.preventDefault();
+ return [4 /*yield*/, dpop_callback(oidcConfig.dpop_callback, oidcConfig)];
+ case 1: return [2 /*return*/, _a.sent()];
+ }
+ });
+ }); };
+ onClickHandler = function (event) { return __awaiter(void 0, void 0, void 0, function () {
+ var dpop_jkt, dpop_response, redirected, err_1;
+ return __generator(this, function (_a) {
+ switch (_a.label) {
+ case 0:
+ event.preventDefault();
+ _a.label = 1;
+ case 1:
+ _a.trys.push([1, 10, , 11]);
+ dpop_jkt = "";
+ if (!hasDpopCallback) return [3 /*break*/, 6];
+ return [4 /*yield*/, handleDPopCallback(event)];
+ case 2:
+ dpop_response = _a.sent();
+ if (dpop_response && !Object.values(errorMessage).includes(dpop_response)) {
+ dpop_jkt = dpop_response;
+ }
+ else {
+ redirected = buildErrorRedirectUrl(dpop_response, "dpop_failed", oidcConfig);
+ if (!redirected) {
+ errorMsg = errorMessage.dpopFailed;
+ rerenderButton(signInElement, label, buttonCustomStyle, buttonClasses, buttonStyle, logoPath, errorMsg, buttonConfig.type);
+ }
+ return [2 /*return*/];
+ }
+ if (!hasParCallback) return [3 /*break*/, 4];
+ // Then handle PAR if available
+ return [4 /*yield*/, handleParCallback(event, dpop_jkt)];
+ case 3:
+ // Then handle PAR if available
+ _a.sent();
+ return [3 /*break*/, 5];
+ case 4:
+ if (!errorMsg) {
+ urlToNavigate = buildRedirectURL(oidcConfig, dpop_jkt);
+ window.location.href = urlToNavigate;
+ }
+ _a.label = 5;
+ case 5: return [3 /*break*/, 9];
+ case 6:
+ if (!hasParCallback) return [3 /*break*/, 8];
+ // Only PAR
+ return [4 /*yield*/, handleParCallback(event)];
+ case 7:
+ // Only PAR
+ _a.sent();
+ return [3 /*break*/, 9];
+ case 8:
+ if (!errorMsg) {
+ // Fallback redirect
+ urlToNavigate = buildRedirectURL(oidcConfig);
+ window.location.href = urlToNavigate;
+ }
+ _a.label = 9;
+ case 9: return [3 /*break*/, 11];
+ case 10:
+ err_1 = _a.sent();
+ console.error("Error in button handler:", err_1);
+ return [3 /*break*/, 11];
+ case 11: return [2 /*return*/];
+ }
+ });
+ }); };
+ if (!buttonConfig) {
+ //default values
+ buttonConfig = {
+ type: buttonTypes.standard,
+ theme: defaultThemes.outline,
+ labelText: defaultButtonLabel,
+ shape: defaultShapes.sharpEdges,
+ };
+ }
+ label = (_b = buttonConfig.labelText) !== null && _b !== void 0 ? _b : defaultButtonLabel;
+ logoPath = (_c = buttonConfig.logoPath) !== null && _c !== void 0 ? _c : img;
+ baseStyle = style || {};
+ buttonCustomStyle = null;
+ buttonClasses = null;
+ buttonStyle = {};
+ // customStyle has precedence over buttonClasses
+ if (buttonConfig.customStyle) {
+ buttonCustomStyle = buildButtonCustomStyles(baseStyle, buttonConfig);
+ }
+ else {
+ buttonClasses = buildButtonClasses(buttonConfig);
+ buttonStyle = buildButtonStyles(baseStyle, buttonConfig);
+ }
+ button = createButton(label, urlToNavigate, buttonCustomStyle, buttonClasses, buttonStyle, logoPath, errorMsg, buttonConfig.type, onClickHandler);
+ signInElement.innerHTML = "";
+ signInElement.appendChild(button);
+ return [2 /*return*/, signInElement];
+ });
+ }); };
+ var init = function (_a) { return __awaiter(void 0, void 0, void 0, function () {
+ var props = __rest(_a, []);
+ return __generator(this, function (_b) {
+ switch (_b.label) {
+ case 0: return [4 /*yield*/, SignInWithEsignet(props)];
+ case 1: return [2 /*return*/, _b.sent()];
+ }
+ });
+ }); };
+
+ exports.init = init;
+
+ Object.defineProperty(exports, '__esModule', { value: true });
+
+ return exports;
+
+})({});