/******/ (() => { // webpackBootstrap /******/ "use strict"; /******/ var __webpack_modules__ = ({ /***/ 294: /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ DU: () => (/* binding */ webinarsAtom), /* harmony export */ SI: () => (/* binding */ webinarCTADialogPropsAtom), /* harmony export */ mm: () => (/* binding */ webinarLeadFormDialogPropsAtom), /* harmony export */ ps: () => (/* binding */ webinarsErrorAtom), /* harmony export */ pv: () => (/* binding */ combinedFormPropsAtom), /* harmony export */ xL: () => (/* binding */ webinarsLoadingAtom) /* harmony export */ }); /* unused harmony exports webinarListDialogPropsAtom, upcomingWebinarsDialogPropsAtom, upcomingFpuWebinarsDialogPropsAtom */ /* harmony import */ var jotai__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(2035); /* harmony import */ var jotai_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(4929); const webinarsAtom = (0,jotai__WEBPACK_IMPORTED_MODULE_0__/* .atom */ .eU)([]); const webinarsLoadingAtom = (0,jotai__WEBPACK_IMPORTED_MODULE_0__/* .atom */ .eU)(false); const webinarsErrorAtom = (0,jotai__WEBPACK_IMPORTED_MODULE_0__/* .atom */ .eU)(null); const webinarListDialogPropsAtom = (0,jotai__WEBPACK_IMPORTED_MODULE_0__/* .atom */ .eU)(window._WEBINAR_LIST_REQUEST || undefined); const upcomingWebinarsDialogPropsAtom = (0,jotai__WEBPACK_IMPORTED_MODULE_0__/* .atom */ .eU)(Array.isArray(window._UPCOMING_WEBINARS_REQUEST) ? window._UPCOMING_WEBINARS_REQUEST : []); const upcomingFpuWebinarsDialogPropsAtom = (0,jotai__WEBPACK_IMPORTED_MODULE_0__/* .atom */ .eU)(Array.isArray(window._UPCOMING_WEBINARS_REQUEST) ? window._UPCOMING_WEBINARS_REQUEST : []); const webinarCTADialogPropsAtom = (0,jotai__WEBPACK_IMPORTED_MODULE_0__/* .atom */ .eU)(window._WEBINAR_PAGE_CTA_REQUEST || undefined); const webinarLeadFormDialogPropsAtom = (0,jotai__WEBPACK_IMPORTED_MODULE_0__/* .atom */ .eU)(window._WEBINAR_LEAD_FORM_REQUEST || undefined); function findUpcomingWebinarByTopic(webinars, filterTopic) { return webinars.find((w) => w.filterTopic === filterTopic); } const combinedFormPropsAtom = (0,jotai_utils__WEBPACK_IMPORTED_MODULE_1__/* .atomFamily */ .Iz)((filterTopic) => (0,jotai__WEBPACK_IMPORTED_MODULE_0__/* .atom */ .eU)((get) => { const listProps = get(webinarListDialogPropsAtom); const ctaProps = get(webinarCTADialogPropsAtom); const leadFormProps = get(webinarLeadFormDialogPropsAtom); const upcomingWebinarsProps = findUpcomingWebinarByTopic(get(upcomingWebinarsDialogPropsAtom), filterTopic); return { showPhoneNumber: leadFormProps?.showPhoneNumber ?? ctaProps?.showPhoneNumber ?? listProps?.showPhoneNumber ?? upcomingWebinarsProps?.showPhoneNumber ?? false, requirePhoneNumber: leadFormProps?.requirePhoneNumber ?? ctaProps?.requirePhoneNumber ?? listProps?.requirePhoneNumber ?? upcomingWebinarsProps?.requirePhoneNumber ?? false, showEmailOptIn: leadFormProps?.showEmailOptIn ?? ctaProps?.showEmailOptIn ?? listProps?.showEmailOptIn ?? upcomingWebinarsProps?.showEmailOptIn ?? false, showSmsOptIn: leadFormProps?.showSmsOptIn ?? ctaProps?.showSmsOptIn ?? listProps?.showSmsOptIn ?? upcomingWebinarsProps?.showSmsOptIn ?? false, buttonQuantity: ctaProps?.buttonQuantity ?? 2, buttonAppearance: ctaProps?.buttonAppearance ?? 'primary', onDarkCanvas: ctaProps?.onDarkCanvas ?? false, showRecording: ctaProps?.showRecording ?? listProps?.showRecording ?? false, filterOptions: ctaProps?.filterOptions ?? '' }; })); /***/ }), /***/ 4506: /***/ ((__unused_webpack_module, __unused_webpack___webpack_exports__, __webpack_require__) => { // EXTERNAL MODULE: ./node_modules/react/jsx-runtime.js var jsx_runtime = __webpack_require__(4848); // EXTERNAL MODULE: ./node_modules/react-dom/client.js var client = __webpack_require__(5338); // EXTERNAL MODULE: ./node_modules/react/index.js var react = __webpack_require__(6540); // EXTERNAL MODULE: ./node_modules/jotai/esm/react.mjs var esm_react = __webpack_require__(4843); // EXTERNAL MODULE: ./node_modules/@ramsey-design-system/button/dist/Button.esm.js + 1 modules var Button_esm = __webpack_require__(9438); // EXTERNAL MODULE: ./node_modules/@ramsey-design-system/heading/dist/Heading.esm.js var Heading_esm = __webpack_require__(1266); // EXTERNAL MODULE: ./node_modules/@ramsey-design-system/dialog/dist/Dialog.esm.js + 1 modules var Dialog_esm = __webpack_require__(2911); ;// ./src/rplus-forms/shared/components/Dialog.tsx const DIALOG_PADDING = (/* unused pure expression or super */ null && (['sm', 'md', 'lg', 'none'])); const DIALOG_WIDTH = (/* unused pure expression or super */ null && (['sm', 'md', 'lg'])); /** * * RDS Dialog component requires a triggerRef prop to be passed in. * This is a wrapper to make the triggerRef optiobal. */ function Dialog({ children, className, onClose, open = false, padding = 'md', portalMount, triggerRef, width = 'md' }) { if (!open) { return null; // Do not render anything if `open` is false } return ((0,jsx_runtime.jsx)(Dialog_esm/* default */.A, { "data-testid": "rds-dialog", onClose: onClose, open: open, padding: padding, portalMount: portalMount, width: width, triggerRef: triggerRef || null, className: `[&_.rds-Dialog-overlay]:bg-white [&_.rds-Dialog-overlay]:bg-opacity-30 [&_.rds-Dialog-overlay]:backdrop-blur-[8px] ${className ?? ''}`, children: children })); } Dialog.Title = Dialog_esm/* default */.A.Title; Dialog.Description = Dialog_esm/* default */.A.Description; /* harmony default export */ const components_Dialog = (Dialog); // EXTERNAL MODULE: ./src/rplus-forms/modules/WebinarLeadForm/WebinarLeadForm.tsx + 4 modules var WebinarLeadForm = __webpack_require__(902); ;// ./src/rplus-forms/modules/UpcomingWebinarList/WebinarDialog.tsx // RDS // Components function WebinarDialog({ onClose, isOpen, webinarId, webinarName, webinarTopic, webinarTime }) { const handleClose = () => { onClose(); }; const isRecording = !webinarId; const dialogTitle = webinarName ?? webinarTopic; return ((0,jsx_runtime.jsx)(components_Dialog, { open: isOpen, onClose: handleClose, width: "md", className: "[&_.rds-Dialog-content]:max-w-[600px] [&_.rds-Dialog-content]:p-3 [&_.rds-Dialog-content]:md:p-5", children: (0,jsx_runtime.jsxs)("div", { "data-testid": "webinar-dialog", className: "flex flex-col items-center", children: [(0,jsx_runtime.jsxs)(Heading_esm/* default */.A, { level: "2", size: "medium", className: "text-blue-80 text-center !mb-2", "data-testid": "dialog-title", children: [dialogTitle, isRecording ? ((0,jsx_runtime.jsxs)(jsx_runtime.Fragment, { children: [(0,jsx_runtime.jsx)("br", {}), (0,jsx_runtime.jsx)("span", { children: "Recording" })] })) : null, (0,jsx_runtime.jsx)("br", {}), webinarTime] }), (0,jsx_runtime.jsx)(WebinarLeadForm/* default */.A, { webinarId: webinarId, webinarTopic: webinarTopic })] }) })); } // EXTERNAL MODULE: ./node_modules/date-fns-tz/dist/esm/index.js + 50 modules var esm = __webpack_require__(7971); ;// ./src/rplus-forms/shared/utils/formatDate.ts const formatDate = (dateString, timeZone) => { try { const date = new Date(dateString); const zonedDate = (0,esm/* toZonedTime */.L_)(date, timeZone); const formatDate = (0,esm/* format */.GP)(zonedDate, 'MMM d, h aa z', { timeZone }); // Manually remove D from CDT const formattedDate = formatDate.replace(/\bC[DS]T\b/, 'CT'); return formattedDate; } catch (error) { console.error('Error formatting date:', error); return 'Invalid Date'; } }; const formatShortDate = (dateString) => { try { const date = new Date(dateString); return format(date, 'MMM d'); } catch (error) { console.error('Error formatting date:', error); return 'Invalid Date'; } }; // EXTERNAL MODULE: ./node_modules/classnames/index.js var classnames = __webpack_require__(6942); var classnames_default = /*#__PURE__*/__webpack_require__.n(classnames); // EXTERNAL MODULE: ./node_modules/@tanstack/react-query/build/modern/useQuery.js + 6 modules var useQuery = __webpack_require__(3930); // EXTERNAL MODULE: ./src/rplus-forms/shared/application.ts var application = __webpack_require__(659); // EXTERNAL MODULE: ./src/rplus-forms/shared/utils/constants.ts var constants = __webpack_require__(7202); // EXTERNAL MODULE: ./src/rplus-forms/shared/stores/webinarAtoms.ts var webinarAtoms = __webpack_require__(294); ;// ./src/rplus-forms/shared/hooks/useWebinars.ts function useWebinars() { const setWebinars = (0,esm_react/* useSetAtom */.Xr)(webinarAtoms/* webinarsAtom */.DU); const setLoading = (0,esm_react/* useSetAtom */.Xr)(webinarAtoms/* webinarsLoadingAtom */.xL); const setError = (0,esm_react/* useSetAtom */.Xr)(webinarAtoms/* webinarsErrorAtom */.ps); const upcomingWebinars = (0,useQuery/* useQuery */.I)({ queryKey: ['webinars'], queryFn: async () => { const response = await fetch(`${application/* applicationConfig */.L.magnoliaFormsWebUrl}${constants/* PATHS */.R.API.UPCOMING_WEBINARS}`, { method: 'GET', headers: { 'Content-Type': 'application/json' } }); if (!response.ok) { throw new Error('Failed to fetch webinars'); } return response.json(); }, staleTime: 5 * 60 * 1000, // 5 minutes gcTime: 10 * 60 * 1000 // 10 minutes }); (0,react.useEffect)(() => { setWebinars(upcomingWebinars.data || []); setLoading(upcomingWebinars.isLoading); setError(upcomingWebinars.error); }, [ upcomingWebinars.data, upcomingWebinars.isLoading, upcomingWebinars.error, setWebinars, setLoading, setError ]); return upcomingWebinars; } ;// ./src/rplus-forms/modules/WebinarPageCTA/WebinarPageCTA.tsx // Components // Utils // Hooks // Atoms function WebinarPageCTA() { const { refetch } = useWebinars(); const webinars = (0,esm_react/* useAtomValue */.md)(webinarAtoms/* webinarsAtom */.DU); const loading = (0,esm_react/* useAtomValue */.md)(webinarAtoms/* webinarsLoadingAtom */.xL); const error = (0,esm_react/* useAtomValue */.md)(webinarAtoms/* webinarsErrorAtom */.ps); const [ctaDialogProps, setCTADialogProps] = (0,esm_react/* useAtom */.fp)(webinarAtoms/* webinarCTADialogPropsAtom */.SI); const webinarTitle = ctaDialogProps?.webinarName || ctaDialogProps?.filterOptions; const buttonQuantity = ctaDialogProps?.buttonQuantity ?? 2; const buttonAppearance = ctaDialogProps?.buttonAppearance ?? 'primary'; const onDarkCanvas = ctaDialogProps?.onDarkCanvas ?? false; const buttonText = ctaDialogProps?.buttonText ?? 'Watch Recording'; const showRecording = ctaDialogProps?.showRecording ?? false; const filterTopic = ctaDialogProps?.filterOptions ?? null; const [dialogOpen, setDialogOpen] = (0,react.useState)(false); const [selectedWebinar, setSelectedWebinar] = (0,react.useState)({ id: '', name: null, topic: null, time: null }); const filteredWebinars = filterTopic ? webinars.filter((webinar) => webinar.topic.toLowerCase() === filterTopic.toLowerCase()) : webinars; const openDialog = (id, name, topic, time) => { setSelectedWebinar({ id: id || '', name, topic, time }); setDialogOpen(true); }; const closeDialog = () => { setDialogOpen(false); }; (0,react.useEffect)(() => { const hasNoAtomWebinars = !webinars || webinars.length === 0; if (hasNoAtomWebinars && !loading && !error) { console.log('Triggering automatic refetch...'); refetch(); } }, [webinars, loading, error]); (0,react.useEffect)(() => { if (window._WEBINAR_PAGE_CTA_REQUEST && !ctaDialogProps) { setCTADialogProps(window._WEBINAR_PAGE_CTA_REQUEST); } }, [ctaDialogProps, setCTADialogProps]); if (loading) { return (0,jsx_runtime.jsx)("div", { children: "Loading..." }); } if (error) { return (0,jsx_runtime.jsx)("div", { className: "mb-4 text-center text-red-500", children: error.message }); } return ((0,jsx_runtime.jsxs)(jsx_runtime.Fragment, { children: [(0,jsx_runtime.jsxs)("div", { "data-testid": "webinar-button-grid", className: `mx-auto grid gap-1 max-w-[12.5rem] grid-cols-1 ${classnames_default()(buttonQuantity > 3 ? 'md:grid-cols-3 sm:max-w-xl' : 'md:grid-cols-2 sm:max-w-md')}`, children: [filteredWebinars.length > 0 ? (filteredWebinars.slice(0, buttonQuantity).map((webinar) => { const formattedDate = webinar.start_time ? formatDate(webinar.start_time, 'America/Chicago') : 'Invalid Date'; return ((0,jsx_runtime.jsx)(Button_esm/* default */.A, { isOnDarkCanvas: onDarkCanvas, size: "large", appearance: buttonAppearance, onClick: () => { openDialog(webinar.id, webinarTitle, webinar.topic, formattedDate); }, disabled: formattedDate === 'Invalid Date', children: formattedDate }, webinar.id)); })) : ((0,jsx_runtime.jsx)(Button_esm/* default */.A, { size: "large", disabled: true, children: "Coming Soon" })), showRecording && ((0,jsx_runtime.jsx)(Button_esm/* default */.A, { size: "large", className: `whitespace-nowrap md:whitespace-break-spaces lg:whitespace-nowrap`, isOnDarkCanvas: onDarkCanvas, onClick: () => { openDialog('', webinarTitle, filterTopic, ''); }, children: buttonText || 'Watch Recording' }))] }), (0,jsx_runtime.jsx)(WebinarDialog, { isOpen: dialogOpen, onClose: closeDialog, webinarId: selectedWebinar.id, webinarName: webinarTitle, webinarTopic: selectedWebinar.topic, webinarTime: selectedWebinar.time })] })); } /* harmony default export */ const WebinarPageCTA_WebinarPageCTA = (WebinarPageCTA); // EXTERNAL MODULE: ./node_modules/@tanstack/react-query/build/modern/QueryClientProvider.js var QueryClientProvider = __webpack_require__(7665); // EXTERNAL MODULE: ./src/rplus-forms/shared/config/sharedQueryClient.ts var sharedQueryClient = __webpack_require__(5288); ;// ./src/rplus-forms/modules/WebinarPageCTA/index.tsx const rootElement = document.getElementById('webinar-page-cta-root'); const root = (0,client.createRoot)(rootElement); root.render((0,jsx_runtime.jsx)(QueryClientProvider/* QueryClientProvider */.Ht, { client: sharedQueryClient/* sharedQueryClient */.T, children: (0,jsx_runtime.jsx)(WebinarPageCTA_WebinarPageCTA, {}) })); /***/ }), /***/ 6540: /***/ ((module, __unused_webpack_exports, __webpack_require__) => { if (true) { module.exports = __webpack_require__(9869); } else // removed by dead control flow {} /***/ }) /******/ }); /************************************************************************/ /******/ // 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; /******/ } /******/ /******/ // expose the modules object (__webpack_modules__) /******/ __webpack_require__.m = __webpack_modules__; /******/ /************************************************************************/ /******/ /* webpack/runtime/chunk loaded */ /******/ (() => { /******/ var deferred = []; /******/ __webpack_require__.O = (result, chunkIds, fn, priority) => { /******/ if(chunkIds) { /******/ priority = priority || 0; /******/ for(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1]; /******/ deferred[i] = [chunkIds, fn, priority]; /******/ return; /******/ } /******/ var notFulfilled = Infinity; /******/ for (var i = 0; i < deferred.length; i++) { /******/ var [chunkIds, fn, priority] = deferred[i]; /******/ var fulfilled = true; /******/ for (var j = 0; j < chunkIds.length; j++) { /******/ if ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every((key) => (__webpack_require__.O[key](chunkIds[j])))) { /******/ chunkIds.splice(j--, 1); /******/ } else { /******/ fulfilled = false; /******/ if(priority < notFulfilled) notFulfilled = priority; /******/ } /******/ } /******/ if(fulfilled) { /******/ deferred.splice(i--, 1) /******/ var r = fn(); /******/ if (r !== undefined) result = r; /******/ } /******/ } /******/ return result; /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/compat get default export */ /******/ (() => { /******/ // getDefaultExport function for compatibility with non-harmony modules /******/ __webpack_require__.n = (module) => { /******/ var getter = module && module.__esModule ? /******/ () => (module['default']) : /******/ () => (module); /******/ __webpack_require__.d(getter, { a: getter }); /******/ return getter; /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/define property getters */ /******/ (() => { /******/ // define getter functions for harmony exports /******/ __webpack_require__.d = (exports, definition) => { /******/ for(var key in definition) { /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); /******/ } /******/ } /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/hasOwnProperty shorthand */ /******/ (() => { /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) /******/ })(); /******/ /******/ /* webpack/runtime/jsonp chunk loading */ /******/ (() => { /******/ // no baseURI /******/ /******/ // object to store loaded and loading chunks /******/ // undefined = chunk not loaded, null = chunk preloaded/prefetched /******/ // [resolve, reject, Promise] = chunk loading, 0 = chunk loaded /******/ var installedChunks = { /******/ 112: 0, /******/ 886: 0 /******/ }; /******/ /******/ // no chunk on demand loading /******/ /******/ // no prefetching /******/ /******/ // no preloaded /******/ /******/ // no HMR /******/ /******/ // no HMR manifest /******/ /******/ __webpack_require__.O.j = (chunkId) => (installedChunks[chunkId] === 0); /******/ /******/ // install a JSONP callback for chunk loading /******/ var webpackJsonpCallback = (parentChunkLoadingFunction, data) => { /******/ var [chunkIds, moreModules, runtime] = data; /******/ // add "moreModules" to the modules object, /******/ // then flag all "chunkIds" as loaded and fire callback /******/ var moduleId, chunkId, i = 0; /******/ if(chunkIds.some((id) => (installedChunks[id] !== 0))) { /******/ for(moduleId in moreModules) { /******/ if(__webpack_require__.o(moreModules, moduleId)) { /******/ __webpack_require__.m[moduleId] = moreModules[moduleId]; /******/ } /******/ } /******/ if(runtime) var result = runtime(__webpack_require__); /******/ } /******/ if(parentChunkLoadingFunction) parentChunkLoadingFunction(data); /******/ for(;i < chunkIds.length; i++) { /******/ chunkId = chunkIds[i]; /******/ if(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) { /******/ installedChunks[chunkId][0](); /******/ } /******/ installedChunks[chunkId] = 0; /******/ } /******/ return __webpack_require__.O(result); /******/ } /******/ /******/ var chunkLoadingGlobal = self["webpackChunkramsey_plus_forms"] = self["webpackChunkramsey_plus_forms"] || []; /******/ chunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0)); /******/ chunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal)); /******/ })(); /******/ /******/ /* webpack/runtime/nonce */ /******/ (() => { /******/ __webpack_require__.nc = undefined; /******/ })(); /******/ /************************************************************************/ /******/ /******/ // startup /******/ // Load entry module and return exports /******/ // This entry module depends on other loaded chunks and execution need to be delayed /******/ var __webpack_exports__ = __webpack_require__.O(undefined, [279,749,428,266,950,468,780,886,377], () => (__webpack_require__(4506))) /******/ __webpack_exports__ = __webpack_require__.O(__webpack_exports__); /******/ /******/ })() ; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"webinar-page-cta.js","mappings":"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EACnC,WAAW,EAAE,eAAe,CAAC,IAAI,GACjC,IACD,CACJ,CAAC;AACJ,CAAC;AAED,oEAAe,cAAc,EAAC;;;;;;;;AC3JgB;AACb;AACa;AACc;AACc;AAE1E,MAAM,WAAW,GAAG,QAAQ,CAAC,cAAc,CAAC,uBAAuB,CAAC,CAAC;AACrE,MAAM,IAAI,GAAG,qBAAU,CAAC,WAAY,CAAC,CAAC;AAEtC,IAAI,CAAC,MAAM,CACT,oBAAC,+CAAmB,IAAC,MAAM,EAAE,0CAAiB,YAC5C,oBAAC,6BAAc,KAAG,GACE,CACvB,CAAC;;;;;;;;ACbW;;AAEb,IAAI,IAAqC;AACzC,EAAE,0CAAqD;AACvD,EAAE,KAAK;AAAA,EAEN;;;;;;;UCND;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;UAEA;UACA;;;;;WCzBA;WACA;WACA;WACA;WACA,+BAA+B,wCAAwC;WACvE;WACA;WACA;WACA;WACA,iBAAiB,qBAAqB;WACtC;WACA;WACA,kBAAkB,qBAAqB;WACvC;WACA;WACA,KAAK;WACL;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA,E;;;;;WC3BA;WACA;WACA;WACA;WACA;WACA,iCAAiC,WAAW;WAC5C;WACA,E;;;;;WCPA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA,E;;;;;WCPA,wF;;;;;WCAA;;WAEA;WACA;WACA;WACA;WACA;WACA;WACA;;WAEA;;WAEA;;WAEA;;WAEA;;WAEA;;WAEA;;WAEA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA,MAAM,qBAAqB;WAC3B;WACA;WACA;WACA;WACA;WACA;WACA;WACA;;WAEA;WACA;WACA,4G;;;;;WCjDA,mC;;;;;UEAA;UACA;UACA;UACA;UACA","sources":["webpack://ramsey-plus-forms/./src/rplus-forms/shared/stores/webinarAtoms.ts","webpack://ramsey-plus-forms/./src/rplus-forms/shared/components/Dialog.tsx","webpack://ramsey-plus-forms/./src/rplus-forms/modules/UpcomingWebinarList/WebinarDialog.tsx","webpack://ramsey-plus-forms/./src/rplus-forms/shared/utils/formatDate.ts","webpack://ramsey-plus-forms/./src/rplus-forms/shared/hooks/useWebinars.ts","webpack://ramsey-plus-forms/./src/rplus-forms/modules/WebinarPageCTA/WebinarPageCTA.tsx","webpack://ramsey-plus-forms/./src/rplus-forms/modules/WebinarPageCTA/index.tsx","webpack://ramsey-plus-forms/./node_modules/react/index.js","webpack://ramsey-plus-forms/webpack/bootstrap","webpack://ramsey-plus-forms/webpack/runtime/chunk loaded","webpack://ramsey-plus-forms/webpack/runtime/compat get default export","webpack://ramsey-plus-forms/webpack/runtime/define property getters","webpack://ramsey-plus-forms/webpack/runtime/hasOwnProperty shorthand","webpack://ramsey-plus-forms/webpack/runtime/jsonp chunk loading","webpack://ramsey-plus-forms/webpack/runtime/nonce","webpack://ramsey-plus-forms/webpack/before-startup","webpack://ramsey-plus-forms/webpack/startup","webpack://ramsey-plus-forms/webpack/after-startup"],"sourcesContent":["import { atom } from 'jotai';\nimport { atomFamily } from 'jotai/utils';\nimport type { Webinar } from '../types/webinarTypes';\nimport type { WebinarListDialogProps } from '../../modules/UpcomingWebinarList/types';\nimport { UpcomingWebinarsDialogPropsType } from '../../modules/UpcomingWebinars/types';\nimport { UpcomingFpuWebinarsDialogPropsType } from '../../modules/UpcomingFpuWebinars/types';\nimport type { WebinarCTADialogProps } from '../../modules/WebinarPageCTA/types';\nimport type { WebinarDialogProps } from '../../modules/WebinarLeadForm/types';\n\nexport const webinarsAtom = atom<Webinar[]>([]);\nexport const webinarsLoadingAtom = atom<boolean>(false);\nexport const webinarsErrorAtom = atom<Error | null>(null);\n\nexport const webinarListDialogPropsAtom = atom<\n  WebinarListDialogProps | undefined\n>(window._WEBINAR_LIST_REQUEST || undefined);\n\nexport const upcomingWebinarsDialogPropsAtom = atom<\n  UpcomingWebinarsDialogPropsType[]\n>(\n  Array.isArray(window._UPCOMING_WEBINARS_REQUEST)\n    ? window._UPCOMING_WEBINARS_REQUEST\n    : []\n);\n\nexport const upcomingFpuWebinarsDialogPropsAtom = atom<\n  UpcomingFpuWebinarsDialogPropsType[]\n>(\n  Array.isArray(window._UPCOMING_WEBINARS_REQUEST)\n    ? window._UPCOMING_WEBINARS_REQUEST\n    : []\n);\n\nexport const webinarCTADialogPropsAtom = atom<\n  WebinarCTADialogProps | undefined\n>(window._WEBINAR_PAGE_CTA_REQUEST || undefined);\n\nexport const webinarLeadFormDialogPropsAtom = atom<\n  WebinarDialogProps | undefined\n>(window._WEBINAR_LEAD_FORM_REQUEST || undefined);\n\nfunction findUpcomingWebinarByTopic(\n  webinars: UpcomingWebinarsDialogPropsType[],\n  filterTopic: string | undefined\n): UpcomingWebinarsDialogPropsType | undefined {\n  return webinars.find((w) => w.filterTopic === filterTopic);\n}\n\nexport const combinedFormPropsAtom = atomFamily((filterTopic?: string) =>\n  atom((get) => {\n    const listProps = get(webinarListDialogPropsAtom);\n    const ctaProps = get(webinarCTADialogPropsAtom);\n    const leadFormProps = get(webinarLeadFormDialogPropsAtom);\n    const upcomingWebinarsProps = findUpcomingWebinarByTopic(\n      get(upcomingWebinarsDialogPropsAtom),\n      filterTopic\n    );\n\n    return {\n      showPhoneNumber:\n        leadFormProps?.showPhoneNumber ??\n        ctaProps?.showPhoneNumber ??\n        listProps?.showPhoneNumber ??\n        upcomingWebinarsProps?.showPhoneNumber ??\n        false,\n      requirePhoneNumber:\n        leadFormProps?.requirePhoneNumber ??\n        ctaProps?.requirePhoneNumber ??\n        listProps?.requirePhoneNumber ??\n        upcomingWebinarsProps?.requirePhoneNumber ??\n        false,\n      showEmailOptIn:\n        leadFormProps?.showEmailOptIn ??\n        ctaProps?.showEmailOptIn ??\n        listProps?.showEmailOptIn ??\n        upcomingWebinarsProps?.showEmailOptIn ??\n        false,\n      showSmsOptIn:\n        leadFormProps?.showSmsOptIn ??\n        ctaProps?.showSmsOptIn ??\n        listProps?.showSmsOptIn ??\n        upcomingWebinarsProps?.showSmsOptIn ??\n        false,\n      buttonQuantity: ctaProps?.buttonQuantity ?? 2,\n      buttonAppearance: ctaProps?.buttonAppearance ?? 'primary',\n      onDarkCanvas: ctaProps?.onDarkCanvas ?? false,\n      showRecording:\n        ctaProps?.showRecording ?? listProps?.showRecording ?? false,\n      filterOptions: ctaProps?.filterOptions ?? ''\n    };\n  })\n);\n","import { HTMLAttributes, MutableRefObject } from 'react';\nimport RDSDialog from '@ramsey-design-system/dialog';\n\nconst DIALOG_PADDING = ['sm', 'md', 'lg', 'none'] as const;\ntype Padding = (typeof DIALOG_PADDING)[number];\n\nconst DIALOG_WIDTH = ['sm', 'md', 'lg'] as const;\ntype Width = (typeof DIALOG_WIDTH)[number];\n\ntype DialogProps = HTMLAttributes<HTMLDivElement> & {\n  children: React.ReactNode;\n  onClose: () => void;\n  open?: boolean;\n  padding?: Padding;\n  portalMount?: HTMLElement;\n  triggerRef?: MutableRefObject<any>;\n  width?: Width;\n};\n\n/**\n *\n * RDS Dialog component requires a triggerRef prop to be passed in.\n * This is a wrapper to make the triggerRef optiobal.\n */\nfunction Dialog({\n  children,\n  className,\n  onClose,\n  open = false,\n  padding = 'md',\n  portalMount,\n  triggerRef,\n  width = 'md'\n}: DialogProps) {\n  if (!open) {\n    return null; // Do not render anything if `open` is false\n  }\n\n  return (\n    <RDSDialog\n      data-testid=\"rds-dialog\"\n      onClose={onClose}\n      open={open}\n      padding={padding}\n      portalMount={portalMount}\n      width={width}\n      triggerRef={triggerRef || (null as unknown as React.RefObject<any>)}\n      className={`[&_.rds-Dialog-overlay]:bg-white [&_.rds-Dialog-overlay]:bg-opacity-30 [&_.rds-Dialog-overlay]:backdrop-blur-[8px] ${\n        className ?? ''\n      }`}\n    >\n      {children}\n    </RDSDialog>\n  );\n}\n\nDialog.Title = RDSDialog.Title;\nDialog.Description = RDSDialog.Description;\n\nexport default Dialog;\n","// RDS\nimport Heading from '@ramsey-design-system/heading';\n\n// Components\nimport Dialog from '../../shared/components/Dialog';\nimport WebinarLeadForm from '../WebinarLeadForm/WebinarLeadForm';\n\ninterface WebinarDialogProps {\n  readonly isOpen: boolean;\n  readonly webinarId: string | null | undefined;\n  readonly webinarTopic: string | null | undefined;\n  readonly webinarName?: string | null;\n  readonly webinarTime: string | null | undefined;\n  readonly onClose: () => void;\n}\n\nexport default function WebinarDialog({\n  onClose,\n  isOpen,\n  webinarId,\n  webinarName,\n  webinarTopic,\n  webinarTime\n}: WebinarDialogProps) {\n  const handleClose = () => {\n    onClose();\n  };\n\n  const isRecording = !webinarId;\n\n  const dialogTitle = webinarName ?? webinarTopic;\n\n  return (\n    <Dialog\n      open={isOpen}\n      onClose={handleClose}\n      width=\"md\"\n      className=\"[&_.rds-Dialog-content]:max-w-[600px] [&_.rds-Dialog-content]:p-3 [&_.rds-Dialog-content]:md:p-5\"\n    >\n      <div data-testid=\"webinar-dialog\" className=\"flex flex-col items-center\">\n        <Heading\n          level=\"2\"\n          size=\"medium\"\n          className=\"text-blue-80 text-center !mb-2\"\n          data-testid=\"dialog-title\"\n        >\n          {dialogTitle}\n          {isRecording ? (\n            <>\n              <br />\n              <span>Recording</span>\n            </>\n          ) : null}\n          <br />\n          {webinarTime}\n        </Heading>\n        <WebinarLeadForm webinarId={webinarId} webinarTopic={webinarTopic} />\n      </div>\n    </Dialog>\n  );\n}\n","import { format, toZonedTime } from 'date-fns-tz';\n\nconst formatDate = (dateString: string, timeZone: string) => {\n  try {\n    const date = new Date(dateString);\n    const zonedDate = toZonedTime(date, timeZone);\n\n    const formatDate = format(zonedDate, 'MMM d, h aa z', { timeZone });\n\n    // Manually remove D from CDT\n    const formattedDate = formatDate.replace(/\\bC[DS]T\\b/, 'CT');\n\n    return formattedDate;\n  } catch (error) {\n    console.error('Error formatting date:', error);\n    return 'Invalid Date';\n  }\n};\n\nconst formatShortDate = (dateString: string) => {\n  try {\n    const date = new Date(dateString);\n\n    return format(date, 'MMM d');\n  } catch (error) {\n    console.error('Error formatting date:', error);\n    return 'Invalid Date';\n  }\n};\n\nexport { formatDate, formatShortDate };\n","import { useQuery } from '@tanstack/react-query';\nimport { useSetAtom } from 'jotai';\nimport { useEffect } from 'react';\nimport { applicationConfig } from '../../shared/application';\nimport { PATHS } from '../../shared/utils/constants';\nimport {\n  webinarsAtom,\n  webinarsLoadingAtom,\n  webinarsErrorAtom\n} from '../../shared/stores/webinarAtoms';\nimport type { Webinar } from '../../shared/types/webinarTypes';\n\nexport default function useWebinars() {\n  const setWebinars = useSetAtom(webinarsAtom);\n  const setLoading = useSetAtom(webinarsLoadingAtom);\n  const setError = useSetAtom(webinarsErrorAtom);\n\n  const upcomingWebinars = useQuery({\n    queryKey: ['webinars'],\n    queryFn: async (): Promise<Webinar[]> => {\n      const response = await fetch(\n        `${applicationConfig.magnoliaFormsWebUrl}${PATHS.API.UPCOMING_WEBINARS}`,\n        {\n          method: 'GET',\n          headers: {\n            'Content-Type': 'application/json'\n          }\n        }\n      );\n\n      if (!response.ok) {\n        throw new Error('Failed to fetch webinars');\n      }\n\n      return response.json();\n    },\n    staleTime: 5 * 60 * 1000, // 5 minutes\n    gcTime: 10 * 60 * 1000 // 10 minutes\n  });\n\n  useEffect(() => {\n    setWebinars(upcomingWebinars.data || []);\n    setLoading(upcomingWebinars.isLoading);\n    setError(upcomingWebinars.error);\n  }, [\n    upcomingWebinars.data,\n    upcomingWebinars.isLoading,\n    upcomingWebinars.error,\n    setWebinars,\n    setLoading,\n    setError\n  ]);\n\n  return upcomingWebinars;\n}\n","import { useState, useEffect } from 'react';\nimport { useAtom, useAtomValue } from 'jotai';\n\n// Components\nimport Button from '@ramsey-design-system/button';\nimport WebinarDialog from '../UpcomingWebinarList/WebinarDialog';\n\n// Utils\nimport { formatDate } from '../../shared/utils/formatDate';\nimport classNames from 'classnames';\n\n// Hooks\nimport useWebinars from '../../shared/hooks/useWebinars';\n\n// Atoms\nimport {\n  webinarsAtom,\n  webinarsLoadingAtom,\n  webinarsErrorAtom,\n  webinarCTADialogPropsAtom\n} from '../../shared/stores/webinarAtoms';\n\nfunction WebinarPageCTA() {\n  const { refetch } = useWebinars();\n\n  const webinars = useAtomValue(webinarsAtom);\n  const loading = useAtomValue(webinarsLoadingAtom);\n  const error = useAtomValue(webinarsErrorAtom);\n\n  const [ctaDialogProps, setCTADialogProps] = useAtom(\n    webinarCTADialogPropsAtom\n  );\n\n  const webinarTitle =\n    ctaDialogProps?.webinarName || ctaDialogProps?.filterOptions;\n  const buttonQuantity = ctaDialogProps?.buttonQuantity ?? 2;\n  const buttonAppearance = ctaDialogProps?.buttonAppearance ?? 'primary';\n  const onDarkCanvas = ctaDialogProps?.onDarkCanvas ?? false;\n  const buttonText = ctaDialogProps?.buttonText ?? 'Watch Recording';\n  const showRecording = ctaDialogProps?.showRecording ?? false;\n  const filterTopic = ctaDialogProps?.filterOptions ?? null;\n\n  const [dialogOpen, setDialogOpen] = useState<boolean>(false);\n  const [selectedWebinar, setSelectedWebinar] = useState<{\n    id: string;\n    name: string | undefined | null;\n    topic: string | null;\n    time: string | null;\n  }>({ id: '', name: null, topic: null, time: null });\n\n  const filteredWebinars = filterTopic\n    ? webinars.filter(\n        (webinar) => webinar.topic.toLowerCase() === filterTopic.toLowerCase()\n      )\n    : webinars;\n\n  const openDialog = (\n    id: string,\n    name: string | undefined | null,\n    topic: string | null,\n    time: string | null\n  ) => {\n    setSelectedWebinar({ id: id || '', name, topic, time });\n    setDialogOpen(true);\n  };\n\n  const closeDialog = () => {\n    setDialogOpen(false);\n  };\n\n  useEffect(() => {\n    const hasNoAtomWebinars = !webinars || webinars.length === 0;\n\n    if (hasNoAtomWebinars && !loading && !error) {\n      console.log('Triggering automatic refetch...');\n      refetch();\n    }\n  }, [webinars, loading, error]);\n\n  useEffect(() => {\n    if (window._WEBINAR_PAGE_CTA_REQUEST && !ctaDialogProps) {\n      setCTADialogProps(window._WEBINAR_PAGE_CTA_REQUEST);\n    }\n  }, [ctaDialogProps, setCTADialogProps]);\n\n  if (loading) {\n    return <div>Loading...</div>;\n  }\n\n  if (error) {\n    return <div className=\"mb-4 text-center text-red-500\">{error.message}</div>;\n  }\n\n  return (\n    <>\n      <div\n        data-testid=\"webinar-button-grid\"\n        className={`mx-auto grid gap-1 max-w-[12.5rem] grid-cols-1 ${classNames(buttonQuantity > 3 ? 'md:grid-cols-3 sm:max-w-xl' : 'md:grid-cols-2 sm:max-w-md')}`}\n      >\n        {filteredWebinars.length > 0 ? (\n          filteredWebinars.slice(0, buttonQuantity).map((webinar) => {\n            const formattedDate = webinar.start_time\n              ? formatDate(webinar.start_time, 'America/Chicago')\n              : 'Invalid Date';\n\n            return (\n              <Button\n                key={webinar.id}\n                isOnDarkCanvas={onDarkCanvas}\n                size=\"large\"\n                appearance={buttonAppearance}\n                onClick={() => {\n                  openDialog(\n                    webinar.id,\n                    webinarTitle,\n                    webinar.topic,\n                    formattedDate\n                  );\n                }}\n                disabled={formattedDate === 'Invalid Date'}\n              >\n                {formattedDate}\n              </Button>\n            );\n          })\n        ) : (\n          <Button size=\"large\" disabled>\n            Coming Soon\n          </Button>\n        )}\n        {showRecording && (\n          <Button\n            size=\"large\"\n            className={`whitespace-nowrap md:whitespace-break-spaces lg:whitespace-nowrap`}\n            isOnDarkCanvas={onDarkCanvas}\n            onClick={() => {\n              openDialog('', webinarTitle, filterTopic, '');\n            }}\n          >\n            {buttonText || 'Watch Recording'}\n          </Button>\n        )}\n      </div>\n      <WebinarDialog\n        isOpen={dialogOpen}\n        onClose={closeDialog}\n        webinarId={selectedWebinar.id}\n        webinarName={webinarTitle}\n        webinarTopic={selectedWebinar.topic}\n        webinarTime={selectedWebinar.time}\n      />\n    </>\n  );\n}\n\nexport default WebinarPageCTA;\n","import { createRoot } from 'react-dom/client';\nimport '../../../css/global.css';\nimport WebinarPageCTA from './WebinarPageCTA';\nimport { QueryClientProvider } from '@tanstack/react-query';\nimport { sharedQueryClient } from '../../shared/config/sharedQueryClient';\n\nconst rootElement = document.getElementById('webinar-page-cta-root');\nconst root = createRoot(rootElement!);\n\nroot.render(\n  <QueryClientProvider client={sharedQueryClient}>\n    <WebinarPageCTA />\n  </QueryClientProvider>\n);\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n  module.exports = require('./cjs/react.production.js');\n} else {\n  module.exports = require('./cjs/react.development.js');\n}\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// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","var deferred = [];\n__webpack_require__.O = (result, chunkIds, fn, priority) => {\n\tif(chunkIds) {\n\t\tpriority = priority || 0;\n\t\tfor(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];\n\t\tdeferred[i] = [chunkIds, fn, priority];\n\t\treturn;\n\t}\n\tvar notFulfilled = Infinity;\n\tfor (var i = 0; i < deferred.length; i++) {\n\t\tvar [chunkIds, fn, priority] = deferred[i];\n\t\tvar fulfilled = true;\n\t\tfor (var j = 0; j < chunkIds.length; j++) {\n\t\t\tif ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every((key) => (__webpack_require__.O[key](chunkIds[j])))) {\n\t\t\t\tchunkIds.splice(j--, 1);\n\t\t\t} else {\n\t\t\t\tfulfilled = false;\n\t\t\t\tif(priority < notFulfilled) notFulfilled = priority;\n\t\t\t}\n\t\t}\n\t\tif(fulfilled) {\n\t\t\tdeferred.splice(i--, 1)\n\t\t\tvar r = fn();\n\t\t\tif (r !== undefined) result = r;\n\t\t}\n\t}\n\treturn result;\n};","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t112: 0,\n\t886: 0\n};\n\n// no chunk on demand loading\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n__webpack_require__.O.j = (chunkId) => (installedChunks[chunkId] === 0);\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = (parentChunkLoadingFunction, data) => {\n\tvar [chunkIds, moreModules, runtime] = data;\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some((id) => (installedChunks[id] !== 0))) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\treturn __webpack_require__.O(result);\n}\n\nvar chunkLoadingGlobal = self[\"webpackChunkramsey_plus_forms\"] = self[\"webpackChunkramsey_plus_forms\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","__webpack_require__.nc = undefined;","","// startup\n// Load entry module and return exports\n// This entry module depends on other loaded chunks and execution need to be delayed\nvar __webpack_exports__ = __webpack_require__.O(undefined, [279,749,428,266,950,468,780,886,377], () => (__webpack_require__(4506)))\n__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n",""],"names":[],"ignoreList":[],"sourceRoot":""}