(function webpackUniversalModuleDefinition(root, factory) {
if(typeof exports === 'object' && typeof module === 'object')
module.exports = factory();
else if(typeof define === 'function' && define.amd)
define([], factory);
else if(typeof exports === 'object')
exports["AhoraCrypto"] = factory();
else
root["AhoraCrypto"] = factory();
})(this, () => {
return /******/ (() => { // webpackBootstrap
/******/ "use strict";
/******/ var __webpack_modules__ = ({
/***/ "./src/webwidget/webwidget.ts":
/*!************************************!*\
!*** ./src/webwidget/webwidget.ts ***!
\************************************/
/***/ ((__unused_webpack_module, exports) => {
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.renderWebwidget = void 0;
/**
* Renders the AhoraCrypto web widget in the specified container element
* @param config Configuration object for the widget
* @param config.referral Optional referral identifier used for tracking traffic sources.
* If not provided, the domain of the container will be used automatically.
* The system extracts the base domain (e.g., "example.com" from "sub.example.com")
* @returns WebwidgetController that allows interaction with the iframe
*/
function renderWebwidget(config) {
// Extract container element
var container = document.getElementById(config.containerId);
if (!container) {
console.error("Container with ID '".concat(config.containerId, "' not found."));
throw new Error("Container with ID '".concat(config.containerId, "' not found."));
}
// Generate iframe URL with parameters
var baseUrl = "https://ahoracrypto.com/";
// Only add language to URL if it's specified
if (config.language) {
baseUrl += config.language + "/";
}
baseUrl += "webwidget/";
// Create URL params object
var params = new URLSearchParams();
// Add parameters if they exist (mapping from config param to iframe param)
if (config.cryptoCurrency)
params.append('crypto', config.cryptoCurrency);
if (config.fiatCurrency)
params.append('fiat', config.fiatCurrency);
if (config.logoUrl && config.logoUrl.trim() !== '')
params.append('lurl', config.logoUrl);
if (config.backgroundColor)
params.append('bgc', config.backgroundColor);
if (config.buttonColor)
params.append('btc', config.buttonColor);
if (config.borderRadius !== undefined)
params.append('br', config.borderRadius.toString());
if (config.borderWithShadow !== undefined)
params.append('bws', config.borderWithShadow ? '1' : '0');
if (config.paymentIntentId)
params.append('pi', config.paymentIntentId);
if (config.cryptos && config.cryptos.trim() !== '')
params.append('cryptos', config.cryptos);
if (config.defaultNetwork && config.defaultNetwork.trim() !== '')
params.append('defaultNetwork', config.defaultNetwork);
// Add referral parameter (if provided) or use current domain
var referral = config.referral;
if (!referral) {
// Extract domain from current URL (without subdomains, path, protocol, or port)
try {
var hostname = window.location.hostname;
// Extract the domain: split by dots and take the last two parts
// This handles cases like sub.domain.com -> domain.com
var parts = hostname.split('.');
if (parts.length >= 2) {
// For normal domains like example.com
var domain = parts.slice(-2).join('.');
referral = domain;
}
else {
// For localhost or IP addresses
referral = hostname;
}
params.append('referral', referral);
}
catch (e) {
console.warn('Could not extract domain for referral:', e);
}
}
// Always pass the current theme to the iframe
var theme = 'light';
try {
// Check first for a theme passed in the configuration
if (config.theme) {
theme = config.theme.toLowerCase();
}
else {
// If not in config, try our prefixed localStorage key first
var ahoraCryptoTheme = localStorage.getItem('ahoracrypto-theme');
if (ahoraCryptoTheme && (ahoraCryptoTheme === 'dark' || ahoraCryptoTheme === 'light')) {
theme = ahoraCryptoTheme;
}
// Fall back to generic 'theme' key in localStorage
else {
var savedTheme = localStorage.getItem('theme');
if (savedTheme && (savedTheme === 'dark' || savedTheme === 'light')) {
theme = savedTheme;
}
else if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {
// If not in localStorage, check system preference
theme = 'dark';
}
}
}
// Add a console log for debugging
console.log('Detected theme:', theme);
}
catch (e) {
// In case localStorage is not accessible
console.warn('Could not access localStorage for theme:', e);
// Default to light theme on error
theme = 'light';
}
// Always pass the current theme to the iframe
params.append('theme', theme);
// Create iframe element
var iframe = document.createElement('iframe');
// Default background colors based on theme
var defaultBgColor = theme === 'dark' ?
'rgb(55 55 55 / 1)' : 'white';
var defaultBgColor2 = theme === 'dark' ?
'rgb(55 55 55 / 1)' : 'white';
// Add custom styles to head
var styleElement = document.createElement('style');
styleElement.textContent = "\n .AhoraCrypto_iframe_container {\n max-width: 26rem;\n max-height: 600px;\n width: auto;\n height: auto;\n margin-left: auto;\n margin-right: auto;\n background-color: white;\n position: relative;\n overflow: hidden;\n border-radius: 24px;\n }\n \n .AhoraCrypto_iframe_with_shadow {\n box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);\n }\n \n @media (prefers-color-scheme: dark) {\n .AhoraCrypto_iframe_container {\n background-color: ".concat(config.backgroundColor ? "#".concat(config.backgroundColor) : 'rgb(55 55 55 / 1)', ";\n }\n }\n \n .AhoraCrypto_loading__container {\n z-index: 1;\n }\n \n /* Skeleton loading animation styles */\n .ahoracrypto-fixed {\n position: fixed;\n }\n \n .ahoracrypto-z-50 {\n z-index: 50;\n }\n\n .ahoracrypto-z-1 {\n z-index: 1;\n }\n \n .ahoracrypto-top-0 {\n top: 0;\n }\n \n .ahoracrypto-left-0 {\n left: 0;\n }\n \n .ahoracrypto-right-0 {\n right: 0;\n }\n \n .ahoracrypto-bottom-0 {\n bottom: 0;\n }\n \n .ahoracrypto-flex {\n display: flex;\n }\n \n .ahoracrypto-flex-1 {\n flex: 1 1 0%;\n }\n \n .ahoracrypto-flex-col {\n flex-direction: column;\n }\n \n .ahoracrypto-items-center {\n align-items: center;\n }\n \n .ahoracrypto-items-stretch {\n align-items: stretch;\n }\n \n .ahoracrypto-justify-center {\n justify-content: center;\n }\n \n .ahoracrypto-justify-between {\n justify-content: space-between;\n }\n \n .ahoracrypto-bg-gray-100 {\n background-color: #f3f4f6;\n }\n \n .ahoracrypto-bg-black {\n background-color: #000000;\n }\n \n .ahoracrypto-bg-opacity-50 {\n background-color: rgba(0, 0, 0, 0.5);\n }\n \n .ahoracrypto-max-w-26rem {\n max-width: 26rem;\n }\n \n .ahoracrypto-w-full {\n width: 100%;\n }\n \n .ahoracrypto-h-510px {\n height: 510px;\n }\n \n .ahoracrypto-mx-auto {\n margin-left: auto;\n margin-right: auto;\n }\n \n .ahoracrypto-bg-white {\n background-color: white;\n }\n \n .ahoracrypto-bg-brand-darkGray {\n background-color: rgb(55 55 55 / 1);\n }\n \n .ahoracrypto-bg-brand-darkGray2 {\n background-color: rgb(55 55 55 / 1);\n }\n \n .ahoracrypto-rounded-3xl {\n border-radius: 1.5rem;\n }\n \n .ahoracrypto-rounded-lg {\n border-radius: 0.5rem;\n }\n \n .ahoracrypto-rounded-full {\n border-radius: 9999px;\n }\n \n .ahoracrypto-rounded {\n border-radius: 0.25rem;\n }\n \n .ahoracrypto-shadow-lg {\n box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);\n }\n \n .ahoracrypto-p-4 {\n padding: 1rem;\n }\n \n .ahoracrypto-pt-6 {\n padding-top: 1.5rem;\n }\n \n .ahoracrypto-px-6 {\n padding-left: 1.5rem;\n padding-right: 1.5rem;\n }\n\n .ahoracrypto-p-6 {\n padding: 1.5rem;\n }\n\n\n .ahoracrypto-relative {\n position: relative;\n }\n \n .ahoracrypto-absolute {\n position: absolute;\n }\n \n .ahoracrypto-inset-0 {\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n }\n \n .ahoracrypto-overflow-hidden {\n overflow: hidden;\n }\n \n .ahoracrypto-animate-pulse {\n animation: ahoracryptoPulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;\n }\n \n @keyframes ahoracryptoPulse {\n 0%, 100% {\n opacity: 1;\n }\n 50% {\n opacity: .5;\n }\n }\n \n .ahoracrypto-w-10 {\n width: 2.5rem;\n }\n \n .ahoracrypto-h-10 {\n height: 2.5rem;\n }\n \n .ahoracrypto-w-8 {\n width: 2rem;\n }\n \n .ahoracrypto-h-8 {\n height: 2rem;\n }\n \n .ahoracrypto-bg-gray-300 {\n background-color: #d1d5db;\n }\n \n .ahoracrypto-mb-4 {\n margin-bottom: 1rem;\n }\n \n .ahoracrypto-mb-3 {\n margin-bottom: 0.75rem;\n }\n \n .ahoracrypto-h-24 {\n height: 6rem;\n }\n \n .ahoracrypto-h-14 {\n height: 3.5rem;\n }\n \n .ahoracrypto-h-5 {\n height: 1.25rem;\n }\n \n .ahoracrypto-h-4 {\n height: 1rem;\n }\n \n .ahoracrypto-w-1/4 {\n width: 25%;\n }\n \n .ahoracrypto-w-1/3 {\n width: 33.333333%;\n }\n \n .ahoracrypto-ml-4 {\n margin-left: 1rem;\n }\n \n .ahoracrypto-mt-3 {\n margin-top: 0.75rem;\n }\n \n .ahoracrypto-mt-2 {\n margin-top: 0.5rem;\n }\n \n .ahoracrypto-text-center {\n text-align: center;\n }\n \n .ahoracrypto-py-4 {\n padding-top: 1rem;\n padding-bottom: 1rem;\n }\n \n .ahoracrypto-py-2 {\n padding-top: 0.5rem;\n padding-bottom: 0.5rem;\n }\n\n .ahoracrypto-mb-2 {\n margin-bottom: 0.5rem;\n }\n\n .ahoracrypto-mb-4 {\n margin-bottom: 1rem;\n }\n\n .ahoracrypto-mb-6 {\n margin-bottom: 1.5rem;\n }\n\n .ahoracrypto-w-1/3 {\n width: 33.333333%;\n }\n\n /* A\u00F1adimos clases adicionales usadas en el skeleton loader */\n .ahoracrypto-justify-between {\n justify-content: space-between;\n }\n \n /* Media queries para responsive */\n @media (min-width: 640px) {\n .sm\\:ahoracrypto-h-510px {\n height: 510px;\n }\n \n .sm\\:ahoracrypto-rounded-3xl {\n border-radius: 1.5rem;\n }\n \n .sm\\:ahoracrypto-shadow-lg {\n box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);\n }\n }\n \n /* Aseguramos que todas las clases para las animaciones est\u00E9n definidas */\n .ahoracrypto-max-h-600px {\n max-height: 600px;\n }\n \n .ahoracrypto-h-full {\n height: 100%;\n }\n \n .ahoracrypto-w-full {\n width: 100%;\n }\n\n ");
document.head.appendChild(styleElement);
// Add shadow class conditionally
var baseClass = 'AhoraCrypto_iframe__f0bRD AhoraCrypto_iframe_container';
iframe.className = config.borderWithShadow !== false
? "".concat(baseClass, " AhoraCrypto_iframe_with_shadow")
: baseClass;
iframe.id = 'ahoracrypto-widget';
iframe.title = 'AhoraCrypto Widget';
// Ensure minimum dimensions of 416x510 regardless of user input
var defaultWidth = 416;
var defaultHeight = 510;
var width = config.iframeWidth != null ? config.iframeWidth : defaultWidth;
var height = config.iframeHeight != null ? config.iframeHeight : defaultHeight;
// Use a default border radius of 24px if not specified
var borderRadius = config.borderRadius != null ? config.borderRadius : 24;
// Set dimensions with inline styles to ensure they take precedence over CSS classes
iframe.style.width = '100%';
iframe.style.height = height + 'px';
iframe.style.backgroundColor = 'transparent';
iframe.style.border = 'none';
// Still set width/height attributes for compatibility
iframe.width = width.toString();
iframe.height = height.toString();
// Apply border radius (default or configured)
iframe.style.borderRadius = "".concat(borderRadius, "px");
iframe.frameBorder = '0';
iframe.src = baseUrl + '?' + params.toString();
iframe.allow = 'camera; microphone; clipboard-read; clipboard-write; payment';
iframe.setAttribute('allowpaymentrequest', 'true');
iframe.style.display = 'none'; // Initially hide iframe until it's ready
// Function to update styling based on theme
var updateThemeStyling = function (newTheme) {
var isDarkTheme = newTheme === 'dark';
// Update iframe background color if not using a custom background color
if (!config.backgroundColor) {
var bgColor = isDarkTheme ? 'rgb(55 55 55 / 1)' : 'white';
// Update main container background
if (iframe.parentElement) {
iframe.parentElement.style.backgroundColor = bgColor;
}
}
// Ensure the border radius is maintained after theme change
iframe.style.borderRadius = "".concat(borderRadius, "px");
// If loading container is still present, update its style too
var loadingEl = document.getElementById('loading-section');
if (loadingEl) {
loadingEl.style.backgroundColor = isDarkTheme ? 'rgba(40, 40, 40, 0.8)' : 'rgba(243, 244, 246, 0.8)';
// Find the skeleton section inside loading container and update its style
var skeletonEl = loadingEl.querySelector('section');
if (skeletonEl) {
skeletonEl.style.backgroundColor = isDarkTheme ? 'rgb(55 55 55 / 1)' : 'white';
// Ensure the skeleton section also maintains its border radius
skeletonEl.classList.add('ahoracrypto-rounded-3xl');
}
}
};
// Reutilizamos el valor del tema que ya obtuvimos anteriormente
var isDarkTheme = theme === 'dark';
console.log('Using dark theme for skeleton:', isDarkTheme);
// Add iframe to container first to establish positioning context
container.appendChild(iframe);
// Create a wrapper div to contener both the iframe and the loading animation
// This ensures they ocuppy the same space
var widgetWrapper = document.createElement('div');
widgetWrapper.className = 'ahoracrypto-relative';
widgetWrapper.style.width = '100%';
widgetWrapper.style.maxWidth = width + 'px';
widgetWrapper.style.height = height + 'px';
widgetWrapper.style.backgroundColor = isDarkTheme ? 'rgb(55 55 55 / 1)' : 'white';
widgetWrapper.style.borderRadius = "".concat(borderRadius, "px");
// Remove iframe from container and add it to the wrapper
container.removeChild(iframe);
widgetWrapper.appendChild(iframe);
// Apply initial theme styling
updateThemeStyling(theme);
// Create loading skeleton container
var loadingContainer = document.createElement('div');
loadingContainer.id = 'loading-section';
// Apply styles to make the loading container position absolutely within the wrapper
loadingContainer.className = 'ahoracrypto-absolute ahoracrypto-z-1 ahoracrypto-inset-0 ahoracrypto-flex ahoracrypto-items-center ahoracrypto-justify-center';
// Make sure the loading container is visible initially
loadingContainer.style.display = 'block';
loadingContainer.style.borderRadius = "".concat(borderRadius, "px");
// Apply a semi-transparent background based on theme - use explicit colors
loadingContainer.style.backgroundColor = isDarkTheme ? 'rgba(40, 40, 40, 0.8)' : 'rgba(243, 244, 246, 0.8)';
// Get dimensions for the skeleton section to match the iframe
var skeletonSection = document.createElement('section');
// Make sure the loading section matches the iframe dimensions
loadingContainer.style.width = '100%';
loadingContainer.style.maxWidth = width + 'px';
loadingContainer.style.height = height + 'px';
// Set fixed dimensions for the skeleton section to match the iframe
skeletonSection.style.maxWidth = width + 'px';
skeletonSection.style.height = height + 'px';
// Fix specific height for the skeleton section (removes h-full since that can cause issues)
var shadowClass = config.borderWithShadow !== false ? 'ahoracrypto-shadow-lg' : '';
// Set the className for skeletonSection
skeletonSection.className = "ahoracrypto-mx-auto ahoracrypto-rounded-3xl ".concat(shadowClass, " ahoracrypto-p-4 ahoracrypto-pt-6 ahoracrypto-relative ahoracrypto-overflow-hidden");
// Apply background color directly with style to ensure it's applied correctly
skeletonSection.style.backgroundColor = isDarkTheme ? 'rgb(55 55 55 / 1)' : 'white';
// If custom borderRadius is defined, apply it
if (borderRadius !== 24) { // Default is 24px
skeletonSection.style.borderRadius = "".concat(borderRadius, "px");
loadingContainer.style.borderRadius = "".concat(borderRadius, "px");
}
// Create the inner container with the skeleton UI - make it fill the entire height
var innerContainer = document.createElement('div');
innerContainer.className = "ahoracrypto-absolute ahoracrypto-inset-0 ahoracrypto-z-1 ahoracrypto-flex ahoracrypto-items-stretch ahoracrypto-justify-center";
// Apply background color directly with style
innerContainer.style.backgroundColor = isDarkTheme ? 'rgb(55 55 55 / 1)' : 'white';
// Create the skeleton pulse animation content - make it full height with flex column
var skeletonContent = document.createElement('div');
skeletonContent.className = 'ahoracrypto-animate-pulse ahoracrypto-w-full ahoracrypto-p-6 ahoracrypto-flex ahoracrypto-flex-col ahoracrypto-justify-between';
skeletonContent.style.height = '100%';
// Define color for skeleton elements based on theme
var skeletonElementColor = isDarkTheme ? 'rgb(89 89 89 / 1)' : '#d1d5db'; // Usar el color menos oscuro para elementos
skeletonContent.innerHTML = "\n
\n\n \n \n
\n\n
\n\n
\n\n \n
\n\n \n
\n
\n\n \n \n ");
// Assemble the loading skeleton
innerContainer.appendChild(skeletonContent);
skeletonSection.appendChild(innerContainer);
loadingContainer.appendChild(skeletonSection);
// Add the loading container to the wrapper
widgetWrapper.appendChild(loadingContainer);
// Add the wrapper to the container
container.appendChild(widgetWrapper);
// Ready state tracking
var isWidgetReady = false;
var readyCallbacks = [];
var pendingMessages = [];
var readyResolver = null;
var readyPromise = new Promise(function (resolve) {
readyResolver = resolve;
});
// Function to send a message to the iframe
var sendMessageToIframe = function (message) {
if (isWidgetReady && iframe.contentWindow) {
iframe.contentWindow.postMessage(message, '*');
}
else {
pendingMessages.push(message);
}
};
// Function to handle widget ready state
var handleWidgetReady = function () {
if (isWidgetReady)
return;
isWidgetReady = true;
setTimeout(function () {
// Show iframe and hide loading animation
loadingContainer.style.display = 'none';
iframe.style.display = 'block';
// Ensure iframe maintains its configured dimensions
//if (config.iframeWidth) {
iframe.style.width = '100%';
//}
if (config.iframeHeight) {
iframe.style.height = height + 'px';
}
// Ensure border radius is maintained
iframe.style.borderRadius = "".concat(borderRadius, "px");
// Also apply current theme styling to make sure all styles are in sync
updateThemeStyling(theme);
// Send any pending messages
pendingMessages.forEach(function (message) {
if (iframe.contentWindow) {
iframe.contentWindow.postMessage(message, '*');
}
});
pendingMessages = [];
// Execute ready callbacks
readyCallbacks.forEach(function (callback) { return callback(); });
readyCallbacks = [];
// Resolve the ready promise
if (readyResolver)
readyResolver();
}, 1000);
};
// Set up message listener for ready event from iframe
window.addEventListener('message', function (event) {
// Check if message is from our iframe
if (event.source === iframe.contentWindow && event.data) {
// Handle widget ready message
if (event.data.type === 'WIDGET_READY') {
handleWidgetReady();
}
// Handle theme changed message
else if (event.data.type === 'THEME_CHANGED' && event.data.theme) {
var newTheme = event.data.theme;
console.log('Theme changed from iframe:', newTheme);
// Store the theme in localStorage with a prefix to avoid collisions
try {
localStorage.setItem('ahoracrypto-theme', newTheme);
}
catch (e) {
console.warn('Could not save theme to localStorage:', e);
}
// Update our internal theme state
theme = newTheme;
// Update the styling to match the new theme
// This will also ensure border radius and other styles are preserved
updateThemeStyling(newTheme);
}
}
});
// Also listen for load event (as a fallback)
iframe.addEventListener('load', function () {
// Give the iframe content a moment to initialize after load
setTimeout(function () {
if (!isWidgetReady) {
console.warn('Widget iframe loaded but did not send WIDGET_READY message. Assuming it is ready.');
handleWidgetReady();
}
}, 1000); // Wait 1 second after load before assuming ready
});
// Create and return the widget controller
return {
iframe: iframe,
setWalletAddress: function (walletAddress) {
sendMessageToIframe({
type: 'SET_WALLET_ADDRESS',
walletAddress: walletAddress
});
},
setPaymentIntentId: function (paymentIntentId) {
sendMessageToIframe({
type: 'SET_PAYMENT_INTENT_ID',
paymentIntentId: paymentIntentId
});
},
sendSignedMessage: function (signature, address, messageHash) {
sendMessageToIframe({
type: 'SIGNED_MESSAGE',
signature: signature,
address: address,
messageHash: messageHash
});
},
requestMessageToSign: function () {
sendMessageToIframe({
type: 'REQUEST_MESSAGE_TO_SIGN'
});
},
connectWeb3Wallet: function (provider, accountAddress, chainId) {
// Provider objects cannot be sent via postMessage, so we extract the relevant information
sendMessageToIframe({
type: 'CONNECT_WEB3_WALLET',
accountAddress: accountAddress,
chainId: chainId
});
// Set up event listeners for wallet changes if provider has ethereum methods
if (provider && provider.on) {
// Listen for account changes
provider.on('accountsChanged', function (accounts) {
if (accounts && accounts.length > 0) {
sendMessageToIframe({
type: 'WALLET_ACCOUNT_CHANGED',
accountAddress: accounts[0]
});
}
});
// Listen for chain changes
provider.on('chainChanged', function (chainId) {
sendMessageToIframe({
type: 'WALLET_CHAIN_CHANGED',
chainId: typeof chainId === 'string' ? parseInt(chainId, 16) : chainId
});
});
// Listen for disconnect
provider.on('disconnect', function () {
sendMessageToIframe({
type: 'WALLET_DISCONNECTED'
});
});
}
},
onReady: function (callback) {
if (isWidgetReady) {
// If already ready, execute immediately
callback();
}
else {
// Otherwise add to callback queue
readyCallbacks.push(callback);
}
},
ready: function () {
return readyPromise;
},
isReady: function () {
return isWidgetReady;
},
setTheme: function (newTheme) {
// Update our internal state
theme = newTheme;
// Store in localStorage with prefix to avoid collisions
try {
localStorage.setItem('ahoracrypto-theme', newTheme);
}
catch (e) {
console.warn('Could not save theme to localStorage:', e);
}
// Update styling of the parent container
updateThemeStyling(newTheme);
// Also inform the iframe about the theme change
sendMessageToIframe({
type: 'SET_THEME',
theme: newTheme
});
}
};
}
exports.renderWebwidget = renderWebwidget;
/***/ })
/******/ });
/************************************************************************/
/******/ // The module cache
/******/ var __webpack_module_cache__ = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/ // Check if module is in cache
/******/ var cachedModule = __webpack_module_cache__[moduleId];
/******/ if (cachedModule !== undefined) {
/******/ return cachedModule.exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = __webpack_module_cache__[moduleId] = {
/******/ // no module.id needed
/******/ // no module.loaded needed
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/************************************************************************/
var __webpack_exports__ = {};
// This entry needs to be wrapped in an IIFE because it needs to be isolated against other modules in the chunk.
(() => {
var exports = __webpack_exports__;
/*!**********************!*\
!*** ./src/index.ts ***!
\**********************/
Object.defineProperty(exports, "__esModule", ({ value: true }));
exports.renderWebwidget = void 0;
var webwidget_1 = __webpack_require__(/*! ./webwidget/webwidget */ "./src/webwidget/webwidget.ts");
Object.defineProperty(exports, "renderWebwidget", ({ enumerable: true, get: function () { return webwidget_1.renderWebwidget; } }));
})();
/******/ return __webpack_exports__;
/******/ })()
;
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"webwidget.js","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;;;;;;;;;;ACVa;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D,uBAAuB;AACvB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uEAAuE,2BAA2B,4BAA4B,sBAAsB,uBAAuB,4BAA4B,6BAA6B,kCAAkC,6BAA6B,2BAA2B,8BAA8B,SAAS,iDAAiD,8FAA8F,SAAS,qDAAqD,yCAAyC,4HAA4H,WAAW,SAAS,iDAAiD,qBAAqB,SAAS,mFAAmF,0BAA0B,SAAS,mCAAmC,sBAAsB,SAAS,4BAA4B,qBAAqB,SAAS,oCAAoC,iBAAiB,SAAS,qCAAqC,kBAAkB,SAAS,sCAAsC,mBAAmB,SAAS,uCAAuC,oBAAoB,SAAS,mCAAmC,wBAAwB,SAAS,qCAAqC,uBAAuB,SAAS,uCAAuC,iCAAiC,SAAS,2CAA2C,8BAA8B,SAAS,4CAA4C,+BAA+B,SAAS,6CAA6C,kCAAkC,SAAS,8CAA8C,yCAAyC,SAAS,0CAA0C,oCAAoC,SAAS,uCAAuC,oCAAoC,SAAS,4CAA4C,+CAA+C,SAAS,0CAA0C,2BAA2B,SAAS,qCAAqC,sBAAsB,SAAS,sCAAsC,wBAAwB,SAAS,sCAAsC,4BAA4B,6BAA6B,SAAS,uCAAuC,kCAAkC,SAAS,gDAAgD,8CAA8C,SAAS,iDAAiD,8CAA8C,SAAS,0CAA0C,gCAAgC,SAAS,yCAAyC,gCAAgC,SAAS,2CAA2C,gCAAgC,SAAS,sCAAsC,iCAAiC,SAAS,wCAAwC,8FAA8F,SAAS,kCAAkC,wBAAwB,SAAS,mCAAmC,8BAA8B,SAAS,mCAAmC,+BAA+B,gCAAgC,SAAS,4BAA4B,0BAA0B,SAAS,mCAAmC,6BAA6B,SAAS,uCAAuC,6BAA6B,SAAS,sCAAsC,iBAAiB,mBAAmB,oBAAoB,kBAAkB,SAAS,8CAA8C,2BAA2B,SAAS,4CAA4C,+EAA+E,SAAS,6CAA6C,oBAAoB,uBAAuB,WAAW,eAAe,wBAAwB,WAAW,SAAS,mCAAmC,wBAAwB,SAAS,mCAAmC,yBAAyB,SAAS,kCAAkC,sBAAsB,SAAS,kCAAkC,uBAAuB,SAAS,0CAA0C,oCAAoC,SAAS,mCAAmC,8BAA8B,SAAS,mCAAmC,iCAAiC,SAAS,mCAAmC,uBAAuB,SAAS,mCAAmC,yBAAyB,SAAS,kCAAkC,0BAA0B,SAAS,kCAAkC,uBAAuB,SAAS,oCAAoC,qBAAqB,SAAS,oCAAoC,4BAA4B,SAAS,mCAAmC,4BAA4B,SAAS,mCAAmC,8BAA8B,SAAS,mCAAmC,6BAA6B,SAAS,0CAA0C,6BAA6B,SAAS,mCAAmC,4BAA4B,+BAA+B,SAAS,mCAAmC,8BAA8B,iCAAiC,SAAS,6BAA6B,gCAAgC,SAAS,6BAA6B,8BAA8B,SAAS,6BAA6B,gCAAgC,SAAS,8BAA8B,4BAA4B,SAAS,mHAAmH,yCAAyC,SAAS,sFAAsF,qCAAqC,0BAA0B,WAAW,mDAAmD,kCAAkC,WAAW,iDAAiD,gGAAgG,WAAW,SAAS,iIAAiI,4BAA4B,SAAS,qCAAqC,uBAAuB,SAAS,qCAAqC,sBAAsB,SAAS;AACxoN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,YAAY,gBAAgB,iBAAiB;AACzE;AACA,mCAAmC;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8EAA8E;AAC9E,8TAA8T,gLAAgL,yWAAyW,uLAAuL,yNAAyN,sQAAsQ,uMAAuM,sTAAsT;AAC1+D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,yDAAyD,oBAAoB;AAC7E;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,SAAS;AAClB,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB;AACzB;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB,iBAAiB;AACjB;AACA;AACA;AACA;AACA,qBAAqB;AACrB,iBAAiB;AACjB;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,uBAAuB;;;;;;;UC7avB;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;;;;;;ACtBa;AACb,8CAA6C,EAAE,aAAa,EAAC;AAC7D,uBAAuB;AACvB,kBAAkB,mBAAO,CAAC,2DAAuB;AACjD,mDAAkD,EAAE,qCAAqC,uCAAuC,EAAC","sources":["webpack://AhoraCrypto/webpack/universalModuleDefinition","webpack://AhoraCrypto/./src/webwidget/webwidget.ts","webpack://AhoraCrypto/webpack/bootstrap","webpack://AhoraCrypto/./src/index.ts"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"AhoraCrypto\"] = factory();\n\telse\n\t\troot[\"AhoraCrypto\"] = factory();\n})(this, () => {\nreturn ","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.renderWebwidget = void 0;\n/**\n * Renders the AhoraCrypto web widget in the specified container element\n * @param config Configuration object for the widget\n * @param config.referral Optional referral identifier used for tracking traffic sources.\n *                      If not provided, the domain of the container will be used automatically.\n *                      The system extracts the base domain (e.g., \"example.com\" from \"sub.example.com\")\n * @returns WebwidgetController that allows interaction with the iframe\n */\nfunction renderWebwidget(config) {\n    // Extract container element\n    var container = document.getElementById(config.containerId);\n    if (!container) {\n        console.error(\"Container with ID '\".concat(config.containerId, \"' not found.\"));\n        throw new Error(\"Container with ID '\".concat(config.containerId, \"' not found.\"));\n    }\n    // Generate iframe URL with parameters\n    var baseUrl = \"https://ahoracrypto.com/\";\n    // Only add language to URL if it's specified\n    if (config.language) {\n        baseUrl += config.language + \"/\";\n    }\n    baseUrl += \"webwidget/\";\n    // Create URL params object\n    var params = new URLSearchParams();\n    // Add parameters if they exist (mapping from config param to iframe param)\n    if (config.cryptoCurrency)\n        params.append('crypto', config.cryptoCurrency);\n    if (config.fiatCurrency)\n        params.append('fiat', config.fiatCurrency);\n    if (config.logoUrl && config.logoUrl.trim() !== '')\n        params.append('lurl', config.logoUrl);\n    if (config.backgroundColor)\n        params.append('bgc', config.backgroundColor);\n    if (config.buttonColor)\n        params.append('btc', config.buttonColor);\n    if (config.borderRadius !== undefined)\n        params.append('br', config.borderRadius.toString());\n    if (config.borderWithShadow !== undefined)\n        params.append('bws', config.borderWithShadow ? '1' : '0');\n    if (config.paymentIntentId)\n        params.append('pi', config.paymentIntentId);\n    if (config.cryptos && config.cryptos.trim() !== '')\n        params.append('cryptos', config.cryptos);\n    if (config.defaultNetwork && config.defaultNetwork.trim() !== '')\n        params.append('defaultNetwork', config.defaultNetwork);\n    // Add referral parameter (if provided) or use current domain\n    var referral = config.referral;\n    if (!referral) {\n        // Extract domain from current URL (without subdomains, path, protocol, or port)\n        try {\n            var hostname = window.location.hostname;\n            // Extract the domain: split by dots and take the last two parts\n            // This handles cases like sub.domain.com -> domain.com\n            var parts = hostname.split('.');\n            if (parts.length >= 2) {\n                // For normal domains like example.com\n                var domain = parts.slice(-2).join('.');\n                referral = domain;\n            }\n            else {\n                // For localhost or IP addresses\n                referral = hostname;\n            }\n            params.append('referral', referral);\n        }\n        catch (e) {\n            console.warn('Could not extract domain for referral:', e);\n        }\n    }\n    // Always pass the current theme to the iframe\n    var theme = 'light';\n    try {\n        // Check first for a theme passed in the configuration\n        if (config.theme) {\n            theme = config.theme.toLowerCase();\n        }\n        else {\n            // If not in config, try our prefixed localStorage key first\n            var ahoraCryptoTheme = localStorage.getItem('ahoracrypto-theme');\n            if (ahoraCryptoTheme && (ahoraCryptoTheme === 'dark' || ahoraCryptoTheme === 'light')) {\n                theme = ahoraCryptoTheme;\n            }\n            // Fall back to generic 'theme' key in localStorage\n            else {\n                var savedTheme = localStorage.getItem('theme');\n                if (savedTheme && (savedTheme === 'dark' || savedTheme === 'light')) {\n                    theme = savedTheme;\n                }\n                else if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {\n                    // If not in localStorage, check system preference\n                    theme = 'dark';\n                }\n            }\n        }\n        // Add a console log for debugging\n        console.log('Detected theme:', theme);\n    }\n    catch (e) {\n        // In case localStorage is not accessible\n        console.warn('Could not access localStorage for theme:', e);\n        // Default to light theme on error\n        theme = 'light';\n    }\n    // Always pass the current theme to the iframe\n    params.append('theme', theme);\n    // Create iframe element\n    var iframe = document.createElement('iframe');\n    // Default background colors based on theme\n    var defaultBgColor = theme === 'dark' ?\n        'rgb(55 55 55 / 1)' : 'white';\n    var defaultBgColor2 = theme === 'dark' ?\n        'rgb(55 55 55 / 1)' : 'white';\n    // Add custom styles to head\n    var styleElement = document.createElement('style');\n    styleElement.textContent = \"\\n      .AhoraCrypto_iframe_container {\\n        max-width: 26rem;\\n        max-height: 600px;\\n        width: auto;\\n        height: auto;\\n        margin-left: auto;\\n        margin-right: auto;\\n        background-color: white;\\n        position: relative;\\n        overflow: hidden;\\n        border-radius: 24px;\\n      }\\n      \\n      .AhoraCrypto_iframe_with_shadow {\\n        box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);\\n      }\\n      \\n      @media (prefers-color-scheme: dark) {\\n        .AhoraCrypto_iframe_container {\\n          background-color: \".concat(config.backgroundColor ? \"#\".concat(config.backgroundColor) : 'rgb(55 55 55 / 1)', \";\\n        }\\n      }\\n      \\n      .AhoraCrypto_loading__container {\\n        z-index: 1;\\n      }\\n      \\n      /* Skeleton loading animation styles */\\n      .ahoracrypto-fixed {\\n        position: fixed;\\n      }\\n      \\n      .ahoracrypto-z-50 {\\n        z-index: 50;\\n      }\\n\\n      .ahoracrypto-z-1 {\\n        z-index: 1;\\n      }\\n      \\n      .ahoracrypto-top-0 {\\n        top: 0;\\n      }\\n      \\n      .ahoracrypto-left-0 {\\n        left: 0;\\n      }\\n      \\n      .ahoracrypto-right-0 {\\n        right: 0;\\n      }\\n      \\n      .ahoracrypto-bottom-0 {\\n        bottom: 0;\\n      }\\n      \\n      .ahoracrypto-flex {\\n        display: flex;\\n      }\\n      \\n      .ahoracrypto-flex-1 {\\n        flex: 1 1 0%;\\n      }\\n      \\n      .ahoracrypto-flex-col {\\n        flex-direction: column;\\n      }\\n      \\n      .ahoracrypto-items-center {\\n        align-items: center;\\n      }\\n      \\n      .ahoracrypto-items-stretch {\\n        align-items: stretch;\\n      }\\n      \\n      .ahoracrypto-justify-center {\\n        justify-content: center;\\n      }\\n      \\n      .ahoracrypto-justify-between {\\n        justify-content: space-between;\\n      }\\n      \\n      .ahoracrypto-bg-gray-100 {\\n        background-color: #f3f4f6;\\n      }\\n      \\n      .ahoracrypto-bg-black {\\n        background-color: #000000;\\n      }\\n      \\n      .ahoracrypto-bg-opacity-50 {\\n        background-color: rgba(0, 0, 0, 0.5);\\n      }\\n      \\n      .ahoracrypto-max-w-26rem {\\n        max-width: 26rem;\\n      }\\n      \\n      .ahoracrypto-w-full {\\n        width: 100%;\\n      }\\n      \\n      .ahoracrypto-h-510px {\\n        height: 510px;\\n      }\\n      \\n      .ahoracrypto-mx-auto {\\n        margin-left: auto;\\n        margin-right: auto;\\n      }\\n      \\n      .ahoracrypto-bg-white {\\n        background-color: white;\\n      }\\n      \\n      .ahoracrypto-bg-brand-darkGray {\\n        background-color: rgb(55 55 55 / 1);\\n      }\\n      \\n      .ahoracrypto-bg-brand-darkGray2 {\\n        background-color: rgb(55 55 55 / 1);\\n      }\\n      \\n      .ahoracrypto-rounded-3xl {\\n        border-radius: 1.5rem;\\n      }\\n      \\n      .ahoracrypto-rounded-lg {\\n        border-radius: 0.5rem;\\n      }\\n      \\n      .ahoracrypto-rounded-full {\\n        border-radius: 9999px;\\n      }\\n      \\n      .ahoracrypto-rounded {\\n        border-radius: 0.25rem;\\n      }\\n      \\n      .ahoracrypto-shadow-lg {\\n        box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);\\n      }\\n      \\n      .ahoracrypto-p-4 {\\n        padding: 1rem;\\n      }\\n      \\n      .ahoracrypto-pt-6 {\\n        padding-top: 1.5rem;\\n      }\\n      \\n      .ahoracrypto-px-6 {\\n        padding-left: 1.5rem;\\n        padding-right: 1.5rem;\\n      }\\n\\n      .ahoracrypto-p-6 {\\n        padding: 1.5rem;\\n      }\\n\\n\\n      .ahoracrypto-relative {\\n        position: relative;\\n      }\\n      \\n      .ahoracrypto-absolute {\\n        position: absolute;\\n      }\\n      \\n      .ahoracrypto-inset-0 {\\n        top: 0;\\n        right: 0;\\n        bottom: 0;\\n        left: 0;\\n      }\\n      \\n      .ahoracrypto-overflow-hidden {\\n        overflow: hidden;\\n      }\\n      \\n      .ahoracrypto-animate-pulse {\\n        animation: ahoracryptoPulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;\\n      }\\n      \\n      @keyframes ahoracryptoPulse {\\n        0%, 100% {\\n          opacity: 1;\\n        }\\n        50% {\\n          opacity: .5;\\n        }\\n      }\\n      \\n      .ahoracrypto-w-10 {\\n        width: 2.5rem;\\n      }\\n      \\n      .ahoracrypto-h-10 {\\n        height: 2.5rem;\\n      }\\n      \\n      .ahoracrypto-w-8 {\\n        width: 2rem;\\n      }\\n      \\n      .ahoracrypto-h-8 {\\n        height: 2rem;\\n      }\\n      \\n      .ahoracrypto-bg-gray-300 {\\n        background-color: #d1d5db;\\n      }\\n      \\n      .ahoracrypto-mb-4 {\\n        margin-bottom: 1rem;\\n      }\\n      \\n      .ahoracrypto-mb-3 {\\n        margin-bottom: 0.75rem;\\n      }\\n      \\n      .ahoracrypto-h-24 {\\n        height: 6rem;\\n      }\\n      \\n      .ahoracrypto-h-14 {\\n        height: 3.5rem;\\n      }\\n      \\n      .ahoracrypto-h-5 {\\n        height: 1.25rem;\\n      }\\n      \\n      .ahoracrypto-h-4 {\\n        height: 1rem;\\n      }\\n      \\n      .ahoracrypto-w-1/4 {\\n        width: 25%;\\n      }\\n      \\n      .ahoracrypto-w-1/3 {\\n        width: 33.333333%;\\n      }\\n      \\n      .ahoracrypto-ml-4 {\\n        margin-left: 1rem;\\n      }\\n      \\n      .ahoracrypto-mt-3 {\\n        margin-top: 0.75rem;\\n      }\\n      \\n      .ahoracrypto-mt-2 {\\n        margin-top: 0.5rem;\\n      }\\n      \\n      .ahoracrypto-text-center {\\n        text-align: center;\\n      }\\n      \\n      .ahoracrypto-py-4 {\\n        padding-top: 1rem;\\n        padding-bottom: 1rem;\\n      }\\n      \\n      .ahoracrypto-py-2 {\\n        padding-top: 0.5rem;\\n        padding-bottom: 0.5rem;\\n      }\\n\\n      .ahoracrypto-mb-2 {\\n        margin-bottom: 0.5rem;\\n      }\\n\\n      .ahoracrypto-mb-4 {\\n        margin-bottom: 1rem;\\n      }\\n\\n      .ahoracrypto-mb-6 {\\n        margin-bottom: 1.5rem;\\n      }\\n\\n      .ahoracrypto-w-1/3 {\\n        width: 33.333333%;\\n      }\\n\\n      /* A\\u00F1adimos clases adicionales usadas en el skeleton loader */\\n      .ahoracrypto-justify-between {\\n        justify-content: space-between;\\n      }\\n      \\n      /* Media queries para responsive */\\n      @media (min-width: 640px) {\\n        .sm\\\\:ahoracrypto-h-510px {\\n          height: 510px;\\n        }\\n        \\n        .sm\\\\:ahoracrypto-rounded-3xl {\\n          border-radius: 1.5rem;\\n        }\\n        \\n        .sm\\\\:ahoracrypto-shadow-lg {\\n          box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);\\n        }\\n      }\\n      \\n      /* Aseguramos que todas las clases para las animaciones est\\u00E9n definidas */\\n      .ahoracrypto-max-h-600px {\\n        max-height: 600px;\\n      }\\n      \\n      .ahoracrypto-h-full {\\n        height: 100%;\\n      }\\n      \\n      .ahoracrypto-w-full {\\n        width: 100%;\\n      }\\n\\n    \");\n    document.head.appendChild(styleElement);\n    // Add shadow class conditionally\n    var baseClass = 'AhoraCrypto_iframe__f0bRD AhoraCrypto_iframe_container';\n    iframe.className = config.borderWithShadow !== false\n        ? \"\".concat(baseClass, \" AhoraCrypto_iframe_with_shadow\")\n        : baseClass;\n    iframe.id = 'ahoracrypto-widget';\n    iframe.title = 'AhoraCrypto Widget';\n    // Ensure minimum dimensions of 416x510 regardless of user input\n    var defaultWidth = 416;\n    var defaultHeight = 510;\n    var width = config.iframeWidth != null ? config.iframeWidth : defaultWidth;\n    var height = config.iframeHeight != null ? config.iframeHeight : defaultHeight;\n    // Use a default border radius of 24px if not specified\n    var borderRadius = config.borderRadius != null ? config.borderRadius : 24;\n    // Set dimensions with inline styles to ensure they take precedence over CSS classes\n    iframe.style.width = '100%';\n    iframe.style.height = height + 'px';\n    iframe.style.backgroundColor = 'transparent';\n    iframe.style.border = 'none';\n    // Still set width/height attributes for compatibility\n    iframe.width = width.toString();\n    iframe.height = height.toString();\n    // Apply border radius (default or configured)\n    iframe.style.borderRadius = \"\".concat(borderRadius, \"px\");\n    iframe.frameBorder = '0';\n    iframe.src = baseUrl + '?' + params.toString();\n    iframe.allow = 'camera; microphone; clipboard-read; clipboard-write; payment';\n    iframe.setAttribute('allowpaymentrequest', 'true');\n    iframe.style.display = 'none'; // Initially hide iframe until it's ready\n    // Function to update styling based on theme\n    var updateThemeStyling = function (newTheme) {\n        var isDarkTheme = newTheme === 'dark';\n        // Update iframe background color if not using a custom background color\n        if (!config.backgroundColor) {\n            var bgColor = isDarkTheme ? 'rgb(55 55 55 / 1)' : 'white';\n            // Update main container background\n            if (iframe.parentElement) {\n                iframe.parentElement.style.backgroundColor = bgColor;\n            }\n        }\n        // Ensure the border radius is maintained after theme change\n        iframe.style.borderRadius = \"\".concat(borderRadius, \"px\");\n        // If loading container is still present, update its style too\n        var loadingEl = document.getElementById('loading-section');\n        if (loadingEl) {\n            loadingEl.style.backgroundColor = isDarkTheme ? 'rgba(40, 40, 40, 0.8)' : 'rgba(243, 244, 246, 0.8)';\n            // Find the skeleton section inside loading container and update its style\n            var skeletonEl = loadingEl.querySelector('section');\n            if (skeletonEl) {\n                skeletonEl.style.backgroundColor = isDarkTheme ? 'rgb(55 55 55 / 1)' : 'white';\n                // Ensure the skeleton section also maintains its border radius\n                skeletonEl.classList.add('ahoracrypto-rounded-3xl');\n            }\n        }\n    };\n    // Reutilizamos el valor del tema que ya obtuvimos anteriormente\n    var isDarkTheme = theme === 'dark';\n    console.log('Using dark theme for skeleton:', isDarkTheme);\n    // Add iframe to container first to establish positioning context\n    container.appendChild(iframe);\n    // Create a wrapper div to contener both the iframe and the loading animation\n    // This ensures they ocuppy the same space\n    var widgetWrapper = document.createElement('div');\n    widgetWrapper.className = 'ahoracrypto-relative';\n    widgetWrapper.style.width = '100%';\n    widgetWrapper.style.maxWidth = width + 'px';\n    widgetWrapper.style.height = height + 'px';\n    widgetWrapper.style.backgroundColor = isDarkTheme ? 'rgb(55 55 55 / 1)' : 'white';\n    widgetWrapper.style.borderRadius = \"\".concat(borderRadius, \"px\");\n    // Remove iframe from container and add it to the wrapper\n    container.removeChild(iframe);\n    widgetWrapper.appendChild(iframe);\n    // Apply initial theme styling\n    updateThemeStyling(theme);\n    // Create loading skeleton container\n    var loadingContainer = document.createElement('div');\n    loadingContainer.id = 'loading-section';\n    // Apply styles to make the loading container position absolutely within the wrapper\n    loadingContainer.className = 'ahoracrypto-absolute ahoracrypto-z-1 ahoracrypto-inset-0 ahoracrypto-flex ahoracrypto-items-center ahoracrypto-justify-center';\n    // Make sure the loading container is visible initially\n    loadingContainer.style.display = 'block';\n    loadingContainer.style.borderRadius = \"\".concat(borderRadius, \"px\");\n    // Apply a semi-transparent background based on theme - use explicit colors\n    loadingContainer.style.backgroundColor = isDarkTheme ? 'rgba(40, 40, 40, 0.8)' : 'rgba(243, 244, 246, 0.8)';\n    // Get dimensions for the skeleton section to match the iframe\n    var skeletonSection = document.createElement('section');\n    // Make sure the loading section matches the iframe dimensions\n    loadingContainer.style.width = '100%';\n    loadingContainer.style.maxWidth = width + 'px';\n    loadingContainer.style.height = height + 'px';\n    // Set fixed dimensions for the skeleton section to match the iframe\n    skeletonSection.style.maxWidth = width + 'px';\n    skeletonSection.style.height = height + 'px';\n    // Fix specific height for the skeleton section (removes h-full since that can cause issues)\n    var shadowClass = config.borderWithShadow !== false ? 'ahoracrypto-shadow-lg' : '';\n    // Set the className for skeletonSection\n    skeletonSection.className = \"ahoracrypto-mx-auto ahoracrypto-rounded-3xl \".concat(shadowClass, \" ahoracrypto-p-4 ahoracrypto-pt-6 ahoracrypto-relative ahoracrypto-overflow-hidden\");\n    // Apply background color directly with style to ensure it's applied correctly\n    skeletonSection.style.backgroundColor = isDarkTheme ? 'rgb(55 55 55 / 1)' : 'white';\n    // If custom borderRadius is defined, apply it\n    if (borderRadius !== 24) { // Default is 24px\n        skeletonSection.style.borderRadius = \"\".concat(borderRadius, \"px\");\n        loadingContainer.style.borderRadius = \"\".concat(borderRadius, \"px\");\n    }\n    // Create the inner container with the skeleton UI - make it fill the entire height\n    var innerContainer = document.createElement('div');\n    innerContainer.className = \"ahoracrypto-absolute ahoracrypto-inset-0 ahoracrypto-z-1 ahoracrypto-flex ahoracrypto-items-stretch ahoracrypto-justify-center\";\n    // Apply background color directly with style\n    innerContainer.style.backgroundColor = isDarkTheme ? 'rgb(55 55 55 / 1)' : 'white';\n    // Create the skeleton pulse animation content - make it full height with flex column\n    var skeletonContent = document.createElement('div');\n    skeletonContent.className = 'ahoracrypto-animate-pulse ahoracrypto-w-full ahoracrypto-p-6 ahoracrypto-flex ahoracrypto-flex-col ahoracrypto-justify-between';\n    skeletonContent.style.height = '100%';\n    // Define color for skeleton elements based on theme\n    var skeletonElementColor = isDarkTheme ? 'rgb(89 89 89 / 1)' : '#d1d5db'; // Usar el color menos oscuro para elementos\n    skeletonContent.innerHTML = \"\\n        <div class=\\\"ahoracrypto-flex ahoracrypto-justify-between ahoracrypto-items-center ahoracrypto-mb-2\\\">\\n            <div class=\\\"ahoracrypto-w-10 ahoracrypto-h-10 ahoracrypto-rounded-full ahoracrypto-animate-pulse\\\" style=\\\"background-color: \".concat(skeletonElementColor, \";\\\"></div>\\n            <div class=\\\"ahoracrypto-w-8 ahoracrypto-h-8 ahoracrypto-rounded ahoracrypto-animate-pulse\\\" style=\\\"background-color: \").concat(skeletonElementColor, \";\\\"></div>\\n        </div>\\n\\n        <div class=\\\"ahoracrypto-flex-1 ahoracrypto-flex ahoracrypto-flex-col ahoracrypto-justify-between ahoracrypto-py-2\\\">\\n            <!-- Amount Input -->\\n            <div class=\\\"ahoracrypto-rounded-lg ahoracrypto-h-24 ahoracrypto-mb-3 ahoracrypto-animate-pulse\\\" style=\\\"background-color: \").concat(skeletonElementColor, \";\\\"></div>\\n\\n            <div class=\\\"ahoracrypto-rounded-lg ahoracrypto-h-24 ahoracrypto-mb-3 ahoracrypto-animate-pulse\\\" style=\\\"background-color: \").concat(skeletonElementColor, \";\\\"></div>\\n\\n            <div class=\\\"ahoracrypto-h-5 ahoracrypto-w-1/4 ahoracrypto-ml-4 ahoracrypto-mb-3 ahoracrypto-rounded-lg ahoracrypto-animate-pulse\\\" style=\\\"background-color: \").concat(skeletonElementColor, \";\\\"></div>\\n\\n            <!-- Payment Method -->\\n            <div class=\\\"ahoracrypto-h-14 ahoracrypto-rounded-lg ahoracrypto-mb-4 ahoracrypto-flex ahoracrypto-items-center ahoracrypto-animate-pulse\\\" style=\\\"background-color: \").concat(skeletonElementColor, \";\\\"></div>\\n\\n            <!-- Buy Button -->\\n            <div class=\\\"ahoracrypto-h-14 ahoracrypto-rounded-lg ahoracrypto-animate-pulse\\\" style=\\\"background-color: \").concat(skeletonElementColor, \";\\\"></div>\\n        </div>\\n\\n        <!-- Footer -->\\n        <div class=\\\"ahoracrypto-mt-3 ahoracrypto-text-center\\\">\\n            <div class=\\\"ahoracrypto-h-4 ahoracrypto-w-1/3 ahoracrypto-rounded-lg ahoracrypto-mx-auto ahoracrypto-animate-pulse\\\" style=\\\"background-color: \").concat(skeletonElementColor, \";\\\"></div>\\n        </div>\\n    \");\n    // Assemble the loading skeleton\n    innerContainer.appendChild(skeletonContent);\n    skeletonSection.appendChild(innerContainer);\n    loadingContainer.appendChild(skeletonSection);\n    // Add the loading container to the wrapper\n    widgetWrapper.appendChild(loadingContainer);\n    // Add the wrapper to the container\n    container.appendChild(widgetWrapper);\n    // Ready state tracking\n    var isWidgetReady = false;\n    var readyCallbacks = [];\n    var pendingMessages = [];\n    var readyResolver = null;\n    var readyPromise = new Promise(function (resolve) {\n        readyResolver = resolve;\n    });\n    // Function to send a message to the iframe\n    var sendMessageToIframe = function (message) {\n        if (isWidgetReady && iframe.contentWindow) {\n            iframe.contentWindow.postMessage(message, '*');\n        }\n        else {\n            pendingMessages.push(message);\n        }\n    };\n    // Function to handle widget ready state\n    var handleWidgetReady = function () {\n        if (isWidgetReady)\n            return;\n        isWidgetReady = true;\n        setTimeout(function () {\n            // Show iframe and hide loading animation\n            loadingContainer.style.display = 'none';\n            iframe.style.display = 'block';\n            // Ensure iframe maintains its configured dimensions\n            //if (config.iframeWidth) {\n            iframe.style.width = '100%';\n            //}\n            if (config.iframeHeight) {\n                iframe.style.height = height + 'px';\n            }\n            // Ensure border radius is maintained\n            iframe.style.borderRadius = \"\".concat(borderRadius, \"px\");\n            // Also apply current theme styling to make sure all styles are in sync\n            updateThemeStyling(theme);\n            // Send any pending messages\n            pendingMessages.forEach(function (message) {\n                if (iframe.contentWindow) {\n                    iframe.contentWindow.postMessage(message, '*');\n                }\n            });\n            pendingMessages = [];\n            // Execute ready callbacks\n            readyCallbacks.forEach(function (callback) { return callback(); });\n            readyCallbacks = [];\n            // Resolve the ready promise\n            if (readyResolver)\n                readyResolver();\n        }, 1000);\n    };\n    // Set up message listener for ready event from iframe\n    window.addEventListener('message', function (event) {\n        // Check if message is from our iframe\n        if (event.source === iframe.contentWindow && event.data) {\n            // Handle widget ready message\n            if (event.data.type === 'WIDGET_READY') {\n                handleWidgetReady();\n            }\n            // Handle theme changed message\n            else if (event.data.type === 'THEME_CHANGED' && event.data.theme) {\n                var newTheme = event.data.theme;\n                console.log('Theme changed from iframe:', newTheme);\n                // Store the theme in localStorage with a prefix to avoid collisions\n                try {\n                    localStorage.setItem('ahoracrypto-theme', newTheme);\n                }\n                catch (e) {\n                    console.warn('Could not save theme to localStorage:', e);\n                }\n                // Update our internal theme state\n                theme = newTheme;\n                // Update the styling to match the new theme\n                // This will also ensure border radius and other styles are preserved\n                updateThemeStyling(newTheme);\n            }\n        }\n    });\n    // Also listen for load event (as a fallback)\n    iframe.addEventListener('load', function () {\n        // Give the iframe content a moment to initialize after load\n        setTimeout(function () {\n            if (!isWidgetReady) {\n                console.warn('Widget iframe loaded but did not send WIDGET_READY message. Assuming it is ready.');\n                handleWidgetReady();\n            }\n        }, 1000); // Wait 1 second after load before assuming ready\n    });\n    // Create and return the widget controller\n    return {\n        iframe: iframe,\n        setWalletAddress: function (walletAddress) {\n            sendMessageToIframe({\n                type: 'SET_WALLET_ADDRESS',\n                walletAddress: walletAddress\n            });\n        },\n        setPaymentIntentId: function (paymentIntentId) {\n            sendMessageToIframe({\n                type: 'SET_PAYMENT_INTENT_ID',\n                paymentIntentId: paymentIntentId\n            });\n        },\n        sendSignedMessage: function (signature, address, messageHash) {\n            sendMessageToIframe({\n                type: 'SIGNED_MESSAGE',\n                signature: signature,\n                address: address,\n                messageHash: messageHash\n            });\n        },\n        requestMessageToSign: function () {\n            sendMessageToIframe({\n                type: 'REQUEST_MESSAGE_TO_SIGN'\n            });\n        },\n        connectWeb3Wallet: function (provider, accountAddress, chainId) {\n            // Provider objects cannot be sent via postMessage, so we extract the relevant information\n            sendMessageToIframe({\n                type: 'CONNECT_WEB3_WALLET',\n                accountAddress: accountAddress,\n                chainId: chainId\n            });\n            // Set up event listeners for wallet changes if provider has ethereum methods\n            if (provider && provider.on) {\n                // Listen for account changes\n                provider.on('accountsChanged', function (accounts) {\n                    if (accounts && accounts.length > 0) {\n                        sendMessageToIframe({\n                            type: 'WALLET_ACCOUNT_CHANGED',\n                            accountAddress: accounts[0]\n                        });\n                    }\n                });\n                // Listen for chain changes\n                provider.on('chainChanged', function (chainId) {\n                    sendMessageToIframe({\n                        type: 'WALLET_CHAIN_CHANGED',\n                        chainId: typeof chainId === 'string' ? parseInt(chainId, 16) : chainId\n                    });\n                });\n                // Listen for disconnect\n                provider.on('disconnect', function () {\n                    sendMessageToIframe({\n                        type: 'WALLET_DISCONNECTED'\n                    });\n                });\n            }\n        },\n        onReady: function (callback) {\n            if (isWidgetReady) {\n                // If already ready, execute immediately\n                callback();\n            }\n            else {\n                // Otherwise add to callback queue\n                readyCallbacks.push(callback);\n            }\n        },\n        ready: function () {\n            return readyPromise;\n        },\n        isReady: function () {\n            return isWidgetReady;\n        },\n        setTheme: function (newTheme) {\n            // Update our internal state\n            theme = newTheme;\n            // Store in localStorage with prefix to avoid collisions\n            try {\n                localStorage.setItem('ahoracrypto-theme', newTheme);\n            }\n            catch (e) {\n                console.warn('Could not save theme to localStorage:', e);\n            }\n            // Update styling of the parent container\n            updateThemeStyling(newTheme);\n            // Also inform the iframe about the theme change\n            sendMessageToIframe({\n                type: 'SET_THEME',\n                theme: newTheme\n            });\n        }\n    };\n}\nexports.renderWebwidget = renderWebwidget;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.renderWebwidget = void 0;\nvar webwidget_1 = require(\"./webwidget/webwidget\");\nObject.defineProperty(exports, \"renderWebwidget\", { enumerable: true, get: function () { return webwidget_1.renderWebwidget; } });\n"],"names":[],"sourceRoot":""}