@seamly/web-ui 23.0.0-alpha.2 → 23.0.0-alpha.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/dist/lib/components.js +58 -75
- package/build/dist/lib/components.js.map +1 -1
- package/build/dist/lib/components.min.js +1 -1
- package/build/dist/lib/components.min.js.map +1 -1
- package/build/dist/lib/hooks.js +55 -72
- package/build/dist/lib/hooks.js.map +1 -1
- package/build/dist/lib/hooks.min.js +1 -1
- package/build/dist/lib/hooks.min.js.map +1 -1
- package/build/dist/lib/index.debug.js +8 -8
- package/build/dist/lib/index.debug.min.js +1 -1
- package/build/dist/lib/index.debug.min.js.map +1 -1
- package/build/dist/lib/index.js +42 -63
- package/build/dist/lib/index.js.map +1 -1
- package/build/dist/lib/index.min.js +1 -1
- package/build/dist/lib/index.min.js.map +1 -1
- package/build/dist/lib/standalone.js +52 -74
- package/build/dist/lib/standalone.js.map +1 -1
- package/build/dist/lib/standalone.min.js +1 -1
- package/build/dist/lib/standalone.min.js.map +1 -1
- package/build/dist/lib/style-guide.js +51 -68
- package/build/dist/lib/style-guide.js.map +1 -1
- package/build/dist/lib/style-guide.min.js +1 -1
- package/build/dist/lib/style-guide.min.js.map +1 -1
- package/build/dist/lib/utils.js +63 -99
- package/build/dist/lib/utils.js.map +1 -1
- package/build/dist/lib/utils.min.js +1 -1
- package/build/dist/lib/utils.min.js.map +1 -1
- package/package.json +1 -1
- package/src/javascripts/api/index.ts +2 -18
- package/src/javascripts/domains/config/actions.ts +3 -0
- package/src/javascripts/domains/config/slice.ts +3 -0
- package/src/javascripts/domains/i18n/slice.ts +1 -1
- package/src/javascripts/domains/translations/components/options-dialog/translation-options.tsx +1 -1
- package/src/javascripts/domains/translations/hooks.ts +1 -1
- package/src/javascripts/domains/translations/middleware.ts +4 -10
- package/src/javascripts/domains/translations/slice.ts +2 -2
- package/src/javascripts/style-guide/states.js +4 -0
- package/src/javascripts/style-guide/style-guide-engine.js +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"components.min.js","mappings":"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","sources":["webpack:///./node_modules/phoenix/priv/static/phoenix.mjs","webpack:///./src/javascripts/api/conversation-connector.ts","webpack:///./src/javascripts/config.ts","webpack:///./src/javascripts/domains/app/actions.ts","webpack:///./src/javascripts/domains/redux/create-debounced-async-thunk.ts","webpack:///./src/javascripts/domains/app/selectors.ts","webpack:///./src/javascripts/domains/app/slice.ts","webpack:///./src/javascripts/domains/config/actions.ts","webpack:///./src/javascripts/domains/config/hooks.ts","webpack:///./src/javascripts/domains/config/selectors.ts","webpack:///./src/javascripts/domains/config/slice.ts","webpack:///./src/javascripts/domains/errors/index.ts","webpack:///./src/javascripts/domains/forms/slice.ts","webpack:///./src/javascripts/domains/i18n/actions.ts","webpack:///./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js","webpack:///./node_modules/@babel/runtime/helpers/esm/typeof.js","webpack:///./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","webpack:///./node_modules/@babel/runtime/helpers/esm/toPrimitive.js","webpack:///./node_modules/@babel/runtime/helpers/esm/createClass.js","webpack:///./node_modules/@babel/runtime/helpers/esm/defineProperty.js","webpack:///./node_modules/@ultraq/array-utils/array-utils.es.js","webpack:///./node_modules/@ultraq/icu-message-formatter/lib/icu-message-formatter.es.js","webpack:///./node_modules/@ultraq/function-utils/function-utils.es.js","webpack:///./node_modules/@babel/runtime/helpers/esm/classCallCheck.js","webpack:///./node_modules/@babel/runtime/helpers/esm/slicedToArray.js","webpack:///./node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js","webpack:///./node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js","webpack:///./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js","webpack:///./node_modules/@babel/runtime/helpers/esm/nonIterableRest.js","webpack:///./src/javascripts/domains/i18n/hooks.ts","webpack:///./src/javascripts/domains/i18n/selectors.ts","webpack:///./src/javascripts/domains/interrupt/hooks.ts","webpack:///./src/javascripts/domains/interrupt/selectors.ts","webpack:///./src/javascripts/domains/interrupt/slice.ts","webpack:///./src/javascripts/domains/store/actions.ts","webpack:///./src/javascripts/domains/i18n/slice.ts","webpack:///./src/javascripts/domains/store/index.ts","webpack:///./src/javascripts/domains/store/slice.ts","webpack:///./src/javascripts/domains/translations/selectors.ts","webpack:///./src/javascripts/domains/translations/hooks.ts","webpack:///./src/javascripts/domains/translations/slice.ts","webpack:///./src/javascripts/domains/visibility/actions.ts","webpack:///./src/javascripts/domains/visibility/constants.ts","webpack:///./src/javascripts/domains/visibility/hooks.ts","webpack:///./src/javascripts/domains/visibility/selectors.ts","webpack:///./src/javascripts/domains/visibility/slice.ts","webpack:///./src/javascripts/ui/components/core/seamly-api-context.ts","webpack:///./src/javascripts/ui/hooks/seamly-api-hooks.ts","webpack:///./src/javascripts/ui/hooks/seamly-state-hooks.ts","webpack:///./src/javascripts/ui/utils/seamly-utils.ts","webpack:///./src/javascripts/api/errors/seamly-base-error.js","webpack:///./src/javascripts/api/errors/seamly-configuration-error.js","webpack:///./src/javascripts/api/errors/seamly-general-error.js","webpack:///./src/javascripts/api/errors/seamly-offline-error.js","webpack:///./src/javascripts/api/errors/seamly-session-expired-error.js","webpack:///./src/javascripts/api/errors/seamly-unauthorized-error.js","webpack:///./src/javascripts/api/errors/seamly-unavailable-error.js","webpack:///./src/javascripts/domains/app/hooks.js","webpack:///./src/javascripts/domains/visibility/utils.js","webpack:///./src/javascripts/lib/css.js","webpack:///./src/javascripts/lib/debug.js","webpack:///./src/javascripts/lib/id.js","webpack:///./src/javascripts/ui/components/conversation/event/choice-prompt.js","webpack:///./src/javascripts/ui/components/conversation/event/event-participant.js","webpack:///./src/javascripts/ui/components/conversation/message-container.js","webpack:///./src/javascripts/ui/components/core/seamly-activity-event-context.js","webpack:///./src/javascripts/ui/components/core/seamly-file-upload-context.js","webpack:///./src/javascripts/ui/components/core/seamly-live-region-context.js","webpack:///./src/javascripts/ui/hooks/component-helper-hooks.js","webpack:///./src/javascripts/ui/hooks/focus-helper-hooks.js","webpack:///./src/javascripts/ui/hooks/live-region-hooks.js","webpack:///./src/javascripts/ui/hooks/file-upload-hooks.js","webpack:///./src/javascripts/ui/hooks/seamly-option-hooks.js","webpack:///./src/javascripts/ui/hooks/use-seamly-activity-event-handler.js","webpack:///./src/javascripts/ui/hooks/use-seamly-commands.js","webpack:///./src/javascripts/ui/hooks/use-seamly-idle-detach-countdown.js","webpack:///./src/javascripts/ui/hooks/use-seamly-resume-conversation-prompt.js","webpack:///./src/javascripts/ui/hooks/utility-hooks.js","webpack:///./src/javascripts/ui/utils/general-utils.js","webpack:///./node_modules/preact/compat/dist/compat.module.js","webpack:///./src/javascripts/ui/components/layout/icon.tsx","webpack:///./src/icons/icon_send-32.svg","webpack:///./src/icons/icon_balloon-32.svg","webpack:///./src/icons/icon_newtopic-32.svg","webpack:///./src/icons/icon_newtranslation-16.svg","webpack:///./src/icons/icon_newtranslation-32.svg","webpack:///./src/icons/avatar_bot-32.svg","webpack:///./src/icons/icon_chevron_down-8.svg","webpack:///./src/icons/icon_chevron_down-32.svg","webpack:///./src/icons/icon_chevron_right-8.svg","webpack:///./src/icons/icon_chevron_right-16.svg","webpack:///./src/icons/icon_close-8.svg","webpack:///./src/icons/icon_close-16.svg","webpack:///./src/icons/icon_enlarge-32.svg","webpack:///./src/icons/icon_options-32.svg","webpack:///./src/icons/icon_file-32.svg","webpack:///./src/icons/icon_upload-32.svg","webpack:///./src/icons/icon_download-16.svg","webpack:///./src/icons/icon_error-16.svg","webpack:///./src/icons/icon_arrow_left-16.svg","webpack:///./src/icons/icon_arrow_right-16.svg","webpack:///./src/icons/icon_check-16.svg","webpack:///./src/icons/icon_check-32.svg","webpack:///./node_modules/use-sync-external-store/cjs/use-sync-external-store-with-selector.production.min.js","webpack:///./node_modules/use-sync-external-store/with-selector.js","webpack:///external commonjs2 \"preact\"","webpack:///external commonjs2 \"preact/compat\"","webpack:///external commonjs2 \"preact/hooks\"","webpack:///external commonjs2 \"preact/jsx-runtime\"","webpack:///./node_modules/immer/dist/immer.mjs","webpack:///./node_modules/@reduxjs/toolkit/dist/redux-toolkit.modern.mjs","webpack:///./node_modules/react-redux/dist/react-redux.mjs","webpack:///./node_modules/redux/dist/redux.mjs","webpack:///./node_modules/reselect/dist/reselect.mjs","webpack:///webpack/bootstrap","webpack:///webpack/runtime/compat get default export","webpack:///webpack/runtime/define property getters","webpack:///webpack/runtime/global","webpack:///webpack/runtime/hasOwnProperty shorthand","webpack:///webpack/runtime/make namespace object","webpack:///webpack/runtime/publicPath","webpack:///./src/javascripts/ui/components/layout/privacy-disclaimer.js","webpack:///./src/javascripts/domains/forms/selectors.ts","webpack:///./src/javascripts/domains/forms/context.ts","webpack:///./src/javascripts/domains/forms/hooks.ts","webpack:///./src/javascripts/ui/components/entry/text-entry/hooks.ts","webpack:///./src/javascripts/ui/components/entry/abort-transaction-button/abort-transaction-button.tsx","webpack:///./src/javascripts/ui/components/conversation/component-context.js","webpack:///./src/javascripts/ui/components/conversation/event/card-component.tsx","webpack:///./src/javascripts/ui/components/conversation/event/carousel-message/components/slide.js","webpack:///./src/javascripts/ui/components/conversation/event/carousel-component/components/controls.js","webpack:///./src/javascripts/ui/components/conversation/event/carousel-component/components/pagination.js","webpack:///./src/javascripts/ui/components/conversation/event/carousel-component/index.js","webpack:///./src/javascripts/ui/components/conversation/event/carousel-message/index.js","webpack:///./src/javascripts/ui/components/suggestions/suggestions-item.js","webpack:///./src/javascripts/ui/components/suggestions/suggestions-list.js","webpack:///./src/javascripts/ui/components/conversation/event/hooks/use-event-link-click-handler.js","webpack:///./src/javascripts/ui/components/conversation/event-divider.js","webpack:///./src/javascripts/ui/components/conversation/event/divider/variants/default.js","webpack:///./src/javascripts/ui/components/conversation/event/divider/variants/new-translation.js","webpack:///./src/javascripts/ui/components/conversation/event/divider/index.js","webpack:///./src/javascripts/ui/components/conversation/event/hooks/use-formatted-date.js","webpack:///./src/javascripts/ui/components/conversation/event/divider/variants/time-indicator.js","webpack:///./node_modules/tabbable/dist/index.esm.js","webpack:///./node_modules/focus-trap/dist/focus-trap.esm.js","webpack:///./src/javascripts/ui/components/widgets/modal.js","webpack:///./src/javascripts/ui/components/widgets/lightbox.js","webpack:///./src/javascripts/ui/components/conversation/event/image-lightbox.js","webpack:///./src/javascripts/ui/components/conversation/event/text.js","webpack:///./src/javascripts/ui/components/conversation/event/upload.js","webpack:///./src/javascripts/ui/components/conversation/component-filter.js","webpack:///./src/javascripts/ui/components/conversation/event/image.js","webpack:///./src/javascripts/ui/components/conversation/event/splash.js","webpack:///./src/javascripts/ui/components/conversation/event/video.js","webpack:///./src/javascripts/ui/components/conversation/event/cta.js","webpack:///./src/javascripts/ui/components/conversation/event/card-message.js","webpack:///./src/javascripts/ui/components/conversation/event/translation.js","webpack:///./src/javascripts/ui/components/conversation/event/participant.js","webpack:///./src/javascripts/ui/components/conversation/event/conversation-suggestions.js","webpack:///./src/javascripts/ui/components/conversation/event/chat-scroll/chat-scroll-context.ts","webpack:///./src/javascripts/ui/hooks/use-event-component-mapping.js","webpack:///./src/javascripts/ui/components/conversation/event/event.tsx","webpack:///./src/javascripts/ui/components/conversation/loader.js","webpack:///./src/javascripts/ui/components/conversation/conversation.tsx","webpack:///./src/javascripts/ui/hooks/use-debounce.ts","webpack:///./src/javascripts/ui/components/warnings/prompt.js","webpack:///./src/javascripts/ui/components/warnings/idle-detach-warning.js","webpack:///./src/javascripts/ui/components/warnings/resume-conversation-prompt.js","webpack:///./src/javascripts/ui/hooks/seamly-entry-hooks.js","webpack:///./src/javascripts/domains/forms/provider.tsx","webpack:///./src/javascripts/domains/forms/utils.ts","webpack:///./src/javascripts/ui/components/form-controls/form.js","webpack:///./src/javascripts/ui/components/form-controls/error.js","webpack:///./src/javascripts/ui/components/form-controls/wrapper.tsx","webpack:///./src/javascripts/ui/components/form-controls/input.tsx","webpack:///./src/javascripts/ui/components/entry/text-entry/text-entry-form.tsx","webpack:///./src/javascripts/ui/components/entry/text-entry/index.js","webpack:///./src/javascripts/ui/components/widgets/upload-progress.js","webpack:///./src/javascripts/ui/utils/form-utils.js","webpack:///./src/javascripts/ui/utils/validations.js","webpack:///./src/javascripts/ui/components/form-controls/file-input.js","webpack:///./src/javascripts/ui/components/entry/upload/file-upload-form.js","webpack:///./src/javascripts/ui/components/entry/upload/index.js","webpack:///./src/javascripts/ui/hooks/use-single-file-upload.js","webpack:///./src/javascripts/ui/hooks/use-timeout.ts","webpack:///./src/javascripts/ui/components/widgets/in-out-transition.tsx","webpack:///./src/javascripts/ui/components/entry/upload-toggle.js","webpack:///./src/javascripts/ui/components/entry/entry-container.js","webpack:///./src/javascripts/ui/components/layout/agent-info.js","webpack:///./src/javascripts/ui/components/suggestions/index.js","webpack:///./src/javascripts/ui/components/layout/chat.js","webpack:///./src/javascripts/ui/components/chat-status/index.tsx","webpack:///./src/javascripts/ui/components/chat-status/chat-status-action.tsx","webpack:///./src/javascripts/ui/components/translation-proposal/index.tsx","webpack:///./src/javascripts/domains/translations/components/translation-status.tsx","webpack:///./src/javascripts/domains/translations/components/options-dialog/translation-option.tsx","webpack:///./src/javascripts/domains/translations/components/options-dialog/translation-options.tsx","webpack:///./src/javascripts/ui/components/options/options-frame.tsx","webpack:///./src/javascripts/ui/hooks/use-click-outside.ts","webpack:///./src/javascripts/domains/translations/components/options-dialog/index.tsx","webpack:///./src/javascripts/domains/translations/components/options-button.tsx","webpack:///./src/javascripts/ui/components/options/transcript/transcript-form.js","webpack:///./src/javascripts/ui/components/options/transcript/index.js","webpack:///./src/javascripts/ui/components/options/options.js","webpack:///./src/javascripts/ui/components/options/options-button.js","webpack:///./src/javascripts/ui/components/app-options/index.js","webpack:///./src/javascripts/ui/components/conversation/event/chat-scroll/unread-messages-button.tsx","webpack:///./src/javascripts/domains/store/selectors.ts","webpack:///./src/javascripts/ui/components/conversation/use-chat-scroll.ts","webpack:///./src/javascripts/ui/components/conversation/event/chat-scroll/chat-scroll-provider.tsx","webpack:///./src/javascripts/ui/components/view/window-view/collapse-button.js","webpack:///./src/javascripts/ui/components/layout/interrupt.js","webpack:///./src/javascripts/ui/components/layout/chat-frame.js","webpack:///./src/javascripts/ui/components/layout/header.js","webpack:///./src/javascripts/ui/components/layout/collapsed-chat-messages.tsx","webpack:///./src/javascripts/ui/components/layout/pre-chat-messages.tsx","webpack:///./src/javascripts/ui/components/layout/continue-chat-messages.tsx","webpack:///./src/javascripts/ui/components/view/window-view/window-open-button.js","webpack:///./src/javascripts/ui/components/view/window-view/index.tsx","webpack:///./src/javascripts/ui/hooks/sounds/beep.mp3","webpack:///./src/javascripts/ui/hooks/use-notifications.ts","webpack:///./src/javascripts/ui/components/view/index.tsx","webpack:///./src/javascripts/ui/components/view/app-view.js","webpack:///./src/javascripts/ui/components/view/inline-view.js"],"sourcesContent":["// js/phoenix/utils.js\nvar closure = (value) => {\n if (typeof value === \"function\") {\n return value;\n } else {\n let closure2 = function() {\n return value;\n };\n return closure2;\n }\n};\n\n// js/phoenix/constants.js\nvar globalSelf = typeof self !== \"undefined\" ? self : null;\nvar phxWindow = typeof window !== \"undefined\" ? window : null;\nvar global = globalSelf || phxWindow || global;\nvar DEFAULT_VSN = \"2.0.0\";\nvar SOCKET_STATES = { connecting: 0, open: 1, closing: 2, closed: 3 };\nvar DEFAULT_TIMEOUT = 1e4;\nvar WS_CLOSE_NORMAL = 1e3;\nvar CHANNEL_STATES = {\n closed: \"closed\",\n errored: \"errored\",\n joined: \"joined\",\n joining: \"joining\",\n leaving: \"leaving\"\n};\nvar CHANNEL_EVENTS = {\n close: \"phx_close\",\n error: \"phx_error\",\n join: \"phx_join\",\n reply: \"phx_reply\",\n leave: \"phx_leave\"\n};\nvar TRANSPORTS = {\n longpoll: \"longpoll\",\n websocket: \"websocket\"\n};\nvar XHR_STATES = {\n complete: 4\n};\n\n// js/phoenix/push.js\nvar Push = class {\n constructor(channel, event, payload, timeout) {\n this.channel = channel;\n this.event = event;\n this.payload = payload || function() {\n return {};\n };\n this.receivedResp = null;\n this.timeout = timeout;\n this.timeoutTimer = null;\n this.recHooks = [];\n this.sent = false;\n }\n /**\n *\n * @param {number} timeout\n */\n resend(timeout) {\n this.timeout = timeout;\n this.reset();\n this.send();\n }\n /**\n *\n */\n send() {\n if (this.hasReceived(\"timeout\")) {\n return;\n }\n this.startTimeout();\n this.sent = true;\n this.channel.socket.push({\n topic: this.channel.topic,\n event: this.event,\n payload: this.payload(),\n ref: this.ref,\n join_ref: this.channel.joinRef()\n });\n }\n /**\n *\n * @param {*} status\n * @param {*} callback\n */\n receive(status, callback) {\n if (this.hasReceived(status)) {\n callback(this.receivedResp.response);\n }\n this.recHooks.push({ status, callback });\n return this;\n }\n /**\n * @private\n */\n reset() {\n this.cancelRefEvent();\n this.ref = null;\n this.refEvent = null;\n this.receivedResp = null;\n this.sent = false;\n }\n /**\n * @private\n */\n matchReceive({ status, response, _ref }) {\n this.recHooks.filter((h) => h.status === status).forEach((h) => h.callback(response));\n }\n /**\n * @private\n */\n cancelRefEvent() {\n if (!this.refEvent) {\n return;\n }\n this.channel.off(this.refEvent);\n }\n /**\n * @private\n */\n cancelTimeout() {\n clearTimeout(this.timeoutTimer);\n this.timeoutTimer = null;\n }\n /**\n * @private\n */\n startTimeout() {\n if (this.timeoutTimer) {\n this.cancelTimeout();\n }\n this.ref = this.channel.socket.makeRef();\n this.refEvent = this.channel.replyEventName(this.ref);\n this.channel.on(this.refEvent, (payload) => {\n this.cancelRefEvent();\n this.cancelTimeout();\n this.receivedResp = payload;\n this.matchReceive(payload);\n });\n this.timeoutTimer = setTimeout(() => {\n this.trigger(\"timeout\", {});\n }, this.timeout);\n }\n /**\n * @private\n */\n hasReceived(status) {\n return this.receivedResp && this.receivedResp.status === status;\n }\n /**\n * @private\n */\n trigger(status, response) {\n this.channel.trigger(this.refEvent, { status, response });\n }\n};\n\n// js/phoenix/timer.js\nvar Timer = class {\n constructor(callback, timerCalc) {\n this.callback = callback;\n this.timerCalc = timerCalc;\n this.timer = null;\n this.tries = 0;\n }\n reset() {\n this.tries = 0;\n clearTimeout(this.timer);\n }\n /**\n * Cancels any previous scheduleTimeout and schedules callback\n */\n scheduleTimeout() {\n clearTimeout(this.timer);\n this.timer = setTimeout(() => {\n this.tries = this.tries + 1;\n this.callback();\n }, this.timerCalc(this.tries + 1));\n }\n};\n\n// js/phoenix/channel.js\nvar Channel = class {\n constructor(topic, params, socket) {\n this.state = CHANNEL_STATES.closed;\n this.topic = topic;\n this.params = closure(params || {});\n this.socket = socket;\n this.bindings = [];\n this.bindingRef = 0;\n this.timeout = this.socket.timeout;\n this.joinedOnce = false;\n this.joinPush = new Push(this, CHANNEL_EVENTS.join, this.params, this.timeout);\n this.pushBuffer = [];\n this.stateChangeRefs = [];\n this.rejoinTimer = new Timer(() => {\n if (this.socket.isConnected()) {\n this.rejoin();\n }\n }, this.socket.rejoinAfterMs);\n this.stateChangeRefs.push(this.socket.onError(() => this.rejoinTimer.reset()));\n this.stateChangeRefs.push(\n this.socket.onOpen(() => {\n this.rejoinTimer.reset();\n if (this.isErrored()) {\n this.rejoin();\n }\n })\n );\n this.joinPush.receive(\"ok\", () => {\n this.state = CHANNEL_STATES.joined;\n this.rejoinTimer.reset();\n this.pushBuffer.forEach((pushEvent) => pushEvent.send());\n this.pushBuffer = [];\n });\n this.joinPush.receive(\"error\", () => {\n this.state = CHANNEL_STATES.errored;\n if (this.socket.isConnected()) {\n this.rejoinTimer.scheduleTimeout();\n }\n });\n this.onClose(() => {\n this.rejoinTimer.reset();\n if (this.socket.hasLogger())\n this.socket.log(\"channel\", `close ${this.topic} ${this.joinRef()}`);\n this.state = CHANNEL_STATES.closed;\n this.socket.remove(this);\n });\n this.onError((reason) => {\n if (this.socket.hasLogger())\n this.socket.log(\"channel\", `error ${this.topic}`, reason);\n if (this.isJoining()) {\n this.joinPush.reset();\n }\n this.state = CHANNEL_STATES.errored;\n if (this.socket.isConnected()) {\n this.rejoinTimer.scheduleTimeout();\n }\n });\n this.joinPush.receive(\"timeout\", () => {\n if (this.socket.hasLogger())\n this.socket.log(\"channel\", `timeout ${this.topic} (${this.joinRef()})`, this.joinPush.timeout);\n let leavePush = new Push(this, CHANNEL_EVENTS.leave, closure({}), this.timeout);\n leavePush.send();\n this.state = CHANNEL_STATES.errored;\n this.joinPush.reset();\n if (this.socket.isConnected()) {\n this.rejoinTimer.scheduleTimeout();\n }\n });\n this.on(CHANNEL_EVENTS.reply, (payload, ref) => {\n this.trigger(this.replyEventName(ref), payload);\n });\n }\n /**\n * Join the channel\n * @param {integer} timeout\n * @returns {Push}\n */\n join(timeout = this.timeout) {\n if (this.joinedOnce) {\n throw new Error(\"tried to join multiple times. 'join' can only be called a single time per channel instance\");\n } else {\n this.timeout = timeout;\n this.joinedOnce = true;\n this.rejoin();\n return this.joinPush;\n }\n }\n /**\n * Hook into channel close\n * @param {Function} callback\n */\n onClose(callback) {\n this.on(CHANNEL_EVENTS.close, callback);\n }\n /**\n * Hook into channel errors\n * @param {Function} callback\n */\n onError(callback) {\n return this.on(CHANNEL_EVENTS.error, (reason) => callback(reason));\n }\n /**\n * Subscribes on channel events\n *\n * Subscription returns a ref counter, which can be used later to\n * unsubscribe the exact event listener\n *\n * @example\n * const ref1 = channel.on(\"event\", do_stuff)\n * const ref2 = channel.on(\"event\", do_other_stuff)\n * channel.off(\"event\", ref1)\n * // Since unsubscription, do_stuff won't fire,\n * // while do_other_stuff will keep firing on the \"event\"\n *\n * @param {string} event\n * @param {Function} callback\n * @returns {integer} ref\n */\n on(event, callback) {\n let ref = this.bindingRef++;\n this.bindings.push({ event, ref, callback });\n return ref;\n }\n /**\n * Unsubscribes off of channel events\n *\n * Use the ref returned from a channel.on() to unsubscribe one\n * handler, or pass nothing for the ref to unsubscribe all\n * handlers for the given event.\n *\n * @example\n * // Unsubscribe the do_stuff handler\n * const ref1 = channel.on(\"event\", do_stuff)\n * channel.off(\"event\", ref1)\n *\n * // Unsubscribe all handlers from event\n * channel.off(\"event\")\n *\n * @param {string} event\n * @param {integer} ref\n */\n off(event, ref) {\n this.bindings = this.bindings.filter((bind) => {\n return !(bind.event === event && (typeof ref === \"undefined\" || ref === bind.ref));\n });\n }\n /**\n * @private\n */\n canPush() {\n return this.socket.isConnected() && this.isJoined();\n }\n /**\n * Sends a message `event` to phoenix with the payload `payload`.\n * Phoenix receives this in the `handle_in(event, payload, socket)`\n * function. if phoenix replies or it times out (default 10000ms),\n * then optionally the reply can be received.\n *\n * @example\n * channel.push(\"event\")\n * .receive(\"ok\", payload => console.log(\"phoenix replied:\", payload))\n * .receive(\"error\", err => console.log(\"phoenix errored\", err))\n * .receive(\"timeout\", () => console.log(\"timed out pushing\"))\n * @param {string} event\n * @param {Object} payload\n * @param {number} [timeout]\n * @returns {Push}\n */\n push(event, payload, timeout = this.timeout) {\n payload = payload || {};\n if (!this.joinedOnce) {\n throw new Error(`tried to push '${event}' to '${this.topic}' before joining. Use channel.join() before pushing events`);\n }\n let pushEvent = new Push(this, event, function() {\n return payload;\n }, timeout);\n if (this.canPush()) {\n pushEvent.send();\n } else {\n pushEvent.startTimeout();\n this.pushBuffer.push(pushEvent);\n }\n return pushEvent;\n }\n /** Leaves the channel\n *\n * Unsubscribes from server events, and\n * instructs channel to terminate on server\n *\n * Triggers onClose() hooks\n *\n * To receive leave acknowledgements, use the `receive`\n * hook to bind to the server ack, ie:\n *\n * @example\n * channel.leave().receive(\"ok\", () => alert(\"left!\") )\n *\n * @param {integer} timeout\n * @returns {Push}\n */\n leave(timeout = this.timeout) {\n this.rejoinTimer.reset();\n this.joinPush.cancelTimeout();\n this.state = CHANNEL_STATES.leaving;\n let onClose = () => {\n if (this.socket.hasLogger())\n this.socket.log(\"channel\", `leave ${this.topic}`);\n this.trigger(CHANNEL_EVENTS.close, \"leave\");\n };\n let leavePush = new Push(this, CHANNEL_EVENTS.leave, closure({}), timeout);\n leavePush.receive(\"ok\", () => onClose()).receive(\"timeout\", () => onClose());\n leavePush.send();\n if (!this.canPush()) {\n leavePush.trigger(\"ok\", {});\n }\n return leavePush;\n }\n /**\n * Overridable message hook\n *\n * Receives all events for specialized message handling\n * before dispatching to the channel callbacks.\n *\n * Must return the payload, modified or unmodified\n * @param {string} event\n * @param {Object} payload\n * @param {integer} ref\n * @returns {Object}\n */\n onMessage(_event, payload, _ref) {\n return payload;\n }\n /**\n * @private\n */\n isMember(topic, event, payload, joinRef) {\n if (this.topic !== topic) {\n return false;\n }\n if (joinRef && joinRef !== this.joinRef()) {\n if (this.socket.hasLogger())\n this.socket.log(\"channel\", \"dropping outdated message\", { topic, event, payload, joinRef });\n return false;\n } else {\n return true;\n }\n }\n /**\n * @private\n */\n joinRef() {\n return this.joinPush.ref;\n }\n /**\n * @private\n */\n rejoin(timeout = this.timeout) {\n if (this.isLeaving()) {\n return;\n }\n this.socket.leaveOpenTopic(this.topic);\n this.state = CHANNEL_STATES.joining;\n this.joinPush.resend(timeout);\n }\n /**\n * @private\n */\n trigger(event, payload, ref, joinRef) {\n let handledPayload = this.onMessage(event, payload, ref, joinRef);\n if (payload && !handledPayload) {\n throw new Error(\"channel onMessage callbacks must return the payload, modified or unmodified\");\n }\n let eventBindings = this.bindings.filter((bind) => bind.event === event);\n for (let i = 0; i < eventBindings.length; i++) {\n let bind = eventBindings[i];\n bind.callback(handledPayload, ref, joinRef || this.joinRef());\n }\n }\n /**\n * @private\n */\n replyEventName(ref) {\n return `chan_reply_${ref}`;\n }\n /**\n * @private\n */\n isClosed() {\n return this.state === CHANNEL_STATES.closed;\n }\n /**\n * @private\n */\n isErrored() {\n return this.state === CHANNEL_STATES.errored;\n }\n /**\n * @private\n */\n isJoined() {\n return this.state === CHANNEL_STATES.joined;\n }\n /**\n * @private\n */\n isJoining() {\n return this.state === CHANNEL_STATES.joining;\n }\n /**\n * @private\n */\n isLeaving() {\n return this.state === CHANNEL_STATES.leaving;\n }\n};\n\n// js/phoenix/ajax.js\nvar Ajax = class {\n static request(method, endPoint, accept, body, timeout, ontimeout, callback) {\n if (global.XDomainRequest) {\n let req = new global.XDomainRequest();\n return this.xdomainRequest(req, method, endPoint, body, timeout, ontimeout, callback);\n } else {\n let req = new global.XMLHttpRequest();\n return this.xhrRequest(req, method, endPoint, accept, body, timeout, ontimeout, callback);\n }\n }\n static xdomainRequest(req, method, endPoint, body, timeout, ontimeout, callback) {\n req.timeout = timeout;\n req.open(method, endPoint);\n req.onload = () => {\n let response = this.parseJSON(req.responseText);\n callback && callback(response);\n };\n if (ontimeout) {\n req.ontimeout = ontimeout;\n }\n req.onprogress = () => {\n };\n req.send(body);\n return req;\n }\n static xhrRequest(req, method, endPoint, accept, body, timeout, ontimeout, callback) {\n req.open(method, endPoint, true);\n req.timeout = timeout;\n req.setRequestHeader(\"Content-Type\", accept);\n req.onerror = () => callback && callback(null);\n req.onreadystatechange = () => {\n if (req.readyState === XHR_STATES.complete && callback) {\n let response = this.parseJSON(req.responseText);\n callback(response);\n }\n };\n if (ontimeout) {\n req.ontimeout = ontimeout;\n }\n req.send(body);\n return req;\n }\n static parseJSON(resp) {\n if (!resp || resp === \"\") {\n return null;\n }\n try {\n return JSON.parse(resp);\n } catch (e) {\n console && console.log(\"failed to parse JSON response\", resp);\n return null;\n }\n }\n static serialize(obj, parentKey) {\n let queryStr = [];\n for (var key in obj) {\n if (!Object.prototype.hasOwnProperty.call(obj, key)) {\n continue;\n }\n let paramKey = parentKey ? `${parentKey}[${key}]` : key;\n let paramVal = obj[key];\n if (typeof paramVal === \"object\") {\n queryStr.push(this.serialize(paramVal, paramKey));\n } else {\n queryStr.push(encodeURIComponent(paramKey) + \"=\" + encodeURIComponent(paramVal));\n }\n }\n return queryStr.join(\"&\");\n }\n static appendParams(url, params) {\n if (Object.keys(params).length === 0) {\n return url;\n }\n let prefix = url.match(/\\?/) ? \"&\" : \"?\";\n return `${url}${prefix}${this.serialize(params)}`;\n }\n};\n\n// js/phoenix/longpoll.js\nvar arrayBufferToBase64 = (buffer) => {\n let binary = \"\";\n let bytes = new Uint8Array(buffer);\n let len = bytes.byteLength;\n for (let i = 0; i < len; i++) {\n binary += String.fromCharCode(bytes[i]);\n }\n return btoa(binary);\n};\nvar LongPoll = class {\n constructor(endPoint) {\n this.endPoint = null;\n this.token = null;\n this.skipHeartbeat = true;\n this.reqs = /* @__PURE__ */ new Set();\n this.awaitingBatchAck = false;\n this.currentBatch = null;\n this.currentBatchTimer = null;\n this.batchBuffer = [];\n this.onopen = function() {\n };\n this.onerror = function() {\n };\n this.onmessage = function() {\n };\n this.onclose = function() {\n };\n this.pollEndpoint = this.normalizeEndpoint(endPoint);\n this.readyState = SOCKET_STATES.connecting;\n setTimeout(() => this.poll(), 0);\n }\n normalizeEndpoint(endPoint) {\n return endPoint.replace(\"ws://\", \"http://\").replace(\"wss://\", \"https://\").replace(new RegExp(\"(.*)/\" + TRANSPORTS.websocket), \"$1/\" + TRANSPORTS.longpoll);\n }\n endpointURL() {\n return Ajax.appendParams(this.pollEndpoint, { token: this.token });\n }\n closeAndRetry(code, reason, wasClean) {\n this.close(code, reason, wasClean);\n this.readyState = SOCKET_STATES.connecting;\n }\n ontimeout() {\n this.onerror(\"timeout\");\n this.closeAndRetry(1005, \"timeout\", false);\n }\n isActive() {\n return this.readyState === SOCKET_STATES.open || this.readyState === SOCKET_STATES.connecting;\n }\n poll() {\n this.ajax(\"GET\", \"application/json\", null, () => this.ontimeout(), (resp) => {\n if (resp) {\n var { status, token, messages } = resp;\n this.token = token;\n } else {\n status = 0;\n }\n switch (status) {\n case 200:\n messages.forEach((msg) => {\n setTimeout(() => this.onmessage({ data: msg }), 0);\n });\n this.poll();\n break;\n case 204:\n this.poll();\n break;\n case 410:\n this.readyState = SOCKET_STATES.open;\n this.onopen({});\n this.poll();\n break;\n case 403:\n this.onerror(403);\n this.close(1008, \"forbidden\", false);\n break;\n case 0:\n case 500:\n this.onerror(500);\n this.closeAndRetry(1011, \"internal server error\", 500);\n break;\n default:\n throw new Error(`unhandled poll status ${status}`);\n }\n });\n }\n // we collect all pushes within the current event loop by\n // setTimeout 0, which optimizes back-to-back procedural\n // pushes against an empty buffer\n send(body) {\n if (typeof body !== \"string\") {\n body = arrayBufferToBase64(body);\n }\n if (this.currentBatch) {\n this.currentBatch.push(body);\n } else if (this.awaitingBatchAck) {\n this.batchBuffer.push(body);\n } else {\n this.currentBatch = [body];\n this.currentBatchTimer = setTimeout(() => {\n this.batchSend(this.currentBatch);\n this.currentBatch = null;\n }, 0);\n }\n }\n batchSend(messages) {\n this.awaitingBatchAck = true;\n this.ajax(\"POST\", \"application/x-ndjson\", messages.join(\"\\n\"), () => this.onerror(\"timeout\"), (resp) => {\n this.awaitingBatchAck = false;\n if (!resp || resp.status !== 200) {\n this.onerror(resp && resp.status);\n this.closeAndRetry(1011, \"internal server error\", false);\n } else if (this.batchBuffer.length > 0) {\n this.batchSend(this.batchBuffer);\n this.batchBuffer = [];\n }\n });\n }\n close(code, reason, wasClean) {\n for (let req of this.reqs) {\n req.abort();\n }\n this.readyState = SOCKET_STATES.closed;\n let opts = Object.assign({ code: 1e3, reason: void 0, wasClean: true }, { code, reason, wasClean });\n this.batchBuffer = [];\n clearTimeout(this.currentBatchTimer);\n this.currentBatchTimer = null;\n if (typeof CloseEvent !== \"undefined\") {\n this.onclose(new CloseEvent(\"close\", opts));\n } else {\n this.onclose(opts);\n }\n }\n ajax(method, contentType, body, onCallerTimeout, callback) {\n let req;\n let ontimeout = () => {\n this.reqs.delete(req);\n onCallerTimeout();\n };\n req = Ajax.request(method, this.endpointURL(), contentType, body, this.timeout, ontimeout, (resp) => {\n this.reqs.delete(req);\n if (this.isActive()) {\n callback(resp);\n }\n });\n this.reqs.add(req);\n }\n};\n\n// js/phoenix/presence.js\nvar Presence = class {\n constructor(channel, opts = {}) {\n let events = opts.events || { state: \"presence_state\", diff: \"presence_diff\" };\n this.state = {};\n this.pendingDiffs = [];\n this.channel = channel;\n this.joinRef = null;\n this.caller = {\n onJoin: function() {\n },\n onLeave: function() {\n },\n onSync: function() {\n }\n };\n this.channel.on(events.state, (newState) => {\n let { onJoin, onLeave, onSync } = this.caller;\n this.joinRef = this.channel.joinRef();\n this.state = Presence.syncState(this.state, newState, onJoin, onLeave);\n this.pendingDiffs.forEach((diff) => {\n this.state = Presence.syncDiff(this.state, diff, onJoin, onLeave);\n });\n this.pendingDiffs = [];\n onSync();\n });\n this.channel.on(events.diff, (diff) => {\n let { onJoin, onLeave, onSync } = this.caller;\n if (this.inPendingSyncState()) {\n this.pendingDiffs.push(diff);\n } else {\n this.state = Presence.syncDiff(this.state, diff, onJoin, onLeave);\n onSync();\n }\n });\n }\n onJoin(callback) {\n this.caller.onJoin = callback;\n }\n onLeave(callback) {\n this.caller.onLeave = callback;\n }\n onSync(callback) {\n this.caller.onSync = callback;\n }\n list(by) {\n return Presence.list(this.state, by);\n }\n inPendingSyncState() {\n return !this.joinRef || this.joinRef !== this.channel.joinRef();\n }\n // lower-level public static API\n /**\n * Used to sync the list of presences on the server\n * with the client's state. An optional `onJoin` and `onLeave` callback can\n * be provided to react to changes in the client's local presences across\n * disconnects and reconnects with the server.\n *\n * @returns {Presence}\n */\n static syncState(currentState, newState, onJoin, onLeave) {\n let state = this.clone(currentState);\n let joins = {};\n let leaves = {};\n this.map(state, (key, presence) => {\n if (!newState[key]) {\n leaves[key] = presence;\n }\n });\n this.map(newState, (key, newPresence) => {\n let currentPresence = state[key];\n if (currentPresence) {\n let newRefs = newPresence.metas.map((m) => m.phx_ref);\n let curRefs = currentPresence.metas.map((m) => m.phx_ref);\n let joinedMetas = newPresence.metas.filter((m) => curRefs.indexOf(m.phx_ref) < 0);\n let leftMetas = currentPresence.metas.filter((m) => newRefs.indexOf(m.phx_ref) < 0);\n if (joinedMetas.length > 0) {\n joins[key] = newPresence;\n joins[key].metas = joinedMetas;\n }\n if (leftMetas.length > 0) {\n leaves[key] = this.clone(currentPresence);\n leaves[key].metas = leftMetas;\n }\n } else {\n joins[key] = newPresence;\n }\n });\n return this.syncDiff(state, { joins, leaves }, onJoin, onLeave);\n }\n /**\n *\n * Used to sync a diff of presence join and leave\n * events from the server, as they happen. Like `syncState`, `syncDiff`\n * accepts optional `onJoin` and `onLeave` callbacks to react to a user\n * joining or leaving from a device.\n *\n * @returns {Presence}\n */\n static syncDiff(state, diff, onJoin, onLeave) {\n let { joins, leaves } = this.clone(diff);\n if (!onJoin) {\n onJoin = function() {\n };\n }\n if (!onLeave) {\n onLeave = function() {\n };\n }\n this.map(joins, (key, newPresence) => {\n let currentPresence = state[key];\n state[key] = this.clone(newPresence);\n if (currentPresence) {\n let joinedRefs = state[key].metas.map((m) => m.phx_ref);\n let curMetas = currentPresence.metas.filter((m) => joinedRefs.indexOf(m.phx_ref) < 0);\n state[key].metas.unshift(...curMetas);\n }\n onJoin(key, currentPresence, newPresence);\n });\n this.map(leaves, (key, leftPresence) => {\n let currentPresence = state[key];\n if (!currentPresence) {\n return;\n }\n let refsToRemove = leftPresence.metas.map((m) => m.phx_ref);\n currentPresence.metas = currentPresence.metas.filter((p) => {\n return refsToRemove.indexOf(p.phx_ref) < 0;\n });\n onLeave(key, currentPresence, leftPresence);\n if (currentPresence.metas.length === 0) {\n delete state[key];\n }\n });\n return state;\n }\n /**\n * Returns the array of presences, with selected metadata.\n *\n * @param {Object} presences\n * @param {Function} chooser\n *\n * @returns {Presence}\n */\n static list(presences, chooser) {\n if (!chooser) {\n chooser = function(key, pres) {\n return pres;\n };\n }\n return this.map(presences, (key, presence) => {\n return chooser(key, presence);\n });\n }\n // private\n static map(obj, func) {\n return Object.getOwnPropertyNames(obj).map((key) => func(key, obj[key]));\n }\n static clone(obj) {\n return JSON.parse(JSON.stringify(obj));\n }\n};\n\n// js/phoenix/serializer.js\nvar serializer_default = {\n HEADER_LENGTH: 1,\n META_LENGTH: 4,\n KINDS: { push: 0, reply: 1, broadcast: 2 },\n encode(msg, callback) {\n if (msg.payload.constructor === ArrayBuffer) {\n return callback(this.binaryEncode(msg));\n } else {\n let payload = [msg.join_ref, msg.ref, msg.topic, msg.event, msg.payload];\n return callback(JSON.stringify(payload));\n }\n },\n decode(rawPayload, callback) {\n if (rawPayload.constructor === ArrayBuffer) {\n return callback(this.binaryDecode(rawPayload));\n } else {\n let [join_ref, ref, topic, event, payload] = JSON.parse(rawPayload);\n return callback({ join_ref, ref, topic, event, payload });\n }\n },\n // private\n binaryEncode(message) {\n let { join_ref, ref, event, topic, payload } = message;\n let metaLength = this.META_LENGTH + join_ref.length + ref.length + topic.length + event.length;\n let header = new ArrayBuffer(this.HEADER_LENGTH + metaLength);\n let view = new DataView(header);\n let offset = 0;\n view.setUint8(offset++, this.KINDS.push);\n view.setUint8(offset++, join_ref.length);\n view.setUint8(offset++, ref.length);\n view.setUint8(offset++, topic.length);\n view.setUint8(offset++, event.length);\n Array.from(join_ref, (char) => view.setUint8(offset++, char.charCodeAt(0)));\n Array.from(ref, (char) => view.setUint8(offset++, char.charCodeAt(0)));\n Array.from(topic, (char) => view.setUint8(offset++, char.charCodeAt(0)));\n Array.from(event, (char) => view.setUint8(offset++, char.charCodeAt(0)));\n var combined = new Uint8Array(header.byteLength + payload.byteLength);\n combined.set(new Uint8Array(header), 0);\n combined.set(new Uint8Array(payload), header.byteLength);\n return combined.buffer;\n },\n binaryDecode(buffer) {\n let view = new DataView(buffer);\n let kind = view.getUint8(0);\n let decoder = new TextDecoder();\n switch (kind) {\n case this.KINDS.push:\n return this.decodePush(buffer, view, decoder);\n case this.KINDS.reply:\n return this.decodeReply(buffer, view, decoder);\n case this.KINDS.broadcast:\n return this.decodeBroadcast(buffer, view, decoder);\n }\n },\n decodePush(buffer, view, decoder) {\n let joinRefSize = view.getUint8(1);\n let topicSize = view.getUint8(2);\n let eventSize = view.getUint8(3);\n let offset = this.HEADER_LENGTH + this.META_LENGTH - 1;\n let joinRef = decoder.decode(buffer.slice(offset, offset + joinRefSize));\n offset = offset + joinRefSize;\n let topic = decoder.decode(buffer.slice(offset, offset + topicSize));\n offset = offset + topicSize;\n let event = decoder.decode(buffer.slice(offset, offset + eventSize));\n offset = offset + eventSize;\n let data = buffer.slice(offset, buffer.byteLength);\n return { join_ref: joinRef, ref: null, topic, event, payload: data };\n },\n decodeReply(buffer, view, decoder) {\n let joinRefSize = view.getUint8(1);\n let refSize = view.getUint8(2);\n let topicSize = view.getUint8(3);\n let eventSize = view.getUint8(4);\n let offset = this.HEADER_LENGTH + this.META_LENGTH;\n let joinRef = decoder.decode(buffer.slice(offset, offset + joinRefSize));\n offset = offset + joinRefSize;\n let ref = decoder.decode(buffer.slice(offset, offset + refSize));\n offset = offset + refSize;\n let topic = decoder.decode(buffer.slice(offset, offset + topicSize));\n offset = offset + topicSize;\n let event = decoder.decode(buffer.slice(offset, offset + eventSize));\n offset = offset + eventSize;\n let data = buffer.slice(offset, buffer.byteLength);\n let payload = { status: event, response: data };\n return { join_ref: joinRef, ref, topic, event: CHANNEL_EVENTS.reply, payload };\n },\n decodeBroadcast(buffer, view, decoder) {\n let topicSize = view.getUint8(1);\n let eventSize = view.getUint8(2);\n let offset = this.HEADER_LENGTH + 2;\n let topic = decoder.decode(buffer.slice(offset, offset + topicSize));\n offset = offset + topicSize;\n let event = decoder.decode(buffer.slice(offset, offset + eventSize));\n offset = offset + eventSize;\n let data = buffer.slice(offset, buffer.byteLength);\n return { join_ref: null, ref: null, topic, event, payload: data };\n }\n};\n\n// js/phoenix/socket.js\nvar Socket = class {\n constructor(endPoint, opts = {}) {\n this.stateChangeCallbacks = { open: [], close: [], error: [], message: [] };\n this.channels = [];\n this.sendBuffer = [];\n this.ref = 0;\n this.timeout = opts.timeout || DEFAULT_TIMEOUT;\n this.transport = opts.transport || global.WebSocket || LongPoll;\n this.longPollFallbackMs = opts.longPollFallbackMs;\n this.fallbackTimer = null;\n this.sessionStore = opts.sessionStorage || global.sessionStorage;\n this.establishedConnections = 0;\n this.defaultEncoder = serializer_default.encode.bind(serializer_default);\n this.defaultDecoder = serializer_default.decode.bind(serializer_default);\n this.closeWasClean = false;\n this.binaryType = opts.binaryType || \"arraybuffer\";\n this.connectClock = 1;\n if (this.transport !== LongPoll) {\n this.encode = opts.encode || this.defaultEncoder;\n this.decode = opts.decode || this.defaultDecoder;\n } else {\n this.encode = this.defaultEncoder;\n this.decode = this.defaultDecoder;\n }\n let awaitingConnectionOnPageShow = null;\n if (phxWindow && phxWindow.addEventListener) {\n phxWindow.addEventListener(\"pagehide\", (_e) => {\n if (this.conn) {\n this.disconnect();\n awaitingConnectionOnPageShow = this.connectClock;\n }\n });\n phxWindow.addEventListener(\"pageshow\", (_e) => {\n if (awaitingConnectionOnPageShow === this.connectClock) {\n awaitingConnectionOnPageShow = null;\n this.connect();\n }\n });\n }\n this.heartbeatIntervalMs = opts.heartbeatIntervalMs || 3e4;\n this.rejoinAfterMs = (tries) => {\n if (opts.rejoinAfterMs) {\n return opts.rejoinAfterMs(tries);\n } else {\n return [1e3, 2e3, 5e3][tries - 1] || 1e4;\n }\n };\n this.reconnectAfterMs = (tries) => {\n if (opts.reconnectAfterMs) {\n return opts.reconnectAfterMs(tries);\n } else {\n return [10, 50, 100, 150, 200, 250, 500, 1e3, 2e3][tries - 1] || 5e3;\n }\n };\n this.logger = opts.logger || null;\n if (!this.logger && opts.debug) {\n this.logger = (kind, msg, data) => {\n console.log(`${kind}: ${msg}`, data);\n };\n }\n this.longpollerTimeout = opts.longpollerTimeout || 2e4;\n this.params = closure(opts.params || {});\n this.endPoint = `${endPoint}/${TRANSPORTS.websocket}`;\n this.vsn = opts.vsn || DEFAULT_VSN;\n this.heartbeatTimeoutTimer = null;\n this.heartbeatTimer = null;\n this.pendingHeartbeatRef = null;\n this.reconnectTimer = new Timer(() => {\n this.teardown(() => this.connect());\n }, this.reconnectAfterMs);\n }\n /**\n * Returns the LongPoll transport reference\n */\n getLongPollTransport() {\n return LongPoll;\n }\n /**\n * Disconnects and replaces the active transport\n *\n * @param {Function} newTransport - The new transport class to instantiate\n *\n */\n replaceTransport(newTransport) {\n this.connectClock++;\n this.closeWasClean = true;\n clearTimeout(this.fallbackTimer);\n this.reconnectTimer.reset();\n if (this.conn) {\n this.conn.close();\n this.conn = null;\n }\n this.transport = newTransport;\n }\n /**\n * Returns the socket protocol\n *\n * @returns {string}\n */\n protocol() {\n return location.protocol.match(/^https/) ? \"wss\" : \"ws\";\n }\n /**\n * The fully qualified socket url\n *\n * @returns {string}\n */\n endPointURL() {\n let uri = Ajax.appendParams(\n Ajax.appendParams(this.endPoint, this.params()),\n { vsn: this.vsn }\n );\n if (uri.charAt(0) !== \"/\") {\n return uri;\n }\n if (uri.charAt(1) === \"/\") {\n return `${this.protocol()}:${uri}`;\n }\n return `${this.protocol()}://${location.host}${uri}`;\n }\n /**\n * Disconnects the socket\n *\n * See https://developer.mozilla.org/en-US/docs/Web/API/CloseEvent#Status_codes for valid status codes.\n *\n * @param {Function} callback - Optional callback which is called after socket is disconnected.\n * @param {integer} code - A status code for disconnection (Optional).\n * @param {string} reason - A textual description of the reason to disconnect. (Optional)\n */\n disconnect(callback, code, reason) {\n this.connectClock++;\n this.closeWasClean = true;\n clearTimeout(this.fallbackTimer);\n this.reconnectTimer.reset();\n this.teardown(callback, code, reason);\n }\n /**\n *\n * @param {Object} params - The params to send when connecting, for example `{user_id: userToken}`\n *\n * Passing params to connect is deprecated; pass them in the Socket constructor instead:\n * `new Socket(\"/socket\", {params: {user_id: userToken}})`.\n */\n connect(params) {\n if (params) {\n console && console.log(\"passing params to connect is deprecated. Instead pass :params to the Socket constructor\");\n this.params = closure(params);\n }\n if (this.conn) {\n return;\n }\n if (this.longPollFallbackMs && this.transport !== LongPoll) {\n this.connectWithFallback(LongPoll, this.longPollFallbackMs);\n } else {\n this.transportConnect();\n }\n }\n /**\n * Logs the message. Override `this.logger` for specialized logging. noops by default\n * @param {string} kind\n * @param {string} msg\n * @param {Object} data\n */\n log(kind, msg, data) {\n this.logger && this.logger(kind, msg, data);\n }\n /**\n * Returns true if a logger has been set on this socket.\n */\n hasLogger() {\n return this.logger !== null;\n }\n /**\n * Registers callbacks for connection open events\n *\n * @example socket.onOpen(function(){ console.info(\"the socket was opened\") })\n *\n * @param {Function} callback\n */\n onOpen(callback) {\n let ref = this.makeRef();\n this.stateChangeCallbacks.open.push([ref, callback]);\n return ref;\n }\n /**\n * Registers callbacks for connection close events\n * @param {Function} callback\n */\n onClose(callback) {\n let ref = this.makeRef();\n this.stateChangeCallbacks.close.push([ref, callback]);\n return ref;\n }\n /**\n * Registers callbacks for connection error events\n *\n * @example socket.onError(function(error){ alert(\"An error occurred\") })\n *\n * @param {Function} callback\n */\n onError(callback) {\n let ref = this.makeRef();\n this.stateChangeCallbacks.error.push([ref, callback]);\n return ref;\n }\n /**\n * Registers callbacks for connection message events\n * @param {Function} callback\n */\n onMessage(callback) {\n let ref = this.makeRef();\n this.stateChangeCallbacks.message.push([ref, callback]);\n return ref;\n }\n /**\n * Pings the server and invokes the callback with the RTT in milliseconds\n * @param {Function} callback\n *\n * Returns true if the ping was pushed or false if unable to be pushed.\n */\n ping(callback) {\n if (!this.isConnected()) {\n return false;\n }\n let ref = this.makeRef();\n let startTime = Date.now();\n this.push({ topic: \"phoenix\", event: \"heartbeat\", payload: {}, ref });\n let onMsgRef = this.onMessage((msg) => {\n if (msg.ref === ref) {\n this.off([onMsgRef]);\n callback(Date.now() - startTime);\n }\n });\n return true;\n }\n /**\n * @private\n */\n transportConnect() {\n this.connectClock++;\n this.closeWasClean = false;\n this.conn = new this.transport(this.endPointURL());\n this.conn.binaryType = this.binaryType;\n this.conn.timeout = this.longpollerTimeout;\n this.conn.onopen = () => this.onConnOpen();\n this.conn.onerror = (error) => this.onConnError(error);\n this.conn.onmessage = (event) => this.onConnMessage(event);\n this.conn.onclose = (event) => this.onConnClose(event);\n }\n getSession(key) {\n return this.sessionStore && this.sessionStore.getItem(key);\n }\n storeSession(key, val) {\n this.sessionStore && this.sessionStore.setItem(key, val);\n }\n connectWithFallback(fallbackTransport, fallbackThreshold = 2500) {\n clearTimeout(this.fallbackTimer);\n let established = false;\n let primaryTransport = true;\n let openRef, errorRef;\n let fallback = (reason) => {\n this.log(\"transport\", `falling back to ${fallbackTransport.name}...`, reason);\n this.off([openRef, errorRef]);\n primaryTransport = false;\n this.storeSession(\"phx:longpoll\", \"true\");\n this.replaceTransport(fallbackTransport);\n this.transportConnect();\n };\n if (this.getSession(\"phx:longpoll\")) {\n return fallback(\"memorized\");\n }\n this.fallbackTimer = setTimeout(fallback, fallbackThreshold);\n errorRef = this.onError((reason) => {\n this.log(\"transport\", \"error\", reason);\n if (primaryTransport && !established) {\n clearTimeout(this.fallbackTimer);\n fallback(reason);\n }\n });\n this.onOpen(() => {\n established = true;\n if (!primaryTransport) {\n return console.log(\"transport\", `established ${fallbackTransport.name} fallback`);\n }\n clearTimeout(this.fallbackTimer);\n this.fallbackTimer = setTimeout(fallback, fallbackThreshold);\n this.ping((rtt) => {\n this.log(\"transport\", \"connected to primary after\", rtt);\n clearTimeout(this.fallbackTimer);\n });\n });\n this.transportConnect();\n }\n clearHeartbeats() {\n clearTimeout(this.heartbeatTimer);\n clearTimeout(this.heartbeatTimeoutTimer);\n }\n onConnOpen() {\n if (this.hasLogger())\n this.log(\"transport\", `${this.transport.name} connected to ${this.endPointURL()}`);\n this.closeWasClean = false;\n this.establishedConnections++;\n this.flushSendBuffer();\n this.reconnectTimer.reset();\n this.resetHeartbeat();\n this.stateChangeCallbacks.open.forEach(([, callback]) => callback());\n }\n /**\n * @private\n */\n heartbeatTimeout() {\n if (this.pendingHeartbeatRef) {\n this.pendingHeartbeatRef = null;\n if (this.hasLogger()) {\n this.log(\"transport\", \"heartbeat timeout. Attempting to re-establish connection\");\n }\n this.triggerChanError();\n this.closeWasClean = false;\n this.teardown(() => this.reconnectTimer.scheduleTimeout(), WS_CLOSE_NORMAL, \"heartbeat timeout\");\n }\n }\n resetHeartbeat() {\n if (this.conn && this.conn.skipHeartbeat) {\n return;\n }\n this.pendingHeartbeatRef = null;\n this.clearHeartbeats();\n this.heartbeatTimer = setTimeout(() => this.sendHeartbeat(), this.heartbeatIntervalMs);\n }\n teardown(callback, code, reason) {\n if (!this.conn) {\n return callback && callback();\n }\n this.waitForBufferDone(() => {\n if (this.conn) {\n if (code) {\n this.conn.close(code, reason || \"\");\n } else {\n this.conn.close();\n }\n }\n this.waitForSocketClosed(() => {\n if (this.conn) {\n this.conn.onopen = function() {\n };\n this.conn.onerror = function() {\n };\n this.conn.onmessage = function() {\n };\n this.conn.onclose = function() {\n };\n this.conn = null;\n }\n callback && callback();\n });\n });\n }\n waitForBufferDone(callback, tries = 1) {\n if (tries === 5 || !this.conn || !this.conn.bufferedAmount) {\n callback();\n return;\n }\n setTimeout(() => {\n this.waitForBufferDone(callback, tries + 1);\n }, 150 * tries);\n }\n waitForSocketClosed(callback, tries = 1) {\n if (tries === 5 || !this.conn || this.conn.readyState === SOCKET_STATES.closed) {\n callback();\n return;\n }\n setTimeout(() => {\n this.waitForSocketClosed(callback, tries + 1);\n }, 150 * tries);\n }\n onConnClose(event) {\n let closeCode = event && event.code;\n if (this.hasLogger())\n this.log(\"transport\", \"close\", event);\n this.triggerChanError();\n this.clearHeartbeats();\n if (!this.closeWasClean && closeCode !== 1e3) {\n this.reconnectTimer.scheduleTimeout();\n }\n this.stateChangeCallbacks.close.forEach(([, callback]) => callback(event));\n }\n /**\n * @private\n */\n onConnError(error) {\n if (this.hasLogger())\n this.log(\"transport\", error);\n let transportBefore = this.transport;\n let establishedBefore = this.establishedConnections;\n this.stateChangeCallbacks.error.forEach(([, callback]) => {\n callback(error, transportBefore, establishedBefore);\n });\n if (transportBefore === this.transport || establishedBefore > 0) {\n this.triggerChanError();\n }\n }\n /**\n * @private\n */\n triggerChanError() {\n this.channels.forEach((channel) => {\n if (!(channel.isErrored() || channel.isLeaving() || channel.isClosed())) {\n channel.trigger(CHANNEL_EVENTS.error);\n }\n });\n }\n /**\n * @returns {string}\n */\n connectionState() {\n switch (this.conn && this.conn.readyState) {\n case SOCKET_STATES.connecting:\n return \"connecting\";\n case SOCKET_STATES.open:\n return \"open\";\n case SOCKET_STATES.closing:\n return \"closing\";\n default:\n return \"closed\";\n }\n }\n /**\n * @returns {boolean}\n */\n isConnected() {\n return this.connectionState() === \"open\";\n }\n /**\n * @private\n *\n * @param {Channel}\n */\n remove(channel) {\n this.off(channel.stateChangeRefs);\n this.channels = this.channels.filter((c) => c.joinRef() !== channel.joinRef());\n }\n /**\n * Removes `onOpen`, `onClose`, `onError,` and `onMessage` registrations.\n *\n * @param {refs} - list of refs returned by calls to\n * `onOpen`, `onClose`, `onError,` and `onMessage`\n */\n off(refs) {\n for (let key in this.stateChangeCallbacks) {\n this.stateChangeCallbacks[key] = this.stateChangeCallbacks[key].filter(([ref]) => {\n return refs.indexOf(ref) === -1;\n });\n }\n }\n /**\n * Initiates a new channel for the given topic\n *\n * @param {string} topic\n * @param {Object} chanParams - Parameters for the channel\n * @returns {Channel}\n */\n channel(topic, chanParams = {}) {\n let chan = new Channel(topic, chanParams, this);\n this.channels.push(chan);\n return chan;\n }\n /**\n * @param {Object} data\n */\n push(data) {\n if (this.hasLogger()) {\n let { topic, event, payload, ref, join_ref } = data;\n this.log(\"push\", `${topic} ${event} (${join_ref}, ${ref})`, payload);\n }\n if (this.isConnected()) {\n this.encode(data, (result) => this.conn.send(result));\n } else {\n this.sendBuffer.push(() => this.encode(data, (result) => this.conn.send(result)));\n }\n }\n /**\n * Return the next message ref, accounting for overflows\n * @returns {string}\n */\n makeRef() {\n let newRef = this.ref + 1;\n if (newRef === this.ref) {\n this.ref = 0;\n } else {\n this.ref = newRef;\n }\n return this.ref.toString();\n }\n sendHeartbeat() {\n if (this.pendingHeartbeatRef && !this.isConnected()) {\n return;\n }\n this.pendingHeartbeatRef = this.makeRef();\n this.push({ topic: \"phoenix\", event: \"heartbeat\", payload: {}, ref: this.pendingHeartbeatRef });\n this.heartbeatTimeoutTimer = setTimeout(() => this.heartbeatTimeout(), this.heartbeatIntervalMs);\n }\n flushSendBuffer() {\n if (this.isConnected() && this.sendBuffer.length > 0) {\n this.sendBuffer.forEach((callback) => callback());\n this.sendBuffer = [];\n }\n }\n onConnMessage(rawMessage) {\n this.decode(rawMessage.data, (msg) => {\n let { topic, event, payload, ref, join_ref } = msg;\n if (ref && ref === this.pendingHeartbeatRef) {\n this.clearHeartbeats();\n this.pendingHeartbeatRef = null;\n this.heartbeatTimer = setTimeout(() => this.sendHeartbeat(), this.heartbeatIntervalMs);\n }\n if (this.hasLogger())\n this.log(\"receive\", `${payload.status || \"\"} ${topic} ${event} ${ref && \"(\" + ref + \")\" || \"\"}`, payload);\n for (let i = 0; i < this.channels.length; i++) {\n const channel = this.channels[i];\n if (!channel.isMember(topic, event, payload, join_ref)) {\n continue;\n }\n channel.trigger(event, payload, ref, join_ref);\n }\n for (let i = 0; i < this.stateChangeCallbacks.message.length; i++) {\n let [, callback] = this.stateChangeCallbacks.message[i];\n callback(msg);\n }\n });\n }\n leaveOpenTopic(topic) {\n let dupChannel = this.channels.find((c) => c.topic === topic && (c.isJoined() || c.isJoining()));\n if (dupChannel) {\n if (this.hasLogger())\n this.log(\"transport\", `leaving duplicate topic \"${topic}\"`);\n dupChannel.leave();\n }\n }\n};\nexport {\n Channel,\n LongPoll,\n Presence,\n serializer_default as Serializer,\n Socket\n};\n//# sourceMappingURL=phoenix.mjs.map\n","import { Channel, Socket } from 'phoenix'\nimport { apiVersion } from 'config'\nimport debug from 'lib/debug'\nimport splitUrlParams from 'lib/split-url-params'\n\nconst log = debug('seamly')\ntype CurrentConnectionState =\n | 'socket_closed' // Socket is closed.\n | 'channel_closed' // Channel is closed.\n | 'channel_erred' // Errors received from joined channel.\n | 'join_channel_succeeded' // Joined channel succesfully.\n | 'join_channel_erred' // Error on joining channel. This is usefull when you want to restart a chat sessions.\n | 'attach_channel_succeeded' // Attached channel to system.\n | 'attach_channel_erred' // Error attaching channel.\n\ntype ConnectionState = {\n connected: boolean\n ready: boolean\n currentState: CurrentConnectionState\n}\n\n// Subscribers set which are used to subscribe to changes in the conversation.\n// Needs to be outside of the ConversationConnector class so its not recreated for each instance.\nconst subscribers = new Set<Function>()\n\n// Syncs the lifecycle of the conversation with Preact. Each subscriber will fetch the latest value from the conversation if needed.\nconst emitChange = () => {\n // Call the callback function for each subscriber\n subscribers.forEach((callback) => callback())\n}\n\nexport default class ConversationConnector {\n #connectionListeners: ((_payload: ConnectionState) => boolean | void)[] = []\n\n accessToken: string\n\n channelName: string\n\n channelTopic: string\n\n url: string\n\n socket?: Socket\n\n channel: Channel\n\n async connect(\n url: string,\n channelName: string,\n channelTopic: string,\n accessToken: string,\n ) {\n this.url = url\n\n this.accessToken = accessToken\n this.channelName = channelName\n this.channelTopic = channelTopic\n const { url: splittedUrl, params } = splitUrlParams(this.url)\n\n this.socket = new Socket(splittedUrl, {\n params: { ...params, v: apiVersion },\n reconnectAfterMs: (tries) => {\n // Calculate the backoff time based on the number of tries.\n const backoff = 2 ** tries * 250\n\n // Limit the backoff time to 10 seconds.\n return Math.min(backoff, 10000)\n },\n })\n\n this.socket.onError((err) => {\n log('[SOCKET][ERROR]', err)\n })\n\n this.socket.onOpen(() => {\n log('[SOCKET]OPEN')\n })\n\n this.socket.onClose(() => {\n log('[SOCKET]CLOSE')\n this.#emitConnectionState({\n connected: false,\n ready: false,\n currentState: 'socket_closed',\n })\n })\n\n this.socket.connect()\n\n this.channel = this.socket.channel(this.channelTopic, {\n authorization: `Bearer ${this.accessToken}`,\n channelName: this.channelName,\n })\n\n this.start()\n\n this.channel.on('system', (msg) => {\n switch (msg.type) {\n case 'attach_channel_succeeded':\n this.#emitConnectionState({\n connected: true,\n ready: true,\n currentState: 'attach_channel_succeeded',\n })\n break\n }\n })\n\n this.channel.onClose(() => {\n log('[CHANNEL]CLOSE')\n this.#emitConnectionState({\n connected: false,\n ready: false,\n currentState: 'channel_closed',\n })\n })\n\n this.channel.onError((msg) => {\n log('[CHANNEL][ERROR]', msg)\n\n this.#emitConnectionState({\n connected: false,\n ready: false,\n currentState: 'channel_erred',\n })\n })\n\n this.#listenTo(\n 'ack',\n 'ui',\n 'error',\n 'participant',\n 'message',\n 'service_data',\n 'system',\n 'info',\n 'sync',\n )\n }\n\n start() {\n this.channel\n .join()\n .receive('ok', () => {\n log('[CHANNEL][JOIN] OK')\n this.#emitConnectionState({\n connected: true,\n ready: false,\n currentState: 'join_channel_succeeded',\n })\n })\n .receive('error', (err) => {\n log('[CHANNEL][JOIN] ERROR', err)\n this.#emitConnectionState({\n connected: false,\n ready: false,\n currentState: 'join_channel_erred',\n })\n })\n .receive('timeout', () => {\n log('[CHANEL][JOIN] Networking issue. Still waiting...')\n })\n }\n\n disconnect() {\n this.channel?.leave().receive('ok', () => {\n this.socket?.disconnect()\n log('[CHANNEL][LEAVE] OK')\n this.#connectionListeners = []\n })\n }\n\n #listenTo(...types: string[]) {\n types.forEach((type) => {\n this.channel.on(type, (msg) => {\n log('[RECEIVE]', type, msg)\n })\n })\n }\n\n onConnection(cb: (_payload: ConnectionState) => boolean | void) {\n this.#connectionListeners.push(cb)\n }\n\n #emitConnectionState(payload: ConnectionState) {\n this.#connectionListeners = this.#connectionListeners.filter((item) => {\n const complete = item(payload)\n\n // If we only want to execute the callback once, remove it from the listener\n return !complete\n })\n\n emitChange()\n }\n\n pushToChannel(\n command: string,\n payload: { type: string; error: unknown },\n timeout = 10000,\n ) {\n this.channel.push(command, payload, timeout)\n }\n\n // Adds a callback function to the subscribers set and returns a method to unsubscribe from the store.\n // This method is used to sync the state with the lifecycle of Preact.\n static subscribe(callback: Function) {\n subscribers.add(callback)\n\n // Returns a function that removes the callback from the subscribers set.\n return () => subscribers.delete(callback)\n }\n}\n","import type { Config } from 'config.types'\n\nexport const CSS_NAME = 'cvco'\n\nexport const apiVersion = '3'\n\nexport const userParticipantId = 'seamly-client-participant'\n\n// How long to debounce distinct changes in unread messages for before\n// broadcasting to the screen reader. This is done to avoid verbosity.\nexport const unreadScreenReaderWait = 2000\n\nexport const newMessageScreenReaderWait = 1000\n\nexport const screenReaderDebounceDelaySeconds = 10\n\nexport const activitySendDelay = 15000\n\nexport const maxCharacterWarningLimit = 50\n\nexport const maxCharacterSrDebounceDelay = 300\n\nexport const defaultTransitionTimeMs = 300\n\n// How long to wait before we decide the user isn't typing\nexport const typingTimeout = 2000\n\nexport const defaultConfig: Partial<Config> = {\n namespace: 'default',\n layoutMode: 'window', // \"window\", \"inline\" (\"sidebar\")\n messages: {\n agent: {\n showAvatar: false, // true, \"inline\"\n showName: false,\n },\n user: {\n showAvatar: false, // true, \"inline\"\n showName: false,\n },\n timeIndicator: {\n enabled: false,\n threshold: 3600000, // Default threshold is an hour in milliseconds\n },\n },\n}\n","import { createAsyncThunk } from '@reduxjs/toolkit'\nimport SeamlySessionExpiredError from 'api/errors/seamly-session-expired-error'\nimport SeamlyUnavailableError from 'api/errors/seamly-unavailable-error'\nimport { initializeConfig, resetConfig } from 'domains/config/actions'\nimport createDebouncedAsyncThunk from 'domains/redux/create-debounced-async-thunk'\nimport { ThunkAPI } from 'domains/redux/redux.types'\nimport { initializeVisibility } from 'domains/visibility/actions'\nimport { actionTypes } from 'ui/utils/seamly-utils'\nimport type { Config } from 'config.types'\nimport type { RootState } from 'domains/store'\n\nexport const initializeApp = createAsyncThunk<\n {\n initialState: RootState['state']['initialState']\n contentLocale: string\n userLocale: string\n config: Config\n },\n void,\n ThunkAPI\n>('initializeApp', async (_, { extra: { api, config }, rejectWithValue }) => {\n let contentLocale = config?.context?.contentLocale\n let userLocale = config?.context?.userLocale\n\n const environment =\n config.api.sendEnvironment !== false\n ? api.getEnvironment()\n : config.api.sendEnvironment\n\n try {\n if (api.hasConversation()) {\n const initialState = await api.getConversationIntitialState()\n\n contentLocale = initialState.context.contentLocale || contentLocale\n userLocale = initialState.context.userLocale || userLocale\n\n api.sendContext({ ...initialState.context, environment })\n return { initialState, contentLocale, userLocale, config }\n } else {\n if (config?.context?.topic) {\n api.send('action', {\n type: actionTypes.setTopic,\n body: {\n name: config.context.topic,\n // Separate fallback message is not needed here. Only an attached service will use this, but none will\n // be attached before the conversation has started (meaning the fallback message will never be shown).\n fallbackMessage: config.context.topic,\n },\n })\n }\n\n // Send context\n api.sendContext({\n ...config.context,\n environment,\n })\n return { initialState: undefined, contentLocale, userLocale, config }\n }\n } catch (e) {\n if (e instanceof SeamlySessionExpiredError) {\n const err = new SeamlySessionExpiredError()\n\n return rejectWithValue({\n name: err.name,\n message: err.message,\n originalEvent: err.originalEvent,\n originalError: err.originalError,\n action: err.action,\n })\n }\n\n const err = new SeamlyUnavailableError()\n return rejectWithValue({\n name: err.name,\n message: err.message,\n langKey: err.langKey,\n })\n }\n})\n\nexport const resetApp = createDebouncedAsyncThunk<unknown, void, ThunkAPI>(\n 'resetApp',\n async (_, { dispatch, extra: { api } }) => {\n await api.disconnect()\n api.clearStore()\n\n dispatch(resetConfig())\n await dispatch(initializeConfig())\n await dispatch(initializeApp())\n\n dispatch(initializeVisibility())\n },\n {\n wait: 2000,\n leading: true,\n },\n)\n","import {\n AsyncThunkPayloadCreator,\n Dispatch,\n createAsyncThunk,\n} from '@reduxjs/toolkit'\nimport { ThunkAPI } from './redux.types'\n\ntype DebounceOptionsType = {\n /**\n * The number of milliseconds to delay\n * @defaultValue `300`\n */\n wait: number\n\n /**\n * The maximum time `payloadCreator` is allowed to be delayed before\n * it's invoked.\n * @defaultValue `0`\n */\n maxWait?: number\n\n /**\n * Specify invoking on the leading edge of the timeout.\n * @defaultValue `false`\n */\n leading?: boolean\n}\n\ntype AsyncThunkConfig = ThunkAPI & {\n dispatch?: Dispatch\n rejectValue?: unknown\n serializedErrorType?: unknown\n pendingMeta?: unknown\n fulfilledMeta?: unknown\n rejectedMeta?: unknown\n}\n\n/**\n * A debounced analogue of the `createAsyncThunk` from `@reduxjs/toolkit`\n * @param typePrefix - a string action type value\n * @param payloadCreator - a callback function that should return a promise containing the result of some asynchronous logic\n * @param debounceOptions - the debounce options object\n */\nconst createDebouncedAsyncThunk = <\n Returned,\n ThunkArg,\n ThunkApiConfig extends AsyncThunkConfig,\n>(\n typePrefix: string,\n payloadCreator: AsyncThunkPayloadCreator<Returned, ThunkArg, ThunkApiConfig>,\n debounceOptions?: DebounceOptionsType,\n) => {\n const { wait = 300, maxWait = 0, leading = false } = debounceOptions ?? {}\n\n let debounceTimer: ReturnType<typeof setTimeout> = null\n let maxWaitTimer: ReturnType<typeof setTimeout> = null\n let resolve: ((_value: boolean) => void) | undefined\n\n const cancel = (): void => {\n if (resolve) {\n resolve(false)\n resolve = undefined\n }\n }\n\n const invoke = (): void => {\n clearTimeout(maxWaitTimer)\n maxWaitTimer = undefined\n\n if (resolve) {\n resolve(true)\n resolve = undefined\n }\n }\n\n const debounceExecutionCondition = (): Promise<boolean> | boolean => {\n const immediate = leading && !debounceTimer\n\n // Start debounced condition resolution\n clearTimeout(debounceTimer)\n debounceTimer = setTimeout(() => {\n invoke()\n debounceTimer = null\n }, wait)\n\n if (immediate) {\n return true\n }\n\n cancel()\n\n // Start max wait condition resolution\n if (maxWait && !maxWaitTimer) {\n maxWaitTimer = setTimeout(invoke, maxWait)\n }\n\n return new Promise((res) => {\n resolve = res\n })\n }\n\n return createAsyncThunk(typePrefix, payloadCreator, {\n condition: debounceExecutionCondition,\n })\n}\n\nexport default createDebouncedAsyncThunk\n","import { createSelector } from '@reduxjs/toolkit'\n\nexport const selectUserHasResponded = createSelector(\n ({ app }) => app,\n ({ userHasResponded }) => userHasResponded,\n)\n","import { createSlice } from '@reduxjs/toolkit'\nimport { initializeApp, resetApp } from 'domains/app/actions'\nimport { AppState } from 'domains/app/app.types'\n\nconst initialState: AppState = {\n userHasResponded: false,\n}\n\nexport const appSlice = createSlice({\n name: 'app',\n initialState,\n reducers: {\n setHasResponded: (state, { payload }) => {\n state.userHasResponded = payload\n },\n },\n extraReducers: (builder) => {\n builder\n .addCase(resetApp.pending, () => initialState)\n .addCase(initializeApp.fulfilled, (state, { payload }) => {\n if (payload.initialState && 'userResponded' in payload.initialState) {\n state.userHasResponded = payload.initialState?.userResponded\n }\n })\n },\n})\n\nexport const { setHasResponded } = appSlice.actions\n\nexport default appSlice.reducer\n","import { createAsyncThunk } from '@reduxjs/toolkit'\nimport { Config, ConfigResponse } from 'config.types'\nimport { ThunkAPI } from 'domains/redux/redux.types'\n\ntype InitializeConfigReturn = ConfigResponse & {\n defaultContentLocale: ConfigResponse['defaultLocale']\n connectWhenInView: Config['connectWhenInView']\n}\n\nexport const initializeConfig = createAsyncThunk<\n InitializeConfigReturn,\n void,\n ThunkAPI\n>(\n 'initializeConfig',\n async (_, { extra: { api, config }, rejectWithValue }) => {\n try {\n const {\n features,\n defaultLocale,\n preChat,\n agentParticipant,\n userParticipant,\n startChatIcon,\n } = await api.getConfig()\n\n const defaultContentLocale =\n config?.context?.contentLocale || defaultLocale\n const { connectWhenInView } = config\n\n return {\n features,\n defaultLocale,\n preChat,\n agentParticipant,\n userParticipant,\n startChatIcon,\n defaultContentLocale,\n connectWhenInView,\n }\n } catch (error) {\n return rejectWithValue(error)\n }\n },\n)\n\nexport const resetConfig = createAsyncThunk<unknown, void, ThunkAPI>(\n 'resetConfig',\n async (_, { extra: { config } }) => {\n return config\n },\n)\n","import { useSelector } from 'react-redux'\nimport { selectConfig } from 'domains/config/selectors'\n\nexport const useConfig = () => useSelector(selectConfig)\n\nexport function useParticipants() {\n const { agentParticipant, userParticipant } = useConfig()\n\n return {\n agent: agentParticipant,\n user: userParticipant,\n }\n}\n\nexport function useStartChatIcon() {\n const { startChatIcon } = useConfig()\n\n return startChatIcon\n}\n","import { createSelector } from '@reduxjs/toolkit'\nimport { visibilityStates } from 'domains/visibility/constants'\nimport type { VisibilityOptions } from 'config.types'\nimport type { RootState } from 'domains/store'\n\nexport const selectConfig = createSelector(\n ({ config }: RootState) => config,\n (config) => {\n let newConfig = {\n visible: (config?.layoutMode === 'inline'\n ? visibilityStates.open\n : visibilityStates.minimized) as VisibilityOptions,\n appContainerClassNames: config?.appContainerClassNames || [],\n ...config,\n }\n if (typeof newConfig.appContainerClassNames === 'function') {\n newConfig = {\n ...newConfig,\n appContainerClassNames: newConfig.appContainerClassNames(newConfig),\n }\n }\n return newConfig\n },\n)\n","import { PayloadAction, createSlice } from '@reduxjs/toolkit'\nimport { defaultConfig } from 'config'\nimport { Config } from 'config.types'\nimport { initializeConfig, resetConfig } from 'domains/config/actions'\nimport { pick } from 'ui/utils/general-utils'\nimport type { ChannelEvent } from 'domains/store/store.types'\n\nexport const initialConfigState: Config = {\n ...defaultConfig,\n api: {\n domain: '',\n key: '',\n secure: true,\n sendEnvironment: true,\n },\n notificationAudioURL: undefined,\n hideOnNoUserResponse: false,\n connectWhenInView: true,\n showDisclaimer: false,\n showSuggestions: true,\n preChat: {\n enterDelay: 1000,\n exitAfter: 4000,\n },\n continueChat: {\n enterDelay: 0,\n exitAfter: 2000,\n },\n customComponents: {},\n defaults: {\n visible: null,\n },\n preChatEvents: [],\n}\n\nconst configKeys: (keyof Config)[] = [\n 'hideOnNoUserResponse',\n 'connectWhenInView',\n 'showDisclaimer',\n 'showSuggestions',\n 'continueChat',\n 'preChat',\n 'namespace',\n 'customComponents',\n 'defaults',\n 'layoutMode',\n 'api',\n 'zIndex',\n 'context',\n 'appContainerClassNames',\n 'messages',\n 'visible',\n 'visibilityCallback',\n 'errorCallback',\n 'agentParticipant',\n 'userParticipant',\n 'startChatIcon',\n 'notificationAudioURL',\n]\n\nconst updateState = (state, config: Config): Config => {\n const { messages, ...partialConfig } = pick(config, configKeys)\n let newState = state\n if (Object.keys(partialConfig).length > 0) {\n newState = {\n ...newState,\n ...partialConfig,\n }\n }\n if (messages) {\n newState = {\n ...newState,\n messages: {\n ...newState.messages,\n ...messages,\n },\n }\n }\n return newState\n}\n\nexport const configSlice = createSlice({\n name: 'config',\n initialState: initialConfigState,\n reducers: {\n setConfig: (state, { payload }: PayloadAction<Config>) =>\n updateState(state, payload),\n updateConfig: (state, { payload }: PayloadAction<Config>) =>\n updateState(state, payload),\n setPreChatEvents: (state, { payload }: PayloadAction<ChannelEvent[]>) => {\n state.preChatEvents = payload\n },\n },\n extraReducers: (builder) => {\n builder\n .addCase(resetConfig.fulfilled, (config) => config)\n .addCase(\n initializeConfig.fulfilled,\n (\n state,\n {\n payload: {\n preChat,\n agentParticipant,\n userParticipant,\n startChatIcon,\n defaultContentLocale,\n },\n },\n ) => {\n // @ts-ignore\n state.preChatEvents = preChat.map((payload) => ({\n type: 'message',\n payload,\n }))\n\n state.context.contentLocale = defaultContentLocale\n state.agentParticipant = agentParticipant\n state.userParticipant = userParticipant\n state.startChatIcon = startChatIcon\n },\n )\n },\n})\n\nexport const { setConfig, updateConfig, setPreChatEvents } = configSlice.actions\n\nexport default configSlice.reducer\n","import { createAction } from '@reduxjs/toolkit'\nimport SeamlyBaseError from 'api/errors/seamly-base-error'\nimport SeamlyConfigurationError from 'api/errors/seamly-configuration-error'\nimport SeamlyGeneralError from 'api/errors/seamly-general-error'\nimport SeamlyOfflineError from 'api/errors/seamly-offline-error'\nimport SeamlySessionExpiredError from 'api/errors/seamly-session-expired-error'\nimport SeamlyUnauthorizedError from 'api/errors/seamly-unauthorized-error'\nimport SeamlyUnavailableError from 'api/errors/seamly-unavailable-error'\nimport { selectConfig } from 'domains/config/selectors'\n\nconst ErrorTypes = {\n SeamlyGeneralError,\n SeamlyConfigurationError,\n SeamlySessionExpiredError,\n SeamlyOfflineError,\n SeamlyUnauthorizedError,\n SeamlyUnavailableError,\n}\n\nexport const catchError = createAction('catch-error', (error) => ({\n payload: error,\n}))\n\nexport function createErrorsMiddleware({ api: seamlyApi }) {\n return ({ getState }) => {\n const handleError = (action) => {\n const { errorCallback, namespace, api, layoutMode } =\n selectConfig(getState())\n\n const { error, type } = action\n\n const errorType = ErrorTypes[error?.name]\n ? new ErrorTypes[error.name](error)\n : new SeamlyBaseError(error)\n\n errorCallback?.(errorType, {\n namespace,\n api,\n layoutMode,\n conversationUrl: seamlyApi.getConversationUrl(),\n action: type ? action : undefined,\n })\n }\n\n return (next) => (action) => {\n try {\n if (action.payload?.originalEvent?.payload) {\n handleError({\n error: action.payload,\n type: action.payload?.originalEvent?.payload?.type,\n })\n } else if (action.payload?.originalError) {\n handleError({\n error: action.payload,\n type: undefined,\n })\n }\n return next(action)\n } catch (error) {\n handleError({ error })\n throw error\n }\n }\n }\n}\n","import { createSlice } from '@reduxjs/toolkit'\nimport { resetApp } from 'domains/app/actions'\nimport { ControlState } from 'domains/forms/forms.types'\n\nconst initialFormState: Record<string, ControlState> = {\n controls: {},\n}\n\nconst initialControlState: ControlState = {\n value: '',\n touched: false,\n}\n\nconst initialState = {\n controls: initialControlState,\n}\n\nexport const formsSlice = createSlice({\n name: 'forms',\n initialState,\n reducers: {\n registerForm: (state, { payload: { persistData, formId } }) => {\n const formState = persistData\n ? state[formId] ?? { ...initialFormState, persistData }\n : { ...initialFormState, persistData }\n\n state[formId] = formState\n },\n deregisterForm: (state, { payload: { formId } }) => {\n if (!state[formId]?.persistData) {\n delete state[formId]\n }\n\n return state\n },\n // Form control handlers\n registerControl: (state, { payload: { name, formId } }) => {\n state[formId].controls = {\n [name]: initialControlState,\n }\n },\n deregisterControl: (state, { payload: { name, formId } }) => {\n const form = state[formId]\n if (!form) {\n return state\n }\n if (form.persistData) {\n return state\n }\n const controls = { ...form.controls }\n delete controls[name]\n return {\n ...state,\n [formId]: {\n ...form,\n controls,\n },\n }\n },\n updateControlValue: (state, { payload: { formId, name, value } }) => {\n // return updateFormControl(state, formId, name, { value })\n if (!state[formId]?.controls) return\n state[formId].controls[name].value = value\n },\n updateControlTouched: (state, { payload: { formId, name, touched } }) => {\n if (!state[formId]?.controls[name]) return\n state[formId].controls[name].touched = touched\n },\n },\n extraReducers: (builder) => {\n builder.addCase(resetApp.pending, () => initialState)\n },\n})\n\nexport const {\n registerForm,\n deregisterForm,\n registerControl,\n deregisterControl,\n updateControlValue,\n updateControlTouched,\n} = formsSlice.actions\n\nexport default formsSlice.reducer\n","import { createAsyncThunk } from '@reduxjs/toolkit'\nimport { ThunkAPI } from 'domains/redux/redux.types'\nimport type { I18nState } from 'domains/i18n/i18n.types'\n\nexport const setLocale = createAsyncThunk<\n {\n translations: I18nState['translations']\n userLocale: I18nState['userLocale']\n },\n string,\n ThunkAPI\n>(\n 'setLocale',\n async (userLocale, { extra: { api }, rejectWithValue }) => {\n try {\n const response = await api.getTranslations(userLocale)\n\n return {\n translations: response,\n userLocale,\n }\n } catch (error) {\n return rejectWithValue(error)\n }\n },\n {\n condition: (locale, { getState }) => {\n const {\n i18n: { isLoading, userLocale },\n } = getState()\n\n if (locale === userLocale || isLoading) {\n // Already fetched or in progress, don't need to re-fetch\n return false\n }\n\n return true\n },\n },\n)\n","export default function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];\n return arr2;\n}","export default function _typeof(o) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n return typeof o;\n } : function (o) {\n return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n }, _typeof(o);\n}","import _typeof from \"./typeof.js\";\nimport toPrimitive from \"./toPrimitive.js\";\nexport default function toPropertyKey(t) {\n var i = toPrimitive(t, \"string\");\n return \"symbol\" == _typeof(i) ? i : String(i);\n}","import _typeof from \"./typeof.js\";\nexport default function toPrimitive(t, r) {\n if (\"object\" != _typeof(t) || !t) return t;\n var e = t[Symbol.toPrimitive];\n if (void 0 !== e) {\n var i = e.call(t, r || \"default\");\n if (\"object\" != _typeof(i)) return i;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (\"string\" === r ? String : Number)(t);\n}","import toPropertyKey from \"./toPropertyKey.js\";\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, toPropertyKey(descriptor.key), descriptor);\n }\n}\nexport default function _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}","import toPropertyKey from \"./toPropertyKey.js\";\nexport default function _defineProperty(obj, key, value) {\n key = toPropertyKey(key);\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}","/* \n * Copyright 2017, Emanuel Rabina (http://www.ultraq.net.nz/)\n * \n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * \n * http://www.apache.org/licenses/LICENSE-2.0\n * \n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * Flattens an array of arrays of infinite depth into a single-dimension array.\n * \n * > This is now natively in JavaScript as the `flat` method on an Array\n * > instance. [Check MDN for which browsers have access to this feature](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/flat).\n * > If you can't use `flat`, then this method will do the job 🙂\n * \n * @param {Array} array\n * @return {Array} Flattened array.\n */\nexport function flatten(array) {\n return array.reduce(function (accumulator, value) {\n return accumulator.concat(Array.isArray(value) ? flatten(value) : value);\n }, []);\n}\n/**\n * Creates an array of numbers from the starting value (inclusive) to the end\n * (exclusive), with an optional step (the gap between values).\n * \n * @param {Number} start\n * The value to start at, the first item in the returned array.\n * @param {Number} end\n * The value to end with, the last item in the returned array.\n * @param {Number} [step=1]\n * The increment/gap between values, defaults to 1.\n * @return {Array} An array encompassing the given range.\n */\n\nexport function range(start, end) {\n var step = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1;\n return Array.apply(0, Array(Math.ceil((end - start) / step))).map(function (empty, index) {\n return index * step + start;\n });\n}\n/**\n * Remove and return the first item from `array` that matches the predicate\n * function.\n * \n * @param {Array} array\n * @param {Function} predicate\n * Invoked with the array item.\n * @return {Object} The matching item, or `null` if no match was found.\n */\n\nexport function remove(array, predicate) {\n return array.find(function (item, index) {\n if (predicate(item)) {\n array.splice(index, 1);\n return item;\n }\n });\n}\n\n//# sourceMappingURL=array-utils.es.js.map","import _slicedToArray from '@babel/runtime/helpers/slicedToArray';\nimport _classCallCheck from '@babel/runtime/helpers/classCallCheck';\nimport _createClass from '@babel/runtime/helpers/createClass';\nimport _defineProperty from '@babel/runtime/helpers/defineProperty';\nimport { flatten } from '@ultraq/array-utils';\nimport { memoize } from '@ultraq/function-utils';\n\n/* \n * Copyright 2019, Emanuel Rabina (http://www.ultraq.net.nz/)\n * \n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * \n * http://www.apache.org/licenses/LICENSE-2.0\n * \n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * Most branch-based type handlers are based around \"cases\".\n * For example, `select` and `plural` compare compare a value\n * to \"case keys\" to choose a subtranslation.\n * \n * This util splits \"matches\" portions provided to the aforementioned\n * handlers into case strings, and extracts any prepended arguments\n * (for example, `plural` supports an `offset:n` argument used for\n * populating the magic `#` variable).\n * \n * @param {String} string\n * @return {Object} The `cases` key points to a map of all cases.\n * The `arguments` key points to a list of prepended arguments.\n */\nfunction parseCases(string) {\n var isWhitespace = function isWhitespace(ch) {\n return /\\s/.test(ch);\n };\n\n var args = [];\n var cases = {};\n var currTermStart = 0;\n var latestTerm = null;\n var inTerm = false;\n var i = 0;\n\n while (i < string.length) {\n // Term ended\n if (inTerm && (isWhitespace(string[i]) || string[i] === '{')) {\n inTerm = false;\n latestTerm = string.slice(currTermStart, i); // We want to process the opening char again so the case will be properly registered.\n\n if (string[i] === '{') {\n i--;\n }\n } // New term\n else if (!inTerm && !isWhitespace(string[i])) {\n var caseBody = string[i] === '{'; // If there's a previous term, we can either handle a whole\n // case, or add that as an argument.\n\n if (latestTerm && caseBody) {\n var branchEndIndex = findClosingBracket(string, i);\n\n if (branchEndIndex === -1) {\n throw new Error(\"Unbalanced curly braces in string: \\\"\".concat(string, \"\\\"\"));\n }\n\n cases[latestTerm] = string.slice(i + 1, branchEndIndex); // Don't include the braces\n\n i = branchEndIndex; // Will be moved up where needed at end of loop.\n\n latestTerm = null;\n } else {\n if (latestTerm) {\n args.push(latestTerm);\n latestTerm = null;\n }\n\n inTerm = true;\n currTermStart = i;\n }\n }\n\n i++;\n }\n\n if (inTerm) {\n latestTerm = string.slice(currTermStart);\n }\n\n if (latestTerm) {\n args.push(latestTerm);\n }\n\n return {\n args: args,\n cases: cases\n };\n}\n/**\n * Finds the index of the matching closing curly bracket, including through\n * strings that could have nested brackets.\n * \n * @param {String} string\n * @param {Number} fromIndex\n * @return {Number} The index of the matching closing bracket, or -1 if no\n * closing bracket could be found.\n */\n\nfunction findClosingBracket(string, fromIndex) {\n var depth = 0;\n\n for (var i = fromIndex + 1; i < string.length; i++) {\n var char = string.charAt(i);\n\n if (char === '}') {\n if (depth === 0) {\n return i;\n }\n\n depth--;\n } else if (char === '{') {\n depth++;\n }\n }\n\n return -1;\n}\n/**\n * Split a `{key, type, format}` block into those 3 parts, taking into account\n * nested message syntax that can exist in the `format` part.\n * \n * @param {String} block\n * @return {Array}\n * An array with `key`, `type`, and `format` items in that order, if present\n * in the formatted argument block.\n */\n\nfunction splitFormattedArgument(block) {\n return split(block.slice(1, -1), ',', 3);\n}\n/**\n * Like `String.prototype.split()` but where the limit parameter causes the\n * remainder of the string to be grouped together in a final entry.\n * \n * @private\n * @param {String} string\n * @param {String} separator\n * @param {Number} limit\n * @param {Array} [accumulator=[]]\n * @return {Array}\n */\n\nfunction split(string, separator, limit) {\n var accumulator = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : [];\n\n if (!string) {\n return accumulator;\n }\n\n if (limit === 1) {\n accumulator.push(string);\n return accumulator;\n }\n\n var indexOfDelimiter = string.indexOf(separator);\n\n if (indexOfDelimiter === -1) {\n accumulator.push(string);\n return accumulator;\n }\n\n var head = string.substring(0, indexOfDelimiter).trim();\n var tail = string.substring(indexOfDelimiter + separator.length + 1).trim();\n accumulator.push(head);\n return split(tail, separator, limit - 1, accumulator);\n}\n\n/**\n * The main class for formatting messages.\n * \n * @author Emanuel Rabina\n */\n\nvar MessageFormatter = /*#__PURE__*/function () {\n /**\n * Creates a new formatter that can work using any of the custom type handlers\n * you register.\n * \n * @param {String} locale\n * @param {Object} [typeHandlers={}]\n * Optional object where the keys are the names of the types to register,\n * their values being the functions that will return a nicely formatted\n * string for the data and locale they are given.\n */\n function MessageFormatter(locale) {\n var _this = this;\n\n var typeHandlers = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n _classCallCheck(this, MessageFormatter);\n\n _defineProperty(this, \"format\", memoize(function (message) {\n var values = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n return flatten(_this.process(message, values)).join('');\n }));\n\n this.locale = locale;\n this.typeHandlers = typeHandlers;\n }\n /**\n * Formats an ICU message syntax string using `values` for placeholder data\n * and any currently-registered type handlers.\n * \n * @param {String} message\n * @param {Object} [values={}]\n * @return {String}\n */\n\n\n _createClass(MessageFormatter, [{\n key: \"process\",\n value:\n /**\n * Process an ICU message syntax string using `values` for placeholder data\n * and any currently-registered type handlers. The result of this method is\n * an array of the component parts after they have been processed in turn by\n * their own type handlers. This raw output is useful for other renderers,\n * eg: React where components can be used instead of being forced to return\n * raw strings.\n * \n * This method is used by {@link MessageFormatter#format} where it acts as a\n * string renderer.\n * \n * @param {String} message\n * @param {Object} [values={}]\n * @return {Array}\n */\n function process(message) {\n var values = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n if (!message) {\n return [];\n }\n\n var blockStartIndex = message.indexOf('{');\n\n if (blockStartIndex !== -1) {\n var blockEndIndex = findClosingBracket(message, blockStartIndex);\n\n if (blockEndIndex !== -1) {\n var block = message.substring(blockStartIndex, blockEndIndex + 1);\n\n if (block) {\n var result = [];\n var head = message.substring(0, blockStartIndex);\n\n if (head) {\n result.push(head);\n }\n\n var _splitFormattedArgume = splitFormattedArgument(block),\n _splitFormattedArgume2 = _slicedToArray(_splitFormattedArgume, 3),\n key = _splitFormattedArgume2[0],\n type = _splitFormattedArgume2[1],\n format = _splitFormattedArgume2[2];\n\n var body = values[key];\n\n if (body === null || body === undefined) {\n body = '';\n }\n\n var typeHandler = type && this.typeHandlers[type];\n result.push(typeHandler ? typeHandler(body, format, this.locale, values, this.process.bind(this)) : body);\n var tail = message.substring(blockEndIndex + 1);\n\n if (tail) {\n result.push(this.process(tail, values));\n }\n\n return result;\n }\n } else {\n throw new Error(\"Unbalanced curly braces in string: \\\"\".concat(message, \"\\\"\"));\n }\n }\n\n return [message];\n }\n }]);\n\n return MessageFormatter;\n}();\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\nvar pluralFormatter;\nvar keyCounter = 0; // All the special keywords that can be used in `plural` blocks for the various branches\n\nvar ONE = 'one';\nvar OTHER$1 = 'other';\n/**\n * @private\n * @param {String} caseBody\n * @param {Number} value\n * @return {Object} {caseBody: string, numberValues: object}\n */\n\nfunction replaceNumberSign(caseBody, value) {\n var i = 0;\n var output = '';\n var numBraces = 0;\n var numberValues = {};\n\n while (i < caseBody.length) {\n if (caseBody[i] === '#' && !numBraces) {\n var keyParam = \"__hashToken\".concat(keyCounter++);\n output += \"{\".concat(keyParam, \", number}\");\n numberValues[keyParam] = value;\n } else {\n output += caseBody[i];\n }\n\n if (caseBody[i] === '{') {\n numBraces++;\n } else if (caseBody[i] === '}') {\n numBraces--;\n }\n\n i++;\n }\n\n return {\n caseBody: output,\n numberValues: numberValues\n };\n}\n/**\n * Handler for `plural` statements within ICU message syntax strings. Returns\n * a formatted string for the branch that closely matches the current value.\n * \n * See https://formatjs.io/docs/core-concepts/icu-syntax#plural-format for more\n * details on how the `plural` statement works.\n * \n * @param {String} value\n * @param {String} matches\n * @param {String} locale\n * @param {String} values\n * @param {Function} format\n * @return {String}\n */\n\n\nfunction pluralTypeHandler(value) {\n var matches = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n var locale = arguments.length > 2 ? arguments[2] : undefined;\n var values = arguments.length > 3 ? arguments[3] : undefined;\n var format = arguments.length > 4 ? arguments[4] : undefined;\n\n var _parseCases = parseCases(matches),\n args = _parseCases.args,\n cases = _parseCases.cases;\n\n var intValue = parseInt(value);\n args.forEach(function (arg) {\n if (arg.startsWith('offset:')) {\n intValue -= parseInt(arg.slice('offset:'.length));\n }\n });\n var keywordPossibilities = [];\n\n if ('PluralRules' in Intl) {\n // Effectively memoize because instantiation of `Int.*` objects is expensive.\n if (pluralFormatter === undefined || pluralFormatter.resolvedOptions().locale !== locale) {\n pluralFormatter = new Intl.PluralRules(locale);\n }\n\n var pluralKeyword = pluralFormatter.select(intValue); // Other is always added last with least priority, so we don't want to add it here.\n\n if (pluralKeyword !== OTHER$1) {\n keywordPossibilities.push(pluralKeyword);\n }\n }\n\n if (intValue === 1) {\n keywordPossibilities.push(ONE);\n }\n\n keywordPossibilities.push(\"=\".concat(intValue), OTHER$1);\n\n for (var i = 0; i < keywordPossibilities.length; i++) {\n var keyword = keywordPossibilities[i];\n\n if (keyword in cases) {\n var _replaceNumberSign = replaceNumberSign(cases[keyword], intValue),\n caseBody = _replaceNumberSign.caseBody,\n numberValues = _replaceNumberSign.numberValues;\n\n return format(caseBody, _objectSpread(_objectSpread({}, values), numberValues));\n }\n }\n\n return value;\n}\n\n/* \n * Copyright 2019, Emanuel Rabina (http://www.ultraq.net.nz/)\n * \n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * \n * http://www.apache.org/licenses/LICENSE-2.0\n * \n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nvar OTHER = 'other';\n/**\n * Handler for `select` statements within ICU message syntax strings. Returns\n * a formatted string for the branch that closely matches the current value.\n * \n * See https://formatjs.io/docs/core-concepts/icu-syntax#select-format for more\n * details on how the `select` statement works.\n * \n * @param {String} value\n * @param {String} matches\n * @param {String} locale\n * @param {String} values\n * @param {Function} format\n * @return {String}\n */\n\nfunction selectTypeHandler(value) {\n var matches = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n var values = arguments.length > 3 ? arguments[3] : undefined;\n var format = arguments.length > 4 ? arguments[4] : undefined;\n\n var _parseCases = parseCases(matches),\n cases = _parseCases.cases;\n\n if (value in cases) {\n return format(cases[value], values);\n } else if (OTHER in cases) {\n return format(cases[OTHER], values);\n }\n\n return value;\n}\n\nexport { MessageFormatter, findClosingBracket, parseCases, pluralTypeHandler, selectTypeHandler, splitFormattedArgument };\n//# sourceMappingURL=icu-message-formatter.es.js.map\n","/**\n * A higher-order function to apply [memoization](https://en.wikipedia.org/wiki/Memoization).\n * \n * If memoizing a recursive function, then memoize and define the function at\n * the same time so you can make a call to the memoized function, eg:\n * \n * ```javascript\n * const myFunction = memoize(() => myFunction());\n * ```\n * \n * @param {Function} func\n * @return {Function} \n */\nexport function memoize(func) {\n var cache = {};\n return function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var key = args.length ? args.map(function (arg) {\n return arg === null ? 'null' : arg === undefined ? 'undefined' : typeof arg === 'function' ? arg.toString() : arg instanceof Date ? arg.toISOString() : JSON.stringify(arg);\n }).join('|') : '_(no-args)_';\n\n if (Object.prototype.hasOwnProperty.call(cache, key)) {\n return cache[key];\n }\n\n var result = func.apply(void 0, args);\n cache[key] = result;\n return result;\n };\n}\n\n//# sourceMappingURL=function-utils.es.js.map","export default function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}","import arrayWithHoles from \"./arrayWithHoles.js\";\nimport iterableToArrayLimit from \"./iterableToArrayLimit.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableRest from \"./nonIterableRest.js\";\nexport default function _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}","export default function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}","export default function _iterableToArrayLimit(r, l) {\n var t = null == r ? null : \"undefined\" != typeof Symbol && r[Symbol.iterator] || r[\"@@iterator\"];\n if (null != t) {\n var e,\n n,\n i,\n u,\n a = [],\n f = !0,\n o = !1;\n try {\n if (i = (t = t.call(r)).next, 0 === l) {\n if (Object(t) !== t) return;\n f = !1;\n } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0);\n } catch (r) {\n o = !0, n = r;\n } finally {\n try {\n if (!f && null != t[\"return\"] && (u = t[\"return\"](), Object(u) !== u)) return;\n } finally {\n if (o) throw n;\n }\n }\n return a;\n }\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}","export default function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","import {\n MessageFormatter,\n pluralTypeHandler,\n selectTypeHandler,\n} from '@ultraq/icu-message-formatter'\nimport { useCallback } from 'preact/hooks'\nimport { useSelector } from 'react-redux'\nimport {\n selectInitialLocale,\n selectIsLoading,\n selectLocale,\n selectTranslations,\n} from 'domains/i18n/selectors'\n\n// pluralTypeHandler. Since we only use exact plural matches (=0, =1 etc) we can\n// safely use en-GB all the time.\nconst formatter = new MessageFormatter('en-GB', {\n plural: pluralTypeHandler,\n select: selectTypeHandler,\n})\n\nexport function useI18n() {\n const translations = useSelector(selectTranslations)\n const userLocale = useSelector(selectLocale)\n const initialLocale = useSelector(selectInitialLocale)\n const isLoading = useSelector(selectIsLoading)\n\n const t = useCallback(\n (key: string, values = {}) => {\n const translation = translations[key]\n if (!translation) {\n if (isLoading) return null\n\n console.warn(\n `Translation key: ${key} is missing in locale: ${userLocale}`,\n )\n return null\n }\n return formatter.format(translation, values)\n },\n [translations, userLocale, isLoading],\n )\n\n return {\n t,\n userLocale,\n initialLocale,\n }\n}\n","import { createSelector } from '@reduxjs/toolkit'\nimport type { RootState } from 'domains/store'\n\nexport const selectTranslations = createSelector(\n ({ i18n }: RootState) => i18n,\n ({ translations }) => translations,\n)\n\nexport const selectInitialLocale = createSelector(\n ({ i18n }: RootState) => i18n,\n ({ initialLocale }) => initialLocale,\n)\n\nexport const selectLocale = createSelector(\n ({ i18n }: RootState) => i18n,\n ({ userLocale }) => userLocale,\n)\n\nexport const selectIsLoading = createSelector(\n ({ i18n }: RootState) => i18n,\n ({ isLoading }) => isLoading,\n)\n","import { useMemo } from 'preact/hooks'\nimport { useSelector } from 'react-redux'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { selectError, selectHasError } from './selectors'\n\nexport function useInterrupt() {\n const { t } = useI18n()\n const error = useSelector(selectError)\n const hasError = useSelector(selectHasError)\n\n const meta = useMemo(() => {\n if (!hasError) {\n return {\n title: undefined,\n message: undefined,\n srText: undefined,\n buttonText: undefined,\n originalError: undefined,\n }\n }\n\n const { langKey, action } = error\n const title = t(`${langKey}.title`)\n const message = t(`${langKey}.message`)\n const srText = t(`${langKey}.srText`)\n const buttonText = action ? t(`${langKey}.buttonText`) : null\n\n return {\n ...(langKey ? { title, message, srText } : {}),\n ...(action ? { action } : {}),\n ...(action && langKey ? { buttonText } : {}),\n originalError: error,\n }\n }, [hasError, error, t])\n\n return { hasError, meta, error }\n}\n","import { createSelector } from '@reduxjs/toolkit'\nimport { RootState } from 'domains/store'\n\nexport const selectError = createSelector(\n ({ interrupt }: RootState) => interrupt,\n ({ error }: RootState['interrupt']) => error,\n)\n\nexport const selectHasError = createSelector(selectError, (error) =>\n Boolean(error),\n)\n","import { createSlice, isAnyOf } from '@reduxjs/toolkit'\nimport { initializeApp } from 'domains/app/actions'\nimport { initializeConfig } from 'domains/config/actions'\nimport { setLocale } from 'domains/i18n/actions'\nimport { getConversation } from 'domains/store/actions'\nimport { initializeVisibility, setVisibility } from 'domains/visibility/actions'\n\nconst initialState = {\n error: undefined,\n}\n\nexport const interruptSlice = createSlice({\n name: 'interrupt',\n initialState,\n reducers: {\n setInterrupt: (state, action) => {\n state.error = action.payload\n },\n clearInterrupt: () => initialState,\n },\n extraReducers: (builder) => {\n builder\n .addCase(initializeConfig.pending, () => initialState)\n .addMatcher(\n isAnyOf(\n initializeApp.rejected,\n initializeConfig.rejected,\n setLocale.rejected,\n setVisibility.rejected,\n initializeVisibility.rejected,\n getConversation.rejected,\n ),\n (state, { payload }) => {\n state.error = payload\n },\n )\n },\n})\n\nexport const { setInterrupt, clearInterrupt } = interruptSlice.actions\n\nexport default interruptSlice.reducer\n","import { createAsyncThunk } from '@reduxjs/toolkit'\nimport { ConversationHistoryResponse } from 'api'\nimport { ThunkAPI } from 'domains/redux/redux.types'\n\nexport const getConversation = createAsyncThunk<\n ConversationHistoryResponse | undefined,\n {\n lastEvent: { id: string; occurredAt: number }\n },\n ThunkAPI\n>(\n 'getConversation',\n async (_, { extra: { api }, rejectWithValue }) => {\n try {\n return api.getConversation()\n } catch (error) {\n return rejectWithValue({\n name: error?.name,\n message: error?.message,\n langKey: error?.langKey,\n action: error?.action,\n originalEvent: error?.originalEvent,\n originalError: error?.originalError,\n })\n }\n },\n {\n condition(payload, { getState }) {\n const {\n state: { events },\n } = getState()\n\n const lastEvent = events[events.length - 1]\n const payloadLastEventId = payload?.lastEvent?.id\n return lastEvent && payloadLastEventId !== lastEvent.payload.id\n },\n },\n)\n","import { createSlice } from '@reduxjs/toolkit'\nimport { resetApp } from 'domains/app/actions'\nimport { initializeConfig } from 'domains/config/actions'\nimport { setLocale } from 'domains/i18n/actions'\nimport { I18nState } from 'domains/i18n/i18n.types'\n\nconst initialState: I18nState = {\n translations: {\n 'errors.configError.message':\n 'We are sorry this happened, please retry at a later time.',\n 'errors.configError.srText':\n 'A chat configuration error occurred. Our apologies, please retry at a later time.',\n 'errors.configError.title': 'Chat configuration error.',\n 'errors.general.buttonText': 'Restart chat',\n 'errors.general.message': 'Do you want to start a new chat session?',\n 'errors.general.srText':\n 'Something went wrong with the chat session. You can restart the chat.',\n 'errors.general.title': 'Something went wrong',\n 'errors.seamlyOffline.message':\n 'There might be a problem with your or our network connection. The chat session should resume as soon the connection is available again.',\n 'errors.seamlyOffline.srText':\n 'The chat has connection issues. There might be a problem with your or our network connection. The chat session should resume as soon as the connection is available again.',\n 'errors.seamlyOffline.title': 'Connection issues',\n 'errors.seamlyUnavailable.buttonText': 'Try again',\n 'errors.seamlyUnavailable.message':\n 'The server could not be reached. Try again in a little while.',\n 'errors.seamlyUnavailable.srText':\n 'The chat server could not be reached. Try again in a little while.',\n 'errors.seamlyUnavailable.title': 'Server unavailable',\n },\n isLoading: false,\n initialLocale: undefined,\n userLocale: undefined,\n}\n\nexport const i18nSlice = createSlice({\n name: 'app',\n initialState,\n reducers: {\n setInitialLocale: (state, action) => {\n state.initialLocale = action.payload\n },\n setTranslations: (state, { payload }) => {\n state.translations = payload\n },\n },\n extraReducers: (builder) => {\n // Add reducers for additional action types here, and handle loading state as needed\n builder\n .addCase(resetApp.pending, () => initialState)\n .addCase(initializeConfig.fulfilled, (state, { payload }) => {\n state.initialLocale = payload.defaultContentLocale\n })\n .addCase(setLocale.pending, (state) => {\n state.isLoading = true\n })\n .addCase(setLocale.rejected, (state) => {\n state.isLoading = false\n })\n .addCase(setLocale.fulfilled, (state, { payload }) => {\n state.isLoading = false\n if (!payload?.translations) {\n return\n }\n\n state.userLocale = payload.userLocale\n state.translations = Object.keys(payload.translations)\n .sort()\n .reduce(\n (accum, key) => ({\n ...accum,\n [key]: payload.translations[key],\n }),\n {},\n )\n })\n },\n})\n\nexport const { setInitialLocale, setTranslations } = i18nSlice.actions\n\nexport default i18nSlice.reducer\n","import { combineReducers, configureStore } from '@reduxjs/toolkit'\nimport { Events } from 'minivents'\nimport { useDispatch } from 'react-redux'\nimport { API } from 'api'\nimport { Config } from 'config.types'\nimport appReducer from 'domains/app/slice'\nimport configReducer from 'domains/config/slice'\nimport { createErrorsMiddleware } from 'domains/errors'\nimport formsReducer from 'domains/forms/slice'\nimport i18nReducer from 'domains/i18n/slice'\nimport createInterruptMiddleware from 'domains/interrupt/middleware'\nimport interruptReducer from 'domains/interrupt/slice'\nimport createOptionsMiddleware from 'domains/options/middleware'\nimport stateReducer from 'domains/store/slice'\nimport createI18nMiddleware from 'domains/translations/middleware'\nimport translationReducer from 'domains/translations/slice'\nimport visibilityReducer from 'domains/visibility/slice'\n\ntype CreateStore = {\n initialState: unknown\n api: API\n eventBus: Events\n config: Config\n}\n\nconst rootReducer = combineReducers({\n state: stateReducer,\n app: appReducer,\n config: configReducer,\n i18n: i18nReducer,\n translations: translationReducer,\n visibility: visibilityReducer,\n forms: formsReducer,\n interrupt: interruptReducer,\n})\n\nexport function createStore({\n initialState,\n api,\n eventBus,\n config,\n}: CreateStore) {\n const store = configureStore({\n reducer: rootReducer,\n preloadedState: initialState,\n middleware: (getDefaultMiddleWare) =>\n getDefaultMiddleWare({\n thunk: {\n extraArgument: {\n api,\n eventBus,\n config,\n },\n },\n serializableCheck: false,\n }).concat(\n createErrorsMiddleware({ api }),\n createInterruptMiddleware({ api }),\n createOptionsMiddleware({ api }),\n createI18nMiddleware,\n ),\n })\n\n return store\n}\nexport type Store = ReturnType<typeof createStore>\nexport type RootState = ReturnType<typeof rootReducer>\nexport type AppDispatch = Store['dispatch']\n\nexport const useAppDispatch: () => AppDispatch = useDispatch\n","import { PayloadAction, createSlice, isAnyOf } from '@reduxjs/toolkit'\nimport { initializeApp, resetApp } from 'domains/app/actions'\nimport { initializeConfig } from 'domains/config/actions'\nimport { randomId } from 'lib/id'\nimport { getTimeFromSeconds } from 'ui/utils/general-utils'\nimport {\n entryTypes,\n eventTypes,\n featureKeys,\n payloadTypes,\n readStates,\n} from 'ui/utils/seamly-utils'\nimport type { ConversationHistoryResponse, InitialConversation } from 'api'\nimport type {\n AckEvent,\n ChannelEvent,\n CurrentUploadPayload,\n EntryMeta,\n MessageParticipant,\n ServiceInfo,\n StoreState,\n} from 'domains/store/store.types'\n\nexport const isUnreadMessage = ({ type, payload }: ChannelEvent) =>\n document.visibilityState === 'hidden' ||\n (type === eventTypes.message && !payload.fromClient) ||\n (type === eventTypes.info && payload.type === payloadTypes.text)\n\nexport const orderHistory = (events: ChannelEvent[]) => {\n return events.sort(\n (\n { payload: { occurredAt: occurredAtA } },\n { payload: { occurredAt: occurredAtB } },\n ) => occurredAtA - occurredAtB,\n )\n}\n\nexport const mergeHistory = (\n stateEvents: ChannelEvent[],\n historyEvents: ConversationHistoryResponse['events'],\n) => {\n const newStateEvents = stateEvents.filter(\n (stateEvent) =>\n stateEvent.type === 'message' &&\n !stateEvent.payload.optimisticallyInjected &&\n // Deduplicate the event streams, giving events in historyEvents\n // precedence so the server is able to push changes to events.\n !historyEvents.some(\n (historyEvent) => historyEvent.payload.id === stateEvent.payload.id,\n ),\n )\n\n const newHistoryEvents = historyEvents\n .filter(\n (historyEvent) =>\n // Remove all non displayable participant messages\n !(\n historyEvent.type === 'participant' &&\n !historyEvent.payload.participant.introduction\n ),\n )\n // Reverse is done here because the server sends the history in the order\n // newest to oldest. In the case of exactly the same occurredAt timestamps\n // these messages will be shown in the wrong order if not reversed. For\n // the normal merging logic there is no added effect.\n .reverse()\n\n return orderHistory([...newHistoryEvents, ...newStateEvents])\n}\n\nconst participantReducer = (participantInfo, action) => {\n // TODO: a) Styleguide only! b) Should be removed after styleguide overhaul.\n if (!participantInfo) {\n return {\n participants: {},\n currentAgent: '',\n }\n }\n\n const { participants } = participantInfo || { participants: {} }\n const { id, avatar, name, introduction } = action.participant\n const oldParticipant = participants[id]\n\n const newParticipants = {\n ...participants,\n [id]: oldParticipant\n ? {\n ...oldParticipant,\n ...(avatar ? { avatar } : {}),\n ...(name ? { name } : {}),\n ...(introduction ? { introduction } : {}),\n }\n : action.participant,\n }\n\n return {\n ...participantInfo,\n participants: newParticipants,\n currentAgent:\n participantInfo.currentAgent !== id && !action.fromClient\n ? id\n : participantInfo.currentAgent,\n }\n}\n\nconst calculateNewEntryMeta = (\n entryMeta: EntryMeta,\n channelEvent?: ChannelEvent,\n) => {\n const entry =\n channelEvent?.type === 'message'\n ? channelEvent?.payload.translatedEntry || channelEvent?.payload.entry\n : {}\n\n const { blockAutoEntrySwitch } = entryMeta\n const actions = channelEvent?.payload?.actions || {}\n const translatedActions = channelEvent?.payload?.translatedActions || {}\n\n if (!entry) {\n return {\n ...entryMeta,\n optionsOverride: {},\n actions,\n translatedActions,\n }\n }\n\n const { type, options } = entry\n\n let newActive = entryMeta.active\n\n if (!blockAutoEntrySwitch && type !== entryMeta.userSelected) {\n newActive = type\n }\n\n return {\n ...entryMeta,\n active: newActive,\n optionsOverride: {\n ...(entryMeta.optionsOverride || {}),\n ...(type ? { [type]: options } : {}),\n },\n actions,\n translatedActions,\n }\n}\n\nexport const initialStoreState: StoreState = {\n events: [],\n isLastEventFromClient: false,\n initialState: {\n userResponded: false,\n },\n unreadEvents: 0,\n userHasResponded: false,\n loadedImageEventIds: [],\n isLoading: false,\n idleDetachCountdown: {\n hasCountdown: false,\n isActive: false,\n remaining: undefined,\n wasStopped: undefined,\n count: undefined,\n timer: undefined,\n },\n resumeConversationPrompt: false,\n serviceInfo: {\n activeServiceSessionId: '',\n proactiveMessages: false,\n },\n participantInfo: {\n participants: {},\n currentAgent: '',\n },\n headerTitles: {\n title: null,\n subTitle: '',\n },\n historyLoaded: false,\n skiplinkTargetId: randomId(),\n optionsButtonId: randomId(),\n headerCollapseButtonId: randomId(),\n serviceData: {},\n options: {\n features: {\n webNotifications: {\n enabled: false,\n },\n },\n panelActive: false,\n optionActive: '',\n userSelectedOptions: {},\n },\n showFileUpload: false,\n currentUploads: [],\n processingFileUploads: [],\n entryMeta: {\n default: entryTypes.text,\n active: entryTypes.text,\n userSelected: null,\n blockAutoEntrySwitch: false,\n options: {},\n optionsOverride: {},\n actions: {},\n translatedActions: {},\n },\n seamlyContainerElement: null,\n}\n\nexport const storeSlice = createSlice({\n name: 'store',\n initialState: initialStoreState,\n reducers: {\n addEvent: (state, action: PayloadAction<ChannelEvent>) => {\n const { type: eventType, payload } = action.payload\n\n const accountHasUploads = state.options.features.hasOwnProperty(\n featureKeys.uploads,\n )\n\n let newOptions = { ...state.options }\n\n // This enabled override of the service enabled value for uploads.\n // If a message is sent with entry of type upload it will temporarily\n // override service value and enable uploads.\n if (\n accountHasUploads &&\n (eventType === eventTypes.message ||\n eventType === eventTypes.participant) &&\n !payload.fromClient\n ) {\n const entryType = eventType === 'message' ? payload.entry?.type : {}\n newOptions = {\n ...newOptions,\n features: {\n ...newOptions.features,\n uploads: {\n ...newOptions.features?.uploads,\n enabledFromEntry: entryType === entryTypes.upload,\n },\n },\n }\n }\n\n const incrementUnread = isUnreadMessage(action.payload)\n\n // We check for duplicated and ignore them as in some error of the websocket\n // a duplicate join can be active for a while until the server connection\n // times out.\n const eventExists = state.events.find((e) => e.payload.id === payload.id)\n if (eventExists) {\n return\n }\n\n const newEntryMeta = calculateNewEntryMeta(\n state.entryMeta,\n action.payload,\n )\n\n state.entryMeta =\n !accountHasUploads && newEntryMeta.active === entryTypes.upload\n ? { ...state.entryMeta }\n : newEntryMeta\n\n state.options = newOptions\n\n if (incrementUnread) {\n state.unreadEvents += 1\n if (eventType !== 'service_data') {\n action.payload.payload.messageStatus = payload.fromClient\n ? readStates.read\n : readStates.received\n }\n }\n\n action.payload.payload.key = randomId()\n state.events.push(action.payload)\n\n state.isLastEventFromClient = payload.fromClient\n },\n ackEvent: (state, { payload: { payload } }: PayloadAction<AckEvent>) => {\n // If any ACKs are sent without transactionID the conversation crashes.\n // Ensure that this edge case is handled gracefully.\n if (!payload.transactionId) {\n console.warn('ACK received without transaction ID.')\n return\n }\n\n const matchedEvent = state.events.find(\n (m) =>\n m.payload.transactionId === payload.transactionId &&\n (!payload.type || m.type === payload.type),\n )\n\n const { id, occurredAt } = payload\n if (matchedEvent) {\n matchedEvent.payload.id = id\n matchedEvent.payload.occurredAt = occurredAt\n\n state.events = orderHistory(state.events)\n }\n },\n clearEvents: (state) => {\n state.unreadEvents = 0\n state.loadedImageEventIds = []\n state.events = []\n },\n setEventsRead: (state, { payload }: PayloadAction<string[]>) => {\n state.unreadEvents = 0\n state.events.forEach((event) => {\n if (payload.indexOf(event.payload.id) !== -1) {\n event.payload = {\n ...event.payload,\n ...(event.type !== 'service_data' &&\n event.payload.messageStatus === readStates.received && {\n messageStatus: readStates.read,\n }),\n }\n }\n return event\n })\n },\n setLoadedImageEventIds: (state, { payload }) => {\n state.loadedImageEventIds.push(payload)\n },\n setHistory: (\n state,\n {\n payload: {\n events: history,\n participants,\n activeServiceSessionId,\n activeServiceSettings = {},\n serviceData,\n resumeConversationPrompt,\n },\n }: PayloadAction<ConversationHistoryResponse>,\n ) => {\n const events = mergeHistory(state.events, history)\n\n const mergedParticipants = {\n ...state.participantInfo.participants,\n ...participants,\n }\n\n const lastParticipantEvent = events\n .slice()\n .reverse()\n .find(\n (m) =>\n (m.type === 'message' || m.type === 'participant') &&\n !m.payload.fromClient,\n )\n\n let lastParticipantId = null\n\n if (lastParticipantEvent) {\n if (lastParticipantEvent.type === 'message') {\n lastParticipantId = lastParticipantEvent.payload.participant\n }\n if (lastParticipantEvent.type === 'participant') {\n lastParticipantId = lastParticipantEvent.payload.participant.id\n }\n }\n\n const { entry } = activeServiceSettings\n const upload = entry?.options?.upload\n\n const historyNewEntryMeta = calculateNewEntryMeta(\n {\n ...state.entryMeta,\n ...entry,\n active: entry?.default || payloadTypes.text,\n options: { ...(entry?.options ? entry.options : {}) },\n },\n events[events.length - 1],\n )\n\n let newFeatures = { ...state.options.features }\n\n const newFeaturesHasUpload = newFeatures.hasOwnProperty(\n featureKeys.uploads,\n )\n\n // Only set uploads if it was initialised by the account config.\n if (newFeaturesHasUpload && lastParticipantEvent?.type === 'message') {\n const { payload: lastParticipantEventPayload } = lastParticipantEvent\n const entryType = lastParticipantEventPayload?.entry?.type || {}\n newFeatures = {\n ...newFeatures,\n uploads: {\n enabled: !!(upload && upload?.enabled),\n enabledFromEntry: entryType === entryTypes.upload,\n },\n }\n }\n\n state.unreadEvents = events.filter(\n (event) =>\n event.type === 'message' &&\n event.payload.messageStatus === readStates.received,\n ).length\n state.events = events.filter(\n (e) => e.type !== 'participant' || !!e.payload.participant.introduction,\n )\n state.participantInfo = {\n ...state.participantInfo,\n ...(lastParticipantId\n ? participantReducer(state.participantInfo, {\n participant: mergedParticipants[lastParticipantId],\n })\n : {}),\n participants: mergedParticipants,\n }\n state.historyLoaded = true\n state.serviceInfo = {\n ...state.serviceInfo,\n activeServiceSessionId,\n proactiveMessages:\n activeServiceSettings?.proactiveMessages?.enabled || false,\n }\n\n state.serviceData = {\n ...state.serviceData,\n ...serviceData,\n }\n\n state.options = {\n ...state.options,\n features: newFeatures,\n }\n state.entryMeta =\n !newFeaturesHasUpload &&\n historyNewEntryMeta.active === entryTypes.upload\n ? { ...state.entryMeta }\n : historyNewEntryMeta\n state.resumeConversationPrompt = resumeConversationPrompt || false\n\n if (lastParticipantId) {\n state.headerTitles.subTitle = mergedParticipants[lastParticipantId].name\n }\n },\n resetHistoryLoadedFlag: (state) => {\n state.historyLoaded = false\n },\n setIsLoading: (state, { payload }) => {\n state.isLoading = payload\n },\n initIdleDetachCountdown: (state, { payload }) => {\n const { delaySeconds, delayTime } = payload\n\n state.idleDetachCountdown = {\n hasCountdown: true,\n isActive: true,\n wasStopped: false,\n count: delaySeconds,\n remaining: delaySeconds,\n timer: delayTime,\n }\n },\n decrementIdleDetachCountdownCounter: (state) => {\n const { idleDetachCountdown } = state\n\n const { remaining: prevRemaining } = idleDetachCountdown\n\n const remaining = prevRemaining - 1\n\n state.idleDetachCountdown.remaining = remaining\n state.idleDetachCountdown.timer = getTimeFromSeconds(remaining)\n },\n stopIdleDetachCountdownCounter: (state) => {\n state.idleDetachCountdown.isActive = false\n state.idleDetachCountdown.wasStopped = true\n },\n clearIdleDetachCountdown: (state) => {\n state.idleDetachCountdown.hasCountdown = false\n state.idleDetachCountdown.isActive = false\n },\n initResumeConversationPrompt: (state) => {\n state.resumeConversationPrompt = true\n },\n clearResumeConversationPrompt: (state) => {\n state.resumeConversationPrompt = false\n },\n setParticipant: (state, { payload }: PayloadAction<MessageParticipant>) => {\n state.participantInfo = participantReducer(state.participantInfo, {\n participant: payload.participant,\n fromClient: payload.fromClient,\n })\n },\n setActiveService: (\n state,\n { payload }: PayloadAction<ServiceInfo['activeServiceSessionId']>,\n ) => {\n if (state.serviceInfo.activeServiceSessionId !== payload) {\n state.serviceInfo.activeServiceSessionId = payload\n }\n },\n setHeaderTitle: (state, { payload }) => {\n state.headerTitles.title = payload\n },\n setHeaderSubTitle: (state, { payload }) => {\n state.headerTitles.subTitle = payload\n },\n setInitialState: (\n state,\n { payload }: PayloadAction<InitialConversation>,\n ) => {\n state.initialState = payload\n state.unreadEvents = initialStoreState.unreadEvents\n },\n setServiceDataItem: (state, { payload }) => {\n state.serviceData[payload.type] = payload\n },\n setFeatures: (state, { payload }) => {\n if (!payload.features) {\n return\n }\n state.options.features = payload.features\n },\n setFeatureEnabledState: (state, { payload }) => {\n if (!state.options.features.hasOwnProperty(payload.key)) {\n return\n }\n state.options.features[payload.key].enabled = payload.enabled\n },\n clearFeatures: (state) => {\n state.options.features = {\n webNotifications: state.options.features.webNotifications,\n }\n },\n showOption: (state, { payload }) => {\n state.options.panelActive = true\n state.options.optionActive = payload\n },\n hideOption: (state) => {\n state.options.panelActive = false\n state.options.optionActive = ''\n },\n setUserSelectedOptions: (state, { payload }) => {\n state.options.userSelectedOptions = payload\n },\n setUserSelectedOption: (state, { payload }) => {\n const { option, value } = payload\n state.options.userSelectedOptions[option] = value\n },\n setBlockAutoEntrySwitch: (state, { payload }) => {\n state.entryMeta.blockAutoEntrySwitch = payload\n },\n setServiceEntryMetadata: (state, { payload }) => {\n state.entryMeta.active = payload.default\n state.entryMeta.options = payload.options || {}\n state.entryMeta.optionsOverride = {}\n state.entryMeta.actions = {}\n state.entryMeta.translatedActions = {}\n },\n setActiveEntryType: (state, { payload }) => {\n state.entryMeta.active = payload\n },\n setUserEntryType: (state, { payload }) => {\n state.entryMeta.userSelected = payload\n },\n clearAbortTransaction: (state) => {\n state.entryMeta.actions = {}\n state.entryMeta.translatedActions = {}\n },\n registerUpload: (\n state,\n { payload }: PayloadAction<Omit<CurrentUploadPayload, 'progress'>>,\n ) => {\n state.currentUploads.push({\n id: payload.fileId,\n name: payload.fileName,\n progress: 1,\n uploading: true,\n complete: false,\n error: '',\n uploadHandle: payload.uploadHandle,\n })\n },\n setUploadProgress: (\n state,\n {\n payload,\n }: PayloadAction<Omit<CurrentUploadPayload, 'uploadHandle' | 'fileName'>>,\n ) => {\n state.currentUploads = state.currentUploads.map((fileUpload) => {\n if (fileUpload.id === payload.fileId) {\n return {\n ...fileUpload,\n progress: payload.progress,\n uploading: payload.progress !== 100,\n uploadHandle:\n payload.progress === 100 ? null : fileUpload.uploadHandle,\n }\n }\n return fileUpload\n })\n },\n startProcessingImage: (state, { payload }: PayloadAction<string>) => {\n state.processingFileUploads.push(payload)\n },\n doneProcessingImage: (state, { payload }: PayloadAction<string>) => {\n state.processingFileUploads = state.processingFileUploads.filter(\n (fileId) => fileId !== payload,\n )\n },\n setUploadError: (state, { payload }) => {\n state.currentUploads = state.currentUploads.map((fileUpload) => {\n if (fileUpload.id === payload.fileId) {\n return {\n ...fileUpload,\n error: payload.errorText,\n progress: 0,\n uploading: false,\n uploadHandle: null,\n }\n }\n return fileUpload\n })\n },\n setUploadComplete: (\n state,\n { payload }: PayloadAction<CurrentUploadPayload['fileId']>,\n ) => {\n state.currentUploads = state.currentUploads.map((fileUpload) => {\n if (fileUpload.id === payload) {\n return {\n ...fileUpload,\n complete: true,\n }\n }\n return fileUpload\n })\n },\n clearAllUploads: (state) => {\n state.currentUploads = []\n },\n setSeamlyContainerElement: (state, { payload }) => {\n state.seamlyContainerElement = payload\n },\n setProactiveMessages: (\n state,\n { payload }: PayloadAction<ServiceInfo['proactiveMessages']>,\n ) => {\n state.serviceInfo.proactiveMessages = payload\n },\n },\n extraReducers: (builder) => {\n builder\n .addCase(resetApp.pending, () => initialStoreState)\n .addCase(initializeApp.pending, (state) => {\n state.isLoading = true\n })\n .addCase(initializeConfig.fulfilled, (state, { payload }) => {\n state.headerTitles.subTitle = payload.agentParticipant?.name\n\n if (!payload.features) return\n\n state.options.features = payload.features\n })\n .addCase(initializeApp.fulfilled, (state, { payload }) => {\n state.isLoading = false\n\n if (!payload.initialState) return\n state.initialState = payload.initialState\n })\n .addMatcher(\n isAnyOf(initIdleDetachCountdown, initResumeConversationPrompt),\n (state) => {\n state.isLastEventFromClient = false\n },\n )\n },\n})\n\nexport const {\n ackEvent,\n addEvent,\n clearAllUploads,\n clearEvents,\n clearFeatures,\n clearIdleDetachCountdown,\n clearResumeConversationPrompt,\n decrementIdleDetachCountdownCounter,\n hideOption,\n initIdleDetachCountdown,\n initResumeConversationPrompt,\n registerUpload,\n resetHistoryLoadedFlag,\n setActiveEntryType,\n setActiveService,\n setBlockAutoEntrySwitch,\n setEventsRead,\n setFeatureEnabledState,\n setFeatures,\n setHeaderSubTitle,\n setHeaderTitle,\n setHistory,\n setInitialState,\n setIsLoading,\n setLoadedImageEventIds,\n setParticipant,\n setSeamlyContainerElement,\n setServiceDataItem,\n setServiceEntryMetadata,\n clearAbortTransaction,\n setUploadComplete,\n setUploadError,\n setUploadProgress,\n startProcessingImage,\n doneProcessingImage,\n setUserEntryType,\n setUserSelectedOption,\n setUserSelectedOptions,\n showOption,\n stopIdleDetachCountdownCounter,\n setProactiveMessages,\n} = storeSlice.actions\n\nexport default storeSlice.reducer\n","import { createSelector } from '@reduxjs/toolkit'\nimport { RootState } from 'domains/store'\nimport { ChannelEvent } from 'domains/store/store.types'\n\nexport const selectIsTranslated = (channelEvent: ChannelEvent) =>\n createSelector(\n (store: RootState) => store.translations.translatedEventGroups,\n (translatedEventGroups: Record<string, string[]>) =>\n Object.values(translatedEventGroups).every(\n (value) => !value.includes(channelEvent?.payload?.id),\n ),\n )\n","import { useCallback, useMemo } from 'preact/hooks'\nimport { useDispatch, useSelector } from 'react-redux'\nimport { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport {\n ChannelEvent,\n InfoEvent,\n MessageEvent,\n ParticipantEvent,\n ServiceDataEvent,\n} from 'domains/store/store.types'\nimport { selectIsTranslated } from 'domains/translations/selectors'\nimport {\n disableTranslation,\n disableTranslationProposalPrompt,\n} from 'domains/translations/slice'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport {\n useElementFocusingById,\n useSeamlyCommands,\n} from 'ui/hooks/seamly-hooks'\nimport { TRANSLATION_PROPOSAL, actionTypes } from 'ui/utils/seamly-utils'\nimport type { RootState } from 'domains/store'\nimport type { Language } from 'domains/translations/translations.types'\n\nexport function useTranslations() {\n const { sendContext } = useSeamlyCommands()\n const dispatch = useDispatch()\n const config = useConfig()\n const enableTranslations = useCallback(\n (userLocale: Language['locale']) => {\n sendContext({\n userLocale,\n })\n },\n [sendContext],\n )\n const disableTranslations = useCallback(() => {\n sendContext({\n userLocale: config.context.userLocale,\n })\n dispatch(disableTranslation())\n }, [config.context, dispatch, sendContext])\n\n const { languages, isActive, isAvailable, currentLocale } = useSelector(\n ({ translations }: RootState) => translations,\n )\n\n return {\n languages,\n isActive,\n isAvailable,\n currentLocale,\n enableTranslations,\n disableTranslations,\n }\n}\n\ntype EventDataBody =\n | ParticipantEvent['payload']['participant']['introduction']\n | MessageEvent['payload']['body']\n | InfoEvent['payload']['body']\n | ServiceDataEvent['payload']['body']\n\ntype TranslatedEventDataBody =\n | ParticipantEvent['payload']['participant']['translatedIntroduction']\n | MessageEvent['payload']['translatedBody']\n | InfoEvent['payload']['translatedBody']\n | ServiceDataEvent['payload']['translatedBody']\n\nexport function useTranslatedEventData(channelEvent: ChannelEvent): {\n body: EventDataBody\n hasTranslation: boolean\n isTranslated: boolean\n userLocale: string\n} {\n const getTranslations = (): {\n body: EventDataBody\n translatedBody: TranslatedEventDataBody\n translation?: any\n } => {\n if (!channelEvent?.payload)\n return { body: undefined, translatedBody: undefined }\n if (channelEvent.type === 'participant') {\n return {\n body: channelEvent.payload?.participant.introduction,\n translatedBody:\n channelEvent.payload?.participant?.translatedIntroduction,\n translation:\n // @ts-ignore\n channelEvent.payload?.participant?.translation,\n }\n }\n\n return {\n body: channelEvent.payload.body,\n translatedBody: channelEvent.payload.translatedBody,\n // @ts-ignore\n translation: channelEvent?.payload?.translation,\n }\n }\n\n const { translatedBody, translation, body } = getTranslations()\n const hasTranslation = !!translatedBody\n const isTranslated = useSelector(selectIsTranslated(channelEvent))\n\n return {\n // @ts-ignore\n body: hasTranslation && isTranslated ? translatedBody : body,\n hasTranslation,\n isTranslated: isTranslated && hasTranslation,\n locale: translation?.locale,\n }\n}\n\nexport function useTranslationsContainer() {\n const id = useSelector(({ translations }) => translations.containerId)\n const focusContainer = useElementFocusingById(id)\n return { id, focusContainer }\n}\n\nexport function useLocaleNativeName(userLocale: string) {\n const { languages } = useTranslations()\n\n return useMemo(\n () => languages?.find((lang) => lang.locale === userLocale)?.nativeName,\n [userLocale, languages],\n )\n}\n\nexport const useTranslationProposal = () => {\n const { isActive, languages } = useTranslations()\n\n const dispatch = useDispatch()\n const { sendAction } = useSeamlyCommands()\n\n const { translationProposal } = useSelector(\n (state: RootState) => state.translations,\n )\n const { enableTranslations } = useTranslations()\n const { isOpen } = useVisibility()\n const { userLocale } = useI18n()\n const proposedLocale = translationProposal?.proposedLocale\n const proposedLocaleNativeName = useLocaleNativeName(proposedLocale)\n\n const showProposal = useMemo(\n () =>\n translationProposal !== null &&\n !isActive &&\n isOpen &&\n userLocale !== proposedLocale &&\n languages.some((language) => language.locale === proposedLocale),\n [\n translationProposal,\n isActive,\n isOpen,\n userLocale,\n proposedLocale,\n languages,\n ],\n )\n\n const dismissTranslationProposal = () => {\n sendAction({\n type: actionTypes.dismiss,\n body: { type: TRANSLATION_PROPOSAL },\n })\n dispatch(disableTranslationProposalPrompt())\n }\n\n const activateTranslationProposal = () => {\n enableTranslations(translationProposal?.proposedLocale)\n }\n\n return {\n activateTranslationProposal,\n dismissTranslationProposal,\n proposedLocale,\n proposedLocaleNativeName,\n showProposal,\n translationProposal,\n }\n}\n","import { PayloadAction, createSlice, nanoid } from '@reduxjs/toolkit'\nimport { resetApp } from 'domains/app/actions'\nimport { initializeConfig } from 'domains/config/actions'\nimport { setLocale } from 'domains/i18n/actions'\nimport { addEvent, setHistory } from 'domains/store/slice'\nimport type { ChannelEvent, HistoryResponse } from 'domains/store/store.types'\nimport type { TranslationState } from 'domains/translations/translations.types'\n\nexport const translationsInitialState: TranslationState = {\n isActive: false,\n currentLocale: undefined,\n isAvailable: false,\n languages: [],\n containerId: nanoid(),\n translatedEventGroups: {},\n translationProposal: null,\n}\n\nconst getLastGroupId = (events: ChannelEvent[], id: string) => {\n const eventGroup = [...events].reduce<Record<string, string[]>>(\n (acc, { payload }, _index, arr) => {\n if (acc[id]) {\n // Splice to break early (make the reducer think we are done)\n // This is needed to avoid events of other groups from being added to the array.\n // @ts-ignore\n if (payload?.type === 'divider' && payload?.body?.translationEnabled) {\n arr.splice(0)\n return acc\n }\n\n acc[id].push(payload.id)\n }\n\n if (payload.id === id) acc[id] = []\n\n return acc\n },\n {},\n )\n\n const [[groupId, eventIds]] = Object.entries(eventGroup)\n\n const lastGroupId = events\n // @ts-ignore\n .filter((event) => event.payload?.type === 'divider')\n .map((event) => event.payload.id)\n .at(-1)\n\n return { lastGroupId, groupId, eventIds }\n}\n\nexport const translationSlice = createSlice({\n name: 'translation',\n initialState: translationsInitialState,\n reducers: {\n enableTranslation: (state, { payload }) => {\n state.isActive = true\n state.currentLocale = payload\n },\n disableTranslation: (state) => {\n state.isActive = false\n state.currentLocale = undefined\n },\n enableEventsTranslation: (\n state,\n {\n payload: { events, id },\n }: PayloadAction<{ events: ChannelEvent[]; id: string }>,\n ) => {\n delete state.translatedEventGroups[id]\n\n const { lastGroupId } = getLastGroupId(events, id)\n state.lastGroupId = lastGroupId\n },\n disableEventsTranslation: (\n state,\n {\n payload: { events, id },\n }: PayloadAction<{ events: ChannelEvent[]; id: string }>,\n ) => {\n const { lastGroupId, groupId, eventIds } = getLastGroupId(events, id)\n\n state.lastGroupId = lastGroupId\n state.translatedEventGroups[groupId] = eventIds\n },\n disableTranslationProposalPrompt: (state) => {\n state.translationProposal = null\n },\n setTranslationProposalPrompt: (\n state,\n { payload }: PayloadAction<HistoryResponse['translationProposal']>,\n ) => {\n state.translationProposal = payload\n },\n },\n extraReducers: (builder) => {\n builder\n .addCase(resetApp.pending, () => translationsInitialState)\n .addCase(initializeConfig.fulfilled, (state, { payload }) => {\n const feature = payload?.features?.translation\n if (!feature) return\n\n state.isAvailable = feature.enabled === true\n state.languages = [...feature.languages].sort((a, b) => {\n if (a.locale === payload.defaultContentLocale) return -1\n if (b.locale === payload.defaultContentLocale) return 1\n\n return a.nativeName.localeCompare(b.nativeName, undefined, {\n sensitivity: 'base',\n })\n })\n })\n .addCase(setHistory, (state, { payload }) => {\n state.translationProposal = payload.translationProposal\n })\n .addCase(setLocale.fulfilled, (state, { payload }) => {\n state.currentLocale = payload.userLocale\n })\n .addCase(addEvent, (state, { payload }) => {\n if (state.translatedEventGroups[state.lastGroupId]) {\n state.translatedEventGroups[state.lastGroupId].push(\n payload.payload.id,\n )\n }\n })\n },\n})\n\nexport const {\n enableTranslation,\n disableTranslation,\n enableEventsTranslation,\n disableEventsTranslation,\n setTranslationProposalPrompt,\n disableTranslationProposalPrompt,\n} = translationSlice.actions\n\nexport default translationSlice.reducer\n","import { createAsyncThunk } from '@reduxjs/toolkit'\nimport { selectUserHasResponded } from 'domains/app/selectors'\nimport * as ConfigSelectors from 'domains/config/selectors'\nimport { calculateVisibility } from 'domains/visibility/utils'\nimport { selectState } from 'ui/hooks/seamly-state-hooks'\nimport { StoreKey, visibilityStates } from './constants'\nimport * as Selectors from './selectors'\nimport type { VisibilityOptions } from 'config.types'\nimport type { ThunkAPI } from 'domains/redux/redux.types'\n\nconst validVisibilityStates = [\n visibilityStates.open,\n visibilityStates.minimized,\n visibilityStates.hidden,\n]\nexport const setVisibility = createAsyncThunk<\n VisibilityOptions,\n VisibilityOptions,\n ThunkAPI\n>(\n 'setVisibility',\n (requestedVisibility, { getState, extra: { api, eventBus } }) => {\n const state = getState()\n const previousVisibility = Selectors.selectVisibility(state)\n const userHasResponded = selectUserHasResponded(state)\n const hasConversation = api.hasConversation()\n const config = ConfigSelectors.selectConfig(state)\n\n const { visibilityCallback = calculateVisibility, layoutMode } = config\n const { unreadEvents: unreadMessageCount } = selectState(state)\n\n const calculatedVisibility = visibilityCallback({\n hasResponded: userHasResponded,\n previousVisibility,\n requestedVisibility,\n config,\n })\n if (!validVisibilityStates.includes(calculatedVisibility)) {\n console.error(\n 'The visibilityCallback function should return \"open\", \"minimized\" or \"hidden\".',\n )\n return undefined\n }\n if (previousVisibility === calculatedVisibility) {\n return undefined\n }\n\n const visibility = api.store.get(StoreKey) as object | undefined\n\n // Store the user-requested visibility in order to reinitialize after refresh\n api.store.set(StoreKey, {\n ...(visibility || {}),\n [layoutMode]: requestedVisibility,\n })\n if (requestedVisibility) {\n eventBus.emit('ui.visible', requestedVisibility, {\n visibility: requestedVisibility,\n hasConversation,\n hasResponded: userHasResponded,\n unreadMessageCount,\n })\n }\n\n return calculatedVisibility\n },\n)\n\nexport const initializeVisibility = createAsyncThunk<unknown, void, ThunkAPI>(\n 'initialize',\n async (_, { dispatch, getState, extra: { api } }) => {\n // initialize stored visibility\n const { layoutMode } = ConfigSelectors.selectConfig(getState())\n\n const storedVisibility =\n api.store.get(StoreKey)?.[layoutMode] || visibilityStates.initialize\n\n dispatch(setVisibility(storedVisibility))\n return storedVisibility\n },\n)\n","export const StoreKey = 'visibility'\n\nexport const visibilityStates = {\n hidden: 'hidden',\n minimized: 'minimized',\n open: 'open',\n initialize: null,\n} as const\n","import { RefObject, createRef } from 'preact'\nimport { useCallback, useEffect, useState } from 'preact/hooks'\nimport { useDispatch, useSelector } from 'react-redux'\nimport { useConfig } from 'domains/config/hooks'\nimport { useAppDispatch } from 'domains/store'\nimport { setVisibility } from 'domains/visibility/actions'\nimport { setShowInlineView } from 'domains/visibility/slice'\nimport { visibilityStates } from './constants'\nimport { selectShowInlineView, selectVisibility } from './selectors'\nimport type { VisibilityOptions } from 'config.types'\n\nexport const useVisibility = () => {\n const dispatch = useAppDispatch()\n const visible = useSelector(selectVisibility)\n const isVisible = visible ? visible !== visibilityStates.hidden : false\n const isOpen = visible === visibilityStates.open\n const isMinimized = visible === visibilityStates.minimized\n\n const dispatchVisibility = useCallback(\n (visibility: VisibilityOptions) => dispatch(setVisibility(visibility)),\n [dispatch],\n )\n\n const openChat = () => {\n dispatchVisibility(visibilityStates.open as VisibilityOptions)\n }\n\n const closeChat = () => {\n dispatchVisibility(visibilityStates.minimized as VisibilityOptions)\n }\n\n return {\n isVisible,\n isOpen,\n isMinimized,\n visible,\n setVisibility: dispatchVisibility,\n openChat,\n closeChat,\n }\n}\n\ntype UseIntersectOptions = {\n /** Stops observing when the root element is visible. */\n freezeOnceVisible?: boolean\n /** Determines if useIntersect is enabled. */\n enabled?: boolean\n /** The node ref to apply the intersection to */\n containerRef?: RefObject<any>\n}\n\n/**\n * Custom hook which enables initializing of IntersectionObserver on any node ref.\n */\nexport const useIntersect = ({\n freezeOnceVisible = false,\n enabled = true,\n containerRef = createRef(),\n}: UseIntersectOptions) => {\n const [entry, setEntry] = useState(null)\n const isVisible = !!entry?.isIntersecting || !enabled\n const frozen = isVisible && freezeOnceVisible\n\n const observerCallback = ([updatedEntry]) => setEntry(updatedEntry)\n\n useEffect(() => {\n const node = containerRef?.current\n const hasIOSupport = !!window.IntersectionObserver\n\n if (!node && process.env.NODE_ENV === 'development') {\n console.error(\n 'containerRef must be set on a DOM element. check the component where useIntersect is being used.',\n )\n }\n\n // Return an arrow function to have a consistent return value\n if (!hasIOSupport || frozen || !node || !enabled) return () => undefined\n\n const observerOptions = { threshold: 0, root: null, rootMargin: '0%' }\n const observer = new IntersectionObserver(observerCallback, observerOptions)\n\n observer.observe(node)\n\n return () => observer.disconnect()\n }, [containerRef, enabled, frozen])\n\n return { isVisible, containerRef }\n}\n\nexport const useShowInlineView = () => {\n const dispatch = useDispatch()\n const { connectWhenInView } = useConfig()\n const showInlineView = useSelector(selectShowInlineView)\n\n const { containerRef, isVisible } = useIntersect({\n enabled: connectWhenInView,\n freezeOnceVisible: true,\n })\n\n useEffect(() => {\n if (!isVisible) return\n\n dispatch(setShowInlineView())\n }, [dispatch, isVisible])\n\n return { containerRef, showInlineView }\n}\n","import { createSelector } from '@reduxjs/toolkit'\nimport type { RootState } from 'domains/store'\n\nexport const selectVisibility = createSelector(\n ({ visibility }: RootState) => visibility,\n (state) => state.visibility,\n)\n\nexport const selectShowInlineView = createSelector(\n ({ visibility }: RootState) => visibility,\n (state) => state.showInlineView,\n)\n","import { PayloadAction, createSlice } from '@reduxjs/toolkit'\nimport { initializeConfig } from 'domains/config/actions'\nimport { setVisibility } from 'domains/visibility/actions'\nimport { visibilityStates } from 'domains/visibility/constants'\nimport type { VisibilityOptions } from 'config.types'\nimport type { VisibilityState } from 'domains/visibility/visibility.types'\n\nconst initialState: VisibilityState = {\n visibility: visibilityStates.initialize,\n showInlineView: false,\n}\n\nexport const visibilitySlice = createSlice({\n name: 'visibility',\n initialState,\n reducers: {\n setShowInlineView: (state) => {\n state.showInlineView = true\n },\n },\n extraReducers: (builder) => {\n builder\n .addCase(\n setVisibility.fulfilled,\n (state, { payload: visibility }: PayloadAction<VisibilityOptions>) => {\n if (visibility) {\n state.visibility = visibility\n }\n },\n )\n .addCase(initializeConfig.fulfilled, (state, { payload }) => {\n // We only want to (always) show the inlineView when connectWhenInView is disabled\n if (!payload.connectWhenInView) {\n state.showInlineView = !payload.connectWhenInView\n }\n })\n },\n})\n\nexport const { setShowInlineView } = visibilitySlice.actions\n\nexport default visibilitySlice.reducer\n","import { Events } from 'minivents'\nimport { createContext } from 'preact'\nimport { API } from 'api'\n\nexport const SeamlyApiContext = createContext<API>(null)\n\nexport const SeamlyEventBusContext = createContext<Events>(null)\n","import { useCallback, useContext } from 'preact/hooks'\nimport { SeamlyApiContext } from 'ui/components/core/seamly-api-context'\n\nexport const useSeamlyApiContext = () => useContext(SeamlyApiContext)\n\nexport const useSeamlyObjectStore = () => {\n const api = useSeamlyApiContext()\n\n return api.store\n}\n\nexport const useSeamlyConversationUrl = () => {\n const { get } = useSeamlyObjectStore()\n\n if (get) {\n return get('conversationUrl')\n }\n return null\n}\n\nexport const useSeamlyHasConversation = () => {\n const api = useSeamlyApiContext()\n\n const hasConversation = useCallback(() => {\n return api.hasConversation()\n }, [api])\n\n return hasConversation\n}\n","import { createSelector } from '@reduxjs/toolkit'\nimport { useSelector } from 'react-redux'\nimport { selectUserHasResponded } from 'domains/app/selectors'\nimport { useConfig } from 'domains/config/hooks'\nimport * as ConfigSelectors from 'domains/config/selectors'\nimport { microsecondsToMilliseconds } from 'ui/utils/general-utils'\nimport type { RootState } from 'domains/store'\nimport type { ChannelEvent, ServiceDataEvent } from 'domains/store/store.types'\n\nexport const selectState = ({ state }: RootState) => state\nexport const useSeamlyStateContext = () => useSelector(selectState)\n\nexport const selectEventsWithSuggestion = createSelector(\n selectState,\n ConfigSelectors.selectConfig,\n selectUserHasResponded,\n ({ events, serviceData }, config, hasUserResponded) => {\n if (\n hasUserResponded ||\n config.layoutMode === 'inline' ||\n !serviceData?.suggestion ||\n !serviceData?.suggestion?.body.length\n ) {\n return events\n }\n\n const suggestionsEvent: ServiceDataEvent = {\n type: 'service_data',\n payload: serviceData.suggestion,\n }\n\n return [...events, suggestionsEvent]\n },\n)\n\nexport const selectEvents = createSelector(\n selectEventsWithSuggestion,\n ConfigSelectors.selectConfig,\n (events, config): ChannelEvent[] => {\n const { enabled, threshold } = config?.messages?.timeIndicator ?? {}\n if (!enabled) {\n return events\n }\n\n const mappedEvents = []\n let previousEvent = null\n events.forEach((event, idx) => {\n // always add timeIndicator to first message\n if (idx === 0) {\n mappedEvents.push({ ...event, timeIndicator: event.payload.occurredAt })\n // else check if diff is greater than threshold\n } else {\n const timeIndicator =\n previousEvent &&\n microsecondsToMilliseconds(\n event.payload.occurredAt - previousEvent.payload.occurredAt,\n ) >= threshold\n ? event.payload.occurredAt\n : undefined\n mappedEvents.push({ ...event, timeIndicator })\n }\n previousEvent = event\n })\n\n return mappedEvents\n },\n)\nexport const useEvents = () => useSelector(selectEvents)\n\nexport const selectEventIds = createSelector(selectEvents, (events) => {\n return events.map((event) => event.payload.id)\n})\n\nexport const useEventsIds = () => useSelector(selectEventIds)\n\nexport const useSeamlyIsLoading = () => useSeamlyStateContext().isLoading\n\nexport const useSeamlyHeaderData = () => useSeamlyStateContext().headerTitles\n\nexport const useSeamlyUnreadCount = () => useSeamlyStateContext().unreadEvents\n\nexport const useLoadedImageEventIds = () =>\n useSeamlyStateContext().loadedImageEventIds\n\nexport const useSkiplink = () => useSeamlyStateContext().skiplinkTargetId\n\nexport const useSeamlyParticipant = (participantId) =>\n useSeamlyStateContext().participantInfo.participants[participantId]\n\nexport const useSeamlyServiceInfo = () => useSeamlyStateContext().serviceInfo\n\nconst selectLastMessageEventId = createSelector(selectEvents, (events) => {\n const filteredEvents = events.filter((event) => event.type === 'message')\n return filteredEvents[filteredEvents.length - 1]?.payload.id\n})\nexport const useLastMessageEventId = () => useSelector(selectLastMessageEventId)\n\nexport const useSeamlyIsHistoryLoaded = () =>\n useSeamlyStateContext().historyLoaded\n\nexport const useSeamlyCurrentAgent = () => {\n const { participants, currentAgent } = useSeamlyStateContext().participantInfo\n\n return currentAgent ? participants[currentAgent] : null\n}\n\nexport const useSeamlyServiceData = (key) => {\n return useSeamlyStateContext().serviceData[key]\n}\n\nexport const useEntryTextLimit = () => {\n const {\n entryMeta: {\n options: { text },\n optionsOverride: { text: overrideText },\n },\n } = useSeamlyStateContext()\n\n const { limit } = overrideText || text || { limit: null }\n\n return {\n hasLimit: limit !== null,\n limit: limit !== null ? limit : null,\n }\n}\n\nexport const useSeamlyLayoutMode = () => {\n const { layoutMode } = useConfig()\n\n return {\n isInline: layoutMode === 'inline',\n isWindow: layoutMode === 'window',\n isApp: layoutMode === 'app',\n isResolving: !layoutMode,\n }\n}\n","export const eventTypes = {\n info: 'info',\n message: 'message',\n participant: 'participant',\n system: 'system',\n} as const\n\nexport const payloadTypes = {\n choicePrompt: 'choice_prompt',\n text: 'text',\n image: 'image',\n video: 'video',\n participant: 'participant',\n divider: 'divider',\n translation: 'translation',\n message: 'message',\n countdown: 'countdown',\n upload: 'upload',\n cta: 'cta',\n splash: 'splash',\n}\n\nexport const entryTypes = {\n text: 'text',\n upload: 'upload',\n}\n\nexport const readStates = {\n received: 'received',\n read: 'read',\n}\n\nexport const actionTypes = {\n pickChoice: 'pick_choice',\n navigate: 'navigate',\n custom: 'custom',\n typing: 'typing',\n read: 'read',\n detachService: 'detach_service',\n interactivityUpdate: 'interactivity_update',\n dismiss: 'dismiss',\n sendTranscript: 'send_transcript',\n setTopic: 'set_topic',\n setTranslation: 'set_translation',\n setContext: 'set_context',\n clickCta: 'click_cta',\n clickCard: 'click_card',\n}\n\nexport const TRANSLATION_PROPOSAL = 'translation_proposal'\n\nexport const dismissTypes = {\n resumeConversationPrompt: 'resume_conversation_prompt',\n translationProposal: TRANSLATION_PROPOSAL,\n} as const\n\nexport const sourceTypes = {\n translationProposal: TRANSLATION_PROPOSAL,\n translationChoice: 'translation_choice',\n windowApi: 'window_api',\n} as const\n\nexport const ariaLiveLevels = {\n assertive: 'assertive',\n polite: 'polite',\n}\n\nexport const dividerKeys = {\n new_topic: 'newTopic',\n new_translation: 'newTranslation',\n}\n\nexport const featureKeys = {\n sendTranscript: 'sendTranscript',\n typingPeekahead: 'typingPeekahead',\n uploads: 'uploads',\n}\n\nexport const cardTypes = {\n ask: 'ask',\n navigate: 'navigate',\n topic: 'topic',\n}\n","function parseOriginalErrMsg(str) {\n try {\n const json = JSON.parse(str)\n return json.error\n } catch (e) {\n return str\n }\n}\n\nexport default class SeamlyBaseError extends Error {\n action = ''\n\n langKey = ''\n\n constructor(originalError, ...params) {\n super(...params)\n\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, Object.getPrototypeOf(this))\n }\n this.originalError = originalError\n\n if (originalError?.payload) {\n this.originalEvent = originalError\n this.originalError = originalError.payload.error\n this.message = `Event of type ${originalError.payload.type} encountered`\n }\n if (!this.message && originalError?.message) {\n const parsedOriginalMessage = parseOriginalErrMsg(originalError.message)\n this.message = parsedOriginalMessage\n }\n\n if (originalError?.error) {\n this.originalError = originalError.error\n }\n }\n}\n","import SeamlyBaseError from './seamly-base-error'\n\nexport default class SeamlyConfigurationError extends SeamlyBaseError {\n constructor(originalError, ...params) {\n super(originalError, ...params)\n\n this.name = 'SeamlyConfigurationError'\n this.langKey = 'errors.configError'\n }\n}\n","import SeamlyBaseError from './seamly-base-error'\n\nexport default class SeamlyGeneralError extends SeamlyBaseError {\n constructor(originalError, ...params) {\n super(originalError, ...params)\n\n this.name = 'SeamlyGeneralError'\n this.langKey = 'errors.general'\n this.action = 'reset'\n }\n}\n","import SeamlyBaseError from './seamly-base-error'\n\nexport default class SeamlyOfflineError extends SeamlyBaseError {\n constructor(originalError, ...params) {\n super(originalError, ...params)\n\n this.name = 'SeamlyOfflineError'\n this.langKey = 'errors.seamlyOffline'\n }\n}\n","import SeamlyBaseError from './seamly-base-error'\n\nexport default class SeamlySessionExpiredError extends SeamlyBaseError {\n constructor(originalError, ...params) {\n super(originalError, ...params)\n\n this.name = 'SeamlySessionExpiredError'\n this.action = 'reset'\n }\n}\n","import SeamlyBaseError from './seamly-base-error'\n\nexport default class SeamlyUnauthorizedError extends SeamlyBaseError {\n constructor(originalError, ...params) {\n super(originalError, ...params)\n\n this.name = 'SeamlyUnauthorizedError'\n this.langKey = 'errors.general'\n this.action = 'reset'\n }\n}\n","import SeamlyBaseError from './seamly-base-error'\n\n/**\n * This error is used to alert the user that there's a problem with the connection\n * when initialising the application because of a connection issue on either the server\n * or the client side.\n */\nexport default class SeamlyUnavailableError extends SeamlyBaseError {\n constructor(originalError, ...params) {\n super(originalError, ...params)\n\n this.name = 'SeamlyUnavailableError'\n this.langKey = 'errors.seamlyUnavailable'\n }\n}\n","import { useSelector } from 'react-redux'\nimport { selectUserHasResponded } from 'domains/app/selectors'\n\nexport const useUserHasResponded = () => useSelector(selectUserHasResponded)\n","import { visibilityStates } from './constants'\n\nexport const calculateVisibility = ({\n hasResponded,\n previousVisibility,\n requestedVisibility,\n config,\n}) => {\n const { defaults, layoutMode, hideOnNoUserResponse } = config\n const { visible: defaultVisibility } = defaults || {}\n\n // The app layout should always be open by default.\n if (layoutMode === 'app' && !previousVisibility) {\n return visibilityStates.open\n }\n\n // Requesting open should override the responded check.\n if (\n layoutMode === 'window' &&\n hideOnNoUserResponse &&\n requestedVisibility !== visibilityStates.open\n ) {\n return hasResponded\n ? requestedVisibility || previousVisibility || visibilityStates.open\n : visibilityStates.hidden\n }\n\n // Allow users to continue a conversation (if they have responded and no visibility is requested)\n // when switching from the window layout to the inline layout\n if (layoutMode === 'inline' && hasResponded && !requestedVisibility) {\n return previousVisibility || visibilityStates.open\n }\n\n const baseVisibility = visibilityStates.minimized\n\n return (\n requestedVisibility ||\n previousVisibility ||\n defaultVisibility ||\n baseVisibility\n )\n}\n","import { CSS_NAME } from 'config'\n\n/**\n * Generate a className with all classes prefixed with the CSS_NAME\n *\n * @export\n * @param {*} names\n */\n\nexport const className = (...classes) =>\n classes\n .flat()\n .map((c) => {\n if (typeof c === 'object') {\n return Object.entries(c)\n .map(([key, value]) => (value ? key : ''))\n .join(' ')\n }\n return c\n })\n .filter((c) => typeof c === 'string')\n .map((c) => c.split(' '))\n .flat()\n .filter((c) => c.length)\n .map((c) => {\n // This rule makes sure the CSS_NAME is not added yet\n if (c.indexOf(CSS_NAME) > -1) {\n return c\n }\n return [CSS_NAME, c].join('-')\n })\n .join(' ')\n","if (process.env.NODE_ENV === 'development') {\n module.exports = require('debug')\n} else {\n // eslint-disable-next-line react/display-name\n module.exports = () => () => null\n}\n","export function randomId() {\n return `_${(\n Number(String(Math.random()).slice(2)) +\n Date.now() +\n Math.round(performance.now())\n ).toString(36)}`\n}\n","import { toChildArray } from 'preact'\nimport { useEffect, useMemo, useState } from 'preact/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { useTranslatedEventData } from 'domains/translations/hooks'\nimport { className } from 'lib/css'\nimport { randomId } from 'lib/id'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport Icon from 'ui/components/layout/icon'\nimport {\n useGeneratedId,\n useLastMessageEventId,\n useSeamlyCommands,\n useSeamlyServiceInfo,\n} from 'ui/hooks/seamly-hooks'\nimport { actionTypes } from 'ui/utils/seamly-utils'\n\nexport const useChoicePrompt = (event) => {\n const { payload } = event\n const [showOptions, setShowOptions] = useState(false)\n const { sendAction, addMessageBubble, addDivider } = useSeamlyCommands()\n const { activeServiceSessionId } = useSeamlyServiceInfo()\n const lastEventId = useLastMessageEventId()\n const { body } = useTranslatedEventData(event)\n const { service } = payload\n\n const subEvent = useMemo(() => {\n return {\n ...event,\n payload: {\n ...event.payload,\n body: event.payload.body?.prompt,\n translatedBody: event.payload.translatedBody && {\n ...event.payload.translatedBody,\n data: event.payload.translatedBody.prompt,\n },\n },\n }\n }, [event])\n\n const chooseAgain =\n body.chooseAgain &&\n activeServiceSessionId === service.serviceSessionId &&\n payload.id !== lastEventId\n\n useEffect(() => {\n setShowOptions(payload.id === lastEventId)\n }, [payload, lastEventId])\n\n const onChoiceClickHandler = (choice) => {\n const transactionId = randomId()\n\n if (chooseAgain) {\n addDivider('new_topic', transactionId)\n }\n addMessageBubble(choice.text, transactionId)\n sendAction({\n type: actionTypes.pickChoice,\n originMessage: payload.id,\n choice: {\n id: choice.id,\n text: choice.text,\n chooseAgain,\n },\n transactionId,\n })\n setShowOptions(false)\n }\n\n const onChooseAgainClickHandler = () => {\n setShowOptions((s) => !s)\n }\n\n return {\n body,\n subEvent,\n showOptions,\n chooseAgain,\n onChoiceClickHandler,\n onChooseAgainClickHandler,\n }\n}\n\nconst ChoicePrompt = ({ event, children, ...props }) => {\n const { t } = useI18n()\n const descriptorId = useGeneratedId()\n\n const {\n body,\n subEvent,\n showOptions,\n chooseAgain,\n onChoiceClickHandler,\n onChooseAgainClickHandler,\n } = useChoicePrompt(event)\n\n return (\n <>\n {toChildArray(children).map((child) => {\n child.props = {\n ...child.props,\n event: subEvent,\n descriptorId,\n showTranslationToggle: false,\n }\n return child\n })}\n {chooseAgain && (\n <button\n type=\"button\"\n className={className(\n 'button',\n 'button--secondary',\n 'button--choose-again',\n )}\n aria-expanded={showOptions ? 'true' : 'false'}\n onClick={onChooseAgainClickHandler}\n aria-describedby={descriptorId}\n >\n {showOptions\n ? t('message.choicePrompts.cancelChooseAgain')\n : t('message.choicePrompts.chooseAgain')}\n <Icon name=\"chevronDown\" size=\"8\" alt=\"\" />\n </button>\n )}\n {showOptions && (\n <MessageContainer\n type=\"choice-prompt\"\n showParticipant={false}\n event={event}\n {...props}\n >\n <ul className={className('choice-prompt', 'choice-prompt--many')}>\n {body.choices.map((choice) => (\n <li\n key={choice.id}\n className={className('choice-prompt__item', {\n [`choice-prompt__item--${choice.category}`]: choice.category,\n })}\n >\n <button\n type=\"button\"\n className={className('button', 'button--primary')}\n onClick={() => {\n onChoiceClickHandler(choice)\n }}\n >\n {choice.text}\n </button>\n </li>\n ))}\n </ul>\n </MessageContainer>\n )}\n </>\n )\n}\n\nexport default ChoicePrompt\n","import { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport { useSeamlyParticipant } from 'ui/hooks/seamly-hooks'\n\nconst EventParticipant = ({ eventPayload }) => {\n const { t } = useI18n()\n const { fromClient, participant: participantId } = eventPayload\n const participant = useSeamlyParticipant(participantId) || {}\n const { messages } = useConfig()\n\n const participantName = fromClient\n ? t('participants.user.name')\n : participant && participant.name\n const { showAvatar, showName } = messages[fromClient ? 'user' : 'agent'] || {}\n\n if (!showAvatar && !showName) {\n return null\n }\n\n const authorInfo = []\n\n if (showAvatar && participantName && participant.avatar) {\n authorInfo.push(\n <span className={className('message__avatar')}>\n <img src={participant.avatar} className={className('avatar')} alt=\"\" />\n </span>,\n )\n }\n\n if (showName && participantName) {\n authorInfo.push(\n <span className={className('message__author-name')}>\n {participantName}\n </span>,\n )\n }\n\n return (\n authorInfo.length > 0 && (\n <div className={className('message__author')}>{authorInfo}</div>\n )\n )\n}\n\nexport default EventParticipant\n","import { useTranslatedEventData } from 'domains/translations/hooks'\nimport { className } from 'lib/css'\nimport { useSeamlyMessageContainerClassNames } from 'ui/hooks/component-helper-hooks'\nimport EventParticipant from './event/event-participant'\n\nfunction MessageContainer({\n showParticipant = true,\n event,\n type,\n modifiers,\n children,\n bodyProps = {},\n info,\n ...props\n}) {\n const classNames = useSeamlyMessageContainerClassNames(event)\n\n const { hasTranslation, isTranslated, locale } = useTranslatedEventData(event)\n\n if (type) {\n classNames.push(`message--type-${type}`)\n }\n if (modifiers) {\n if (typeof modifiers === 'string') {\n // eslint-disable-next-line no-param-reassign\n modifiers = modifiers.split(' ').filter((v) => v.length)\n }\n modifiers.forEach((modifier) => {\n classNames.push(`message--${modifier}`)\n })\n }\n if (isTranslated) {\n classNames.push('message--is-translated')\n }\n if (hasTranslation) {\n classNames.push('message--has-translation')\n }\n\n if (isTranslated) {\n // eslint-disable-next-line no-param-reassign\n bodyProps = {\n ...bodyProps,\n lang: locale,\n }\n }\n\n return (\n <>\n <div className={className(classNames)} {...props}>\n {showParticipant && <EventParticipant eventPayload={event.payload} />}\n <div className={className('message__body')} {...bodyProps}>\n {children}\n </div>\n {info && (\n <div aria-hidden=\"true\" className={className('message__info')}>\n {info}\n </div>\n )}\n </div>\n </>\n )\n}\n\nexport default MessageContainer\n","import { createContext } from 'preact'\n\nconst SeamlyActivityEventContext = createContext(null)\n\nexport default SeamlyActivityEventContext\n","import { createContext } from 'preact'\n\nconst SeamlyFileUploadContext = createContext({})\n\nexport default SeamlyFileUploadContext\n","import { createContext } from 'preact'\n\nexport const SeamlyLiveRegionContext = createContext(null)\n","import { useConfig } from 'domains/config/hooks'\n\nexport const useSeamlyAppContainerClassNames = () => {\n return useConfig().appContainerClassNames\n}\n\nexport const useSeamlyMessageContainerClassNames = (event) => {\n const { fromClient } = event.payload\n const classNames = ['message']\n\n if (event.type === 'info') {\n classNames.push('message--source-info')\n } else if (!fromClient) {\n classNames.push('message--source-agent')\n } else {\n classNames.push('message--source-user')\n }\n\n return classNames\n}\n","import { useCallback, useRef } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { setSeamlyContainerElement } from 'domains/store/slice'\nimport {\n focusElement,\n runIfElementContainsOrHasFocus,\n} from 'ui/utils/general-utils'\nimport { useSeamlyStateContext, useSkiplink } from './seamly-state-hooks'\n\nexport const timeout = (ms = 0) =>\n new Promise((resolve) => {\n setTimeout(resolve, ms)\n })\n\nconst focusWithRaf = (el) => {\n requestAnimationFrame(async () => {\n await timeout(180) // wait for next 3 ticks\n const focusEl = typeof el === 'string' ? document.getElementById(el) : el\n focusElement(focusEl)\n })\n}\n\nexport const useSeamlyContainerElement = () => {\n const { seamlyContainerElement } = useSeamlyStateContext()\n\n const dispatch = useDispatch()\n\n const dispatchSeamlyContainerElement = useCallback(\n (element) => {\n dispatch(setSeamlyContainerElement(element))\n },\n [dispatch],\n )\n\n return [seamlyContainerElement, dispatchSeamlyContainerElement]\n}\n\nexport const useElementFocusingById = (elementId) =>\n useCallback(() => {\n focusWithRaf(elementId)\n }, [elementId])\n\nexport const useSkiplinkTargetFocusing = () => {\n const skiplinkTargetId = useSkiplink()\n return useElementFocusingById(skiplinkTargetId)\n}\n\nexport const useFocusIfSeamlyContainedFocus = () => {\n const containerElementRef = useRef(null)\n const [seamlyContainerElement] = useSeamlyContainerElement()\n\n containerElementRef.current = seamlyContainerElement\n\n return useCallback((elementToFocus) => {\n const focusFn = () => {\n focusWithRaf(elementToFocus)\n }\n\n runIfElementContainsOrHasFocus(containerElementRef.current, focusFn)\n }, [])\n}\n","import { useCallback, useContext } from 'preact/hooks'\nimport { SeamlyLiveRegionContext } from 'ui/components/core/seamly-live-region-context'\nimport { ariaLiveLevels } from 'ui/utils/seamly-utils'\n\nexport const useSeamlyLiveRegionContext = () =>\n useContext(SeamlyLiveRegionContext)\n\nexport const useLiveRegion = () => {\n const sendMessage = useSeamlyLiveRegionContext()\n const sendPolite = useCallback(\n (messageText) => {\n if (!messageText) return\n sendMessage({\n ariaLive: ariaLiveLevels.polite,\n messageText,\n })\n },\n [sendMessage],\n )\n const sendAssertive = useCallback(\n (messageText) => {\n if (!messageText) return\n sendMessage({\n ariaLive: ariaLiveLevels.assertive,\n messageText,\n })\n },\n [sendMessage],\n )\n\n return { sendPolite, sendAssertive }\n}\n","import { useCallback, useContext } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { clearAllUploads } from 'domains/store/slice'\nimport SeamlyFileUploadContext from 'ui/components/core/seamly-file-upload-context'\nimport { useSeamlyStateContext } from './seamly-state-hooks'\n\nconst useSeamlyFileUploadContext = () => useContext(SeamlyFileUploadContext)\n\nexport const useFileUploadMeta = () => {\n const {\n showFileUpload,\n entryMeta: { options, optionsOverride },\n options: {\n features: { uploads: uploadsFeature },\n },\n } = useSeamlyStateContext()\n\n const {\n allowedMimeTypes: allowedMimeTypesOverride,\n maxSize: maxSizeOverride,\n } = optionsOverride.upload || {}\n\n const { enabled: uploadsEnabled, enabledFromEntry: uploadsEnabledFromEntry } =\n uploadsFeature || {}\n\n const { allowedMimeTypes, maxSize } = {\n ...(options.upload || {\n allowedMimeTypes: [],\n maxSize: 0,\n }),\n ...(allowedMimeTypesOverride\n ? { allowedMimeTypes: allowedMimeTypesOverride }\n : {}),\n ...(maxSizeOverride ? { maxSize: maxSizeOverride } : {}),\n }\n\n return {\n showFileUpload,\n accountAllowsUploads: !!uploadsFeature,\n serviceAllowsUploads: uploadsEnabledFromEntry || uploadsEnabled,\n allowedMimeTypes,\n maxSize,\n }\n}\n\nexport const useFileUploads = () => {\n const { currentUploads } = useSeamlyStateContext()\n const dispatch = useDispatch()\n const upload = useSeamlyFileUploadContext()\n\n const uploadFile = useCallback(\n (file) => {\n upload(file)\n },\n [upload],\n )\n\n const clearUploads = useCallback(() => {\n dispatch(clearAllUploads())\n }, [dispatch])\n\n return {\n uploadFile,\n clearUploads,\n currentUploads,\n isUploading: currentUploads.some((file) => file.uploading),\n isComplete: currentUploads.every((file) => file.complete),\n }\n}\n","import { useCallback } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { useI18n } from 'domains/i18n/hooks'\nimport {\n hideOption as dispatchHideOption,\n showOption as dispatchShowOption,\n setUserSelectedOption as dispatchUserSelectedOption,\n setUserSelectedOptions as dispatchUserSelectedOptions,\n} from 'domains/store/slice'\nimport { useElementFocusingById } from 'ui/hooks/focus-helper-hooks'\nimport { useSeamlyObjectStore } from 'ui/hooks/seamly-api-hooks'\nimport { useSeamlyStateContext } from 'ui/hooks/seamly-state-hooks'\n\nexport const useSeamlyOptions = () => {\n const { t } = useI18n()\n const { options } = useSeamlyStateContext()\n\n const { panelActive, optionActive, userSelectedOptions, features } = options\n\n const { extraMenuItem, sendTranscript } = features\n\n const optionsObj = { extraMenuItem, sendTranscript }\n\n const menuTitle = (option) => {\n return option === 'extraMenuItem'\n ? 'Extra menu item'\n : t(`options.${option}.menuTitle`)\n }\n\n const menuOptions = Object.keys(optionsObj)\n .filter((key) => {\n return optionsObj[key]\n })\n .map((option) => ({\n name: option,\n title: menuTitle(option),\n available: optionsObj[option].enabled,\n }))\n\n const allowOptionSelection = extraMenuItem || sendTranscript\n\n const dispatch = useDispatch()\n const { get, set } = useSeamlyObjectStore()\n\n const initUserSelectedOptions = useCallback(() => {\n const storedOptions = get('options') || {}\n dispatch(dispatchUserSelectedOptions(storedOptions))\n }, [get, dispatch])\n\n const setUserSelectedOptions = useCallback(\n (optionValues) => {\n dispatch(dispatchUserSelectedOptions(optionValues))\n set('options', optionValues)\n },\n [set, dispatch],\n )\n\n const setUserSelectedOption = useCallback(\n (option, value) => {\n const storedOptions = get('options') || {}\n set('options', {\n ...storedOptions,\n [option]: value,\n })\n dispatch(dispatchUserSelectedOption({ option, value }))\n },\n [dispatch, get, set],\n )\n\n const showOption = (optionName) => {\n dispatch(dispatchShowOption(optionName))\n }\n\n const hideOption = () => {\n dispatch(dispatchHideOption())\n }\n\n return {\n allowOptionSelection,\n userSelectedOptions,\n features,\n menuOptions,\n initUserSelectedOptions,\n setUserSelectedOptions,\n setUserSelectedOption,\n showOption,\n hideOption,\n panelActive,\n optionActive,\n }\n}\n\nexport const useOptionButton = () => {\n const { optionsButtonId: id } = useSeamlyStateContext()\n const focusButton = useElementFocusingById(id)\n\n return { id, focusButton }\n}\n","import { useContext } from 'preact/hooks'\nimport SeamlyActivityEventContext from 'ui/components/core/seamly-activity-event-context'\n\nconst useSeamlyActivityEventHandler = () =>\n useContext(SeamlyActivityEventContext)\n\nexport default useSeamlyActivityEventHandler\n","import { useCallback, useContext } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { userParticipantId } from 'config'\nimport * as AppActions from 'domains/app/actions'\nimport { useUserHasResponded } from 'domains/app/hooks'\nimport { setHasResponded } from 'domains/app/slice'\nimport { setInterrupt } from 'domains/interrupt/slice'\nimport { addEvent, setInitialState } from 'domains/store/slice'\nimport { visibilityStates } from 'domains/visibility/constants'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { randomId } from 'lib/id'\nimport { SeamlyEventBusContext } from 'ui/components/core/seamly-api-context'\nimport { actionTypes } from 'ui/utils/seamly-utils'\nimport {\n useSeamlyApiContext,\n useSeamlyHasConversation,\n} from './seamly-api-hooks'\nimport { useSeamlyUnreadCount } from './seamly-state-hooks'\n\nconst useSeamlyCommands = () => {\n const api = useSeamlyApiContext()\n const dispatch = useDispatch()\n const eventBus = useContext(SeamlyEventBusContext)\n const userHasResponded = useUserHasResponded()\n const hasConversation = useSeamlyHasConversation()\n const { visible: visibility, setVisibility } = useVisibility()\n const unreadMessageCount = useSeamlyUnreadCount()\n\n const emitEvent = useCallback(\n (...args) => {\n eventBus.emit(...args)\n },\n [eventBus],\n )\n\n const start = useCallback(() => {\n emitEvent('ui.beforeStart', {\n visibility,\n hasConversation: hasConversation(),\n hasResponded: userHasResponded,\n unreadMessageCount,\n })\n\n api.send('start')\n emitEvent('ui.start', {\n visibility,\n hasConversation: hasConversation(),\n hasResponded: userHasResponded,\n unreadMessageCount,\n })\n }, [\n api,\n emitEvent,\n hasConversation,\n userHasResponded,\n unreadMessageCount,\n visibility,\n ])\n\n const reset = useCallback(async () => {\n dispatch(AppActions.resetApp())\n }, [dispatch])\n\n const getMessageBase = useCallback(\n (type) => ({\n type,\n id: randomId(),\n transactionId: randomId(),\n participant: userParticipantId,\n fromClient: true,\n occurredAt: Date.now() * 1000,\n meta: {},\n }),\n [],\n )\n\n const getTextMessageBase = useCallback(\n (bodyText) => {\n const base = getMessageBase('text')\n\n return {\n ...base,\n body: {\n text: bodyText,\n },\n }\n },\n [getMessageBase],\n )\n\n const sendMessage = useCallback(\n ({ body, config = {} }) => {\n if (body.trim() === '') {\n return\n }\n\n const message = {\n ...getTextMessageBase(body),\n ...config,\n }\n\n api.send('message', message)\n emitEvent('message', message)\n dispatch(\n addEvent({\n type: 'message',\n payload: {\n ...message,\n optimisticallyInjected: true,\n },\n }),\n )\n },\n [api, dispatch, emitEvent, getTextMessageBase],\n )\n\n const addMessageBubble = useCallback(\n (text, transactionId = randomId()) => {\n dispatch(\n addEvent({\n type: 'message',\n payload: { ...getTextMessageBase(text), transactionId },\n }),\n )\n },\n [dispatch, getTextMessageBase],\n )\n\n const addUploadBubble = useCallback(\n (id, transactionId, occurredAt, contentType, filename, filesize, url) => {\n dispatch(\n addEvent({\n type: 'message',\n payload: {\n type: 'upload',\n id,\n transactionId,\n participant: userParticipantId,\n fromClient: true,\n occurredAt,\n meta: {},\n body: { contentType, filename, filesize, url },\n },\n }),\n )\n },\n [dispatch],\n )\n\n const addDivider = useCallback(\n (subtype, transactionId = randomId()) => {\n const payload = {\n body: { subtype, type: 'divider' },\n fromClient: false,\n fromHistory: true,\n id: randomId(),\n transactionId,\n type: 'divider',\n }\n\n dispatch(addEvent({ type: 'info', payload }))\n },\n [dispatch],\n )\n\n const sendAction = useCallback(\n (body) => {\n if (!body) {\n return\n }\n\n api.send('action', body)\n\n const { type } = body\n if (type !== actionTypes.typing && type !== actionTypes.read) {\n emitEvent(`action.${type}`, body)\n }\n },\n [api, emitEvent],\n )\n\n const sendContext = useCallback(\n (context) => {\n api.sendContext(context)\n },\n [api],\n )\n\n const connect = useCallback(() => {\n if (api.connected) {\n return Promise.reject(new Error('The API is already connected'))\n }\n\n return api\n .connect()\n .then((initialState) => {\n if (initialState) {\n dispatch(setInitialState(initialState))\n if (initialState.userResponded) {\n dispatch(setHasResponded(initialState.userResponded))\n setVisibility(visibilityStates.open)\n }\n }\n })\n .catch((error) => {\n dispatch(\n setInterrupt({\n name: error?.name,\n message: error?.message,\n langKey: error?.langKey,\n action: error?.action,\n originalEvent: error?.originalEvent,\n originalError: error?.originalError,\n }),\n )\n })\n }, [api, dispatch, setVisibility])\n\n return {\n connect,\n start,\n sendMessage,\n sendAction,\n sendContext,\n reset,\n emitEvent,\n addMessageBubble,\n addUploadBubble,\n addDivider,\n apiConnected: api.connected,\n apiConfigReady: api.configReady,\n }\n}\n\nexport default useSeamlyCommands\n","import { useCallback, useRef } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { screenReaderDebounceDelaySeconds } from 'config'\nimport { useI18n } from 'domains/i18n/hooks'\nimport {\n clearIdleDetachCountdown,\n decrementIdleDetachCountdownCounter,\n initIdleDetachCountdown,\n stopIdleDetachCountdownCounter,\n} from 'domains/store/slice'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport {\n getTimeFromSeconds,\n millisecondsToSeconds,\n} from 'ui/utils/general-utils'\nimport { actionTypes } from 'ui/utils/seamly-utils'\nimport { useLiveRegion } from './live-region-hooks'\nimport { useSeamlyStateContext } from './seamly-state-hooks'\nimport useSeamlyCommands from './use-seamly-commands'\n\nconst useSeamlyIdleDetachCountdown = () => {\n const dispatch = useDispatch()\n\n const { idleDetachCountdown } = useSeamlyStateContext()\n\n const { isOpen: isSeamlyOpen } = useVisibility()\n\n const stableState = useRef({})\n\n stableState.current = {\n hasCountdown: idleDetachCountdown.hasCountdown,\n isActive: idleDetachCountdown.isActive,\n remaining: idleDetachCountdown.remaining,\n wasStopped: idleDetachCountdown.wasStopped,\n isOpen: isSeamlyOpen,\n }\n\n const { emitEvent, sendAction } = useSeamlyCommands()\n const { t } = useI18n()\n const { sendAssertive, sendPolite } = useLiveRegion()\n\n const sendAssertiveIfOpen = useCallback(\n (text) => {\n const { isOpen } = stableState.current\n if (isOpen) {\n sendAssertive(text)\n }\n },\n [sendAssertive],\n )\n\n const sendPoliteIfOpen = useCallback(\n (text) => {\n const { isOpen } = stableState.current\n if (isOpen) {\n sendPolite(text)\n }\n },\n [sendPolite],\n )\n\n const initCountdown = useCallback(\n (milliseconds) => {\n const delaySeconds = millisecondsToSeconds(milliseconds)\n const delayTime = getTimeFromSeconds(delaySeconds)\n\n dispatch(\n initIdleDetachCountdown({\n delaySeconds,\n delayTime,\n }),\n )\n emitEvent('idleTimer.start')\n sendAssertiveIfOpen(\n `${t('idleDetachWarning.countdownTitle')} ${t(\n 'idleDetachWarning.countdownText',\n )} ${t('idleDetachWarning.countdownTimer', delayTime)}`,\n )\n },\n [dispatch, emitEvent, sendAssertiveIfOpen, t],\n )\n\n const endCountdown = useCallback(\n (continueChat, isServerAction) => {\n const { hasCountdown, wasStopped } = stableState.current\n if (!hasCountdown) {\n return\n }\n\n if (!continueChat) {\n if (!isServerAction) {\n sendAction({ type: actionTypes.detachService })\n }\n sendAssertiveIfOpen(t('idleDetachWarning.notifyTransferText'))\n }\n\n if (!wasStopped) {\n emitEvent('idleTimer.stop')\n }\n\n dispatch(clearIdleDetachCountdown())\n },\n [dispatch, sendAction, emitEvent, sendAssertiveIfOpen, t],\n )\n\n const decrementCountdown = useCallback(() => {\n const { remaining } = stableState.current\n if (remaining <= 0) {\n return\n }\n\n const newRemaining = remaining - 1\n\n if (newRemaining % screenReaderDebounceDelaySeconds === 0) {\n sendAssertiveIfOpen(\n `${t('idleDetachWarning.countdownText')} ${t(\n 'idleDetachWarning.countdownTimer',\n getTimeFromSeconds(newRemaining),\n )}`,\n )\n }\n\n dispatch(decrementIdleDetachCountdownCounter())\n }, [dispatch, sendAssertiveIfOpen, t])\n\n const stopCountdown = useCallback(() => {\n const { isActive, remaining } = stableState.current\n if (!isActive) {\n return\n }\n\n dispatch(stopIdleDetachCountdownCounter())\n\n if (remaining) {\n emitEvent('idleTimer.stop')\n sendPoliteIfOpen(t('idleDetachWarning.srCountDownStoppedText'))\n }\n }, [dispatch, emitEvent, sendPoliteIfOpen, t])\n\n return {\n ...idleDetachCountdown,\n initCountdown,\n endCountdown,\n decrementCountdown,\n stopCountdown,\n }\n}\n\nexport default useSeamlyIdleDetachCountdown\n","import { useDispatch } from 'react-redux'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { clearResumeConversationPrompt } from 'domains/store/slice'\nimport { actionTypes, dismissTypes } from 'ui/utils/seamly-utils'\nimport { useLiveRegion } from './live-region-hooks'\nimport { useSeamlyStateContext } from './seamly-state-hooks'\nimport useSeamlyCommands from './use-seamly-commands'\n\nconst useSeamlyResumeConversationPrompt = () => {\n const dispatch = useDispatch()\n const hasPrompt = useSeamlyStateContext().resumeConversationPrompt\n const { sendAction } = useSeamlyCommands()\n const { t } = useI18n()\n const { sendAssertive } = useLiveRegion()\n\n const continueChat = () => {\n sendAction({\n type: actionTypes.dismiss,\n body: { type: dismissTypes.resumeConversationPrompt },\n })\n dispatch(clearResumeConversationPrompt())\n }\n\n const restartChat = () => {\n sendAssertive(t('resumeConversationPrompt.srNotifyRestartText'))\n sendAction({ type: actionTypes.detachService })\n dispatch(clearResumeConversationPrompt())\n }\n\n return { continueChat, hasPrompt, restartChat }\n}\n\nexport default useSeamlyResumeConversationPrompt\n","import {\n useCallback,\n useMemo,\n useReducer,\n useRef,\n useState,\n} from 'preact/hooks'\nimport { randomId } from 'lib/id'\n\nexport const useForceUpdate = () => {\n // This is an escape hatch mentioned in the React docs:\n // https://reactjs.org/docs/hooks-faq.html#is-there-something-like-forceupdate\n /* eslint-disable-next-line no-unused-vars */\n const [_, forceUpdate] = useReducer((x) => x + 1, 0)\n\n return useCallback(() => {\n setTimeout(() => {\n forceUpdate()\n })\n }, [])\n}\n\nexport const useGeneratedId = () => {\n const [id] = useState(() => randomId())\n return id\n}\n\nexport const useStableCallback = (callback) => {\n const callbackRef = useRef(null)\n callbackRef.current = callback\n const isFunction = typeof callback === 'function'\n return useMemo(() => {\n return isFunction ? (...args) => callbackRef.current(...args) : undefined\n }, [isFunction])\n}\n","export const debounce = (func, wait) => {\n let timeout\n return function (...args) {\n let isCancelled = false\n clearTimeout(timeout)\n timeout = setTimeout(() => {\n timeout = null\n if (!isCancelled) {\n func.apply(this, args)\n }\n isCancelled = false\n }, wait)\n\n return (runInstant) => {\n isCancelled = true\n if (runInstant) {\n func.apply(this, args)\n }\n }\n }\n}\n\nexport const elementMatch = (el, match) => {\n if (el.matches) {\n el.matches(match)\n } else if (el.msMatchesSelector) {\n return el.msMatchesSelector(match)\n } else if (el.webkitMatchesSelector) {\n return el.webkitMatchesSelector(match)\n }\n return false\n}\n\nexport const closestElement = (el, match) => {\n if (el.closest) {\n return el.closest(match)\n }\n\n let foundElement = el\n\n do {\n if (elementMatch(foundElement, match)) {\n break\n }\n foundElement = foundElement.parentElement || foundElement.parentNode\n } while (foundElement !== null && foundElement.nodeType === 1)\n\n return foundElement !== null && foundElement.nodeType === 1\n ? foundElement\n : null\n}\n\nexport const createAriaHider = () => {\n const originalValues = []\n const rootNodes = []\n document.querySelectorAll('body > *:not([role=\"dialog\"])').forEach((node) => {\n const attr = node.getAttribute('aria-hidden')\n const alreadyHidden = attr !== null && attr !== 'false'\n if (alreadyHidden) {\n return\n }\n originalValues.push(attr)\n rootNodes.push(node)\n node.setAttribute('aria-hidden', 'true')\n })\n\n return () => {\n rootNodes.forEach((node, index) => {\n const originalValue = originalValues[index]\n if (originalValue === null) {\n node.removeAttribute('aria-hidden')\n } else {\n node.setAttribute('aria-hidden', originalValue)\n }\n })\n }\n}\n\nexport const propIsTrue = (prop) => prop === 'true' || prop === true\n\nexport const millisecondsToSeconds = (milliseconds) => {\n return Math.ceil(milliseconds / 1000)\n}\n\nexport const microsecondsToMilliseconds = (microseconds) => {\n return Math.ceil(microseconds / 1000)\n}\n\nexport const getTimeFromSeconds = (seconds) => {\n const minutes = Math.floor(seconds / 60)\n const secondsPartial = seconds - minutes * 60\n\n return { minutes, seconds: secondsPartial }\n}\n\nexport const formatBytes = (bytes, decimals = 2) => {\n if (bytes === 0) return '0 Bytes'\n\n const k = 1024\n const dm = decimals < 0 ? 0 : decimals\n const sizes = ['Bytes', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB']\n\n const i = Math.floor(Math.log(bytes) / Math.log(k))\n\n return `${parseFloat((bytes / k ** i).toFixed(dm))} ${sizes[i]}`\n}\n\nexport const keyCodes = {\n 27: 'Escape',\n 35: 'End',\n 36: 'Home',\n 37: 'ArrowLeft',\n 38: 'ArrowUp',\n 39: 'ArrowRight',\n 40: 'ArrowDown',\n}\n\nexport const keyNames = {\n Escape: 'Escape',\n End: 'End',\n Home: 'Home',\n ArrowLeft: 'ArrowLeft',\n ArrowUp: 'ArrowUp',\n ArrowRight: 'ArrowRight',\n ArrowDown: 'ArrowDown',\n}\n\nexport const getKey = (e) => (e.code ? keyNames[e.code] : keyCodes[e.keyCode])\n\nexport const focusElement = (el) => {\n if (el) {\n el.focus()\n }\n}\n\nexport const runIfElementContainsOrHasFocus = (el, callback) => {\n if (\n el &&\n (el.contains(document.activeElement) || el === document.activeElement)\n ) {\n callback()\n }\n}\n\n// Compare two dates to decide which relative date to return\nexport const getRelativeDate = (date, currentDate) => {\n const msMidnightToday = new Date(currentDate).setHours(0, 0, 0, 0)\n const msDate = date.getTime()\n const dayInMs = 86400000\n if (msDate >= msMidnightToday + dayInMs) {\n // Future date\n return date\n } else if (msDate > msMidnightToday) {\n // Today\n return 'today'\n } else if (msDate > msMidnightToday - dayInMs) {\n // Yesterday\n return 'yesterday'\n } else {\n // Older date\n return date\n }\n}\n\nexport const pick = (obj, keys) =>\n keys.reduce((accum, key) => {\n if (key in obj) accum[key] = obj[key]\n return accum\n }, {})\n\nexport const omit = (obj, keys) =>\n Object.keys(obj).reduce((accum, key) => {\n if (!keys.includes(key)) accum[key] = obj[key]\n return accum\n }, {})\n","import{Component as n,createElement as t,options as e,toChildArray as r,Fragment as u,render as o,hydrate as i,createContext as l,createRef as c,cloneElement as f}from\"preact\";export{Component,Fragment,createContext,createElement,createRef}from\"preact\";import{useState as a,useId as s,useReducer as h,useEffect as v,useLayoutEffect as d,useRef as p,useImperativeHandle as m,useMemo as y,useCallback as _,useContext as b,useDebugValue as S}from\"preact/hooks\";export*from\"preact/hooks\";function g(n,t){for(var e in t)n[e]=t[e];return n}function C(n,t){for(var e in n)if(\"__source\"!==e&&!(e in t))return!0;for(var r in t)if(\"__source\"!==r&&n[r]!==t[r])return!0;return!1}function E(n){this.props=n}function w(n,e){function r(n){var t=this.props.ref,r=t==n.ref;return!r&&t&&(t.call?t(null):t.current=null),e?!e(this.props,n)||!r:C(this.props,n)}function u(e){return this.shouldComponentUpdate=r,t(n,e)}return u.displayName=\"Memo(\"+(n.displayName||n.name)+\")\",u.prototype.isReactComponent=!0,u.__f=!0,u}(E.prototype=new n).isPureReactComponent=!0,E.prototype.shouldComponentUpdate=function(n,t){return C(this.props,n)||C(this.state,t)};var x=e.__b;e.__b=function(n){n.type&&n.type.__f&&n.ref&&(n.props.ref=n.ref,n.ref=null),x&&x(n)};var R=\"undefined\"!=typeof Symbol&&Symbol.for&&Symbol.for(\"react.forward_ref\")||3911;function N(n){function t(t){var e=g({},t);return delete e.ref,n(e,t.ref||null)}return t.$$typeof=R,t.render=t,t.prototype.isReactComponent=t.__f=!0,t.displayName=\"ForwardRef(\"+(n.displayName||n.name)+\")\",t}var k=function(n,t){return null==n?null:r(r(n).map(t))},A={map:k,forEach:k,count:function(n){return n?r(n).length:0},only:function(n){var t=r(n);if(1!==t.length)throw\"Children.only\";return t[0]},toArray:r},O=e.__e;e.__e=function(n,t,e,r){if(n.then)for(var u,o=t;o=o.__;)if((u=o.__c)&&u.__c)return null==t.__e&&(t.__e=e.__e,t.__k=e.__k),u.__c(n,t);O(n,t,e,r)};var T=e.unmount;function F(n,t,e){return n&&(n.__c&&n.__c.__H&&(n.__c.__H.__.forEach(function(n){\"function\"==typeof n.__c&&n.__c()}),n.__c.__H=null),null!=(n=g({},n)).__c&&(n.__c.__P===e&&(n.__c.__P=t),n.__c=null),n.__k=n.__k&&n.__k.map(function(n){return F(n,t,e)})),n}function I(n,t,e){return n&&e&&(n.__v=null,n.__k=n.__k&&n.__k.map(function(n){return I(n,t,e)}),n.__c&&n.__c.__P===t&&(n.__e&&e.appendChild(n.__e),n.__c.__e=!0,n.__c.__P=e)),n}function L(){this.__u=0,this.t=null,this.__b=null}function U(n){var t=n.__.__c;return t&&t.__a&&t.__a(n)}function D(n){var e,r,u;function o(o){if(e||(e=n()).then(function(n){r=n.default||n},function(n){u=n}),u)throw u;if(!r)throw e;return t(r,o)}return o.displayName=\"Lazy\",o.__f=!0,o}function M(){this.u=null,this.o=null}e.unmount=function(n){var t=n.__c;t&&t.__R&&t.__R(),t&&32&n.__u&&(n.type=null),T&&T(n)},(L.prototype=new n).__c=function(n,t){var e=t.__c,r=this;null==r.t&&(r.t=[]),r.t.push(e);var u=U(r.__v),o=!1,i=function(){o||(o=!0,e.__R=null,u?u(l):l())};e.__R=i;var l=function(){if(!--r.__u){if(r.state.__a){var n=r.state.__a;r.__v.__k[0]=I(n,n.__c.__P,n.__c.__O)}var t;for(r.setState({__a:r.__b=null});t=r.t.pop();)t.forceUpdate()}};r.__u++||32&t.__u||r.setState({__a:r.__b=r.__v.__k[0]}),n.then(i,i)},L.prototype.componentWillUnmount=function(){this.t=[]},L.prototype.render=function(n,e){if(this.__b){if(this.__v.__k){var r=document.createElement(\"div\"),o=this.__v.__k[0].__c;this.__v.__k[0]=F(this.__b,r,o.__O=o.__P)}this.__b=null}var i=e.__a&&t(u,null,n.fallback);return i&&(i.__u&=-33),[t(u,null,e.__a?null:n.children),i]};var V=function(n,t,e){if(++e[1]===e[0]&&n.o.delete(t),n.props.revealOrder&&(\"t\"!==n.props.revealOrder[0]||!n.o.size))for(e=n.u;e;){for(;e.length>3;)e.pop()();if(e[1]<e[0])break;n.u=e=e[2]}};function W(n){return this.getChildContext=function(){return n.context},n.children}function P(n){var e=this,r=n.i;e.componentWillUnmount=function(){o(null,e.l),e.l=null,e.i=null},e.i&&e.i!==r&&e.componentWillUnmount(),e.l||(e.i=r,e.l={nodeType:1,parentNode:r,childNodes:[],appendChild:function(n){this.childNodes.push(n),e.i.appendChild(n)},insertBefore:function(n,t){this.childNodes.push(n),e.i.appendChild(n)},removeChild:function(n){this.childNodes.splice(this.childNodes.indexOf(n)>>>1,1),e.i.removeChild(n)}}),o(t(W,{context:e.context},n.__v),e.l)}function j(n,e){var r=t(P,{__v:n,i:e});return r.containerInfo=e,r}(M.prototype=new n).__a=function(n){var t=this,e=U(t.__v),r=t.o.get(n);return r[0]++,function(u){var o=function(){t.props.revealOrder?(r.push(u),V(t,n,r)):u()};e?e(o):o()}},M.prototype.render=function(n){this.u=null,this.o=new Map;var t=r(n.children);n.revealOrder&&\"b\"===n.revealOrder[0]&&t.reverse();for(var e=t.length;e--;)this.o.set(t[e],this.u=[1,0,this.u]);return n.children},M.prototype.componentDidUpdate=M.prototype.componentDidMount=function(){var n=this;this.o.forEach(function(t,e){V(n,e,t)})};var z=\"undefined\"!=typeof Symbol&&Symbol.for&&Symbol.for(\"react.element\")||60103,B=/^(?:accent|alignment|arabic|baseline|cap|clip(?!PathU)|color|dominant|fill|flood|font|glyph(?!R)|horiz|image(!S)|letter|lighting|marker(?!H|W|U)|overline|paint|pointer|shape|stop|strikethrough|stroke|text(?!L)|transform|underline|unicode|units|v|vector|vert|word|writing|x(?!C))[A-Z]/,H=/^on(Ani|Tra|Tou|BeforeInp|Compo)/,Z=/[A-Z0-9]/g,Y=\"undefined\"!=typeof document,$=function(n){return(\"undefined\"!=typeof Symbol&&\"symbol\"==typeof Symbol()?/fil|che|rad/:/fil|che|ra/).test(n)};function q(n,t,e){return null==t.__k&&(t.textContent=\"\"),o(n,t),\"function\"==typeof e&&e(),n?n.__c:null}function G(n,t,e){return i(n,t),\"function\"==typeof e&&e(),n?n.__c:null}n.prototype.isReactComponent={},[\"componentWillMount\",\"componentWillReceiveProps\",\"componentWillUpdate\"].forEach(function(t){Object.defineProperty(n.prototype,t,{configurable:!0,get:function(){return this[\"UNSAFE_\"+t]},set:function(n){Object.defineProperty(this,t,{configurable:!0,writable:!0,value:n})}})});var J=e.event;function K(){}function Q(){return this.cancelBubble}function X(){return this.defaultPrevented}e.event=function(n){return J&&(n=J(n)),n.persist=K,n.isPropagationStopped=Q,n.isDefaultPrevented=X,n.nativeEvent=n};var nn,tn={enumerable:!1,configurable:!0,get:function(){return this.class}},en=e.vnode;e.vnode=function(n){\"string\"==typeof n.type&&function(n){var t=n.props,e=n.type,u={};for(var o in t){var i=t[o];if(!(\"value\"===o&&\"defaultValue\"in t&&null==i||Y&&\"children\"===o&&\"noscript\"===e||\"class\"===o||\"className\"===o)){var l=o.toLowerCase();\"defaultValue\"===o&&\"value\"in t&&null==t.value?o=\"value\":\"download\"===o&&!0===i?i=\"\":\"ondoubleclick\"===l?o=\"ondblclick\":\"onchange\"!==l||\"input\"!==e&&\"textarea\"!==e||$(t.type)?\"onfocus\"===l?o=\"onfocusin\":\"onblur\"===l?o=\"onfocusout\":H.test(o)?o=l:-1===e.indexOf(\"-\")&&B.test(o)?o=o.replace(Z,\"-$&\").toLowerCase():null===i&&(i=void 0):l=o=\"oninput\",\"oninput\"===l&&u[o=l]&&(o=\"oninputCapture\"),u[o]=i}}\"select\"==e&&u.multiple&&Array.isArray(u.value)&&(u.value=r(t.children).forEach(function(n){n.props.selected=-1!=u.value.indexOf(n.props.value)})),\"select\"==e&&null!=u.defaultValue&&(u.value=r(t.children).forEach(function(n){n.props.selected=u.multiple?-1!=u.defaultValue.indexOf(n.props.value):u.defaultValue==n.props.value})),t.class&&!t.className?(u.class=t.class,Object.defineProperty(u,\"className\",tn)):(t.className&&!t.class||t.class&&t.className)&&(u.class=u.className=t.className),n.props=u}(n),n.$$typeof=z,en&&en(n)};var rn=e.__r;e.__r=function(n){rn&&rn(n),nn=n.__c};var un=e.diffed;e.diffed=function(n){un&&un(n);var t=n.props,e=n.__e;null!=e&&\"textarea\"===n.type&&\"value\"in t&&t.value!==e.value&&(e.value=null==t.value?\"\":t.value),nn=null};var on={ReactCurrentDispatcher:{current:{readContext:function(n){return nn.__n[n.__c].props.value}}}},ln=\"17.0.2\";function cn(n){return t.bind(null,n)}function fn(n){return!!n&&n.$$typeof===z}function an(n){return fn(n)&&n.type===u}function sn(n){return fn(n)?f.apply(null,arguments):n}function hn(n){return!!n.__k&&(o(null,n),!0)}function vn(n){return n&&(n.base||1===n.nodeType&&n)||null}var dn=function(n,t){return n(t)},pn=function(n,t){return n(t)},mn=u;function yn(n){n()}function _n(n){return n}function bn(){return[!1,yn]}var Sn=d,gn=fn;function Cn(n,t){var e=t(),r=a({h:{__:e,v:t}}),u=r[0].h,o=r[1];return d(function(){u.__=e,u.v=t,En(u)&&o({h:u})},[n,e,t]),v(function(){return En(u)&&o({h:u}),n(function(){En(u)&&o({h:u})})},[n]),e}function En(n){var t,e,r=n.v,u=n.__;try{var o=r();return!((t=u)===(e=o)&&(0!==t||1/t==1/e)||t!=t&&e!=e)}catch(n){return!0}}var wn={useState:a,useId:s,useReducer:h,useEffect:v,useLayoutEffect:d,useInsertionEffect:Sn,useTransition:bn,useDeferredValue:_n,useSyncExternalStore:Cn,startTransition:yn,useRef:p,useImperativeHandle:m,useMemo:y,useCallback:_,useContext:b,useDebugValue:S,version:\"17.0.2\",Children:A,render:q,hydrate:G,unmountComponentAtNode:hn,createPortal:j,createElement:t,createContext:l,createFactory:cn,cloneElement:sn,createRef:c,Fragment:u,isValidElement:fn,isElement:gn,isFragment:an,findDOMNode:vn,Component:n,PureComponent:E,memo:w,forwardRef:N,flushSync:pn,unstable_batchedUpdates:dn,StrictMode:mn,Suspense:L,SuspenseList:M,lazy:D,__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED:on};export{A as Children,E as PureComponent,mn as StrictMode,L as Suspense,M as SuspenseList,on as __SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED,sn as cloneElement,cn as createFactory,j as createPortal,wn as default,vn as findDOMNode,pn as flushSync,N as forwardRef,G as hydrate,gn as isElement,an as isFragment,fn as isValidElement,D as lazy,w as memo,q as render,yn as startTransition,hn as unmountComponentAtNode,dn as unstable_batchedUpdates,_n as useDeferredValue,Sn as useInsertionEffect,Cn as useSyncExternalStore,bn as useTransition,ln as version};\n//# sourceMappingURL=compat.module.js.map\n","/* eslint-disable import/no-webpack-loader-syntax */\n// The eslint rules are disabled for this as otherwsise we'd need to include the loader rule in all implementations\n// this can again be changed when we can import pre-built packages in implementations\nimport iconAvatar32 from '!!raw-loader!../../../../icons/avatar_bot-32.svg'\nimport iconArrowLeft16 from '!!raw-loader!../../../../icons/icon_arrow_left-16.svg'\nimport iconArrowRight16 from '!!raw-loader!../../../../icons/icon_arrow_right-16.svg'\nimport iconBalloon32 from '!!raw-loader!../../../../icons/icon_balloon-32.svg'\nimport iconCheck16 from '!!raw-loader!../../../../icons/icon_check-16.svg'\nimport iconCheck32 from '!!raw-loader!../../../../icons/icon_check-32.svg'\nimport iconChevronDown32 from '!!raw-loader!../../../../icons/icon_chevron_down-32.svg'\nimport iconChevronDown8 from '!!raw-loader!../../../../icons/icon_chevron_down-8.svg'\nimport iconChevronRight16 from '!!raw-loader!../../../../icons/icon_chevron_right-16.svg'\nimport iconChevronRight8 from '!!raw-loader!../../../../icons/icon_chevron_right-8.svg'\nimport iconClose16 from '!!raw-loader!../../../../icons/icon_close-16.svg'\nimport iconClose8 from '!!raw-loader!../../../../icons/icon_close-8.svg'\nimport iconDownload16 from '!!raw-loader!../../../../icons/icon_download-16.svg'\nimport iconEnlarge32 from '!!raw-loader!../../../../icons/icon_enlarge-32.svg'\nimport iconError16 from '!!raw-loader!../../../../icons/icon_error-16.svg'\nimport iconFile32 from '!!raw-loader!../../../../icons/icon_file-32.svg'\nimport iconNewTopic32 from '!!raw-loader!../../../../icons/icon_newtopic-32.svg'\nimport iconNewTranslation16 from '!!raw-loader!../../../../icons/icon_newtranslation-16.svg'\nimport iconNewTranslation32 from '!!raw-loader!../../../../icons/icon_newtranslation-32.svg'\nimport iconOptions32 from '!!raw-loader!../../../../icons/icon_options-32.svg'\nimport iconSend32 from '!!raw-loader!../../../../icons/icon_send-32.svg'\nimport iconUpload32 from '!!raw-loader!../../../../icons/icon_upload-32.svg'\nimport { className as classNameFn } from 'lib/css'\n\n/* eslint-enable import/no-webpack-loader-syntax */\n\nexport const ICONS = {\n send: {\n 32: iconSend32,\n },\n balloon: {\n 32: iconBalloon32,\n },\n newTopic: {\n 32: iconNewTopic32,\n },\n newTranslation: {\n 16: iconNewTranslation16,\n 32: iconNewTranslation32,\n },\n avatar: {\n 32: iconAvatar32,\n },\n chevronDown: {\n 8: iconChevronDown8,\n 32: iconChevronDown32,\n },\n chevronRight: {\n 8: iconChevronRight8,\n 16: iconChevronRight16,\n },\n close: {\n 8: iconClose8,\n 16: iconClose16,\n },\n enlarge: {\n 32: iconEnlarge32,\n },\n options: {\n 32: iconOptions32,\n },\n file: {\n 32: iconFile32,\n },\n upload: {\n 32: iconUpload32,\n },\n download: {\n 16: iconDownload16,\n },\n error: {\n 16: iconError16,\n },\n arrowLeft: {\n 16: iconArrowLeft16,\n },\n arrowRight: {\n 16: iconArrowRight16,\n },\n check: {\n 16: iconCheck16,\n 32: iconCheck32,\n },\n} as const\n\nexport type IconProps = {\n name: keyof typeof ICONS\n size?: '8' | '16' | '32'\n className?: string\n alt: string\n}\n\nconst Icon = ({ name, size = '32', className, alt }: IconProps) => (\n <>\n <div\n aria-hidden=\"true\"\n className={className || classNameFn('icon')}\n dangerouslySetInnerHTML={{ __html: ICONS[name][size] }}\n />\n {alt && <span className={classNameFn('visually-hidden')}>{alt}</span>}\n </>\n)\n\nexport default Icon\n","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"32px\\\" height=\\\"32px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 32 32\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M6.714,14.985l17.837-7.906c0.681-0.302,1.414,0.301,1.25,1.027L22.273,23.59\\tc-0.13,0.566-0.751,0.865-1.275,0.613l-3.623-1.752l-2.334,2.287c-0.572,0.562-1.538,0.156-1.538-0.645V21.01\\tc0-0.217,0.078-0.43,0.222-0.594l7.676-8.841l-10.414,7.472l-4.351-2.445C5.987,16.236,6.033,15.287,6.714,14.985L6.714,14.985z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"32px\\\" height=\\\"32px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 32 32\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M24,10.824v10.375c0,1.104-0.896,2-2,2h-4.694l-4.931,3.625v-3.625H10c-1.104,0-2-0.896-2-2V10.824\\tc0-1.104,0.896-2,2-2h12C23.104,8.824,24,9.719,24,10.824z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"32px\\\" height=\\\"32px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 32 32\\\"><path fill=\\\"#4A48C1\\\" d=\\\"M16,8.593l2.407,4.573l5.093,0.876l-3.604,3.702l0.74,5.115L16,20.574l-4.634,2.285l0.739-5.115L8.5,14.042\\tl5.094-0.876L16,8.593z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 16 16\\\"><path fill=\\\"#4A48C1\\\" d=\\\"M8,0C3.6,0,0,3.6,0,8s3.6,8,8,8s8-3.6,8-8S12.4,0,8,0z M14.1,7.1h-1.4c-0.1-1.5-0.4-2.9-1-4\\tC13,4,13.9,5.4,14.1,7.1z M7.1,2.1v5H5C5.2,4.7,6.1,2.9,7.1,2.1z M7.1,8.9v5c-1-0.7-1.9-2.5-2.1-5H7.1z M8.9,13.9v-5H11\\tC10.8,11.3,9.9,13.2,8.9,13.9z M8.9,7.1v-5c1,0.7,1.9,2.5,2.1,5H8.9z M4.2,3.1c-0.5,1.1-0.9,2.5-1,4H1.9C2.1,5.4,3,4,4.2,3.1z M1.9,8.9h1.4c0.1,1.5,0.4,2.9,1,4C3,12,2.1,10.5,1.9,8.9z M11.8,12.9c0.5-1.1,0.9-2.5,1-4h1.4C13.9,10.5,13,12,11.8,12.9z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 32 32\\\"><path fill=\\\"#4A48C1\\\" d=\\\"M16,7c-4.9,0-9,4.1-9,9s4.1,9,9,9s9-4.1,9-9S20.9,7,16,7z M22.9,15h-1.6c-0.1-1.7-0.5-3.3-1.1-4.5\\tC21.6,11.5,22.6,13.1,22.9,15z M15,9.4V15h-2.3C12.9,12.3,13.9,10.2,15,9.4z M15,17v5.6c-1.1-0.8-2.1-2.9-2.3-5.6H15z M17,22.6V17\\th2.3C19.1,19.8,18.1,21.8,17,22.6z M17,15V9.4c1.1,0.8,2.1,2.9,2.3,5.6H17z M11.8,10.4c-0.6,1.3-1,2.8-1.1,4.5H9.1\\tC9.4,13.1,10.4,11.5,11.8,10.4z M9.1,17h1.6c0.1,1.7,0.5,3.3,1.1,4.5C10.4,20.5,9.4,18.9,9.1,17z M20.2,21.5c0.6-1.3,1-2.8,1.1-4.5\\th1.6C22.6,18.8,21.6,20.5,20.2,21.5z\\\"/></svg>\";","export default \"<svg version=\\\"1.1\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" xmlns:xlink=\\\"http://www.w3.org/1999/xlink\\\" x=\\\"0px\\\" y=\\\"0px\\\"\\n\\t viewBox=\\\"0 0 32 32\\\" enable-background=\\\"new 0 0 32 32\\\" xml:space=\\\"preserve\\\">\\n<path fill=\\\"#4A48C1\\\" d=\\\"M10,14.8c-1.1,0-2-0.9-2-2s0.9-2,2-2s2,0.9,2,2S11.1,14.8,10,14.8z M15.9,14.8c1.1,0,2-0.9,2-2s-0.9-2-2-2\\n\\ts-2,0.9-2,2S14.8,14.8,15.9,14.8z M21.8,10.8c-1.1,0-2,0.9-2,2s0.9,2,2,2s2-0.9,2-2S22.9,10.8,21.8,10.8z M21.3,18.1H10.7\\n\\tC11.7,23.9,20.2,23.9,21.3,18.1z\\\"/>\\n</svg>\\n\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"8px\\\" height=\\\"8px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 8 8\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M-0.001,2.876c0-0.247,0.091-0.494,0.273-0.688c0.38-0.401,1.013-0.418,1.414-0.039l1.938,1.834\\tc0.199,0.188,0.547,0.188,0.746,0L6.31,2.15c0.401-0.379,1.034-0.362,1.414,0.04c0.379,0.401,0.361,1.034-0.04,1.414L5.745,5.437\\tC4.782,6.35,3.213,6.35,2.249,5.436L0.311,3.603C0.103,3.406-0.001,3.142-0.001,2.876z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"32px\\\" height=\\\"32px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 32 32\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M16,20.425c-0.782,0-1.563-0.291-2.159-0.874l-6.541-6.408c-0.395-0.387-0.401-1.02-0.015-1.414\\tc0.387-0.394,1.021-0.4,1.414-0.015l6.541,6.408c0.42,0.409,1.102,0.409,1.52-0.001l6.541-6.407c0.396-0.386,1.028-0.38,1.414,0.015\\tc0.387,0.395,0.381,1.027-0.014,1.414l-6.541,6.407C17.563,20.133,16.782,20.425,16,20.425z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"8px\\\" height=\\\"8px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 8 8\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M2.875,7.998c-0.247,0-0.494-0.091-0.688-0.273c-0.401-0.38-0.418-1.013-0.039-1.414l1.834-1.938\\tc0.188-0.199,0.188-0.547,0-0.746l-1.835-1.94c-0.379-0.401-0.362-1.034,0.04-1.414s1.034-0.361,1.414,0.04l1.834,1.939\\tc0.913,0.963,0.913,2.532-0.001,3.496L3.601,7.686C3.405,7.894,3.14,7.998,2.875,7.998z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"16px\\\" height=\\\"16px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 16 16\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M6.5,13c-0.247,0-0.494-0.091-0.687-0.273c-0.401-0.38-0.419-1.013-0.04-1.414L8.22,8.727\\tc0.373-0.394,0.373-1.06,0-1.454L5.773,4.687c-0.379-0.401-0.362-1.034,0.04-1.414c0.4-0.378,1.034-0.362,1.414,0.04l2.446,2.586\\tc1.096,1.159,1.096,3.043,0,4.203l-2.446,2.586C7.03,12.896,6.765,13,6.5,13z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"8px\\\" height=\\\"8px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 8 8\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M7.705,7.729C7.511,7.923,7.255,8.02,7,8.02c-0.257,0-0.514-0.099-0.709-0.295L4,5.423L1.709,7.725\\tC1.513,7.921,1.257,8.02,1,8.02c-0.255,0-0.51-0.097-0.706-0.291c-0.391-0.39-0.393-1.022-0.003-1.414l2.298-2.309l-2.27-2.28\\tC-0.07,1.334-0.068,0.701,0.323,0.311c0.392-0.389,1.024-0.387,1.415,0.003L4,2.587l2.263-2.274C6.653-0.077,7.287-0.079,7.677,0.31\\tC8.068,0.7,8.07,1.333,7.681,1.725l-2.27,2.281l2.298,2.309C8.099,6.705,8.097,7.339,7.705,7.729z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"16px\\\" height=\\\"16px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 16 16\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M12.709,11.295L9.411,7.982l3.262-3.276c0.39-0.392,0.388-1.024-0.004-1.414\\tc-0.39-0.39-1.023-0.388-1.414,0.003L8,6.564L4.746,3.295C4.357,2.904,3.724,2.903,3.332,3.292C2.94,3.682,2.939,4.315,3.329,4.707\\tl3.261,3.275l-3.298,3.313c-0.39,0.391-0.388,1.024,0.003,1.414C3.49,12.903,3.745,13,4,13c0.257,0,0.513-0.099,0.708-0.295L8,9.399\\tl3.291,3.306C11.486,12.901,11.743,13,12,13c0.255,0,0.511-0.097,0.705-0.291C13.097,12.319,13.099,11.686,12.709,11.295z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"32px\\\" height=\\\"32px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 32 32\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M24,9v6.5c0,0.552-0.447,1-1,1s-1-0.448-1-1v-4.086L11.414,22H15.5c0.552,0,1,0.447,1,1s-0.448,1-1,1H9\\tc-0.13,0-0.26-0.026-0.382-0.077c-0.245-0.102-0.439-0.296-0.541-0.541C8.026,23.26,8,23.13,8,23v-6.5c0-0.552,0.448-1,1-1\\ts1,0.448,1,1v4.085L20.586,10H16.5c-0.552,0-1-0.448-1-1s0.448-1,1-1H23c0.13,0,0.26,0.026,0.382,0.077\\tc0.245,0.102,0.439,0.296,0.541,0.541C23.974,8.74,24,8.87,24,9z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"32px\\\" height=\\\"32px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 32 32\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M26.1,21.383c0.334-0.625,0.602-1.279,0.812-1.949L32,18.609V13.51l-5.058-0.846\\tc-0.208-0.67-0.468-1.325-0.795-1.956l3.009-4.145l-3.604-3.634L21.38,5.903c-0.626-0.333-1.276-0.602-1.948-0.81L18.609,0\\tl-5.098,0.001l-0.847,5.061c-0.669,0.203-1.326,0.465-1.957,0.794L6.562,2.847L2.929,6.449l2.973,4.171\\tC5.569,11.247,5.3,11.9,5.091,12.569L0,13.373v5.099l5.06,0.866c0.204,0.669,0.467,1.324,0.796,1.955l-3.009,4.146l3.601,3.635\\tl4.171-2.975c0.627,0.335,1.282,0.603,1.951,0.811L13.372,32h5.118l0.849-5.057c0.668-0.207,1.323-0.469,1.953-0.795l4.144,3.01\\tl3.639-3.604L26.1,21.383z M19.01,19.035c-1.675,1.663-4.381,1.652-6.041-0.025c-1.662-1.675-1.649-4.381,0.024-6.042\\tc1.676-1.661,4.382-1.648,6.043,0.025C20.699,14.67,20.686,17.377,19.01,19.035z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" xml:space=\\\"preserve\\\" x=\\\"0px\\\" y=\\\"0px\\\" version=\\\"1.1\\\" viewBox=\\\"0 0 32 32\\\"><path fill=\\\"#4A48C1\\\" d=\\\"M16,28.5c-3.6,0-6.5-3-6.5-6.6V9.6c0-0.6,0.4-1,1-1s1,0.4,1,1v12.3c0,2.5,2,4.6,4.5,4.6\\tc2.5,0,4.5-2.1,4.5-4.6V8.3c0-1.5-1.2-2.8-2.7-2.8c-1.5,0-2.7,1.3-2.7,2.8v13.5c0,0.6,0.5,1.1,1,1.1c0.6,0,1-0.5,1-1.1v-10\\tc0-0.6,0.4-1,1-1s1,0.4,1,1v10c0,1.7-1.4,3.1-3,3.1s-3-1.4-3-3.1V8.3c0-2.6,2.1-4.8,4.7-4.8c2.6,0,4.7,2.2,4.7,4.8v13.6\\tC22.5,25.5,19.6,28.5,16,28.5z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"32px\\\" height=\\\"32px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 32 32\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M9.488,13.481c-0.391-0.391-0.391-1.023,0-1.414l5.805-5.805c0.026-0.026,0.06-0.036,0.088-0.058\\tc0.073-0.06,0.146-0.119,0.235-0.156c0.246-0.103,0.522-0.103,0.769,0c0.093,0.039,0.171,0.101,0.249,0.165\\tc0.023,0.02,0.053,0.027,0.074,0.049l5.805,5.805c0.391,0.391,0.391,1.023,0,1.414c-0.195,0.195-0.451,0.293-0.707,0.293\\ts-0.512-0.098-0.707-0.293L17,9.383V20.33c0,0.553-0.447,1-1,1c-0.552,0-1-0.447-1-1V9.383l-4.098,4.098\\tC10.512,13.872,9.879,13.872,9.488,13.481z M22.819,24.031H9.181c-0.552,0-1,0.447-1,1s0.448,1,1,1h13.639c0.553,0,1-0.447,1-1\\tS23.372,24.031,22.819,24.031z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"16px\\\" height=\\\"16px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 16 16\\\"><defs/><path fill=\\\"#FFF\\\" d=\\\"M3.175,7.726c-0.413-0.367-0.45-0.999-0.083-1.412c0.367-0.413,0.999-0.45,1.412-0.083L7,8.45V1.5\\tc0-0.552,0.448-1,1-1c0.553,0,1,0.448,1,1v6.95l2.496-2.219c0.412-0.367,1.044-0.331,1.411,0.083\\tc0.367,0.413,0.33,1.045-0.083,1.412l-4.16,3.698c-0.047,0.041-0.103,0.062-0.154,0.094c-0.047,0.028-0.089,0.064-0.141,0.085\\tC8.25,11.649,8.125,11.677,8,11.677c-0.126,0-0.25-0.027-0.369-0.074c-0.05-0.021-0.09-0.055-0.136-0.083\\tc-0.053-0.031-0.111-0.053-0.159-0.096L3.175,7.726z M12.018,13.5H3.983c-0.552,0-1,0.447-1,1s0.448,1,1,1h8.035\\tc0.553,0,1-0.447,1-1S12.57,13.5,12.018,13.5z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"16px\\\" height=\\\"16px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 16 16\\\"><defs/><path fill=\\\"#ad001f\\\" d=\\\"M15.744,13.104L9.097,1.47c-0.604-1.055-1.59-1.055-2.193,0L0.256,13.104\\tc-0.604,1.056-0.102,1.919,1.113,1.919H14.63C15.847,15.022,16.348,14.159,15.744,13.104z M7,5.045c0-0.552,0.448-1,1-1s1,0.448,1,1\\tv3.656c0,0.552-0.448,1-1,1s-1-0.448-1-1V5.045z M8,13.212c-0.748,0-1.354-0.607-1.354-1.354c0-0.748,0.606-1.354,1.354-1.354\\ts1.354,0.606,1.354,1.354C9.354,12.604,8.748,13.212,8,13.212z\\\"/></svg>\";","export default \"<?xml version=\\\"1.0\\\" encoding=\\\"utf-8\\\"?>\\n<!-- Generator: Adobe Illustrator 25.2.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->\\n<svg version=\\\"1.1\\\" id=\\\"Layer_1\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" xmlns:xlink=\\\"http://www.w3.org/1999/xlink\\\" x=\\\"0px\\\" y=\\\"0px\\\"\\n\\t viewBox=\\\"0 0 16 16\\\" enable-background=\\\"new 0 0 16 16\\\" xml:space=\\\"preserve\\\">\\n<path fill=\\\"#5053A4\\\" d=\\\"M13.6,8c0,0.6-0.4,1-1,1h-7l2.2,2.5c0.4,0.4,0.3,1-0.1,1.4c-0.2,0.2-0.4,0.2-0.7,0.2c-0.3,0-0.6-0.1-0.8-0.3\\n\\tL2.6,8.6c0,0-0.1-0.1-0.1-0.2c0,0-0.1-0.1-0.1-0.1c0-0.1-0.1-0.2-0.1-0.3c0,0,0,0,0,0c0,0,0,0,0,0c0-0.1,0-0.3,0.1-0.4\\n\\tc0,0,0.1-0.1,0.1-0.1c0-0.1,0.1-0.1,0.1-0.2l3.7-4.1c0.4-0.4,1-0.4,1.4-0.1c0.4,0.4,0.4,1,0.1,1.4L5.6,7h7C13.2,7,13.6,7.4,13.6,8z\\\"\\n\\t/>\\n</svg>\\n\";","export default \"<?xml version=\\\"1.0\\\" encoding=\\\"utf-8\\\"?>\\n<!-- Generator: Adobe Illustrator 25.2.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->\\n<svg version=\\\"1.1\\\" id=\\\"Layer_1\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" xmlns:xlink=\\\"http://www.w3.org/1999/xlink\\\" x=\\\"0px\\\" y=\\\"0px\\\"\\n\\t viewBox=\\\"0 0 16 16\\\" enable-background=\\\"new 0 0 16 16\\\" xml:space=\\\"preserve\\\">\\n<path fill=\\\"#5053A4\\\" d=\\\"M2.4,8.1c0-0.6,0.4-1,1-1h7L8.1,4.5c-0.4-0.4-0.3-1,0.1-1.4c0.2-0.2,0.4-0.2,0.7-0.2c0.3,0,0.6,0.1,0.8,0.3\\n\\tl3.7,4.2c0,0,0.1,0.1,0.1,0.2c0,0,0.1,0.1,0.1,0.1c0,0.1,0.1,0.2,0.1,0.3c0,0,0,0,0,0c0,0,0,0,0,0c0,0.1,0,0.3-0.1,0.4\\n\\tc0,0-0.1,0.1-0.1,0.1c0,0.1-0.1,0.1-0.1,0.2l-3.7,4.1c-0.4,0.4-1,0.4-1.4,0.1c-0.4-0.4-0.4-1-0.1-1.4l2.2-2.4h-7\\n\\tC2.8,9.1,2.4,8.6,2.4,8.1z\\\"/>\\n</svg>\\n\";","export default \"<svg\\n xmlns=\\\"http://www.w3.org/2000/svg\\\"\\n width=\\\"16px\\\"\\n height=\\\"16px\\\"\\n x=\\\"0px\\\"\\n y=\\\"0px\\\"\\n viewBox=\\\"0 0 16 16\\\"\\n>\\n <path\\n fill=\\\"currentColor\\\"\\n d=\\\"M11.6,4.3l-5,5L4.9,7.5C4.4,7,3.7,7,3.2,7.5l0,0C2.8,8,2.8,8.7,3.2,9.2l1.7,1.7l0,0l0.8,0.8\\n\\tc0.5,0.5,1.2,0.5,1.7,0l0.8-0.8l5-5c0.5-0.5,0.5-1.2,0-1.7l0,0C12.8,3.8,12.1,3.8,11.6,4.3z\\\"\\n />\\n</svg>\\n\";","export default \"<svg\\n xmlns=\\\"http://www.w3.org/2000/svg\\\"\\n width=\\\"32px\\\"\\n height=\\\"32px\\\"\\n x=\\\"0px\\\"\\n y=\\\"0px\\\"\\n viewBox=\\\"0 0 32 32\\\"\\n>\\n <path\\n fill=\\\"currentColor\\\"\\n d=\\\"M22.9,9.3l-9.3,9.3l-3.2-3.2c-0.9-0.9-2.3-0.9-3.2,0l0,0c-0.9,0.9-0.9,2.3,0,3.2l3.2,3.2l0,0l1.6,1.6\\n\\tc0.9,0.9,2.3,0.9,3.2,0l1.6-1.6l9.3-9.3c0.9-0.9,0.9-2.3,0-3.2l0,0C25.2,8.4,23.7,8.4,22.9,9.3z\\\"\\n />\\n</svg>\\n\";","/**\n * @license React\n * use-sync-external-store-with-selector.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var g=require(\"react\");function n(a,b){return a===b&&(0!==a||1/a===1/b)||a!==a&&b!==b}var p=\"function\"===typeof Object.is?Object.is:n,q=g.useSyncExternalStore,r=g.useRef,t=g.useEffect,u=g.useMemo,v=g.useDebugValue;\nexports.useSyncExternalStoreWithSelector=function(a,b,e,l,h){var c=r(null);if(null===c.current){var f={hasValue:!1,value:null};c.current=f}else f=c.current;c=u(function(){function a(a){if(!c){c=!0;d=a;a=l(a);if(void 0!==h&&f.hasValue){var b=f.value;if(h(b,a))return k=b}return k=a}b=k;if(p(d,a))return b;var e=l(a);if(void 0!==h&&h(b,e))return b;d=a;return k=e}var c=!1,d,k,m=void 0===e?null:e;return[function(){return a(b())},null===m?void 0:function(){return a(m())}]},[b,e,l,h]);var d=q(a,c[0],c[1]);\nt(function(){f.hasValue=!0;f.value=d},[d]);v(d);return d};\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/use-sync-external-store-with-selector.production.min.js');\n} else {\n module.exports = require('./cjs/use-sync-external-store-with-selector.development.js');\n}\n","module.exports = require(\"preact\");","module.exports = require(\"preact/compat\");","module.exports = require(\"preact/hooks\");","module.exports = require(\"preact/jsx-runtime\");","// src/utils/env.ts\nvar NOTHING = Symbol.for(\"immer-nothing\");\nvar DRAFTABLE = Symbol.for(\"immer-draftable\");\nvar DRAFT_STATE = Symbol.for(\"immer-state\");\n\n// src/utils/errors.ts\nvar errors = process.env.NODE_ENV !== \"production\" ? [\n // All error codes, starting by 0:\n function(plugin) {\n return `The plugin for '${plugin}' has not been loaded into Immer. To enable the plugin, import and call \\`enable${plugin}()\\` when initializing your application.`;\n },\n function(thing) {\n return `produce can only be called on things that are draftable: plain objects, arrays, Map, Set or classes that are marked with '[immerable]: true'. Got '${thing}'`;\n },\n \"This object has been frozen and should not be mutated\",\n function(data) {\n return \"Cannot use a proxy that has been revoked. Did you pass an object from inside an immer function to an async process? \" + data;\n },\n \"An immer producer returned a new value *and* modified its draft. Either return a new value *or* modify the draft.\",\n \"Immer forbids circular references\",\n \"The first or second argument to `produce` must be a function\",\n \"The third argument to `produce` must be a function or undefined\",\n \"First argument to `createDraft` must be a plain object, an array, or an immerable object\",\n \"First argument to `finishDraft` must be a draft returned by `createDraft`\",\n function(thing) {\n return `'current' expects a draft, got: ${thing}`;\n },\n \"Object.defineProperty() cannot be used on an Immer draft\",\n \"Object.setPrototypeOf() cannot be used on an Immer draft\",\n \"Immer only supports deleting array indices\",\n \"Immer only supports setting array indices and the 'length' property\",\n function(thing) {\n return `'original' expects a draft, got: ${thing}`;\n }\n // Note: if more errors are added, the errorOffset in Patches.ts should be increased\n // See Patches.ts for additional errors\n] : [];\nfunction die(error, ...args) {\n if (process.env.NODE_ENV !== \"production\") {\n const e = errors[error];\n const msg = typeof e === \"function\" ? e.apply(null, args) : e;\n throw new Error(`[Immer] ${msg}`);\n }\n throw new Error(\n `[Immer] minified error nr: ${error}. Full error at: https://bit.ly/3cXEKWf`\n );\n}\n\n// src/utils/common.ts\nvar getPrototypeOf = Object.getPrototypeOf;\nfunction isDraft(value) {\n return !!value && !!value[DRAFT_STATE];\n}\nfunction isDraftable(value) {\n if (!value)\n return false;\n return isPlainObject(value) || Array.isArray(value) || !!value[DRAFTABLE] || !!value.constructor?.[DRAFTABLE] || isMap(value) || isSet(value);\n}\nvar objectCtorString = Object.prototype.constructor.toString();\nfunction isPlainObject(value) {\n if (!value || typeof value !== \"object\")\n return false;\n const proto = getPrototypeOf(value);\n if (proto === null) {\n return true;\n }\n const Ctor = Object.hasOwnProperty.call(proto, \"constructor\") && proto.constructor;\n if (Ctor === Object)\n return true;\n return typeof Ctor == \"function\" && Function.toString.call(Ctor) === objectCtorString;\n}\nfunction original(value) {\n if (!isDraft(value))\n die(15, value);\n return value[DRAFT_STATE].base_;\n}\nfunction each(obj, iter) {\n if (getArchtype(obj) === 0 /* Object */) {\n Object.entries(obj).forEach(([key, value]) => {\n iter(key, value, obj);\n });\n } else {\n obj.forEach((entry, index) => iter(index, entry, obj));\n }\n}\nfunction getArchtype(thing) {\n const state = thing[DRAFT_STATE];\n return state ? state.type_ : Array.isArray(thing) ? 1 /* Array */ : isMap(thing) ? 2 /* Map */ : isSet(thing) ? 3 /* Set */ : 0 /* Object */;\n}\nfunction has(thing, prop) {\n return getArchtype(thing) === 2 /* Map */ ? thing.has(prop) : Object.prototype.hasOwnProperty.call(thing, prop);\n}\nfunction get(thing, prop) {\n return getArchtype(thing) === 2 /* Map */ ? thing.get(prop) : thing[prop];\n}\nfunction set(thing, propOrOldValue, value) {\n const t = getArchtype(thing);\n if (t === 2 /* Map */)\n thing.set(propOrOldValue, value);\n else if (t === 3 /* Set */) {\n thing.add(value);\n } else\n thing[propOrOldValue] = value;\n}\nfunction is(x, y) {\n if (x === y) {\n return x !== 0 || 1 / x === 1 / y;\n } else {\n return x !== x && y !== y;\n }\n}\nfunction isMap(target) {\n return target instanceof Map;\n}\nfunction isSet(target) {\n return target instanceof Set;\n}\nfunction latest(state) {\n return state.copy_ || state.base_;\n}\nfunction shallowCopy(base, strict) {\n if (isMap(base)) {\n return new Map(base);\n }\n if (isSet(base)) {\n return new Set(base);\n }\n if (Array.isArray(base))\n return Array.prototype.slice.call(base);\n if (!strict && isPlainObject(base)) {\n if (!getPrototypeOf(base)) {\n const obj = /* @__PURE__ */ Object.create(null);\n return Object.assign(obj, base);\n }\n return { ...base };\n }\n const descriptors = Object.getOwnPropertyDescriptors(base);\n delete descriptors[DRAFT_STATE];\n let keys = Reflect.ownKeys(descriptors);\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i];\n const desc = descriptors[key];\n if (desc.writable === false) {\n desc.writable = true;\n desc.configurable = true;\n }\n if (desc.get || desc.set)\n descriptors[key] = {\n configurable: true,\n writable: true,\n // could live with !!desc.set as well here...\n enumerable: desc.enumerable,\n value: base[key]\n };\n }\n return Object.create(getPrototypeOf(base), descriptors);\n}\nfunction freeze(obj, deep = false) {\n if (isFrozen(obj) || isDraft(obj) || !isDraftable(obj))\n return obj;\n if (getArchtype(obj) > 1) {\n obj.set = obj.add = obj.clear = obj.delete = dontMutateFrozenCollections;\n }\n Object.freeze(obj);\n if (deep)\n each(obj, (_key, value) => freeze(value, true), true);\n return obj;\n}\nfunction dontMutateFrozenCollections() {\n die(2);\n}\nfunction isFrozen(obj) {\n return Object.isFrozen(obj);\n}\n\n// src/utils/plugins.ts\nvar plugins = {};\nfunction getPlugin(pluginKey) {\n const plugin = plugins[pluginKey];\n if (!plugin) {\n die(0, pluginKey);\n }\n return plugin;\n}\nfunction loadPlugin(pluginKey, implementation) {\n if (!plugins[pluginKey])\n plugins[pluginKey] = implementation;\n}\n\n// src/core/scope.ts\nvar currentScope;\nfunction getCurrentScope() {\n return currentScope;\n}\nfunction createScope(parent_, immer_) {\n return {\n drafts_: [],\n parent_,\n immer_,\n // Whenever the modified draft contains a draft from another scope, we\n // need to prevent auto-freezing so the unowned draft can be finalized.\n canAutoFreeze_: true,\n unfinalizedDrafts_: 0\n };\n}\nfunction usePatchesInScope(scope, patchListener) {\n if (patchListener) {\n getPlugin(\"Patches\");\n scope.patches_ = [];\n scope.inversePatches_ = [];\n scope.patchListener_ = patchListener;\n }\n}\nfunction revokeScope(scope) {\n leaveScope(scope);\n scope.drafts_.forEach(revokeDraft);\n scope.drafts_ = null;\n}\nfunction leaveScope(scope) {\n if (scope === currentScope) {\n currentScope = scope.parent_;\n }\n}\nfunction enterScope(immer2) {\n return currentScope = createScope(currentScope, immer2);\n}\nfunction revokeDraft(draft) {\n const state = draft[DRAFT_STATE];\n if (state.type_ === 0 /* Object */ || state.type_ === 1 /* Array */)\n state.revoke_();\n else\n state.revoked_ = true;\n}\n\n// src/core/finalize.ts\nfunction processResult(result, scope) {\n scope.unfinalizedDrafts_ = scope.drafts_.length;\n const baseDraft = scope.drafts_[0];\n const isReplaced = result !== void 0 && result !== baseDraft;\n if (isReplaced) {\n if (baseDraft[DRAFT_STATE].modified_) {\n revokeScope(scope);\n die(4);\n }\n if (isDraftable(result)) {\n result = finalize(scope, result);\n if (!scope.parent_)\n maybeFreeze(scope, result);\n }\n if (scope.patches_) {\n getPlugin(\"Patches\").generateReplacementPatches_(\n baseDraft[DRAFT_STATE].base_,\n result,\n scope.patches_,\n scope.inversePatches_\n );\n }\n } else {\n result = finalize(scope, baseDraft, []);\n }\n revokeScope(scope);\n if (scope.patches_) {\n scope.patchListener_(scope.patches_, scope.inversePatches_);\n }\n return result !== NOTHING ? result : void 0;\n}\nfunction finalize(rootScope, value, path) {\n if (isFrozen(value))\n return value;\n const state = value[DRAFT_STATE];\n if (!state) {\n each(\n value,\n (key, childValue) => finalizeProperty(rootScope, state, value, key, childValue, path),\n true\n // See #590, don't recurse into non-enumerable of non drafted objects\n );\n return value;\n }\n if (state.scope_ !== rootScope)\n return value;\n if (!state.modified_) {\n maybeFreeze(rootScope, state.base_, true);\n return state.base_;\n }\n if (!state.finalized_) {\n state.finalized_ = true;\n state.scope_.unfinalizedDrafts_--;\n const result = state.copy_;\n let resultEach = result;\n let isSet2 = false;\n if (state.type_ === 3 /* Set */) {\n resultEach = new Set(result);\n result.clear();\n isSet2 = true;\n }\n each(\n resultEach,\n (key, childValue) => finalizeProperty(rootScope, state, result, key, childValue, path, isSet2)\n );\n maybeFreeze(rootScope, result, false);\n if (path && rootScope.patches_) {\n getPlugin(\"Patches\").generatePatches_(\n state,\n path,\n rootScope.patches_,\n rootScope.inversePatches_\n );\n }\n }\n return state.copy_;\n}\nfunction finalizeProperty(rootScope, parentState, targetObject, prop, childValue, rootPath, targetIsSet) {\n if (process.env.NODE_ENV !== \"production\" && childValue === targetObject)\n die(5);\n if (isDraft(childValue)) {\n const path = rootPath && parentState && parentState.type_ !== 3 /* Set */ && // Set objects are atomic since they have no keys.\n !has(parentState.assigned_, prop) ? rootPath.concat(prop) : void 0;\n const res = finalize(rootScope, childValue, path);\n set(targetObject, prop, res);\n if (isDraft(res)) {\n rootScope.canAutoFreeze_ = false;\n } else\n return;\n } else if (targetIsSet) {\n targetObject.add(childValue);\n }\n if (isDraftable(childValue) && !isFrozen(childValue)) {\n if (!rootScope.immer_.autoFreeze_ && rootScope.unfinalizedDrafts_ < 1) {\n return;\n }\n finalize(rootScope, childValue);\n if (!parentState || !parentState.scope_.parent_)\n maybeFreeze(rootScope, childValue);\n }\n}\nfunction maybeFreeze(scope, value, deep = false) {\n if (!scope.parent_ && scope.immer_.autoFreeze_ && scope.canAutoFreeze_) {\n freeze(value, deep);\n }\n}\n\n// src/core/proxy.ts\nfunction createProxyProxy(base, parent) {\n const isArray = Array.isArray(base);\n const state = {\n type_: isArray ? 1 /* Array */ : 0 /* Object */,\n // Track which produce call this is associated with.\n scope_: parent ? parent.scope_ : getCurrentScope(),\n // True for both shallow and deep changes.\n modified_: false,\n // Used during finalization.\n finalized_: false,\n // Track which properties have been assigned (true) or deleted (false).\n assigned_: {},\n // The parent draft state.\n parent_: parent,\n // The base state.\n base_: base,\n // The base proxy.\n draft_: null,\n // set below\n // The base copy with any updated values.\n copy_: null,\n // Called by the `produce` function.\n revoke_: null,\n isManual_: false\n };\n let target = state;\n let traps = objectTraps;\n if (isArray) {\n target = [state];\n traps = arrayTraps;\n }\n const { revoke, proxy } = Proxy.revocable(target, traps);\n state.draft_ = proxy;\n state.revoke_ = revoke;\n return proxy;\n}\nvar objectTraps = {\n get(state, prop) {\n if (prop === DRAFT_STATE)\n return state;\n const source = latest(state);\n if (!has(source, prop)) {\n return readPropFromProto(state, source, prop);\n }\n const value = source[prop];\n if (state.finalized_ || !isDraftable(value)) {\n return value;\n }\n if (value === peek(state.base_, prop)) {\n prepareCopy(state);\n return state.copy_[prop] = createProxy(value, state);\n }\n return value;\n },\n has(state, prop) {\n return prop in latest(state);\n },\n ownKeys(state) {\n return Reflect.ownKeys(latest(state));\n },\n set(state, prop, value) {\n const desc = getDescriptorFromProto(latest(state), prop);\n if (desc?.set) {\n desc.set.call(state.draft_, value);\n return true;\n }\n if (!state.modified_) {\n const current2 = peek(latest(state), prop);\n const currentState = current2?.[DRAFT_STATE];\n if (currentState && currentState.base_ === value) {\n state.copy_[prop] = value;\n state.assigned_[prop] = false;\n return true;\n }\n if (is(value, current2) && (value !== void 0 || has(state.base_, prop)))\n return true;\n prepareCopy(state);\n markChanged(state);\n }\n if (state.copy_[prop] === value && // special case: handle new props with value 'undefined'\n (value !== void 0 || prop in state.copy_) || // special case: NaN\n Number.isNaN(value) && Number.isNaN(state.copy_[prop]))\n return true;\n state.copy_[prop] = value;\n state.assigned_[prop] = true;\n return true;\n },\n deleteProperty(state, prop) {\n if (peek(state.base_, prop) !== void 0 || prop in state.base_) {\n state.assigned_[prop] = false;\n prepareCopy(state);\n markChanged(state);\n } else {\n delete state.assigned_[prop];\n }\n if (state.copy_) {\n delete state.copy_[prop];\n }\n return true;\n },\n // Note: We never coerce `desc.value` into an Immer draft, because we can't make\n // the same guarantee in ES5 mode.\n getOwnPropertyDescriptor(state, prop) {\n const owner = latest(state);\n const desc = Reflect.getOwnPropertyDescriptor(owner, prop);\n if (!desc)\n return desc;\n return {\n writable: true,\n configurable: state.type_ !== 1 /* Array */ || prop !== \"length\",\n enumerable: desc.enumerable,\n value: owner[prop]\n };\n },\n defineProperty() {\n die(11);\n },\n getPrototypeOf(state) {\n return getPrototypeOf(state.base_);\n },\n setPrototypeOf() {\n die(12);\n }\n};\nvar arrayTraps = {};\neach(objectTraps, (key, fn) => {\n arrayTraps[key] = function() {\n arguments[0] = arguments[0][0];\n return fn.apply(this, arguments);\n };\n});\narrayTraps.deleteProperty = function(state, prop) {\n if (process.env.NODE_ENV !== \"production\" && isNaN(parseInt(prop)))\n die(13);\n return arrayTraps.set.call(this, state, prop, void 0);\n};\narrayTraps.set = function(state, prop, value) {\n if (process.env.NODE_ENV !== \"production\" && prop !== \"length\" && isNaN(parseInt(prop)))\n die(14);\n return objectTraps.set.call(this, state[0], prop, value, state[0]);\n};\nfunction peek(draft, prop) {\n const state = draft[DRAFT_STATE];\n const source = state ? latest(state) : draft;\n return source[prop];\n}\nfunction readPropFromProto(state, source, prop) {\n const desc = getDescriptorFromProto(source, prop);\n return desc ? `value` in desc ? desc.value : (\n // This is a very special case, if the prop is a getter defined by the\n // prototype, we should invoke it with the draft as context!\n desc.get?.call(state.draft_)\n ) : void 0;\n}\nfunction getDescriptorFromProto(source, prop) {\n if (!(prop in source))\n return void 0;\n let proto = getPrototypeOf(source);\n while (proto) {\n const desc = Object.getOwnPropertyDescriptor(proto, prop);\n if (desc)\n return desc;\n proto = getPrototypeOf(proto);\n }\n return void 0;\n}\nfunction markChanged(state) {\n if (!state.modified_) {\n state.modified_ = true;\n if (state.parent_) {\n markChanged(state.parent_);\n }\n }\n}\nfunction prepareCopy(state) {\n if (!state.copy_) {\n state.copy_ = shallowCopy(\n state.base_,\n state.scope_.immer_.useStrictShallowCopy_\n );\n }\n}\n\n// src/core/immerClass.ts\nvar Immer2 = class {\n constructor(config) {\n this.autoFreeze_ = true;\n this.useStrictShallowCopy_ = false;\n /**\n * The `produce` function takes a value and a \"recipe function\" (whose\n * return value often depends on the base state). The recipe function is\n * free to mutate its first argument however it wants. All mutations are\n * only ever applied to a __copy__ of the base state.\n *\n * Pass only a function to create a \"curried producer\" which relieves you\n * from passing the recipe function every time.\n *\n * Only plain objects and arrays are made mutable. All other objects are\n * considered uncopyable.\n *\n * Note: This function is __bound__ to its `Immer` instance.\n *\n * @param {any} base - the initial state\n * @param {Function} recipe - function that receives a proxy of the base state as first argument and which can be freely modified\n * @param {Function} patchListener - optional function that will be called with all the patches produced here\n * @returns {any} a new state, or the initial state if nothing was modified\n */\n this.produce = (base, recipe, patchListener) => {\n if (typeof base === \"function\" && typeof recipe !== \"function\") {\n const defaultBase = recipe;\n recipe = base;\n const self = this;\n return function curriedProduce(base2 = defaultBase, ...args) {\n return self.produce(base2, (draft) => recipe.call(this, draft, ...args));\n };\n }\n if (typeof recipe !== \"function\")\n die(6);\n if (patchListener !== void 0 && typeof patchListener !== \"function\")\n die(7);\n let result;\n if (isDraftable(base)) {\n const scope = enterScope(this);\n const proxy = createProxy(base, void 0);\n let hasError = true;\n try {\n result = recipe(proxy);\n hasError = false;\n } finally {\n if (hasError)\n revokeScope(scope);\n else\n leaveScope(scope);\n }\n usePatchesInScope(scope, patchListener);\n return processResult(result, scope);\n } else if (!base || typeof base !== \"object\") {\n result = recipe(base);\n if (result === void 0)\n result = base;\n if (result === NOTHING)\n result = void 0;\n if (this.autoFreeze_)\n freeze(result, true);\n if (patchListener) {\n const p = [];\n const ip = [];\n getPlugin(\"Patches\").generateReplacementPatches_(base, result, p, ip);\n patchListener(p, ip);\n }\n return result;\n } else\n die(1, base);\n };\n this.produceWithPatches = (base, recipe) => {\n if (typeof base === \"function\") {\n return (state, ...args) => this.produceWithPatches(state, (draft) => base(draft, ...args));\n }\n let patches, inversePatches;\n const result = this.produce(base, recipe, (p, ip) => {\n patches = p;\n inversePatches = ip;\n });\n return [result, patches, inversePatches];\n };\n if (typeof config?.autoFreeze === \"boolean\")\n this.setAutoFreeze(config.autoFreeze);\n if (typeof config?.useStrictShallowCopy === \"boolean\")\n this.setUseStrictShallowCopy(config.useStrictShallowCopy);\n }\n createDraft(base) {\n if (!isDraftable(base))\n die(8);\n if (isDraft(base))\n base = current(base);\n const scope = enterScope(this);\n const proxy = createProxy(base, void 0);\n proxy[DRAFT_STATE].isManual_ = true;\n leaveScope(scope);\n return proxy;\n }\n finishDraft(draft, patchListener) {\n const state = draft && draft[DRAFT_STATE];\n if (!state || !state.isManual_)\n die(9);\n const { scope_: scope } = state;\n usePatchesInScope(scope, patchListener);\n return processResult(void 0, scope);\n }\n /**\n * Pass true to automatically freeze all copies created by Immer.\n *\n * By default, auto-freezing is enabled.\n */\n setAutoFreeze(value) {\n this.autoFreeze_ = value;\n }\n /**\n * Pass true to enable strict shallow copy.\n *\n * By default, immer does not copy the object descriptors such as getter, setter and non-enumrable properties.\n */\n setUseStrictShallowCopy(value) {\n this.useStrictShallowCopy_ = value;\n }\n applyPatches(base, patches) {\n let i;\n for (i = patches.length - 1; i >= 0; i--) {\n const patch = patches[i];\n if (patch.path.length === 0 && patch.op === \"replace\") {\n base = patch.value;\n break;\n }\n }\n if (i > -1) {\n patches = patches.slice(i + 1);\n }\n const applyPatchesImpl = getPlugin(\"Patches\").applyPatches_;\n if (isDraft(base)) {\n return applyPatchesImpl(base, patches);\n }\n return this.produce(\n base,\n (draft) => applyPatchesImpl(draft, patches)\n );\n }\n};\nfunction createProxy(value, parent) {\n const draft = isMap(value) ? getPlugin(\"MapSet\").proxyMap_(value, parent) : isSet(value) ? getPlugin(\"MapSet\").proxySet_(value, parent) : createProxyProxy(value, parent);\n const scope = parent ? parent.scope_ : getCurrentScope();\n scope.drafts_.push(draft);\n return draft;\n}\n\n// src/core/current.ts\nfunction current(value) {\n if (!isDraft(value))\n die(10, value);\n return currentImpl(value);\n}\nfunction currentImpl(value) {\n if (!isDraftable(value) || isFrozen(value))\n return value;\n const state = value[DRAFT_STATE];\n let copy;\n if (state) {\n if (!state.modified_)\n return state.base_;\n state.finalized_ = true;\n copy = shallowCopy(value, state.scope_.immer_.useStrictShallowCopy_);\n } else {\n copy = shallowCopy(value, true);\n }\n each(copy, (key, childValue) => {\n set(copy, key, currentImpl(childValue));\n });\n if (state) {\n state.finalized_ = false;\n }\n return copy;\n}\n\n// src/plugins/patches.ts\nfunction enablePatches() {\n const errorOffset = 16;\n if (process.env.NODE_ENV !== \"production\") {\n errors.push(\n 'Sets cannot have \"replace\" patches.',\n function(op) {\n return \"Unsupported patch operation: \" + op;\n },\n function(path) {\n return \"Cannot apply patch, path doesn't resolve: \" + path;\n },\n \"Patching reserved attributes like __proto__, prototype and constructor is not allowed\"\n );\n }\n const REPLACE = \"replace\";\n const ADD = \"add\";\n const REMOVE = \"remove\";\n function generatePatches_(state, basePath, patches, inversePatches) {\n switch (state.type_) {\n case 0 /* Object */:\n case 2 /* Map */:\n return generatePatchesFromAssigned(\n state,\n basePath,\n patches,\n inversePatches\n );\n case 1 /* Array */:\n return generateArrayPatches(state, basePath, patches, inversePatches);\n case 3 /* Set */:\n return generateSetPatches(\n state,\n basePath,\n patches,\n inversePatches\n );\n }\n }\n function generateArrayPatches(state, basePath, patches, inversePatches) {\n let { base_, assigned_ } = state;\n let copy_ = state.copy_;\n if (copy_.length < base_.length) {\n ;\n [base_, copy_] = [copy_, base_];\n [patches, inversePatches] = [inversePatches, patches];\n }\n for (let i = 0; i < base_.length; i++) {\n if (assigned_[i] && copy_[i] !== base_[i]) {\n const path = basePath.concat([i]);\n patches.push({\n op: REPLACE,\n path,\n // Need to maybe clone it, as it can in fact be the original value\n // due to the base/copy inversion at the start of this function\n value: clonePatchValueIfNeeded(copy_[i])\n });\n inversePatches.push({\n op: REPLACE,\n path,\n value: clonePatchValueIfNeeded(base_[i])\n });\n }\n }\n for (let i = base_.length; i < copy_.length; i++) {\n const path = basePath.concat([i]);\n patches.push({\n op: ADD,\n path,\n // Need to maybe clone it, as it can in fact be the original value\n // due to the base/copy inversion at the start of this function\n value: clonePatchValueIfNeeded(copy_[i])\n });\n }\n for (let i = copy_.length - 1; base_.length <= i; --i) {\n const path = basePath.concat([i]);\n inversePatches.push({\n op: REMOVE,\n path\n });\n }\n }\n function generatePatchesFromAssigned(state, basePath, patches, inversePatches) {\n const { base_, copy_ } = state;\n each(state.assigned_, (key, assignedValue) => {\n const origValue = get(base_, key);\n const value = get(copy_, key);\n const op = !assignedValue ? REMOVE : has(base_, key) ? REPLACE : ADD;\n if (origValue === value && op === REPLACE)\n return;\n const path = basePath.concat(key);\n patches.push(op === REMOVE ? { op, path } : { op, path, value });\n inversePatches.push(\n op === ADD ? { op: REMOVE, path } : op === REMOVE ? { op: ADD, path, value: clonePatchValueIfNeeded(origValue) } : { op: REPLACE, path, value: clonePatchValueIfNeeded(origValue) }\n );\n });\n }\n function generateSetPatches(state, basePath, patches, inversePatches) {\n let { base_, copy_ } = state;\n let i = 0;\n base_.forEach((value) => {\n if (!copy_.has(value)) {\n const path = basePath.concat([i]);\n patches.push({\n op: REMOVE,\n path,\n value\n });\n inversePatches.unshift({\n op: ADD,\n path,\n value\n });\n }\n i++;\n });\n i = 0;\n copy_.forEach((value) => {\n if (!base_.has(value)) {\n const path = basePath.concat([i]);\n patches.push({\n op: ADD,\n path,\n value\n });\n inversePatches.unshift({\n op: REMOVE,\n path,\n value\n });\n }\n i++;\n });\n }\n function generateReplacementPatches_(baseValue, replacement, patches, inversePatches) {\n patches.push({\n op: REPLACE,\n path: [],\n value: replacement === NOTHING ? void 0 : replacement\n });\n inversePatches.push({\n op: REPLACE,\n path: [],\n value: baseValue\n });\n }\n function applyPatches_(draft, patches) {\n patches.forEach((patch) => {\n const { path, op } = patch;\n let base = draft;\n for (let i = 0; i < path.length - 1; i++) {\n const parentType = getArchtype(base);\n let p = path[i];\n if (typeof p !== \"string\" && typeof p !== \"number\") {\n p = \"\" + p;\n }\n if ((parentType === 0 /* Object */ || parentType === 1 /* Array */) && (p === \"__proto__\" || p === \"constructor\"))\n die(errorOffset + 3);\n if (typeof base === \"function\" && p === \"prototype\")\n die(errorOffset + 3);\n base = get(base, p);\n if (typeof base !== \"object\")\n die(errorOffset + 2, path.join(\"/\"));\n }\n const type = getArchtype(base);\n const value = deepClonePatchValue(patch.value);\n const key = path[path.length - 1];\n switch (op) {\n case REPLACE:\n switch (type) {\n case 2 /* Map */:\n return base.set(key, value);\n case 3 /* Set */:\n die(errorOffset);\n default:\n return base[key] = value;\n }\n case ADD:\n switch (type) {\n case 1 /* Array */:\n return key === \"-\" ? base.push(value) : base.splice(key, 0, value);\n case 2 /* Map */:\n return base.set(key, value);\n case 3 /* Set */:\n return base.add(value);\n default:\n return base[key] = value;\n }\n case REMOVE:\n switch (type) {\n case 1 /* Array */:\n return base.splice(key, 1);\n case 2 /* Map */:\n return base.delete(key);\n case 3 /* Set */:\n return base.delete(patch.value);\n default:\n return delete base[key];\n }\n default:\n die(errorOffset + 1, op);\n }\n });\n return draft;\n }\n function deepClonePatchValue(obj) {\n if (!isDraftable(obj))\n return obj;\n if (Array.isArray(obj))\n return obj.map(deepClonePatchValue);\n if (isMap(obj))\n return new Map(\n Array.from(obj.entries()).map(([k, v]) => [k, deepClonePatchValue(v)])\n );\n if (isSet(obj))\n return new Set(Array.from(obj).map(deepClonePatchValue));\n const cloned = Object.create(getPrototypeOf(obj));\n for (const key in obj)\n cloned[key] = deepClonePatchValue(obj[key]);\n if (has(obj, DRAFTABLE))\n cloned[DRAFTABLE] = obj[DRAFTABLE];\n return cloned;\n }\n function clonePatchValueIfNeeded(obj) {\n if (isDraft(obj)) {\n return deepClonePatchValue(obj);\n } else\n return obj;\n }\n loadPlugin(\"Patches\", {\n applyPatches_,\n generatePatches_,\n generateReplacementPatches_\n });\n}\n\n// src/plugins/mapset.ts\nfunction enableMapSet() {\n class DraftMap extends Map {\n constructor(target, parent) {\n super();\n this[DRAFT_STATE] = {\n type_: 2 /* Map */,\n parent_: parent,\n scope_: parent ? parent.scope_ : getCurrentScope(),\n modified_: false,\n finalized_: false,\n copy_: void 0,\n assigned_: void 0,\n base_: target,\n draft_: this,\n isManual_: false,\n revoked_: false\n };\n }\n get size() {\n return latest(this[DRAFT_STATE]).size;\n }\n has(key) {\n return latest(this[DRAFT_STATE]).has(key);\n }\n set(key, value) {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (!latest(state).has(key) || latest(state).get(key) !== value) {\n prepareMapCopy(state);\n markChanged(state);\n state.assigned_.set(key, true);\n state.copy_.set(key, value);\n state.assigned_.set(key, true);\n }\n return this;\n }\n delete(key) {\n if (!this.has(key)) {\n return false;\n }\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n prepareMapCopy(state);\n markChanged(state);\n if (state.base_.has(key)) {\n state.assigned_.set(key, false);\n } else {\n state.assigned_.delete(key);\n }\n state.copy_.delete(key);\n return true;\n }\n clear() {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (latest(state).size) {\n prepareMapCopy(state);\n markChanged(state);\n state.assigned_ = /* @__PURE__ */ new Map();\n each(state.base_, (key) => {\n state.assigned_.set(key, false);\n });\n state.copy_.clear();\n }\n }\n forEach(cb, thisArg) {\n const state = this[DRAFT_STATE];\n latest(state).forEach((_value, key, _map) => {\n cb.call(thisArg, this.get(key), key, this);\n });\n }\n get(key) {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n const value = latest(state).get(key);\n if (state.finalized_ || !isDraftable(value)) {\n return value;\n }\n if (value !== state.base_.get(key)) {\n return value;\n }\n const draft = createProxy(value, state);\n prepareMapCopy(state);\n state.copy_.set(key, draft);\n return draft;\n }\n keys() {\n return latest(this[DRAFT_STATE]).keys();\n }\n values() {\n const iterator = this.keys();\n return {\n [Symbol.iterator]: () => this.values(),\n next: () => {\n const r = iterator.next();\n if (r.done)\n return r;\n const value = this.get(r.value);\n return {\n done: false,\n value\n };\n }\n };\n }\n entries() {\n const iterator = this.keys();\n return {\n [Symbol.iterator]: () => this.entries(),\n next: () => {\n const r = iterator.next();\n if (r.done)\n return r;\n const value = this.get(r.value);\n return {\n done: false,\n value: [r.value, value]\n };\n }\n };\n }\n [(DRAFT_STATE, Symbol.iterator)]() {\n return this.entries();\n }\n }\n function proxyMap_(target, parent) {\n return new DraftMap(target, parent);\n }\n function prepareMapCopy(state) {\n if (!state.copy_) {\n state.assigned_ = /* @__PURE__ */ new Map();\n state.copy_ = new Map(state.base_);\n }\n }\n class DraftSet extends Set {\n constructor(target, parent) {\n super();\n this[DRAFT_STATE] = {\n type_: 3 /* Set */,\n parent_: parent,\n scope_: parent ? parent.scope_ : getCurrentScope(),\n modified_: false,\n finalized_: false,\n copy_: void 0,\n base_: target,\n draft_: this,\n drafts_: /* @__PURE__ */ new Map(),\n revoked_: false,\n isManual_: false\n };\n }\n get size() {\n return latest(this[DRAFT_STATE]).size;\n }\n has(value) {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (!state.copy_) {\n return state.base_.has(value);\n }\n if (state.copy_.has(value))\n return true;\n if (state.drafts_.has(value) && state.copy_.has(state.drafts_.get(value)))\n return true;\n return false;\n }\n add(value) {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (!this.has(value)) {\n prepareSetCopy(state);\n markChanged(state);\n state.copy_.add(value);\n }\n return this;\n }\n delete(value) {\n if (!this.has(value)) {\n return false;\n }\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n prepareSetCopy(state);\n markChanged(state);\n return state.copy_.delete(value) || (state.drafts_.has(value) ? state.copy_.delete(state.drafts_.get(value)) : (\n /* istanbul ignore next */\n false\n ));\n }\n clear() {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (latest(state).size) {\n prepareSetCopy(state);\n markChanged(state);\n state.copy_.clear();\n }\n }\n values() {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n prepareSetCopy(state);\n return state.copy_.values();\n }\n entries() {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n prepareSetCopy(state);\n return state.copy_.entries();\n }\n keys() {\n return this.values();\n }\n [(DRAFT_STATE, Symbol.iterator)]() {\n return this.values();\n }\n forEach(cb, thisArg) {\n const iterator = this.values();\n let result = iterator.next();\n while (!result.done) {\n cb.call(thisArg, result.value, result.value, this);\n result = iterator.next();\n }\n }\n }\n function proxySet_(target, parent) {\n return new DraftSet(target, parent);\n }\n function prepareSetCopy(state) {\n if (!state.copy_) {\n state.copy_ = /* @__PURE__ */ new Set();\n state.base_.forEach((value) => {\n if (isDraftable(value)) {\n const draft = createProxy(value, state);\n state.drafts_.set(value, draft);\n state.copy_.add(draft);\n } else {\n state.copy_.add(value);\n }\n });\n }\n }\n function assertUnrevoked(state) {\n if (state.revoked_)\n die(3, JSON.stringify(latest(state)));\n }\n loadPlugin(\"MapSet\", { proxyMap_, proxySet_ });\n}\n\n// src/immer.ts\nvar immer = new Immer2();\nvar produce = immer.produce;\nvar produceWithPatches = immer.produceWithPatches.bind(\n immer\n);\nvar setAutoFreeze = immer.setAutoFreeze.bind(immer);\nvar setUseStrictShallowCopy = immer.setUseStrictShallowCopy.bind(immer);\nvar applyPatches = immer.applyPatches.bind(immer);\nvar createDraft = immer.createDraft.bind(immer);\nvar finishDraft = immer.finishDraft.bind(immer);\nfunction castDraft(value) {\n return value;\n}\nfunction castImmutable(value) {\n return value;\n}\nexport {\n Immer2 as Immer,\n applyPatches,\n castDraft,\n castImmutable,\n createDraft,\n current,\n enableMapSet,\n enablePatches,\n finishDraft,\n freeze,\n DRAFTABLE as immerable,\n isDraft,\n isDraftable,\n NOTHING as nothing,\n original,\n produce,\n produceWithPatches,\n setAutoFreeze,\n setUseStrictShallowCopy\n};\n//# sourceMappingURL=immer.mjs.map","// src/index.ts\nexport * from \"redux\";\nimport { produce, current as current2, freeze, original as original2, isDraft as isDraft4 } from \"immer\";\nimport { createSelector, createSelectorCreator as createSelectorCreator2, lruMemoize, weakMapMemoize as weakMapMemoize2 } from \"reselect\";\n\n// src/createDraftSafeSelector.ts\nimport { current, isDraft } from \"immer\";\nimport { createSelectorCreator, weakMapMemoize } from \"reselect\";\nvar createDraftSafeSelectorCreator = (...args) => {\n const createSelector2 = createSelectorCreator(...args);\n const createDraftSafeSelector2 = Object.assign((...args2) => {\n const selector = createSelector2(...args2);\n const wrappedSelector = (value, ...rest) => selector(isDraft(value) ? current(value) : value, ...rest);\n Object.assign(wrappedSelector, selector);\n return wrappedSelector;\n }, {\n withTypes: () => createDraftSafeSelector2\n });\n return createDraftSafeSelector2;\n};\nvar createDraftSafeSelector = createDraftSafeSelectorCreator(weakMapMemoize);\n\n// src/configureStore.ts\nimport { applyMiddleware, createStore, compose as compose2, combineReducers, isPlainObject as isPlainObject2 } from \"redux\";\n\n// src/devtoolsExtension.ts\nimport { compose } from \"redux\";\nvar composeWithDevTools = typeof window !== \"undefined\" && window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ ? window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ : function() {\n if (arguments.length === 0)\n return void 0;\n if (typeof arguments[0] === \"object\")\n return compose;\n return compose.apply(null, arguments);\n};\nvar devToolsEnhancer = typeof window !== \"undefined\" && window.__REDUX_DEVTOOLS_EXTENSION__ ? window.__REDUX_DEVTOOLS_EXTENSION__ : function() {\n return function(noop3) {\n return noop3;\n };\n};\n\n// src/getDefaultMiddleware.ts\nimport { thunk as thunkMiddleware, withExtraArgument } from \"redux-thunk\";\n\n// src/createAction.ts\nimport { isAction } from \"redux\";\n\n// src/tsHelpers.ts\nvar hasMatchFunction = (v) => {\n return v && typeof v.match === \"function\";\n};\n\n// src/createAction.ts\nfunction createAction(type, prepareAction) {\n function actionCreator(...args) {\n if (prepareAction) {\n let prepared = prepareAction(...args);\n if (!prepared) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(0) : \"prepareAction did not return an object\");\n }\n return {\n type,\n payload: prepared.payload,\n ...\"meta\" in prepared && {\n meta: prepared.meta\n },\n ...\"error\" in prepared && {\n error: prepared.error\n }\n };\n }\n return {\n type,\n payload: args[0]\n };\n }\n actionCreator.toString = () => `${type}`;\n actionCreator.type = type;\n actionCreator.match = (action) => isAction(action) && action.type === type;\n return actionCreator;\n}\nfunction isActionCreator(action) {\n return typeof action === \"function\" && \"type\" in action && // hasMatchFunction only wants Matchers but I don't see the point in rewriting it\n hasMatchFunction(action);\n}\nfunction isFSA(action) {\n return isAction(action) && Object.keys(action).every(isValidKey);\n}\nfunction isValidKey(key) {\n return [\"type\", \"payload\", \"error\", \"meta\"].indexOf(key) > -1;\n}\n\n// src/actionCreatorInvariantMiddleware.ts\nfunction getMessage(type) {\n const splitType = type ? `${type}`.split(\"/\") : [];\n const actionName = splitType[splitType.length - 1] || \"actionCreator\";\n return `Detected an action creator with type \"${type || \"unknown\"}\" being dispatched. \nMake sure you're calling the action creator before dispatching, i.e. \\`dispatch(${actionName}())\\` instead of \\`dispatch(${actionName})\\`. This is necessary even if the action has no payload.`;\n}\nfunction createActionCreatorInvariantMiddleware(options = {}) {\n if (process.env.NODE_ENV === \"production\") {\n return () => (next) => (action) => next(action);\n }\n const {\n isActionCreator: isActionCreator2 = isActionCreator\n } = options;\n return () => (next) => (action) => {\n if (isActionCreator2(action)) {\n console.warn(getMessage(action.type));\n }\n return next(action);\n };\n}\n\n// src/utils.ts\nimport { produce as createNextState, isDraftable } from \"immer\";\nfunction getTimeMeasureUtils(maxDelay, fnName) {\n let elapsed = 0;\n return {\n measureTime(fn) {\n const started = Date.now();\n try {\n return fn();\n } finally {\n const finished = Date.now();\n elapsed += finished - started;\n }\n },\n warnIfExceeded() {\n if (elapsed > maxDelay) {\n console.warn(`${fnName} took ${elapsed}ms, which is more than the warning threshold of ${maxDelay}ms. \nIf your state or actions are very large, you may want to disable the middleware as it might cause too much of a slowdown in development mode. See https://redux-toolkit.js.org/api/getDefaultMiddleware for instructions.\nIt is disabled in production builds, so you don't need to worry about that.`);\n }\n }\n };\n}\nfunction find(iterable, comparator) {\n for (const entry of iterable) {\n if (comparator(entry)) {\n return entry;\n }\n }\n return void 0;\n}\nvar Tuple = class _Tuple extends Array {\n constructor(...items) {\n super(...items);\n Object.setPrototypeOf(this, _Tuple.prototype);\n }\n static get [Symbol.species]() {\n return _Tuple;\n }\n concat(...arr) {\n return super.concat.apply(this, arr);\n }\n prepend(...arr) {\n if (arr.length === 1 && Array.isArray(arr[0])) {\n return new _Tuple(...arr[0].concat(this));\n }\n return new _Tuple(...arr.concat(this));\n }\n};\nfunction freezeDraftable(val) {\n return isDraftable(val) ? createNextState(val, () => {\n }) : val;\n}\nfunction emplace(map, key, handler) {\n if (map.has(key)) {\n let value = map.get(key);\n if (handler.update) {\n value = handler.update(value, key, map);\n map.set(key, value);\n }\n return value;\n }\n if (!handler.insert)\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(10) : \"No insert provided for key not already in map\");\n const inserted = handler.insert(key, map);\n map.set(key, inserted);\n return inserted;\n}\n\n// src/immutableStateInvariantMiddleware.ts\nfunction isImmutableDefault(value) {\n return typeof value !== \"object\" || value == null || Object.isFrozen(value);\n}\nfunction trackForMutations(isImmutable, ignorePaths, obj) {\n const trackedProperties = trackProperties(isImmutable, ignorePaths, obj);\n return {\n detectMutations() {\n return detectMutations(isImmutable, ignorePaths, trackedProperties, obj);\n }\n };\n}\nfunction trackProperties(isImmutable, ignorePaths = [], obj, path = \"\", checkedObjects = /* @__PURE__ */ new Set()) {\n const tracked = {\n value: obj\n };\n if (!isImmutable(obj) && !checkedObjects.has(obj)) {\n checkedObjects.add(obj);\n tracked.children = {};\n for (const key in obj) {\n const childPath = path ? path + \".\" + key : key;\n if (ignorePaths.length && ignorePaths.indexOf(childPath) !== -1) {\n continue;\n }\n tracked.children[key] = trackProperties(isImmutable, ignorePaths, obj[key], childPath);\n }\n }\n return tracked;\n}\nfunction detectMutations(isImmutable, ignoredPaths = [], trackedProperty, obj, sameParentRef = false, path = \"\") {\n const prevObj = trackedProperty ? trackedProperty.value : void 0;\n const sameRef = prevObj === obj;\n if (sameParentRef && !sameRef && !Number.isNaN(obj)) {\n return {\n wasMutated: true,\n path\n };\n }\n if (isImmutable(prevObj) || isImmutable(obj)) {\n return {\n wasMutated: false\n };\n }\n const keysToDetect = {};\n for (let key in trackedProperty.children) {\n keysToDetect[key] = true;\n }\n for (let key in obj) {\n keysToDetect[key] = true;\n }\n const hasIgnoredPaths = ignoredPaths.length > 0;\n for (let key in keysToDetect) {\n const nestedPath = path ? path + \".\" + key : key;\n if (hasIgnoredPaths) {\n const hasMatches = ignoredPaths.some((ignored) => {\n if (ignored instanceof RegExp) {\n return ignored.test(nestedPath);\n }\n return nestedPath === ignored;\n });\n if (hasMatches) {\n continue;\n }\n }\n const result = detectMutations(isImmutable, ignoredPaths, trackedProperty.children[key], obj[key], sameRef, nestedPath);\n if (result.wasMutated) {\n return result;\n }\n }\n return {\n wasMutated: false\n };\n}\nfunction createImmutableStateInvariantMiddleware(options = {}) {\n if (process.env.NODE_ENV === \"production\") {\n return () => (next) => (action) => next(action);\n } else {\n let stringify2 = function(obj, serializer, indent, decycler) {\n return JSON.stringify(obj, getSerialize2(serializer, decycler), indent);\n }, getSerialize2 = function(serializer, decycler) {\n let stack = [], keys = [];\n if (!decycler)\n decycler = function(_, value) {\n if (stack[0] === value)\n return \"[Circular ~]\";\n return \"[Circular ~.\" + keys.slice(0, stack.indexOf(value)).join(\".\") + \"]\";\n };\n return function(key, value) {\n if (stack.length > 0) {\n var thisPos = stack.indexOf(this);\n ~thisPos ? stack.splice(thisPos + 1) : stack.push(this);\n ~thisPos ? keys.splice(thisPos, Infinity, key) : keys.push(key);\n if (~stack.indexOf(value))\n value = decycler.call(this, key, value);\n } else\n stack.push(value);\n return serializer == null ? value : serializer.call(this, key, value);\n };\n };\n var stringify = stringify2, getSerialize = getSerialize2;\n let {\n isImmutable = isImmutableDefault,\n ignoredPaths,\n warnAfter = 32\n } = options;\n const track = trackForMutations.bind(null, isImmutable, ignoredPaths);\n return ({\n getState\n }) => {\n let state = getState();\n let tracker = track(state);\n let result;\n return (next) => (action) => {\n const measureUtils = getTimeMeasureUtils(warnAfter, \"ImmutableStateInvariantMiddleware\");\n measureUtils.measureTime(() => {\n state = getState();\n result = tracker.detectMutations();\n tracker = track(state);\n if (result.wasMutated) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(19) : `A state mutation was detected between dispatches, in the path '${result.path || \"\"}'. This may cause incorrect behavior. (https://redux.js.org/style-guide/style-guide#do-not-mutate-state)`);\n }\n });\n const dispatchedAction = next(action);\n measureUtils.measureTime(() => {\n state = getState();\n result = tracker.detectMutations();\n tracker = track(state);\n if (result.wasMutated) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(20) : `A state mutation was detected inside a dispatch, in the path: ${result.path || \"\"}. Take a look at the reducer(s) handling the action ${stringify2(action)}. (https://redux.js.org/style-guide/style-guide#do-not-mutate-state)`);\n }\n });\n measureUtils.warnIfExceeded();\n return dispatchedAction;\n };\n };\n }\n}\n\n// src/serializableStateInvariantMiddleware.ts\nimport { isAction as isAction2, isPlainObject } from \"redux\";\nfunction isPlain(val) {\n const type = typeof val;\n return val == null || type === \"string\" || type === \"boolean\" || type === \"number\" || Array.isArray(val) || isPlainObject(val);\n}\nfunction findNonSerializableValue(value, path = \"\", isSerializable = isPlain, getEntries, ignoredPaths = [], cache) {\n let foundNestedSerializable;\n if (!isSerializable(value)) {\n return {\n keyPath: path || \"<root>\",\n value\n };\n }\n if (typeof value !== \"object\" || value === null) {\n return false;\n }\n if (cache?.has(value))\n return false;\n const entries = getEntries != null ? getEntries(value) : Object.entries(value);\n const hasIgnoredPaths = ignoredPaths.length > 0;\n for (const [key, nestedValue] of entries) {\n const nestedPath = path ? path + \".\" + key : key;\n if (hasIgnoredPaths) {\n const hasMatches = ignoredPaths.some((ignored) => {\n if (ignored instanceof RegExp) {\n return ignored.test(nestedPath);\n }\n return nestedPath === ignored;\n });\n if (hasMatches) {\n continue;\n }\n }\n if (!isSerializable(nestedValue)) {\n return {\n keyPath: nestedPath,\n value: nestedValue\n };\n }\n if (typeof nestedValue === \"object\") {\n foundNestedSerializable = findNonSerializableValue(nestedValue, nestedPath, isSerializable, getEntries, ignoredPaths, cache);\n if (foundNestedSerializable) {\n return foundNestedSerializable;\n }\n }\n }\n if (cache && isNestedFrozen(value))\n cache.add(value);\n return false;\n}\nfunction isNestedFrozen(value) {\n if (!Object.isFrozen(value))\n return false;\n for (const nestedValue of Object.values(value)) {\n if (typeof nestedValue !== \"object\" || nestedValue === null)\n continue;\n if (!isNestedFrozen(nestedValue))\n return false;\n }\n return true;\n}\nfunction createSerializableStateInvariantMiddleware(options = {}) {\n if (process.env.NODE_ENV === \"production\") {\n return () => (next) => (action) => next(action);\n } else {\n const {\n isSerializable = isPlain,\n getEntries,\n ignoredActions = [],\n ignoredActionPaths = [\"meta.arg\", \"meta.baseQueryMeta\"],\n ignoredPaths = [],\n warnAfter = 32,\n ignoreState = false,\n ignoreActions = false,\n disableCache = false\n } = options;\n const cache = !disableCache && WeakSet ? /* @__PURE__ */ new WeakSet() : void 0;\n return (storeAPI) => (next) => (action) => {\n if (!isAction2(action)) {\n return next(action);\n }\n const result = next(action);\n const measureUtils = getTimeMeasureUtils(warnAfter, \"SerializableStateInvariantMiddleware\");\n if (!ignoreActions && !(ignoredActions.length && ignoredActions.indexOf(action.type) !== -1)) {\n measureUtils.measureTime(() => {\n const foundActionNonSerializableValue = findNonSerializableValue(action, \"\", isSerializable, getEntries, ignoredActionPaths, cache);\n if (foundActionNonSerializableValue) {\n const {\n keyPath,\n value\n } = foundActionNonSerializableValue;\n console.error(`A non-serializable value was detected in an action, in the path: \\`${keyPath}\\`. Value:`, value, \"\\nTake a look at the logic that dispatched this action: \", action, \"\\n(See https://redux.js.org/faq/actions#why-should-type-be-a-string-or-at-least-serializable-why-should-my-action-types-be-constants)\", \"\\n(To allow non-serializable values see: https://redux-toolkit.js.org/usage/usage-guide#working-with-non-serializable-data)\");\n }\n });\n }\n if (!ignoreState) {\n measureUtils.measureTime(() => {\n const state = storeAPI.getState();\n const foundStateNonSerializableValue = findNonSerializableValue(state, \"\", isSerializable, getEntries, ignoredPaths, cache);\n if (foundStateNonSerializableValue) {\n const {\n keyPath,\n value\n } = foundStateNonSerializableValue;\n console.error(`A non-serializable value was detected in the state, in the path: \\`${keyPath}\\`. Value:`, value, `\nTake a look at the reducer(s) handling this action type: ${action.type}.\n(See https://redux.js.org/faq/organizing-state#can-i-put-functions-promises-or-other-non-serializable-items-in-my-store-state)`);\n }\n });\n measureUtils.warnIfExceeded();\n }\n return result;\n };\n }\n}\n\n// src/getDefaultMiddleware.ts\nfunction isBoolean(x) {\n return typeof x === \"boolean\";\n}\nvar buildGetDefaultMiddleware = () => function getDefaultMiddleware(options) {\n const {\n thunk = true,\n immutableCheck = true,\n serializableCheck = true,\n actionCreatorCheck = true\n } = options ?? {};\n let middlewareArray = new Tuple();\n if (thunk) {\n if (isBoolean(thunk)) {\n middlewareArray.push(thunkMiddleware);\n } else {\n middlewareArray.push(withExtraArgument(thunk.extraArgument));\n }\n }\n if (process.env.NODE_ENV !== \"production\") {\n if (immutableCheck) {\n let immutableOptions = {};\n if (!isBoolean(immutableCheck)) {\n immutableOptions = immutableCheck;\n }\n middlewareArray.unshift(createImmutableStateInvariantMiddleware(immutableOptions));\n }\n if (serializableCheck) {\n let serializableOptions = {};\n if (!isBoolean(serializableCheck)) {\n serializableOptions = serializableCheck;\n }\n middlewareArray.push(createSerializableStateInvariantMiddleware(serializableOptions));\n }\n if (actionCreatorCheck) {\n let actionCreatorOptions = {};\n if (!isBoolean(actionCreatorCheck)) {\n actionCreatorOptions = actionCreatorCheck;\n }\n middlewareArray.unshift(createActionCreatorInvariantMiddleware(actionCreatorOptions));\n }\n }\n return middlewareArray;\n};\n\n// src/autoBatchEnhancer.ts\nvar SHOULD_AUTOBATCH = \"RTK_autoBatch\";\nvar prepareAutoBatched = () => (payload) => ({\n payload,\n meta: {\n [SHOULD_AUTOBATCH]: true\n }\n});\nvar createQueueWithTimer = (timeout) => {\n return (notify) => {\n setTimeout(notify, timeout);\n };\n};\nvar rAF = typeof window !== \"undefined\" && window.requestAnimationFrame ? window.requestAnimationFrame : createQueueWithTimer(10);\nvar autoBatchEnhancer = (options = {\n type: \"raf\"\n}) => (next) => (...args) => {\n const store = next(...args);\n let notifying = true;\n let shouldNotifyAtEndOfTick = false;\n let notificationQueued = false;\n const listeners = /* @__PURE__ */ new Set();\n const queueCallback = options.type === \"tick\" ? queueMicrotask : options.type === \"raf\" ? rAF : options.type === \"callback\" ? options.queueNotification : createQueueWithTimer(options.timeout);\n const notifyListeners = () => {\n notificationQueued = false;\n if (shouldNotifyAtEndOfTick) {\n shouldNotifyAtEndOfTick = false;\n listeners.forEach((l) => l());\n }\n };\n return Object.assign({}, store, {\n // Override the base `store.subscribe` method to keep original listeners\n // from running if we're delaying notifications\n subscribe(listener2) {\n const wrappedListener = () => notifying && listener2();\n const unsubscribe = store.subscribe(wrappedListener);\n listeners.add(listener2);\n return () => {\n unsubscribe();\n listeners.delete(listener2);\n };\n },\n // Override the base `store.dispatch` method so that we can check actions\n // for the `shouldAutoBatch` flag and determine if batching is active\n dispatch(action) {\n try {\n notifying = !action?.meta?.[SHOULD_AUTOBATCH];\n shouldNotifyAtEndOfTick = !notifying;\n if (shouldNotifyAtEndOfTick) {\n if (!notificationQueued) {\n notificationQueued = true;\n queueCallback(notifyListeners);\n }\n }\n return store.dispatch(action);\n } finally {\n notifying = true;\n }\n }\n });\n};\n\n// src/getDefaultEnhancers.ts\nvar buildGetDefaultEnhancers = (middlewareEnhancer) => function getDefaultEnhancers(options) {\n const {\n autoBatch = true\n } = options ?? {};\n let enhancerArray = new Tuple(middlewareEnhancer);\n if (autoBatch) {\n enhancerArray.push(autoBatchEnhancer(typeof autoBatch === \"object\" ? autoBatch : void 0));\n }\n return enhancerArray;\n};\n\n// src/configureStore.ts\nvar IS_PRODUCTION = process.env.NODE_ENV === \"production\";\nfunction configureStore(options) {\n const getDefaultMiddleware = buildGetDefaultMiddleware();\n const {\n reducer = void 0,\n middleware,\n devTools = true,\n preloadedState = void 0,\n enhancers = void 0\n } = options || {};\n let rootReducer;\n if (typeof reducer === \"function\") {\n rootReducer = reducer;\n } else if (isPlainObject2(reducer)) {\n rootReducer = combineReducers(reducer);\n } else {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(1) : \"`reducer` is a required argument, and must be a function or an object of functions that can be passed to combineReducers\");\n }\n if (!IS_PRODUCTION && middleware && typeof middleware !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(2) : \"`middleware` field must be a callback\");\n }\n let finalMiddleware;\n if (typeof middleware === \"function\") {\n finalMiddleware = middleware(getDefaultMiddleware);\n if (!IS_PRODUCTION && !Array.isArray(finalMiddleware)) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(3) : \"when using a middleware builder function, an array of middleware must be returned\");\n }\n } else {\n finalMiddleware = getDefaultMiddleware();\n }\n if (!IS_PRODUCTION && finalMiddleware.some((item) => typeof item !== \"function\")) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(4) : \"each middleware provided to configureStore must be a function\");\n }\n let finalCompose = compose2;\n if (devTools) {\n finalCompose = composeWithDevTools({\n // Enable capture of stack traces for dispatched Redux actions\n trace: !IS_PRODUCTION,\n ...typeof devTools === \"object\" && devTools\n });\n }\n const middlewareEnhancer = applyMiddleware(...finalMiddleware);\n const getDefaultEnhancers = buildGetDefaultEnhancers(middlewareEnhancer);\n if (!IS_PRODUCTION && enhancers && typeof enhancers !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(5) : \"`enhancers` field must be a callback\");\n }\n let storeEnhancers = typeof enhancers === \"function\" ? enhancers(getDefaultEnhancers) : getDefaultEnhancers();\n if (!IS_PRODUCTION && !Array.isArray(storeEnhancers)) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(6) : \"`enhancers` callback must return an array\");\n }\n if (!IS_PRODUCTION && storeEnhancers.some((item) => typeof item !== \"function\")) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(7) : \"each enhancer provided to configureStore must be a function\");\n }\n if (!IS_PRODUCTION && finalMiddleware.length && !storeEnhancers.includes(middlewareEnhancer)) {\n console.error(\"middlewares were provided, but middleware enhancer was not included in final enhancers - make sure to call `getDefaultEnhancers`\");\n }\n const composedEnhancer = finalCompose(...storeEnhancers);\n return createStore(rootReducer, preloadedState, composedEnhancer);\n}\n\n// src/createReducer.ts\nimport { produce as createNextState2, isDraft as isDraft2, isDraftable as isDraftable2 } from \"immer\";\n\n// src/mapBuilders.ts\nfunction executeReducerBuilderCallback(builderCallback) {\n const actionsMap = {};\n const actionMatchers = [];\n let defaultCaseReducer;\n const builder = {\n addCase(typeOrActionCreator, reducer) {\n if (process.env.NODE_ENV !== \"production\") {\n if (actionMatchers.length > 0) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(26) : \"`builder.addCase` should only be called before calling `builder.addMatcher`\");\n }\n if (defaultCaseReducer) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(27) : \"`builder.addCase` should only be called before calling `builder.addDefaultCase`\");\n }\n }\n const type = typeof typeOrActionCreator === \"string\" ? typeOrActionCreator : typeOrActionCreator.type;\n if (!type) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(28) : \"`builder.addCase` cannot be called with an empty action type\");\n }\n if (type in actionsMap) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(29) : `\\`builder.addCase\\` cannot be called with two reducers for the same action type '${type}'`);\n }\n actionsMap[type] = reducer;\n return builder;\n },\n addMatcher(matcher, reducer) {\n if (process.env.NODE_ENV !== \"production\") {\n if (defaultCaseReducer) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(30) : \"`builder.addMatcher` should only be called before calling `builder.addDefaultCase`\");\n }\n }\n actionMatchers.push({\n matcher,\n reducer\n });\n return builder;\n },\n addDefaultCase(reducer) {\n if (process.env.NODE_ENV !== \"production\") {\n if (defaultCaseReducer) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(31) : \"`builder.addDefaultCase` can only be called once\");\n }\n }\n defaultCaseReducer = reducer;\n return builder;\n }\n };\n builderCallback(builder);\n return [actionsMap, actionMatchers, defaultCaseReducer];\n}\n\n// src/createReducer.ts\nfunction isStateFunction(x) {\n return typeof x === \"function\";\n}\nfunction createReducer(initialState, mapOrBuilderCallback) {\n if (process.env.NODE_ENV !== \"production\") {\n if (typeof mapOrBuilderCallback === \"object\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(8) : \"The object notation for `createReducer` has been removed. Please use the 'builder callback' notation instead: https://redux-toolkit.js.org/api/createReducer\");\n }\n }\n let [actionsMap, finalActionMatchers, finalDefaultCaseReducer] = executeReducerBuilderCallback(mapOrBuilderCallback);\n let getInitialState;\n if (isStateFunction(initialState)) {\n getInitialState = () => freezeDraftable(initialState());\n } else {\n const frozenInitialState = freezeDraftable(initialState);\n getInitialState = () => frozenInitialState;\n }\n function reducer(state = getInitialState(), action) {\n let caseReducers = [actionsMap[action.type], ...finalActionMatchers.filter(({\n matcher\n }) => matcher(action)).map(({\n reducer: reducer2\n }) => reducer2)];\n if (caseReducers.filter((cr) => !!cr).length === 0) {\n caseReducers = [finalDefaultCaseReducer];\n }\n return caseReducers.reduce((previousState, caseReducer) => {\n if (caseReducer) {\n if (isDraft2(previousState)) {\n const draft = previousState;\n const result = caseReducer(draft, action);\n if (result === void 0) {\n return previousState;\n }\n return result;\n } else if (!isDraftable2(previousState)) {\n const result = caseReducer(previousState, action);\n if (result === void 0) {\n if (previousState === null) {\n return previousState;\n }\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(9) : \"A case reducer on a non-draftable value must not return undefined\");\n }\n return result;\n } else {\n return createNextState2(previousState, (draft) => {\n return caseReducer(draft, action);\n });\n }\n }\n return previousState;\n }, state);\n }\n reducer.getInitialState = getInitialState;\n return reducer;\n}\n\n// src/nanoid.ts\nvar urlAlphabet = \"ModuleSymbhasOwnPr-0123456789ABCDEFGHNRVfgctiUvz_KqYTJkLxpZXIjQW\";\nvar nanoid = (size = 21) => {\n let id = \"\";\n let i = size;\n while (i--) {\n id += urlAlphabet[Math.random() * 64 | 0];\n }\n return id;\n};\n\n// src/matchers.ts\nvar matches = (matcher, action) => {\n if (hasMatchFunction(matcher)) {\n return matcher.match(action);\n } else {\n return matcher(action);\n }\n};\nfunction isAnyOf(...matchers) {\n return (action) => {\n return matchers.some((matcher) => matches(matcher, action));\n };\n}\nfunction isAllOf(...matchers) {\n return (action) => {\n return matchers.every((matcher) => matches(matcher, action));\n };\n}\nfunction hasExpectedRequestMetadata(action, validStatus) {\n if (!action || !action.meta)\n return false;\n const hasValidRequestId = typeof action.meta.requestId === \"string\";\n const hasValidRequestStatus = validStatus.indexOf(action.meta.requestStatus) > -1;\n return hasValidRequestId && hasValidRequestStatus;\n}\nfunction isAsyncThunkArray(a) {\n return typeof a[0] === \"function\" && \"pending\" in a[0] && \"fulfilled\" in a[0] && \"rejected\" in a[0];\n}\nfunction isPending(...asyncThunks) {\n if (asyncThunks.length === 0) {\n return (action) => hasExpectedRequestMetadata(action, [\"pending\"]);\n }\n if (!isAsyncThunkArray(asyncThunks)) {\n return isPending()(asyncThunks[0]);\n }\n return (action) => {\n const matchers = asyncThunks.map((asyncThunk) => asyncThunk.pending);\n const combinedMatcher = isAnyOf(...matchers);\n return combinedMatcher(action);\n };\n}\nfunction isRejected(...asyncThunks) {\n if (asyncThunks.length === 0) {\n return (action) => hasExpectedRequestMetadata(action, [\"rejected\"]);\n }\n if (!isAsyncThunkArray(asyncThunks)) {\n return isRejected()(asyncThunks[0]);\n }\n return (action) => {\n const matchers = asyncThunks.map((asyncThunk) => asyncThunk.rejected);\n const combinedMatcher = isAnyOf(...matchers);\n return combinedMatcher(action);\n };\n}\nfunction isRejectedWithValue(...asyncThunks) {\n const hasFlag = (action) => {\n return action && action.meta && action.meta.rejectedWithValue;\n };\n if (asyncThunks.length === 0) {\n return (action) => {\n const combinedMatcher = isAllOf(isRejected(...asyncThunks), hasFlag);\n return combinedMatcher(action);\n };\n }\n if (!isAsyncThunkArray(asyncThunks)) {\n return isRejectedWithValue()(asyncThunks[0]);\n }\n return (action) => {\n const combinedMatcher = isAllOf(isRejected(...asyncThunks), hasFlag);\n return combinedMatcher(action);\n };\n}\nfunction isFulfilled(...asyncThunks) {\n if (asyncThunks.length === 0) {\n return (action) => hasExpectedRequestMetadata(action, [\"fulfilled\"]);\n }\n if (!isAsyncThunkArray(asyncThunks)) {\n return isFulfilled()(asyncThunks[0]);\n }\n return (action) => {\n const matchers = asyncThunks.map((asyncThunk) => asyncThunk.fulfilled);\n const combinedMatcher = isAnyOf(...matchers);\n return combinedMatcher(action);\n };\n}\nfunction isAsyncThunkAction(...asyncThunks) {\n if (asyncThunks.length === 0) {\n return (action) => hasExpectedRequestMetadata(action, [\"pending\", \"fulfilled\", \"rejected\"]);\n }\n if (!isAsyncThunkArray(asyncThunks)) {\n return isAsyncThunkAction()(asyncThunks[0]);\n }\n return (action) => {\n const matchers = [];\n for (const asyncThunk of asyncThunks) {\n matchers.push(asyncThunk.pending, asyncThunk.rejected, asyncThunk.fulfilled);\n }\n const combinedMatcher = isAnyOf(...matchers);\n return combinedMatcher(action);\n };\n}\n\n// src/createAsyncThunk.ts\nvar commonProperties = [\"name\", \"message\", \"stack\", \"code\"];\nvar RejectWithValue = class {\n constructor(payload, meta) {\n this.payload = payload;\n this.meta = meta;\n }\n /*\n type-only property to distinguish between RejectWithValue and FulfillWithMeta\n does not exist at runtime\n */\n _type;\n};\nvar FulfillWithMeta = class {\n constructor(payload, meta) {\n this.payload = payload;\n this.meta = meta;\n }\n /*\n type-only property to distinguish between RejectWithValue and FulfillWithMeta\n does not exist at runtime\n */\n _type;\n};\nvar miniSerializeError = (value) => {\n if (typeof value === \"object\" && value !== null) {\n const simpleError = {};\n for (const property of commonProperties) {\n if (typeof value[property] === \"string\") {\n simpleError[property] = value[property];\n }\n }\n return simpleError;\n }\n return {\n message: String(value)\n };\n};\nvar createAsyncThunk = /* @__PURE__ */ (() => {\n function createAsyncThunk2(typePrefix, payloadCreator, options) {\n const fulfilled = createAction(typePrefix + \"/fulfilled\", (payload, requestId, arg, meta) => ({\n payload,\n meta: {\n ...meta || {},\n arg,\n requestId,\n requestStatus: \"fulfilled\"\n }\n }));\n const pending = createAction(typePrefix + \"/pending\", (requestId, arg, meta) => ({\n payload: void 0,\n meta: {\n ...meta || {},\n arg,\n requestId,\n requestStatus: \"pending\"\n }\n }));\n const rejected = createAction(typePrefix + \"/rejected\", (error, requestId, arg, payload, meta) => ({\n payload,\n error: (options && options.serializeError || miniSerializeError)(error || \"Rejected\"),\n meta: {\n ...meta || {},\n arg,\n requestId,\n rejectedWithValue: !!payload,\n requestStatus: \"rejected\",\n aborted: error?.name === \"AbortError\",\n condition: error?.name === \"ConditionError\"\n }\n }));\n function actionCreator(arg) {\n return (dispatch, getState, extra) => {\n const requestId = options?.idGenerator ? options.idGenerator(arg) : nanoid();\n const abortController = new AbortController();\n let abortHandler;\n let abortReason;\n function abort(reason) {\n abortReason = reason;\n abortController.abort();\n }\n const promise = async function() {\n let finalAction;\n try {\n let conditionResult = options?.condition?.(arg, {\n getState,\n extra\n });\n if (isThenable(conditionResult)) {\n conditionResult = await conditionResult;\n }\n if (conditionResult === false || abortController.signal.aborted) {\n throw {\n name: \"ConditionError\",\n message: \"Aborted due to condition callback returning false.\"\n };\n }\n const abortedPromise = new Promise((_, reject) => {\n abortHandler = () => {\n reject({\n name: \"AbortError\",\n message: abortReason || \"Aborted\"\n });\n };\n abortController.signal.addEventListener(\"abort\", abortHandler);\n });\n dispatch(pending(requestId, arg, options?.getPendingMeta?.({\n requestId,\n arg\n }, {\n getState,\n extra\n })));\n finalAction = await Promise.race([abortedPromise, Promise.resolve(payloadCreator(arg, {\n dispatch,\n getState,\n extra,\n requestId,\n signal: abortController.signal,\n abort,\n rejectWithValue: (value, meta) => {\n return new RejectWithValue(value, meta);\n },\n fulfillWithValue: (value, meta) => {\n return new FulfillWithMeta(value, meta);\n }\n })).then((result) => {\n if (result instanceof RejectWithValue) {\n throw result;\n }\n if (result instanceof FulfillWithMeta) {\n return fulfilled(result.payload, requestId, arg, result.meta);\n }\n return fulfilled(result, requestId, arg);\n })]);\n } catch (err) {\n finalAction = err instanceof RejectWithValue ? rejected(null, requestId, arg, err.payload, err.meta) : rejected(err, requestId, arg);\n } finally {\n if (abortHandler) {\n abortController.signal.removeEventListener(\"abort\", abortHandler);\n }\n }\n const skipDispatch = options && !options.dispatchConditionRejection && rejected.match(finalAction) && finalAction.meta.condition;\n if (!skipDispatch) {\n dispatch(finalAction);\n }\n return finalAction;\n }();\n return Object.assign(promise, {\n abort,\n requestId,\n arg,\n unwrap() {\n return promise.then(unwrapResult);\n }\n });\n };\n }\n return Object.assign(actionCreator, {\n pending,\n rejected,\n fulfilled,\n settled: isAnyOf(rejected, fulfilled),\n typePrefix\n });\n }\n createAsyncThunk2.withTypes = () => createAsyncThunk2;\n return createAsyncThunk2;\n})();\nfunction unwrapResult(action) {\n if (action.meta && action.meta.rejectedWithValue) {\n throw action.payload;\n }\n if (action.error) {\n throw action.error;\n }\n return action.payload;\n}\nfunction isThenable(value) {\n return value !== null && typeof value === \"object\" && typeof value.then === \"function\";\n}\n\n// src/createSlice.ts\nvar asyncThunkSymbol = Symbol.for(\"rtk-slice-createasyncthunk\");\nvar asyncThunkCreator = {\n [asyncThunkSymbol]: createAsyncThunk\n};\nvar ReducerType = /* @__PURE__ */ ((ReducerType2) => {\n ReducerType2[\"reducer\"] = \"reducer\";\n ReducerType2[\"reducerWithPrepare\"] = \"reducerWithPrepare\";\n ReducerType2[\"asyncThunk\"] = \"asyncThunk\";\n return ReducerType2;\n})(ReducerType || {});\nfunction getType(slice, actionKey) {\n return `${slice}/${actionKey}`;\n}\nfunction buildCreateSlice({\n creators\n} = {}) {\n const cAT = creators?.asyncThunk?.[asyncThunkSymbol];\n return function createSlice2(options) {\n const {\n name,\n reducerPath = name\n } = options;\n if (!name) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(11) : \"`name` is a required option for createSlice\");\n }\n if (typeof process !== \"undefined\" && process.env.NODE_ENV === \"development\") {\n if (options.initialState === void 0) {\n console.error(\"You must provide an `initialState` value that is not `undefined`. You may have misspelled `initialState`\");\n }\n }\n const reducers = (typeof options.reducers === \"function\" ? options.reducers(buildReducerCreators()) : options.reducers) || {};\n const reducerNames = Object.keys(reducers);\n const context = {\n sliceCaseReducersByName: {},\n sliceCaseReducersByType: {},\n actionCreators: {},\n sliceMatchers: []\n };\n const contextMethods = {\n addCase(typeOrActionCreator, reducer2) {\n const type = typeof typeOrActionCreator === \"string\" ? typeOrActionCreator : typeOrActionCreator.type;\n if (!type) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(12) : \"`context.addCase` cannot be called with an empty action type\");\n }\n if (type in context.sliceCaseReducersByType) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(13) : \"`context.addCase` cannot be called with two reducers for the same action type: \" + type);\n }\n context.sliceCaseReducersByType[type] = reducer2;\n return contextMethods;\n },\n addMatcher(matcher, reducer2) {\n context.sliceMatchers.push({\n matcher,\n reducer: reducer2\n });\n return contextMethods;\n },\n exposeAction(name2, actionCreator) {\n context.actionCreators[name2] = actionCreator;\n return contextMethods;\n },\n exposeCaseReducer(name2, reducer2) {\n context.sliceCaseReducersByName[name2] = reducer2;\n return contextMethods;\n }\n };\n reducerNames.forEach((reducerName) => {\n const reducerDefinition = reducers[reducerName];\n const reducerDetails = {\n reducerName,\n type: getType(name, reducerName),\n createNotation: typeof options.reducers === \"function\"\n };\n if (isAsyncThunkSliceReducerDefinition(reducerDefinition)) {\n handleThunkCaseReducerDefinition(reducerDetails, reducerDefinition, contextMethods, cAT);\n } else {\n handleNormalReducerDefinition(reducerDetails, reducerDefinition, contextMethods);\n }\n });\n function buildReducer() {\n if (process.env.NODE_ENV !== \"production\") {\n if (typeof options.extraReducers === \"object\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(14) : \"The object notation for `createSlice.extraReducers` has been removed. Please use the 'builder callback' notation instead: https://redux-toolkit.js.org/api/createSlice\");\n }\n }\n const [extraReducers = {}, actionMatchers = [], defaultCaseReducer = void 0] = typeof options.extraReducers === \"function\" ? executeReducerBuilderCallback(options.extraReducers) : [options.extraReducers];\n const finalCaseReducers = {\n ...extraReducers,\n ...context.sliceCaseReducersByType\n };\n return createReducer(options.initialState, (builder) => {\n for (let key in finalCaseReducers) {\n builder.addCase(key, finalCaseReducers[key]);\n }\n for (let sM of context.sliceMatchers) {\n builder.addMatcher(sM.matcher, sM.reducer);\n }\n for (let m of actionMatchers) {\n builder.addMatcher(m.matcher, m.reducer);\n }\n if (defaultCaseReducer) {\n builder.addDefaultCase(defaultCaseReducer);\n }\n });\n }\n const selectSelf = (state) => state;\n const injectedSelectorCache = /* @__PURE__ */ new Map();\n let _reducer;\n function reducer(state, action) {\n if (!_reducer)\n _reducer = buildReducer();\n return _reducer(state, action);\n }\n function getInitialState() {\n if (!_reducer)\n _reducer = buildReducer();\n return _reducer.getInitialState();\n }\n function makeSelectorProps(reducerPath2, injected = false) {\n function selectSlice(state) {\n let sliceState = state[reducerPath2];\n if (typeof sliceState === \"undefined\") {\n if (injected) {\n sliceState = getInitialState();\n } else if (process.env.NODE_ENV !== \"production\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(15) : \"selectSlice returned undefined for an uninjected slice reducer\");\n }\n }\n return sliceState;\n }\n function getSelectors(selectState = selectSelf) {\n const selectorCache = emplace(injectedSelectorCache, injected, {\n insert: () => /* @__PURE__ */ new WeakMap()\n });\n return emplace(selectorCache, selectState, {\n insert: () => {\n const map = {};\n for (const [name2, selector] of Object.entries(options.selectors ?? {})) {\n map[name2] = wrapSelector(selector, selectState, getInitialState, injected);\n }\n return map;\n }\n });\n }\n return {\n reducerPath: reducerPath2,\n getSelectors,\n get selectors() {\n return getSelectors(selectSlice);\n },\n selectSlice\n };\n }\n const slice = {\n name,\n reducer,\n actions: context.actionCreators,\n caseReducers: context.sliceCaseReducersByName,\n getInitialState,\n ...makeSelectorProps(reducerPath),\n injectInto(injectable, {\n reducerPath: pathOpt,\n ...config\n } = {}) {\n const newReducerPath = pathOpt ?? reducerPath;\n injectable.inject({\n reducerPath: newReducerPath,\n reducer\n }, config);\n return {\n ...slice,\n ...makeSelectorProps(newReducerPath, true)\n };\n }\n };\n return slice;\n };\n}\nfunction wrapSelector(selector, selectState, getInitialState, injected) {\n function wrapper(rootState, ...args) {\n let sliceState = selectState(rootState);\n if (typeof sliceState === \"undefined\") {\n if (injected) {\n sliceState = getInitialState();\n } else if (process.env.NODE_ENV !== \"production\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(16) : \"selectState returned undefined for an uninjected slice reducer\");\n }\n }\n return selector(sliceState, ...args);\n }\n wrapper.unwrapped = selector;\n return wrapper;\n}\nvar createSlice = buildCreateSlice();\nfunction buildReducerCreators() {\n function asyncThunk(payloadCreator, config) {\n return {\n _reducerDefinitionType: \"asyncThunk\" /* asyncThunk */,\n payloadCreator,\n ...config\n };\n }\n asyncThunk.withTypes = () => asyncThunk;\n return {\n reducer(caseReducer) {\n return Object.assign({\n // hack so the wrapping function has the same name as the original\n // we need to create a wrapper so the `reducerDefinitionType` is not assigned to the original\n [caseReducer.name](...args) {\n return caseReducer(...args);\n }\n }[caseReducer.name], {\n _reducerDefinitionType: \"reducer\" /* reducer */\n });\n },\n preparedReducer(prepare, reducer) {\n return {\n _reducerDefinitionType: \"reducerWithPrepare\" /* reducerWithPrepare */,\n prepare,\n reducer\n };\n },\n asyncThunk\n };\n}\nfunction handleNormalReducerDefinition({\n type,\n reducerName,\n createNotation\n}, maybeReducerWithPrepare, context) {\n let caseReducer;\n let prepareCallback;\n if (\"reducer\" in maybeReducerWithPrepare) {\n if (createNotation && !isCaseReducerWithPrepareDefinition(maybeReducerWithPrepare)) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(17) : \"Please use the `create.preparedReducer` notation for prepared action creators with the `create` notation.\");\n }\n caseReducer = maybeReducerWithPrepare.reducer;\n prepareCallback = maybeReducerWithPrepare.prepare;\n } else {\n caseReducer = maybeReducerWithPrepare;\n }\n context.addCase(type, caseReducer).exposeCaseReducer(reducerName, caseReducer).exposeAction(reducerName, prepareCallback ? createAction(type, prepareCallback) : createAction(type));\n}\nfunction isAsyncThunkSliceReducerDefinition(reducerDefinition) {\n return reducerDefinition._reducerDefinitionType === \"asyncThunk\" /* asyncThunk */;\n}\nfunction isCaseReducerWithPrepareDefinition(reducerDefinition) {\n return reducerDefinition._reducerDefinitionType === \"reducerWithPrepare\" /* reducerWithPrepare */;\n}\nfunction handleThunkCaseReducerDefinition({\n type,\n reducerName\n}, reducerDefinition, context, cAT) {\n if (!cAT) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(18) : \"Cannot use `create.asyncThunk` in the built-in `createSlice`. Use `buildCreateSlice({ creators: { asyncThunk: asyncThunkCreator } })` to create a customised version of `createSlice`.\");\n }\n const {\n payloadCreator,\n fulfilled,\n pending,\n rejected,\n settled,\n options\n } = reducerDefinition;\n const thunk = cAT(type, payloadCreator, options);\n context.exposeAction(reducerName, thunk);\n if (fulfilled) {\n context.addCase(thunk.fulfilled, fulfilled);\n }\n if (pending) {\n context.addCase(thunk.pending, pending);\n }\n if (rejected) {\n context.addCase(thunk.rejected, rejected);\n }\n if (settled) {\n context.addMatcher(thunk.settled, settled);\n }\n context.exposeCaseReducer(reducerName, {\n fulfilled: fulfilled || noop,\n pending: pending || noop,\n rejected: rejected || noop,\n settled: settled || noop\n });\n}\nfunction noop() {\n}\n\n// src/entities/entity_state.ts\nfunction getInitialEntityState() {\n return {\n ids: [],\n entities: {}\n };\n}\nfunction createInitialStateFactory() {\n function getInitialState(additionalState = {}) {\n return Object.assign(getInitialEntityState(), additionalState);\n }\n return {\n getInitialState\n };\n}\n\n// src/entities/state_selectors.ts\nfunction createSelectorsFactory() {\n function getSelectors(selectState, options = {}) {\n const {\n createSelector: createSelector2 = createDraftSafeSelector\n } = options;\n const selectIds = (state) => state.ids;\n const selectEntities = (state) => state.entities;\n const selectAll = createSelector2(selectIds, selectEntities, (ids, entities) => ids.map((id) => entities[id]));\n const selectId = (_, id) => id;\n const selectById = (entities, id) => entities[id];\n const selectTotal = createSelector2(selectIds, (ids) => ids.length);\n if (!selectState) {\n return {\n selectIds,\n selectEntities,\n selectAll,\n selectTotal,\n selectById: createSelector2(selectEntities, selectId, selectById)\n };\n }\n const selectGlobalizedEntities = createSelector2(selectState, selectEntities);\n return {\n selectIds: createSelector2(selectState, selectIds),\n selectEntities: selectGlobalizedEntities,\n selectAll: createSelector2(selectState, selectAll),\n selectTotal: createSelector2(selectState, selectTotal),\n selectById: createSelector2(selectGlobalizedEntities, selectId, selectById)\n };\n }\n return {\n getSelectors\n };\n}\n\n// src/entities/state_adapter.ts\nimport { produce as createNextState3, isDraft as isDraft3 } from \"immer\";\nvar isDraftTyped = isDraft3;\nfunction createSingleArgumentStateOperator(mutator) {\n const operator = createStateOperator((_, state) => mutator(state));\n return function operation(state) {\n return operator(state, void 0);\n };\n}\nfunction createStateOperator(mutator) {\n return function operation(state, arg) {\n function isPayloadActionArgument(arg2) {\n return isFSA(arg2);\n }\n const runMutator = (draft) => {\n if (isPayloadActionArgument(arg)) {\n mutator(arg.payload, draft);\n } else {\n mutator(arg, draft);\n }\n };\n if (isDraftTyped(state)) {\n runMutator(state);\n return state;\n }\n return createNextState3(state, runMutator);\n };\n}\n\n// src/entities/utils.ts\nfunction selectIdValue(entity, selectId) {\n const key = selectId(entity);\n if (process.env.NODE_ENV !== \"production\" && key === void 0) {\n console.warn(\"The entity passed to the `selectId` implementation returned undefined.\", \"You should probably provide your own `selectId` implementation.\", \"The entity that was passed:\", entity, \"The `selectId` implementation:\", selectId.toString());\n }\n return key;\n}\nfunction ensureEntitiesArray(entities) {\n if (!Array.isArray(entities)) {\n entities = Object.values(entities);\n }\n return entities;\n}\nfunction splitAddedUpdatedEntities(newEntities, selectId, state) {\n newEntities = ensureEntitiesArray(newEntities);\n const added = [];\n const updated = [];\n for (const entity of newEntities) {\n const id = selectIdValue(entity, selectId);\n if (id in state.entities) {\n updated.push({\n id,\n changes: entity\n });\n } else {\n added.push(entity);\n }\n }\n return [added, updated];\n}\n\n// src/entities/unsorted_state_adapter.ts\nfunction createUnsortedStateAdapter(selectId) {\n function addOneMutably(entity, state) {\n const key = selectIdValue(entity, selectId);\n if (key in state.entities) {\n return;\n }\n state.ids.push(key);\n state.entities[key] = entity;\n }\n function addManyMutably(newEntities, state) {\n newEntities = ensureEntitiesArray(newEntities);\n for (const entity of newEntities) {\n addOneMutably(entity, state);\n }\n }\n function setOneMutably(entity, state) {\n const key = selectIdValue(entity, selectId);\n if (!(key in state.entities)) {\n state.ids.push(key);\n }\n state.entities[key] = entity;\n }\n function setManyMutably(newEntities, state) {\n newEntities = ensureEntitiesArray(newEntities);\n for (const entity of newEntities) {\n setOneMutably(entity, state);\n }\n }\n function setAllMutably(newEntities, state) {\n newEntities = ensureEntitiesArray(newEntities);\n state.ids = [];\n state.entities = {};\n addManyMutably(newEntities, state);\n }\n function removeOneMutably(key, state) {\n return removeManyMutably([key], state);\n }\n function removeManyMutably(keys, state) {\n let didMutate = false;\n keys.forEach((key) => {\n if (key in state.entities) {\n delete state.entities[key];\n didMutate = true;\n }\n });\n if (didMutate) {\n state.ids = state.ids.filter((id) => id in state.entities);\n }\n }\n function removeAllMutably(state) {\n Object.assign(state, {\n ids: [],\n entities: {}\n });\n }\n function takeNewKey(keys, update, state) {\n const original3 = state.entities[update.id];\n if (original3 === void 0) {\n return false;\n }\n const updated = Object.assign({}, original3, update.changes);\n const newKey = selectIdValue(updated, selectId);\n const hasNewKey = newKey !== update.id;\n if (hasNewKey) {\n keys[update.id] = newKey;\n delete state.entities[update.id];\n }\n state.entities[newKey] = updated;\n return hasNewKey;\n }\n function updateOneMutably(update, state) {\n return updateManyMutably([update], state);\n }\n function updateManyMutably(updates, state) {\n const newKeys = {};\n const updatesPerEntity = {};\n updates.forEach((update) => {\n if (update.id in state.entities) {\n updatesPerEntity[update.id] = {\n id: update.id,\n // Spreads ignore falsy values, so this works even if there isn't\n // an existing update already at this key\n changes: {\n ...updatesPerEntity[update.id] ? updatesPerEntity[update.id].changes : null,\n ...update.changes\n }\n };\n }\n });\n updates = Object.values(updatesPerEntity);\n const didMutateEntities = updates.length > 0;\n if (didMutateEntities) {\n const didMutateIds = updates.filter((update) => takeNewKey(newKeys, update, state)).length > 0;\n if (didMutateIds) {\n state.ids = Object.values(state.entities).map((e) => selectIdValue(e, selectId));\n }\n }\n }\n function upsertOneMutably(entity, state) {\n return upsertManyMutably([entity], state);\n }\n function upsertManyMutably(newEntities, state) {\n const [added, updated] = splitAddedUpdatedEntities(newEntities, selectId, state);\n updateManyMutably(updated, state);\n addManyMutably(added, state);\n }\n return {\n removeAll: createSingleArgumentStateOperator(removeAllMutably),\n addOne: createStateOperator(addOneMutably),\n addMany: createStateOperator(addManyMutably),\n setOne: createStateOperator(setOneMutably),\n setMany: createStateOperator(setManyMutably),\n setAll: createStateOperator(setAllMutably),\n updateOne: createStateOperator(updateOneMutably),\n updateMany: createStateOperator(updateManyMutably),\n upsertOne: createStateOperator(upsertOneMutably),\n upsertMany: createStateOperator(upsertManyMutably),\n removeOne: createStateOperator(removeOneMutably),\n removeMany: createStateOperator(removeManyMutably)\n };\n}\n\n// src/entities/sorted_state_adapter.ts\nfunction createSortedStateAdapter(selectId, sort) {\n const {\n removeOne,\n removeMany,\n removeAll\n } = createUnsortedStateAdapter(selectId);\n function addOneMutably(entity, state) {\n return addManyMutably([entity], state);\n }\n function addManyMutably(newEntities, state) {\n newEntities = ensureEntitiesArray(newEntities);\n const models = newEntities.filter((model) => !(selectIdValue(model, selectId) in state.entities));\n if (models.length !== 0) {\n merge(models, state);\n }\n }\n function setOneMutably(entity, state) {\n return setManyMutably([entity], state);\n }\n function setManyMutably(newEntities, state) {\n newEntities = ensureEntitiesArray(newEntities);\n if (newEntities.length !== 0) {\n merge(newEntities, state);\n }\n }\n function setAllMutably(newEntities, state) {\n newEntities = ensureEntitiesArray(newEntities);\n state.entities = {};\n state.ids = [];\n addManyMutably(newEntities, state);\n }\n function updateOneMutably(update, state) {\n return updateManyMutably([update], state);\n }\n function updateManyMutably(updates, state) {\n let appliedUpdates = false;\n for (let update of updates) {\n const entity = state.entities[update.id];\n if (!entity) {\n continue;\n }\n appliedUpdates = true;\n Object.assign(entity, update.changes);\n const newId = selectId(entity);\n if (update.id !== newId) {\n delete state.entities[update.id];\n state.entities[newId] = entity;\n }\n }\n if (appliedUpdates) {\n resortEntities(state);\n }\n }\n function upsertOneMutably(entity, state) {\n return upsertManyMutably([entity], state);\n }\n function upsertManyMutably(newEntities, state) {\n const [added, updated] = splitAddedUpdatedEntities(newEntities, selectId, state);\n updateManyMutably(updated, state);\n addManyMutably(added, state);\n }\n function areArraysEqual(a, b) {\n if (a.length !== b.length) {\n return false;\n }\n for (let i = 0; i < a.length && i < b.length; i++) {\n if (a[i] === b[i]) {\n continue;\n }\n return false;\n }\n return true;\n }\n function merge(models, state) {\n models.forEach((model) => {\n state.entities[selectId(model)] = model;\n });\n resortEntities(state);\n }\n function resortEntities(state) {\n const allEntities = Object.values(state.entities);\n allEntities.sort(sort);\n const newSortedIds = allEntities.map(selectId);\n const {\n ids\n } = state;\n if (!areArraysEqual(ids, newSortedIds)) {\n state.ids = newSortedIds;\n }\n }\n return {\n removeOne,\n removeMany,\n removeAll,\n addOne: createStateOperator(addOneMutably),\n updateOne: createStateOperator(updateOneMutably),\n upsertOne: createStateOperator(upsertOneMutably),\n setOne: createStateOperator(setOneMutably),\n setMany: createStateOperator(setManyMutably),\n setAll: createStateOperator(setAllMutably),\n addMany: createStateOperator(addManyMutably),\n updateMany: createStateOperator(updateManyMutably),\n upsertMany: createStateOperator(upsertManyMutably)\n };\n}\n\n// src/entities/create_adapter.ts\nfunction createEntityAdapter(options = {}) {\n const {\n selectId,\n sortComparer\n } = {\n sortComparer: false,\n selectId: (instance) => instance.id,\n ...options\n };\n const stateFactory = createInitialStateFactory();\n const selectorsFactory = createSelectorsFactory();\n const stateAdapter = sortComparer ? createSortedStateAdapter(selectId, sortComparer) : createUnsortedStateAdapter(selectId);\n return {\n selectId,\n sortComparer,\n ...stateFactory,\n ...selectorsFactory,\n ...stateAdapter\n };\n}\n\n// src/listenerMiddleware/index.ts\nimport { isAction as isAction3 } from \"redux\";\n\n// src/listenerMiddleware/exceptions.ts\nvar task = \"task\";\nvar listener = \"listener\";\nvar completed = \"completed\";\nvar cancelled = \"cancelled\";\nvar taskCancelled = `task-${cancelled}`;\nvar taskCompleted = `task-${completed}`;\nvar listenerCancelled = `${listener}-${cancelled}`;\nvar listenerCompleted = `${listener}-${completed}`;\nvar TaskAbortError = class {\n constructor(code) {\n this.code = code;\n this.message = `${task} ${cancelled} (reason: ${code})`;\n }\n name = \"TaskAbortError\";\n message;\n};\n\n// src/listenerMiddleware/utils.ts\nvar assertFunction = (func, expected) => {\n if (typeof func !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(32) : `${expected} is not a function`);\n }\n};\nvar noop2 = () => {\n};\nvar catchRejection = (promise, onError = noop2) => {\n promise.catch(onError);\n return promise;\n};\nvar addAbortSignalListener = (abortSignal, callback) => {\n abortSignal.addEventListener(\"abort\", callback, {\n once: true\n });\n return () => abortSignal.removeEventListener(\"abort\", callback);\n};\nvar abortControllerWithReason = (abortController, reason) => {\n const signal = abortController.signal;\n if (signal.aborted) {\n return;\n }\n if (!(\"reason\" in signal)) {\n Object.defineProperty(signal, \"reason\", {\n enumerable: true,\n value: reason,\n configurable: true,\n writable: true\n });\n }\n ;\n abortController.abort(reason);\n};\n\n// src/listenerMiddleware/task.ts\nvar validateActive = (signal) => {\n if (signal.aborted) {\n const {\n reason\n } = signal;\n throw new TaskAbortError(reason);\n }\n};\nfunction raceWithSignal(signal, promise) {\n let cleanup = noop2;\n return new Promise((resolve, reject) => {\n const notifyRejection = () => reject(new TaskAbortError(signal.reason));\n if (signal.aborted) {\n notifyRejection();\n return;\n }\n cleanup = addAbortSignalListener(signal, notifyRejection);\n promise.finally(() => cleanup()).then(resolve, reject);\n }).finally(() => {\n cleanup = noop2;\n });\n}\nvar runTask = async (task2, cleanUp) => {\n try {\n await Promise.resolve();\n const value = await task2();\n return {\n status: \"ok\",\n value\n };\n } catch (error) {\n return {\n status: error instanceof TaskAbortError ? \"cancelled\" : \"rejected\",\n error\n };\n } finally {\n cleanUp?.();\n }\n};\nvar createPause = (signal) => {\n return (promise) => {\n return catchRejection(raceWithSignal(signal, promise).then((output) => {\n validateActive(signal);\n return output;\n }));\n };\n};\nvar createDelay = (signal) => {\n const pause = createPause(signal);\n return (timeoutMs) => {\n return pause(new Promise((resolve) => setTimeout(resolve, timeoutMs)));\n };\n};\n\n// src/listenerMiddleware/index.ts\nvar {\n assign\n} = Object;\nvar INTERNAL_NIL_TOKEN = {};\nvar alm = \"listenerMiddleware\";\nvar createFork = (parentAbortSignal, parentBlockingPromises) => {\n const linkControllers = (controller) => addAbortSignalListener(parentAbortSignal, () => abortControllerWithReason(controller, parentAbortSignal.reason));\n return (taskExecutor, opts) => {\n assertFunction(taskExecutor, \"taskExecutor\");\n const childAbortController = new AbortController();\n linkControllers(childAbortController);\n const result = runTask(async () => {\n validateActive(parentAbortSignal);\n validateActive(childAbortController.signal);\n const result2 = await taskExecutor({\n pause: createPause(childAbortController.signal),\n delay: createDelay(childAbortController.signal),\n signal: childAbortController.signal\n });\n validateActive(childAbortController.signal);\n return result2;\n }, () => abortControllerWithReason(childAbortController, taskCompleted));\n if (opts?.autoJoin) {\n parentBlockingPromises.push(result.catch(noop2));\n }\n return {\n result: createPause(parentAbortSignal)(result),\n cancel() {\n abortControllerWithReason(childAbortController, taskCancelled);\n }\n };\n };\n};\nvar createTakePattern = (startListening, signal) => {\n const take = async (predicate, timeout) => {\n validateActive(signal);\n let unsubscribe = () => {\n };\n const tuplePromise = new Promise((resolve, reject) => {\n let stopListening = startListening({\n predicate,\n effect: (action, listenerApi) => {\n listenerApi.unsubscribe();\n resolve([action, listenerApi.getState(), listenerApi.getOriginalState()]);\n }\n });\n unsubscribe = () => {\n stopListening();\n reject();\n };\n });\n const promises = [tuplePromise];\n if (timeout != null) {\n promises.push(new Promise((resolve) => setTimeout(resolve, timeout, null)));\n }\n try {\n const output = await raceWithSignal(signal, Promise.race(promises));\n validateActive(signal);\n return output;\n } finally {\n unsubscribe();\n }\n };\n return (predicate, timeout) => catchRejection(take(predicate, timeout));\n};\nvar getListenerEntryPropsFrom = (options) => {\n let {\n type,\n actionCreator,\n matcher,\n predicate,\n effect\n } = options;\n if (type) {\n predicate = createAction(type).match;\n } else if (actionCreator) {\n type = actionCreator.type;\n predicate = actionCreator.match;\n } else if (matcher) {\n predicate = matcher;\n } else if (predicate) {\n } else {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(21) : \"Creating or removing a listener requires one of the known fields for matching an action\");\n }\n assertFunction(effect, \"options.listener\");\n return {\n predicate,\n type,\n effect\n };\n};\nvar createListenerEntry = Object.assign((options) => {\n const {\n type,\n predicate,\n effect\n } = getListenerEntryPropsFrom(options);\n const id = nanoid();\n const entry = {\n id,\n effect,\n type,\n predicate,\n pending: /* @__PURE__ */ new Set(),\n unsubscribe: () => {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(22) : \"Unsubscribe not initialized\");\n }\n };\n return entry;\n}, {\n withTypes: () => createListenerEntry\n});\nvar cancelActiveListeners = (entry) => {\n entry.pending.forEach((controller) => {\n abortControllerWithReason(controller, listenerCancelled);\n });\n};\nvar createClearListenerMiddleware = (listenerMap) => {\n return () => {\n listenerMap.forEach(cancelActiveListeners);\n listenerMap.clear();\n };\n};\nvar safelyNotifyError = (errorHandler, errorToNotify, errorInfo) => {\n try {\n errorHandler(errorToNotify, errorInfo);\n } catch (errorHandlerError) {\n setTimeout(() => {\n throw errorHandlerError;\n }, 0);\n }\n};\nvar addListener = Object.assign(createAction(`${alm}/add`), {\n withTypes: () => addListener\n});\nvar clearAllListeners = createAction(`${alm}/removeAll`);\nvar removeListener = Object.assign(createAction(`${alm}/remove`), {\n withTypes: () => removeListener\n});\nvar defaultErrorHandler = (...args) => {\n console.error(`${alm}/error`, ...args);\n};\nvar createListenerMiddleware = (middlewareOptions = {}) => {\n const listenerMap = /* @__PURE__ */ new Map();\n const {\n extra,\n onError = defaultErrorHandler\n } = middlewareOptions;\n assertFunction(onError, \"onError\");\n const insertEntry = (entry) => {\n entry.unsubscribe = () => listenerMap.delete(entry.id);\n listenerMap.set(entry.id, entry);\n return (cancelOptions) => {\n entry.unsubscribe();\n if (cancelOptions?.cancelActive) {\n cancelActiveListeners(entry);\n }\n };\n };\n const startListening = (options) => {\n let entry = find(Array.from(listenerMap.values()), (existingEntry) => existingEntry.effect === options.effect);\n if (!entry) {\n entry = createListenerEntry(options);\n }\n return insertEntry(entry);\n };\n Object.assign(startListening, {\n withTypes: () => startListening\n });\n const stopListening = (options) => {\n const {\n type,\n effect,\n predicate\n } = getListenerEntryPropsFrom(options);\n const entry = find(Array.from(listenerMap.values()), (entry2) => {\n const matchPredicateOrType = typeof type === \"string\" ? entry2.type === type : entry2.predicate === predicate;\n return matchPredicateOrType && entry2.effect === effect;\n });\n if (entry) {\n entry.unsubscribe();\n if (options.cancelActive) {\n cancelActiveListeners(entry);\n }\n }\n return !!entry;\n };\n Object.assign(stopListening, {\n withTypes: () => stopListening\n });\n const notifyListener = async (entry, action, api, getOriginalState) => {\n const internalTaskController = new AbortController();\n const take = createTakePattern(startListening, internalTaskController.signal);\n const autoJoinPromises = [];\n try {\n entry.pending.add(internalTaskController);\n await Promise.resolve(entry.effect(\n action,\n // Use assign() rather than ... to avoid extra helper functions added to bundle\n assign({}, api, {\n getOriginalState,\n condition: (predicate, timeout) => take(predicate, timeout).then(Boolean),\n take,\n delay: createDelay(internalTaskController.signal),\n pause: createPause(internalTaskController.signal),\n extra,\n signal: internalTaskController.signal,\n fork: createFork(internalTaskController.signal, autoJoinPromises),\n unsubscribe: entry.unsubscribe,\n subscribe: () => {\n listenerMap.set(entry.id, entry);\n },\n cancelActiveListeners: () => {\n entry.pending.forEach((controller, _, set) => {\n if (controller !== internalTaskController) {\n abortControllerWithReason(controller, listenerCancelled);\n set.delete(controller);\n }\n });\n },\n cancel: () => {\n abortControllerWithReason(internalTaskController, listenerCancelled);\n entry.pending.delete(internalTaskController);\n },\n throwIfCancelled: () => {\n validateActive(internalTaskController.signal);\n }\n })\n ));\n } catch (listenerError) {\n if (!(listenerError instanceof TaskAbortError)) {\n safelyNotifyError(onError, listenerError, {\n raisedBy: \"effect\"\n });\n }\n } finally {\n await Promise.all(autoJoinPromises);\n abortControllerWithReason(internalTaskController, listenerCompleted);\n entry.pending.delete(internalTaskController);\n }\n };\n const clearListenerMiddleware = createClearListenerMiddleware(listenerMap);\n const middleware = (api) => (next) => (action) => {\n if (!isAction3(action)) {\n return next(action);\n }\n if (addListener.match(action)) {\n return startListening(action.payload);\n }\n if (clearAllListeners.match(action)) {\n clearListenerMiddleware();\n return;\n }\n if (removeListener.match(action)) {\n return stopListening(action.payload);\n }\n let originalState = api.getState();\n const getOriginalState = () => {\n if (originalState === INTERNAL_NIL_TOKEN) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(23) : `${alm}: getOriginalState can only be called synchronously`);\n }\n return originalState;\n };\n let result;\n try {\n result = next(action);\n if (listenerMap.size > 0) {\n const currentState = api.getState();\n const listenerEntries = Array.from(listenerMap.values());\n for (const entry of listenerEntries) {\n let runListener = false;\n try {\n runListener = entry.predicate(action, currentState, originalState);\n } catch (predicateError) {\n runListener = false;\n safelyNotifyError(onError, predicateError, {\n raisedBy: \"predicate\"\n });\n }\n if (!runListener) {\n continue;\n }\n notifyListener(entry, action, api, getOriginalState);\n }\n }\n } finally {\n originalState = INTERNAL_NIL_TOKEN;\n }\n return result;\n };\n return {\n middleware,\n startListening,\n stopListening,\n clearListeners: clearListenerMiddleware\n };\n};\n\n// src/dynamicMiddleware/index.ts\nimport { compose as compose3 } from \"redux\";\nvar createMiddlewareEntry = (middleware) => ({\n id: nanoid(),\n middleware,\n applied: /* @__PURE__ */ new Map()\n});\nvar matchInstance = (instanceId) => (action) => action?.meta?.instanceId === instanceId;\nvar createDynamicMiddleware = () => {\n const instanceId = nanoid();\n const middlewareMap = /* @__PURE__ */ new Map();\n const withMiddleware = Object.assign(createAction(\"dynamicMiddleware/add\", (...middlewares) => ({\n payload: middlewares,\n meta: {\n instanceId\n }\n })), {\n withTypes: () => withMiddleware\n });\n const addMiddleware = Object.assign(function addMiddleware2(...middlewares) {\n middlewares.forEach((middleware2) => {\n let entry = find(Array.from(middlewareMap.values()), (entry2) => entry2.middleware === middleware2);\n if (!entry) {\n entry = createMiddlewareEntry(middleware2);\n }\n middlewareMap.set(entry.id, entry);\n });\n }, {\n withTypes: () => addMiddleware\n });\n const getFinalMiddleware = (api) => {\n const appliedMiddleware = Array.from(middlewareMap.values()).map((entry) => emplace(entry.applied, api, {\n insert: () => entry.middleware(api)\n }));\n return compose3(...appliedMiddleware);\n };\n const isWithMiddleware = isAllOf(withMiddleware, matchInstance(instanceId));\n const middleware = (api) => (next) => (action) => {\n if (isWithMiddleware(action)) {\n addMiddleware(...action.payload);\n return api.dispatch;\n }\n return getFinalMiddleware(api)(next)(action);\n };\n return {\n middleware,\n addMiddleware,\n withMiddleware,\n instanceId\n };\n};\n\n// src/combineSlices.ts\nimport { combineReducers as combineReducers2 } from \"redux\";\nvar isSliceLike = (maybeSliceLike) => \"reducerPath\" in maybeSliceLike && typeof maybeSliceLike.reducerPath === \"string\";\nvar getReducers = (slices) => slices.flatMap((sliceOrMap) => isSliceLike(sliceOrMap) ? [[sliceOrMap.reducerPath, sliceOrMap.reducer]] : Object.entries(sliceOrMap));\nvar ORIGINAL_STATE = Symbol.for(\"rtk-state-proxy-original\");\nvar isStateProxy = (value) => !!value && !!value[ORIGINAL_STATE];\nvar stateProxyMap = /* @__PURE__ */ new WeakMap();\nvar createStateProxy = (state, reducerMap) => emplace(stateProxyMap, state, {\n insert: () => new Proxy(state, {\n get: (target, prop, receiver) => {\n if (prop === ORIGINAL_STATE)\n return target;\n const result = Reflect.get(target, prop, receiver);\n if (typeof result === \"undefined\") {\n const reducer = reducerMap[prop.toString()];\n if (reducer) {\n const reducerResult = reducer(void 0, {\n type: nanoid()\n });\n if (typeof reducerResult === \"undefined\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(24) : `The slice reducer for key \"${prop.toString()}\" returned undefined when called for selector(). If the state passed to the reducer is undefined, you must explicitly return the initial state. The initial state may not be undefined. If you don't want to set a value for this reducer, you can use null instead of undefined.`);\n }\n return reducerResult;\n }\n }\n return result;\n }\n })\n});\nvar original = (state) => {\n if (!isStateProxy(state)) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(25) : \"original must be used on state Proxy\");\n }\n return state[ORIGINAL_STATE];\n};\nfunction combineSlices(...slices) {\n const reducerMap = Object.fromEntries(getReducers(slices));\n const getReducer = () => combineReducers2(reducerMap);\n let reducer = getReducer();\n function combinedReducer(state, action) {\n return reducer(state, action);\n }\n combinedReducer.withLazyLoadedSlices = () => combinedReducer;\n const inject = (slice, config = {}) => {\n const {\n reducerPath,\n reducer: reducerToInject\n } = slice;\n const currentReducer = reducerMap[reducerPath];\n if (!config.overrideExisting && currentReducer && currentReducer !== reducerToInject) {\n if (typeof process !== \"undefined\" && process.env.NODE_ENV === \"development\") {\n console.error(`called \\`inject\\` to override already-existing reducer ${reducerPath} without specifying \\`overrideExisting: true\\``);\n }\n return combinedReducer;\n }\n reducerMap[reducerPath] = reducerToInject;\n reducer = getReducer();\n return combinedReducer;\n };\n const selector = Object.assign(function makeSelector(selectorFn, selectState) {\n return function selector2(state, ...args) {\n return selectorFn(createStateProxy(selectState ? selectState(state, ...args) : state, reducerMap), ...args);\n };\n }, {\n original\n });\n return Object.assign(combinedReducer, {\n inject,\n selector\n });\n}\n\n// src/formatProdErrorMessage.ts\nfunction formatProdErrorMessage(code) {\n return `Minified Redux Toolkit error #${code}; visit https://redux-toolkit.js.org/Errors?code=${code} for the full message or use the non-minified dev environment for full errors. `;\n}\nexport {\n ReducerType,\n SHOULD_AUTOBATCH,\n TaskAbortError,\n Tuple,\n addListener,\n asyncThunkCreator,\n autoBatchEnhancer,\n buildCreateSlice,\n clearAllListeners,\n combineSlices,\n configureStore,\n createAction,\n createActionCreatorInvariantMiddleware,\n createAsyncThunk,\n createDraftSafeSelector,\n createDraftSafeSelectorCreator,\n createDynamicMiddleware,\n createEntityAdapter,\n createImmutableStateInvariantMiddleware,\n createListenerMiddleware,\n produce as createNextState,\n createReducer,\n createSelector,\n createSelectorCreator2 as createSelectorCreator,\n createSerializableStateInvariantMiddleware,\n createSlice,\n current2 as current,\n findNonSerializableValue,\n formatProdErrorMessage,\n freeze,\n isActionCreator,\n isAllOf,\n isAnyOf,\n isAsyncThunkAction,\n isDraft4 as isDraft,\n isFSA as isFluxStandardAction,\n isFulfilled,\n isImmutableDefault,\n isPending,\n isPlain,\n isRejected,\n isRejectedWithValue,\n lruMemoize,\n miniSerializeError,\n nanoid,\n original2 as original,\n prepareAutoBatched,\n removeListener,\n unwrapResult,\n weakMapMemoize2 as weakMapMemoize\n};\n//# sourceMappingURL=redux-toolkit.modern.mjs.map","// src/index.ts\nimport * as React2 from \"react\";\nimport { useSyncExternalStoreWithSelector as useSyncExternalStoreWithSelector2 } from \"use-sync-external-store/with-selector.js\";\n\n// src/utils/react.ts\nimport * as ReactOriginal from \"react\";\nvar React = (\n // prettier-ignore\n // @ts-ignore\n \"default\" in ReactOriginal ? ReactOriginal[\"default\"] : ReactOriginal\n);\n\n// src/components/Context.ts\nvar ContextKey = Symbol.for(`react-redux-context`);\nvar gT = typeof globalThis !== \"undefined\" ? globalThis : (\n /* fall back to a per-module scope (pre-8.1 behaviour) if `globalThis` is not available */\n {}\n);\nfunction getContext() {\n if (!React.createContext)\n return {};\n const contextMap = gT[ContextKey] ?? (gT[ContextKey] = /* @__PURE__ */ new Map());\n let realContext = contextMap.get(React.createContext);\n if (!realContext) {\n realContext = React.createContext(\n null\n );\n if (process.env.NODE_ENV !== \"production\") {\n realContext.displayName = \"ReactRedux\";\n }\n contextMap.set(React.createContext, realContext);\n }\n return realContext;\n}\nvar ReactReduxContext = /* @__PURE__ */ getContext();\n\n// src/utils/useSyncExternalStore.ts\nvar notInitialized = () => {\n throw new Error(\"uSES not initialized!\");\n};\n\n// src/hooks/useReduxContext.ts\nfunction createReduxContextHook(context = ReactReduxContext) {\n return function useReduxContext2() {\n const contextValue = React.useContext(context);\n if (process.env.NODE_ENV !== \"production\" && !contextValue) {\n throw new Error(\n \"could not find react-redux context value; please ensure the component is wrapped in a <Provider>\"\n );\n }\n return contextValue;\n };\n}\nvar useReduxContext = /* @__PURE__ */ createReduxContextHook();\n\n// src/hooks/useSelector.ts\nvar useSyncExternalStoreWithSelector = notInitialized;\nvar initializeUseSelector = (fn) => {\n useSyncExternalStoreWithSelector = fn;\n};\nvar refEquality = (a, b) => a === b;\nfunction createSelectorHook(context = ReactReduxContext) {\n const useReduxContext2 = context === ReactReduxContext ? useReduxContext : createReduxContextHook(context);\n const useSelector2 = (selector, equalityFnOrOptions = {}) => {\n const { equalityFn = refEquality, devModeChecks = {} } = typeof equalityFnOrOptions === \"function\" ? { equalityFn: equalityFnOrOptions } : equalityFnOrOptions;\n if (process.env.NODE_ENV !== \"production\") {\n if (!selector) {\n throw new Error(`You must pass a selector to useSelector`);\n }\n if (typeof selector !== \"function\") {\n throw new Error(`You must pass a function as a selector to useSelector`);\n }\n if (typeof equalityFn !== \"function\") {\n throw new Error(\n `You must pass a function as an equality function to useSelector`\n );\n }\n }\n const {\n store,\n subscription,\n getServerState,\n stabilityCheck,\n identityFunctionCheck\n } = useReduxContext2();\n const firstRun = React.useRef(true);\n const wrappedSelector = React.useCallback(\n {\n [selector.name](state) {\n const selected = selector(state);\n if (process.env.NODE_ENV !== \"production\") {\n const {\n identityFunctionCheck: finalIdentityFunctionCheck,\n stabilityCheck: finalStabilityCheck\n } = {\n stabilityCheck,\n identityFunctionCheck,\n ...devModeChecks\n };\n if (finalStabilityCheck === \"always\" || finalStabilityCheck === \"once\" && firstRun.current) {\n const toCompare = selector(state);\n if (!equalityFn(selected, toCompare)) {\n let stack = void 0;\n try {\n throw new Error();\n } catch (e) {\n ;\n ({ stack } = e);\n }\n console.warn(\n \"Selector \" + (selector.name || \"unknown\") + \" returned a different result when called with the same parameters. This can lead to unnecessary rerenders.\\nSelectors that return a new reference (such as an object or an array) should be memoized: https://redux.js.org/usage/deriving-data-selectors#optimizing-selectors-with-memoization\",\n {\n state,\n selected,\n selected2: toCompare,\n stack\n }\n );\n }\n }\n if (finalIdentityFunctionCheck === \"always\" || finalIdentityFunctionCheck === \"once\" && firstRun.current) {\n if (selected === state) {\n let stack = void 0;\n try {\n throw new Error();\n } catch (e) {\n ;\n ({ stack } = e);\n }\n console.warn(\n \"Selector \" + (selector.name || \"unknown\") + \" returned the root state when called. This can lead to unnecessary rerenders.\\nSelectors that return the entire state are almost certainly a mistake, as they will cause a rerender whenever *anything* in state changes.\",\n { stack }\n );\n }\n }\n if (firstRun.current)\n firstRun.current = false;\n }\n return selected;\n }\n }[selector.name],\n [selector, stabilityCheck, devModeChecks.stabilityCheck]\n );\n const selectedState = useSyncExternalStoreWithSelector(\n subscription.addNestedSub,\n store.getState,\n getServerState || store.getState,\n wrappedSelector,\n equalityFn\n );\n React.useDebugValue(selectedState);\n return selectedState;\n };\n Object.assign(useSelector2, {\n withTypes: () => useSelector2\n });\n return useSelector2;\n}\nvar useSelector = /* @__PURE__ */ createSelectorHook();\n\n// src/utils/react-is.ts\nvar REACT_ELEMENT_TYPE = Symbol.for(\"react.element\");\nvar REACT_PORTAL_TYPE = Symbol.for(\"react.portal\");\nvar REACT_FRAGMENT_TYPE = Symbol.for(\"react.fragment\");\nvar REACT_STRICT_MODE_TYPE = Symbol.for(\"react.strict_mode\");\nvar REACT_PROFILER_TYPE = Symbol.for(\"react.profiler\");\nvar REACT_PROVIDER_TYPE = Symbol.for(\"react.provider\");\nvar REACT_CONTEXT_TYPE = Symbol.for(\"react.context\");\nvar REACT_SERVER_CONTEXT_TYPE = Symbol.for(\"react.server_context\");\nvar REACT_FORWARD_REF_TYPE = Symbol.for(\"react.forward_ref\");\nvar REACT_SUSPENSE_TYPE = Symbol.for(\"react.suspense\");\nvar REACT_SUSPENSE_LIST_TYPE = Symbol.for(\"react.suspense_list\");\nvar REACT_MEMO_TYPE = Symbol.for(\"react.memo\");\nvar REACT_LAZY_TYPE = Symbol.for(\"react.lazy\");\nvar REACT_OFFSCREEN_TYPE = Symbol.for(\"react.offscreen\");\nvar REACT_CLIENT_REFERENCE = Symbol.for(\"react.client.reference\");\nvar ForwardRef = REACT_FORWARD_REF_TYPE;\nvar Memo = REACT_MEMO_TYPE;\nfunction isValidElementType(type) {\n if (typeof type === \"string\" || typeof type === \"function\") {\n return true;\n }\n if (type === REACT_FRAGMENT_TYPE || type === REACT_PROFILER_TYPE || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || type === REACT_OFFSCREEN_TYPE) {\n return true;\n }\n if (typeof type === \"object\" && type !== null) {\n if (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || // This needs to include all possible module reference object\n // types supported by any Flight configuration anywhere since\n // we don't know which Flight build this will end up being used\n // with.\n type.$$typeof === REACT_CLIENT_REFERENCE || type.getModuleId !== void 0) {\n return true;\n }\n }\n return false;\n}\nfunction typeOf(object) {\n if (typeof object === \"object\" && object !== null) {\n const $$typeof = object.$$typeof;\n switch ($$typeof) {\n case REACT_ELEMENT_TYPE: {\n const type = object.type;\n switch (type) {\n case REACT_FRAGMENT_TYPE:\n case REACT_PROFILER_TYPE:\n case REACT_STRICT_MODE_TYPE:\n case REACT_SUSPENSE_TYPE:\n case REACT_SUSPENSE_LIST_TYPE:\n return type;\n default: {\n const $$typeofType = type && type.$$typeof;\n switch ($$typeofType) {\n case REACT_SERVER_CONTEXT_TYPE:\n case REACT_CONTEXT_TYPE:\n case REACT_FORWARD_REF_TYPE:\n case REACT_LAZY_TYPE:\n case REACT_MEMO_TYPE:\n case REACT_PROVIDER_TYPE:\n return $$typeofType;\n default:\n return $$typeof;\n }\n }\n }\n }\n case REACT_PORTAL_TYPE: {\n return $$typeof;\n }\n }\n }\n return void 0;\n}\nfunction isContextConsumer(object) {\n return typeOf(object) === REACT_CONTEXT_TYPE;\n}\nfunction isMemo(object) {\n return typeOf(object) === REACT_MEMO_TYPE;\n}\n\n// src/utils/warning.ts\nfunction warning(message) {\n if (typeof console !== \"undefined\" && typeof console.error === \"function\") {\n console.error(message);\n }\n try {\n throw new Error(message);\n } catch (e) {\n }\n}\n\n// src/connect/verifySubselectors.ts\nfunction verify(selector, methodName) {\n if (!selector) {\n throw new Error(`Unexpected value for ${methodName} in connect.`);\n } else if (methodName === \"mapStateToProps\" || methodName === \"mapDispatchToProps\") {\n if (!Object.prototype.hasOwnProperty.call(selector, \"dependsOnOwnProps\")) {\n warning(\n `The selector for ${methodName} of connect did not specify a value for dependsOnOwnProps.`\n );\n }\n }\n}\nfunction verifySubselectors(mapStateToProps, mapDispatchToProps, mergeProps) {\n verify(mapStateToProps, \"mapStateToProps\");\n verify(mapDispatchToProps, \"mapDispatchToProps\");\n verify(mergeProps, \"mergeProps\");\n}\n\n// src/connect/selectorFactory.ts\nfunction pureFinalPropsSelectorFactory(mapStateToProps, mapDispatchToProps, mergeProps, dispatch, {\n areStatesEqual,\n areOwnPropsEqual,\n areStatePropsEqual\n}) {\n let hasRunAtLeastOnce = false;\n let state;\n let ownProps;\n let stateProps;\n let dispatchProps;\n let mergedProps;\n function handleFirstCall(firstState, firstOwnProps) {\n state = firstState;\n ownProps = firstOwnProps;\n stateProps = mapStateToProps(state, ownProps);\n dispatchProps = mapDispatchToProps(dispatch, ownProps);\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n hasRunAtLeastOnce = true;\n return mergedProps;\n }\n function handleNewPropsAndNewState() {\n stateProps = mapStateToProps(state, ownProps);\n if (mapDispatchToProps.dependsOnOwnProps)\n dispatchProps = mapDispatchToProps(dispatch, ownProps);\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n return mergedProps;\n }\n function handleNewProps() {\n if (mapStateToProps.dependsOnOwnProps)\n stateProps = mapStateToProps(state, ownProps);\n if (mapDispatchToProps.dependsOnOwnProps)\n dispatchProps = mapDispatchToProps(dispatch, ownProps);\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n return mergedProps;\n }\n function handleNewState() {\n const nextStateProps = mapStateToProps(state, ownProps);\n const statePropsChanged = !areStatePropsEqual(nextStateProps, stateProps);\n stateProps = nextStateProps;\n if (statePropsChanged)\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n return mergedProps;\n }\n function handleSubsequentCalls(nextState, nextOwnProps) {\n const propsChanged = !areOwnPropsEqual(nextOwnProps, ownProps);\n const stateChanged = !areStatesEqual(\n nextState,\n state,\n nextOwnProps,\n ownProps\n );\n state = nextState;\n ownProps = nextOwnProps;\n if (propsChanged && stateChanged)\n return handleNewPropsAndNewState();\n if (propsChanged)\n return handleNewProps();\n if (stateChanged)\n return handleNewState();\n return mergedProps;\n }\n return function pureFinalPropsSelector(nextState, nextOwnProps) {\n return hasRunAtLeastOnce ? handleSubsequentCalls(nextState, nextOwnProps) : handleFirstCall(nextState, nextOwnProps);\n };\n}\nfunction finalPropsSelectorFactory(dispatch, {\n initMapStateToProps,\n initMapDispatchToProps,\n initMergeProps,\n ...options\n}) {\n const mapStateToProps = initMapStateToProps(dispatch, options);\n const mapDispatchToProps = initMapDispatchToProps(dispatch, options);\n const mergeProps = initMergeProps(dispatch, options);\n if (process.env.NODE_ENV !== \"production\") {\n verifySubselectors(mapStateToProps, mapDispatchToProps, mergeProps);\n }\n return pureFinalPropsSelectorFactory(mapStateToProps, mapDispatchToProps, mergeProps, dispatch, options);\n}\n\n// src/utils/bindActionCreators.ts\nfunction bindActionCreators(actionCreators, dispatch) {\n const boundActionCreators = {};\n for (const key in actionCreators) {\n const actionCreator = actionCreators[key];\n if (typeof actionCreator === \"function\") {\n boundActionCreators[key] = (...args) => dispatch(actionCreator(...args));\n }\n }\n return boundActionCreators;\n}\n\n// src/utils/isPlainObject.ts\nfunction isPlainObject(obj) {\n if (typeof obj !== \"object\" || obj === null)\n return false;\n const proto = Object.getPrototypeOf(obj);\n if (proto === null)\n return true;\n let baseProto = proto;\n while (Object.getPrototypeOf(baseProto) !== null) {\n baseProto = Object.getPrototypeOf(baseProto);\n }\n return proto === baseProto;\n}\n\n// src/utils/verifyPlainObject.ts\nfunction verifyPlainObject(value, displayName, methodName) {\n if (!isPlainObject(value)) {\n warning(\n `${methodName}() in ${displayName} must return a plain object. Instead received ${value}.`\n );\n }\n}\n\n// src/connect/wrapMapToProps.ts\nfunction wrapMapToPropsConstant(getConstant) {\n return function initConstantSelector(dispatch) {\n const constant = getConstant(dispatch);\n function constantSelector() {\n return constant;\n }\n constantSelector.dependsOnOwnProps = false;\n return constantSelector;\n };\n}\nfunction getDependsOnOwnProps(mapToProps) {\n return mapToProps.dependsOnOwnProps ? Boolean(mapToProps.dependsOnOwnProps) : mapToProps.length !== 1;\n}\nfunction wrapMapToPropsFunc(mapToProps, methodName) {\n return function initProxySelector(dispatch, { displayName }) {\n const proxy = function mapToPropsProxy(stateOrDispatch, ownProps) {\n return proxy.dependsOnOwnProps ? proxy.mapToProps(stateOrDispatch, ownProps) : proxy.mapToProps(stateOrDispatch, void 0);\n };\n proxy.dependsOnOwnProps = true;\n proxy.mapToProps = function detectFactoryAndVerify(stateOrDispatch, ownProps) {\n proxy.mapToProps = mapToProps;\n proxy.dependsOnOwnProps = getDependsOnOwnProps(mapToProps);\n let props = proxy(stateOrDispatch, ownProps);\n if (typeof props === \"function\") {\n proxy.mapToProps = props;\n proxy.dependsOnOwnProps = getDependsOnOwnProps(props);\n props = proxy(stateOrDispatch, ownProps);\n }\n if (process.env.NODE_ENV !== \"production\")\n verifyPlainObject(props, displayName, methodName);\n return props;\n };\n return proxy;\n };\n}\n\n// src/connect/invalidArgFactory.ts\nfunction createInvalidArgFactory(arg, name) {\n return (dispatch, options) => {\n throw new Error(\n `Invalid value of type ${typeof arg} for ${name} argument when connecting component ${options.wrappedComponentName}.`\n );\n };\n}\n\n// src/connect/mapDispatchToProps.ts\nfunction mapDispatchToPropsFactory(mapDispatchToProps) {\n return mapDispatchToProps && typeof mapDispatchToProps === \"object\" ? wrapMapToPropsConstant(\n (dispatch) => (\n // @ts-ignore\n bindActionCreators(mapDispatchToProps, dispatch)\n )\n ) : !mapDispatchToProps ? wrapMapToPropsConstant((dispatch) => ({\n dispatch\n })) : typeof mapDispatchToProps === \"function\" ? (\n // @ts-ignore\n wrapMapToPropsFunc(mapDispatchToProps, \"mapDispatchToProps\")\n ) : createInvalidArgFactory(mapDispatchToProps, \"mapDispatchToProps\");\n}\n\n// src/connect/mapStateToProps.ts\nfunction mapStateToPropsFactory(mapStateToProps) {\n return !mapStateToProps ? wrapMapToPropsConstant(() => ({})) : typeof mapStateToProps === \"function\" ? (\n // @ts-ignore\n wrapMapToPropsFunc(mapStateToProps, \"mapStateToProps\")\n ) : createInvalidArgFactory(mapStateToProps, \"mapStateToProps\");\n}\n\n// src/connect/mergeProps.ts\nfunction defaultMergeProps(stateProps, dispatchProps, ownProps) {\n return { ...ownProps, ...stateProps, ...dispatchProps };\n}\nfunction wrapMergePropsFunc(mergeProps) {\n return function initMergePropsProxy(dispatch, { displayName, areMergedPropsEqual }) {\n let hasRunOnce = false;\n let mergedProps;\n return function mergePropsProxy(stateProps, dispatchProps, ownProps) {\n const nextMergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n if (hasRunOnce) {\n if (!areMergedPropsEqual(nextMergedProps, mergedProps))\n mergedProps = nextMergedProps;\n } else {\n hasRunOnce = true;\n mergedProps = nextMergedProps;\n if (process.env.NODE_ENV !== \"production\")\n verifyPlainObject(mergedProps, displayName, \"mergeProps\");\n }\n return mergedProps;\n };\n };\n}\nfunction mergePropsFactory(mergeProps) {\n return !mergeProps ? () => defaultMergeProps : typeof mergeProps === \"function\" ? wrapMergePropsFunc(mergeProps) : createInvalidArgFactory(mergeProps, \"mergeProps\");\n}\n\n// src/utils/batch.ts\nfunction defaultNoopBatch(callback) {\n callback();\n}\n\n// src/utils/Subscription.ts\nfunction createListenerCollection() {\n let first = null;\n let last = null;\n return {\n clear() {\n first = null;\n last = null;\n },\n notify() {\n defaultNoopBatch(() => {\n let listener = first;\n while (listener) {\n listener.callback();\n listener = listener.next;\n }\n });\n },\n get() {\n const listeners = [];\n let listener = first;\n while (listener) {\n listeners.push(listener);\n listener = listener.next;\n }\n return listeners;\n },\n subscribe(callback) {\n let isSubscribed = true;\n const listener = last = {\n callback,\n next: null,\n prev: last\n };\n if (listener.prev) {\n listener.prev.next = listener;\n } else {\n first = listener;\n }\n return function unsubscribe() {\n if (!isSubscribed || first === null)\n return;\n isSubscribed = false;\n if (listener.next) {\n listener.next.prev = listener.prev;\n } else {\n last = listener.prev;\n }\n if (listener.prev) {\n listener.prev.next = listener.next;\n } else {\n first = listener.next;\n }\n };\n }\n };\n}\nvar nullListeners = {\n notify() {\n },\n get: () => []\n};\nfunction createSubscription(store, parentSub) {\n let unsubscribe;\n let listeners = nullListeners;\n let subscriptionsAmount = 0;\n let selfSubscribed = false;\n function addNestedSub(listener) {\n trySubscribe();\n const cleanupListener = listeners.subscribe(listener);\n let removed = false;\n return () => {\n if (!removed) {\n removed = true;\n cleanupListener();\n tryUnsubscribe();\n }\n };\n }\n function notifyNestedSubs() {\n listeners.notify();\n }\n function handleChangeWrapper() {\n if (subscription.onStateChange) {\n subscription.onStateChange();\n }\n }\n function isSubscribed() {\n return selfSubscribed;\n }\n function trySubscribe() {\n subscriptionsAmount++;\n if (!unsubscribe) {\n unsubscribe = parentSub ? parentSub.addNestedSub(handleChangeWrapper) : store.subscribe(handleChangeWrapper);\n listeners = createListenerCollection();\n }\n }\n function tryUnsubscribe() {\n subscriptionsAmount--;\n if (unsubscribe && subscriptionsAmount === 0) {\n unsubscribe();\n unsubscribe = void 0;\n listeners.clear();\n listeners = nullListeners;\n }\n }\n function trySubscribeSelf() {\n if (!selfSubscribed) {\n selfSubscribed = true;\n trySubscribe();\n }\n }\n function tryUnsubscribeSelf() {\n if (selfSubscribed) {\n selfSubscribed = false;\n tryUnsubscribe();\n }\n }\n const subscription = {\n addNestedSub,\n notifyNestedSubs,\n handleChangeWrapper,\n isSubscribed,\n trySubscribe: trySubscribeSelf,\n tryUnsubscribe: tryUnsubscribeSelf,\n getListeners: () => listeners\n };\n return subscription;\n}\n\n// src/utils/useIsomorphicLayoutEffect.ts\nvar canUseDOM = !!(typeof window !== \"undefined\" && typeof window.document !== \"undefined\" && typeof window.document.createElement !== \"undefined\");\nvar useIsomorphicLayoutEffect = canUseDOM ? React.useLayoutEffect : React.useEffect;\n\n// src/utils/shallowEqual.ts\nfunction is(x, y) {\n if (x === y) {\n return x !== 0 || y !== 0 || 1 / x === 1 / y;\n } else {\n return x !== x && y !== y;\n }\n}\nfunction shallowEqual(objA, objB) {\n if (is(objA, objB))\n return true;\n if (typeof objA !== \"object\" || objA === null || typeof objB !== \"object\" || objB === null) {\n return false;\n }\n const keysA = Object.keys(objA);\n const keysB = Object.keys(objB);\n if (keysA.length !== keysB.length)\n return false;\n for (let i = 0; i < keysA.length; i++) {\n if (!Object.prototype.hasOwnProperty.call(objB, keysA[i]) || !is(objA[keysA[i]], objB[keysA[i]])) {\n return false;\n }\n }\n return true;\n}\n\n// src/utils/hoistStatics.ts\nvar REACT_STATICS = {\n childContextTypes: true,\n contextType: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n getDerivedStateFromError: true,\n getDerivedStateFromProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\nvar FORWARD_REF_STATICS = {\n $$typeof: true,\n render: true,\n defaultProps: true,\n displayName: true,\n propTypes: true\n};\nvar MEMO_STATICS = {\n $$typeof: true,\n compare: true,\n defaultProps: true,\n displayName: true,\n propTypes: true,\n type: true\n};\nvar TYPE_STATICS = {\n [ForwardRef]: FORWARD_REF_STATICS,\n [Memo]: MEMO_STATICS\n};\nfunction getStatics(component) {\n if (isMemo(component)) {\n return MEMO_STATICS;\n }\n return TYPE_STATICS[component[\"$$typeof\"]] || REACT_STATICS;\n}\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = Object.prototype;\nfunction hoistNonReactStatics(targetComponent, sourceComponent) {\n if (typeof sourceComponent !== \"string\") {\n if (objectPrototype) {\n const inheritedComponent = getPrototypeOf(sourceComponent);\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent);\n }\n }\n let keys = getOwnPropertyNames(sourceComponent);\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n const targetStatics = getStatics(targetComponent);\n const sourceStatics = getStatics(sourceComponent);\n for (let i = 0; i < keys.length; ++i) {\n const key = keys[i];\n if (!KNOWN_STATICS[key] && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) {\n const descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n try {\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {\n }\n }\n }\n }\n return targetComponent;\n}\n\n// src/components/connect.tsx\nvar useSyncExternalStore = notInitialized;\nvar initializeConnect = (fn) => {\n useSyncExternalStore = fn;\n};\nvar NO_SUBSCRIPTION_ARRAY = [null, null];\nvar stringifyComponent = (Comp) => {\n try {\n return JSON.stringify(Comp);\n } catch (err) {\n return String(Comp);\n }\n};\nfunction useIsomorphicLayoutEffectWithArgs(effectFunc, effectArgs, dependencies) {\n useIsomorphicLayoutEffect(() => effectFunc(...effectArgs), dependencies);\n}\nfunction captureWrapperProps(lastWrapperProps, lastChildProps, renderIsScheduled, wrapperProps, childPropsFromStoreUpdate, notifyNestedSubs) {\n lastWrapperProps.current = wrapperProps;\n renderIsScheduled.current = false;\n if (childPropsFromStoreUpdate.current) {\n childPropsFromStoreUpdate.current = null;\n notifyNestedSubs();\n }\n}\nfunction subscribeUpdates(shouldHandleStateChanges, store, subscription, childPropsSelector, lastWrapperProps, lastChildProps, renderIsScheduled, isMounted, childPropsFromStoreUpdate, notifyNestedSubs, additionalSubscribeListener) {\n if (!shouldHandleStateChanges)\n return () => {\n };\n let didUnsubscribe = false;\n let lastThrownError = null;\n const checkForUpdates = () => {\n if (didUnsubscribe || !isMounted.current) {\n return;\n }\n const latestStoreState = store.getState();\n let newChildProps, error;\n try {\n newChildProps = childPropsSelector(\n latestStoreState,\n lastWrapperProps.current\n );\n } catch (e) {\n error = e;\n lastThrownError = e;\n }\n if (!error) {\n lastThrownError = null;\n }\n if (newChildProps === lastChildProps.current) {\n if (!renderIsScheduled.current) {\n notifyNestedSubs();\n }\n } else {\n lastChildProps.current = newChildProps;\n childPropsFromStoreUpdate.current = newChildProps;\n renderIsScheduled.current = true;\n additionalSubscribeListener();\n }\n };\n subscription.onStateChange = checkForUpdates;\n subscription.trySubscribe();\n checkForUpdates();\n const unsubscribeWrapper = () => {\n didUnsubscribe = true;\n subscription.tryUnsubscribe();\n subscription.onStateChange = null;\n if (lastThrownError) {\n throw lastThrownError;\n }\n };\n return unsubscribeWrapper;\n}\nfunction strictEqual(a, b) {\n return a === b;\n}\nvar hasWarnedAboutDeprecatedPureOption = false;\nfunction connect(mapStateToProps, mapDispatchToProps, mergeProps, {\n // The `pure` option has been removed, so TS doesn't like us destructuring this to check its existence.\n // @ts-ignore\n pure,\n areStatesEqual = strictEqual,\n areOwnPropsEqual = shallowEqual,\n areStatePropsEqual = shallowEqual,\n areMergedPropsEqual = shallowEqual,\n // use React's forwardRef to expose a ref of the wrapped component\n forwardRef = false,\n // the context consumer to use\n context = ReactReduxContext\n} = {}) {\n if (process.env.NODE_ENV !== \"production\") {\n if (pure !== void 0 && !hasWarnedAboutDeprecatedPureOption) {\n hasWarnedAboutDeprecatedPureOption = true;\n warning(\n 'The `pure` option has been removed. `connect` is now always a \"pure/memoized\" component'\n );\n }\n }\n const Context = context;\n const initMapStateToProps = mapStateToPropsFactory(mapStateToProps);\n const initMapDispatchToProps = mapDispatchToPropsFactory(mapDispatchToProps);\n const initMergeProps = mergePropsFactory(mergeProps);\n const shouldHandleStateChanges = Boolean(mapStateToProps);\n const wrapWithConnect = (WrappedComponent) => {\n if (process.env.NODE_ENV !== \"production\") {\n const isValid = /* @__PURE__ */ isValidElementType(WrappedComponent);\n if (!isValid)\n throw new Error(\n `You must pass a component to the function returned by connect. Instead received ${stringifyComponent(\n WrappedComponent\n )}`\n );\n }\n const wrappedComponentName = WrappedComponent.displayName || WrappedComponent.name || \"Component\";\n const displayName = `Connect(${wrappedComponentName})`;\n const selectorFactoryOptions = {\n shouldHandleStateChanges,\n displayName,\n wrappedComponentName,\n WrappedComponent,\n // @ts-ignore\n initMapStateToProps,\n // @ts-ignore\n initMapDispatchToProps,\n initMergeProps,\n areStatesEqual,\n areStatePropsEqual,\n areOwnPropsEqual,\n areMergedPropsEqual\n };\n function ConnectFunction(props) {\n const [propsContext, reactReduxForwardedRef, wrapperProps] = React.useMemo(() => {\n const { reactReduxForwardedRef: reactReduxForwardedRef2, ...wrapperProps2 } = props;\n return [props.context, reactReduxForwardedRef2, wrapperProps2];\n }, [props]);\n const ContextToUse = React.useMemo(() => {\n let ResultContext = Context;\n if (propsContext?.Consumer) {\n if (process.env.NODE_ENV !== \"production\") {\n const isValid = /* @__PURE__ */ isContextConsumer(\n // @ts-ignore\n /* @__PURE__ */ React.createElement(propsContext.Consumer, null)\n );\n if (!isValid) {\n throw new Error(\n \"You must pass a valid React context consumer as `props.context`\"\n );\n }\n ResultContext = propsContext;\n }\n }\n return ResultContext;\n }, [propsContext, Context]);\n const contextValue = React.useContext(ContextToUse);\n const didStoreComeFromProps = Boolean(props.store) && Boolean(props.store.getState) && Boolean(props.store.dispatch);\n const didStoreComeFromContext = Boolean(contextValue) && Boolean(contextValue.store);\n if (process.env.NODE_ENV !== \"production\" && !didStoreComeFromProps && !didStoreComeFromContext) {\n throw new Error(\n `Could not find \"store\" in the context of \"${displayName}\". Either wrap the root component in a <Provider>, or pass a custom React context provider to <Provider> and the corresponding React context consumer to ${displayName} in connect options.`\n );\n }\n const store = didStoreComeFromProps ? props.store : contextValue.store;\n const getServerState = didStoreComeFromContext ? contextValue.getServerState : store.getState;\n const childPropsSelector = React.useMemo(() => {\n return finalPropsSelectorFactory(store.dispatch, selectorFactoryOptions);\n }, [store]);\n const [subscription, notifyNestedSubs] = React.useMemo(() => {\n if (!shouldHandleStateChanges)\n return NO_SUBSCRIPTION_ARRAY;\n const subscription2 = createSubscription(\n store,\n didStoreComeFromProps ? void 0 : contextValue.subscription\n );\n const notifyNestedSubs2 = subscription2.notifyNestedSubs.bind(subscription2);\n return [subscription2, notifyNestedSubs2];\n }, [store, didStoreComeFromProps, contextValue]);\n const overriddenContextValue = React.useMemo(() => {\n if (didStoreComeFromProps) {\n return contextValue;\n }\n return {\n ...contextValue,\n subscription\n };\n }, [didStoreComeFromProps, contextValue, subscription]);\n const lastChildProps = React.useRef();\n const lastWrapperProps = React.useRef(wrapperProps);\n const childPropsFromStoreUpdate = React.useRef();\n const renderIsScheduled = React.useRef(false);\n const isProcessingDispatch = React.useRef(false);\n const isMounted = React.useRef(false);\n const latestSubscriptionCallbackError = React.useRef();\n useIsomorphicLayoutEffect(() => {\n isMounted.current = true;\n return () => {\n isMounted.current = false;\n };\n }, []);\n const actualChildPropsSelector = React.useMemo(() => {\n const selector = () => {\n if (childPropsFromStoreUpdate.current && wrapperProps === lastWrapperProps.current) {\n return childPropsFromStoreUpdate.current;\n }\n return childPropsSelector(store.getState(), wrapperProps);\n };\n return selector;\n }, [store, wrapperProps]);\n const subscribeForReact = React.useMemo(() => {\n const subscribe = (reactListener) => {\n if (!subscription) {\n return () => {\n };\n }\n return subscribeUpdates(\n shouldHandleStateChanges,\n store,\n subscription,\n // @ts-ignore\n childPropsSelector,\n lastWrapperProps,\n lastChildProps,\n renderIsScheduled,\n isMounted,\n childPropsFromStoreUpdate,\n notifyNestedSubs,\n reactListener\n );\n };\n return subscribe;\n }, [subscription]);\n useIsomorphicLayoutEffectWithArgs(captureWrapperProps, [\n lastWrapperProps,\n lastChildProps,\n renderIsScheduled,\n wrapperProps,\n childPropsFromStoreUpdate,\n notifyNestedSubs\n ]);\n let actualChildProps;\n try {\n actualChildProps = useSyncExternalStore(\n // TODO We're passing through a big wrapper that does a bunch of extra side effects besides subscribing\n subscribeForReact,\n // TODO This is incredibly hacky. We've already processed the store update and calculated new child props,\n // TODO and we're just passing that through so it triggers a re-render for us rather than relying on `uSES`.\n actualChildPropsSelector,\n getServerState ? () => childPropsSelector(getServerState(), wrapperProps) : actualChildPropsSelector\n );\n } catch (err) {\n if (latestSubscriptionCallbackError.current) {\n ;\n err.message += `\nThe error may be correlated with this previous error:\n${latestSubscriptionCallbackError.current.stack}\n\n`;\n }\n throw err;\n }\n useIsomorphicLayoutEffect(() => {\n latestSubscriptionCallbackError.current = void 0;\n childPropsFromStoreUpdate.current = void 0;\n lastChildProps.current = actualChildProps;\n });\n const renderedWrappedComponent = React.useMemo(() => {\n return (\n // @ts-ignore\n /* @__PURE__ */ React.createElement(\n WrappedComponent,\n {\n ...actualChildProps,\n ref: reactReduxForwardedRef\n }\n )\n );\n }, [reactReduxForwardedRef, WrappedComponent, actualChildProps]);\n const renderedChild = React.useMemo(() => {\n if (shouldHandleStateChanges) {\n return /* @__PURE__ */ React.createElement(ContextToUse.Provider, { value: overriddenContextValue }, renderedWrappedComponent);\n }\n return renderedWrappedComponent;\n }, [ContextToUse, renderedWrappedComponent, overriddenContextValue]);\n return renderedChild;\n }\n const _Connect = React.memo(ConnectFunction);\n const Connect = _Connect;\n Connect.WrappedComponent = WrappedComponent;\n Connect.displayName = ConnectFunction.displayName = displayName;\n if (forwardRef) {\n const _forwarded = React.forwardRef(function forwardConnectRef(props, ref) {\n return /* @__PURE__ */ React.createElement(Connect, { ...props, reactReduxForwardedRef: ref });\n });\n const forwarded = _forwarded;\n forwarded.displayName = displayName;\n forwarded.WrappedComponent = WrappedComponent;\n return /* @__PURE__ */ hoistNonReactStatics(forwarded, WrappedComponent);\n }\n return /* @__PURE__ */ hoistNonReactStatics(Connect, WrappedComponent);\n };\n return wrapWithConnect;\n}\nvar connect_default = connect;\n\n// src/components/Provider.tsx\nfunction Provider({\n store,\n context,\n children,\n serverState,\n stabilityCheck = \"once\",\n identityFunctionCheck = \"once\"\n}) {\n const contextValue = React.useMemo(() => {\n const subscription = createSubscription(store);\n return {\n store,\n subscription,\n getServerState: serverState ? () => serverState : void 0,\n stabilityCheck,\n identityFunctionCheck\n };\n }, [store, serverState, stabilityCheck, identityFunctionCheck]);\n const previousState = React.useMemo(() => store.getState(), [store]);\n useIsomorphicLayoutEffect(() => {\n const { subscription } = contextValue;\n subscription.onStateChange = subscription.notifyNestedSubs;\n subscription.trySubscribe();\n if (previousState !== store.getState()) {\n subscription.notifyNestedSubs();\n }\n return () => {\n subscription.tryUnsubscribe();\n subscription.onStateChange = void 0;\n };\n }, [contextValue, previousState]);\n const Context = context || ReactReduxContext;\n return /* @__PURE__ */ React.createElement(Context.Provider, { value: contextValue }, children);\n}\nvar Provider_default = Provider;\n\n// src/hooks/useStore.ts\nfunction createStoreHook(context = ReactReduxContext) {\n const useReduxContext2 = context === ReactReduxContext ? useReduxContext : (\n // @ts-ignore\n createReduxContextHook(context)\n );\n const useStore2 = () => {\n const { store } = useReduxContext2();\n return store;\n };\n Object.assign(useStore2, {\n withTypes: () => useStore2\n });\n return useStore2;\n}\nvar useStore = /* @__PURE__ */ createStoreHook();\n\n// src/hooks/useDispatch.ts\nfunction createDispatchHook(context = ReactReduxContext) {\n const useStore2 = context === ReactReduxContext ? useStore : createStoreHook(context);\n const useDispatch2 = () => {\n const store = useStore2();\n return store.dispatch;\n };\n Object.assign(useDispatch2, {\n withTypes: () => useDispatch2\n });\n return useDispatch2;\n}\nvar useDispatch = /* @__PURE__ */ createDispatchHook();\n\n// src/exports.ts\nvar batch = defaultNoopBatch;\n\n// src/index.ts\ninitializeUseSelector(useSyncExternalStoreWithSelector2);\ninitializeConnect(React2.useSyncExternalStore);\nexport {\n Provider_default as Provider,\n ReactReduxContext,\n batch,\n connect_default as connect,\n createDispatchHook,\n createSelectorHook,\n createStoreHook,\n shallowEqual,\n useDispatch,\n useSelector,\n useStore\n};\n//# sourceMappingURL=react-redux.mjs.map","// src/utils/formatProdErrorMessage.ts\nfunction formatProdErrorMessage(code) {\n return `Minified Redux error #${code}; visit https://redux.js.org/Errors?code=${code} for the full message or use the non-minified dev environment for full errors. `;\n}\n\n// src/utils/symbol-observable.ts\nvar $$observable = /* @__PURE__ */ (() => typeof Symbol === \"function\" && Symbol.observable || \"@@observable\")();\nvar symbol_observable_default = $$observable;\n\n// src/utils/actionTypes.ts\nvar randomString = () => Math.random().toString(36).substring(7).split(\"\").join(\".\");\nvar ActionTypes = {\n INIT: `@@redux/INIT${/* @__PURE__ */ randomString()}`,\n REPLACE: `@@redux/REPLACE${/* @__PURE__ */ randomString()}`,\n PROBE_UNKNOWN_ACTION: () => `@@redux/PROBE_UNKNOWN_ACTION${randomString()}`\n};\nvar actionTypes_default = ActionTypes;\n\n// src/utils/isPlainObject.ts\nfunction isPlainObject(obj) {\n if (typeof obj !== \"object\" || obj === null)\n return false;\n let proto = obj;\n while (Object.getPrototypeOf(proto) !== null) {\n proto = Object.getPrototypeOf(proto);\n }\n return Object.getPrototypeOf(obj) === proto || Object.getPrototypeOf(obj) === null;\n}\n\n// src/utils/kindOf.ts\nfunction miniKindOf(val) {\n if (val === void 0)\n return \"undefined\";\n if (val === null)\n return \"null\";\n const type = typeof val;\n switch (type) {\n case \"boolean\":\n case \"string\":\n case \"number\":\n case \"symbol\":\n case \"function\": {\n return type;\n }\n }\n if (Array.isArray(val))\n return \"array\";\n if (isDate(val))\n return \"date\";\n if (isError(val))\n return \"error\";\n const constructorName = ctorName(val);\n switch (constructorName) {\n case \"Symbol\":\n case \"Promise\":\n case \"WeakMap\":\n case \"WeakSet\":\n case \"Map\":\n case \"Set\":\n return constructorName;\n }\n return Object.prototype.toString.call(val).slice(8, -1).toLowerCase().replace(/\\s/g, \"\");\n}\nfunction ctorName(val) {\n return typeof val.constructor === \"function\" ? val.constructor.name : null;\n}\nfunction isError(val) {\n return val instanceof Error || typeof val.message === \"string\" && val.constructor && typeof val.constructor.stackTraceLimit === \"number\";\n}\nfunction isDate(val) {\n if (val instanceof Date)\n return true;\n return typeof val.toDateString === \"function\" && typeof val.getDate === \"function\" && typeof val.setDate === \"function\";\n}\nfunction kindOf(val) {\n let typeOfVal = typeof val;\n if (process.env.NODE_ENV !== \"production\") {\n typeOfVal = miniKindOf(val);\n }\n return typeOfVal;\n}\n\n// src/createStore.ts\nfunction createStore(reducer, preloadedState, enhancer) {\n if (typeof reducer !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(2) : `Expected the root reducer to be a function. Instead, received: '${kindOf(reducer)}'`);\n }\n if (typeof preloadedState === \"function\" && typeof enhancer === \"function\" || typeof enhancer === \"function\" && typeof arguments[3] === \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(0) : \"It looks like you are passing several store enhancers to createStore(). This is not supported. Instead, compose them together to a single function. See https://redux.js.org/tutorials/fundamentals/part-4-store#creating-a-store-with-enhancers for an example.\");\n }\n if (typeof preloadedState === \"function\" && typeof enhancer === \"undefined\") {\n enhancer = preloadedState;\n preloadedState = void 0;\n }\n if (typeof enhancer !== \"undefined\") {\n if (typeof enhancer !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(1) : `Expected the enhancer to be a function. Instead, received: '${kindOf(enhancer)}'`);\n }\n return enhancer(createStore)(reducer, preloadedState);\n }\n let currentReducer = reducer;\n let currentState = preloadedState;\n let currentListeners = /* @__PURE__ */ new Map();\n let nextListeners = currentListeners;\n let listenerIdCounter = 0;\n let isDispatching = false;\n function ensureCanMutateNextListeners() {\n if (nextListeners === currentListeners) {\n nextListeners = /* @__PURE__ */ new Map();\n currentListeners.forEach((listener, key) => {\n nextListeners.set(key, listener);\n });\n }\n }\n function getState() {\n if (isDispatching) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(3) : \"You may not call store.getState() while the reducer is executing. The reducer has already received the state as an argument. Pass it down from the top reducer instead of reading it from the store.\");\n }\n return currentState;\n }\n function subscribe(listener) {\n if (typeof listener !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(4) : `Expected the listener to be a function. Instead, received: '${kindOf(listener)}'`);\n }\n if (isDispatching) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(5) : \"You may not call store.subscribe() while the reducer is executing. If you would like to be notified after the store has been updated, subscribe from a component and invoke store.getState() in the callback to access the latest state. See https://redux.js.org/api/store#subscribelistener for more details.\");\n }\n let isSubscribed = true;\n ensureCanMutateNextListeners();\n const listenerId = listenerIdCounter++;\n nextListeners.set(listenerId, listener);\n return function unsubscribe() {\n if (!isSubscribed) {\n return;\n }\n if (isDispatching) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(6) : \"You may not unsubscribe from a store listener while the reducer is executing. See https://redux.js.org/api/store#subscribelistener for more details.\");\n }\n isSubscribed = false;\n ensureCanMutateNextListeners();\n nextListeners.delete(listenerId);\n currentListeners = null;\n };\n }\n function dispatch(action) {\n if (!isPlainObject(action)) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(7) : `Actions must be plain objects. Instead, the actual type was: '${kindOf(action)}'. You may need to add middleware to your store setup to handle dispatching other values, such as 'redux-thunk' to handle dispatching functions. See https://redux.js.org/tutorials/fundamentals/part-4-store#middleware and https://redux.js.org/tutorials/fundamentals/part-6-async-logic#using-the-redux-thunk-middleware for examples.`);\n }\n if (typeof action.type === \"undefined\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(8) : 'Actions may not have an undefined \"type\" property. You may have misspelled an action type string constant.');\n }\n if (typeof action.type !== \"string\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(17) : `Action \"type\" property must be a string. Instead, the actual type was: '${kindOf(action.type)}'. Value was: '${action.type}' (stringified)`);\n }\n if (isDispatching) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(9) : \"Reducers may not dispatch actions.\");\n }\n try {\n isDispatching = true;\n currentState = currentReducer(currentState, action);\n } finally {\n isDispatching = false;\n }\n const listeners = currentListeners = nextListeners;\n listeners.forEach((listener) => {\n listener();\n });\n return action;\n }\n function replaceReducer(nextReducer) {\n if (typeof nextReducer !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(10) : `Expected the nextReducer to be a function. Instead, received: '${kindOf(nextReducer)}`);\n }\n currentReducer = nextReducer;\n dispatch({\n type: actionTypes_default.REPLACE\n });\n }\n function observable() {\n const outerSubscribe = subscribe;\n return {\n /**\n * The minimal observable subscription method.\n * @param observer Any object that can be used as an observer.\n * The observer object should have a `next` method.\n * @returns An object with an `unsubscribe` method that can\n * be used to unsubscribe the observable from the store, and prevent further\n * emission of values from the observable.\n */\n subscribe(observer) {\n if (typeof observer !== \"object\" || observer === null) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(11) : `Expected the observer to be an object. Instead, received: '${kindOf(observer)}'`);\n }\n function observeState() {\n const observerAsObserver = observer;\n if (observerAsObserver.next) {\n observerAsObserver.next(getState());\n }\n }\n observeState();\n const unsubscribe = outerSubscribe(observeState);\n return {\n unsubscribe\n };\n },\n [symbol_observable_default]() {\n return this;\n }\n };\n }\n dispatch({\n type: actionTypes_default.INIT\n });\n const store = {\n dispatch,\n subscribe,\n getState,\n replaceReducer,\n [symbol_observable_default]: observable\n };\n return store;\n}\nfunction legacy_createStore(reducer, preloadedState, enhancer) {\n return createStore(reducer, preloadedState, enhancer);\n}\n\n// src/utils/warning.ts\nfunction warning(message) {\n if (typeof console !== \"undefined\" && typeof console.error === \"function\") {\n console.error(message);\n }\n try {\n throw new Error(message);\n } catch (e) {\n }\n}\n\n// src/combineReducers.ts\nfunction getUnexpectedStateShapeWarningMessage(inputState, reducers, action, unexpectedKeyCache) {\n const reducerKeys = Object.keys(reducers);\n const argumentName = action && action.type === actionTypes_default.INIT ? \"preloadedState argument passed to createStore\" : \"previous state received by the reducer\";\n if (reducerKeys.length === 0) {\n return \"Store does not have a valid reducer. Make sure the argument passed to combineReducers is an object whose values are reducers.\";\n }\n if (!isPlainObject(inputState)) {\n return `The ${argumentName} has unexpected type of \"${kindOf(inputState)}\". Expected argument to be an object with the following keys: \"${reducerKeys.join('\", \"')}\"`;\n }\n const unexpectedKeys = Object.keys(inputState).filter((key) => !reducers.hasOwnProperty(key) && !unexpectedKeyCache[key]);\n unexpectedKeys.forEach((key) => {\n unexpectedKeyCache[key] = true;\n });\n if (action && action.type === actionTypes_default.REPLACE)\n return;\n if (unexpectedKeys.length > 0) {\n return `Unexpected ${unexpectedKeys.length > 1 ? \"keys\" : \"key\"} \"${unexpectedKeys.join('\", \"')}\" found in ${argumentName}. Expected to find one of the known reducer keys instead: \"${reducerKeys.join('\", \"')}\". Unexpected keys will be ignored.`;\n }\n}\nfunction assertReducerShape(reducers) {\n Object.keys(reducers).forEach((key) => {\n const reducer = reducers[key];\n const initialState = reducer(void 0, {\n type: actionTypes_default.INIT\n });\n if (typeof initialState === \"undefined\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(12) : `The slice reducer for key \"${key}\" returned undefined during initialization. If the state passed to the reducer is undefined, you must explicitly return the initial state. The initial state may not be undefined. If you don't want to set a value for this reducer, you can use null instead of undefined.`);\n }\n if (typeof reducer(void 0, {\n type: actionTypes_default.PROBE_UNKNOWN_ACTION()\n }) === \"undefined\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(13) : `The slice reducer for key \"${key}\" returned undefined when probed with a random type. Don't try to handle '${actionTypes_default.INIT}' or other actions in \"redux/*\" namespace. They are considered private. Instead, you must return the current state for any unknown actions, unless it is undefined, in which case you must return the initial state, regardless of the action type. The initial state may not be undefined, but can be null.`);\n }\n });\n}\nfunction combineReducers(reducers) {\n const reducerKeys = Object.keys(reducers);\n const finalReducers = {};\n for (let i = 0; i < reducerKeys.length; i++) {\n const key = reducerKeys[i];\n if (process.env.NODE_ENV !== \"production\") {\n if (typeof reducers[key] === \"undefined\") {\n warning(`No reducer provided for key \"${key}\"`);\n }\n }\n if (typeof reducers[key] === \"function\") {\n finalReducers[key] = reducers[key];\n }\n }\n const finalReducerKeys = Object.keys(finalReducers);\n let unexpectedKeyCache;\n if (process.env.NODE_ENV !== \"production\") {\n unexpectedKeyCache = {};\n }\n let shapeAssertionError;\n try {\n assertReducerShape(finalReducers);\n } catch (e) {\n shapeAssertionError = e;\n }\n return function combination(state = {}, action) {\n if (shapeAssertionError) {\n throw shapeAssertionError;\n }\n if (process.env.NODE_ENV !== \"production\") {\n const warningMessage = getUnexpectedStateShapeWarningMessage(state, finalReducers, action, unexpectedKeyCache);\n if (warningMessage) {\n warning(warningMessage);\n }\n }\n let hasChanged = false;\n const nextState = {};\n for (let i = 0; i < finalReducerKeys.length; i++) {\n const key = finalReducerKeys[i];\n const reducer = finalReducers[key];\n const previousStateForKey = state[key];\n const nextStateForKey = reducer(previousStateForKey, action);\n if (typeof nextStateForKey === \"undefined\") {\n const actionType = action && action.type;\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(14) : `When called with an action of type ${actionType ? `\"${String(actionType)}\"` : \"(unknown type)\"}, the slice reducer for key \"${key}\" returned undefined. To ignore an action, you must explicitly return the previous state. If you want this reducer to hold no value, you can return null instead of undefined.`);\n }\n nextState[key] = nextStateForKey;\n hasChanged = hasChanged || nextStateForKey !== previousStateForKey;\n }\n hasChanged = hasChanged || finalReducerKeys.length !== Object.keys(state).length;\n return hasChanged ? nextState : state;\n };\n}\n\n// src/bindActionCreators.ts\nfunction bindActionCreator(actionCreator, dispatch) {\n return function(...args) {\n return dispatch(actionCreator.apply(this, args));\n };\n}\nfunction bindActionCreators(actionCreators, dispatch) {\n if (typeof actionCreators === \"function\") {\n return bindActionCreator(actionCreators, dispatch);\n }\n if (typeof actionCreators !== \"object\" || actionCreators === null) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(16) : `bindActionCreators expected an object or a function, but instead received: '${kindOf(actionCreators)}'. Did you write \"import ActionCreators from\" instead of \"import * as ActionCreators from\"?`);\n }\n const boundActionCreators = {};\n for (const key in actionCreators) {\n const actionCreator = actionCreators[key];\n if (typeof actionCreator === \"function\") {\n boundActionCreators[key] = bindActionCreator(actionCreator, dispatch);\n }\n }\n return boundActionCreators;\n}\n\n// src/compose.ts\nfunction compose(...funcs) {\n if (funcs.length === 0) {\n return (arg) => arg;\n }\n if (funcs.length === 1) {\n return funcs[0];\n }\n return funcs.reduce((a, b) => (...args) => a(b(...args)));\n}\n\n// src/applyMiddleware.ts\nfunction applyMiddleware(...middlewares) {\n return (createStore2) => (reducer, preloadedState) => {\n const store = createStore2(reducer, preloadedState);\n let dispatch = () => {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(15) : \"Dispatching while constructing your middleware is not allowed. Other middleware would not be applied to this dispatch.\");\n };\n const middlewareAPI = {\n getState: store.getState,\n dispatch: (action, ...args) => dispatch(action, ...args)\n };\n const chain = middlewares.map((middleware) => middleware(middlewareAPI));\n dispatch = compose(...chain)(store.dispatch);\n return {\n ...store,\n dispatch\n };\n };\n}\n\n// src/utils/isAction.ts\nfunction isAction(action) {\n return isPlainObject(action) && \"type\" in action && typeof action.type === \"string\";\n}\nexport {\n actionTypes_default as __DO_NOT_USE__ActionTypes,\n applyMiddleware,\n bindActionCreators,\n combineReducers,\n compose,\n createStore,\n isAction,\n isPlainObject,\n legacy_createStore\n};\n//# sourceMappingURL=redux.mjs.map","// src/devModeChecks/identityFunctionCheck.ts\nvar runIdentityFunctionCheck = (resultFunc, inputSelectorsResults, outputSelectorResult) => {\n if (inputSelectorsResults.length === 1 && inputSelectorsResults[0] === outputSelectorResult) {\n let isInputSameAsOutput = false;\n try {\n const emptyObject = {};\n if (resultFunc(emptyObject) === emptyObject)\n isInputSameAsOutput = true;\n } catch {\n }\n if (isInputSameAsOutput) {\n let stack = void 0;\n try {\n throw new Error();\n } catch (e) {\n ;\n ({ stack } = e);\n }\n console.warn(\n \"The result function returned its own inputs without modification. e.g\\n`createSelector([state => state.todos], todos => todos)`\\nThis could lead to inefficient memoization and unnecessary re-renders.\\nEnsure transformation logic is in the result function, and extraction logic is in the input selectors.\",\n { stack }\n );\n }\n }\n};\n\n// src/devModeChecks/inputStabilityCheck.ts\nvar runInputStabilityCheck = (inputSelectorResultsObject, options, inputSelectorArgs) => {\n const { memoize, memoizeOptions } = options;\n const { inputSelectorResults, inputSelectorResultsCopy } = inputSelectorResultsObject;\n const createAnEmptyObject = memoize(() => ({}), ...memoizeOptions);\n const areInputSelectorResultsEqual = createAnEmptyObject.apply(null, inputSelectorResults) === createAnEmptyObject.apply(null, inputSelectorResultsCopy);\n if (!areInputSelectorResultsEqual) {\n let stack = void 0;\n try {\n throw new Error();\n } catch (e) {\n ;\n ({ stack } = e);\n }\n console.warn(\n \"An input selector returned a different result when passed same arguments.\\nThis means your output selector will likely run more frequently than intended.\\nAvoid returning a new reference inside your input selector, e.g.\\n`createSelector([state => state.todos.map(todo => todo.id)], todoIds => todoIds.length)`\",\n {\n arguments: inputSelectorArgs,\n firstInputs: inputSelectorResults,\n secondInputs: inputSelectorResultsCopy,\n stack\n }\n );\n }\n};\n\n// src/devModeChecks/setGlobalDevModeChecks.ts\nvar globalDevModeChecks = {\n inputStabilityCheck: \"once\",\n identityFunctionCheck: \"once\"\n};\nvar setGlobalDevModeChecks = (devModeChecks) => {\n Object.assign(globalDevModeChecks, devModeChecks);\n};\n\n// src/utils.ts\nvar NOT_FOUND = \"NOT_FOUND\";\nfunction assertIsFunction(func, errorMessage = `expected a function, instead received ${typeof func}`) {\n if (typeof func !== \"function\") {\n throw new TypeError(errorMessage);\n }\n}\nfunction assertIsObject(object, errorMessage = `expected an object, instead received ${typeof object}`) {\n if (typeof object !== \"object\") {\n throw new TypeError(errorMessage);\n }\n}\nfunction assertIsArrayOfFunctions(array, errorMessage = `expected all items to be functions, instead received the following types: `) {\n if (!array.every((item) => typeof item === \"function\")) {\n const itemTypes = array.map(\n (item) => typeof item === \"function\" ? `function ${item.name || \"unnamed\"}()` : typeof item\n ).join(\", \");\n throw new TypeError(`${errorMessage}[${itemTypes}]`);\n }\n}\nvar ensureIsArray = (item) => {\n return Array.isArray(item) ? item : [item];\n};\nfunction getDependencies(createSelectorArgs) {\n const dependencies = Array.isArray(createSelectorArgs[0]) ? createSelectorArgs[0] : createSelectorArgs;\n assertIsArrayOfFunctions(\n dependencies,\n `createSelector expects all input-selectors to be functions, but received the following types: `\n );\n return dependencies;\n}\nfunction collectInputSelectorResults(dependencies, inputSelectorArgs) {\n const inputSelectorResults = [];\n const { length } = dependencies;\n for (let i = 0; i < length; i++) {\n inputSelectorResults.push(dependencies[i].apply(null, inputSelectorArgs));\n }\n return inputSelectorResults;\n}\nvar getDevModeChecksExecutionInfo = (firstRun, devModeChecks) => {\n const { identityFunctionCheck, inputStabilityCheck } = {\n ...globalDevModeChecks,\n ...devModeChecks\n };\n return {\n identityFunctionCheck: {\n shouldRun: identityFunctionCheck === \"always\" || identityFunctionCheck === \"once\" && firstRun,\n run: runIdentityFunctionCheck\n },\n inputStabilityCheck: {\n shouldRun: inputStabilityCheck === \"always\" || inputStabilityCheck === \"once\" && firstRun,\n run: runInputStabilityCheck\n }\n };\n};\n\n// src/autotrackMemoize/autotracking.ts\nvar $REVISION = 0;\nvar CURRENT_TRACKER = null;\nvar Cell = class {\n revision = $REVISION;\n _value;\n _lastValue;\n _isEqual = tripleEq;\n constructor(initialValue, isEqual = tripleEq) {\n this._value = this._lastValue = initialValue;\n this._isEqual = isEqual;\n }\n // Whenever a storage value is read, it'll add itself to the current tracker if\n // one exists, entangling its state with that cache.\n get value() {\n CURRENT_TRACKER?.add(this);\n return this._value;\n }\n // Whenever a storage value is updated, we bump the global revision clock,\n // assign the revision for this storage to the new value, _and_ we schedule a\n // rerender. This is important, and it's what makes autotracking _pull_\n // based. We don't actively tell the caches which depend on the storage that\n // anything has happened. Instead, we recompute the caches when needed.\n set value(newValue) {\n if (this.value === newValue)\n return;\n this._value = newValue;\n this.revision = ++$REVISION;\n }\n};\nfunction tripleEq(a, b) {\n return a === b;\n}\nvar TrackingCache = class {\n _cachedValue;\n _cachedRevision = -1;\n _deps = [];\n hits = 0;\n fn;\n constructor(fn) {\n this.fn = fn;\n }\n clear() {\n this._cachedValue = void 0;\n this._cachedRevision = -1;\n this._deps = [];\n this.hits = 0;\n }\n get value() {\n if (this.revision > this._cachedRevision) {\n const { fn } = this;\n const currentTracker = /* @__PURE__ */ new Set();\n const prevTracker = CURRENT_TRACKER;\n CURRENT_TRACKER = currentTracker;\n this._cachedValue = fn();\n CURRENT_TRACKER = prevTracker;\n this.hits++;\n this._deps = Array.from(currentTracker);\n this._cachedRevision = this.revision;\n }\n CURRENT_TRACKER?.add(this);\n return this._cachedValue;\n }\n get revision() {\n return Math.max(...this._deps.map((d) => d.revision), 0);\n }\n};\nfunction getValue(cell) {\n if (!(cell instanceof Cell)) {\n console.warn(\"Not a valid cell! \", cell);\n }\n return cell.value;\n}\nfunction setValue(storage, value) {\n if (!(storage instanceof Cell)) {\n throw new TypeError(\n \"setValue must be passed a tracked store created with `createStorage`.\"\n );\n }\n storage.value = storage._lastValue = value;\n}\nfunction createCell(initialValue, isEqual = tripleEq) {\n return new Cell(initialValue, isEqual);\n}\nfunction createCache(fn) {\n assertIsFunction(\n fn,\n \"the first parameter to `createCache` must be a function\"\n );\n return new TrackingCache(fn);\n}\n\n// src/autotrackMemoize/tracking.ts\nvar neverEq = (a, b) => false;\nfunction createTag() {\n return createCell(null, neverEq);\n}\nfunction dirtyTag(tag, value) {\n setValue(tag, value);\n}\nvar consumeCollection = (node) => {\n let tag = node.collectionTag;\n if (tag === null) {\n tag = node.collectionTag = createTag();\n }\n getValue(tag);\n};\nvar dirtyCollection = (node) => {\n const tag = node.collectionTag;\n if (tag !== null) {\n dirtyTag(tag, null);\n }\n};\n\n// src/autotrackMemoize/proxy.ts\nvar REDUX_PROXY_LABEL = Symbol();\nvar nextId = 0;\nvar proto = Object.getPrototypeOf({});\nvar ObjectTreeNode = class {\n constructor(value) {\n this.value = value;\n this.value = value;\n this.tag.value = value;\n }\n proxy = new Proxy(this, objectProxyHandler);\n tag = createTag();\n tags = {};\n children = {};\n collectionTag = null;\n id = nextId++;\n};\nvar objectProxyHandler = {\n get(node, key) {\n function calculateResult() {\n const { value } = node;\n const childValue = Reflect.get(value, key);\n if (typeof key === \"symbol\") {\n return childValue;\n }\n if (key in proto) {\n return childValue;\n }\n if (typeof childValue === \"object\" && childValue !== null) {\n let childNode = node.children[key];\n if (childNode === void 0) {\n childNode = node.children[key] = createNode(childValue);\n }\n if (childNode.tag) {\n getValue(childNode.tag);\n }\n return childNode.proxy;\n } else {\n let tag = node.tags[key];\n if (tag === void 0) {\n tag = node.tags[key] = createTag();\n tag.value = childValue;\n }\n getValue(tag);\n return childValue;\n }\n }\n const res = calculateResult();\n return res;\n },\n ownKeys(node) {\n consumeCollection(node);\n return Reflect.ownKeys(node.value);\n },\n getOwnPropertyDescriptor(node, prop) {\n return Reflect.getOwnPropertyDescriptor(node.value, prop);\n },\n has(node, prop) {\n return Reflect.has(node.value, prop);\n }\n};\nvar ArrayTreeNode = class {\n constructor(value) {\n this.value = value;\n this.value = value;\n this.tag.value = value;\n }\n proxy = new Proxy([this], arrayProxyHandler);\n tag = createTag();\n tags = {};\n children = {};\n collectionTag = null;\n id = nextId++;\n};\nvar arrayProxyHandler = {\n get([node], key) {\n if (key === \"length\") {\n consumeCollection(node);\n }\n return objectProxyHandler.get(node, key);\n },\n ownKeys([node]) {\n return objectProxyHandler.ownKeys(node);\n },\n getOwnPropertyDescriptor([node], prop) {\n return objectProxyHandler.getOwnPropertyDescriptor(node, prop);\n },\n has([node], prop) {\n return objectProxyHandler.has(node, prop);\n }\n};\nfunction createNode(value) {\n if (Array.isArray(value)) {\n return new ArrayTreeNode(value);\n }\n return new ObjectTreeNode(value);\n}\nfunction updateNode(node, newValue) {\n const { value, tags, children } = node;\n node.value = newValue;\n if (Array.isArray(value) && Array.isArray(newValue) && value.length !== newValue.length) {\n dirtyCollection(node);\n } else {\n if (value !== newValue) {\n let oldKeysSize = 0;\n let newKeysSize = 0;\n let anyKeysAdded = false;\n for (const _key in value) {\n oldKeysSize++;\n }\n for (const key in newValue) {\n newKeysSize++;\n if (!(key in value)) {\n anyKeysAdded = true;\n break;\n }\n }\n const isDifferent = anyKeysAdded || oldKeysSize !== newKeysSize;\n if (isDifferent) {\n dirtyCollection(node);\n }\n }\n }\n for (const key in tags) {\n const childValue = value[key];\n const newChildValue = newValue[key];\n if (childValue !== newChildValue) {\n dirtyCollection(node);\n dirtyTag(tags[key], newChildValue);\n }\n if (typeof newChildValue === \"object\" && newChildValue !== null) {\n delete tags[key];\n }\n }\n for (const key in children) {\n const childNode = children[key];\n const newChildValue = newValue[key];\n const childValue = childNode.value;\n if (childValue === newChildValue) {\n continue;\n } else if (typeof newChildValue === \"object\" && newChildValue !== null) {\n updateNode(childNode, newChildValue);\n } else {\n deleteNode(childNode);\n delete children[key];\n }\n }\n}\nfunction deleteNode(node) {\n if (node.tag) {\n dirtyTag(node.tag, null);\n }\n dirtyCollection(node);\n for (const key in node.tags) {\n dirtyTag(node.tags[key], null);\n }\n for (const key in node.children) {\n deleteNode(node.children[key]);\n }\n}\n\n// src/lruMemoize.ts\nfunction createSingletonCache(equals) {\n let entry;\n return {\n get(key) {\n if (entry && equals(entry.key, key)) {\n return entry.value;\n }\n return NOT_FOUND;\n },\n put(key, value) {\n entry = { key, value };\n },\n getEntries() {\n return entry ? [entry] : [];\n },\n clear() {\n entry = void 0;\n }\n };\n}\nfunction createLruCache(maxSize, equals) {\n let entries = [];\n function get(key) {\n const cacheIndex = entries.findIndex((entry) => equals(key, entry.key));\n if (cacheIndex > -1) {\n const entry = entries[cacheIndex];\n if (cacheIndex > 0) {\n entries.splice(cacheIndex, 1);\n entries.unshift(entry);\n }\n return entry.value;\n }\n return NOT_FOUND;\n }\n function put(key, value) {\n if (get(key) === NOT_FOUND) {\n entries.unshift({ key, value });\n if (entries.length > maxSize) {\n entries.pop();\n }\n }\n }\n function getEntries() {\n return entries;\n }\n function clear() {\n entries = [];\n }\n return { get, put, getEntries, clear };\n}\nvar referenceEqualityCheck = (a, b) => a === b;\nfunction createCacheKeyComparator(equalityCheck) {\n return function areArgumentsShallowlyEqual(prev, next) {\n if (prev === null || next === null || prev.length !== next.length) {\n return false;\n }\n const { length } = prev;\n for (let i = 0; i < length; i++) {\n if (!equalityCheck(prev[i], next[i])) {\n return false;\n }\n }\n return true;\n };\n}\nfunction lruMemoize(func, equalityCheckOrOptions) {\n const providedOptions = typeof equalityCheckOrOptions === \"object\" ? equalityCheckOrOptions : { equalityCheck: equalityCheckOrOptions };\n const {\n equalityCheck = referenceEqualityCheck,\n maxSize = 1,\n resultEqualityCheck\n } = providedOptions;\n const comparator = createCacheKeyComparator(equalityCheck);\n let resultsCount = 0;\n const cache = maxSize === 1 ? createSingletonCache(comparator) : createLruCache(maxSize, comparator);\n function memoized() {\n let value = cache.get(arguments);\n if (value === NOT_FOUND) {\n value = func.apply(null, arguments);\n resultsCount++;\n if (resultEqualityCheck) {\n const entries = cache.getEntries();\n const matchingEntry = entries.find(\n (entry) => resultEqualityCheck(entry.value, value)\n );\n if (matchingEntry) {\n value = matchingEntry.value;\n resultsCount !== 0 && resultsCount--;\n }\n }\n cache.put(arguments, value);\n }\n return value;\n }\n memoized.clearCache = () => {\n cache.clear();\n memoized.resetResultsCount();\n };\n memoized.resultsCount = () => resultsCount;\n memoized.resetResultsCount = () => {\n resultsCount = 0;\n };\n return memoized;\n}\n\n// src/autotrackMemoize/autotrackMemoize.ts\nfunction autotrackMemoize(func) {\n const node = createNode(\n []\n );\n let lastArgs = null;\n const shallowEqual = createCacheKeyComparator(referenceEqualityCheck);\n const cache = createCache(() => {\n const res = func.apply(null, node.proxy);\n return res;\n });\n function memoized() {\n if (!shallowEqual(lastArgs, arguments)) {\n updateNode(node, arguments);\n lastArgs = arguments;\n }\n return cache.value;\n }\n memoized.clearCache = () => {\n return cache.clear();\n };\n return memoized;\n}\n\n// src/weakMapMemoize.ts\nvar StrongRef = class {\n constructor(value) {\n this.value = value;\n }\n deref() {\n return this.value;\n }\n};\nvar Ref = typeof WeakRef !== \"undefined\" ? WeakRef : StrongRef;\nvar UNTERMINATED = 0;\nvar TERMINATED = 1;\nfunction createCacheNode() {\n return {\n s: UNTERMINATED,\n v: void 0,\n o: null,\n p: null\n };\n}\nfunction weakMapMemoize(func, options = {}) {\n let fnNode = createCacheNode();\n const { resultEqualityCheck } = options;\n let lastResult;\n let resultsCount = 0;\n function memoized() {\n let cacheNode = fnNode;\n const { length } = arguments;\n for (let i = 0, l = length; i < l; i++) {\n const arg = arguments[i];\n if (typeof arg === \"function\" || typeof arg === \"object\" && arg !== null) {\n let objectCache = cacheNode.o;\n if (objectCache === null) {\n cacheNode.o = objectCache = /* @__PURE__ */ new WeakMap();\n }\n const objectNode = objectCache.get(arg);\n if (objectNode === void 0) {\n cacheNode = createCacheNode();\n objectCache.set(arg, cacheNode);\n } else {\n cacheNode = objectNode;\n }\n } else {\n let primitiveCache = cacheNode.p;\n if (primitiveCache === null) {\n cacheNode.p = primitiveCache = /* @__PURE__ */ new Map();\n }\n const primitiveNode = primitiveCache.get(arg);\n if (primitiveNode === void 0) {\n cacheNode = createCacheNode();\n primitiveCache.set(arg, cacheNode);\n } else {\n cacheNode = primitiveNode;\n }\n }\n }\n const terminatedNode = cacheNode;\n let result;\n if (cacheNode.s === TERMINATED) {\n result = cacheNode.v;\n } else {\n result = func.apply(null, arguments);\n resultsCount++;\n }\n terminatedNode.s = TERMINATED;\n if (resultEqualityCheck) {\n const lastResultValue = lastResult?.deref?.() ?? lastResult;\n if (lastResultValue != null && resultEqualityCheck(lastResultValue, result)) {\n result = lastResultValue;\n resultsCount !== 0 && resultsCount--;\n }\n const needsWeakRef = typeof result === \"object\" && result !== null || typeof result === \"function\";\n lastResult = needsWeakRef ? new Ref(result) : result;\n }\n terminatedNode.v = result;\n return result;\n }\n memoized.clearCache = () => {\n fnNode = createCacheNode();\n memoized.resetResultsCount();\n };\n memoized.resultsCount = () => resultsCount;\n memoized.resetResultsCount = () => {\n resultsCount = 0;\n };\n return memoized;\n}\n\n// src/createSelectorCreator.ts\nfunction createSelectorCreator(memoizeOrOptions, ...memoizeOptionsFromArgs) {\n const createSelectorCreatorOptions = typeof memoizeOrOptions === \"function\" ? {\n memoize: memoizeOrOptions,\n memoizeOptions: memoizeOptionsFromArgs\n } : memoizeOrOptions;\n const createSelector2 = (...createSelectorArgs) => {\n let recomputations = 0;\n let dependencyRecomputations = 0;\n let lastResult;\n let directlyPassedOptions = {};\n let resultFunc = createSelectorArgs.pop();\n if (typeof resultFunc === \"object\") {\n directlyPassedOptions = resultFunc;\n resultFunc = createSelectorArgs.pop();\n }\n assertIsFunction(\n resultFunc,\n `createSelector expects an output function after the inputs, but received: [${typeof resultFunc}]`\n );\n const combinedOptions = {\n ...createSelectorCreatorOptions,\n ...directlyPassedOptions\n };\n const {\n memoize,\n memoizeOptions = [],\n argsMemoize = weakMapMemoize,\n argsMemoizeOptions = [],\n devModeChecks = {}\n } = combinedOptions;\n const finalMemoizeOptions = ensureIsArray(memoizeOptions);\n const finalArgsMemoizeOptions = ensureIsArray(argsMemoizeOptions);\n const dependencies = getDependencies(createSelectorArgs);\n const memoizedResultFunc = memoize(function recomputationWrapper() {\n recomputations++;\n return resultFunc.apply(\n null,\n arguments\n );\n }, ...finalMemoizeOptions);\n let firstRun = true;\n const selector = argsMemoize(function dependenciesChecker() {\n dependencyRecomputations++;\n const inputSelectorResults = collectInputSelectorResults(\n dependencies,\n arguments\n );\n lastResult = memoizedResultFunc.apply(null, inputSelectorResults);\n if (process.env.NODE_ENV !== \"production\") {\n const { identityFunctionCheck, inputStabilityCheck } = getDevModeChecksExecutionInfo(firstRun, devModeChecks);\n if (identityFunctionCheck.shouldRun) {\n identityFunctionCheck.run(\n resultFunc,\n inputSelectorResults,\n lastResult\n );\n }\n if (inputStabilityCheck.shouldRun) {\n const inputSelectorResultsCopy = collectInputSelectorResults(\n dependencies,\n arguments\n );\n inputStabilityCheck.run(\n { inputSelectorResults, inputSelectorResultsCopy },\n { memoize, memoizeOptions: finalMemoizeOptions },\n arguments\n );\n }\n if (firstRun)\n firstRun = false;\n }\n return lastResult;\n }, ...finalArgsMemoizeOptions);\n return Object.assign(selector, {\n resultFunc,\n memoizedResultFunc,\n dependencies,\n dependencyRecomputations: () => dependencyRecomputations,\n resetDependencyRecomputations: () => {\n dependencyRecomputations = 0;\n },\n lastResult: () => lastResult,\n recomputations: () => recomputations,\n resetRecomputations: () => {\n recomputations = 0;\n },\n memoize,\n argsMemoize\n });\n };\n Object.assign(createSelector2, {\n withTypes: () => createSelector2\n });\n return createSelector2;\n}\nvar createSelector = /* @__PURE__ */ createSelectorCreator(weakMapMemoize);\n\n// src/createStructuredSelector.ts\nvar createStructuredSelector = Object.assign(\n (inputSelectorsObject, selectorCreator = createSelector) => {\n assertIsObject(\n inputSelectorsObject,\n `createStructuredSelector expects first argument to be an object where each property is a selector, instead received a ${typeof inputSelectorsObject}`\n );\n const inputSelectorKeys = Object.keys(inputSelectorsObject);\n const dependencies = inputSelectorKeys.map(\n (key) => inputSelectorsObject[key]\n );\n const structuredSelector = selectorCreator(\n dependencies,\n (...inputSelectorResults) => {\n return inputSelectorResults.reduce((composition, value, index) => {\n composition[inputSelectorKeys[index]] = value;\n return composition;\n }, {});\n }\n );\n return structuredSelector;\n },\n { withTypes: () => createStructuredSelector }\n);\nexport {\n createSelector,\n createSelectorCreator,\n createStructuredSelector,\n lruMemoize,\n referenceEqualityCheck,\n setGlobalDevModeChecks,\n autotrackMemoize as unstable_autotrackMemoize,\n weakMapMemoize\n};\n//# sourceMappingURL=reselect.mjs.map","// 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","// 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__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","var scriptUrl;\nif (__webpack_require__.g.importScripts) scriptUrl = __webpack_require__.g.location + \"\";\nvar document = __webpack_require__.g.document;\nif (!scriptUrl && document) {\n\tif (document.currentScript)\n\t\tscriptUrl = document.currentScript.src;\n\tif (!scriptUrl) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tif(scripts.length) {\n\t\t\tvar i = scripts.length - 1;\n\t\t\twhile (i > -1 && !scriptUrl) scriptUrl = scripts[i--].src;\n\t\t}\n\t}\n}\n// When supporting browsers where an automatic publicPath is not supported you must specify an output.publicPath manually via configuration\n// or pass an empty string (\"\") and set the __webpack_public_path__ variable from your code to use your own logic.\nif (!scriptUrl) throw new Error(\"Automatic publicPath is not supported in this browser\");\nscriptUrl = scriptUrl.replace(/#.*$/, \"\").replace(/\\?.*$/, \"\").replace(/\\/[^\\/]+$/, \"/\");\n__webpack_require__.p = scriptUrl;","import { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\n\nconst PrivacyDisclaimer = () => {\n const { t } = useI18n()\n const { showDisclaimer } = useConfig()\n\n return (\n showDisclaimer && (\n <div className={className('disclaimer')} tabIndex=\"0\">\n <h2 className={className('disclaimer__title')}>\n {t('disclaimer.title')}\n </h2>\n <div\n className={className('disclaimer__message')}\n dangerouslySetInnerHTML={{ __html: t('disclaimer.content') }}\n />\n </div>\n )\n )\n}\n\nexport default PrivacyDisclaimer\n","import { createSelector } from '@reduxjs/toolkit'\nimport type { RootState } from 'domains/store'\n\nconst getState = ({ forms }: RootState) => forms\n\nexport const getFormById = createSelector(\n [getState, (_, { formId }): string => formId],\n (forms, formId) => forms[formId],\n)\n\nconst getFormControlsByFormId = createSelector(\n getFormById,\n (form) => form?.controls || {},\n)\n\nexport const getFormValuesByFormId = createSelector(\n getFormControlsByFormId,\n (controls: { [key: string]: { value: string } }) => {\n const valuesObj = {}\n Object.entries(controls).forEach(([key, { value }]) => {\n valuesObj[key] = value\n })\n\n return valuesObj\n },\n)\n\nexport const getControlValueByName = createSelector(\n [getFormControlsByFormId, (_, { name }): string => name],\n (controls, name) => controls[name]?.value,\n)\n\nexport const getControlTouchedByName = createSelector(\n [getFormControlsByFormId, (_, { name }): string => name],\n (controls, name) => controls[name]?.touched,\n)\n","import { createContext } from 'preact'\nimport type { FormContextType } from 'domains/forms/forms.types'\n\nconst FormContext = createContext<FormContextType>({\n handleSubmit: () => undefined,\n isSubmitted: false,\n isValid: false,\n updateControlValue: () => undefined,\n updateControlTouched: () => undefined,\n errors: undefined,\n})\n\nexport default FormContext\nexport const { Provider, Consumer } = FormContext\n","import {\n useCallback,\n useContext,\n useEffect,\n useLayoutEffect,\n useMemo,\n} from 'preact/hooks'\nimport { useDispatch, useSelector } from 'react-redux'\nimport {\n getControlTouchedByName,\n getControlValueByName,\n getFormById,\n} from 'domains/forms/selectors'\nimport { deregisterControl, registerControl } from 'domains/forms/slice'\nimport FormContext from './context'\nimport { validate } from './utils'\nimport type { ControlState, FormContextType } from 'domains/forms/forms.types'\nimport type { RootState } from 'domains/store'\n\nexport function useFormContext(): FormContextType {\n return useContext(FormContext)\n}\n\nexport function useForm() {\n const { handleSubmit, isSubmitted, isValid } = useFormContext()\n\n return {\n handleSubmit,\n isSubmitted,\n isValid,\n }\n}\n\nexport function useValidations(values, validationSchema) {\n const errors = useMemo(\n () => validate(values, validationSchema),\n [values, validationSchema],\n )\n return {\n isValid: Object.keys(errors).length === 0,\n errors,\n }\n}\n\nexport function useFormControl(name): [\n {\n name: string\n onInput: (_e: any) => void\n onBlur: () => void\n value: string\n },\n ControlState,\n] {\n const dispatch = useDispatch()\n const { formId, updateControlValue, updateControlTouched, errors } =\n useFormContext()\n const form = useSelector((state: RootState) => getFormById(state, { formId }))\n const isRegistered = !!form\n const value = useSelector((state: RootState) => {\n return getControlValueByName(state, { formId, name })\n })\n\n const touched = useSelector((state: RootState) =>\n getControlTouchedByName(state, { formId, name }),\n )\n const error = errors?.[name]\n const isValid = !error\n\n useEffect(() => {\n // Make sure the form is registered\n // Since child useEffect runs before FormProvider useEffect\n if (isRegistered) {\n dispatch(registerControl({ formId, name }))\n }\n }, [isRegistered, formId, name, dispatch])\n useLayoutEffect(() => {\n return () => {\n dispatch(deregisterControl({ formId, name }))\n }\n }, [isRegistered, formId, name, dispatch])\n\n // preact uses onInput instead of onChange\n const onInput = useCallback(\n (e) => updateControlValue(name, e.target.value),\n [name, updateControlValue],\n )\n\n const onBlur = useCallback(() => {\n updateControlTouched(name, true)\n }, [updateControlTouched, name])\n\n const field = useMemo(\n () => ({\n name,\n onInput,\n onBlur,\n value,\n }),\n [name, onInput, onBlur, value],\n )\n\n const meta = useMemo(\n () => ({\n isValid,\n error,\n touched,\n }),\n [isValid, error, touched],\n )\n\n return [field, meta]\n}\n","import { useEffect, useMemo } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { maxCharacterSrDebounceDelay, maxCharacterWarningLimit } from 'config'\nimport { ControlState } from 'domains/forms/forms.types'\nimport { useFormControl } from 'domains/forms/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { clearAbortTransaction } from 'domains/store/slice'\nimport { useLiveRegion } from 'ui/hooks/live-region-hooks'\nimport {\n useEntryTextLimit,\n useSeamlyStateContext,\n} from 'ui/hooks/seamly-state-hooks'\nimport { debounce } from 'ui/utils/general-utils'\n\nexport function useCharacterLimit(controlName) {\n const { t } = useI18n()\n const { sendAssertive } = useLiveRegion()\n const { hasLimit, limit } = useEntryTextLimit()\n\n const debouncedSendAssertive = useMemo(\n () => debounce(sendAssertive, maxCharacterSrDebounceDelay),\n [sendAssertive],\n )\n const validateLimit = useMemo(() => {\n return debounce((_reachedCharacterWarning, _remainingChars) => {\n if (_reachedCharacterWarning) {\n debouncedSendAssertive(\n t('input.srCharacterLimitText', { limit: _remainingChars }),\n )\n }\n }, maxCharacterSrDebounceDelay)\n }, [debouncedSendAssertive, t])\n\n const [{ value }] = useFormControl(controlName)\n const remainingChars = hasLimit && value ? limit - value.length : limit\n const reachedCharacterWarning = hasLimit\n ? remainingChars <= maxCharacterWarningLimit\n : false\n const reachedCharacterLimit = hasLimit ? remainingChars < 0 : false\n\n useEffect(() => {\n validateLimit(reachedCharacterWarning, remainingChars)\n }, [reachedCharacterWarning, remainingChars, validateLimit])\n\n return {\n hasCharacterLimit: hasLimit,\n characterLimit: limit,\n reachedCharacterWarning,\n reachedCharacterLimit,\n remainingChars,\n }\n}\n\nexport const useEntryTextTranslation = (controlName: ControlState['name']) => {\n const { hasCharacterLimit, characterLimit } = useCharacterLimit(controlName)\n\n const {\n entryMeta: {\n optionsOverride: { text },\n },\n } = useSeamlyStateContext()\n\n const { t } = useI18n()\n\n const placeholder: string = useMemo(\n () =>\n t('input.inputPlaceholder', {\n hasLimit: hasCharacterLimit,\n text: text?.placeholder || t('input.inputPlaceholderText'),\n limit: hasCharacterLimit ? characterLimit : null,\n }),\n [t, hasCharacterLimit, characterLimit, text?.placeholder],\n )\n\n const label: string = useMemo(\n () =>\n t('input.inputLabel', {\n hasLimit: !text?.label ? hasCharacterLimit : false,\n text: text?.label || t('input.inputLabelText'),\n limit: !text?.label && hasCharacterLimit ? characterLimit : null,\n }),\n [t, hasCharacterLimit, characterLimit, text?.label],\n )\n\n const labelClass = useMemo(\n () => (text?.label ? 'label' : 'visually-hidden'),\n [text?.label],\n )\n\n return { placeholder, label, labelClass }\n}\n\nexport const useEntryAbortTransaction = () => {\n const dispatch = useDispatch()\n\n const {\n entryMeta: { actions, translatedActions },\n } = useSeamlyStateContext()\n\n const clearEntryAbortTransaction = () => {\n dispatch(clearAbortTransaction())\n }\n\n const abortTransaction =\n translatedActions?.abortTransaction || actions?.abortTransaction\n\n return {\n abortTransaction,\n clearEntryAbortTransaction,\n }\n}\n","import { className } from 'lib/css'\nimport { useSeamlyApiContext } from 'ui/hooks/seamly-api-hooks'\nimport { actionTypes } from 'ui/utils/seamly-utils'\nimport { useEntryAbortTransaction } from '../text-entry/hooks'\n\nexport default function AbortTransactionButton() {\n const { abortTransaction, clearEntryAbortTransaction } =\n useEntryAbortTransaction()\n const api = useSeamlyApiContext()\n\n if (!abortTransaction) return null\n\n const handleAbortTransaction = () => {\n api.send('action', {\n type: actionTypes.setTopic,\n body: {\n name: abortTransaction.topicName,\n fallbackMessage: abortTransaction.topicFallbackMessage,\n },\n })\n\n clearEntryAbortTransaction()\n }\n\n return (\n <li\n className={className([\n 'cvco-conversation__item',\n 'cvco-conversation__item--abort-transaction',\n ])}\n >\n <button\n className={className([\n 'button',\n 'button--secondary',\n 'abort-transaction__button',\n ])}\n type=\"button\"\n onClick={handleAbortTransaction}\n >\n {abortTransaction.label}\n </button>\n </li>\n )\n}\n","import { createContext } from 'preact'\n\nconst ComponentContext = createContext({})\n\nexport default ComponentContext\n","import { useCallback, useEffect, useMemo, useRef } from 'preact/hooks'\nimport { className } from 'lib/css'\nimport { useGeneratedId, useSeamlyCommands } from 'ui/hooks/seamly-hooks'\nimport { actionTypes, cardTypes } from 'ui/utils/seamly-utils'\n\nconst CardComponent = ({\n id,\n action,\n buttonText,\n description,\n hasFocus,\n image,\n title,\n isCarouselItem,\n}) => {\n const cardRef = useRef(null)\n const { sendMessage, sendAction, emitEvent } = useSeamlyCommands()\n const descriptionId = useGeneratedId()\n const isMounted = useRef(false)\n\n const CardActionComponent =\n action.type === cardTypes.navigate ? 'a' : 'button'\n\n const emitCardEvent = useCallback(\n () =>\n emitEvent(`action.${actionTypes.clickCard}`, {\n type: actionTypes.clickCta,\n originMessage: id,\n action,\n }),\n [emitEvent, id, action],\n )\n\n const handleClick = useCallback(() => {\n emitCardEvent()\n if (action.type === cardTypes.ask) {\n sendMessage({ body: action.ask })\n } else if (action.type === cardTypes.topic) {\n const { topic: name, fallbackMessage } = action\n sendAction({\n type: actionTypes.setTopic,\n body: { name, fallbackMessage },\n })\n }\n }, [sendMessage, action, sendAction, emitCardEvent])\n\n const actionProps = useMemo(\n () =>\n action.type === cardTypes.navigate\n ? {\n href: action.link,\n rel: 'noopener noreferrer',\n target: action.newTab ? '_blank' : '_self',\n onClick: emitCardEvent,\n }\n : {\n onClick: handleClick,\n },\n [action, handleClick, emitCardEvent],\n )\n\n useEffect(() => {\n if (isCarouselItem) {\n if (hasFocus && isMounted.current) {\n window.requestAnimationFrame(() => cardRef.current.focus())\n } else {\n cardRef.current.blur()\n }\n }\n isMounted.current = true\n }, [hasFocus, isCarouselItem])\n\n return (\n <div\n className={className('card__wrapper')}\n id={id}\n tabIndex={-1} // set tabIndex of -1 so card can be focussed\n ref={cardRef}\n >\n {image ? (\n <img className={className('card__image')} src={image} alt=\"\" />\n ) : null}\n <div className={className('card__content')} id={id}>\n {title && <h2 className={className('card__title')}>{title}</h2>}\n {description && (\n <div\n className={className('card__description')}\n dangerouslySetInnerHTML={{ __html: description }}\n />\n )}\n <CardActionComponent\n tabIndex={isCarouselItem && !hasFocus ? -1 : undefined} // disable to prevent tabbing through cards\n className={className('button', 'button--primary')}\n aria-describedby={descriptionId}\n {...actionProps}\n >\n {buttonText}\n </CardActionComponent>\n </div>\n </div>\n )\n}\n\nexport default CardComponent\n","import { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport CardComponent from 'ui/components/conversation/event/card-component'\n\nexport default function CarouselMessageSlide({\n item: slide,\n items,\n index,\n isActive,\n}) {\n const { t } = useI18n()\n return (\n <div\n className={className('carousel-item', `carousel-item--${slide.type}`)}\n role=\"group\"\n aria-roledescription=\"slide\"\n aria-label={t('carousel.slide.label', {\n index: index + 1,\n total: items.length,\n })}\n >\n <CardComponent {...slide} isCarouselItem={true} hasFocus={isActive} />\n </div>\n )\n}\n","import { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\n\nexport default function CarouselControls({\n items,\n currentIndex,\n onChange,\n children,\n}) {\n const { t } = useI18n()\n const itemCount = items.length\n const handlePrevious = () => {\n onChange((currentIndex - 1 + itemCount) % itemCount)\n }\n const handleNext = () => {\n onChange((currentIndex + 1) % itemCount)\n }\n\n return (\n <div className={className('carousel-controls')}>\n <button\n className={className('button', 'button--previous')}\n aria-label={t('carousel.controls.previous')}\n onClick={handlePrevious}\n >\n <Icon name=\"arrowLeft\" size=\"16\" alt=\"\" />\n </button>\n {children}\n <button\n className={className('button', 'button--next')}\n aria-label={t('carousel.controls.next')}\n onClick={handleNext}\n >\n <Icon name=\"arrowRight\" size=\"16\" alt=\"\" />\n </button>\n </div>\n )\n}\n","import { useCallback } from 'preact/hooks'\nimport { className } from 'lib/css'\n\nexport default function CarouselPagination({\n items,\n currentIndex,\n onChange,\n getItemKey,\n getItemLabel,\n}) {\n const itemCount = items.length\n const handlePaginate = useCallback(\n (event) => {\n const slideIndex = Number(event.target.dataset.item || '0')\n const nextIndex = Math.min(itemCount - 1, Math.max(0, slideIndex))\n if (nextIndex !== currentIndex) {\n onChange(nextIndex)\n }\n },\n [itemCount, currentIndex, onChange],\n )\n\n return (\n <div className={className('carousel-pagination__wrapper')} role=\"group\">\n <ul className={className('carousel-pagination')}>\n {items.map((item, idx) => {\n const isActive = currentIndex === idx\n return (\n <li\n key={getItemKey(item, idx, 'pagination-item-')}\n className={className(\n 'carousel-pagination__item',\n isActive ? 'is-active' : undefined,\n )}\n >\n <button\n className={className('carousel-pagination__button')}\n type=\"button\"\n onClick={handlePaginate}\n data-item={idx}\n aria-disabled={isActive ? 'true' : undefined}\n aria-label={getItemLabel(item, idx)}\n />\n </li>\n )\n })}\n </ul>\n </div>\n )\n}\n","import { createRef } from 'preact'\nimport { useEffect, useMemo, useRef, useState } from 'preact/hooks'\nimport { className } from 'lib/css'\nimport CarouselMessageSlide from 'ui/components/conversation/event/carousel-message/components/slide'\nimport { useGeneratedId } from 'ui/hooks/utility-hooks'\nimport CarouselControls from './components/controls'\nimport CarouselPagination from './components/pagination'\n\nconst defaultGetItemKey = (item, idx, prefix) => `${prefix}${idx}`\nconst defaultGetItemLabel = (item) => item.label\nconst preventScroll = ({ target }) => {\n target.scrollLeft = 0\n}\n\nexport default function CarouselComponent({\n currentIndex: originalIndex,\n onChange,\n getItemKey = defaultGetItemKey,\n getItemLabel = defaultGetItemLabel,\n items,\n}) {\n const carouselItemsId = useGeneratedId()\n const itemCount = items.length\n const [currentIndex, setCurrentIndex] = useState(Number(originalIndex || '0'))\n\n useEffect(() => {\n setCurrentIndex(Number(originalIndex || '0'))\n }, [setCurrentIndex, originalIndex])\n\n const slideRefs = useRef([])\n slideRefs.current = useMemo(() => {\n return Array(itemCount)\n .fill(1)\n .map(() => createRef())\n }, [itemCount])\n\n const isMountRef = useRef(true)\n const onChangeRef = useRef()\n onChangeRef.current = onChange\n useEffect(() => {\n if (isMountRef.current) {\n isMountRef.current = false\n return\n }\n\n if (onChangeRef.current) {\n onChangeRef.current(currentIndex)\n }\n }, [currentIndex])\n\n return (\n <div\n className={className('carousel')}\n role=\"group\"\n aria-roledescription=\"carousel\"\n >\n <div\n className={className('carousel__slides-wrapper')}\n onScroll={preventScroll}\n >\n <div\n id={carouselItemsId}\n className={className('carousel__slides')}\n style={{\n width: `${itemCount * 100}%`,\n left: `${currentIndex * -100}%`,\n }}\n aria-live=\"polite\"\n aria-atomic=\"false\"\n >\n {items.map((item, idx) => {\n const isActive = currentIndex === idx\n return (\n <div\n key={getItemKey(item, idx, 'item-')}\n ref={slideRefs.current[idx]}\n className={className(\n 'carousel__slide',\n isActive ? 'is-active' : undefined,\n )}\n aria-hidden={!isActive ? 'true' : undefined}\n >\n <CarouselMessageSlide\n item={item}\n items={items}\n currentIndex={currentIndex}\n index={idx}\n isActive={isActive}\n />\n </div>\n )\n })}\n </div>\n </div>\n <div className={className('carousel__controls')}>\n <CarouselControls\n currentIndex={currentIndex}\n items={items}\n onChange={setCurrentIndex}\n controlId={carouselItemsId}\n >\n <div className={className('carousel__pagination')}>\n <CarouselPagination\n currentIndex={currentIndex}\n items={items}\n onChange={setCurrentIndex}\n getItemKey={getItemKey}\n getItemLabel={getItemLabel}\n />\n </div>\n </CarouselControls>\n </div>\n </div>\n )\n}\n","import { useTranslatedEventData } from 'domains/translations/hooks'\nimport CarouselComponent from 'ui/components/conversation/event/carousel-component'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport CarouselMessageSlide from './components/slide'\n\nconst getItemKey = (item, idx, prefix = '') => `${prefix}${item.title}:${idx}`\nconst getItemLabel = (item) => item.title\nconst CarouselMessage = ({ event }) => {\n const { body } = useTranslatedEventData(event)\n const slides = body.cards\n\n return (\n <MessageContainer event={event} modifiers={'type-carousel'}>\n <CarouselComponent\n items={slides}\n ItemComponent={CarouselMessageSlide}\n getItemKey={getItemKey}\n getItemLabel={getItemLabel}\n />\n </MessageContainer>\n )\n}\n\nexport default CarouselMessage\n","import { useCallback, useMemo } from 'preact/hooks'\nimport { className } from '../../../lib/css'\nimport Icon from '../layout/icon'\n\nexport const mapCategoryToClass = (category) =>\n `suggestions__item--${String(category)\n .toLowerCase()\n .replace(/[^a-z0-9_\\\\-]/, '')}`\n\nconst SuggestionsItem = ({\n id,\n categories = [],\n question,\n onClick,\n hasIcon,\n}) => {\n const mappedClassNames = useMemo(() => {\n return ['suggestions__item', ...categories.map(mapCategoryToClass)]\n }, [categories])\n\n const handleClick = useCallback(() => {\n if (onClick) {\n onClick({ id, question })\n }\n }, [id, question, onClick])\n return (\n <li className={className(mappedClassNames)}>\n <button\n type=\"button\"\n onClick={handleClick}\n className={className('button', 'button--primary')}\n >\n {hasIcon && <Icon name=\"chevronRight\" size=\"8\" alt=\"\" />}\n {question}\n </button>\n </li>\n )\n}\n\nexport default SuggestionsItem\n","import { className } from '../../../lib/css'\nimport SuggestionsItem from './suggestions-item'\n\nconst SuggestionsList = ({\n className: givenClassName,\n suggestions = [],\n onClickSuggestion,\n hasIcon = true,\n}) => (\n <ul className={className('suggestions__list', givenClassName)}>\n {suggestions.map((suggestion) => (\n <SuggestionsItem\n hasIcon={hasIcon}\n key={suggestion.id}\n onClick={onClickSuggestion}\n {...suggestion}\n />\n ))}\n </ul>\n)\n\nexport default SuggestionsList\n","import { useSeamlyCommands } from 'ui/hooks/seamly-hooks'\nimport { actionTypes } from 'ui/utils/seamly-utils'\n\nconst useEventLinkClickHandler = (eventId) => {\n const { sendAction } = useSeamlyCommands()\n\n const eventClick = (e) => {\n if (e.target && e.target.dataset.linkId) {\n sendAction({\n type: actionTypes.navigate,\n originMessage: eventId,\n link: {\n id: e.target.dataset.linkId,\n url: e.target.getAttribute('href'),\n },\n })\n }\n }\n\n return eventClick\n}\n\nexport default useEventLinkClickHandler\n","import { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\n\nexport default function EventDivider({\n children,\n childrenHTML,\n className: providedClassName,\n\n graphicSrc,\n graphicType = 'icon',\n iconName,\n iconSize,\n iconClassName,\n\n dividerType,\n}) {\n const hasGraphic = Boolean(iconName || graphicSrc)\n\n const bodyProps = childrenHTML\n ? { dangerouslySetInnerHTML: { __html: childrenHTML } }\n : { children }\n\n return (\n <div\n className={className(\n 'divider',\n dividerType && `divider--type-${dividerType}`,\n providedClassName,\n )}\n >\n {hasGraphic && (\n <span className={className('divider__graphic')}>\n {iconName ? (\n <Icon\n name={iconName}\n size={iconSize}\n className={iconClassName}\n alt=\"\"\n />\n ) : (\n <img\n src={graphicSrc}\n className={className(\n {\n icon: graphicType === 'icon',\n avatar: graphicType === 'avatar',\n },\n iconClassName,\n )}\n />\n )}\n </span>\n )}\n\n <div className={className('divider__body')} {...bodyProps} />\n </div>\n )\n}\n","import { useI18n } from 'domains/i18n/hooks'\nimport EventDivider from 'ui/components/conversation/event-divider'\nimport { dividerKeys } from 'ui/utils/seamly-utils'\n\nconst dividerTypes = {\n [dividerKeys.new_topic]: 'newtopic',\n}\n\nconst Divider = ({ event }) => {\n const { t } = useI18n()\n\n const { subtype } = event.payload.body\n const dividerType = dividerTypes[dividerKeys[subtype]]\n\n return (\n <EventDivider dividerType={dividerType} iconName={dividerKeys[subtype]}>\n <p>{t(`dividerKeys.${dividerKeys[subtype]}`)}</p>\n </EventDivider>\n )\n}\n\nexport default Divider\n","import { useCallback } from 'preact/hooks'\nimport { useDispatch, useSelector } from 'react-redux'\nimport { useI18n } from 'domains/i18n/hooks'\nimport {\n disableEventsTranslation,\n enableEventsTranslation,\n} from 'domains/translations/slice'\nimport { className } from 'lib/css'\nimport EventDivider from 'ui/components/conversation/event-divider'\nimport { useEvents } from 'ui/hooks/seamly-state-hooks'\n\nconst NewTranslationDivider = ({ event }) => {\n const { t } = useI18n()\n const events = useEvents()\n const {\n body: { translationEnabled, text, title },\n id,\n } = event.payload\n const translatedEventGroups = useSelector(\n (state) => state.translations.translatedEventGroups,\n )\n\n const dispatch = useDispatch()\n const toggleTranslations = useCallback(() => {\n if (!translatedEventGroups[id]) {\n dispatch(disableEventsTranslation({ events, id }))\n return\n }\n\n dispatch(enableEventsTranslation({ events, id }))\n }, [dispatch, events, id, translatedEventGroups])\n\n return (\n <EventDivider iconName=\"newTranslation\" dividerType=\"newtranslation\">\n <p className={className('divider__title')}>{title}</p>\n {text && <p>{text}</p>}\n {translationEnabled ? (\n <>\n <button\n className={className('button', 'button--secondary')}\n onClick={toggleTranslations}\n >\n {t(\n !translatedEventGroups[id]\n ? 'translations.toggle.hideTranslationsButtonText'\n : 'translations.toggle.showTranslationsButtonText',\n )}\n </button>\n </>\n ) : null}\n </EventDivider>\n )\n}\n\nexport default NewTranslationDivider\n","import { dividerKeys } from 'ui/utils/seamly-utils'\nimport DefaultDivider from './variants/default'\nimport NewTranslationDivider from './variants/new-translation'\n\nconst Variants = {\n default: DefaultDivider,\n [dividerKeys.new_translation]: NewTranslationDivider,\n}\n\nconst Divider = ({ event, ...props }) => {\n const Component =\n Variants[dividerKeys[event.payload.body.subtype]] || Variants.default\n return <Component event={event} {...props} />\n}\n\nexport default Divider\n","import { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { getRelativeDate } from 'ui/utils/general-utils'\n\nconst dateFormatOptions = { month: 'long', day: 'numeric', year: 'numeric' }\nconst timeFormatOptions = { hour: 'numeric', minute: 'numeric' }\n\nexport const useFormattedDate = (date) => {\n const { t } = useI18n()\n const config = useConfig()\n const locale = config?.context?.locale ?? []\n const eventDate = new Date(date)\n const currentDate = new Date()\n const midnight = new Date(currentDate)\n midnight.setHours(24, 0, 0, 0)\n const timeUntilMidnight = midnight - currentDate\n const fullDateTime = eventDate.toString()\n const time = new Intl.DateTimeFormat(locale, timeFormatOptions).format(\n eventDate,\n )\n\n let relativeDate = getRelativeDate(eventDate, currentDate)\n switch (relativeDate) {\n case 'today':\n relativeDate = t('dateTime.today')\n break\n case 'yesterday':\n relativeDate = t('dateTime.yesterday')\n break\n default:\n relativeDate = new Intl.DateTimeFormat(locale, dateFormatOptions).format(\n eventDate,\n )\n }\n\n const srText = t('dateTime.srText', { date: relativeDate, time })\n\n return {\n date: relativeDate,\n srText,\n time,\n fullDateTime,\n timeUntilMidnight,\n }\n}\n","import { useEffect } from 'preact/hooks'\nimport { className } from 'lib/css'\nimport { useFormattedDate } from 'ui/components/conversation/event/hooks/use-formatted-date'\nimport EventDivider from 'ui/components/conversation/event-divider'\nimport { useForceUpdate } from 'ui/hooks/utility-hooks'\nimport { microsecondsToMilliseconds } from 'ui/utils/general-utils'\n\nconst TimeIndicator = ({ event }) => {\n const forceUpdate = useForceUpdate()\n const { date, time, timeUntilMidnight, srText } = useFormattedDate(\n microsecondsToMilliseconds(event.timeIndicator),\n )\n\n // At midnight, force a re-render so \"Today\" can become \"Yesterday\"\n useEffect(() => {\n const timeout = setTimeout(() => {\n forceUpdate()\n }, timeUntilMidnight)\n\n return () => {\n clearTimeout(timeout)\n }\n }, [forceUpdate, timeUntilMidnight])\n\n return (\n <EventDivider dividerType=\"time-indicator\">\n <p className={className('divider__time')} aria-hidden=\"true\">\n <span>{date}</span>\n <span>{time}</span>\n </p>\n <p className={className('visually-hidden')}>{srText}</p>\n </EventDivider>\n )\n}\n\nexport default TimeIndicator\n","/*!\n* tabbable 6.2.0\n* @license MIT, https://github.com/focus-trap/tabbable/blob/master/LICENSE\n*/\n// NOTE: separate `:not()` selectors has broader browser support than the newer\n// `:not([inert], [inert] *)` (Feb 2023)\n// CAREFUL: JSDom does not support `:not([inert] *)` as a selector; using it causes\n// the entire query to fail, resulting in no nodes found, which will break a lot\n// of things... so we have to rely on JS to identify nodes inside an inert container\nvar candidateSelectors = ['input:not([inert])', 'select:not([inert])', 'textarea:not([inert])', 'a[href]:not([inert])', 'button:not([inert])', '[tabindex]:not(slot):not([inert])', 'audio[controls]:not([inert])', 'video[controls]:not([inert])', '[contenteditable]:not([contenteditable=\"false\"]):not([inert])', 'details>summary:first-of-type:not([inert])', 'details:not([inert])'];\nvar candidateSelector = /* #__PURE__ */candidateSelectors.join(',');\nvar NoElement = typeof Element === 'undefined';\nvar matches = NoElement ? function () {} : Element.prototype.matches || Element.prototype.msMatchesSelector || Element.prototype.webkitMatchesSelector;\nvar getRootNode = !NoElement && Element.prototype.getRootNode ? function (element) {\n var _element$getRootNode;\n return element === null || element === void 0 ? void 0 : (_element$getRootNode = element.getRootNode) === null || _element$getRootNode === void 0 ? void 0 : _element$getRootNode.call(element);\n} : function (element) {\n return element === null || element === void 0 ? void 0 : element.ownerDocument;\n};\n\n/**\n * Determines if a node is inert or in an inert ancestor.\n * @param {Element} [node]\n * @param {boolean} [lookUp] If true and `node` is not inert, looks up at ancestors to\n * see if any of them are inert. If false, only `node` itself is considered.\n * @returns {boolean} True if inert itself or by way of being in an inert ancestor.\n * False if `node` is falsy.\n */\nvar isInert = function isInert(node, lookUp) {\n var _node$getAttribute;\n if (lookUp === void 0) {\n lookUp = true;\n }\n // CAREFUL: JSDom does not support inert at all, so we can't use the `HTMLElement.inert`\n // JS API property; we have to check the attribute, which can either be empty or 'true';\n // if it's `null` (not specified) or 'false', it's an active element\n var inertAtt = node === null || node === void 0 ? void 0 : (_node$getAttribute = node.getAttribute) === null || _node$getAttribute === void 0 ? void 0 : _node$getAttribute.call(node, 'inert');\n var inert = inertAtt === '' || inertAtt === 'true';\n\n // NOTE: this could also be handled with `node.matches('[inert], :is([inert] *)')`\n // if it weren't for `matches()` not being a function on shadow roots; the following\n // code works for any kind of node\n // CAREFUL: JSDom does not appear to support certain selectors like `:not([inert] *)`\n // so it likely would not support `:is([inert] *)` either...\n var result = inert || lookUp && node && isInert(node.parentNode); // recursive\n\n return result;\n};\n\n/**\n * Determines if a node's content is editable.\n * @param {Element} [node]\n * @returns True if it's content-editable; false if it's not or `node` is falsy.\n */\nvar isContentEditable = function isContentEditable(node) {\n var _node$getAttribute2;\n // CAREFUL: JSDom does not support the `HTMLElement.isContentEditable` API so we have\n // to use the attribute directly to check for this, which can either be empty or 'true';\n // if it's `null` (not specified) or 'false', it's a non-editable element\n var attValue = node === null || node === void 0 ? void 0 : (_node$getAttribute2 = node.getAttribute) === null || _node$getAttribute2 === void 0 ? void 0 : _node$getAttribute2.call(node, 'contenteditable');\n return attValue === '' || attValue === 'true';\n};\n\n/**\n * @param {Element} el container to check in\n * @param {boolean} includeContainer add container to check\n * @param {(node: Element) => boolean} filter filter candidates\n * @returns {Element[]}\n */\nvar getCandidates = function getCandidates(el, includeContainer, filter) {\n // even if `includeContainer=false`, we still have to check it for inertness because\n // if it's inert, all its children are inert\n if (isInert(el)) {\n return [];\n }\n var candidates = Array.prototype.slice.apply(el.querySelectorAll(candidateSelector));\n if (includeContainer && matches.call(el, candidateSelector)) {\n candidates.unshift(el);\n }\n candidates = candidates.filter(filter);\n return candidates;\n};\n\n/**\n * @callback GetShadowRoot\n * @param {Element} element to check for shadow root\n * @returns {ShadowRoot|boolean} ShadowRoot if available or boolean indicating if a shadowRoot is attached but not available.\n */\n\n/**\n * @callback ShadowRootFilter\n * @param {Element} shadowHostNode the element which contains shadow content\n * @returns {boolean} true if a shadow root could potentially contain valid candidates.\n */\n\n/**\n * @typedef {Object} CandidateScope\n * @property {Element} scopeParent contains inner candidates\n * @property {Element[]} candidates list of candidates found in the scope parent\n */\n\n/**\n * @typedef {Object} IterativeOptions\n * @property {GetShadowRoot|boolean} getShadowRoot true if shadow support is enabled; falsy if not;\n * if a function, implies shadow support is enabled and either returns the shadow root of an element\n * or a boolean stating if it has an undisclosed shadow root\n * @property {(node: Element) => boolean} filter filter candidates\n * @property {boolean} flatten if true then result will flatten any CandidateScope into the returned list\n * @property {ShadowRootFilter} shadowRootFilter filter shadow roots;\n */\n\n/**\n * @param {Element[]} elements list of element containers to match candidates from\n * @param {boolean} includeContainer add container list to check\n * @param {IterativeOptions} options\n * @returns {Array.<Element|CandidateScope>}\n */\nvar getCandidatesIteratively = function getCandidatesIteratively(elements, includeContainer, options) {\n var candidates = [];\n var elementsToCheck = Array.from(elements);\n while (elementsToCheck.length) {\n var element = elementsToCheck.shift();\n if (isInert(element, false)) {\n // no need to look up since we're drilling down\n // anything inside this container will also be inert\n continue;\n }\n if (element.tagName === 'SLOT') {\n // add shadow dom slot scope (slot itself cannot be focusable)\n var assigned = element.assignedElements();\n var content = assigned.length ? assigned : element.children;\n var nestedCandidates = getCandidatesIteratively(content, true, options);\n if (options.flatten) {\n candidates.push.apply(candidates, nestedCandidates);\n } else {\n candidates.push({\n scopeParent: element,\n candidates: nestedCandidates\n });\n }\n } else {\n // check candidate element\n var validCandidate = matches.call(element, candidateSelector);\n if (validCandidate && options.filter(element) && (includeContainer || !elements.includes(element))) {\n candidates.push(element);\n }\n\n // iterate over shadow content if possible\n var shadowRoot = element.shadowRoot ||\n // check for an undisclosed shadow\n typeof options.getShadowRoot === 'function' && options.getShadowRoot(element);\n\n // no inert look up because we're already drilling down and checking for inertness\n // on the way down, so all containers to this root node should have already been\n // vetted as non-inert\n var validShadowRoot = !isInert(shadowRoot, false) && (!options.shadowRootFilter || options.shadowRootFilter(element));\n if (shadowRoot && validShadowRoot) {\n // add shadow dom scope IIF a shadow root node was given; otherwise, an undisclosed\n // shadow exists, so look at light dom children as fallback BUT create a scope for any\n // child candidates found because they're likely slotted elements (elements that are\n // children of the web component element (which has the shadow), in the light dom, but\n // slotted somewhere _inside_ the undisclosed shadow) -- the scope is created below,\n // _after_ we return from this recursive call\n var _nestedCandidates = getCandidatesIteratively(shadowRoot === true ? element.children : shadowRoot.children, true, options);\n if (options.flatten) {\n candidates.push.apply(candidates, _nestedCandidates);\n } else {\n candidates.push({\n scopeParent: element,\n candidates: _nestedCandidates\n });\n }\n } else {\n // there's not shadow so just dig into the element's (light dom) children\n // __without__ giving the element special scope treatment\n elementsToCheck.unshift.apply(elementsToCheck, element.children);\n }\n }\n }\n return candidates;\n};\n\n/**\n * @private\n * Determines if the node has an explicitly specified `tabindex` attribute.\n * @param {HTMLElement} node\n * @returns {boolean} True if so; false if not.\n */\nvar hasTabIndex = function hasTabIndex(node) {\n return !isNaN(parseInt(node.getAttribute('tabindex'), 10));\n};\n\n/**\n * Determine the tab index of a given node.\n * @param {HTMLElement} node\n * @returns {number} Tab order (negative, 0, or positive number).\n * @throws {Error} If `node` is falsy.\n */\nvar getTabIndex = function getTabIndex(node) {\n if (!node) {\n throw new Error('No node provided');\n }\n if (node.tabIndex < 0) {\n // in Chrome, <details/>, <audio controls/> and <video controls/> elements get a default\n // `tabIndex` of -1 when the 'tabindex' attribute isn't specified in the DOM,\n // yet they are still part of the regular tab order; in FF, they get a default\n // `tabIndex` of 0; since Chrome still puts those elements in the regular tab\n // order, consider their tab index to be 0.\n // Also browsers do not return `tabIndex` correctly for contentEditable nodes;\n // so if they don't have a tabindex attribute specifically set, assume it's 0.\n if ((/^(AUDIO|VIDEO|DETAILS)$/.test(node.tagName) || isContentEditable(node)) && !hasTabIndex(node)) {\n return 0;\n }\n }\n return node.tabIndex;\n};\n\n/**\n * Determine the tab index of a given node __for sort order purposes__.\n * @param {HTMLElement} node\n * @param {boolean} [isScope] True for a custom element with shadow root or slot that, by default,\n * has tabIndex -1, but needs to be sorted by document order in order for its content to be\n * inserted into the correct sort position.\n * @returns {number} Tab order (negative, 0, or positive number).\n */\nvar getSortOrderTabIndex = function getSortOrderTabIndex(node, isScope) {\n var tabIndex = getTabIndex(node);\n if (tabIndex < 0 && isScope && !hasTabIndex(node)) {\n return 0;\n }\n return tabIndex;\n};\nvar sortOrderedTabbables = function sortOrderedTabbables(a, b) {\n return a.tabIndex === b.tabIndex ? a.documentOrder - b.documentOrder : a.tabIndex - b.tabIndex;\n};\nvar isInput = function isInput(node) {\n return node.tagName === 'INPUT';\n};\nvar isHiddenInput = function isHiddenInput(node) {\n return isInput(node) && node.type === 'hidden';\n};\nvar isDetailsWithSummary = function isDetailsWithSummary(node) {\n var r = node.tagName === 'DETAILS' && Array.prototype.slice.apply(node.children).some(function (child) {\n return child.tagName === 'SUMMARY';\n });\n return r;\n};\nvar getCheckedRadio = function getCheckedRadio(nodes, form) {\n for (var i = 0; i < nodes.length; i++) {\n if (nodes[i].checked && nodes[i].form === form) {\n return nodes[i];\n }\n }\n};\nvar isTabbableRadio = function isTabbableRadio(node) {\n if (!node.name) {\n return true;\n }\n var radioScope = node.form || getRootNode(node);\n var queryRadios = function queryRadios(name) {\n return radioScope.querySelectorAll('input[type=\"radio\"][name=\"' + name + '\"]');\n };\n var radioSet;\n if (typeof window !== 'undefined' && typeof window.CSS !== 'undefined' && typeof window.CSS.escape === 'function') {\n radioSet = queryRadios(window.CSS.escape(node.name));\n } else {\n try {\n radioSet = queryRadios(node.name);\n } catch (err) {\n // eslint-disable-next-line no-console\n console.error('Looks like you have a radio button with a name attribute containing invalid CSS selector characters and need the CSS.escape polyfill: %s', err.message);\n return false;\n }\n }\n var checked = getCheckedRadio(radioSet, node.form);\n return !checked || checked === node;\n};\nvar isRadio = function isRadio(node) {\n return isInput(node) && node.type === 'radio';\n};\nvar isNonTabbableRadio = function isNonTabbableRadio(node) {\n return isRadio(node) && !isTabbableRadio(node);\n};\n\n// determines if a node is ultimately attached to the window's document\nvar isNodeAttached = function isNodeAttached(node) {\n var _nodeRoot;\n // The root node is the shadow root if the node is in a shadow DOM; some document otherwise\n // (but NOT _the_ document; see second 'If' comment below for more).\n // If rootNode is shadow root, it'll have a host, which is the element to which the shadow\n // is attached, and the one we need to check if it's in the document or not (because the\n // shadow, and all nodes it contains, is never considered in the document since shadows\n // behave like self-contained DOMs; but if the shadow's HOST, which is part of the document,\n // is hidden, or is not in the document itself but is detached, it will affect the shadow's\n // visibility, including all the nodes it contains). The host could be any normal node,\n // or a custom element (i.e. web component). Either way, that's the one that is considered\n // part of the document, not the shadow root, nor any of its children (i.e. the node being\n // tested).\n // To further complicate things, we have to look all the way up until we find a shadow HOST\n // that is attached (or find none) because the node might be in nested shadows...\n // If rootNode is not a shadow root, it won't have a host, and so rootNode should be the\n // document (per the docs) and while it's a Document-type object, that document does not\n // appear to be the same as the node's `ownerDocument` for some reason, so it's safer\n // to ignore the rootNode at this point, and use `node.ownerDocument`. Otherwise,\n // using `rootNode.contains(node)` will _always_ be true we'll get false-positives when\n // node is actually detached.\n // NOTE: If `nodeRootHost` or `node` happens to be the `document` itself (which is possible\n // if a tabbable/focusable node was quickly added to the DOM, focused, and then removed\n // from the DOM as in https://github.com/focus-trap/focus-trap-react/issues/905), then\n // `ownerDocument` will be `null`, hence the optional chaining on it.\n var nodeRoot = node && getRootNode(node);\n var nodeRootHost = (_nodeRoot = nodeRoot) === null || _nodeRoot === void 0 ? void 0 : _nodeRoot.host;\n\n // in some cases, a detached node will return itself as the root instead of a document or\n // shadow root object, in which case, we shouldn't try to look further up the host chain\n var attached = false;\n if (nodeRoot && nodeRoot !== node) {\n var _nodeRootHost, _nodeRootHost$ownerDo, _node$ownerDocument;\n attached = !!((_nodeRootHost = nodeRootHost) !== null && _nodeRootHost !== void 0 && (_nodeRootHost$ownerDo = _nodeRootHost.ownerDocument) !== null && _nodeRootHost$ownerDo !== void 0 && _nodeRootHost$ownerDo.contains(nodeRootHost) || node !== null && node !== void 0 && (_node$ownerDocument = node.ownerDocument) !== null && _node$ownerDocument !== void 0 && _node$ownerDocument.contains(node));\n while (!attached && nodeRootHost) {\n var _nodeRoot2, _nodeRootHost2, _nodeRootHost2$ownerD;\n // since it's not attached and we have a root host, the node MUST be in a nested shadow DOM,\n // which means we need to get the host's host and check if that parent host is contained\n // in (i.e. attached to) the document\n nodeRoot = getRootNode(nodeRootHost);\n nodeRootHost = (_nodeRoot2 = nodeRoot) === null || _nodeRoot2 === void 0 ? void 0 : _nodeRoot2.host;\n attached = !!((_nodeRootHost2 = nodeRootHost) !== null && _nodeRootHost2 !== void 0 && (_nodeRootHost2$ownerD = _nodeRootHost2.ownerDocument) !== null && _nodeRootHost2$ownerD !== void 0 && _nodeRootHost2$ownerD.contains(nodeRootHost));\n }\n }\n return attached;\n};\nvar isZeroArea = function isZeroArea(node) {\n var _node$getBoundingClie = node.getBoundingClientRect(),\n width = _node$getBoundingClie.width,\n height = _node$getBoundingClie.height;\n return width === 0 && height === 0;\n};\nvar isHidden = function isHidden(node, _ref) {\n var displayCheck = _ref.displayCheck,\n getShadowRoot = _ref.getShadowRoot;\n // NOTE: visibility will be `undefined` if node is detached from the document\n // (see notes about this further down), which means we will consider it visible\n // (this is legacy behavior from a very long way back)\n // NOTE: we check this regardless of `displayCheck=\"none\"` because this is a\n // _visibility_ check, not a _display_ check\n if (getComputedStyle(node).visibility === 'hidden') {\n return true;\n }\n var isDirectSummary = matches.call(node, 'details>summary:first-of-type');\n var nodeUnderDetails = isDirectSummary ? node.parentElement : node;\n if (matches.call(nodeUnderDetails, 'details:not([open]) *')) {\n return true;\n }\n if (!displayCheck || displayCheck === 'full' || displayCheck === 'legacy-full') {\n if (typeof getShadowRoot === 'function') {\n // figure out if we should consider the node to be in an undisclosed shadow and use the\n // 'non-zero-area' fallback\n var originalNode = node;\n while (node) {\n var parentElement = node.parentElement;\n var rootNode = getRootNode(node);\n if (parentElement && !parentElement.shadowRoot && getShadowRoot(parentElement) === true // check if there's an undisclosed shadow\n ) {\n // node has an undisclosed shadow which means we can only treat it as a black box, so we\n // fall back to a non-zero-area test\n return isZeroArea(node);\n } else if (node.assignedSlot) {\n // iterate up slot\n node = node.assignedSlot;\n } else if (!parentElement && rootNode !== node.ownerDocument) {\n // cross shadow boundary\n node = rootNode.host;\n } else {\n // iterate up normal dom\n node = parentElement;\n }\n }\n node = originalNode;\n }\n // else, `getShadowRoot` might be true, but all that does is enable shadow DOM support\n // (i.e. it does not also presume that all nodes might have undisclosed shadows); or\n // it might be a falsy value, which means shadow DOM support is disabled\n\n // Since we didn't find it sitting in an undisclosed shadow (or shadows are disabled)\n // now we can just test to see if it would normally be visible or not, provided it's\n // attached to the main document.\n // NOTE: We must consider case where node is inside a shadow DOM and given directly to\n // `isTabbable()` or `isFocusable()` -- regardless of `getShadowRoot` option setting.\n\n if (isNodeAttached(node)) {\n // this works wherever the node is: if there's at least one client rect, it's\n // somehow displayed; it also covers the CSS 'display: contents' case where the\n // node itself is hidden in place of its contents; and there's no need to search\n // up the hierarchy either\n return !node.getClientRects().length;\n }\n\n // Else, the node isn't attached to the document, which means the `getClientRects()`\n // API will __always__ return zero rects (this can happen, for example, if React\n // is used to render nodes onto a detached tree, as confirmed in this thread:\n // https://github.com/facebook/react/issues/9117#issuecomment-284228870)\n //\n // It also means that even window.getComputedStyle(node).display will return `undefined`\n // because styles are only computed for nodes that are in the document.\n //\n // NOTE: THIS HAS BEEN THE CASE FOR YEARS. It is not new, nor is it caused by tabbable\n // somehow. Though it was never stated officially, anyone who has ever used tabbable\n // APIs on nodes in detached containers has actually implicitly used tabbable in what\n // was later (as of v5.2.0 on Apr 9, 2021) called `displayCheck=\"none\"` mode -- essentially\n // considering __everything__ to be visible because of the innability to determine styles.\n //\n // v6.0.0: As of this major release, the default 'full' option __no longer treats detached\n // nodes as visible with the 'none' fallback.__\n if (displayCheck !== 'legacy-full') {\n return true; // hidden\n }\n // else, fallback to 'none' mode and consider the node visible\n } else if (displayCheck === 'non-zero-area') {\n // NOTE: Even though this tests that the node's client rect is non-zero to determine\n // whether it's displayed, and that a detached node will __always__ have a zero-area\n // client rect, we don't special-case for whether the node is attached or not. In\n // this mode, we do want to consider nodes that have a zero area to be hidden at all\n // times, and that includes attached or not.\n return isZeroArea(node);\n }\n\n // visible, as far as we can tell, or per current `displayCheck=none` mode, we assume\n // it's visible\n return false;\n};\n\n// form fields (nested) inside a disabled fieldset are not focusable/tabbable\n// unless they are in the _first_ <legend> element of the top-most disabled\n// fieldset\nvar isDisabledFromFieldset = function isDisabledFromFieldset(node) {\n if (/^(INPUT|BUTTON|SELECT|TEXTAREA)$/.test(node.tagName)) {\n var parentNode = node.parentElement;\n // check if `node` is contained in a disabled <fieldset>\n while (parentNode) {\n if (parentNode.tagName === 'FIELDSET' && parentNode.disabled) {\n // look for the first <legend> among the children of the disabled <fieldset>\n for (var i = 0; i < parentNode.children.length; i++) {\n var child = parentNode.children.item(i);\n // when the first <legend> (in document order) is found\n if (child.tagName === 'LEGEND') {\n // if its parent <fieldset> is not nested in another disabled <fieldset>,\n // return whether `node` is a descendant of its first <legend>\n return matches.call(parentNode, 'fieldset[disabled] *') ? true : !child.contains(node);\n }\n }\n // the disabled <fieldset> containing `node` has no <legend>\n return true;\n }\n parentNode = parentNode.parentElement;\n }\n }\n\n // else, node's tabbable/focusable state should not be affected by a fieldset's\n // enabled/disabled state\n return false;\n};\nvar isNodeMatchingSelectorFocusable = function isNodeMatchingSelectorFocusable(options, node) {\n if (node.disabled ||\n // we must do an inert look up to filter out any elements inside an inert ancestor\n // because we're limited in the type of selectors we can use in JSDom (see related\n // note related to `candidateSelectors`)\n isInert(node) || isHiddenInput(node) || isHidden(node, options) ||\n // For a details element with a summary, the summary element gets the focus\n isDetailsWithSummary(node) || isDisabledFromFieldset(node)) {\n return false;\n }\n return true;\n};\nvar isNodeMatchingSelectorTabbable = function isNodeMatchingSelectorTabbable(options, node) {\n if (isNonTabbableRadio(node) || getTabIndex(node) < 0 || !isNodeMatchingSelectorFocusable(options, node)) {\n return false;\n }\n return true;\n};\nvar isValidShadowRootTabbable = function isValidShadowRootTabbable(shadowHostNode) {\n var tabIndex = parseInt(shadowHostNode.getAttribute('tabindex'), 10);\n if (isNaN(tabIndex) || tabIndex >= 0) {\n return true;\n }\n // If a custom element has an explicit negative tabindex,\n // browsers will not allow tab targeting said element's children.\n return false;\n};\n\n/**\n * @param {Array.<Element|CandidateScope>} candidates\n * @returns Element[]\n */\nvar sortByOrder = function sortByOrder(candidates) {\n var regularTabbables = [];\n var orderedTabbables = [];\n candidates.forEach(function (item, i) {\n var isScope = !!item.scopeParent;\n var element = isScope ? item.scopeParent : item;\n var candidateTabindex = getSortOrderTabIndex(element, isScope);\n var elements = isScope ? sortByOrder(item.candidates) : element;\n if (candidateTabindex === 0) {\n isScope ? regularTabbables.push.apply(regularTabbables, elements) : regularTabbables.push(element);\n } else {\n orderedTabbables.push({\n documentOrder: i,\n tabIndex: candidateTabindex,\n item: item,\n isScope: isScope,\n content: elements\n });\n }\n });\n return orderedTabbables.sort(sortOrderedTabbables).reduce(function (acc, sortable) {\n sortable.isScope ? acc.push.apply(acc, sortable.content) : acc.push(sortable.content);\n return acc;\n }, []).concat(regularTabbables);\n};\nvar tabbable = function tabbable(container, options) {\n options = options || {};\n var candidates;\n if (options.getShadowRoot) {\n candidates = getCandidatesIteratively([container], options.includeContainer, {\n filter: isNodeMatchingSelectorTabbable.bind(null, options),\n flatten: false,\n getShadowRoot: options.getShadowRoot,\n shadowRootFilter: isValidShadowRootTabbable\n });\n } else {\n candidates = getCandidates(container, options.includeContainer, isNodeMatchingSelectorTabbable.bind(null, options));\n }\n return sortByOrder(candidates);\n};\nvar focusable = function focusable(container, options) {\n options = options || {};\n var candidates;\n if (options.getShadowRoot) {\n candidates = getCandidatesIteratively([container], options.includeContainer, {\n filter: isNodeMatchingSelectorFocusable.bind(null, options),\n flatten: true,\n getShadowRoot: options.getShadowRoot\n });\n } else {\n candidates = getCandidates(container, options.includeContainer, isNodeMatchingSelectorFocusable.bind(null, options));\n }\n return candidates;\n};\nvar isTabbable = function isTabbable(node, options) {\n options = options || {};\n if (!node) {\n throw new Error('No node provided');\n }\n if (matches.call(node, candidateSelector) === false) {\n return false;\n }\n return isNodeMatchingSelectorTabbable(options, node);\n};\nvar focusableCandidateSelector = /* #__PURE__ */candidateSelectors.concat('iframe').join(',');\nvar isFocusable = function isFocusable(node, options) {\n options = options || {};\n if (!node) {\n throw new Error('No node provided');\n }\n if (matches.call(node, focusableCandidateSelector) === false) {\n return false;\n }\n return isNodeMatchingSelectorFocusable(options, node);\n};\n\nexport { focusable, getTabIndex, isFocusable, isTabbable, tabbable };\n//# sourceMappingURL=index.esm.js.map\n","/*!\n* focus-trap 7.5.4\n* @license MIT, https://github.com/focus-trap/focus-trap/blob/master/LICENSE\n*/\nimport { isFocusable, tabbable, focusable, isTabbable, getTabIndex } from 'tabbable';\n\nfunction ownKeys(e, r) {\n var t = Object.keys(e);\n if (Object.getOwnPropertySymbols) {\n var o = Object.getOwnPropertySymbols(e);\n r && (o = o.filter(function (r) {\n return Object.getOwnPropertyDescriptor(e, r).enumerable;\n })), t.push.apply(t, o);\n }\n return t;\n}\nfunction _objectSpread2(e) {\n for (var r = 1; r < arguments.length; r++) {\n var t = null != arguments[r] ? arguments[r] : {};\n r % 2 ? ownKeys(Object(t), !0).forEach(function (r) {\n _defineProperty(e, r, t[r]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) {\n Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r));\n });\n }\n return e;\n}\nfunction _defineProperty(obj, key, value) {\n key = _toPropertyKey(key);\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nfunction _toPrimitive(input, hint) {\n if (typeof input !== \"object\" || input === null) return input;\n var prim = input[Symbol.toPrimitive];\n if (prim !== undefined) {\n var res = prim.call(input, hint || \"default\");\n if (typeof res !== \"object\") return res;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (hint === \"string\" ? String : Number)(input);\n}\nfunction _toPropertyKey(arg) {\n var key = _toPrimitive(arg, \"string\");\n return typeof key === \"symbol\" ? key : String(key);\n}\n\nvar activeFocusTraps = {\n activateTrap: function activateTrap(trapStack, trap) {\n if (trapStack.length > 0) {\n var activeTrap = trapStack[trapStack.length - 1];\n if (activeTrap !== trap) {\n activeTrap.pause();\n }\n }\n var trapIndex = trapStack.indexOf(trap);\n if (trapIndex === -1) {\n trapStack.push(trap);\n } else {\n // move this existing trap to the front of the queue\n trapStack.splice(trapIndex, 1);\n trapStack.push(trap);\n }\n },\n deactivateTrap: function deactivateTrap(trapStack, trap) {\n var trapIndex = trapStack.indexOf(trap);\n if (trapIndex !== -1) {\n trapStack.splice(trapIndex, 1);\n }\n if (trapStack.length > 0) {\n trapStack[trapStack.length - 1].unpause();\n }\n }\n};\nvar isSelectableInput = function isSelectableInput(node) {\n return node.tagName && node.tagName.toLowerCase() === 'input' && typeof node.select === 'function';\n};\nvar isEscapeEvent = function isEscapeEvent(e) {\n return (e === null || e === void 0 ? void 0 : e.key) === 'Escape' || (e === null || e === void 0 ? void 0 : e.key) === 'Esc' || (e === null || e === void 0 ? void 0 : e.keyCode) === 27;\n};\nvar isTabEvent = function isTabEvent(e) {\n return (e === null || e === void 0 ? void 0 : e.key) === 'Tab' || (e === null || e === void 0 ? void 0 : e.keyCode) === 9;\n};\n\n// checks for TAB by default\nvar isKeyForward = function isKeyForward(e) {\n return isTabEvent(e) && !e.shiftKey;\n};\n\n// checks for SHIFT+TAB by default\nvar isKeyBackward = function isKeyBackward(e) {\n return isTabEvent(e) && e.shiftKey;\n};\nvar delay = function delay(fn) {\n return setTimeout(fn, 0);\n};\n\n// Array.find/findIndex() are not supported on IE; this replicates enough\n// of Array.findIndex() for our needs\nvar findIndex = function findIndex(arr, fn) {\n var idx = -1;\n arr.every(function (value, i) {\n if (fn(value)) {\n idx = i;\n return false; // break\n }\n\n return true; // next\n });\n\n return idx;\n};\n\n/**\n * Get an option's value when it could be a plain value, or a handler that provides\n * the value.\n * @param {*} value Option's value to check.\n * @param {...*} [params] Any parameters to pass to the handler, if `value` is a function.\n * @returns {*} The `value`, or the handler's returned value.\n */\nvar valueOrHandler = function valueOrHandler(value) {\n for (var _len = arguments.length, params = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n params[_key - 1] = arguments[_key];\n }\n return typeof value === 'function' ? value.apply(void 0, params) : value;\n};\nvar getActualTarget = function getActualTarget(event) {\n // NOTE: If the trap is _inside_ a shadow DOM, event.target will always be the\n // shadow host. However, event.target.composedPath() will be an array of\n // nodes \"clicked\" from inner-most (the actual element inside the shadow) to\n // outer-most (the host HTML document). If we have access to composedPath(),\n // then use its first element; otherwise, fall back to event.target (and\n // this only works for an _open_ shadow DOM; otherwise,\n // composedPath()[0] === event.target always).\n return event.target.shadowRoot && typeof event.composedPath === 'function' ? event.composedPath()[0] : event.target;\n};\n\n// NOTE: this must be _outside_ `createFocusTrap()` to make sure all traps in this\n// current instance use the same stack if `userOptions.trapStack` isn't specified\nvar internalTrapStack = [];\nvar createFocusTrap = function createFocusTrap(elements, userOptions) {\n // SSR: a live trap shouldn't be created in this type of environment so this\n // should be safe code to execute if the `document` option isn't specified\n var doc = (userOptions === null || userOptions === void 0 ? void 0 : userOptions.document) || document;\n var trapStack = (userOptions === null || userOptions === void 0 ? void 0 : userOptions.trapStack) || internalTrapStack;\n var config = _objectSpread2({\n returnFocusOnDeactivate: true,\n escapeDeactivates: true,\n delayInitialFocus: true,\n isKeyForward: isKeyForward,\n isKeyBackward: isKeyBackward\n }, userOptions);\n var state = {\n // containers given to createFocusTrap()\n // @type {Array<HTMLElement>}\n containers: [],\n // list of objects identifying tabbable nodes in `containers` in the trap\n // NOTE: it's possible that a group has no tabbable nodes if nodes get removed while the trap\n // is active, but the trap should never get to a state where there isn't at least one group\n // with at least one tabbable node in it (that would lead to an error condition that would\n // result in an error being thrown)\n // @type {Array<{\n // container: HTMLElement,\n // tabbableNodes: Array<HTMLElement>, // empty if none\n // focusableNodes: Array<HTMLElement>, // empty if none\n // posTabIndexesFound: boolean,\n // firstTabbableNode: HTMLElement|undefined,\n // lastTabbableNode: HTMLElement|undefined,\n // firstDomTabbableNode: HTMLElement|undefined,\n // lastDomTabbableNode: HTMLElement|undefined,\n // nextTabbableNode: (node: HTMLElement, forward: boolean) => HTMLElement|undefined\n // }>}\n containerGroups: [],\n // same order/length as `containers` list\n\n // references to objects in `containerGroups`, but only those that actually have\n // tabbable nodes in them\n // NOTE: same order as `containers` and `containerGroups`, but __not necessarily__\n // the same length\n tabbableGroups: [],\n nodeFocusedBeforeActivation: null,\n mostRecentlyFocusedNode: null,\n active: false,\n paused: false,\n // timer ID for when delayInitialFocus is true and initial focus in this trap\n // has been delayed during activation\n delayInitialFocusTimer: undefined,\n // the most recent KeyboardEvent for the configured nav key (typically [SHIFT+]TAB), if any\n recentNavEvent: undefined\n };\n var trap; // eslint-disable-line prefer-const -- some private functions reference it, and its methods reference private functions, so we must declare here and define later\n\n /**\n * Gets a configuration option value.\n * @param {Object|undefined} configOverrideOptions If true, and option is defined in this set,\n * value will be taken from this object. Otherwise, value will be taken from base configuration.\n * @param {string} optionName Name of the option whose value is sought.\n * @param {string|undefined} [configOptionName] Name of option to use __instead of__ `optionName`\n * IIF `configOverrideOptions` is not defined. Otherwise, `optionName` is used.\n */\n var getOption = function getOption(configOverrideOptions, optionName, configOptionName) {\n return configOverrideOptions && configOverrideOptions[optionName] !== undefined ? configOverrideOptions[optionName] : config[configOptionName || optionName];\n };\n\n /**\n * Finds the index of the container that contains the element.\n * @param {HTMLElement} element\n * @param {Event} [event] If available, and `element` isn't directly found in any container,\n * the event's composed path is used to see if includes any known trap containers in the\n * case where the element is inside a Shadow DOM.\n * @returns {number} Index of the container in either `state.containers` or\n * `state.containerGroups` (the order/length of these lists are the same); -1\n * if the element isn't found.\n */\n var findContainerIndex = function findContainerIndex(element, event) {\n var composedPath = typeof (event === null || event === void 0 ? void 0 : event.composedPath) === 'function' ? event.composedPath() : undefined;\n // NOTE: search `containerGroups` because it's possible a group contains no tabbable\n // nodes, but still contains focusable nodes (e.g. if they all have `tabindex=-1`)\n // and we still need to find the element in there\n return state.containerGroups.findIndex(function (_ref) {\n var container = _ref.container,\n tabbableNodes = _ref.tabbableNodes;\n return container.contains(element) || ( // fall back to explicit tabbable search which will take into consideration any\n // web components if the `tabbableOptions.getShadowRoot` option was used for\n // the trap, enabling shadow DOM support in tabbable (`Node.contains()` doesn't\n // look inside web components even if open)\n composedPath === null || composedPath === void 0 ? void 0 : composedPath.includes(container)) || tabbableNodes.find(function (node) {\n return node === element;\n });\n });\n };\n\n /**\n * Gets the node for the given option, which is expected to be an option that\n * can be either a DOM node, a string that is a selector to get a node, `false`\n * (if a node is explicitly NOT given), or a function that returns any of these\n * values.\n * @param {string} optionName\n * @returns {undefined | false | HTMLElement | SVGElement} Returns\n * `undefined` if the option is not specified; `false` if the option\n * resolved to `false` (node explicitly not given); otherwise, the resolved\n * DOM node.\n * @throws {Error} If the option is set, not `false`, and is not, or does not\n * resolve to a node.\n */\n var getNodeForOption = function getNodeForOption(optionName) {\n var optionValue = config[optionName];\n if (typeof optionValue === 'function') {\n for (var _len2 = arguments.length, params = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n params[_key2 - 1] = arguments[_key2];\n }\n optionValue = optionValue.apply(void 0, params);\n }\n if (optionValue === true) {\n optionValue = undefined; // use default value\n }\n\n if (!optionValue) {\n if (optionValue === undefined || optionValue === false) {\n return optionValue;\n }\n // else, empty string (invalid), null (invalid), 0 (invalid)\n\n throw new Error(\"`\".concat(optionName, \"` was specified but was not a node, or did not return a node\"));\n }\n var node = optionValue; // could be HTMLElement, SVGElement, or non-empty string at this point\n\n if (typeof optionValue === 'string') {\n node = doc.querySelector(optionValue); // resolve to node, or null if fails\n if (!node) {\n throw new Error(\"`\".concat(optionName, \"` as selector refers to no known node\"));\n }\n }\n return node;\n };\n var getInitialFocusNode = function getInitialFocusNode() {\n var node = getNodeForOption('initialFocus');\n\n // false explicitly indicates we want no initialFocus at all\n if (node === false) {\n return false;\n }\n if (node === undefined || !isFocusable(node, config.tabbableOptions)) {\n // option not specified nor focusable: use fallback options\n if (findContainerIndex(doc.activeElement) >= 0) {\n node = doc.activeElement;\n } else {\n var firstTabbableGroup = state.tabbableGroups[0];\n var firstTabbableNode = firstTabbableGroup && firstTabbableGroup.firstTabbableNode;\n\n // NOTE: `fallbackFocus` option function cannot return `false` (not supported)\n node = firstTabbableNode || getNodeForOption('fallbackFocus');\n }\n }\n if (!node) {\n throw new Error('Your focus-trap needs to have at least one focusable element');\n }\n return node;\n };\n var updateTabbableNodes = function updateTabbableNodes() {\n state.containerGroups = state.containers.map(function (container) {\n var tabbableNodes = tabbable(container, config.tabbableOptions);\n\n // NOTE: if we have tabbable nodes, we must have focusable nodes; focusable nodes\n // are a superset of tabbable nodes since nodes with negative `tabindex` attributes\n // are focusable but not tabbable\n var focusableNodes = focusable(container, config.tabbableOptions);\n var firstTabbableNode = tabbableNodes.length > 0 ? tabbableNodes[0] : undefined;\n var lastTabbableNode = tabbableNodes.length > 0 ? tabbableNodes[tabbableNodes.length - 1] : undefined;\n var firstDomTabbableNode = focusableNodes.find(function (node) {\n return isTabbable(node);\n });\n var lastDomTabbableNode = focusableNodes.slice().reverse().find(function (node) {\n return isTabbable(node);\n });\n var posTabIndexesFound = !!tabbableNodes.find(function (node) {\n return getTabIndex(node) > 0;\n });\n return {\n container: container,\n tabbableNodes: tabbableNodes,\n focusableNodes: focusableNodes,\n /** True if at least one node with positive `tabindex` was found in this container. */\n posTabIndexesFound: posTabIndexesFound,\n /** First tabbable node in container, __tabindex__ order; `undefined` if none. */\n firstTabbableNode: firstTabbableNode,\n /** Last tabbable node in container, __tabindex__ order; `undefined` if none. */\n lastTabbableNode: lastTabbableNode,\n // NOTE: DOM order is NOT NECESSARILY \"document position\" order, but figuring that out\n // would require more than just https://developer.mozilla.org/en-US/docs/Web/API/Node/compareDocumentPosition\n // because that API doesn't work with Shadow DOM as well as it should (@see\n // https://github.com/whatwg/dom/issues/320) and since this first/last is only needed, so far,\n // to address an edge case related to positive tabindex support, this seems like a much easier,\n // \"close enough most of the time\" alternative for positive tabindexes which should generally\n // be avoided anyway...\n /** First tabbable node in container, __DOM__ order; `undefined` if none. */\n firstDomTabbableNode: firstDomTabbableNode,\n /** Last tabbable node in container, __DOM__ order; `undefined` if none. */\n lastDomTabbableNode: lastDomTabbableNode,\n /**\n * Finds the __tabbable__ node that follows the given node in the specified direction,\n * in this container, if any.\n * @param {HTMLElement} node\n * @param {boolean} [forward] True if going in forward tab order; false if going\n * in reverse.\n * @returns {HTMLElement|undefined} The next tabbable node, if any.\n */\n nextTabbableNode: function nextTabbableNode(node) {\n var forward = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n var nodeIdx = tabbableNodes.indexOf(node);\n if (nodeIdx < 0) {\n // either not tabbable nor focusable, or was focused but not tabbable (negative tabindex):\n // since `node` should at least have been focusable, we assume that's the case and mimic\n // what browsers do, which is set focus to the next node in __document position order__,\n // regardless of positive tabindexes, if any -- and for reasons explained in the NOTE\n // above related to `firstDomTabbable` and `lastDomTabbable` properties, we fall back to\n // basic DOM order\n if (forward) {\n return focusableNodes.slice(focusableNodes.indexOf(node) + 1).find(function (el) {\n return isTabbable(el);\n });\n }\n return focusableNodes.slice(0, focusableNodes.indexOf(node)).reverse().find(function (el) {\n return isTabbable(el);\n });\n }\n return tabbableNodes[nodeIdx + (forward ? 1 : -1)];\n }\n };\n });\n state.tabbableGroups = state.containerGroups.filter(function (group) {\n return group.tabbableNodes.length > 0;\n });\n\n // throw if no groups have tabbable nodes and we don't have a fallback focus node either\n if (state.tabbableGroups.length <= 0 && !getNodeForOption('fallbackFocus') // returning false not supported for this option\n ) {\n throw new Error('Your focus-trap must have at least one container with at least one tabbable node in it at all times');\n }\n\n // NOTE: Positive tabindexes are only properly supported in single-container traps because\n // doing it across multiple containers where tabindexes could be all over the place\n // would require Tabbable to support multiple containers, would require additional\n // specialized Shadow DOM support, and would require Tabbable's multi-container support\n // to look at those containers in document position order rather than user-provided\n // order (as they are treated in Focus-trap, for legacy reasons). See discussion on\n // https://github.com/focus-trap/focus-trap/issues/375 for more details.\n if (state.containerGroups.find(function (g) {\n return g.posTabIndexesFound;\n }) && state.containerGroups.length > 1) {\n throw new Error(\"At least one node with a positive tabindex was found in one of your focus-trap's multiple containers. Positive tabindexes are only supported in single-container focus-traps.\");\n }\n };\n\n /**\n * Gets the current activeElement. If it's a web-component and has open shadow-root\n * it will recursively search inside shadow roots for the \"true\" activeElement.\n *\n * @param {Document | ShadowRoot} el\n *\n * @returns {HTMLElement} The element that currently has the focus\n **/\n var getActiveElement = function getActiveElement(el) {\n var activeElement = el.activeElement;\n if (!activeElement) {\n return;\n }\n if (activeElement.shadowRoot && activeElement.shadowRoot.activeElement !== null) {\n return getActiveElement(activeElement.shadowRoot);\n }\n return activeElement;\n };\n var tryFocus = function tryFocus(node) {\n if (node === false) {\n return;\n }\n if (node === getActiveElement(document)) {\n return;\n }\n if (!node || !node.focus) {\n tryFocus(getInitialFocusNode());\n return;\n }\n node.focus({\n preventScroll: !!config.preventScroll\n });\n // NOTE: focus() API does not trigger focusIn event so set MRU node manually\n state.mostRecentlyFocusedNode = node;\n if (isSelectableInput(node)) {\n node.select();\n }\n };\n var getReturnFocusNode = function getReturnFocusNode(previousActiveElement) {\n var node = getNodeForOption('setReturnFocus', previousActiveElement);\n return node ? node : node === false ? false : previousActiveElement;\n };\n\n /**\n * Finds the next node (in either direction) where focus should move according to a\n * keyboard focus-in event.\n * @param {Object} params\n * @param {Node} [params.target] Known target __from which__ to navigate, if any.\n * @param {KeyboardEvent|FocusEvent} [params.event] Event to use if `target` isn't known (event\n * will be used to determine the `target`). Ignored if `target` is specified.\n * @param {boolean} [params.isBackward] True if focus should move backward.\n * @returns {Node|undefined} The next node, or `undefined` if a next node couldn't be\n * determined given the current state of the trap.\n */\n var findNextNavNode = function findNextNavNode(_ref2) {\n var target = _ref2.target,\n event = _ref2.event,\n _ref2$isBackward = _ref2.isBackward,\n isBackward = _ref2$isBackward === void 0 ? false : _ref2$isBackward;\n target = target || getActualTarget(event);\n updateTabbableNodes();\n var destinationNode = null;\n if (state.tabbableGroups.length > 0) {\n // make sure the target is actually contained in a group\n // NOTE: the target may also be the container itself if it's focusable\n // with tabIndex='-1' and was given initial focus\n var containerIndex = findContainerIndex(target, event);\n var containerGroup = containerIndex >= 0 ? state.containerGroups[containerIndex] : undefined;\n if (containerIndex < 0) {\n // target not found in any group: quite possible focus has escaped the trap,\n // so bring it back into...\n if (isBackward) {\n // ...the last node in the last group\n destinationNode = state.tabbableGroups[state.tabbableGroups.length - 1].lastTabbableNode;\n } else {\n // ...the first node in the first group\n destinationNode = state.tabbableGroups[0].firstTabbableNode;\n }\n } else if (isBackward) {\n // REVERSE\n\n // is the target the first tabbable node in a group?\n var startOfGroupIndex = findIndex(state.tabbableGroups, function (_ref3) {\n var firstTabbableNode = _ref3.firstTabbableNode;\n return target === firstTabbableNode;\n });\n if (startOfGroupIndex < 0 && (containerGroup.container === target || isFocusable(target, config.tabbableOptions) && !isTabbable(target, config.tabbableOptions) && !containerGroup.nextTabbableNode(target, false))) {\n // an exception case where the target is either the container itself, or\n // a non-tabbable node that was given focus (i.e. tabindex is negative\n // and user clicked on it or node was programmatically given focus)\n // and is not followed by any other tabbable node, in which\n // case, we should handle shift+tab as if focus were on the container's\n // first tabbable node, and go to the last tabbable node of the LAST group\n startOfGroupIndex = containerIndex;\n }\n if (startOfGroupIndex >= 0) {\n // YES: then shift+tab should go to the last tabbable node in the\n // previous group (and wrap around to the last tabbable node of\n // the LAST group if it's the first tabbable node of the FIRST group)\n var destinationGroupIndex = startOfGroupIndex === 0 ? state.tabbableGroups.length - 1 : startOfGroupIndex - 1;\n var destinationGroup = state.tabbableGroups[destinationGroupIndex];\n destinationNode = getTabIndex(target) >= 0 ? destinationGroup.lastTabbableNode : destinationGroup.lastDomTabbableNode;\n } else if (!isTabEvent(event)) {\n // user must have customized the nav keys so we have to move focus manually _within_\n // the active group: do this based on the order determined by tabbable()\n destinationNode = containerGroup.nextTabbableNode(target, false);\n }\n } else {\n // FORWARD\n\n // is the target the last tabbable node in a group?\n var lastOfGroupIndex = findIndex(state.tabbableGroups, function (_ref4) {\n var lastTabbableNode = _ref4.lastTabbableNode;\n return target === lastTabbableNode;\n });\n if (lastOfGroupIndex < 0 && (containerGroup.container === target || isFocusable(target, config.tabbableOptions) && !isTabbable(target, config.tabbableOptions) && !containerGroup.nextTabbableNode(target))) {\n // an exception case where the target is the container itself, or\n // a non-tabbable node that was given focus (i.e. tabindex is negative\n // and user clicked on it or node was programmatically given focus)\n // and is not followed by any other tabbable node, in which\n // case, we should handle tab as if focus were on the container's\n // last tabbable node, and go to the first tabbable node of the FIRST group\n lastOfGroupIndex = containerIndex;\n }\n if (lastOfGroupIndex >= 0) {\n // YES: then tab should go to the first tabbable node in the next\n // group (and wrap around to the first tabbable node of the FIRST\n // group if it's the last tabbable node of the LAST group)\n var _destinationGroupIndex = lastOfGroupIndex === state.tabbableGroups.length - 1 ? 0 : lastOfGroupIndex + 1;\n var _destinationGroup = state.tabbableGroups[_destinationGroupIndex];\n destinationNode = getTabIndex(target) >= 0 ? _destinationGroup.firstTabbableNode : _destinationGroup.firstDomTabbableNode;\n } else if (!isTabEvent(event)) {\n // user must have customized the nav keys so we have to move focus manually _within_\n // the active group: do this based on the order determined by tabbable()\n destinationNode = containerGroup.nextTabbableNode(target);\n }\n }\n } else {\n // no groups available\n // NOTE: the fallbackFocus option does not support returning false to opt-out\n destinationNode = getNodeForOption('fallbackFocus');\n }\n return destinationNode;\n };\n\n // This needs to be done on mousedown and touchstart instead of click\n // so that it precedes the focus event.\n var checkPointerDown = function checkPointerDown(e) {\n var target = getActualTarget(e);\n if (findContainerIndex(target, e) >= 0) {\n // allow the click since it ocurred inside the trap\n return;\n }\n if (valueOrHandler(config.clickOutsideDeactivates, e)) {\n // immediately deactivate the trap\n trap.deactivate({\n // NOTE: by setting `returnFocus: false`, deactivate() will do nothing,\n // which will result in the outside click setting focus to the node\n // that was clicked (and if not focusable, to \"nothing\"); by setting\n // `returnFocus: true`, we'll attempt to re-focus the node originally-focused\n // on activation (or the configured `setReturnFocus` node), whether the\n // outside click was on a focusable node or not\n returnFocus: config.returnFocusOnDeactivate\n });\n return;\n }\n\n // This is needed for mobile devices.\n // (If we'll only let `click` events through,\n // then on mobile they will be blocked anyways if `touchstart` is blocked.)\n if (valueOrHandler(config.allowOutsideClick, e)) {\n // allow the click outside the trap to take place\n return;\n }\n\n // otherwise, prevent the click\n e.preventDefault();\n };\n\n // In case focus escapes the trap for some strange reason, pull it back in.\n // NOTE: the focusIn event is NOT cancelable, so if focus escapes, it may cause unexpected\n // scrolling if the node that got focused was out of view; there's nothing we can do to\n // prevent that from happening by the time we discover that focus escaped\n var checkFocusIn = function checkFocusIn(event) {\n var target = getActualTarget(event);\n var targetContained = findContainerIndex(target, event) >= 0;\n\n // In Firefox when you Tab out of an iframe the Document is briefly focused.\n if (targetContained || target instanceof Document) {\n if (targetContained) {\n state.mostRecentlyFocusedNode = target;\n }\n } else {\n // escaped! pull it back in to where it just left\n event.stopImmediatePropagation();\n\n // focus will escape if the MRU node had a positive tab index and user tried to nav forward;\n // it will also escape if the MRU node had a 0 tab index and user tried to nav backward\n // toward a node with a positive tab index\n var nextNode; // next node to focus, if we find one\n var navAcrossContainers = true;\n if (state.mostRecentlyFocusedNode) {\n if (getTabIndex(state.mostRecentlyFocusedNode) > 0) {\n // MRU container index must be >=0 otherwise we wouldn't have it as an MRU node...\n var mruContainerIdx = findContainerIndex(state.mostRecentlyFocusedNode);\n // there MAY not be any tabbable nodes in the container if there are at least 2 containers\n // and the MRU node is focusable but not tabbable (focus-trap requires at least 1 container\n // with at least one tabbable node in order to function, so this could be the other container\n // with nothing tabbable in it)\n var tabbableNodes = state.containerGroups[mruContainerIdx].tabbableNodes;\n if (tabbableNodes.length > 0) {\n // MRU tab index MAY not be found if the MRU node is focusable but not tabbable\n var mruTabIdx = tabbableNodes.findIndex(function (node) {\n return node === state.mostRecentlyFocusedNode;\n });\n if (mruTabIdx >= 0) {\n if (config.isKeyForward(state.recentNavEvent)) {\n if (mruTabIdx + 1 < tabbableNodes.length) {\n nextNode = tabbableNodes[mruTabIdx + 1];\n navAcrossContainers = false;\n }\n // else, don't wrap within the container as focus should move to next/previous\n // container\n } else {\n if (mruTabIdx - 1 >= 0) {\n nextNode = tabbableNodes[mruTabIdx - 1];\n navAcrossContainers = false;\n }\n // else, don't wrap within the container as focus should move to next/previous\n // container\n }\n // else, don't find in container order without considering direction too\n }\n }\n // else, no tabbable nodes in that container (which means we must have at least one other\n // container with at least one tabbable node in it, otherwise focus-trap would've thrown\n // an error the last time updateTabbableNodes() was run): find next node among all known\n // containers\n } else {\n // check to see if there's at least one tabbable node with a positive tab index inside\n // the trap because focus seems to escape when navigating backward from a tabbable node\n // with tabindex=0 when this is the case (instead of wrapping to the tabbable node with\n // the greatest positive tab index like it should)\n if (!state.containerGroups.some(function (g) {\n return g.tabbableNodes.some(function (n) {\n return getTabIndex(n) > 0;\n });\n })) {\n // no containers with tabbable nodes with positive tab indexes which means the focus\n // escaped for some other reason and we should just execute the fallback to the\n // MRU node or initial focus node, if any\n navAcrossContainers = false;\n }\n }\n } else {\n // no MRU node means we're likely in some initial condition when the trap has just\n // been activated and initial focus hasn't been given yet, in which case we should\n // fall through to trying to focus the initial focus node, which is what should\n // happen below at this point in the logic\n navAcrossContainers = false;\n }\n if (navAcrossContainers) {\n nextNode = findNextNavNode({\n // move FROM the MRU node, not event-related node (which will be the node that is\n // outside the trap causing the focus escape we're trying to fix)\n target: state.mostRecentlyFocusedNode,\n isBackward: config.isKeyBackward(state.recentNavEvent)\n });\n }\n if (nextNode) {\n tryFocus(nextNode);\n } else {\n tryFocus(state.mostRecentlyFocusedNode || getInitialFocusNode());\n }\n }\n state.recentNavEvent = undefined; // clear\n };\n\n // Hijack key nav events on the first and last focusable nodes of the trap,\n // in order to prevent focus from escaping. If it escapes for even a\n // moment it can end up scrolling the page and causing confusion so we\n // kind of need to capture the action at the keydown phase.\n var checkKeyNav = function checkKeyNav(event) {\n var isBackward = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n state.recentNavEvent = event;\n var destinationNode = findNextNavNode({\n event: event,\n isBackward: isBackward\n });\n if (destinationNode) {\n if (isTabEvent(event)) {\n // since tab natively moves focus, we wouldn't have a destination node unless we\n // were on the edge of a container and had to move to the next/previous edge, in\n // which case we want to prevent default to keep the browser from moving focus\n // to where it normally would\n event.preventDefault();\n }\n tryFocus(destinationNode);\n }\n // else, let the browser take care of [shift+]tab and move the focus\n };\n\n var checkKey = function checkKey(event) {\n if (isEscapeEvent(event) && valueOrHandler(config.escapeDeactivates, event) !== false) {\n event.preventDefault();\n trap.deactivate();\n return;\n }\n if (config.isKeyForward(event) || config.isKeyBackward(event)) {\n checkKeyNav(event, config.isKeyBackward(event));\n }\n };\n var checkClick = function checkClick(e) {\n var target = getActualTarget(e);\n if (findContainerIndex(target, e) >= 0) {\n return;\n }\n if (valueOrHandler(config.clickOutsideDeactivates, e)) {\n return;\n }\n if (valueOrHandler(config.allowOutsideClick, e)) {\n return;\n }\n e.preventDefault();\n e.stopImmediatePropagation();\n };\n\n //\n // EVENT LISTENERS\n //\n\n var addListeners = function addListeners() {\n if (!state.active) {\n return;\n }\n\n // There can be only one listening focus trap at a time\n activeFocusTraps.activateTrap(trapStack, trap);\n\n // Delay ensures that the focused element doesn't capture the event\n // that caused the focus trap activation.\n state.delayInitialFocusTimer = config.delayInitialFocus ? delay(function () {\n tryFocus(getInitialFocusNode());\n }) : tryFocus(getInitialFocusNode());\n doc.addEventListener('focusin', checkFocusIn, true);\n doc.addEventListener('mousedown', checkPointerDown, {\n capture: true,\n passive: false\n });\n doc.addEventListener('touchstart', checkPointerDown, {\n capture: true,\n passive: false\n });\n doc.addEventListener('click', checkClick, {\n capture: true,\n passive: false\n });\n doc.addEventListener('keydown', checkKey, {\n capture: true,\n passive: false\n });\n return trap;\n };\n var removeListeners = function removeListeners() {\n if (!state.active) {\n return;\n }\n doc.removeEventListener('focusin', checkFocusIn, true);\n doc.removeEventListener('mousedown', checkPointerDown, true);\n doc.removeEventListener('touchstart', checkPointerDown, true);\n doc.removeEventListener('click', checkClick, true);\n doc.removeEventListener('keydown', checkKey, true);\n return trap;\n };\n\n //\n // MUTATION OBSERVER\n //\n\n var checkDomRemoval = function checkDomRemoval(mutations) {\n var isFocusedNodeRemoved = mutations.some(function (mutation) {\n var removedNodes = Array.from(mutation.removedNodes);\n return removedNodes.some(function (node) {\n return node === state.mostRecentlyFocusedNode;\n });\n });\n\n // If the currently focused is removed then browsers will move focus to the\n // <body> element. If this happens, try to move focus back into the trap.\n if (isFocusedNodeRemoved) {\n tryFocus(getInitialFocusNode());\n }\n };\n\n // Use MutationObserver - if supported - to detect if focused node is removed\n // from the DOM.\n var mutationObserver = typeof window !== 'undefined' && 'MutationObserver' in window ? new MutationObserver(checkDomRemoval) : undefined;\n var updateObservedNodes = function updateObservedNodes() {\n if (!mutationObserver) {\n return;\n }\n mutationObserver.disconnect();\n if (state.active && !state.paused) {\n state.containers.map(function (container) {\n mutationObserver.observe(container, {\n subtree: true,\n childList: true\n });\n });\n }\n };\n\n //\n // TRAP DEFINITION\n //\n\n trap = {\n get active() {\n return state.active;\n },\n get paused() {\n return state.paused;\n },\n activate: function activate(activateOptions) {\n if (state.active) {\n return this;\n }\n var onActivate = getOption(activateOptions, 'onActivate');\n var onPostActivate = getOption(activateOptions, 'onPostActivate');\n var checkCanFocusTrap = getOption(activateOptions, 'checkCanFocusTrap');\n if (!checkCanFocusTrap) {\n updateTabbableNodes();\n }\n state.active = true;\n state.paused = false;\n state.nodeFocusedBeforeActivation = doc.activeElement;\n onActivate === null || onActivate === void 0 || onActivate();\n var finishActivation = function finishActivation() {\n if (checkCanFocusTrap) {\n updateTabbableNodes();\n }\n addListeners();\n updateObservedNodes();\n onPostActivate === null || onPostActivate === void 0 || onPostActivate();\n };\n if (checkCanFocusTrap) {\n checkCanFocusTrap(state.containers.concat()).then(finishActivation, finishActivation);\n return this;\n }\n finishActivation();\n return this;\n },\n deactivate: function deactivate(deactivateOptions) {\n if (!state.active) {\n return this;\n }\n var options = _objectSpread2({\n onDeactivate: config.onDeactivate,\n onPostDeactivate: config.onPostDeactivate,\n checkCanReturnFocus: config.checkCanReturnFocus\n }, deactivateOptions);\n clearTimeout(state.delayInitialFocusTimer); // noop if undefined\n state.delayInitialFocusTimer = undefined;\n removeListeners();\n state.active = false;\n state.paused = false;\n updateObservedNodes();\n activeFocusTraps.deactivateTrap(trapStack, trap);\n var onDeactivate = getOption(options, 'onDeactivate');\n var onPostDeactivate = getOption(options, 'onPostDeactivate');\n var checkCanReturnFocus = getOption(options, 'checkCanReturnFocus');\n var returnFocus = getOption(options, 'returnFocus', 'returnFocusOnDeactivate');\n onDeactivate === null || onDeactivate === void 0 || onDeactivate();\n var finishDeactivation = function finishDeactivation() {\n delay(function () {\n if (returnFocus) {\n tryFocus(getReturnFocusNode(state.nodeFocusedBeforeActivation));\n }\n onPostDeactivate === null || onPostDeactivate === void 0 || onPostDeactivate();\n });\n };\n if (returnFocus && checkCanReturnFocus) {\n checkCanReturnFocus(getReturnFocusNode(state.nodeFocusedBeforeActivation)).then(finishDeactivation, finishDeactivation);\n return this;\n }\n finishDeactivation();\n return this;\n },\n pause: function pause(pauseOptions) {\n if (state.paused || !state.active) {\n return this;\n }\n var onPause = getOption(pauseOptions, 'onPause');\n var onPostPause = getOption(pauseOptions, 'onPostPause');\n state.paused = true;\n onPause === null || onPause === void 0 || onPause();\n removeListeners();\n updateObservedNodes();\n onPostPause === null || onPostPause === void 0 || onPostPause();\n return this;\n },\n unpause: function unpause(unpauseOptions) {\n if (!state.paused || !state.active) {\n return this;\n }\n var onUnpause = getOption(unpauseOptions, 'onUnpause');\n var onPostUnpause = getOption(unpauseOptions, 'onPostUnpause');\n state.paused = false;\n onUnpause === null || onUnpause === void 0 || onUnpause();\n updateTabbableNodes();\n addListeners();\n updateObservedNodes();\n onPostUnpause === null || onPostUnpause === void 0 || onPostUnpause();\n return this;\n },\n updateContainerElements: function updateContainerElements(containerElements) {\n var elementsAsArray = [].concat(containerElements).filter(Boolean);\n state.containers = elementsAsArray.map(function (element) {\n return typeof element === 'string' ? doc.querySelector(element) : element;\n });\n if (state.active) {\n updateTabbableNodes();\n }\n updateObservedNodes();\n return this;\n }\n };\n\n // initialize container elements\n trap.updateContainerElements(elements);\n return trap;\n};\n\nexport { createFocusTrap };\n//# sourceMappingURL=focus-trap.esm.js.map\n","import { createFocusTrap } from 'focus-trap'\nimport { render, toChildArray } from 'preact'\nimport { useEffect, useLayoutEffect, useRef, useState } from 'preact/hooks'\nimport { useGeneratedId } from 'ui/hooks/seamly-hooks'\nimport { createAriaHider } from 'ui/utils/general-utils'\n\nconst Modal = ({\n children,\n onClose,\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n fallBackFocusRef,\n}) => {\n const modalId = useGeneratedId()\n const modalContainer = useRef(null)\n const focusTrap = useRef(null)\n const [containerIsSet, setContainerIsSet] = useState(false)\n\n useEffect(() => {\n if (containerIsSet) {\n focusTrap.current = createFocusTrap(modalContainer.current, {\n initialFocus:\n fallBackFocusRef && fallBackFocusRef.current\n ? fallBackFocusRef.current\n : null,\n })\n focusTrap.current.activate()\n }\n return () => {\n if (focusTrap.current) {\n focusTrap.current.deactivate()\n }\n }\n }, [containerIsSet, fallBackFocusRef])\n\n useEffect(() => {\n const disposeAriaHider = createAriaHider()\n return () => {\n disposeAriaHider()\n }\n }, [containerIsSet])\n\n useEffect(() => {\n if (containerIsSet) {\n modalContainer.current.addEventListener('keydown', (event) => {\n if ((event.code && event.code === 'Escape') || event.keyCode === 27) {\n onClose()\n }\n })\n }\n }, [containerIsSet, onClose])\n\n useLayoutEffect(() => {\n const bodyElement = document.getElementsByTagName('body')[0]\n const container = document.createElement('div')\n container.setAttribute('id', modalId)\n container.setAttribute('role', 'dialog')\n container.setAttribute('data-nosnippet', 'true')\n container.setAttribute('aria-modal', 'true')\n if (ariaLabel) {\n container.setAttribute('aria-label', ariaLabel)\n }\n if (ariaLabelledBy) {\n container.setAttribute('aria-labelledby', ariaLabelledBy)\n }\n bodyElement.appendChild(container)\n modalContainer.current = container\n setContainerIsSet(true)\n return () => {\n if (modalContainer.current) {\n bodyElement.removeChild(modalContainer.current)\n modalContainer.current = null\n }\n }\n }, [ariaLabel, ariaLabelledBy, modalId])\n\n // This component can either be provided with a children render\n // function or another component.\n // If a render function the function will be called with the onClose\n // handler function as well as a modalRenderFn that should be used to\n // render your content.\n // <Modal onClose={onCloseHandler} aria-label=\"label test\">\n // {({ onClose, modalRenderFn }) =>\n // modalRenderFn(<MyContent onClose={onClose} />)\n // }\n // </Modal>\n // If called with a single component, no render function is required\n // and the onClose function will be automatically added to the\n // single child component.\n // <Modal onClose={onCloseHandler} aria-label=\"label test\" >\n // <MyContent />\n // </Modal>\n return typeof children === 'function'\n ? children({\n onClose,\n modalRenderFn: (els) =>\n modalContainer.current && render(els, modalContainer.current),\n })\n : modalContainer.current &&\n render(\n toChildArray(children).map((child) => {\n child.props = { ...child.props, onClose }\n return child\n }),\n modalContainer.current,\n )\n}\n\nexport default Modal\n","import { useRef } from 'preact/hooks'\nimport { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport {\n useSeamlyActivityEventHandler,\n useSeamlyAppContainerClassNames,\n} from 'ui/hooks/seamly-hooks'\nimport Modal from './modal'\n\nconst Lightbox = ({ url, description, onClose: onCloseHandler }) => {\n const { zIndex, layoutMode, namespace } = useConfig()\n const onActivityHandler = useSeamlyActivityEventHandler()\n const appContainerClassNames = useSeamlyAppContainerClassNames()\n const focusContainer = useRef(null)\n const { t } = useI18n()\n\n // TODO: Change incorrect usage of css modifiers\n const defaultClassNames = [\n `app--layout-${layoutMode}`,\n `namespace--${namespace}`,\n ]\n const classNames = ['modal', ...defaultClassNames, ...appContainerClassNames]\n\n const onFrameClickHandler = (e) => {\n e.stopPropagation()\n }\n\n const onFloatClickHandler = () => {\n onCloseHandler()\n }\n\n const style = zIndex ? { zIndex: zIndex + 1 } : undefined\n\n const getModalContent = (onClose) => (\n <div\n className={className(classNames)}\n onClick={onFloatClickHandler}\n style={style}\n >\n <div\n className={className('modal__float')}\n tabIndex=\"-1\"\n onMouseDown={onActivityHandler}\n onKeyDown={onActivityHandler}\n onTouchStart={onActivityHandler}\n onMouseMove={onActivityHandler}\n onWheel={onActivityHandler}\n onPointerDown={onActivityHandler}\n onPointerMove={onActivityHandler}\n ref={focusContainer}\n >\n <div\n className={className('modal__inner')}\n onClick={onFrameClickHandler}\n >\n <img\n className={className('modal__image')}\n src={url}\n alt={description}\n />\n </div>\n <button\n type=\"button\"\n className={className('modal__close')}\n onClick={onClose}\n >\n <Icon name=\"close\" size=\"16\" alt=\"\" />\n {t('lightbox.closeLabel')}\n </button>\n </div>\n </div>\n )\n\n return (\n <Modal\n onClose={onCloseHandler}\n aria-label={t('lightbox.heading')}\n fallBackFocusRef={focusContainer}\n >\n {({ onClose, modalRenderFn }) => modalRenderFn(getModalContent(onClose))}\n </Modal>\n )\n}\n\nexport default Lightbox\n","import { useState } from 'preact/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport Lightbox from 'ui/components/widgets/lightbox'\n\nconst ImageLightbox = ({ description, url }) => {\n const { t } = useI18n()\n const [showLightBox, setShowLightBox] = useState(false)\n\n const onOpenLightboxHandler = () => {\n setShowLightBox(true)\n }\n\n const onCloseLightboxHandler = () => {\n setShowLightBox(false)\n }\n\n return (\n <>\n <button\n type=\"button\"\n className={className('modal__enlarge')}\n onClick={onOpenLightboxHandler}\n >\n {t('message.image.srTextEnlargeButtonLabel', { description })}\n <Icon name=\"enlarge\" size=\"32\" alt=\"\" />\n </button>\n {showLightBox && (\n <Lightbox\n url={url}\n description={description}\n onClose={onCloseLightboxHandler}\n />\n )}\n </>\n )\n}\n\nexport default ImageLightbox\n","import { useMemo } from 'preact/hooks'\nimport { useTranslatedEventData } from 'domains/translations/hooks'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport useEventLinkClickHandler from './hooks/use-event-link-click-handler'\n\nconst Text = ({ event, ...props }) => {\n const { body } = useTranslatedEventData(event)\n const eventClick = useEventLinkClickHandler(event.payload.id)\n\n const containerProps = useMemo(() => {\n if (event.payload.optimisticallyInjected) {\n return {\n children: <p>{body.text}</p>,\n }\n }\n\n return {\n bodyProps: {\n dangerouslySetInnerHTML: {\n __html: body?.data?.text || body.text,\n },\n },\n }\n }, [body, event])\n\n return (\n <MessageContainer\n type=\"text\"\n event={event}\n onClick={eventClick}\n {...props}\n {...containerProps}\n />\n )\n}\n\nexport default Text\n","import { useMemo } from 'preact/hooks'\nimport { useSelector } from 'react-redux'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { useTranslatedEventData } from 'domains/translations/hooks'\nimport { className } from 'lib/css'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport Icon from 'ui/components/layout/icon'\n\nconst PROCESSING_IMAGE = 'PROCESSING_IMAGE'\n\nconst useImageFromStorage = (currentFileId) => {\n const { processingFileUploads } = useSelector(({ state }) => state)\n\n return useMemo(() => {\n const isProcessingImg = processingFileUploads.some(\n (fileId) => fileId === currentFileId,\n )\n\n if (isProcessingImg) return PROCESSING_IMAGE\n\n try {\n return sessionStorage.getItem(`image-${currentFileId}`)\n } catch (error) {\n return undefined\n }\n }, [currentFileId, processingFileUploads])\n}\n\nconst UploadedImage = ({ img, filename }) => {\n const { t } = useI18n()\n const srText = t('fileUpload.srFileUploadedText', { fileName: filename })\n\n return (\n <>\n <span className={className(['download', 'download--preview'])}>\n <img src={img} alt={srText} />\n <span aria-hidden=\"true\" className={className('file-download')}>\n {filename}\n </span>\n </span>\n </>\n )\n}\n\nconst UploadContent = ({ children, url, target }) =>\n url ? (\n <a\n href={url}\n download\n target={target}\n className={className(['download', 'download-link'])}\n >\n {children}\n </a>\n ) : (\n <span className={className('download')}>{children}</span>\n )\n\nconst Upload = ({ event, ...props }) => {\n const { t } = useI18n()\n const { body } = useTranslatedEventData(event)\n const { fromClient, id } = event.payload\n const { filename, url } = body\n const img = useImageFromStorage(id)\n\n const srText = useMemo(\n () =>\n url\n ? t('fileUpload.srFileDownloadText', { fileName: filename })\n : t('fileUpload.srFileUploadedText', { fileName: filename }),\n [url, filename, t],\n )\n\n return (\n <MessageContainer event={event} type=\"upload\" {...props}>\n {img && img !== PROCESSING_IMAGE ? (\n <UploadedImage img={img} filename={filename} />\n ) : (\n <UploadContent url={url} target={!fromClient ? '_blank' : undefined}>\n <Icon name=\"download\" size=\"16\" alt={srText} />\n <span aria-hidden=\"true\" className={className('file-download')}>\n {filename}\n </span>\n </UploadContent>\n )}\n </MessageContainer>\n )\n}\n\nexport default Upload\n","import { useMemo } from 'preact/hooks'\nimport { useConfig } from 'domains/config/hooks'\nimport ComponentContext from './component-context'\nimport CardMessage from './event/card-message'\nimport CarouselMessage from './event/carousel-message'\nimport ChoicePrompt from './event/choice-prompt'\nimport ConversationSuggestions from './event/conversation-suggestions'\nimport Cta from './event/cta'\nimport Divider from './event/divider'\nimport TimeIndicator from './event/divider/variants/time-indicator'\nimport Image from './event/image'\nimport Participant from './event/participant'\nimport Splash from './event/splash'\nimport Text from './event/text'\nimport Translation from './event/translation'\nimport Upload from './event/upload'\nimport Video from './event/video'\n\nconst eventTypeMapping = {\n message: {\n choice_prompt: ChoicePrompt,\n text: Text,\n image: Image,\n splash: Splash,\n video: Video,\n upload: Upload,\n cta: Cta,\n carousel: CarouselMessage,\n card: CardMessage,\n },\n info: {\n text: Text,\n divider: Divider,\n translation: Translation,\n timeIndicator: TimeIndicator,\n },\n participant: {\n participant: Participant,\n },\n service_data: {\n suggestion: ConversationSuggestions,\n },\n}\n\nconst ComponentFilter = ({ children }) => {\n const { customComponents } = useConfig()\n\n const resolvedComponents = useMemo(() => {\n // Calculates a combined component mapping object based on the defaults with\n // user implementation component overrides where required.\n return Object.keys(eventTypeMapping).reduce(\n (acc, key) => {\n return {\n ...acc,\n [key]: {\n ...eventTypeMapping[key],\n ...(customComponents ? customComponents[key] : {}),\n },\n }\n },\n { fallback: Text },\n )\n }, [customComponents])\n\n return (\n <ComponentContext.Provider value={resolvedComponents}>\n {children}\n </ComponentContext.Provider>\n )\n}\n\nexport default ComponentFilter\n","import { useState } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { setLoadedImageEventIds } from 'domains/store/slice'\nimport { useTranslatedEventData } from 'domains/translations/hooks'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport ImageLightbox from './image-lightbox'\n\nconst Image = ({ event, descriptorId, ...props }) => {\n const { body } = useTranslatedEventData(event)\n const { description, url, isZoomable } = body\n const [showLighbox, setShowLightbox] = useState(false)\n const dispatch = useDispatch()\n\n const handleOnLoad = () => {\n dispatch(setLoadedImageEventIds(event.payload.id))\n setShowLightbox(true)\n }\n\n return (\n <MessageContainer event={event} type=\"image\" {...props}>\n <img\n src={url}\n id={descriptorId}\n alt={description}\n onLoad={handleOnLoad}\n />\n {isZoomable && showLighbox && (\n <ImageLightbox description={description} url={url} />\n )}\n </MessageContainer>\n )\n}\n\nexport default Image\n","import { useTranslatedEventData } from 'domains/translations/hooks'\nimport useEventLinkClickHandler from 'ui/components/conversation/event/hooks/use-event-link-click-handler'\nimport MessageContainer from 'ui/components/conversation/message-container'\n\nconst Splash = ({ event, ...props }) => {\n const { payload } = event\n const { body } = useTranslatedEventData(event)\n const eventClick = useEventLinkClickHandler(payload.id)\n\n return (\n <MessageContainer\n type=\"splash\"\n event={event}\n onClick={eventClick}\n {...props}\n bodyProps={{\n dangerouslySetInnerHTML: {\n __html: body.text,\n },\n }}\n />\n )\n}\n\nexport default Splash\n","import { useTranslatedEventData } from 'domains/translations/hooks'\nimport { className } from 'lib/css'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport { useSeamlyMessageContainerClassNames } from 'ui/hooks/seamly-hooks'\n\nconst Video = ({ event, descriptorId, ...props }) => {\n const { body } = useTranslatedEventData(event)\n const { description, url } = body\n const classNames = useSeamlyMessageContainerClassNames(event)\n\n classNames.push('message--type-video')\n\n return (\n <MessageContainer event={event} type=\"video\" {...props}>\n <div id={descriptorId} className={className('visually-hidden')}>\n {description}\n </div>\n <iframe\n title={description}\n src={url}\n allow=\"autoplay; encrypted-media\"\n allowFullScreen\n />\n </MessageContainer>\n )\n}\n\nexport default Video\n","import { useCallback } from 'preact/hooks'\nimport { useTranslatedEventData } from 'domains/translations/hooks'\nimport { className } from 'lib/css'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport { useGeneratedId, useSeamlyCommands } from 'ui/hooks/seamly-hooks'\nimport { actionTypes } from 'ui/utils/seamly-utils'\nimport useEventLinkClickHandler from './hooks/use-event-link-click-handler'\n\nconst Cta = ({ event }) => {\n const { body } = useTranslatedEventData(event)\n const eventClick = useEventLinkClickHandler(event.payload.id)\n const { emitEvent } = useSeamlyCommands()\n\n const descriptionId = useGeneratedId()\n\n const onClickHandler = useCallback(\n () =>\n emitEvent(`action.${actionTypes.clickCta}`, {\n type: actionTypes.clickCta,\n originMessage: event.payload.id,\n link: {\n url: body.buttonLink,\n },\n }),\n [emitEvent, body, event],\n )\n\n return (\n <MessageContainer type=\"cta\" event={event}>\n <div\n className={className('cta__content')}\n id={descriptionId}\n dangerouslySetInnerHTML={{ __html: body.description }}\n onClick={eventClick}\n />\n <a\n className={className('button', 'button--primary')}\n aria-describedby={descriptionId}\n href={body.buttonLink}\n rel=\"noreferrer\"\n target={body.buttonNewTab ? '_blank' : '_self'}\n onClick={onClickHandler}\n >\n {body.buttonText}\n </a>\n </MessageContainer>\n )\n}\n\nexport default Cta\n","import { useTranslatedEventData } from 'domains/translations/hooks'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport { useGeneratedId } from 'ui/hooks/seamly-hooks'\nimport CardComponent from './card-component'\n\nconst CardMessage = ({ event }) => {\n const { body } = useTranslatedEventData(event)\n const descriptionId = useGeneratedId()\n\n return (\n <MessageContainer type=\"card\" event={event}>\n <CardComponent id={descriptionId} {...body} />\n </MessageContainer>\n )\n}\n\nexport default CardMessage\n","import { useI18n } from 'domains/i18n/hooks'\nimport { useTranslatedEventData } from 'domains/translations/hooks'\nimport MessageContainer from 'ui/components/conversation/message-container'\n\nconst Translation = ({ event, ...props }) => {\n const { t } = useI18n()\n const { body } = useTranslatedEventData(event)\n return (\n <MessageContainer type=\"text\" event={event} {...props}>\n {t(body.key.join('.'), body.variables)}\n </MessageContainer>\n )\n}\n\nexport default Translation\n","import { useTranslatedEventData } from 'domains/translations/hooks'\nimport EventDivider from 'ui/components/conversation/event-divider'\n\nconst Participant = ({ event }) => {\n const { participant } = event.payload\n const { body: introduction } = useTranslatedEventData(event)\n\n if (!introduction) {\n return null\n }\n\n return (\n <EventDivider\n graphicSrc={participant.avatar}\n graphicType={participant.avatar ? 'avatar' : undefined}\n iconName={!participant.avatar ? 'balloon' : undefined}\n childrenHTML={introduction}\n dividerType=\"participant\"\n />\n )\n}\n\nexport default Participant\n","import { useCallback, useMemo, useState } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { useUserHasResponded } from 'domains/app/hooks'\nimport { setHasResponded } from 'domains/app/slice'\nimport { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { useTranslatedEventData } from 'domains/translations/hooks'\nimport { className } from 'lib/css'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport SuggestionsList from 'ui/components/suggestions/suggestions-list'\nimport { useEvents, useSeamlyCommands } from 'ui/hooks/seamly-hooks'\nimport { actionTypes } from 'ui/utils/seamly-utils'\n\nexport const useSuggestions = (event) => {\n const { payload } = event\n const { body: suggestions } = useTranslatedEventData(event)\n\n return {\n suggestions,\n payload,\n }\n}\n\nconst ConversationSuggestions = ({ event, ...props }) => {\n const [isExpanded, setIsExpanded] = useState(true)\n const dispatch = useDispatch()\n const userHasResponded = useUserHasResponded()\n const { sendAction, addMessageBubble } = useSeamlyCommands()\n const { suggestions, payload } = useSuggestions(event)\n const { showSuggestions } = useConfig()\n const events = useEvents()\n\n const { t } = useI18n()\n const headingText = t('suggestions.headingText')\n const footerText = t('suggestions.footerText')\n\n // We check if there is at least one last transaction\n // to avoid rendering the suggestions before prior events are rendered.\n const hasLastTransactionEvent = useMemo(\n () =>\n events.some(({ payload: eventPayload }) => eventPayload?.transactionLast),\n [events],\n )\n\n const handleClick = useCallback(\n ({ id, question }) => {\n setIsExpanded(false)\n dispatch(setHasResponded(true))\n\n // @todo Refactor to 'suggestionclick'\n sendAction({\n type: actionTypes.custom,\n originMessage: payload.id,\n body: {\n type: 'faqclick',\n body: {\n faqId: id,\n faqQuestion: question,\n },\n },\n })\n\n addMessageBubble(question)\n },\n [dispatch, sendAction, payload.id, addMessageBubble],\n )\n\n if (\n !isExpanded ||\n userHasResponded ||\n !hasLastTransactionEvent ||\n !showSuggestions\n ) {\n return null\n }\n\n return (\n <div className={className('suggestions', 'suggestions--conversation')}>\n {headingText && (\n <p className={className('suggestions__heading')}>{headingText}</p>\n )}\n <MessageContainer\n type=\"suggestions\"\n showParticipant={false}\n event={event}\n {...props}\n >\n <SuggestionsList\n className=\"suggestions__list--conversation\"\n onClickSuggestion={handleClick}\n suggestions={suggestions}\n />\n {footerText && (\n <p className={className('suggestions__footer')}>{footerText}</p>\n )}\n </MessageContainer>\n </div>\n )\n}\n\nexport default ConversationSuggestions\n","import { RefObject, createContext } from 'preact'\nimport { MutableRef } from 'preact/hooks'\n\nconst ChatScrollContext = createContext<{\n eventRefs: Record<string, RefObject<HTMLElement>>\n unreadIds: string[]\n scrollToRef: () => void\n scrollToBottom: () => void\n containerRef: MutableRef<HTMLDivElement>\n}>(null)\n\nexport default ChatScrollContext\n","import { useContext } from 'preact/hooks'\nimport ComponentContext from 'ui/components/conversation/component-context'\nimport { payloadTypes } from 'ui/utils/seamly-utils'\n\nconst useEventComponentMapping = (event) => {\n const components = useContext(ComponentContext)\n const componentType = components[event.type]\n let Component = componentType[event.payload.type]\n let SubComponent = null\n\n if (event.payload.type === payloadTypes.choicePrompt) {\n SubComponent = componentType[event.payload.body.prompt.type]\n }\n\n if (event.type === 'participant') {\n Component = componentType[event.type]\n }\n\n if (Component && typeof Component !== 'function') {\n Component = Component[event.payload.body.type]\n }\n\n return [Component || components?.fallback, SubComponent]\n}\n\nexport default useEventComponentMapping\n","import { FunctionComponent, useContext, useEffect } from 'preact/compat'\nimport { useDispatch } from 'react-redux'\nimport { setEventsRead } from 'domains/store/slice'\nimport { useIntersect } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport ChatScrollContext from 'ui/components/conversation/event/chat-scroll/chat-scroll-context'\nimport TimeIndicator from 'ui/components/conversation/event/divider/variants/time-indicator'\nimport { useSeamlyCommands } from 'ui/hooks/seamly-hooks'\nimport useEventComponentMapping from 'ui/hooks/use-event-component-mapping'\nimport { actionTypes } from 'ui/utils/seamly-utils'\n\nconst Event: FunctionComponent<{\n event\n newParticipant: boolean\n}> = ({ event, newParticipant }) => {\n const { eventRefs, unreadIds } = useContext(ChatScrollContext)\n const { sendAction } = useSeamlyCommands()\n const ref = eventRefs[event.payload.id]\n const { containerRef, isVisible } = useIntersect({\n containerRef: ref,\n freezeOnceVisible: true,\n })\n const dispatch = useDispatch()\n const [Component, SubComponent] = useEventComponentMapping(event)\n\n useEffect(() => {\n if (isVisible && unreadIds?.includes(event.payload.id)) {\n const readIds = unreadIds.reduce<string[]>(\n (arr, id) => (!arr.includes(event.payload.id) ? arr.concat(id) : arr),\n [],\n )\n\n dispatch(setEventsRead(readIds))\n sendAction({ type: actionTypes.read, events: readIds })\n }\n }, [dispatch, event.payload.id, isVisible, sendAction, unreadIds])\n\n if (!Component) {\n return null\n }\n\n const classNames = ['conversation__item']\n\n if (event.type === 'info') {\n classNames.push('conversation__item--source-info')\n } else if (event.payload.fromClient) {\n classNames.push('conversation__item--source-user')\n } else {\n classNames.push('conversation__item--source-agent')\n }\n\n if (newParticipant) {\n classNames.push('conversation__item--new-participant')\n }\n\n return (\n <li className={className(classNames)} ref={containerRef}>\n {event.timeIndicator && <TimeIndicator event={event} />}\n <Component event={event}>\n <SubComponent event={event} />\n </Component>\n </li>\n )\n}\n\nexport default Event\n","import { className } from 'lib/css'\nimport { useSeamlyCurrentAgent } from 'ui/hooks/seamly-hooks'\nimport EventParticipant from './event/event-participant'\n\nconst Loader = () => {\n const { id } = useSeamlyCurrentAgent() || {}\n\n return (\n <li\n className={className(\n 'conversation__item',\n 'conversation__item--source-agent',\n )}\n >\n <div\n className={className(\n 'message',\n 'message--source-agent',\n 'message--type-loading',\n )}\n >\n <EventParticipant\n eventPayload={{\n fromClient: false,\n participant: id,\n }}\n />\n <div className={className('message__body')}>\n <span className={className('loader')}>\n <span className={className('loader__part', 'one')} />\n <span className={className('loader__part', 'two')} />\n <span className={className('loader__part', 'three')} />\n <span className={className('loader__part', 'four')} />\n </span>\n </div>\n </div>\n </li>\n )\n}\n\nexport default Loader\n","import { useI18n } from 'domains/i18n/hooks'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport PrivacyDisclaimer from 'ui/components/layout/privacy-disclaimer'\nimport {\n useSeamlyIsLoading,\n useSkiplink,\n useSkiplinkTargetFocusing,\n} from 'ui/hooks/seamly-hooks'\nimport { useEvents } from 'ui/hooks/seamly-state-hooks'\nimport useDebounce from 'ui/hooks/use-debounce'\nimport AbortTransactionButton from '../entry/abort-transaction-button/abort-transaction-button'\nimport ComponentFilter from './component-filter'\nimport Event from './event/event'\nimport Loader from './loader'\n\nconst Events = () => {\n const events = useEvents()\n\n let prevParticipant = null\n return (\n <>\n {events.map((event) => {\n const { type, payload } = event\n\n let participantChanged = false\n if (type !== 'participant' && type !== 'service_data') {\n const { participant, fromClient } = payload\n const currentParticipant = fromClient\n ? 'seamly-client-participant'\n : participant\n if (event.type !== 'info' && prevParticipant !== currentParticipant) {\n participantChanged = true\n }\n prevParticipant = currentParticipant\n }\n\n return (\n <Event\n key={event.payload.key || event.payload.id}\n event={event}\n newParticipant={participantChanged}\n />\n )\n })}\n </>\n )\n}\n\nconst Conversation = () => {\n const { t } = useI18n()\n const isLoading = useSeamlyIsLoading()\n const debouncedIsLoading = useDebounce(isLoading, isLoading ? 0 : 20)\n const { isOpen } = useVisibility()\n const skiplinkTargetId = useSkiplink()\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n\n const onClickHandler = (e) => {\n e.preventDefault()\n focusSkiplinkTarget()\n }\n\n return (\n <>\n {isOpen && (\n <a\n className={className('skip-link')}\n href={`#${skiplinkTargetId}`}\n onClick={onClickHandler}\n >\n {t('skiplinkText')}\n </a>\n )}\n\n <div className={className('chat__body')}>\n <div className={className('conversation__container')}>\n <PrivacyDisclaimer />\n <ol className={className('conversation')}>\n <ComponentFilter>\n <Events />\n </ComponentFilter>\n {debouncedIsLoading ? <Loader /> : null}\n <AbortTransactionButton />\n </ol>\n </div>\n </div>\n </>\n )\n}\n\nexport default Conversation\n","import { useEffect, useRef, useState } from 'preact/hooks'\n\nconst useDebounce = <T extends unknown>(value: T, delay = 20): T => {\n const [debouncedValue, setDebouncedValue] = useState<T>(value)\n const timeoutRef = useRef<ReturnType<typeof setTimeout>>(null)\n\n useEffect(() => {\n timeoutRef.current = setTimeout(() => setDebouncedValue(value), delay)\n\n return () => {\n clearTimeout(timeoutRef.current)\n }\n }, [value, delay])\n\n return debouncedValue\n}\n\nexport default useDebounce\n","import { className } from 'lib/css'\nimport { useGeneratedId, useSkiplink } from 'ui/hooks/seamly-hooks'\n\nconst Prompt = ({ baseClassName, children, title }) => {\n const skiplinkTargetId = useSkiplink()\n const containerHeadingId = useGeneratedId()\n\n return (\n <section\n id={skiplinkTargetId}\n className={className(baseClassName)}\n aria-describedby={containerHeadingId}\n tabIndex=\"-1\"\n >\n <h2\n className={className(`${baseClassName}__title`)}\n id={containerHeadingId}\n >\n {title}\n </h2>\n {children}\n </section>\n )\n}\n\nexport default Prompt\n","import { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport { useSkiplinkTargetFocusing } from 'ui/hooks/focus-helper-hooks'\nimport useSeamlyActivityEventHandler from 'ui/hooks/use-seamly-activity-event-handler'\nimport useSeamlyCommands from 'ui/hooks/use-seamly-commands'\nimport useSeamlyIdleDetachCountdown from 'ui/hooks/use-seamly-idle-detach-countdown'\nimport Prompt from './prompt'\n\nconst IdleDetachWarning = () => {\n const { t } = useI18n()\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n const sendActivity = useSeamlyActivityEventHandler()\n const { emitEvent } = useSeamlyCommands()\n\n const { isActive, remaining, timer, endCountdown } =\n useSeamlyIdleDetachCountdown()\n\n const continueChat = () => {\n sendActivity()\n endCountdown(true)\n focusSkiplinkTarget()\n emitEvent('idleTimer.selectContinue')\n }\n\n const transferChat = () => {\n endCountdown()\n focusSkiplinkTarget()\n emitEvent('idleTimer.selectEnd')\n }\n\n const countDownComplete = remaining > 0\n const title = countDownComplete\n ? t('idleDetachWarning.countdownTitle')\n : t('idleDetachWarning.notifyTransferText')\n\n return (\n <Prompt baseClassName=\"idle\" title={title}>\n {countDownComplete && (\n <>\n <div className={className('idle__count-container')}>\n {isActive && (\n <>\n <span className={className('idle__count-text')}>\n {t('idleDetachWarning.countdownText')}\n </span>\n <span className={className('idle__count-timer')}>\n {t('idleDetachWarning.countdownTimer', timer)}\n </span>\n </>\n )}\n </div>\n <div className={className('idle__options')}>\n <button\n type=\"button\"\n className={className('button', 'button--primary')}\n onClick={continueChat}\n >\n {t('idleDetachWarning.continueButton')}\n </button>\n <button\n type=\"button\"\n className={className('button', 'button--primary')}\n onClick={transferChat}\n >\n {t('idleDetachWarning.detachButton')}\n </button>\n </div>\n </>\n )}\n </Prompt>\n )\n}\n\nexport default IdleDetachWarning\n","import { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport { useSeamlyCurrentAgent } from 'ui/hooks/seamly-state-hooks'\nimport useSeamlyActivityEventHandler from 'ui/hooks/use-seamly-activity-event-handler'\nimport useSeamlyResumeConversationPrompt from 'ui/hooks/use-seamly-resume-conversation-prompt'\nimport Prompt from './prompt'\n\nconst ResumeConversationPrompt = () => {\n const { t } = useI18n()\n const sendActivity = useSeamlyActivityEventHandler()\n const { name: currentAgentName } = useSeamlyCurrentAgent() || {}\n\n const { continueChat, restartChat } = useSeamlyResumeConversationPrompt()\n\n const continueChatHandler = () => {\n sendActivity()\n continueChat()\n }\n\n return (\n <Prompt\n baseClassName=\"prompt\"\n title={t('resumeConversationPrompt.title', { name: currentAgentName })}\n >\n <div className={className('prompt__options')}>\n <button\n type=\"button\"\n className={className('button', 'button--primary')}\n onClick={continueChatHandler}\n >\n {t('resumeConversationPrompt.continueButton')}\n </button>\n <button\n type=\"button\"\n className={className('button', 'button--primary')}\n onClick={restartChat}\n >\n {t('resumeConversationPrompt.detachButton')}\n </button>\n </div>\n </Prompt>\n )\n}\n\nexport default ResumeConversationPrompt\n","import { useCallback, useEffect, useRef } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { typingTimeout } from 'config'\nimport {\n setActiveEntryType,\n setBlockAutoEntrySwitch,\n setUserEntryType,\n} from 'domains/store/slice'\nimport { useSeamlyCommands, useSeamlyOptions } from 'ui/hooks/seamly-hooks'\nimport { useSeamlyStateContext } from 'ui/hooks/seamly-state-hooks'\nimport { actionTypes } from 'ui/utils/seamly-utils'\n\nexport const useSeamlyTyping = () => {\n const { sendAction } = useSeamlyCommands()\n const { features } = useSeamlyOptions()\n const { typingPeekahead } = features || {}\n const typingTimerId = useRef(null)\n const sendEndTypingTimerId = useRef(null)\n const isTyping = useRef(false)\n const typingIntervalId = useRef(null)\n\n useEffect(() => {\n return () => {\n clearInterval(typingIntervalId.current)\n clearTimeout(typingTimerId.current)\n clearTimeout(sendEndTypingTimerId.current)\n }\n }, [])\n\n const sendTypingState = (state, currentMessage) => {\n sendAction({\n type: actionTypes.typing,\n state,\n ...(typingPeekahead && typingPeekahead.enabled\n ? {\n body: {\n currentMessage,\n },\n }\n : {}),\n })\n }\n\n return (e) => {\n if ((e.code && e.code === 'Enter') || e.keyCode === 13) {\n return\n }\n\n isTyping.current = true\n if (!typingIntervalId.current) {\n sendTypingState(true, e.target.value)\n typingIntervalId.current = setInterval(() => {\n if (!isTyping.current) {\n clearInterval(typingIntervalId.current)\n typingIntervalId.current = null\n } else if (typingPeekahead && typingPeekahead.enabled) {\n sendTypingState(true, e.target.value)\n }\n }, typingTimeout)\n }\n\n clearTimeout(typingTimerId.current)\n clearTimeout(sendEndTypingTimerId.current)\n\n typingTimerId.current = setTimeout(() => {\n isTyping.current = false\n }, 300)\n\n sendEndTypingTimerId.current = setTimeout(() => {\n sendTypingState(false, e.target.value)\n }, typingTimeout)\n }\n}\n\nexport const useSeamlyEntry = () => {\n const {\n default: defaultEntry,\n active,\n userSelected,\n options: entryOptions,\n optionsOverride: entryOptionsOverride,\n } = useSeamlyStateContext().entryMeta\n const dispatch = useDispatch()\n\n const activeEntry = userSelected || active || defaultEntry\n const activeEntryOptions =\n entryOptionsOverride[activeEntry] || entryOptions[activeEntry] || {}\n\n const dispatchBlockAutoEntrySwitch = useCallback(\n (value) => {\n dispatch(setBlockAutoEntrySwitch(value))\n },\n [dispatch],\n )\n\n const dispatchActiveEntryType = useCallback(\n (entryType) => {\n dispatch(setActiveEntryType(entryType))\n },\n [dispatch],\n )\n\n const dispatchUserEntryType = useCallback(\n (entryType) => {\n dispatch(setUserEntryType(entryType))\n },\n [dispatch],\n )\n\n const cancelEntrySelection = useCallback(() => {\n if (userSelected) {\n dispatchUserEntryType(null)\n } else {\n dispatchActiveEntryType(defaultEntry)\n }\n }, [\n userSelected,\n defaultEntry,\n dispatchUserEntryType,\n dispatchActiveEntryType,\n ])\n\n return {\n activeEntry,\n activeEntryOptions,\n setActiveEntryType: dispatchActiveEntryType,\n setUserEntryType: dispatchUserEntryType,\n cancelEntrySelection,\n setBlockAutoEntrySwitch: dispatchBlockAutoEntrySwitch,\n }\n}\n","import {\n useCallback,\n useEffect,\n useLayoutEffect,\n useMemo,\n useState,\n} from 'preact/hooks'\nimport { useDispatch, useSelector } from 'react-redux'\nimport { setHasResponded } from 'domains/app/slice'\nimport { Provider } from 'domains/forms/context'\nimport { useValidations } from 'domains/forms/hooks'\nimport { getFormValuesByFormId } from 'domains/forms/selectors'\nimport {\n deregisterForm,\n updateControlTouched as dispatchControlTouched,\n updateControlValue as dispatchControlValue,\n registerForm,\n} from 'domains/forms/slice'\nimport type { RootState } from 'domains/store'\n\nexport default function FormProvider({\n children,\n formId,\n persistData,\n onError,\n onSubmit,\n validationSchema,\n ...props\n}) {\n const dispatch = useDispatch()\n const values = useSelector((store: RootState) =>\n getFormValuesByFormId(store, { formId }),\n )\n const [isSubmitted, setIsSubmitted] = useState(false)\n const [externalErrors, setExternalErrors] = useState({})\n const { isValid: validationIsValid, errors: validationErrors } =\n useValidations(values, validationSchema)\n const errors = useMemo(\n () => ({\n ...validationErrors,\n ...externalErrors,\n }),\n [validationErrors, externalErrors],\n )\n\n // register\n useLayoutEffect(() => {\n // register form in redux store\n dispatch(registerForm({ formId, persistData }))\n }, [formId, persistData, dispatch])\n\n // deregister\n useEffect(() => {\n return () => {\n // deregister form from redux store\n dispatch(deregisterForm({ formId }))\n }\n }, [formId, persistData, dispatch])\n\n const updateControlValue = useCallback(\n (name, value) => {\n dispatch(dispatchControlValue({ formId, name, value }))\n },\n [formId, dispatch],\n )\n\n const updateControlTouched = useCallback(\n (name, touched) => {\n dispatch(dispatchControlTouched({ formId, name, touched }))\n },\n [dispatch, formId],\n )\n\n // Function to manually set an error\n const setError = useCallback(\n (name, error) => {\n setExternalErrors((val) => {\n return {\n ...val,\n [name]: error,\n }\n })\n },\n [setExternalErrors],\n )\n\n const handleSubmit = useCallback(\n (e) => {\n e.preventDefault()\n // If the submitter is set to being aria-disabled, block the submit action\n const ariaDisabled = e.submitter.getAttribute('aria-disabled') === 'true'\n setIsSubmitted(!ariaDisabled)\n if (!ariaDisabled && validationIsValid) {\n dispatch(setHasResponded(true))\n onSubmit(values, { updateControlValue, setError })\n }\n },\n [\n validationIsValid,\n dispatch,\n onSubmit,\n values,\n updateControlValue,\n setError,\n ],\n )\n\n useEffect(() => {\n if (onError) {\n onError({\n errors,\n isSubmitted,\n isValid: Object.keys(errors).length === 0,\n })\n }\n }, [isSubmitted, errors, onError])\n\n const contextValue = useMemo(\n () => ({\n formId,\n values,\n errors,\n isValid: Object.keys(errors).length === 0,\n isSubmitted,\n handleSubmit,\n validationSchema,\n updateControlValue,\n updateControlTouched,\n }),\n [\n formId,\n values,\n errors,\n isSubmitted,\n handleSubmit,\n validationSchema,\n updateControlValue,\n updateControlTouched,\n ],\n )\n\n if (!formId) {\n console.error('\"formId\" is required.')\n return null\n }\n if (!onSubmit) {\n console.error('\"onSubmit\" is required.')\n return null\n }\n\n return (\n <Provider {...props} value={contextValue}>\n {children}\n </Provider>\n )\n}\n","export function validate(values, schema: Record<string, unknown> = {}) {\n return Object.entries(schema).reduce((errors, [key, validations]) => {\n const validationsArr = !Array.isArray(validations)\n ? [validations]\n : validations\n\n for (let i = 0; i < validationsArr?.length ?? 0; i++) {\n if (!validationsArr[i].fn(values[key], validationsArr[i].compareValue)) {\n errors[key] = validationsArr[i].errorText\n break\n }\n }\n return errors\n }, {})\n}\n","import { useForm } from 'domains/forms/hooks'\nimport { className } from 'lib/css'\n\nfunction Form({\n className: givenClassName,\n disableValidationClasses,\n ...props\n}) {\n const { handleSubmit, isValid, isSubmitted } = useForm()\n\n const formClasses = ['form']\n\n if (!disableValidationClasses && isSubmitted) {\n formClasses.push('form--submitted')\n\n if (isValid) {\n formClasses.push('form--valid')\n } else {\n formClasses.push('form--invalid')\n }\n }\n\n return (\n <form\n onSubmit={handleSubmit}\n className={className([...formClasses, givenClassName])}\n {...props}\n />\n )\n}\n\nexport default Form\n","import { useEffect, useState } from 'preact/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\n\nexport default function Error({ id, error }) {\n const [isAvailable, setIsAvailable] = useState(false)\n useEffect(() => {\n const timerId = setTimeout(() => setIsAvailable(true), 300) // 300 = magic number, could be less or more\n return () => clearTimeout(timerId) // clear timer if error is mounted+unmounted within 300\n }, [])\n\n return (\n <div\n className={className('error')}\n aria-live=\"assertive\"\n aria-atomic=\"true\"\n >\n {isAvailable && error && (\n <span id={id} className={className('error__message')}>\n <Icon name=\"error\" size=\"16\" alt=\"\" />\n {error}\n </span>\n )}\n </div>\n )\n}\n","import { FC } from 'preact/compat'\nimport { className } from 'lib/css'\nimport Error from './error'\n\ntype FormControlWrapperProps = {\n contentHint: string\n id: string\n labelText: string\n labelClass: string\n validity: boolean\n errorText: unknown\n}\n\nconst FormControlWrapper: FC<FormControlWrapperProps> = ({\n contentHint,\n id,\n labelText,\n labelClass,\n validity,\n errorText,\n children,\n}) => {\n return (\n <>\n {contentHint && (\n <span\n id={`${id}-content-hint`}\n className={className('input__content-hint')}\n >\n {contentHint}\n </span>\n )}\n\n <Error id={`${id}-error`} error={!validity && errorText} />\n\n <div className={className('form-control__wrapper')}>\n <label htmlFor={id} className={className(labelClass)}>\n {labelText}\n </label>\n {children}\n </div>\n </>\n )\n}\n\nexport default FormControlWrapper\n","import { HTMLAttributes } from 'preact/compat'\nimport { useFormContext, useFormControl } from 'domains/forms/hooks'\nimport FormControlWrapper from './wrapper'\n\ntype InputProps = HTMLAttributes<HTMLInputElement> & {\n id: string\n name: string\n type: string\n labelText: string\n labelClass: string\n contentHint?: string\n 'aria-describedby'?: string\n}\n\nfunction Input({\n id,\n name,\n type,\n labelText,\n labelClass,\n contentHint = null,\n 'aria-describedby': ariaDescribedBy,\n ...props\n}: InputProps) {\n const { isSubmitted } = useFormContext()\n const [field, { error }] = useFormControl(name)\n const hasError = isSubmitted && error\n\n const describedByIds = []\n if (ariaDescribedBy) {\n describedByIds.push(ariaDescribedBy)\n }\n if (contentHint) {\n describedByIds.push(`${id}-content-hint`)\n }\n if (hasError) {\n describedByIds.push(`${id}-error`)\n }\n\n // todo: destructure Field\n return (\n <FormControlWrapper\n id={id}\n contentHint={contentHint}\n validity={!hasError}\n errorText={error}\n labelText={labelText}\n labelClass={labelClass}\n >\n <input\n id={id}\n name={name}\n type={type}\n aria-invalid={hasError ? 'true' : 'false'}\n aria-describedby={describedByIds.join(' ') || null}\n {...field}\n {...props}\n />\n </FormControlWrapper>\n )\n}\n\nexport default Input\n","import { useCallback, useLayoutEffect } from 'preact/hooks'\nimport { useFormControl } from 'domains/forms/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport Form from 'ui/components/form-controls/form'\nimport Input from 'ui/components/form-controls/input'\nimport Icon from 'ui/components/layout/icon'\nimport { useSeamlyEntry, useSeamlyTyping } from 'ui/hooks/seamly-entry-hooks'\nimport { useLiveRegion, useSeamlyCommands } from 'ui/hooks/seamly-hooks'\nimport { useCharacterLimit, useEntryTextTranslation } from './hooks'\n\nexport default function TextEntryForm({ controlName, skipLinkId }) {\n const { t } = useI18n()\n const { sendAssertive } = useLiveRegion()\n const { emitEvent } = useSeamlyCommands()\n const handleKeyUp = useSeamlyTyping()\n const { setBlockAutoEntrySwitch } = useSeamlyEntry()\n const { placeholder, label, labelClass } =\n useEntryTextTranslation(controlName)\n // TODO: Standardize the validation on form fields\n const {\n hasCharacterLimit,\n reachedCharacterWarning,\n reachedCharacterLimit,\n remainingChars,\n } = useCharacterLimit(controlName)\n const [{ value }] = useFormControl(controlName)\n\n const hasValue = !!value\n\n const handleFocus = useCallback(() => {\n if (reachedCharacterWarning) {\n sendAssertive(t('input.srCharacterLimitText', { limit: remainingChars }))\n }\n\n emitEvent('ui.inputFocus')\n }, [t, sendAssertive, reachedCharacterWarning, remainingChars, emitEvent])\n\n // When the input holds a value, the component should be blocked from switching\n // to file upload form.\n useLayoutEffect(() => {\n setBlockAutoEntrySwitch(hasValue)\n\n return () => {\n setBlockAutoEntrySwitch(false)\n }\n }, [setBlockAutoEntrySwitch, hasValue])\n\n const handlePointerDown = (event) => {\n // When a message is submitted, the keyboard should be prevented from closing on mobile devices\n event.preventDefault()\n }\n\n return (\n <Form\n className={className('entry-form')}\n disableValidationClasses\n noValidate=\"true\"\n >\n <div\n className={className([\n 'input--text__container',\n ...(reachedCharacterWarning && !reachedCharacterLimit\n ? ['character-warning']\n : []),\n ...(reachedCharacterLimit ? ['character-exceeded'] : []),\n ])}\n >\n <Input\n id={skipLinkId}\n type=\"text\"\n name={controlName}\n className={className('input__text')}\n autocomplete=\"off\"\n placeholder={placeholder}\n labelText={label}\n labelClass={className(labelClass)}\n aria-invalid={hasCharacterLimit ? reachedCharacterLimit : null}\n onKeyUp={handleKeyUp}\n onFocus={handleFocus}\n />\n <div className={className('character-count')}>\n {reachedCharacterWarning && <span>{remainingChars}</span>}\n </div>\n </div>\n <button\n className={className('button', 'input__submit')}\n type=\"submit\"\n onPointerDown={handlePointerDown}\n aria-disabled={!hasValue || reachedCharacterLimit ? 'true' : null}\n >\n <Icon name=\"send\" size=\"32\" alt={t('input.sendMessage')} />\n </button>\n </Form>\n )\n}\n","import { useCallback } from 'preact/hooks'\nimport FormProvider from 'domains/forms/provider'\nimport { visibilityStates } from 'domains/visibility/constants'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport {\n useSeamlyCommands,\n useSkiplink,\n useSkiplinkTargetFocusing,\n} from 'ui/hooks/seamly-hooks'\nimport TextEntryForm from './text-entry-form'\n\nexport const textEntryControlName = 'textMessageEntry'\n\nexport default function TextEntry({ ...props }) {\n const { isOpen, setVisibility } = useVisibility()\n const skipLinkId = useSkiplink()\n const focusSkipLinkTarget = useSkiplinkTargetFocusing()\n const { sendMessage } = useSeamlyCommands()\n const handleSubmit = useCallback(\n (values, { updateControlValue }) => {\n sendMessage({ body: values[textEntryControlName] })\n updateControlValue(textEntryControlName, '')\n focusSkipLinkTarget()\n\n if (!isOpen) {\n setVisibility(visibilityStates.open)\n }\n },\n [sendMessage, focusSkipLinkTarget, isOpen, setVisibility],\n )\n\n return (\n <FormProvider\n {...props}\n formId=\"textEntry\"\n persistData={true}\n onSubmit={handleSubmit}\n >\n <TextEntryForm\n controlName={textEntryControlName}\n skipLinkId={skipLinkId}\n />\n </FormProvider>\n )\n}\n","import { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport Error from 'ui/components/form-controls/error'\nimport { useFileUploads } from 'ui/hooks/seamly-hooks'\n\nconst UploadProgress = () => {\n const { t } = useI18n()\n const { currentUploads } = useFileUploads()\n\n return (\n <div className={className('progress')}>\n {currentUploads.map(({ id, name, progress, uploading, error }) => (\n <div key={id} className={className('progress_container')}>\n <div className={className('progress__text')}>\n <span className={className('progress__text--file-name')}>\n {name}\n </span>\n <span\n className={className('progress__text--percentage')}\n >{`${progress}%`}</span>\n </div>\n <Error error={error} />\n <progress\n className={className('progress__bar')}\n role=\"progressbar\"\n aria-valuemin=\"0\"\n aria-valuemax=\"100\"\n aria-label={t('fileUpload.srProgressLabel', { fileName: name })}\n max=\"100\"\n aria-valuenow={progress}\n value={progress}\n aria-busy={uploading}\n >\n {`${progress}%`}\n </progress>\n </div>\n ))}\n </div>\n )\n}\n\nexport default UploadProgress\n","export const getValidator = (fn, errorText, compareValue = null) => ({\n fn,\n errorText,\n compareValue,\n})\n","export const validateFileSize = (fileList, maxSize) => {\n let isValid = true\n for (let i = 0; i < fileList.length; i++) {\n if (fileList[i].size > maxSize) {\n isValid = false\n }\n }\n\n return isValid\n}\n\nexport const fileListObjectIsNotEmpty = (fileListObj) =>\n !!fileListObj?.length > 0\n\n/* eslint-disable no-control-regex */\nexport const isEmailString = (val) => {\n const regex =\n /^(?:[a-z0-9!#$%&'*+/=?^_`{|}~-]+(?:\\.[a-z0-9!#$%&'*+/=?^_`{|}~-]+)*|\"(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21\\x23-\\x5b\\x5d-\\x7f]|\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])*\")@(?:(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?|\\[(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?|[a-z0-9-]*[a-z0-9]:(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21-\\x5a\\x53-\\x7f]|\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])+)\\])$/i\n const trimmedVal = val && val.trim()\n return !!(trimmedVal && trimmedVal.match(regex))\n}\n/* eslint-enable no-control-regex */\n\nexport const isNotEmptyString = (val) => !!val\n","import { useCallback, useState } from 'preact/hooks'\nimport { useFormContext, useFormControl } from 'domains/forms/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport { useGeneratedId } from 'ui/hooks/seamly-hooks'\nimport Error from './error'\n\nexport default function FileInput({\n id,\n name,\n labelText,\n contentHint,\n outputText,\n accept,\n}) {\n const { isSubmitted } = useFormContext()\n const [focusWithin, setFocusWithin] = useState(false)\n const [{ onInput, onBlur }, { error }] = useFormControl(name)\n const errorId = useGeneratedId()\n const contentHintId = useGeneratedId()\n const outputId = useGeneratedId()\n const hasError = isSubmitted && error\n\n const describedByIds = [outputId]\n if (contentHint) {\n describedByIds.push(contentHintId)\n }\n if (hasError) {\n describedByIds.push(errorId)\n }\n\n const handleFocus = useCallback(() => {\n setFocusWithin(true)\n }, [setFocusWithin])\n\n const handleBlur = useCallback(() => {\n setFocusWithin(false)\n onBlur()\n }, [setFocusWithin, onBlur])\n\n const handleChange = useCallback(\n (e) => {\n const customEvent = {\n target: {\n value: e.target.files,\n },\n }\n\n onInput(customEvent)\n },\n [onInput],\n )\n\n return (\n <div className={className('upload__container')}>\n {contentHint && (\n <span className={className('upload__content-hint')} id={contentHintId}>\n {contentHint}\n </span>\n )}\n <Error id={errorId} error={hasError && error} />\n <div\n className={className([\n 'file-upload',\n ...(focusWithin ? ['focus-within'] : []),\n ])}\n >\n <label htmlFor={id} className={className('upload__label')}>\n <Icon name=\"upload\" size=\"32\" alt=\"\" />\n <div>\n <span className={className(['upload__label--text'])}>\n {labelText}\n </span>\n <input\n id={id}\n className={className('upload__input')}\n type=\"file\"\n name={name}\n onChange={handleChange}\n aria-invalid={hasError ? 'true' : 'false'}\n aria-describedby={describedByIds.join(' ')}\n accept={accept || null}\n onFocus={handleFocus}\n onBlur={handleBlur}\n />\n <span\n className={className('upload__output')}\n aria-hidden=\"true\"\n id={outputId}\n >\n {outputText}\n </span>\n </div>\n </label>\n </div>\n </div>\n )\n}\n","import { useFormControl } from 'domains/forms/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport FileInput from 'ui/components/form-controls/file-input'\nimport Form from 'ui/components/form-controls/form'\n\nexport default function FileInputForm({\n skiplinkId,\n controlName,\n accept,\n contentHint,\n isUploading,\n isComplete,\n onClickCancel,\n}) {\n const { t } = useI18n()\n const [{ value: fileList }] = useFormControl(controlName)\n const hasFile = fileList && fileList.length > 0\n const selectedFileName = hasFile ? fileList[0].name : ''\n\n return (\n <Form className={className('upload-form')}>\n <FileInput\n name={controlName}\n id={skiplinkId}\n accept={accept}\n labelText={t('fileUpload.labelText')}\n outputText={t('fileUpload.selectedText', {\n hasFile,\n filename: selectedFileName,\n })}\n contentHint={contentHint}\n />\n <div className={className('upload__button-container')}>\n <button\n id={isUploading || !isComplete ? skiplinkId : undefined}\n type=\"button\"\n onClick={onClickCancel}\n className={className('button', 'button--secondary', 'upload__cancel')}\n >\n {t('fileUpload.cancelButtonText')}\n </button>\n <button\n className={className('button', 'button--primary')}\n type=\"submit\"\n >\n {t('fileUpload.uploadButtonText')}\n </button>\n </div>\n </Form>\n )\n}\n","import { useCallback, useEffect, useMemo, useRef } from 'preact/hooks'\nimport FormProvider from 'domains/forms/provider'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport UploadProgress from 'ui/components/widgets/upload-progress'\nimport { useSeamlyEntry } from 'ui/hooks/seamly-entry-hooks'\nimport {\n useFileUploadMeta,\n useFileUploads,\n useGeneratedId,\n useLiveRegion,\n useSkiplink,\n useSkiplinkTargetFocusing,\n} from 'ui/hooks/seamly-hooks'\nimport useSingleFileUpload from 'ui/hooks/use-single-file-upload'\nimport { getValidator } from 'ui/utils/form-utils'\nimport { formatBytes } from 'ui/utils/general-utils'\nimport {\n fileListObjectIsNotEmpty,\n validateFileSize,\n} from 'ui/utils/validations'\nimport FileInputForm from './file-upload-form'\n\nconst formName = 'fileListForm'\nconst fileInputName = 'fileList'\n\nconst Upload = () => {\n const { t } = useI18n()\n const { sendPolite, sendAssertive } = useLiveRegion()\n const skiplinkTargetId = useSkiplink()\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n // This hook should be refactored at some point\n const { serviceAllowsUploads, allowedMimeTypes, maxSize } =\n useFileUploadMeta()\n const cancelButtonRef = useRef(null)\n const canUpload = useRef(serviceAllowsUploads)\n\n const { cancelEntrySelection } = useSeamlyEntry()\n const { uploadFile, clearUploads, isUploading, isComplete } = useFileUploads()\n\n const hasError = false\n\n const { hasFile, selectedFileName, uploadHandle, hasServerError, progress } =\n useSingleFileUpload(formName, fileInputName)\n const notificationId = useGeneratedId()\n const prevIsComplete = useRef(true)\n\n const contentHintText = t('fileUpload.contentHint', {\n size: formatBytes(maxSize),\n })\n const prevContentHintText = useRef('')\n const containerRef = useRef(null)\n\n useEffect(() => {\n if (\n prevContentHintText.current &&\n containerRef.current?.contains(document.activeElement) &&\n document.activeElement.tagName === 'INPUT'\n ) {\n sendAssertive(contentHintText)\n }\n prevContentHintText.current = contentHintText\n }, [contentHintText, sendAssertive])\n\n // a11y\n useEffect(() => {\n if (progress > 0) {\n switch (progress) {\n case 1:\n sendPolite(t('fileUpload.srStartedText'))\n break\n default:\n sendPolite(`${progress}%`)\n }\n }\n }, [progress, sendPolite, t])\n\n // reset form when uploads are complete\n useEffect(() => {\n if (!prevIsComplete.current && !isUploading && isComplete) {\n clearUploads()\n cancelEntrySelection()\n focusSkiplinkTarget()\n // This timeout is set as testing in VoiceOver revealed that 300 ms is needed for\n // the live region to resolve in this case.\n setTimeout(() => {\n sendPolite(t('fileUpload.srCompleteText'))\n }, 300)\n }\n prevIsComplete.current = isComplete\n }, [\n isUploading,\n isComplete,\n clearUploads,\n cancelEntrySelection,\n focusSkiplinkTarget,\n sendPolite,\n t,\n ])\n\n const handleSubmit = useCallback(\n ({ fileList }) => {\n uploadFile(fileList[0])\n\n if (!hasError) {\n focusSkiplinkTarget()\n }\n },\n [uploadFile, hasError, focusSkiplinkTarget],\n )\n\n const handleOnClickCancel = useCallback(() => {\n if (uploadHandle) {\n uploadHandle.abort()\n }\n clearUploads()\n cancelEntrySelection()\n focusSkiplinkTarget()\n }, [uploadHandle, clearUploads, cancelEntrySelection, focusSkiplinkTarget])\n\n const validationSchema = useMemo(\n () => ({\n [fileInputName]: [\n // For now this is fine, but this shouldn't be a validation on the field itself\n getValidator(\n () => serviceAllowsUploads,\n t('fileUpload.errors.unavailable'),\n ),\n getValidator(fileListObjectIsNotEmpty, t('fileUpload.errors.noFile')),\n getValidator(\n validateFileSize,\n t('fileUpload.errors.tooLarge'),\n maxSize,\n ),\n ],\n }),\n [maxSize, serviceAllowsUploads, t],\n )\n\n return (\n <div\n className={className([\n 'upload',\n ...(hasError || hasServerError ? ['upload--error'] : []),\n ])}\n ref={containerRef}\n >\n <FormProvider\n formId={formName}\n persistData={true}\n onSubmit={handleSubmit}\n validationSchema={validationSchema}\n >\n {(isUploading || !isComplete) && (\n <>\n <UploadProgress />\n <div className={className('upload__button-container')}>\n <button\n id={isUploading || !isComplete ? skiplinkTargetId : undefined}\n type=\"button\"\n onClick={handleOnClickCancel}\n ref={cancelButtonRef}\n className={className(\n 'button',\n 'button--secondary',\n 'upload__cancel',\n )}\n >\n {t('fileUpload.cancelButtonText')}\n </button>\n </div>\n </>\n )}\n {!isUploading && isComplete && (\n <FileInputForm\n controlName={fileInputName}\n skiplinkId={skiplinkTargetId}\n accept={allowedMimeTypes.join(', ')}\n contentHint={contentHintText}\n isComplete={isComplete}\n isUploading={isUploading}\n outputText={t('fileUpload.selectedText', {\n hasFile,\n filename: selectedFileName,\n })}\n onClickCancel={handleOnClickCancel}\n />\n )}\n\n {!canUpload.current && (\n <>\n <span className={className('notification')} id={notificationId}>\n {t('fileUpload.unavailableText')}\n </span>\n <div className={className('upload__button-container')}>\n <button\n id={isUploading || !isComplete ? skiplinkTargetId : undefined}\n type=\"button\"\n onClick={handleOnClickCancel}\n className={className(\n 'button',\n 'button--secondary',\n 'upload__cancel',\n )}\n >\n {t('fileUpload.cancelButtonText')}\n </button>\n </div>\n </>\n )}\n </FormProvider>\n </div>\n )\n}\n\nexport default Upload\n","import { useSelector } from 'react-redux'\nimport { getControlValueByName } from 'domains/forms/selectors'\nimport { useFileUploads } from './seamly-hooks'\n\nconst useSingleFileUpload = (formId, name) => {\n const fileList = useSelector((store) =>\n getControlValueByName(store, { formId, name }),\n )\n // This hook acts as a helper as the data model is built to handle multiple\n // file uploads but currently Seamly only supports single file uploads.\n // This hook HAS to be used inside the FormBoundary of the file upload.\n const { currentUploads } = useFileUploads()\n\n const hasFile = fileList && fileList.length > 0\n\n let uploadHandle = null\n let hasServerError = false\n let progress = 0\n if (currentUploads && currentUploads.length > 0) {\n const currentUpload = currentUploads[0]\n uploadHandle = currentUpload.uploadHandle\n hasServerError = !!currentUpload.error\n progress = currentUpload.progress\n }\n\n return {\n hasFile,\n selectedFileName: hasFile ? fileList[0].name : '',\n uploadHandle,\n hasServerError,\n progress,\n }\n}\n\nexport default useSingleFileUpload\n","import { useEffect, useRef } from 'preact/hooks'\n\nexport default function useTimeout(callback: Function, delay?: number) {\n const timeoutRef = useRef<number | null>(null)\n const savedCallback = useRef(callback)\n\n useEffect(() => {\n savedCallback.current = callback\n }, [callback])\n\n useEffect(() => {\n if (typeof delay !== 'number') return () => undefined\n\n timeoutRef.current = setTimeout(savedCallback.current, delay)\n\n return () => clearTimeout(timeoutRef.current)\n }, [delay])\n\n return timeoutRef\n}\n","import { VNode, cloneElement, toChildArray } from 'preact'\nimport { FC } from 'preact/compat'\nimport { useEffect, useMemo, useRef, useState } from 'preact/hooks'\nimport { defaultTransitionTimeMs } from 'config'\nimport { className } from 'lib/css'\nimport { useStableCallback } from 'ui/hooks/seamly-hooks'\nimport useTimeout from 'ui/hooks/use-timeout'\n\ntype VDOMChild = string | number | VNode\ntype ValueOf<T> = T[keyof T]\nfunction childIsVNode(\n child: VDOMChild,\n): child is VNode<{ className?: string }> {\n return typeof child === 'object'\n}\n\nconst transitionClasses = {\n visible: className('transition--visible'),\n in: className('transition--in'),\n visuallyHidden: className('visually-hidden'),\n}\n\nconst transitionClassesArray = Object.values(transitionClasses)\n\nexport const transitionStartStates = {\n notRendered: 'notRendered',\n rendered: 'rendered',\n visuallyHidden: 'visuallyHidden',\n} as const\n\ntype InOutTransitionProps = {\n isActive: boolean\n timeout?: number\n transitionStartState?: keyof typeof transitionStartStates\n onInTransitionComplete?: Function\n onOutTransitionComplete?: Function\n exitAfter?: number\n enterDelay?: number\n}\n\nconst InOutTransition: FC<InOutTransitionProps> = ({\n children,\n isActive,\n timeout = defaultTransitionTimeMs,\n transitionStartState = transitionStartStates.notRendered,\n onInTransitionComplete = () => {},\n onOutTransitionComplete = () => {},\n exitAfter,\n enterDelay = 0,\n}) => {\n const prevIsActive = useRef(false)\n\n const isVisuallyHidden =\n transitionStartState === transitionStartStates.visuallyHidden\n\n const [activeTransitionClasses, setActiveTransitionClasses] = useState<\n ValueOf<typeof transitionClasses>[]\n >(() => (isVisuallyHidden ? [transitionClasses.visuallyHidden] : []))\n\n const [inState, setInState] = useState(() => enterDelay === 0)\n\n const transitionOutAfter = useMemo(\n () => (exitAfter ? exitAfter + enterDelay : exitAfter),\n [enterDelay, exitAfter],\n )\n\n useTimeout(() => setInState(false), isActive ? transitionOutAfter : undefined)\n useTimeout(() => setInState(true), isActive ? enterDelay : undefined)\n\n const transitionIn = useMemo(() => inState && isActive, [isActive, inState])\n\n const onInTransitionCompleteHandler = useStableCallback(\n onInTransitionComplete,\n )\n\n const onOutTransitionCompleteHandler = useStableCallback(\n onOutTransitionComplete,\n )\n\n const renderChildren =\n transitionStartState !== 'notRendered' || activeTransitionClasses.length > 0\n\n useEffect(() => {\n let activeTimeout = null\n let activeRaf = null\n\n if (prevIsActive.current && !transitionIn) {\n setActiveTransitionClasses([transitionClasses.visible])\n activeTimeout = setTimeout(() => {\n setActiveTransitionClasses([\n ...(isVisuallyHidden ? [transitionClasses.visuallyHidden] : []),\n ])\n\n if (onOutTransitionCompleteHandler) {\n activeRaf = requestAnimationFrame(() => {\n onOutTransitionCompleteHandler()\n })\n }\n }, timeout)\n }\n\n if (!prevIsActive.current && transitionIn) {\n setActiveTransitionClasses([transitionClasses.visible])\n // Doubling up on rAF as a single rAF can be too slow for the\n // animation transition to be resolved.\n activeRaf = requestAnimationFrame(() => {\n activeRaf = requestAnimationFrame(() => {\n setActiveTransitionClasses([\n transitionClasses.visible,\n transitionClasses.in,\n ])\n if (onInTransitionCompleteHandler) {\n activeTimeout = setTimeout(() => {\n onInTransitionCompleteHandler()\n }, timeout)\n }\n })\n })\n }\n\n prevIsActive.current = transitionIn\n\n return () => {\n clearTimeout(activeTimeout)\n cancelAnimationFrame(activeRaf)\n }\n }, [\n isVisuallyHidden,\n onInTransitionCompleteHandler,\n onOutTransitionCompleteHandler,\n timeout,\n transitionIn,\n ])\n\n return (\n <>\n {renderChildren &&\n toChildArray(children)\n .filter(childIsVNode)\n .map((child) => {\n const { className: childClassName = '' } = child.props\n const cleanClasses = childClassName\n .split(' ')\n .filter((cl) => !transitionClassesArray.includes(cl))\n\n return cloneElement(child, {\n className: [...cleanClasses, ...activeTransitionClasses].join(\n ' ',\n ),\n })\n })}\n </>\n )\n}\n\nexport default InOutTransition\n","import { useEffect, useRef, useState } from 'preact/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport InOutTransition, {\n transitionStartStates,\n} from 'ui/components/widgets/in-out-transition'\nimport { useSeamlyEntry } from 'ui/hooks/seamly-entry-hooks'\nimport {\n useFileUploadMeta,\n useLiveRegion,\n useSeamlyCurrentAgent,\n useSkiplinkTargetFocusing,\n} from 'ui/hooks/seamly-hooks'\nimport { runIfElementContainsOrHasFocus } from 'ui/utils/general-utils'\nimport { entryTypes } from 'ui/utils/seamly-utils'\n\nconst UploadToggle = () => {\n const { t } = useI18n()\n const { showFileUpload, serviceAllowsUploads } = useFileUploadMeta()\n const [showUploadButton, setShowUploadButton] = useState(serviceAllowsUploads)\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n const prevServiceAllowsUploads = useRef(null)\n const { setUserEntryType, activeEntry } = useSeamlyEntry()\n const uploadButton = useRef(null)\n const { sendPolite } = useLiveRegion()\n const hasAgent = !!useSeamlyCurrentAgent()\n\n useEffect(() => {\n const focusFn = () => {\n if (!serviceAllowsUploads) {\n focusSkiplinkTarget()\n }\n }\n runIfElementContainsOrHasFocus(uploadButton.current, focusFn)\n setShowUploadButton(serviceAllowsUploads)\n }, [serviceAllowsUploads, focusSkiplinkTarget])\n\n useEffect(() => {\n if (prevServiceAllowsUploads.current && !serviceAllowsUploads) {\n sendPolite(t('fileUpload.srUnavailableText'))\n }\n\n if (prevServiceAllowsUploads.current === false && serviceAllowsUploads) {\n sendPolite(t('fileUpload.srAvailableText'))\n }\n\n // We wait for the first agent to join before activating this check.\n // This is to avoid messages being sent to the screen reader on app\n // startup or app refresh.\n if (hasAgent) {\n prevServiceAllowsUploads.current = serviceAllowsUploads\n }\n }, [serviceAllowsUploads, hasAgent, sendPolite, t])\n\n const onClickHandler = () => {\n setUserEntryType(entryTypes.upload)\n focusSkiplinkTarget()\n }\n\n return (\n !showFileUpload &&\n activeEntry !== entryTypes.upload && (\n <InOutTransition\n isActive={showUploadButton}\n transitionStartState={transitionStartStates.rendered}\n >\n <div className={className('upload-toggle-wrapper')}>\n <InOutTransition\n isActive={showUploadButton}\n transitionStartState={transitionStartStates.visuallyHidden}\n >\n <button\n className={className([\n 'button',\n 'button--secondary',\n 'upload-toggle',\n ])}\n ref={uploadButton}\n aria-disabled={!showUploadButton ? 'true' : null}\n type=\"button\"\n onClick={showUploadButton ? onClickHandler : null}\n >\n <Icon\n name=\"file\"\n size=\"32\"\n alt={t('fileUpload.toggleButtonText')}\n />\n </button>\n </InOutTransition>\n </div>\n </InOutTransition>\n )\n )\n}\n\nexport default UploadToggle\n","import { useCallback, useEffect, useRef, useState } from 'preact/hooks'\nimport { useConfig } from 'domains/config/hooks'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport IdleDetachWarning from 'ui/components/warnings/idle-detach-warning'\nimport ResumeConversationPrompt from 'ui/components/warnings/resume-conversation-prompt'\nimport { useSeamlyEntry } from 'ui/hooks/seamly-entry-hooks'\nimport {\n useFileUploadMeta,\n useSeamlyIdleDetachCountdown,\n useSeamlyResumeConversationPrompt,\n useSkiplinkTargetFocusing,\n} from 'ui/hooks/seamly-hooks'\nimport { runIfElementContainsOrHasFocus } from 'ui/utils/general-utils'\nimport { entryTypes } from 'ui/utils/seamly-utils'\nimport TextEntry from './text-entry'\nimport Upload from './upload'\nimport UploadToggle from './upload-toggle'\n\nconst EntryContainer = () => {\n const { isOpen } = useVisibility()\n const entryContainer = useRef(null)\n const { hasCountdown } = useSeamlyIdleDetachCountdown()\n const [showCountdown, setShowCountDown] = useState(hasCountdown)\n const { hasPrompt: hasResumeConversationPrompt } =\n useSeamlyResumeConversationPrompt()\n const [showResumeConversationPrompt, setShowResumeConversationPrompt] =\n useState(hasResumeConversationPrompt)\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n const containedFocus = useRef(false)\n const { activeEntry } = useSeamlyEntry()\n const [entryComponents, setEntryComponents] = useState({\n text: TextEntry,\n upload: Upload,\n })\n const [renderEntry, setRenderEntry] = useState(() => activeEntry)\n const config = useConfig()\n const { accountAllowsUploads } = useFileUploadMeta()\n\n const focusFn = useCallback(() => {\n runIfElementContainsOrHasFocus(entryContainer.current, focusSkiplinkTarget)\n }, [focusSkiplinkTarget])\n\n useEffect(() => {\n const { customComponents } = config\n const { entry } = customComponents || {}\n\n if (entry) {\n setEntryComponents((c) => ({\n ...c,\n ...entry,\n }))\n }\n }, [config])\n\n useEffect(() => {\n // Focus the current target of the skip link if focus was inside the\n // container before this effect change.\n focusFn()\n setShowCountDown(hasCountdown)\n setShowResumeConversationPrompt(hasResumeConversationPrompt)\n }, [hasCountdown, hasResumeConversationPrompt, focusFn])\n\n useEffect(() => {\n setRenderEntry(activeEntry)\n // This focus action is required for auto entry changes. User driven\n // changes should be handled in the originating components.\n focusFn()\n }, [activeEntry, focusFn, entryContainer])\n\n // Check if the active element is inside this container and save it.\n containedFocus.current = !!(\n entryContainer.current &&\n entryContainer.current.contains(document.activeElement)\n )\n\n const EntryComponent = entryComponents[renderEntry]\n\n return (\n <div className={className('chat__entry')} ref={entryContainer}>\n {showCountdown && <IdleDetachWarning />}\n {showResumeConversationPrompt && <ResumeConversationPrompt />}\n <div\n className={className([\n 'entry__body',\n ...(hasCountdown || hasResumeConversationPrompt\n ? ['entry__body--hidden']\n : []),\n ])}\n >\n {renderEntry !== entryTypes.upload &&\n accountAllowsUploads &&\n isOpen && <UploadToggle />}\n <EntryComponent />\n </div>\n </div>\n )\n}\n\nexport default EntryContainer\n","import { useSelector } from 'react-redux'\nimport { useStartChatIcon } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { selectHasError } from 'domains/interrupt/selectors'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport {\n useSeamlyCurrentAgent,\n useSeamlyHeaderData,\n useSeamlyUnreadCount,\n} from 'ui/hooks/seamly-hooks'\nimport Icon from './icon'\n\nconst AgentInfo = () => {\n const { t } = useI18n()\n const { title, subTitle } = useSeamlyHeaderData()\n const unreadMessageCount = useSeamlyUnreadCount()\n const { isOpen } = useVisibility()\n const currentAgent = useSeamlyCurrentAgent()\n const hasError = useSelector(selectHasError)\n const startChatIcon = useStartChatIcon()\n const src = currentAgent?.avatar ?? startChatIcon\n const displaySubtitle = hasError ? '' : subTitle\n\n const classNames = ['message-count']\n\n if (isOpen) {\n classNames.push('message-count__hide')\n }\n\n if (unreadMessageCount === 0) {\n classNames.push('message-count__empty')\n }\n\n return (\n (displaySubtitle || !isOpen) && (\n <div className={className('agent-info')}>\n <div className={className('agent-info__graphic')}>\n {src ? (\n <img\n className={className(currentAgent?.avatar ? 'avatar' : 'icon')}\n src={src}\n alt=\"\"\n />\n ) : (\n <Icon name=\"avatar\" size=\"32\" alt=\"\" />\n )}\n <span className={className(classNames)} aria-hidden=\"true\">\n {unreadMessageCount}\n </span>\n </div>\n\n <div className={className('agent-info__body')}>\n <p className={className('agent-info__heading')}>\n {title ?? t('header.title')}\n </p>\n <p className={className('agent-info__text')}>{displaySubtitle}</p>\n </div>\n </div>\n )\n )\n}\n\nexport default AgentInfo\n","import { useCallback, useEffect, useMemo, useRef } from 'preact/hooks'\nimport { useSelector } from 'react-redux'\nimport { useUserHasResponded } from 'domains/app/hooks'\nimport { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { selectHasError } from 'domains/interrupt/selectors'\nimport { useTranslatedEventData } from 'domains/translations/hooks'\nimport { visibilityStates } from 'domains/visibility/constants'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport SuggestionsList from 'ui/components/suggestions/suggestions-list'\nimport InOutTransition, {\n transitionStartStates,\n} from 'ui/components/widgets/in-out-transition'\nimport { useSkiplinkTargetFocusing } from 'ui/hooks/focus-helper-hooks'\nimport { useLiveRegion } from 'ui/hooks/live-region-hooks'\nimport {\n useSeamlyLayoutMode,\n useSeamlyServiceData,\n} from 'ui/hooks/seamly-state-hooks'\nimport useSeamlyCommands from 'ui/hooks/use-seamly-commands'\nimport useSeamlyIdleDetachCountdown from 'ui/hooks/use-seamly-idle-detach-countdown'\nimport useSeamlyResumeConversationPrompt from 'ui/hooks/use-seamly-resume-conversation-prompt'\nimport { useGeneratedId } from 'ui/hooks/utility-hooks'\nimport { runIfElementContainsOrHasFocus } from 'ui/utils/general-utils'\nimport { actionTypes } from 'ui/utils/seamly-utils'\n\nconst Suggestions = ({ isAside = false }) => {\n // generic hooks\n const { isInline } = useSeamlyLayoutMode()\n const { t } = useI18n()\n const { sendAction, addMessageBubble } = useSeamlyCommands()\n const { isOpen, setVisibility } = useVisibility()\n const { showSuggestions } = useConfig()\n // a11y hooks\n const sectionId = useGeneratedId()\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n const containerRef = useRef(null)\n const { sendPolite } = useLiveRegion()\n // interrupt & countdown hooks\n const hasError = useSelector(selectHasError)\n const { hasCountdown, endCountdown } = useSeamlyIdleDetachCountdown()\n const { hasPrompt, continueChat } = useSeamlyResumeConversationPrompt()\n // data hooks\n const userHasResponded = useUserHasResponded()\n const payload = useSeamlyServiceData('suggestion')\n const { body: eventBody } = useTranslatedEventData({ payload })\n const suggestions = useMemo(\n () => (payload && !hasError ? eventBody : []),\n [payload, hasError, eventBody],\n )\n\n const prevSuggestions = useRef(null)\n const prevHasSuggestions = useRef(false)\n\n const previousRenderedSuggestions = useRef([])\n const hasSuggestions = !!suggestions.length\n const hideSuggestions = isInline\n ? (userHasResponded || isOpen) && !isAside\n : userHasResponded\n const prevHideSuggestions = useRef(hideSuggestions)\n const showSuggestionsContainer =\n hasSuggestions && !hideSuggestions && showSuggestions\n const renderedSuggestions = hasSuggestions\n ? suggestions\n : previousRenderedSuggestions.current\n previousRenderedSuggestions.current = renderedSuggestions\n\n const suggestionsClassNames = useMemo(() => {\n const classNames = ['suggestions']\n\n if (isAside) {\n classNames.push('suggestions--aside')\n }\n\n return className(classNames)\n }, [isAside])\n\n // click handler\n const handleClick = useCallback(\n ({ id, question }) => {\n if (hasCountdown) {\n endCountdown(true)\n }\n\n if (hasPrompt) {\n continueChat()\n }\n\n // @todo Refactor to 'suggestionclick'\n sendAction({\n type: actionTypes.custom,\n originMessage: payload.id,\n body: {\n type: 'faqclick',\n body: {\n faqId: id,\n faqQuestion: question,\n },\n },\n })\n\n addMessageBubble(question)\n if (!isOpen) {\n setVisibility(visibilityStates.open)\n }\n focusSkiplinkTarget()\n },\n [\n addMessageBubble,\n continueChat,\n endCountdown,\n focusSkiplinkTarget,\n hasCountdown,\n hasPrompt,\n payload,\n sendAction,\n setVisibility,\n isOpen,\n ],\n )\n\n useEffect(() => {\n if (prevSuggestions.current !== suggestions && !hideSuggestions) {\n if (hasSuggestions) {\n const politeText = prevHasSuggestions.current\n ? t('suggestions.srUpdatedText')\n : t('suggestions.srAvailableText')\n setTimeout(() => {\n sendPolite(politeText)\n }, 30)\n } else if (prevHasSuggestions.current) {\n sendPolite(t('suggestions.srUnavailableText'))\n }\n\n prevSuggestions.current = suggestions\n }\n\n if (!prevHideSuggestions.current && hideSuggestions) {\n runIfElementContainsOrHasFocus(containerRef.current, focusSkiplinkTarget)\n sendPolite(t('suggestions.srUnavailableText'))\n } else if (!hasSuggestions && prevHasSuggestions.current) {\n runIfElementContainsOrHasFocus(containerRef.current, focusSkiplinkTarget)\n }\n prevHasSuggestions.current = hasSuggestions\n prevHideSuggestions.current = hideSuggestions\n }, [\n suggestions,\n hasSuggestions,\n hideSuggestions,\n focusSkiplinkTarget,\n sendPolite,\n t,\n ])\n\n const headingText = t('suggestions.headingText')\n const footerText = t('suggestions.footerText')\n const ContainerElement = headingText ? 'section' : 'div'\n\n return (\n <InOutTransition\n isActive={showSuggestionsContainer}\n transitionStartState={transitionStartStates.notRendered}\n >\n <ContainerElement\n className={suggestionsClassNames}\n aria-labelledby={headingText ? sectionId : null}\n ref={containerRef}\n >\n {headingText && (\n <p id={sectionId} className={className('suggestions__heading')}>\n {headingText}\n </p>\n )}\n {!!renderedSuggestions.length && (\n <SuggestionsList\n suggestions={renderedSuggestions}\n onClickSuggestion={handleClick}\n />\n )}\n {footerText && !isOpen && (\n <p className={className('suggestions__footer')}>{footerText}</p>\n )}\n </ContainerElement>\n </InOutTransition>\n )\n}\n\nexport default Suggestions\n","import { forwardRef } from 'preact/compat'\nimport { useUserHasResponded } from 'domains/app/hooks'\nimport { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { visibilityStates } from 'domains/visibility/constants'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport Suggestions from 'ui/components/suggestions'\nimport { useSeamlyAppContainerClassNames } from 'ui/hooks/component-helper-hooks'\nimport { useSeamlyLayoutMode } from 'ui/hooks/seamly-state-hooks'\n\nconst Chat = forwardRef(\n ({ children, className: givenClassName = '' }, forwardedRef) => {\n const { isOpen, isVisible, setVisibility } = useVisibility()\n const { namespace, layoutMode } = useConfig()\n const { isInline } = useSeamlyLayoutMode()\n const appContainerClassNames = useSeamlyAppContainerClassNames()\n const userHasResponded = useUserHasResponded()\n const { t } = useI18n()\n\n const defaultClassNames = [\n 'chat',\n `chat--layout-${layoutMode}`,\n `namespace--${namespace}`,\n ]\n\n const classNames = [\n ...defaultClassNames,\n ...appContainerClassNames,\n givenClassName,\n ]\n\n if (!isOpen && layoutMode !== 'app') {\n classNames.push('chat--collapsed')\n }\n\n if (userHasResponded) {\n classNames.push('chat--user-responded')\n }\n\n const onKeyDownHandler = (e) => {\n if ((e.code && e.code === 'Escape') || e.keyCode === 27)\n if (!isInline && isOpen) {\n setVisibility(visibilityStates.minimized)\n }\n }\n\n return (\n isVisible && (\n <section\n className={className(classNames)}\n onKeyDown={onKeyDownHandler}\n tabIndex=\"-1\"\n ref={forwardedRef}\n aria-label={t('chat.srLabel')}\n >\n <div className={className('chat-wrapper')}>{children}</div>\n {layoutMode === 'inline' && isOpen && <Suggestions isAside={true} />}\n </section>\n )\n )\n },\n)\n\nexport default Chat\n","import { FC } from 'preact/compat'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport { useGeneratedId } from 'ui/hooks/utility-hooks'\n\ntype ChatStatusProps = {\n handleClose: () => void\n title: string\n closeButtonText?: string\n srCloseButtonText?: string\n id: string\n}\n\nconst ChatStatus: FC<ChatStatusProps> = ({\n children,\n handleClose,\n title,\n closeButtonText,\n srCloseButtonText,\n id,\n}) => {\n const headingId = useGeneratedId()\n\n return (\n <section\n tabIndex={-1}\n id={id}\n aria-labelledby={title ? headingId : undefined}\n className={className('chat-status', !title && 'chat-status--condensed')}\n >\n <div className={className('chat-status__body')}>\n {title ? (\n <h2 className={className('chat-status__title')} id={headingId}>\n {title}\n </h2>\n ) : null}\n {children}\n </div>\n {typeof handleClose === 'function' && (\n <button\n type=\"button\"\n onClick={handleClose}\n className={className(\n 'button',\n 'button--tertiary',\n 'chat-status__close',\n )}\n >\n {closeButtonText || <Icon name=\"close\" size=\"16\" alt=\"\" />}\n {srCloseButtonText && (\n <span className={className('visually-hidden')}>\n {srCloseButtonText}\n </span>\n )}\n </button>\n )}\n </section>\n )\n}\n\nexport default ChatStatus\n","import { className } from 'lib/css'\nimport Icon, { IconProps } from 'ui/components/layout/icon'\n\ntype ChatStatusActionProps = {\n handleClick: () => void\n icon: IconProps['name']\n title: string\n srButtonText?: string\n}\n\nconst ChatStatusAction = ({\n handleClick,\n icon,\n title,\n srButtonText,\n}: ChatStatusActionProps) => (\n <button\n type=\"button\"\n onClick={handleClick}\n className={className('button', 'button--primary', 'chat-status__button')}\n >\n <Icon name={icon} size=\"16\" alt=\"\" />\n {title}\n {srButtonText && (\n <span className={className('visually-hidden')}>{srButtonText}</span>\n )}\n </button>\n)\n\nexport default ChatStatusAction\n","import {\n useTranslationProposal,\n useTranslationsContainer,\n} from 'domains/translations/hooks'\nimport ChatStatus from 'ui/components/chat-status'\nimport ChatStatusAction from 'ui/components/chat-status/chat-status-action'\n\nexport default function TranslationProposal() {\n const {\n showProposal,\n translationProposal,\n dismissTranslationProposal,\n activateTranslationProposal,\n } = useTranslationProposal()\n\n const { id } = useTranslationsContainer()\n\n if (!showProposal) {\n return null\n }\n\n return (\n <ChatStatus\n handleClose={dismissTranslationProposal}\n srCloseButtonText={translationProposal.srDismissButtonText}\n id={id}\n title={translationProposal.titleLabel}\n >\n <ChatStatusAction\n handleClick={activateTranslationProposal}\n icon=\"newTranslation\"\n title={translationProposal.buttonLabel}\n />\n </ChatStatus>\n )\n}\n","import { useSelector } from 'react-redux'\nimport { selectHasError } from 'domains/interrupt/selectors'\nimport { useTranslations } from 'domains/translations/hooks'\nimport TranslationProposal from 'ui/components/translation-proposal'\n\nexport default function TranslationStatus() {\n const hasError = useSelector(selectHasError)\n\n const { isActive } = useTranslations()\n if (hasError) {\n return null\n }\n\n return !isActive ? <TranslationProposal /> : null\n}\n","import { FC } from 'preact/compat'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\n\ntype TranslationOptionProps = {\n label: string\n checked: boolean\n description?: string\n onChange: () => void\n id: string\n itemClassName?: string\n}\n\nconst TranslationOption: FC<TranslationOptionProps> = ({\n label,\n checked,\n description,\n onChange,\n id,\n itemClassName,\n}) => {\n const onKeyDown = (e: KeyboardEvent) => {\n if (e.code === 'Space' || e.code === 'Enter') {\n e.preventDefault()\n onChange()\n }\n }\n\n return (\n <li\n className={className([itemClassName, 'translation-options__item'])}\n aria-selected={checked}\n role=\"option\"\n tabIndex={0}\n onClick={onChange}\n onKeyDown={onKeyDown}\n id={id}\n >\n <Icon name=\"check\" size=\"16\" alt=\"\" />\n {label} {description && <span>({description})</span>}\n </li>\n )\n}\n\nexport default TranslationOption\n","import { FC, useMemo } from 'preact/compat'\nimport { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport TranslationOption from 'domains/translations/components/options-dialog/translation-option'\nimport { useTranslations } from 'domains/translations/hooks'\nimport { className } from 'lib/css'\nimport { useSkiplinkTargetFocusing } from 'ui/hooks/focus-helper-hooks'\nimport type { Language } from 'domains/translations/translations.types'\n\ntype TranslationOptionsProps = {\n onChange: () => void\n describedById?: string\n}\n\nconst isChecked = (language, currentLocale, isOriginal): boolean =>\n currentLocale === language.locale || (!currentLocale && isOriginal)\n\nconst TranslationOptions: FC<TranslationOptionsProps> = ({\n onChange,\n describedById,\n}) => {\n const {\n context: { userLocale, contentLocale },\n } = useConfig()\n\n const { t } = useI18n()\n const { languages, currentLocale, enableTranslations, disableTranslations } =\n useTranslations()\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n\n const handleChange = (locale: Language['locale']) => () => {\n if (locale === currentLocale || userLocale === locale) {\n disableTranslations()\n } else {\n enableTranslations(locale)\n }\n\n onChange()\n focusSkiplinkTarget()\n }\n\n const { primaryLanguages, remainingLanguages } = useMemo(\n () =>\n languages.reduce(\n (acc, language) => {\n const isOriginal = language.locale === contentLocale\n const checked = isChecked(language, currentLocale, isOriginal)\n\n if (language.locale !== contentLocale) {\n acc.remainingLanguages.push({ ...language, checked, isOriginal })\n }\n\n const selectedIdx = acc.remainingLanguages.findIndex(\n (l) => l.locale === currentLocale,\n )\n\n if (isOriginal || (checked && selectedIdx > 4)) {\n acc.primaryLanguages.push({ ...language, checked, isOriginal })\n }\n\n return acc\n },\n {\n primaryLanguages: [],\n remainingLanguages: [],\n },\n ),\n [currentLocale, contentLocale, languages],\n )\n\n return (\n <ul\n aria-describedby={describedById}\n role=\"listbox\"\n tabIndex={-1}\n className={className('translation-options')}\n >\n {primaryLanguages.map(\n ({ locale, nativeName, checked, isOriginal }, idx) => (\n <TranslationOption\n key={locale}\n id={locale}\n label={nativeName}\n checked={checked}\n description={isOriginal && t('translations.settings.original')}\n onChange={handleChange(locale)}\n itemClassName={className({\n 'translation-options__item--original': isOriginal,\n 'translation-options__item--selected': checked && idx !== 0,\n })}\n />\n ),\n )}\n {remainingLanguages.map(({ locale, nativeName, checked, isOriginal }) => (\n <TranslationOption\n key={locale}\n id={locale}\n label={nativeName}\n checked={checked}\n description={isOriginal && t('translations.settings.original')}\n onChange={handleChange(locale)}\n />\n ))}\n </ul>\n )\n}\n\nexport default TranslationOptions\n","import { FC } from 'preact/compat'\nimport { MutableRef, useCallback, useEffect } from 'preact/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport {\n useGeneratedId,\n useOptionButton,\n useSeamlyOptions,\n} from 'ui/hooks/seamly-hooks'\nimport useClickOutside from 'ui/hooks/use-click-outside'\nimport { focusElement } from 'ui/utils/general-utils'\n\nexport type FramePosition = {\n vertical: 'top' | 'bottom'\n horizontal: 'left' | 'right'\n}\n\ntype OptionsFrameProps = {\n className?: string\n onCancel?: () => void\n headingText: string\n description?: string\n descriptionId?: string\n cancelButtonText?: string\n cancelButtonRef?: MutableRef<HTMLElement>\n disableButtonFocusing?: boolean\n position: FramePosition\n}\n\nconst OptionsFrame: FC<OptionsFrameProps> = ({\n className: givenClassName,\n children,\n onCancel,\n headingText,\n description,\n descriptionId,\n cancelButtonText,\n cancelButtonRef,\n disableButtonFocusing,\n position = {\n horizontal: 'left',\n vertical: 'top',\n },\n}) => {\n const mainHeadingId = useGeneratedId()\n // @todo Lift this from the \"options frame\" into something reusable\n // when you're not using options\n const { hideOption } = useSeamlyOptions()\n const { focusButton } = useOptionButton()\n\n const closePanel = useCallback(() => {\n hideOption()\n if (!disableButtonFocusing) {\n focusButton()\n }\n }, [disableButtonFocusing, focusButton, hideOption])\n\n const onCancelHandler = useCallback(() => {\n if (onCancel) {\n onCancel()\n }\n closePanel()\n }, [closePanel, onCancel])\n\n const container = useClickOutside(onCancelHandler)\n\n useEffect(() => {\n focusElement(container.current)\n }, [container])\n\n return (\n <section\n className={className(\n 'options',\n {\n 'options--right': position.horizontal === 'right',\n 'options--left': position.horizontal === 'left',\n 'options--top': position.vertical === 'top',\n 'options--bottom': position.vertical === 'bottom',\n },\n givenClassName,\n )}\n aria-labelledby={mainHeadingId}\n tabIndex={-1}\n ref={container}\n >\n <div className={className('options__body')}>\n <h2 id={mainHeadingId} className={className('options__title')}>\n {headingText}\n </h2>\n <button\n type=\"button\"\n onClick={onCancelHandler}\n aria-describedby={mainHeadingId}\n className={className('button', 'options__close')}\n ref={(btn) => {\n if (cancelButtonRef) {\n cancelButtonRef.current = btn\n }\n }}\n >\n <Icon name=\"close\" size=\"16\" alt=\"\" />\n <span>{cancelButtonText}</span>\n </button>\n\n {description ? (\n <p className={className('options__description')} id={descriptionId}>\n {description}\n </p>\n ) : null}\n <div className={className('options__wrapper')}>{children}</div>\n </div>\n </section>\n )\n}\n\nexport default OptionsFrame\n","import { useEffect, useRef } from 'preact/hooks'\n\nconst useClickOutside = (callback: Function) => {\n const ref = useRef<HTMLElement>(null)\n\n useEffect(() => {\n const handler = (el: TouchEvent | MouseEvent): void => {\n if (\n ref.current &&\n el.target instanceof HTMLElement &&\n !ref.current.contains(el.target)\n ) {\n el.preventDefault()\n el.stopPropagation()\n callback()\n }\n }\n\n document.addEventListener('click', handler, true)\n document.addEventListener('touchstart', handler, true)\n\n return () => {\n document.removeEventListener('click', handler, true)\n document.removeEventListener('touchstart', handler, true)\n }\n }, [callback, ref])\n\n return ref\n}\n\nexport default useClickOutside\n","import { useI18n } from 'domains/i18n/hooks'\nimport TranslationOptions from 'domains/translations/components/options-dialog/translation-options'\nimport OptionsFrame from 'ui/components/options/options-frame'\nimport { useGeneratedId } from 'ui/hooks/seamly-hooks'\nimport type { FramePosition } from 'ui/components/options/options-frame'\n\ntype TranslationsOptionsDialogProps = {\n onClose: () => void\n position: FramePosition\n}\n\nfunction TranslationsOptionsDialog({\n onClose,\n position,\n}: TranslationsOptionsDialogProps) {\n const { t } = useI18n()\n const descriptionId = useGeneratedId()\n return (\n <OptionsFrame\n onCancel={onClose}\n headingText={t('translations.menu.title')}\n cancelButtonText={t('translations.settings.cancelButtonText')}\n description={t('translations.menu.description')}\n descriptionId={descriptionId}\n position={position}\n disableButtonFocusing\n >\n <TranslationOptions describedById={descriptionId} onChange={onClose} />\n </OptionsFrame>\n )\n}\n\nexport default TranslationsOptionsDialog\n","import { ComponentChildren } from 'preact'\nimport { useRef, useState } from 'preact/hooks'\nimport { className } from 'lib/css'\nimport InOutTransition, {\n transitionStartStates,\n} from 'ui/components/widgets/in-out-transition'\nimport { useGeneratedId } from 'ui/hooks/seamly-hooks'\nimport { focusElement, getKey, keyNames } from 'ui/utils/general-utils'\nimport TranslationsOptionsDialog from './options-dialog'\nimport type { FramePosition } from 'ui/components/options/options-frame'\n\ntype TranslationsOptionsButtonProps = {\n children: ComponentChildren\n position: FramePosition\n classNames?: string[]\n}\n\nexport default function TranslationsOptionsButton({\n children,\n position = {\n horizontal: 'left',\n vertical: 'top',\n },\n classNames,\n}: TranslationsOptionsButtonProps) {\n const [menuIsOpen, setMenuIsOpen] = useState(false)\n const toggleButton = useRef(null)\n const toggleButtonId = useGeneratedId()\n\n const onMainKeyDownHandler = (e: KeyboardEvent) => {\n if (!menuIsOpen) {\n return\n }\n\n if (getKey(e) === keyNames.Escape) {\n setMenuIsOpen(false)\n focusElement(toggleButton.current)\n }\n }\n\n const handleDialogClose = () => {\n setMenuIsOpen(false)\n }\n\n const handleToggleClick = () => {\n setMenuIsOpen(!menuIsOpen)\n }\n\n const handleToggleKeyDown = (e: KeyboardEvent) => {\n if (getKey(e) === keyNames.ArrowDown) {\n setMenuIsOpen(true)\n e.preventDefault()\n }\n }\n return (\n <div\n className={className('translations__container')}\n onKeyDown={onMainKeyDownHandler}\n >\n <InOutTransition\n transitionStartState={transitionStartStates.notRendered}\n isActive={menuIsOpen}\n >\n <div className={className('options__dialog')} role=\"dialog\">\n <TranslationsOptionsDialog\n onClose={handleDialogClose}\n position={position}\n />\n </div>\n </InOutTransition>\n <button\n type=\"button\"\n className={className([\n 'button',\n 'chat__options__button',\n ...classNames,\n ])}\n id={toggleButtonId}\n onClick={handleToggleClick}\n onKeyDown={handleToggleKeyDown}\n ref={toggleButton}\n aria-haspopup=\"dialog\"\n aria-expanded={menuIsOpen}\n >\n {children}\n </button>\n </div>\n )\n}\n","import { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport Form from 'ui/components/form-controls/form'\nimport Input from 'ui/components/form-controls/input'\n\nexport default function TranscriptForm({ controlName, describedById }) {\n const { t } = useI18n()\n return (\n <Form noValidate=\"true\" className={className('options__form')}>\n <Input\n name={controlName}\n type=\"email\"\n className={className('transcript__input')}\n aria-describedby={describedById}\n labelClass={className('label')}\n labelText={t('options.sendTranscript.label')}\n />\n <div className={className('options__actions')}>\n <button\n type=\"submit\"\n className={className('button', 'button--primary', 'options__submit')}\n >\n {t('options.sendTranscript.sendButtonText')}\n </button>\n </div>\n </Form>\n )\n}\n","import { useCallback, useMemo, useState } from 'preact/hooks'\nimport FormProvider from 'domains/forms/provider'\nimport { useI18n } from 'domains/i18n/hooks'\nimport OptionsFrame from 'ui/components/options/options-frame'\nimport {\n useGeneratedId,\n useOptionButton,\n useSeamlyCommands,\n useSeamlyOptions,\n} from 'ui/hooks/seamly-hooks'\nimport { getValidator } from 'ui/utils/form-utils'\nimport { actionTypes } from 'ui/utils/seamly-utils'\nimport { isEmailString, isNotEmptyString } from 'ui/utils/validations'\nimport TranscriptForm from './transcript-form'\n\nconst formId = 'sendTranscript'\nconst controlName = 'email'\n\nconst Transcript = () => {\n const [errorClass, setErrorClass] = useState(undefined)\n const { hideOption } = useSeamlyOptions()\n const { focusButton } = useOptionButton()\n const { t } = useI18n()\n const transcriptDescriptionId = useGeneratedId()\n const { sendAction } = useSeamlyCommands()\n\n const validationSchema = useMemo(\n () => ({\n [controlName]: [\n getValidator(isNotEmptyString, t('options.sendTranscript.noEmailText')),\n getValidator(\n isEmailString,\n t('options.sendTranscript.invalidEmailText'),\n ),\n ],\n }),\n [t],\n )\n\n const handleSubmit = useCallback(\n (values) => {\n const emailAddress = values[controlName].trim()\n sendAction({\n type: actionTypes.sendTranscript,\n body: { emailAddress },\n })\n hideOption()\n focusButton()\n },\n [sendAction, hideOption, focusButton],\n )\n\n const handleError = useCallback(\n ({ isValid, isSubmitted }) => {\n if (isSubmitted && !isValid) {\n setErrorClass('options--error')\n } else {\n setErrorClass(undefined)\n }\n },\n [setErrorClass],\n )\n\n return (\n <OptionsFrame\n className={errorClass}\n headingText={t('options.sendTranscript.title')}\n cancelButtonText={t('options.cancelButtonText')}\n description={t('options.sendTranscript.description')}\n descriptionId={transcriptDescriptionId}\n position={{\n vertical: 'top',\n horizontal: 'right',\n }}\n >\n <FormProvider\n formId={formId}\n onSubmit={handleSubmit}\n validationSchema={validationSchema}\n onError={handleError}\n >\n <TranscriptForm\n controlName={controlName}\n describedById={transcriptDescriptionId}\n />\n </FormProvider>\n </OptionsFrame>\n )\n}\n\nexport default Transcript\n","import { useRef } from 'preact/hooks'\nimport { useSeamlyOptions } from 'ui/hooks/seamly-hooks'\nimport Transcript from './transcript'\n\nconst mapper = {\n sendTranscript: Transcript,\n}\n\nconst Options = () => {\n const { optionActive } = useSeamlyOptions()\n const prevRenderOption = useRef(null)\n\n // We keep the previously selected option active so that we can animate the options panel.\n const RenderOption = mapper[optionActive || prevRenderOption.current]\n\n if (optionActive) {\n prevRenderOption.current = optionActive\n }\n return RenderOption ? <RenderOption /> : null\n}\n\nexport default Options\n","import { createRef } from 'preact'\nimport { useEffect, useMemo, useRef, useState } from 'preact/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport InOutTransition, {\n transitionStartStates,\n} from 'ui/components/widgets/in-out-transition'\nimport { timeout } from 'ui/hooks/focus-helper-hooks'\nimport { useOptionButton, useSeamlyOptions } from 'ui/hooks/seamly-hooks'\nimport { focusElement, getKey, keyNames } from 'ui/utils/general-utils'\nimport Options from './options'\n\nconst OptionsButton = () => {\n const { t } = useI18n()\n const { menuOptions, showOption, panelActive, hideOption } =\n useSeamlyOptions()\n const { id } = useOptionButton()\n const focusOutDelayTimeoutID = useRef(null)\n\n const [menuIsOpen, setMenuIsOpen] = useState(false)\n\n const toggleButton = useRef(null)\n const optionsLength = menuOptions.length\n const menuItemButtons = useRef(\n Array.from({ length: optionsLength }, () => createRef()),\n )\n const prevMenuIsOpen = useRef(false)\n\n const multiMenu = optionsLength > 1\n const firstOption = menuOptions[0]\n const firstOptionName = useMemo(\n () => firstOption?.name?.trim().replace(/\\s+/g, ''),\n [firstOption],\n )\n\n useEffect(() => {\n return () => {\n clearTimeout(focusOutDelayTimeoutID.current)\n }\n }, [])\n\n useEffect(() => {\n if (menuIsOpen && !prevMenuIsOpen.current) {\n requestAnimationFrame(async () => {\n await timeout(60) // Wait for next frame tick\n const firstActiveOptionIndex = menuOptions.findIndex(\n (option) => option.available,\n )\n\n const focusIndex =\n firstActiveOptionIndex === -1 ? 0 : firstActiveOptionIndex\n focusElement(menuItemButtons.current[focusIndex])\n })\n }\n prevMenuIsOpen.current = menuIsOpen\n }, [menuIsOpen, menuOptions])\n\n const onClickHandler = () => {\n if (panelActive) {\n hideOption()\n }\n if (multiMenu) {\n setMenuIsOpen((o) => !o)\n } else if (firstOption.available && !panelActive) {\n showOption(firstOption.name)\n }\n }\n\n const onMainKeyDownHandler = (e) => {\n if (!menuIsOpen) {\n return\n }\n\n if (getKey(e) === keyNames.Escape) {\n setMenuIsOpen(false)\n focusElement(toggleButton.current)\n }\n if (getKey(e) === keyNames.Home) {\n focusElement(menuItemButtons.current[0])\n e.preventDefault()\n }\n if (getKey(e) === keyNames.End) {\n focusElement(menuItemButtons.current[optionsLength - 1])\n e.preventDefault()\n }\n }\n\n const onButtonKeyDownHandler = (e) => {\n if (getKey(e) === keyNames.ArrowDown) {\n setMenuIsOpen(true)\n e.preventDefault()\n }\n }\n\n const onMenuItemKeyDownHandler = (e, index) => {\n if (getKey(e) === keyNames.ArrowDown) {\n const newIndex = Math.min(optionsLength - 1, index + 1)\n focusElement(menuItemButtons.current[index === newIndex ? 0 : newIndex])\n e.preventDefault()\n }\n if (getKey(e) === keyNames.ArrowUp) {\n const newIndex = Math.max(0, index - 1)\n focusElement(\n menuItemButtons.current[\n index === newIndex ? optionsLength - 1 : newIndex\n ],\n )\n e.preventDefault()\n }\n }\n\n const onFocusOutHandler = () => {\n if (multiMenu) {\n focusOutDelayTimeoutID.current = setTimeout(() => {\n setMenuIsOpen(false)\n }, 200)\n }\n }\n\n const onFocusInHandler = () => {\n clearTimeout(focusOutDelayTimeoutID.current)\n }\n\n const onKeyPressHandler = (e, index) => {\n const char = String.fromCharCode(e.charCode)\n const isPrintableChar = !!(char.length === 1 && char.match(/\\S/))\n\n if (!isPrintableChar) {\n return\n }\n\n let foundIndex = -1\n\n menuOptions.forEach((option, i) => {\n if (\n i > index &&\n option.title.charAt(0).toLowerCase() === char.toLowerCase() &&\n foundIndex === -1\n ) {\n foundIndex = i\n }\n })\n\n if (foundIndex !== -1) {\n focusElement(menuItemButtons.current[foundIndex])\n }\n }\n\n const onMenuItemClickHandler = (name, available) => {\n if (available) {\n setMenuIsOpen(false)\n showOption(name)\n }\n }\n if (!optionsLength) {\n return null\n }\n\n return (\n <div\n className={className('options__container')}\n onKeyDown={onMainKeyDownHandler}\n // eslint-disable-next-line react/no-unknown-property\n onfocusout={onFocusOutHandler}\n // eslint-disable-next-line react/no-unknown-property\n onfocusin={onFocusInHandler}\n >\n <InOutTransition\n transitionStartState={transitionStartStates.notRendered}\n isActive={panelActive}\n >\n <div className={className('options__dialog')}>\n <Options />\n </div>\n </InOutTransition>\n {multiMenu && (\n <InOutTransition\n isActive={menuIsOpen}\n transitionStartState={transitionStartStates.notRendered}\n >\n <ul\n className={className(['options__menu'])}\n role=\"menu\"\n tabIndex=\"-1\"\n aria-labelledby={id}\n >\n {menuOptions.map(({ name, title, available }, i) => (\n <li\n className={className('options__menu__item')}\n key={name}\n role=\"menuitem\"\n data-testid={name}\n >\n <button\n type=\"button\"\n ref={(item) => {\n menuItemButtons.current[i] = item\n }}\n className={className(['button', 'button--secondary'])}\n onKeyDown={(e) => onMenuItemKeyDownHandler(e, i)}\n onKeyPress={(e) => onKeyPressHandler(e, i)}\n onClick={() => onMenuItemClickHandler(name, available)}\n aria-disabled={!available ? 'true' : null}\n >\n <span className={className('button__text')}>\n {title}\n {!available && ' '}\n </span>\n {!available && (\n <span className={className('button__state')}>\n {t('options.unavailableText')}\n </span>\n )}\n </button>\n </li>\n ))}\n </ul>\n </InOutTransition>\n )}\n <button\n type=\"button\"\n className={className([\n 'button',\n 'button--secondary',\n 'chat__options__button',\n ...(!multiMenu && firstOptionName\n ? [`chat__options__button--${firstOptionName}`]\n : []),\n ])}\n id={id}\n onClick={onClickHandler}\n onKeyDown={multiMenu ? onButtonKeyDownHandler : null}\n ref={toggleButton}\n aria-haspopup={multiMenu ? 'menu' : null}\n aria-expanded={multiMenu ? menuIsOpen.toString() : null}\n aria-disabled={!multiMenu && !firstOption.available ? 'true' : null}\n >\n {multiMenu && <Icon name=\"options\" size=\"32\" alt=\"\" />}\n <span className={className('button__text')}>\n {multiMenu\n ? t('options.openButtonText')\n : `${firstOption.title}${!firstOption.available ? ' ' : ''}`}\n </span>\n {!multiMenu && !firstOption.available && (\n <span className={className('button__state')}>\n {t('options.unavailableText')}\n </span>\n )}\n </button>\n </div>\n )\n}\n\nexport default OptionsButton\n","import { useSelector } from 'react-redux'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { selectHasError } from 'domains/interrupt/selectors'\nimport TranslationsOptionsButton from 'domains/translations/components/options-button'\nimport {\n useLocaleNativeName,\n useTranslations,\n} from 'domains/translations/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport OptionsButton from 'ui/components/options/options-button'\nimport { useSeamlyOptions } from 'ui/hooks/seamly-hooks'\n\nexport default function AppOptions() {\n const { menuOptions, allowOptionSelection } = useSeamlyOptions()\n const { isAvailable: isTranslationsAvailable } = useTranslations()\n const hasError = useSelector(selectHasError)\n const { t, locale } = useI18n()\n const localeNativeName = useLocaleNativeName(locale)\n\n if (\n (!isTranslationsAvailable &&\n (!allowOptionSelection || !menuOptions.length)) ||\n hasError\n ) {\n return null\n }\n\n const openButtonText = t('translations.settings.openButtonText', {\n hasLanguage: !!localeNativeName,\n language: localeNativeName,\n })\n\n return (\n <div className={className('chat__options')}>\n {isTranslationsAvailable && (\n <div\n className={className(\n 'chat__options-item',\n 'chat__options-item--left',\n )}\n >\n <TranslationsOptionsButton classNames={['button--secondary']}>\n <Icon alt={openButtonText} name=\"newTranslation\" size=\"16\" />\n <span className={className('button__text')}>{openButtonText}</span>\n </TranslationsOptionsButton>\n </div>\n )}\n {allowOptionSelection && (\n <div\n className={className(\n 'chat__options-item',\n 'chat__options-item--right',\n )}\n >\n <OptionsButton />\n </div>\n )}\n </div>\n )\n}\n","import { useContext } from 'preact/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport ChatScrollContext from 'ui/components/conversation/event/chat-scroll/chat-scroll-context'\nimport Icon from 'ui/components/layout/icon'\nimport InOutTransition from 'ui/components/widgets/in-out-transition'\n\nconst UnreadMessagesButton = () => {\n const { scrollToRef, unreadIds } = useContext(ChatScrollContext)\n const { isMinimized } = useVisibility()\n const { t } = useI18n()\n\n return (\n <InOutTransition isActive={!!unreadIds.length && !isMinimized}>\n <div className={className('unread-messages')}>\n <button\n type=\"button\"\n className={className('button', 'button--primary')}\n onClick={scrollToRef}\n >\n {t('message.unreadMessagesCount', { unreadCount: unreadIds.length })}\n <Icon name=\"chevronDown\" size=\"32\" alt=\"\" />\n </button>\n </div>\n </InOutTransition>\n )\n}\n\nexport default UnreadMessagesButton\n","import { createSelector } from '@reduxjs/toolkit'\nimport { isUnreadMessage } from 'domains/store/slice'\nimport { selectEvents } from 'ui/hooks/seamly-state-hooks'\nimport { readStates } from 'ui/utils/seamly-utils'\nimport { RootState } from '.'\n\nexport const selectUnreadEvents = createSelector(selectEvents, (events) => {\n return events.filter((event) => {\n return (\n isUnreadMessage(event) &&\n event.type !== 'service_data' &&\n event.payload?.messageStatus === readStates.received\n )\n })\n})\nexport const selectLastUnreadEvent = createSelector(\n selectUnreadEvents,\n (events) => events.at(-1),\n)\n\nexport const selectUnreadEventIds = createSelector(\n selectUnreadEvents,\n (events) => events.map((event) => event.payload.id),\n)\n\nexport const selectShowNotifications = createSelector(\n ({ state }: RootState) => state.options.features?.webNotifications,\n (webNotifications) => webNotifications?.enabled,\n)\n","import { RefObject } from 'preact'\nimport {\n MutableRef,\n useCallback,\n useEffect,\n useRef,\n useState,\n} from 'preact/hooks'\nimport { useSelector } from 'react-redux'\nimport { RootState } from 'domains/store'\nimport { selectUnreadEventIds } from 'domains/store/selectors'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { timeout } from 'ui/hooks/focus-helper-hooks'\nimport {\n useEvents,\n useLoadedImageEventIds,\n useSeamlyIsLoading,\n} from 'ui/hooks/seamly-state-hooks'\n\n/**\n * Threshold defines how close to the bottom user needs to scroll for it to be treated as the bottom of the conversation.\n */\nconst THRESHOLD = 10\n\nconst useChatScroll = (\n eventRefs: Record<string, RefObject<HTMLElement>>,\n): {\n containerRef: MutableRef<HTMLDivElement>\n unreadIds: string[]\n scrollToRef: () => void\n scrollToBottom: () => void\n} => {\n const containerRef = useRef<HTMLDivElement>()\n const [hasScrolledToBottom, setHasScrolledToBottom] = useState(true)\n const unreadIds = useSelector(selectUnreadEventIds)\n const events = useEvents()\n const isLoading = useSeamlyIsLoading()\n const { isOpen } = useVisibility()\n const loadedImageEventIds = useLoadedImageEventIds()\n const { processingFileUploads, isLastEventFromClient } = useSelector(\n ({ state }: RootState) => state,\n )\n\n useEffect(() => {\n const element = containerRef.current\n const onScroll = () => {\n const { scrollHeight, scrollTop, clientHeight } = element\n const hasScrolledUp =\n Math.abs(scrollHeight - scrollTop - clientHeight) > THRESHOLD\n\n setHasScrolledToBottom(!hasScrolledUp)\n }\n\n element.addEventListener('scroll', onScroll)\n\n return () => element.removeEventListener('scroll', onScroll)\n }, [])\n\n const scrollToBottom = useCallback(() => {\n requestAnimationFrame(async () => {\n await timeout(30)\n containerRef.current?.scrollTo({\n top: containerRef.current?.scrollHeight,\n left: 0,\n behavior: 'auto',\n })\n })\n }, [])\n\n useEffect(() => {\n if (isLastEventFromClient) {\n scrollToBottom()\n }\n }, [isLastEventFromClient, scrollToBottom])\n\n useEffect(() => {\n if (hasScrolledToBottom) {\n scrollToBottom()\n }\n }, [\n hasScrolledToBottom,\n unreadIds,\n events,\n isLoading,\n isOpen,\n loadedImageEventIds,\n processingFileUploads,\n scrollToBottom,\n ])\n\n const scrollToRef = () => {\n const ref = eventRefs[unreadIds?.at(0)]?.current\n // We scroll to the oldest unread event\n containerRef.current?.scrollTo({\n top: ref?.offsetTop,\n behavior: 'auto',\n left: 0,\n })\n }\n\n return {\n containerRef,\n unreadIds,\n scrollToRef,\n scrollToBottom,\n }\n}\n\nexport default useChatScroll\n","import { RefObject, createRef } from 'preact'\nimport { useMemo } from 'preact/hooks'\nimport { className } from 'lib/css'\nimport ChatScrollContext from 'ui/components/conversation/event/chat-scroll/chat-scroll-context'\nimport UnreadMessagesButton from 'ui/components/conversation/event/chat-scroll/unread-messages-button'\nimport useChatScroll from 'ui/components/conversation/use-chat-scroll'\nimport { useEvents } from 'ui/hooks/seamly-hooks'\n\nconst ChatScrollProvider = ({ children }) => {\n const events = useEvents()\n const eventRefs = useMemo(\n () =>\n events.reduce<Record<string, RefObject<HTMLElement>>>((acc, value) => {\n if (!value.payload.id) return acc\n\n acc[value.payload.id] = createRef()\n return acc\n }, {}),\n [events],\n )\n\n const { scrollToRef, scrollToBottom, containerRef, unreadIds } =\n useChatScroll(eventRefs)\n\n return (\n <ChatScrollContext.Provider\n value={{\n eventRefs,\n unreadIds,\n scrollToRef,\n scrollToBottom,\n containerRef,\n }}\n >\n <div className={className('chat__container')}>\n <div\n className={className('chat__container__scroll-area')}\n ref={containerRef}\n >\n {children}\n </div>\n <UnreadMessagesButton />\n </div>\n </ChatScrollContext.Provider>\n )\n}\n\nexport default ChatScrollProvider\n","import { useI18n } from 'domains/i18n/hooks'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport { useSeamlyLayoutMode } from 'ui/hooks/seamly-state-hooks'\n\nconst CollapseButton = () => {\n const { t } = useI18n()\n const { isOpen, closeChat } = useVisibility()\n const { isWindow } = useSeamlyLayoutMode()\n return isOpen && isWindow ? (\n <button\n type=\"button\"\n className={className('button', 'collapse-button')}\n onClick={closeChat}\n >\n <Icon name=\"chevronDown\" size=\"32\" alt={t('window.srCollapseButton')} />\n </button>\n ) : null\n}\n\nexport default CollapseButton\n","import { useEffect } from 'preact/hooks'\nimport { useInterrupt } from 'domains/interrupt/hooks'\nimport { className } from 'lib/css'\nimport CollapseButton from 'ui/components/view/window-view/collapse-button'\nimport {\n useGeneratedId,\n useLiveRegion,\n useSeamlyCommands,\n useSkiplinkTargetFocusing,\n} from 'ui/hooks/seamly-hooks'\n\nconst Interrupt = () => {\n const {\n meta: { originalError, title, message, buttonText, action, srText },\n } = useInterrupt()\n const seamlyCommands = useSeamlyCommands()\n const headingId = useGeneratedId()\n const { sendPolite } = useLiveRegion()\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n const isExpiredError = originalError?.name === 'SeamlySessionExpiredError'\n\n useEffect(() => {\n if (!isExpiredError && srText) {\n // Wait for live regions to stabilise in case this occurs\n // at an initial render\n setTimeout(() => {\n sendPolite(srText)\n }, 200)\n }\n }, [sendPolite, srText, isExpiredError])\n\n const onClickHandler = () => {\n if (seamlyCommands[action]) {\n seamlyCommands[action]()\n }\n focusSkiplinkTarget()\n }\n\n return !isExpiredError ? (\n <section className={className('interrupt')} aria-labelledby={headingId}>\n <CollapseButton />\n <div className={className('interrupt__body')}>\n <h2 id={headingId} className={className('interrupt__title')}>\n {title}\n </h2>\n <p className={className('interrupt__message')}>{message}</p>\n {buttonText && action && (\n <div className={className('interrupt__actions')}>\n <button\n type=\"button\"\n className={className('button', 'button--primary')}\n onClick={onClickHandler}\n >\n {buttonText}\n </button>\n </div>\n )}\n </div>\n </section>\n ) : (\n <></>\n )\n}\n\nexport default Interrupt\n","import { useSelector } from 'react-redux'\nimport { selectHasError } from 'domains/interrupt/selectors'\nimport TranslationStatus from 'domains/translations/components/translation-status'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport AppOptions from 'ui/components/app-options'\nimport ChatScrollProvider from 'ui/components/conversation/event/chat-scroll/chat-scroll-provider'\nimport EntryContainer from 'ui/components/entry/entry-container'\nimport CollapseButton from 'ui/components/view/window-view/collapse-button'\nimport Interrupt from './interrupt'\n\nfunction ChatFrame({ children }) {\n const hasError = useSelector(selectHasError)\n const { isOpen } = useVisibility()\n\n if (hasError) {\n return <Interrupt />\n }\n\n return (\n <>\n <ChatScrollProvider>\n <div className={className('chat__container__header')}>\n <TranslationStatus />\n <CollapseButton />\n </div>\n {children}\n </ChatScrollProvider>\n <EntryContainer />\n {isOpen && <AppOptions />}\n </>\n )\n}\n\nexport default ChatFrame\n","import { useRef } from 'preact/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport { useSeamlyStateContext } from 'ui/hooks/seamly-hooks'\nimport Icon from './icon'\n\nconst Header = ({ children, onCloseChat }) => {\n const { headerCollapseButtonId } = useSeamlyStateContext()\n const closeButton = useRef(null)\n\n const { t } = useI18n()\n return (\n <header className={className('chat__header')}>\n {children}\n <div className={className('header-controls')}>\n <button\n type=\"button\"\n className={className('button', 'header-controls__collapse')}\n onClick={onCloseChat}\n ref={closeButton}\n id={headerCollapseButtonId}\n >\n <Icon name=\"chevronDown\" size=\"32\" alt={t('header.collapseApp')} />\n </button>\n </div>\n </header>\n )\n}\n\nexport default Header\n","import { ChannelEvent } from 'domains/store/store.types'\nimport { className } from 'lib/css'\nimport useEventComponentMapping from 'ui/hooks/use-event-component-mapping'\n\nfunction CollapsedChatMessage({ event }: { event: ChannelEvent }) {\n const [Component] = useEventComponentMapping(event)\n\n return (\n <li>\n <Component event={event} />\n </li>\n )\n}\n\nexport function CollapsedChatMessages({ events }: { events: ChannelEvent[] }) {\n return (\n <ul className={className('collapsed-chat-messages')}>\n {events.map((event) => (\n <CollapsedChatMessage key={event.payload.id} event={event} />\n ))}\n </ul>\n )\n}\n","import { useSelector } from 'react-redux'\nimport { useConfig } from 'domains/config/hooks'\nimport { selectHasError } from 'domains/interrupt/selectors'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { CollapsedChatMessages } from './collapsed-chat-messages'\n\nexport default function PreChatMessages() {\n const { preChatEvents } = useConfig()\n const hasError = useSelector(selectHasError)\n const { isOpen } = useVisibility()\n\n const isVisible = !(hasError || !preChatEvents?.length || isOpen)\n\n return isVisible && <CollapsedChatMessages events={preChatEvents} />\n}\n","import { useMemo } from 'preact/hooks'\nimport { ChannelEvent } from 'domains/store/store.types'\nimport { useI18n } from 'package/hooks'\nimport { CollapsedChatMessages } from './collapsed-chat-messages'\n\nexport default function ContinueChatMessages() {\n const { t } = useI18n()\n const continueChatText = t('window.chat.continue')\n const continueChatEvent = useMemo(\n (): ChannelEvent => ({\n type: 'message',\n payload: {\n body: {\n text: continueChatText,\n },\n },\n }),\n [continueChatText],\n )\n\n return <CollapsedChatMessages events={[continueChatEvent]} />\n}\n","import { useCallback } from 'preact/hooks'\nimport { useSelector } from 'react-redux'\nimport { useStartChatIcon } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { selectHasError } from 'domains/interrupt/selectors'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport InOutTransition, {\n transitionStartStates,\n} from 'ui/components/widgets/in-out-transition'\nimport { useSkiplinkTargetFocusing } from 'ui/hooks/focus-helper-hooks'\nimport { useSeamlyHasConversation } from 'ui/hooks/seamly-api-hooks'\nimport {\n useSeamlyCurrentAgent,\n useSeamlyUnreadCount,\n} from 'ui/hooks/seamly-state-hooks'\n\nconst ButtonIcon = () => {\n const startChatIcon = useStartChatIcon()\n const currentAgent = useSeamlyCurrentAgent()\n const hasError = useSelector(selectHasError)\n const isActiveConversation = currentAgent && !hasError\n const src = isActiveConversation ? currentAgent.avatar : startChatIcon\n return src ? (\n <img\n className={className(isActiveConversation ? 'avatar' : 'icon')}\n src={src}\n alt=\"\"\n />\n ) : (\n <Icon name=\"avatar\" size=\"32\" alt=\"\" />\n )\n}\n\nconst WindowOpenButton = ({ onClick }) => {\n const hasConversation = useSeamlyHasConversation()\n const { t } = useI18n()\n const ariaLabel = hasConversation()\n ? t('window.openButton.srContinue')\n : t('window.openButton.srStart')\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n const { isOpen } = useVisibility()\n const count = useSeamlyUnreadCount()\n const handleClick = useCallback(() => {\n onClick()\n focusSkiplinkTarget()\n }, [focusSkiplinkTarget, onClick])\n return (\n <InOutTransition\n isActive={!isOpen}\n transitionStartState={transitionStartStates.rendered}\n >\n <button\n className={className('window-open-button')}\n aria-label={ariaLabel}\n aria-hidden={isOpen}\n onClick={handleClick}\n >\n <InOutTransition\n isActive={!!count}\n transitionStartState={transitionStartStates.notRendered}\n >\n <span className={className('message-count')} aria-hidden=\"true\">\n {count}\n </span>\n </InOutTransition>\n <ButtonIcon />\n </button>\n </InOutTransition>\n )\n}\n\nexport default WindowOpenButton\n","import { useUserHasResponded } from 'domains/app/hooks'\nimport { useConfig } from 'domains/config/hooks'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport Conversation from 'ui/components/conversation/conversation'\nimport Chat from 'ui/components/layout/chat'\nimport ChatFrame from 'ui/components/layout/chat-frame'\nimport ContinueChatMessages from 'ui/components/layout/continue-chat-messages'\nimport PreChatMessages from 'ui/components/layout/pre-chat-messages'\nimport InOutTransition, {\n transitionStartStates,\n} from 'ui/components/widgets/in-out-transition'\nimport WindowOpenButton from './window-open-button'\n\nconst getDelay = <T extends string>(\n prop: Record<T, number> | boolean,\n val: T,\n init?: number,\n) => (typeof prop === 'object' ? prop[val] : init)\n\nconst WindowView = () => {\n const { isOpen, openChat } = useVisibility()\n const userHasResponded = useUserHasResponded()\n const { continueChat, preChat } = useConfig()\n\n return (\n <>\n <WindowOpenButton onClick={openChat} />\n <InOutTransition\n isActive={preChat && !isOpen && !userHasResponded}\n exitAfter={getDelay(preChat, 'exitAfter')}\n enterDelay={getDelay(preChat, 'enterDelay')}\n transitionStartState={transitionStartStates.notRendered}\n >\n <div\n className={className(\n 'unstarted-wrapper',\n 'unstarted-wrapper--window',\n )}\n >\n <PreChatMessages />\n </div>\n </InOutTransition>\n <InOutTransition\n isActive={continueChat && !isOpen && userHasResponded}\n exitAfter={getDelay(continueChat, 'exitAfter')}\n enterDelay={getDelay(continueChat, 'enterDelay')}\n transitionStartState={transitionStartStates.notRendered}\n >\n <div\n className={className(\n 'unstarted-wrapper',\n 'unstarted-wrapper--window',\n 'unstarted-wrapper--continue',\n )}\n >\n <ContinueChatMessages />\n </div>\n </InOutTransition>\n <InOutTransition\n isActive={isOpen}\n transitionStartState={transitionStartStates.notRendered}\n >\n <Chat>\n <ChatFrame>\n <Conversation />\n </ChatFrame>\n </Chat>\n </InOutTransition>\n </>\n )\n}\n\nexport default WindowView\n","export default __webpack_public_path__ + \"sounds/beep.mp3\";","import { useCallback, useEffect, useMemo, useState } from 'preact/hooks'\nimport { useSelector } from 'react-redux'\nimport { useConfig } from 'domains/config/hooks'\nimport { selectShowNotifications } from 'domains/store/selectors'\nimport { textEntryControlName } from 'ui/components/entry/text-entry'\nimport { useSeamlyServiceInfo } from './seamly-state-hooks'\nimport beep from './sounds/beep.mp3'\n\nconst hasNotificationSupport = !!window.Notification\n\nconst useNotification = () => {\n const { proactiveMessages } = useSeamlyServiceInfo()\n\n const { notificationAudioURL } = useConfig()\n const [permission, setPermission] = useState(\n hasNotificationSupport ? Notification.permission : 'default',\n )\n const [visibilityState, setVisibilityState] = useState(\n document.visibilityState,\n )\n\n const showNotifications = useSelector(selectShowNotifications)\n\n const requestPermission = useCallback(async () => {\n if (hasNotificationSupport && permission !== 'granted') {\n const notificationPermission = await Notification.requestPermission()\n setPermission(notificationPermission)\n }\n }, [permission])\n\n const permissionGranted = useMemo(\n () => permission === 'granted',\n [permission],\n )\n\n const visibilityStateHidden = useMemo(\n () => visibilityState === 'hidden',\n [visibilityState],\n )\n\n useEffect(() => {\n if (permission === 'default' && proactiveMessages) {\n requestPermission()\n }\n }, [permission, proactiveMessages, requestPermission])\n\n const sendNotification = useCallback(\n // eslint-disable-next-line no-undef\n async (title: string, options?: NotificationOptions) => {\n if (!showNotifications || !hasNotificationSupport) return\n\n if (permission === 'default') {\n requestPermission()\n }\n\n if (\n notificationAudioURL !== false &&\n !permissionGranted &&\n (visibilityStateHidden || !document.hasFocus())\n ) {\n try {\n const AudioPlay = new Audio(notificationAudioURL || beep)\n await AudioPlay.play()\n } catch (error) {\n // Autoplay was prevented. See link for more details\n // https://developer.chrome.com/blog/autoplay/#audiovideo-elements\n console.warn(error)\n }\n }\n\n if (\n permissionGranted &&\n (visibilityStateHidden || !document.hasFocus())\n ) {\n const notification = new Notification(title, options)\n\n notification.onclick = function () {\n window.parent.focus()\n window.focus()\n notification.close()\n\n const entry = document.querySelector<HTMLInputElement>(\n `input[name=${textEntryControlName}]`,\n )\n if (entry) entry.focus()\n }\n }\n },\n [\n notificationAudioURL,\n permission,\n permissionGranted,\n requestPermission,\n showNotifications,\n visibilityStateHidden,\n ],\n )\n\n useEffect(() => {\n if (!showNotifications) return () => {}\n\n function handleVisibilityChange() {\n setVisibilityState(document.visibilityState)\n }\n\n document.addEventListener('visibilitychange', handleVisibilityChange, false)\n\n return () => {\n document.removeEventListener('visibilitychange', handleVisibilityChange)\n }\n }, [showNotifications])\n\n return {\n permission,\n requestPermission,\n sendNotification,\n }\n}\n\nexport default useNotification\n","import { useCallback, useEffect, useMemo, useRef } from 'preact/hooks'\nimport { useSelector } from 'react-redux'\nimport { useUserHasResponded } from 'domains/app/hooks'\nimport { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { selectLastUnreadEvent } from 'domains/store/selectors'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport { useTranslatedEventData } from 'package/hooks'\nimport AppView from 'ui/components/view/app-view'\nimport InlineView from 'ui/components/view/inline-view'\nimport WindowView from 'ui/components/view/window-view'\nimport { useSeamlyAppContainerClassNames } from 'ui/hooks/component-helper-hooks'\nimport { useSeamlyContainerElement } from 'ui/hooks/focus-helper-hooks'\nimport {\n useSeamlyCurrentAgent,\n useSeamlyServiceInfo,\n} from 'ui/hooks/seamly-state-hooks'\nimport useNotification from 'ui/hooks/use-notifications'\n\nconst ViewComponentsMap = {\n app: AppView,\n inline: InlineView,\n window: WindowView,\n}\n\nfunction stripHtml(html?: string | undefined) {\n const tmp = document.createElement('div')\n tmp.innerHTML = html\n return tmp.textContent || tmp.innerText || ''\n}\n\nconst View = ({ children }) => {\n const { sendNotification } = useNotification()\n const [, setSeamlyContainerElement] = useSeamlyContainerElement()\n const { namespace, layoutMode, zIndex } = useConfig()\n const currentAgent = useSeamlyCurrentAgent()\n const { proactiveMessages } = useSeamlyServiceInfo()\n const { isOpen, isVisible } = useVisibility()\n const appContainerClassNames = useSeamlyAppContainerClassNames()\n const userHasResponded = useUserHasResponded()\n const lastUnreadEvent = useSelector(selectLastUnreadEvent)\n const { body } = useTranslatedEventData(lastUnreadEvent)\n const { userLocale } = useI18n()\n const prevLastUnreadEventId = useRef<string | undefined>(undefined)\n\n const notificationBody = useMemo(() => {\n return body\n ? // @ts-ignore\n stripHtml(body?.text || body?.prompt?.text || body)\n : undefined\n }, [body])\n\n useEffect(() => {\n if (\n !currentAgent?.name ||\n !notificationBody ||\n !proactiveMessages ||\n !lastUnreadEvent ||\n prevLastUnreadEventId.current === lastUnreadEvent.payload?.id\n ) {\n return\n }\n\n sendNotification(currentAgent.name, {\n body: notificationBody,\n icon: currentAgent?.avatar,\n })\n\n prevLastUnreadEventId.current = lastUnreadEvent.payload.id\n }, [\n currentAgent?.avatar,\n currentAgent?.name,\n lastUnreadEvent,\n notificationBody,\n proactiveMessages,\n sendNotification,\n ])\n const ViewComponent = ViewComponentsMap[layoutMode]\n\n const containerElementRef = useCallback(\n (container: HTMLElement) => {\n if (typeof setSeamlyContainerElement !== 'function') return\n setSeamlyContainerElement(container)\n },\n [setSeamlyContainerElement],\n )\n\n const blockLang = useMemo(() => {\n if (userLocale) {\n const htmlElementLang = document\n .querySelector('html')\n .getAttribute('lang')\n if (htmlElementLang !== userLocale) {\n return userLocale\n }\n }\n return undefined\n }, [userLocale])\n\n if (!ViewComponent) {\n console.warn('\"layoutMode\" should be one of \"app\", \"inline\" or \"window\"')\n return null\n }\n\n const defaultClassNames = [\n `app--layout-${layoutMode}`,\n `namespace--${namespace}`,\n ]\n\n const classNames = ['app', ...defaultClassNames]\n\n if (typeof appContainerClassNames !== 'function') {\n classNames.push(...appContainerClassNames)\n }\n\n if (!isOpen && layoutMode !== 'app') {\n classNames.push('app--collapsed')\n }\n\n if (userHasResponded) {\n classNames.push('app--user-responded')\n }\n\n return (\n isVisible && (\n <div\n className={className(classNames)}\n lang={blockLang}\n tabIndex={-1}\n data-nosnippet\n style={{ zIndex }}\n ref={containerElementRef}\n >\n {children || <ViewComponent />}\n </div>\n )\n )\n}\n\nexport default View\n","import Conversation from '../conversation/conversation'\nimport Chat from '../layout/chat'\nimport ChatFrame from '../layout/chat-frame'\n\nconst AppView = () => {\n return (\n <Chat>\n <ChatFrame>\n <Conversation />\n </ChatFrame>\n </Chat>\n )\n}\n\nexport default AppView\n","import { useShowInlineView, useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport Conversation from '../conversation/conversation'\nimport Chat from '../layout/chat'\nimport ChatFrame from '../layout/chat-frame'\nimport PreChatMessages from '../layout/pre-chat-messages'\nimport Suggestions from '../suggestions'\nimport InOutTransition, {\n transitionStartStates,\n} from '../widgets/in-out-transition'\n\nconst InlineView = () => {\n const { showInlineView, containerRef } = useShowInlineView()\n\n const { isOpen } = useVisibility()\n return (\n <>\n <InOutTransition\n isActive={!isOpen}\n transitionStartState={transitionStartStates.rendered}\n >\n <div\n ref={containerRef}\n className={className(\n 'unstarted-wrapper',\n 'unstarted-wrapper--inline',\n )}\n >\n <PreChatMessages />\n <Suggestions />\n </div>\n </InOutTransition>\n <InOutTransition\n isActive={isOpen}\n transitionStartState={transitionStartStates.rendered}\n >\n <Chat ref={containerRef}>\n {showInlineView && (\n <ChatFrame>{isOpen && <Conversation />}</ChatFrame>\n )}\n </Chat>\n </InOutTransition>\n </>\n )\n}\n\nexport default InlineView\n"],"names":["self","window","debug","Set","CSS_NAME","userParticipantId","screenReaderDebounceDelaySeconds","maxCharacterWarningLimit","maxCharacterSrDebounceDelay","defaultTransitionTimeMs","typingTimeout","defaultConfig","namespace","layoutMode","messages","agent","showAvatar","showName","user","timeIndicator","enabled","threshold","initializeApp","createAsyncThunk","_","extra","api","config","rejectWithValue","__awaiter","contentLocale","_a","context","userLocale","_b","environment","sendEnvironment","getEnvironment","hasConversation","initialState","getConversationIntitialState","sendContext","Object","assign","_c","topic","send","type","actionTypes","setTopic","body","name","fallbackMessage","undefined","e","SeamlySessionExpiredError","err","message","originalEvent","originalError","action","SeamlyUnavailableError","langKey","resetApp","createDebouncedAsyncThunk","typePrefix","payloadCreator","debounceOptions","wait","maxWait","leading","resolve","debounceTimer","maxWaitTimer","invoke","clearTimeout","condition","debounceExecutionCondition","immediate","setTimeout","Promise","res","dispatch","disconnect","clearStore","resetConfig","initializeConfig","initializeVisibility","selectUserHasResponded","createSelector","app","userHasResponded","appSlice","createSlice","reducers","setHasResponded","state","payload","extraReducers","builder","addCase","pending","fulfilled","userResponded","actions","features","defaultLocale","preChat","agentParticipant","userParticipant","startChatIcon","getConfig","defaultContentLocale","connectWhenInView","error","useConfig","useSelector","selectConfig","useStartChatIcon","newConfig","visible","visibilityStates","open","minimized","appContainerClassNames","initialConfigState","domain","key","secure","notificationAudioURL","hideOnNoUserResponse","showDisclaimer","showSuggestions","enterDelay","exitAfter","continueChat","customComponents","defaults","preChatEvents","configKeys","updateState","pick","partialConfig","__rest","newState","keys","length","configSlice","setConfig","updateConfig","setPreChatEvents","map","createAction","initialFormState","controls","initialControlState","value","touched","formsSlice","registerForm","persistData","formId","formState","deregisterForm","registerControl","deregisterControl","form","updateControlValue","updateControlTouched","setLocale","translations","getTranslations","locale","getState","i18n","isLoading","_arrayLikeToArray","arr","len","i","arr2","Array","_typeof","o","Symbol","iterator","constructor","prototype","toPropertyKey","t","r","toPrimitive","call","TypeError","String","_defineProperties","target","props","descriptor","enumerable","configurable","writable","defineProperty","_defineProperty","obj","flatten","array","reduce","accumulator","concat","isArray","parseCases","string","isWhitespace","ch","test","args","cases","currTermStart","latestTerm","inTerm","slice","caseBody","branchEndIndex","findClosingBracket","Error","push","fromIndex","depth","char","charAt","splitFormattedArgument","block","split","separator","limit","arguments","indexOfDelimiter","indexOf","head","substring","trim","tail","pluralFormatter","MessageFormatter","func","cache","_this","this","typeHandlers","instance","Constructor","_classCallCheck","values","process","join","_len","_key","arg","toString","Date","toISOString","JSON","stringify","hasOwnProperty","result","apply","protoProps","blockStartIndex","blockEndIndex","_splitFormattedArgume2","l","n","u","a","f","next","done","minLen","from","format","typeHandler","bind","ownKeys","object","enumerableOnly","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","_objectSpread","source","forEach","getOwnPropertyDescriptors","defineProperties","keyCounter","OTHER$1","replaceNumberSign","output","numBraces","numberValues","keyParam","OTHER","formatter","plural","_parseCases","intValue","parseInt","startsWith","keywordPossibilities","Intl","resolvedOptions","PluralRules","pluralKeyword","select","keyword","_replaceNumberSign","useI18n","selectTranslations","selectLocale","initialLocale","selectInitialLocale","selectIsLoading","useCallback","translation","console","warn","useInterrupt","selectError","hasError","selectHasError","meta","useMemo","title","srText","buttonText","interrupt","Boolean","interruptSlice","setInterrupt","clearInterrupt","addMatcher","isAnyOf","rejected","setVisibility","getConversation","events","lastEvent","payloadLastEventId","id","i18nSlice","setInitialLocale","setTranslations","sort","accum","combineReducers","stateReducer","appReducer","configReducer","i18nReducer","translationReducer","visibility","visibilityReducer","forms","formsReducer","interruptReducer","useAppDispatch","useDispatch","isUnreadMessage","document","visibilityState","eventTypes","fromClient","info","payloadTypes","text","orderHistory","occurredAt","occurredAtA","occurredAtB","participantReducer","participantInfo","participants","currentAgent","avatar","introduction","participant","oldParticipant","newParticipants","calculateNewEntryMeta","entryMeta","channelEvent","entry","translatedEntry","blockAutoEntrySwitch","translatedActions","optionsOverride","options","newActive","active","userSelected","initialStoreState","isLastEventFromClient","unreadEvents","loadedImageEventIds","idleDetachCountdown","hasCountdown","isActive","remaining","wasStopped","count","timer","resumeConversationPrompt","serviceInfo","activeServiceSessionId","proactiveMessages","headerTitles","subTitle","historyLoaded","skiplinkTargetId","randomId","optionsButtonId","headerCollapseButtonId","serviceData","webNotifications","panelActive","optionActive","userSelectedOptions","showFileUpload","currentUploads","processingFileUploads","default","entryTypes","seamlyContainerElement","storeSlice","addEvent","eventType","accountHasUploads","featureKeys","uploads","newOptions","entryType","enabledFromEntry","upload","incrementUnread","find","newEntryMeta","messageStatus","readStates","read","received","ackEvent","transactionId","matchedEvent","m","clearEvents","setEventsRead","event","setLoadedImageEventIds","setHistory","history","activeServiceSettings","mergeHistory","stateEvents","historyEvents","newStateEvents","stateEvent","optimisticallyInjected","some","historyEvent","newHistoryEvents","reverse","mergedParticipants","lastParticipantEvent","lastParticipantId","historyNewEntryMeta","newFeatures","newFeaturesHasUpload","lastParticipantEventPayload","resetHistoryLoadedFlag","setIsLoading","initIdleDetachCountdown","delaySeconds","delayTime","decrementIdleDetachCountdownCounter","prevRemaining","getTimeFromSeconds","stopIdleDetachCountdownCounter","clearIdleDetachCountdown","initResumeConversationPrompt","clearResumeConversationPrompt","setParticipant","setActiveService","setHeaderTitle","setHeaderSubTitle","setInitialState","setServiceDataItem","setFeatures","setFeatureEnabledState","clearFeatures","showOption","hideOption","setUserSelectedOptions","setUserSelectedOption","option","setBlockAutoEntrySwitch","setServiceEntryMetadata","setActiveEntryType","setUserEntryType","clearAbortTransaction","registerUpload","fileId","fileName","progress","uploading","complete","uploadHandle","setUploadProgress","fileUpload","startProcessingImage","doneProcessingImage","setUploadError","errorText","setUploadComplete","clearAllUploads","setSeamlyContainerElement","setProactiveMessages","selectIsTranslated","store","translatedEventGroups","every","includes","useTranslations","useSeamlyCommands","enableTranslations","disableTranslations","disableTranslation","languages","isAvailable","currentLocale","useTranslatedEventData","translatedBody","translatedIntroduction","_e","_d","_f","hasTranslation","isTranslated","useTranslationsContainer","containerId","focusContainer","useElementFocusingById","useLocaleNativeName","lang","nativeName","useTranslationProposal","sendAction","translationProposal","isOpen","useVisibility","proposedLocale","proposedLocaleNativeName","showProposal","language","activateTranslationProposal","dismissTranslationProposal","dismiss","TRANSLATION_PROPOSAL","disableTranslationProposalPrompt","translationsInitialState","nanoid","getLastGroupId","eventGroup","acc","_index","translationEnabled","splice","groupId","eventIds","entries","lastGroupId","at","translationSlice","enableTranslation","enableEventsTranslation","disableEventsTranslation","setTranslationProposalPrompt","feature","b","localeCompare","sensitivity","validVisibilityStates","hidden","requestedVisibility","eventBus","previousVisibility","Selectors","ConfigSelectors","visibilityCallback","calculateVisibility","unreadMessageCount","selectState","calculatedVisibility","hasResponded","get","StoreKey","set","emit","storedVisibility","initialize","selectVisibility","isVisible","isMinimized","dispatchVisibility","openChat","closeChat","useIntersect","freezeOnceVisible","containerRef","createRef","setEntry","useState","isIntersecting","frozen","observerCallback","updatedEntry","useEffect","node","current","IntersectionObserver","observer","root","rootMargin","observe","useShowInlineView","showInlineView","selectShowInlineView","setShowInlineView","visibilitySlice","SeamlyApiContext","createContext","SeamlyEventBusContext","useSeamlyApiContext","useContext","useSeamlyObjectStore","useSeamlyHasConversation","useSeamlyStateContext","selectEventsWithSuggestion","hasUserResponded","suggestion","suggestionsEvent","selectEvents","mappedEvents","previousEvent","idx","microsecondsToMilliseconds","useEvents","useSeamlyIsLoading","useSeamlyHeaderData","useSeamlyUnreadCount","useLoadedImageEventIds","useSkiplink","useSeamlyParticipant","participantId","useSeamlyServiceInfo","selectLastMessageEventId","filteredEvents","useLastMessageEventId","useSeamlyCurrentAgent","useSeamlyServiceData","useEntryTextLimit","overrideText","hasLimit","useSeamlyLayoutMode","isInline","isWindow","isApp","isResolving","system","choicePrompt","image","video","divider","countdown","cta","splash","pickChoice","navigate","custom","typing","detachService","interactivityUpdate","sendTranscript","setTranslation","setContext","clickCta","clickCard","dismissTypes","ariaLiveLevels","assertive","polite","dividerKeys","new_topic","new_translation","typingPeekahead","cardTypes","ask","SeamlyBaseError","params","super","captureStackTrace","getPrototypeOf","parsedOriginalMessage","str","parse","parseOriginalErrMsg","SeamlyConfigurationError","SeamlyGeneralError","SeamlyOfflineError","SeamlyUnauthorizedError","useUserHasResponded","defaultVisibility","baseVisibility","className","classes","flat","c","module","exports","Number","Math","random","now","round","performance","ChoicePrompt","children","descriptorId","useGeneratedId","subEvent","showOptions","chooseAgain","onChoiceClickHandler","onChooseAgainClickHandler","setShowOptions","addMessageBubble","addDivider","lastEventId","service","prompt","data","serviceSessionId","choice","originMessage","s","useChoicePrompt","_jsxs","_Fragment","toChildArray","child","showTranslationToggle","onClick","_jsx","Icon","size","alt","MessageContainer","showParticipant","choices","category","EventParticipant","eventPayload","participantName","authorInfo","src","modifiers","bodyProps","classNames","useSeamlyMessageContainerClassNames","v","modifier","SeamlyLiveRegionContext","useSeamlyAppContainerClassNames","timeout","ms","useSeamlyContainerElement","element","elementId","el","requestAnimationFrame","async","focusEl","getElementById","focusElement","useSkiplinkTargetFocusing","useLiveRegion","sendMessage","sendPolite","messageText","ariaLive","sendAssertive","useFileUploadMeta","uploadsFeature","allowedMimeTypes","allowedMimeTypesOverride","maxSize","maxSizeOverride","uploadsEnabled","uploadsEnabledFromEntry","accountAllowsUploads","serviceAllowsUploads","useFileUploads","SeamlyFileUploadContext","uploadFile","file","clearUploads","isUploading","isComplete","useSeamlyOptions","extraMenuItem","optionsObj","menuTitle","menuOptions","available","allowOptionSelection","initUserSelectedOptions","storedOptions","dispatchUserSelectedOptions","optionValues","dispatchUserSelectedOption","optionName","dispatchShowOption","dispatchHideOption","useOptionButton","focusButton","useSeamlyActivityEventHandler","SeamlyActivityEventContext","emitEvent","start","reset","AppActions","getMessageBase","getTextMessageBase","bodyText","addUploadBubble","contentType","filename","filesize","url","subtype","fromHistory","connect","connected","reject","then","catch","apiConnected","apiConfigReady","configReady","useSeamlyIdleDetachCountdown","isSeamlyOpen","stableState","useRef","sendAssertiveIfOpen","sendPoliteIfOpen","initCountdown","milliseconds","millisecondsToSeconds","endCountdown","isServerAction","decrementCountdown","newRemaining","stopCountdown","useSeamlyResumeConversationPrompt","hasPrompt","restartChat","useForceUpdate","forceUpdate","useReducer","x","useStableCallback","callback","callbackRef","isFunction","debounce","isCancelled","runInstant","createAriaHider","originalValues","rootNodes","querySelectorAll","attr","getAttribute","setAttribute","index","originalValue","removeAttribute","ceil","microseconds","seconds","minutes","floor","formatBytes","bytes","decimals","dm","log","parseFloat","toFixed","keyCodes","keyNames","Escape","End","Home","ArrowLeft","ArrowUp","ArrowRight","ArrowDown","getKey","code","keyCode","focus","runIfElementContainsOrHasFocus","contains","activeElement","getRelativeDate","date","currentDate","msMidnightToday","setHours","msDate","getTime","dayInMs","g","C","E","w","ref","shouldComponentUpdate","displayName","isReactComponent","__f","isPureReactComponent","__b","R","for","N","$$typeof","render","k","A","only","toArray","O","__e","__","__c","__k","T","unmount","F","__H","__P","I","__v","appendChild","L","__u","U","__a","D","M","__R","__O","setState","pop","componentWillUnmount","createElement","fallback","V","delete","revealOrder","W","getChildContext","P","nodeType","parentNode","childNodes","insertBefore","removeChild","j","containerInfo","Map","componentDidUpdate","componentDidMount","z","B","H","Z","Y","$","q","textContent","G","J","K","Q","cancelBubble","X","defaultPrevented","persist","isPropagationStopped","isDefaultPrevented","nativeEvent","nn","tn","class","en","vnode","toLowerCase","replace","multiple","selected","defaultValue","rn","__r","un","diffed","on","ReactCurrentDispatcher","readContext","__n","ln","cn","fn","an","sn","hn","vn","base","dn","pn","mn","yn","_n","bn","Sn","gn","Cn","h","En","wn","useId","useLayoutEffect","useInsertionEffect","useTransition","useDeferredValue","useSyncExternalStore","startTransition","useImperativeHandle","useDebugValue","version","Children","hydrate","unmountComponentAtNode","createPortal","createFactory","cloneElement","Fragment","isValidElement","isElement","isFragment","findDOMNode","Component","PureComponent","memo","forwardRef","flushSync","unstable_batchedUpdates","StrictMode","Suspense","SuspenseList","lazy","__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED","ICONS","balloon","newTopic","newTranslation","chevronDown","chevronRight","close","enlarge","download","arrowLeft","arrowRight","check","dangerouslySetInnerHTML","__html","p","is","useSyncExternalStoreWithSelector","hasValue","d","require","NOTHING","DRAFTABLE","DRAFT_STATE","die","isDraft","isDraftable","isMap","isSet","objectCtorString","proto","Ctor","Function","each","iter","getArchtype","thing","type_","has","prop","propOrOldValue","add","latest","copy_","base_","shallowCopy","strict","create","descriptors","Reflect","desc","freeze","deep","isFrozen","clear","dontMutateFrozenCollections","currentScope","plugins","getPlugin","pluginKey","plugin","getCurrentScope","usePatchesInScope","scope","patchListener","patches_","inversePatches_","patchListener_","revokeScope","leaveScope","drafts_","revokeDraft","parent_","enterScope","immer2","immer_","canAutoFreeze_","unfinalizedDrafts_","draft","revoke_","revoked_","processResult","baseDraft","modified_","finalize","maybeFreeze","generateReplacementPatches_","rootScope","path","childValue","finalizeProperty","scope_","finalized_","resultEach","isSet2","generatePatches_","parentState","targetObject","rootPath","targetIsSet","assigned_","autoFreeze_","objectTraps","getDescriptorFromProto","draft_","readPropFromProto","peek","prepareCopy","createProxy","current2","currentState","y","markChanged","isNaN","deleteProperty","owner","setPrototypeOf","arrayTraps","useStrictShallowCopy_","parent","proxyMap_","proxySet_","isManual_","traps","revoke","proxy","Proxy","revocable","createProxyProxy","currentImpl","copy","immer","produce","recipe","defaultBase","base2","ip","produceWithPatches","patches","inversePatches","autoFreeze","setAutoFreeze","useStrictShallowCopy","setUseStrictShallowCopy","createDraft","finishDraft","applyPatches","patch","op","applyPatchesImpl","applyPatches_","hasMatchFunction","createSelector2","createDraftSafeSelector2","args2","selector","wrappedSelector","rest","withTypes","createDraftSafeSelectorCreator","__REDUX_DEVTOOLS_EXTENSION_COMPOSE__","__REDUX_DEVTOOLS_EXTENSION__","match","prepareAction","actionCreator","prepared","formatProdErrorMessage","freezeDraftable","val","emplace","handler","update","insert","inserted","species","executeReducerBuilderCallback","builderCallback","actionsMap","actionMatchers","defaultCaseReducer","typeOrActionCreator","reducer","matcher","addDefaultCase","matches","matchers","commonProperties","RejectWithValue","_type","FulfillWithMeta","miniSerializeError","simpleError","property","createAsyncThunk2","requestId","requestStatus","serializeError","rejectedWithValue","aborted","idGenerator","abortController","AbortController","abortHandler","abortReason","abort","reason","promise","finalAction","conditionResult","signal","abortedPromise","addEventListener","getPendingMeta","race","fulfillWithValue","removeEventListener","dispatchConditionRejection","unwrap","unwrapResult","settled","asyncThunkSymbol","getType","actionKey","wrapSelector","getInitialState","injected","wrapper","rootState","sliceState","unwrapped","creators","cAT","asyncThunk","reducerPath","_reducerDefinitionType","caseReducer","preparedReducer","prepare","buildReducerCreators","reducerNames","sliceCaseReducersByName","sliceCaseReducersByType","actionCreators","sliceMatchers","contextMethods","reducer2","exposeAction","name2","exposeCaseReducer","buildReducer","finalCaseReducers","mapOrBuilderCallback","finalActionMatchers","finalDefaultCaseReducer","sM","frozenInitialState","caseReducers","cr","previousState","createReducer","reducerName","reducerDefinition","reducerDetails","createNotation","isAsyncThunkSliceReducerDefinition","maybeReducerWithPrepare","prepareCallback","isCaseReducerWithPrepareDefinition","handleNormalReducerDefinition","thunk","noop","handleThunkCaseReducerDefinition","selectSelf","injectedSelectorCache","_reducer","makeSelectorProps","reducerPath2","selectSlice","getSelectors","selectorCache","WeakMap","selectors","injectInto","injectable","pathOpt","newReducerPath","inject","buildCreateSlice","alm","getListenerEntryPropsFrom","predicate","effect","expected","assertFunction","createListenerEntry","unsubscribe","addListener","removeListener","React","ContextKey","gT","globalThis","getContext","contextMap","realContext","ReactReduxContext","createReduxContextHook","useReduxContext","refEquality","createSelectorHook","useReduxContext2","useSelector2","equalityFnOrOptions","equalityFn","devModeChecks","subscription","getServerState","stabilityCheck","identityFunctionCheck","selectedState","addNestedSub","createStoreHook","useStore2","getOwnPropertyNames","useStore","createDispatchHook","useDispatch2","randomString","actionTypes_default","INIT","REPLACE","PROBE_UNKNOWN_ACTION","reducerKeys","finalReducers","finalReducerKeys","shapeAssertionError","assertReducerShape","hasChanged","nextState","previousStateForKey","nextStateForKey","compose","funcs","isAction","isPlainObject","ensureIsArray","item","Ref","WeakRef","deref","UNTERMINATED","TERMINATED","createCacheNode","weakMapMemoize","fnNode","resultEqualityCheck","lastResult","resultsCount","memoized","cacheNode","objectCache","objectNode","primitiveCache","primitiveNode","terminatedNode","lastResultValue","clearCache","resetResultsCount","createSelectorCreator","memoizeOrOptions","memoizeOptionsFromArgs","createSelectorCreatorOptions","memoize","memoizeOptions","createSelectorArgs","recomputations","dependencyRecomputations","directlyPassedOptions","resultFunc","errorMessage","assertIsFunction","combinedOptions","argsMemoize","argsMemoizeOptions","finalMemoizeOptions","finalArgsMemoizeOptions","dependencies","itemTypes","assertIsArrayOfFunctions","getDependencies","memoizedResultFunc","inputSelectorResults","inputSelectorArgs","collectInputSelectorResults","resetDependencyRecomputations","resetRecomputations","createStructuredSelector","inputSelectorsObject","selectorCreator","assertIsObject","inputSelectorKeys","composition","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","getter","__esModule","definition","toStringTag","scriptUrl","importScripts","location","currentScript","scripts","getElementsByTagName","PrivacyDisclaimer","tabIndex","getFormById","getFormControlsByFormId","getFormValuesByFormId","valuesObj","getControlValueByName","getControlTouchedByName","FormContext","handleSubmit","isSubmitted","isValid","errors","Provider","Consumer","useFormContext","useFormControl","isRegistered","onInput","onBlur","useCharacterLimit","controlName","debouncedSendAssertive","validateLimit","_reachedCharacterWarning","_remainingChars","remainingChars","reachedCharacterWarning","reachedCharacterLimit","hasCharacterLimit","characterLimit","useEntryTextTranslation","placeholder","label","labelClass","AbortTransactionButton","abortTransaction","clearEntryAbortTransaction","useEntryAbortTransaction","topicName","topicFallbackMessage","description","hasFocus","isCarouselItem","cardRef","descriptionId","isMounted","CardActionComponent","emitCardEvent","handleClick","actionProps","href","link","rel","newTab","blur","CarouselMessageSlide","slide","items","role","total","CardComponent","CarouselControls","currentIndex","onChange","itemCount","handlePrevious","handleNext","CarouselPagination","getItemKey","getItemLabel","handlePaginate","slideIndex","dataset","nextIndex","min","max","defaultGetItemKey","prefix","defaultGetItemLabel","preventScroll","scrollLeft","CarouselComponent","originalIndex","carouselItemsId","setCurrentIndex","slideRefs","fill","isMountRef","onChangeRef","onScroll","style","width","left","controlId","mapCategoryToClass","SuggestionsItem","categories","question","hasIcon","mappedClassNames","SuggestionsList","givenClassName","suggestions","onClickSuggestion","eventId","linkId","EventDivider","childrenHTML","providedClassName","graphicSrc","graphicType","iconName","iconSize","iconClassName","dividerType","hasGraphic","icon","dividerTypes","Variants","Divider","NewTranslationDivider","toggleTranslations","dateFormatOptions","month","day","year","timeFormatOptions","hour","minute","TimeIndicator","time","timeUntilMidnight","eventDate","midnight","fullDateTime","DateTimeFormat","relativeDate","useFormattedDate","candidateSelectors","candidateSelector","NoElement","Element","msMatchesSelector","webkitMatchesSelector","getRootNode","_element$getRootNode","ownerDocument","isInert","lookUp","_node$getAttribute","inertAtt","getCandidates","includeContainer","candidates","unshift","getCandidatesIteratively","elements","elementsToCheck","shift","tagName","assigned","assignedElements","nestedCandidates","scopeParent","shadowRoot","getShadowRoot","validShadowRoot","shadowRootFilter","_nestedCandidates","hasTabIndex","getTabIndex","_node$getAttribute2","attValue","isContentEditable","sortOrderedTabbables","documentOrder","isInput","isZeroArea","_node$getBoundingClie","getBoundingClientRect","height","isNodeMatchingSelectorFocusable","disabled","isHiddenInput","_ref","displayCheck","getComputedStyle","nodeUnderDetails","parentElement","originalNode","rootNode","assignedSlot","host","_nodeRoot","_nodeRootHost","_nodeRootHost$ownerDo","_node$ownerDocument","nodeRoot","nodeRootHost","attached","_nodeRoot2","_nodeRootHost2","_nodeRootHost2$ownerD","isNodeAttached","getClientRects","isHidden","isDetailsWithSummary","isDisabledFromFieldset","isNodeMatchingSelectorTabbable","isRadio","radioSet","radioScope","queryRadios","CSS","escape","checked","nodes","getCheckedRadio","isTabbableRadio","isNonTabbableRadio","isValidShadowRootTabbable","shadowHostNode","sortByOrder","regularTabbables","orderedTabbables","isScope","candidateTabindex","getSortOrderTabIndex","content","sortable","isTabbable","focusableCandidateSelector","isFocusable","_objectSpread2","input","hint","prim","_toPrimitive","_toPropertyKey","isTabEvent","isKeyForward","shiftKey","isKeyBackward","delay","findIndex","valueOrHandler","getActualTarget","composedPath","internalTrapStack","createFocusTrap","userOptions","trap","doc","trapStack","returnFocusOnDeactivate","escapeDeactivates","delayInitialFocus","containers","containerGroups","tabbableGroups","nodeFocusedBeforeActivation","mostRecentlyFocusedNode","paused","delayInitialFocusTimer","recentNavEvent","getOption","configOverrideOptions","configOptionName","findContainerIndex","container","tabbableNodes","getNodeForOption","optionValue","_len2","_key2","querySelector","getInitialFocusNode","tabbableOptions","firstTabbableGroup","firstTabbableNode","updateTabbableNodes","tabbable","focusableNodes","focusable","lastTabbableNode","firstDomTabbableNode","lastDomTabbableNode","posTabIndexesFound","nextTabbableNode","forward","nodeIdx","group","getActiveElement","tryFocus","isSelectableInput","getReturnFocusNode","previousActiveElement","findNextNavNode","_ref2","_ref2$isBackward","isBackward","destinationNode","containerIndex","containerGroup","startOfGroupIndex","_ref3","destinationGroupIndex","destinationGroup","lastOfGroupIndex","_ref4","_destinationGroupIndex","_destinationGroup","checkPointerDown","clickOutsideDeactivates","deactivate","returnFocus","allowOutsideClick","preventDefault","checkFocusIn","targetContained","Document","nextNode","stopImmediatePropagation","navAcrossContainers","mruContainerIdx","mruTabIdx","checkKey","checkKeyNav","checkClick","addListeners","activeTrap","pause","trapIndex","activeFocusTraps","capture","passive","removeListeners","mutationObserver","MutationObserver","mutations","mutation","removedNodes","updateObservedNodes","subtree","childList","activate","activateOptions","onActivate","onPostActivate","checkCanFocusTrap","finishActivation","deactivateOptions","onDeactivate","onPostDeactivate","checkCanReturnFocus","unpause","finishDeactivation","pauseOptions","onPause","onPostPause","unpauseOptions","onUnpause","onPostUnpause","updateContainerElements","containerElements","elementsAsArray","Modal","onClose","ariaLabel","ariaLabelledBy","fallBackFocusRef","modalId","modalContainer","focusTrap","containerIsSet","setContainerIsSet","initialFocus","disposeAriaHider","bodyElement","modalRenderFn","els","Lightbox","onCloseHandler","zIndex","onActivityHandler","onFrameClickHandler","stopPropagation","onFloatClickHandler","onMouseDown","onKeyDown","onTouchStart","onMouseMove","onWheel","onPointerDown","onPointerMove","getModalContent","ImageLightbox","showLightBox","setShowLightBox","onOpenLightboxHandler","onCloseLightboxHandler","Text","eventClick","useEventLinkClickHandler","containerProps","PROCESSING_IMAGE","UploadedImage","img","UploadContent","eventTypeMapping","choice_prompt","Image","isZoomable","showLighbox","setShowLightbox","onLoad","handleOnLoad","Splash","Video","allow","allowFullScreen","Upload","currentFileId","sessionStorage","getItem","useImageFromStorage","Cta","onClickHandler","buttonLink","buttonNewTab","carousel","CarouselMessage","slides","cards","ItemComponent","card","CardMessage","Translation","variables","Participant","service_data","ConversationSuggestions","isExpanded","setIsExpanded","useSuggestions","headingText","footerText","hasLastTransactionEvent","transactionLast","faqId","faqQuestion","ComponentFilter","resolvedComponents","ComponentContext","components","componentType","SubComponent","newParticipant","eventRefs","unreadIds","readIds","Loader","Events","prevParticipant","participantChanged","currentParticipant","debouncedIsLoading","useDebounce","debouncedValue","setDebouncedValue","timeoutRef","focusSkiplinkTarget","Prompt","baseClassName","containerHeadingId","IdleDetachWarning","sendActivity","countDownComplete","transferChat","ResumeConversationPrompt","currentAgentName","continueChatHandler","useSeamlyTyping","typingTimerId","sendEndTypingTimerId","isTyping","typingIntervalId","clearInterval","sendTypingState","currentMessage","setInterval","useSeamlyEntry","defaultEntry","entryOptions","entryOptionsOverride","activeEntry","activeEntryOptions","dispatchBlockAutoEntrySwitch","dispatchActiveEntryType","dispatchUserEntryType","cancelEntrySelection","FormProvider","onError","onSubmit","validationSchema","setIsSubmitted","externalErrors","setExternalErrors","validationIsValid","validationErrors","schema","validations","validationsArr","compareValue","validate","useValidations","setError","ariaDisabled","submitter","contextValue","disableValidationClasses","useForm","formClasses","setIsAvailable","timerId","contentHint","labelText","validity","htmlFor","ariaDescribedBy","field","describedByIds","TextEntryForm","skipLinkId","handleKeyUp","handleFocus","noValidate","autocomplete","onKeyUp","onFocus","textEntryControlName","TextEntry","focusSkipLinkTarget","UploadProgress","getValidator","validateFileSize","fileList","fileListObjectIsNotEmpty","fileListObj","isEmailString","trimmedVal","isNotEmptyString","FileInput","outputText","accept","focusWithin","setFocusWithin","errorId","contentHintId","outputId","handleBlur","handleChange","customEvent","files","FileInputForm","skiplinkId","onClickCancel","hasFile","selectedFileName","Form","formName","fileInputName","cancelButtonRef","canUpload","hasServerError","useSingleFileUpload","currentUpload","notificationId","prevIsComplete","contentHintText","prevContentHintText","handleOnClickCancel","useTimeout","savedCallback","childIsVNode","transitionClasses","in","visuallyHidden","transitionClassesArray","transitionStartStates","notRendered","rendered","transitionStartState","onInTransitionComplete","onOutTransitionComplete","prevIsActive","isVisuallyHidden","activeTransitionClasses","setActiveTransitionClasses","inState","setInState","transitionOutAfter","transitionIn","onInTransitionCompleteHandler","onOutTransitionCompleteHandler","renderChildren","activeTimeout","activeRaf","cancelAnimationFrame","childClassName","cleanClasses","cl","UploadToggle","showUploadButton","setShowUploadButton","prevServiceAllowsUploads","uploadButton","hasAgent","focusFn","InOutTransition","EntryContainer","entryContainer","showCountdown","setShowCountDown","hasResumeConversationPrompt","showResumeConversationPrompt","setShowResumeConversationPrompt","containedFocus","entryComponents","setEntryComponents","renderEntry","setRenderEntry","EntryComponent","AgentInfo","displaySubtitle","Suggestions","isAside","sectionId","eventBody","prevSuggestions","prevHasSuggestions","previousRenderedSuggestions","hasSuggestions","hideSuggestions","prevHideSuggestions","showSuggestionsContainer","renderedSuggestions","suggestionsClassNames","politeText","ContainerElement","forwardedRef","handleClose","closeButtonText","srCloseButtonText","headingId","srButtonText","TranslationProposal","srDismissButtonText","titleLabel","buttonLabel","TranslationStatus","itemClassName","describedById","primaryLanguages","remainingLanguages","isOriginal","isChecked","selectedIdx","onCancel","cancelButtonText","disableButtonFocusing","position","horizontal","vertical","mainHeadingId","closePanel","onCancelHandler","HTMLElement","btn","TranslationsOptionsButton","menuIsOpen","setMenuIsOpen","toggleButton","toggleButtonId","TranscriptForm","Input","mapper","Transcript","errorClass","setErrorClass","transcriptDescriptionId","emailAddress","handleError","OptionsFrame","Options","prevRenderOption","RenderOption","OptionsButton","focusOutDelayTimeoutID","optionsLength","menuItemButtons","prevMenuIsOpen","multiMenu","firstOption","firstOptionName","firstActiveOptionIndex","focusIndex","onfocusout","onFocusOutHandler","onfocusin","onFocusInHandler","onMenuItemKeyDownHandler","newIndex","onKeyPress","onKeyPressHandler","fromCharCode","charCode","foundIndex","onMenuItemClickHandler","AppOptions","isTranslationsAvailable","localeNativeName","openButtonText","hasLanguage","scrollToRef","unreadCount","selectUnreadEvents","selectLastUnreadEvent","selectUnreadEventIds","selectShowNotifications","hasScrolledToBottom","setHasScrolledToBottom","scrollHeight","scrollTop","clientHeight","hasScrolledUp","abs","scrollToBottom","scrollTo","top","behavior","offsetTop","CollapseButton","Interrupt","seamlyCommands","isExpiredError","ChatScrollProvider","Header","onCloseChat","closeButton","CollapsedChatMessage","CollapsedChatMessages","PreChatMessages","ContinueChatMessages","continueChatText","continueChatEvent","ButtonIcon","isActiveConversation","WindowOpenButton","getDelay","init","hasNotificationSupport","Notification","ViewComponentsMap","AppView","Chat","ChatFrame","Conversation","inline","InlineView","sendNotification","useNotification","permission","setPermission","setVisibilityState","showNotifications","requestPermission","notificationPermission","permissionGranted","visibilityStateHidden","AudioPlay","Audio","beep","play","notification","onclick","handleVisibilityChange","lastUnreadEvent","prevLastUnreadEventId","notificationBody","html","tmp","innerHTML","innerText","stripHtml","ViewComponent","containerElementRef","blockLang"],"sourceRoot":""}
|
|
1
|
+
{"version":3,"file":"components.min.js","mappings":";yCAaiC,oBAATA,MAAuBA,KACb,oBAAXC,QAAyBA,eAbhD,oBCIYC,GAAM,UAkBE,IAAIC,yICrBjB,MAAMC,EAAW,OAIXC,EAAoB,4BAQpBC,EAAmC,GAInCC,EAA2B,GAE3BC,EAA8B,IAE9BC,EAA0B,IAG1BC,EAAgB,IAEhBC,EAAiC,CAC5CC,UAAW,UACXC,WAAY,SACZC,SAAU,CACRC,MAAO,CACLC,YAAY,EACZC,UAAU,GAEZC,KAAM,CACJF,YAAY,EACZC,UAAU,GAEZE,cAAe,CACbC,SAAS,EACTC,UAAW,saC9BV,MAAMC,GAAgBC,EAAAA,EAAAA,IAS3B,iBAAiB,CAAOC,GAAKC,OAASC,MAAKC,UAAUC,qBAAqBC,OAAA,uCAC1E,IAAIC,EAA+B,QAAfC,EAAAJ,aAAM,EAANA,EAAQK,eAAO,IAAAD,OAAA,EAAAA,EAAED,cACjCG,EAA4B,QAAfC,EAAAP,aAAM,EAANA,EAAQK,eAAO,IAAAE,OAAA,EAAAA,EAAED,WAElC,MAAME,GAC2B,IAA/BR,EAAOD,IAAIU,gBACPV,EAAIW,iBACJV,EAAOD,IAAIU,gBAEjB,IACE,GAAIV,EAAIY,kBAAmB,CACzB,MAAMC,QAAqBb,EAAIc,+BAM/B,OAJAV,EAAgBS,EAAaP,QAAQF,eAAiBA,EACtDG,EAAaM,EAAaP,QAAQC,YAAcA,EAEhDP,EAAIe,YAAWC,OAAAC,OAAAD,OAAAC,OAAC,CAAC,EAAIJ,EAAaP,SAAO,CAAEG,iBACpC,CAAEI,eAAcT,gBAAeG,aAAYN,SACpD,CAkBE,OAjBmB,QAAfiB,EAAAjB,aAAM,EAANA,EAAQK,eAAO,IAAAY,OAAA,EAAAA,EAAEC,QACnBnB,EAAIoB,KAAK,SAAU,CACjBC,KAAMC,EAAAA,GAAYC,SAClBC,KAAM,CACJC,KAAMxB,EAAOK,QAAQa,MAGrBO,gBAAiBzB,EAAOK,QAAQa,SAMtCnB,EAAIe,YAAWC,OAAAC,OAAAD,OAAAC,OAAC,CAAC,EACZhB,EAAOK,SAAO,CACjBG,iBAEK,CAAEI,kBAAcc,EAAWvB,gBAAeG,aAAYN,SAEjE,CAAE,MAAO2B,GACP,GAAIA,aAAaC,EAAAA,EAA2B,CAC1C,MAAMC,EAAM,IAAID,EAAAA,EAEhB,OAAO3B,EAAgB,CACrBuB,KAAMK,EAAIL,KACVM,QAASD,EAAIC,QACbC,cAAeF,EAAIE,cACnBC,cAAeH,EAAIG,cACnBC,OAAQJ,EAAII,QAEhB,CAEA,MAAMJ,EAAM,IAAIK,EAAAA,EAChB,OAAOjC,EAAgB,CACrBuB,KAAMK,EAAIL,KACVM,QAASD,EAAIC,QACbK,QAASN,EAAIM,SAEjB,CACF,MAEaC,ECrCqBC,EAKhCC,EACAC,EACAC,KAEA,MAAM,KAAEC,EAAO,IAAG,QAAEC,EAAU,EAAC,QAAEC,GAAU,GAAUH,QAAAA,EAAmB,CAAC,EAEzE,IAEII,EAFAC,EAA+C,KAC/CC,EAA8C,KAGlD,MAOMC,EAASA,KACbC,aAAaF,GACbA,OAAepB,EAEXkB,IACFA,GAAQ,GACRA,OAAUlB,EACZ,EA6BF,OAAO9B,EAAAA,EAAAA,IAAiB0C,EAAYC,EAAgB,CAClDU,UA3BiCC,KACjC,MAAMC,EAAYR,IAAYE,EAS9B,OANAG,aAAaH,GACbA,EAAgBO,YAAW,KACzBL,IACAF,EAAgB,IAAI,GACnBJ,KAECU,IA1BAP,IACFA,GAAQ,GACRA,OAAUlB,GA+BRgB,IAAYI,IACdA,EAAeM,WAAWL,EAAQL,IAG7B,IAAIW,SAASC,IAClBV,EAAUU,CAAG,IACb,GAKF,EDvBoBjB,CACtB,YACA,CAAOxC,GAAK0D,WAAUzD,OAASC,UAAWG,OAAA,mCAClCH,EAAIyD,aACVzD,EAAI0D,aAEJF,GAASG,EAAAA,EAAAA,YACHH,GAASI,EAAAA,EAAAA,YACTJ,EAAS5D,KAEf4D,GAASK,EAAAA,EAAAA,KACX,KACA,CACEnB,KAAM,IACNE,SAAS,kDE5FN,MAAMkB,GAAyBC,UAAAA,KACpC,EAAGC,SAAUA,IACb,EAAGC,sBAAuBA,kFCA5B,MAAMpD,EAAyB,CAC7BoD,kBAAkB,GAGPC,GAAWC,EAAAA,EAAAA,IAAY,CAClC1C,KAAM,MACNZ,eACAuD,SAAU,CACRC,gBAAiBA,CAACC,GAASC,cACzBD,EAAML,iBAAmBM,CAAO,GAGpCC,cAAgBC,IACdA,EACGC,QAAQrC,EAAAA,EAASsC,SAAS,IAAM9D,IAChC6D,QAAQ9E,EAAAA,EAAcgF,WAAW,CAACN,GAASC,oBACtCA,EAAQ1D,cAAgB,kBAAmB0D,EAAQ1D,eACrDyD,EAAML,iBAAuC,QAApB5D,EAAAkE,EAAQ1D,oBAAY,IAAAR,OAAA,EAAAA,EAAEwE,cACjD,GACA,KAIK,gBAAER,GAAoBH,EAASY,QAE5C,EAAeZ,EAAgB,iXCnBxB,MAAMN,GAAmB/D,EAAAA,EAAAA,IAK9B,oBACA,CAAOC,GAAKC,OAASC,MAAKC,UAAUC,qBAAqBC,OAAA,qCACvD,IACE,MAAM,SACJ4E,EAAQ,cACRC,EAAa,QACbC,EAAO,iBACPC,EAAgB,gBAChBC,EAAe,cACfC,SACQpF,EAAIqF,YAERC,GAAmC,QAAfjF,EAAAJ,aAAM,EAANA,EAAQK,eAAO,IAAAD,OAAA,EAAAA,EAAEE,aAAcyE,EACnDO,GACW,QAAf/E,EAAAP,aAAM,EAANA,EAAQK,eAAO,IAAAE,OAAA,EAAAA,EAAEJ,gBAAiB4E,GAC9B,kBAAEQ,GAAsBvF,EAE9B,MAAO,CACL8E,WACAC,gBACAC,UACAC,mBACAC,kBACAC,gBACAE,oBACAC,uBACAC,oBAEJ,CAAE,MAAOC,GACP,OAAOvF,EAAgBuF,EACzB,CACF,MAGW9B,GAAc9D,EAAAA,EAAAA,IACzB,eACA,CAAOC,GAAKC,OAASE,aAAcE,OAAA,6BACjC,OAAOF,CACT,sFClDK,MAAMyF,EAAYA,KAAMC,EAAAA,EAAAA,IAAYC,EAAAA,GAWrC,SAAUC,IACd,MAAM,cAAET,GAAkBM,IAE1B,OAAON,CACT,wECbO,MAAMQ,GAAe7B,EAAAA,EAAAA,KAC1B,EAAG9D,YAAwBA,IAC1BA,IACC,IAAI6F,EAAS9E,OAAAC,OAAA,CACX8E,QAAiC,YAAvB9F,aAAM,EAANA,EAAQd,YACd6G,EAAAA,EAAiBC,KACjBD,EAAAA,EAAiBE,UACrBC,wBAAwBlG,aAAM,EAANA,EAAQkG,yBAA0B,IACvDlG,GAQL,MANgD,mBAArC6F,EAAUK,yBACnBL,EAAS9E,OAAAC,OAAAD,OAAAC,OAAA,GACJ6E,GAAS,CACZK,uBAAwBL,EAAUK,uBAAuBL,MAGtDA,CAAS,8FCdb,MAAMM,EAAkBpF,OAAAC,OAAAD,OAAAC,OAAA,GAC1BhC,EAAAA,IAAa,CAChBe,IAAK,CACHqG,OAAQ,GACRC,IAAK,GACLC,QAAQ,EACR7F,iBAAiB,GAEnB8F,0BAAsB7E,EACtB8E,sBAAsB,EACtBjB,mBAAmB,EACnBkB,gBAAgB,EAChBC,iBAAiB,EACjB1B,QAAS,CACP2B,WAAY,IACZC,UAAW,KAEbC,aAAc,CACZF,WAAY,EACZC,UAAW,KAEbE,iBAAkB,CAAC,EACnBC,SAAU,CACRjB,QAAS,MAEXkB,cAAe,KAGXC,EAA+B,CACnC,uBACA,oBACA,iBACA,kBACA,eACA,UACA,YACA,mBACA,WACA,aACA,MACA,SACA,UACA,yBACA,WACA,UACA,qBACA,gBACA,mBACA,kBACA,gBACA,wBAGIC,EAAcA,CAAC7C,EAAOrE,KAC1B,MAAMI,GAAiC+G,EAAAA,EAAAA,IAAKnH,EAAQiH,IAA9C,SAAE9H,GAAQiB,EAAKgH,2UAAaC,CAAAjH,EAA5B,cACN,IAAIkH,EAAWjD,EAgBf,OAfItD,OAAOwG,KAAKH,GAAeI,OAAS,IACtCF,EAAQvG,OAAAC,OAAAD,OAAAC,OAAA,GACHsG,GACAF,IAGHjI,IACFmI,EAAQvG,OAAAC,OAAAD,OAAAC,OAAA,GACHsG,GAAQ,CACXnI,SAAQ4B,OAAAC,OAAAD,OAAAC,OAAA,GACHsG,EAASnI,UACTA,MAIFmI,CAAQ,EAGJG,GAAcvD,EAAAA,EAAAA,IAAY,CACrC1C,KAAM,SACNZ,aAAcuF,EACdhC,SAAU,CACRuD,UAAWA,CAACrD,GAASC,aACnB4C,EAAY7C,EAAOC,GACrBqD,aAAcA,CAACtD,GAASC,aACtB4C,EAAY7C,EAAOC,GACrBsD,iBAAkBA,CAACvD,GAASC,cAC1BD,EAAM2C,cAAgB1C,CAAO,GAGjCC,cAAgBC,IACdA,EACGC,QAAQf,EAAAA,EAAYiB,WAAY3E,GAAWA,IAC3CyE,QACCd,EAAAA,EAAiBgB,WACjB,CACEN,GAEEC,SACEU,UACAC,mBACAC,kBACAC,gBACAE,oBACAC,4BAKJjB,EAAM2C,cAAgBhC,EAAQ6C,KAAKvD,IAAO,CACxClD,KAAM,UACNkD,cAGFD,EAAMhE,QAAQC,WAAa+E,EAC3BhB,EAAMhE,QAAQF,cAAgBmF,EAE9BjB,EAAMY,iBAAmBA,EACzBZ,EAAMa,gBAAkBA,EACxBb,EAAMc,cAAgBA,CAAa,GAEtC,KAIM,UAAEuC,EAAS,aAAEC,EAAY,iBAAEC,GAAqBH,EAAY5C,QAEzE,EAAe4C,EAAmB,iICvHd,IACM,IACC,IACP,IACK,IACDvF,EAAAA,GAGE4F,EAAAA,EAAAA,IAAa,eAAgBtC,IAAK,CAC1DlB,QAASkB,kIChBX,MAAMuC,EAAiD,CACrDC,SAAU,CAAC,GAGPC,EAAoC,CACxCC,MAAO,GACPC,SAAS,GAGLvH,EAAe,CACnBoH,SAAUC,GAGCG,GAAalE,EAAAA,EAAAA,IAAY,CACpC1C,KAAM,QACNZ,eACAuD,SAAU,CACRkE,aAAcA,CAAChE,GAASC,SAAWgE,cAAaC,oBAC9C,MAAMC,EAAYF,GACD,QAAblI,EAAAiE,EAAMkE,UAAO,IAAAnI,EAAAA,EACdW,OAAAC,OAAAD,OAAAC,OAAA,GAAM+G,GAAgB,CAAEO,gBAE3BjE,EAAMkE,GAAUC,CAAS,EAE3BC,eAAgBA,CAACpE,GAASC,SAAWiE,oBAKnC,OAJkB,QAAbnI,EAAAiE,EAAMkE,UAAO,IAAAnI,OAAA,EAAAA,EAAEkI,qBACXjE,EAAMkE,GAGRlE,CAAK,EAGdqE,gBAAiBA,CAACrE,GAASC,SAAW9C,OAAM+G,cAC1ClE,EAAMkE,GAAQP,SAAW,CACvB,CAACxG,GAAOyG,EACT,EAEHU,kBAAmBA,CAACtE,GAASC,SAAW9C,OAAM+G,cAC5C,MAAMK,EAAOvE,EAAMkE,GACnB,IAAKK,EACH,OAAOvE,EAET,GAAIuE,EAAKN,YACP,OAAOjE,EAET,MAAM2D,EAAQjH,OAAAC,OAAA,GAAQ4H,EAAKZ,UAE3B,cADOA,EAASxG,GAChBT,OAAAC,OAAAD,OAAAC,OAAA,GACKqD,GAAK,CACR,CAACkE,GAAOxH,OAAAC,OAAAD,OAAAC,OAAA,GACH4H,GAAI,CACPZ,cAAQ,EAIda,mBAAoBA,CAACxE,GAASC,SAAWiE,SAAQ/G,OAAM0G,oBAEnC,QAAb9H,EAAAiE,EAAMkE,UAAO,IAAAnI,OAAA,EAAAA,EAAE4H,YACpB3D,EAAMkE,GAAQP,SAASxG,GAAM0G,MAAQA,EAAK,EAE5CY,qBAAsBA,CAACzE,GAASC,SAAWiE,SAAQ/G,OAAM2G,sBACrC,QAAb/H,EAAAiE,EAAMkE,UAAO,IAAAnI,OAAA,EAAAA,EAAE4H,SAASxG,MAC7B6C,EAAMkE,GAAQP,SAASxG,GAAM2G,QAAUA,EAAO,GAGlD5D,cAAgBC,IACdA,EAAQC,QAAQrC,EAAAA,EAASsC,SAAS,IAAM9D,GAAa,KAI5C,aACXyH,EAAY,eACZI,EAAc,gBACdC,EAAe,kBACfC,EAAiB,mBACjBE,EAAkB,qBAClBC,GACEV,EAAWvD,QAEf,EAAeuD,EAAkB,oEC/E1B,MAAMW,GAAYnJ,EAAAA,EAAAA,IAQvB,aACA,CAAOU,GAAcR,OAASC,OAAOE,sBAAqBC,cAAA,yBACxD,IAGE,MAAO,CACL8I,mBAHqBjJ,EAAIkJ,gBAAgB3I,GAIzCA,aAEJ,CAAE,MAAOkF,GACP,OAAOvF,EAAgBuF,EACzB,CACF,cAX0D,kRAWzD,GACD,CACEvC,UAAWA,CAACiG,GAAUC,eACpB,MACEC,MAAM,UAAEC,EAAS,WAAE/I,IACjB6I,IAEJ,OAAID,IAAW5I,IAAc+I,CAKlB,iCCpCF,SAASC,EAAkBC,EAAKC,IAClC,MAAPA,GAAeA,EAAMD,EAAI/B,UAAQgC,EAAMD,EAAI/B,QAC/C,IAAK,IAAIiC,EAAI,EAAGC,EAAO,IAAIC,MAAMH,GAAMC,EAAID,EAAKC,IAAKC,EAAKD,GAAKF,EAAIE,GACnE,OAAOC,CACT,CCJe,SAASE,EAAQC,GAG9B,OAAOD,EAAU,mBAAqBE,QAAU,iBAAmBA,OAAOC,SAAW,SAAUF,GAC7F,cAAcA,CAChB,EAAI,SAAUA,GACZ,OAAOA,GAAK,mBAAqBC,QAAUD,EAAEG,cAAgBF,QAAUD,IAAMC,OAAOG,UAAY,gBAAkBJ,CACpH,EAAGD,EAAQC,EACb,CCNe,SAASK,EAAcC,GACpC,IAAIV,ECFS,SAAqBU,EAAGC,GACrC,GAAI,UAAYR,EAAQO,KAAOA,EAAG,OAAOA,EACzC,IAAIxI,EAAIwI,EAAEL,OAAOO,aACjB,QAAI,IAAW1I,EAAG,CAChB,IAAI8H,EAAI9H,EAAE2I,KAAKH,EAAGC,UAClB,GAAI,UAAYR,EAAQH,GAAI,OAAOA,EACnC,MAAM,IAAIc,UAAU,+CACtB,CACA,OAAyBC,OAAiBL,EAC5C,CDPUE,CAAYF,GACpB,MAAO,UAAYP,EAAQH,GAAKA,EAAIe,OAAOf,EAC7C,CEJA,SAASgB,EAAkBC,EAAQC,GACjC,IAAK,IAAIlB,EAAI,EAAGA,EAAIkB,EAAMnD,OAAQiC,IAAK,CACrC,IAAImB,EAAaD,EAAMlB,GACvBmB,EAAWC,WAAaD,EAAWC,aAAc,EACjDD,EAAWE,cAAe,EACtB,UAAWF,IAAYA,EAAWG,UAAW,GACjDhK,OAAOiK,eAAeN,EAAQR,EAAcU,EAAWvE,KAAMuE,EAC/D,CACF,CCRe,SAASK,EAAgBC,EAAK7E,EAAK6B,GAYhD,OAXA7B,EAAM6D,EAAc7D,MACT6E,EACTnK,OAAOiK,eAAeE,EAAK7E,EAAK,CAC9B6B,MAAOA,EACP2C,YAAY,EACZC,cAAc,EACdC,UAAU,IAGZG,EAAI7E,GAAO6B,EAENgD,CACT,CCYO,SAASC,EAAQC,GACtB,OAAOA,EAAMC,QAAO,SAAUC,EAAapD,GACzC,OAAOoD,EAAYC,OAAO5B,MAAM6B,QAAQtD,GAASiD,EAAQjD,GAASA,EACpE,GAAG,GACL,CCOA,SAASuD,EAAWC,GAYlB,IAXA,IAAIC,EAAe,SAAsBC,GACvC,MAAO,KAAKC,KAAKD,EACnB,EAEIE,EAAO,GACPC,EAAQ,CAAC,EACTC,EAAgB,EAChBC,EAAa,KACbC,GAAS,EACTzC,EAAI,EAEDA,EAAIiC,EAAOlE,QAAQ,CAExB,GAAI0E,IAAWP,EAAaD,EAAOjC,KAAqB,MAAdiC,EAAOjC,IAC/CyC,GAAS,EACTD,EAAaP,EAAOS,MAAMH,EAAevC,GAEvB,MAAdiC,EAAOjC,IACTA,SAGC,IAAKyC,IAAWP,EAAaD,EAAOjC,IAAK,CAC5C,IAAI2C,EAAyB,MAAdV,EAAOjC,GAGtB,GAAIwC,GAAcG,EAAU,CAC1B,IAAIC,EAAiBC,EAAmBZ,EAAQjC,GAEhD,IAAwB,IAApB4C,EACF,MAAM,IAAIE,MAAM,uCAAwChB,OAAOG,EAAQ,MAGzEK,EAAME,GAAcP,EAAOS,MAAM1C,EAAI,EAAG4C,GAExC5C,EAAI4C,EAEJJ,EAAa,IACf,MACMA,IACFH,EAAKU,KAAKP,GACVA,EAAa,MAGfC,GAAS,EACTF,EAAgBvC,CAEpB,CAEAA,GACF,CAUA,OARIyC,IACFD,EAAaP,EAAOS,MAAMH,IAGxBC,GACFH,EAAKU,KAAKP,GAGL,CACLH,KAAMA,EACNC,MAAOA,EAEX,CAWA,SAASO,EAAmBZ,EAAQe,GAGlC,IAFA,IAAIC,EAAQ,EAEHjD,EAAIgD,EAAY,EAAGhD,EAAIiC,EAAOlE,OAAQiC,IAAK,CAClD,IAAIkD,EAAOjB,EAAOkB,OAAOnD,GAEzB,GAAa,MAATkD,EAAc,CAChB,GAAc,IAAVD,EACF,OAAOjD,EAGTiD,GACF,KAAoB,MAATC,GACTD,GAEJ,CAEA,OAAQ,CACV,CAWA,SAASG,EAAuBC,GAC9B,OAAOC,EAAMD,EAAMX,MAAM,GAAI,GAAI,IAAK,EACxC,CAaA,SAASY,EAAMrB,EAAQsB,EAAWC,GAChC,IAAI3B,EAAc4B,UAAU1F,OAAS,QAAsB9F,IAAjBwL,UAAU,GAAmBA,UAAU,GAAK,GAEtF,IAAKxB,EACH,OAAOJ,EAGT,GAAc,IAAV2B,EAEF,OADA3B,EAAYkB,KAAKd,GACVJ,EAGT,IAAI6B,EAAmBzB,EAAO0B,QAAQJ,GAEtC,IAA0B,IAAtBG,EAEF,OADA7B,EAAYkB,KAAKd,GACVJ,EAGT,IAAI+B,EAAO3B,EAAO4B,UAAU,EAAGH,GAAkBI,OAC7CC,EAAO9B,EAAO4B,UAAUH,EAAmBH,EAAUxF,OAAS,GAAG+F,OAErE,OADAjC,EAAYkB,KAAKa,GACVN,EAAMS,EAAMR,EAAWC,EAAQ,EAAG3B,EAC3C,kBAQA,IAkHImC,EAlHAC,EAAgC,WAWlC,SAASA,EAAiBxE,GACxB,IC1LoByE,EAClBC,EDyLEC,EAAQC,KAERC,EAAeb,UAAU1F,OAAS,QAAsB9F,IAAjBwL,UAAU,GAAmBA,UAAU,GAAK,CAAC,GEzM7E,SAAyBc,EAAUC,GAChD,KAAMD,aAAoBC,GACxB,MAAM,IAAI1D,UAAU,oCAExB,CFuMI2D,CAAgBJ,KAAMJ,GAEtBzC,EAAgB6C,KAAM,UChMFH,EDgMoB,SAAU7L,GAChD,IAAIqM,EAASjB,UAAU1F,OAAS,QAAsB9F,IAAjBwL,UAAU,GAAmBA,UAAU,GAAK,CAAC,EAClF,OAAO/B,EAAQ0C,EAAMO,QAAQtM,EAASqM,IAASE,KAAK,GACtD,EClMET,EAAQ,CAAC,EACN,WACL,IAAK,IAAIU,EAAOpB,UAAU1F,OAAQsE,EAAO,IAAInC,MAAM2E,GAAOC,EAAO,EAAGA,EAAOD,EAAMC,IAC/EzC,EAAKyC,GAAQrB,UAAUqB,GAGzB,IAAIlI,EAAMyF,EAAKtE,OAASsE,EAAKjE,KAAI,SAAU2G,GACzC,OAAe,OAARA,EAAe,YAAiB9M,IAAR8M,EAAoB,YAA6B,mBAARA,EAAqBA,EAAIC,WAAaD,aAAeE,KAAOF,EAAIG,cAAgBC,KAAKC,UAAUL,EACzK,IAAGH,KAAK,KAAO,cAEf,GAAItN,OAAOkJ,UAAU6E,eAAexE,KAAKsD,EAAOvH,GAC9C,OAAOuH,EAAMvH,GAGf,IAAI0I,EAASpB,EAAKqB,WAAM,EAAQlD,GAEhC,OADA8B,EAAMvH,GAAO0I,EACNA,CACT,IDmLEjB,KAAK5E,OAASA,EACd4E,KAAKC,aAAeA,CACtB,CH1Ma,IAAsBE,EAAagB,EG6RhD,OH7RmChB,EGqNtBP,EHrNmCuB,EGqNjB,CAAC,CAC9B5I,IAAK,UACL6B,MAgBA,SAAiBpG,GACf,IAAIqM,EAASjB,UAAU1F,OAAS,QAAsB9F,IAAjBwL,UAAU,GAAmBA,UAAU,GAAK,CAAC,EAElF,IAAKpL,EACH,MAAO,GAGT,IGpPiCyH,EAAKE,EHoPlCyF,EAAkBpN,EAAQsL,QAAQ,KAEtC,IAAyB,IAArB8B,EAAwB,CAC1B,IAAIC,EAAgB7C,EAAmBxK,EAASoN,GAEhD,IAAuB,IAAnBC,EAkCF,MAAM,IAAI5C,MAAM,uCAAwChB,OAAOzJ,EAAS,MAjCxE,IAAIgL,EAAQhL,EAAQwL,UAAU4B,EAAiBC,EAAgB,GAE/D,GAAIrC,EAAO,CACT,IAAIiC,EAAS,GACT1B,EAAOvL,EAAQwL,UAAU,EAAG4B,GAE5B7B,GACF0B,EAAOvC,KAAKa,GAGd,IACI+B,GGrQuB7F,EHoQCsD,EAAuBC,GGpQnBrD,EHqQmC,EIzQhE,SAAyBF,GACtC,GAAII,MAAM6B,QAAQjC,GAAM,OAAOA,CACjC,CDGS,CAAeA,IELT,SAA+Ba,EAAGiF,GAC/C,IAAIlF,EAAI,MAAQC,EAAI,KAAO,oBAAsBN,QAAUM,EAAEN,OAAOC,WAAaK,EAAE,cACnF,GAAI,MAAQD,EAAG,CACb,IAAIxI,EACF2N,EACA7F,EACA8F,EACAC,EAAI,GACJC,GAAI,EACJ5F,GAAI,EACN,IACE,GAAIJ,GAAKU,EAAIA,EAAEG,KAAKF,IAAIsF,KAAM,IAAML,EAAG,CACrC,GAAItO,OAAOoJ,KAAOA,EAAG,OACrBsF,GAAI,CACN,MAAO,OAASA,GAAK9N,EAAI8H,EAAEa,KAAKH,IAAIwF,QAAUH,EAAEhD,KAAK7K,EAAEuG,OAAQsH,EAAEhI,SAAW6H,GAAII,GAAI,GACtF,CAAE,MAAOrF,GACPP,GAAI,EAAIyF,EAAIlF,CACd,CAAE,QACA,IACE,IAAKqF,GAAK,MAAQtF,EAAU,SAAMoF,EAAIpF,EAAU,SAAKpJ,OAAOwO,KAAOA,GAAI,MACzE,CAAE,QACA,GAAI1F,EAAG,MAAMyF,CACf,CACF,CACA,OAAOE,CACT,CACF,CFrBgC,CAAqBjG,EAAKE,IGJ3C,SAAqCI,EAAG+F,GACrD,GAAK/F,EAAL,CACA,GAAiB,iBAANA,EAAgB,OAAO,EAAiBA,EAAG+F,GACtD,IAAIN,EAAIvO,OAAOkJ,UAAUwE,SAASnE,KAAKT,GAAGsC,MAAM,GAAI,GAEpD,MADU,WAANmD,GAAkBzF,EAAEG,cAAasF,EAAIzF,EAAEG,YAAYxI,MAC7C,QAAN8N,GAAqB,QAANA,EAAoB3F,MAAMkG,KAAKhG,GACxC,cAANyF,GAAqB,2CAA2CzD,KAAKyD,GAAW,EAAiBzF,EAAG+F,QAAxG,CALc,CAMhB,CHHgE,CAA2BrG,EAAKE,IILjF,WACb,MAAM,IAAIc,UAAU,4IACtB,CJGsG,IHqQtFlE,EAAM+I,EAAuB,GAC7BhO,EAAOgO,EAAuB,GAC9BU,EAASV,EAAuB,GAEhC7N,EAAO4M,EAAO9H,GAEd9E,UACFA,EAAO,IAGT,IAAIwO,EAAc3O,GAAQ0M,KAAKC,aAAa3M,GAC5C2N,EAAOvC,KAAKuD,EAAcA,EAAYxO,EAAMuO,EAAQhC,KAAK5E,OAAQiF,EAAQL,KAAKM,QAAQ4B,KAAKlC,OAASvM,GACpG,IAAIiM,EAAO1L,EAAQwL,UAAU6B,EAAgB,GAM7C,OAJI3B,GACFuB,EAAOvC,KAAKsB,KAAKM,QAAQZ,EAAMW,IAG1BY,CACT,CAIJ,CAEA,MAAO,CAACjN,EACV,IHzREmN,GAAYxE,EAAkBwD,EAAYhE,UAAWgF,GAEzDlO,OAAOiK,eAAeiD,EAAa,YAAa,CAC9ClD,UAAU,IGyRL2C,CACT,CA7GoC,GA+GpC,SAASuC,EAAQC,EAAQC,GAAkB,IAAI5I,EAAOxG,OAAOwG,KAAK2I,GAAS,GAAInP,OAAOqP,sBAAuB,CAAE,IAAIC,EAAUtP,OAAOqP,sBAAsBF,GAAaC,IAAkBE,EAAUA,EAAQC,QAAO,SAAUC,GAAO,OAAOxP,OAAOyP,yBAAyBN,EAAQK,GAAK1F,UAAY,KAAMtD,EAAKiF,KAAKwC,MAAMzH,EAAM8I,EAAU,CAAE,OAAO9I,CAAM,CAExV,SAASkJ,EAAc/F,GAAU,IAAK,IAAIjB,EAAI,EAAGA,EAAIyD,UAAU1F,OAAQiC,IAAK,CAAE,IAAIiH,EAAyB,MAAhBxD,UAAUzD,GAAayD,UAAUzD,GAAK,CAAC,EAAOA,EAAI,EAAKwG,EAAQlP,OAAO2P,IAAS,GAAMC,SAAQ,SAAUtK,GAAO4E,EAAgBP,EAAQrE,EAAKqK,EAAOrK,GAAO,IAAetF,OAAO6P,0BAA6B7P,OAAO8P,iBAAiBnG,EAAQ3J,OAAO6P,0BAA0BF,IAAmBT,EAAQlP,OAAO2P,IAASC,SAAQ,SAAUtK,GAAOtF,OAAOiK,eAAeN,EAAQrE,EAAKtF,OAAOyP,yBAAyBE,EAAQrK,GAAO,GAAM,CAAE,OAAOqE,CAAQ,CAErhB,IAAIoG,EAAa,EAGbC,EAAU,QAQd,SAASC,EAAkB5E,EAAUlE,GAMnC,IALA,IAAIuB,EAAI,EACJwH,EAAS,GACTC,EAAY,EACZC,EAAe,CAAC,EAEb1H,EAAI2C,EAAS5E,QAAQ,CAC1B,GAAoB,MAAhB4E,EAAS3C,IAAeyH,EAK1BD,GAAU7E,EAAS3C,OALkB,CACrC,IAAI2H,EAAW,cAAc7F,OAAOuF,KACpCG,GAAU,IAAI1F,OAAO6F,EAAU,aAC/BD,EAAaC,GAAYlJ,CAC3B,CAIoB,MAAhBkE,EAAS3C,GACXyH,IACyB,MAAhB9E,EAAS3C,IAClByH,IAGFzH,GACF,CAEA,MAAO,CACL2C,SAAU6E,EACVE,aAAcA,EAElB,CAoFA,IAAIE,EAAQ,sCQtaL,MAAMC,GAAqBxN,EAAAA,EAAAA,KAChC,EAAGsF,UAAsBA,IACzB,EAAGJ,kBAAmBA,IAGXuI,GAAsBzN,EAAAA,EAAAA,KACjC,EAAGsF,UAAsBA,IACzB,EAAGoI,mBAAoBA,IAGZC,GAAe3N,EAAAA,EAAAA,KAC1B,EAAGsF,UAAsBA,IACzB,EAAG9I,gBAAiBA,IAGToR,GAAkB5N,EAAAA,EAAAA,KAC7B,EAAGsF,UAAsBA,IACzB,EAAGC,eAAgBA,ICJfsI,EAAY,IAAIjE,EAAiB,QAAS,CAC9CkE,OTqVF,SAA2B1J,GACzB,IACIgB,EAASgE,UAAU1F,OAAS,EAAI0F,UAAU,QAAKxL,EAC/CyM,EAASjB,UAAU1F,OAAS,EAAI0F,UAAU,QAAKxL,EAC/CoO,EAAS5C,UAAU1F,OAAS,EAAI0F,UAAU,QAAKxL,EAE/CmQ,EAAcpG,EALJyB,UAAU1F,OAAS,QAAsB9F,IAAjBwL,UAAU,GAAmBA,UAAU,GAAK,IAM9EpB,EAAO+F,EAAY/F,KACnBC,EAAQ8F,EAAY9F,MAEpB+F,EAAWC,SAAS7J,GACxB4D,EAAK6E,SAAQ,SAAUnC,GACjBA,EAAIwD,WAAW,aACjBF,GAAYC,SAASvD,EAAIrC,MAAM,IAEnC,IACA,IAAI8F,EAAuB,GAE3B,GAAI,gBAAiBC,KAAM,MAEDxQ,IAApB+L,GAAiCA,EAAgB0E,kBAAkBjJ,SAAWA,IAChFuE,EAAkB,IAAIyE,KAAKE,YAAYlJ,IAGzC,IAAImJ,EAAgB5E,EAAgB6E,OAAOR,GAEvCO,IAAkBtB,GACpBkB,EAAqBzF,KAAK6F,EAE9B,CAEiB,IAAbP,GACFG,EAAqBzF,KAtFf,OAyFRyF,EAAqBzF,KAAK,IAAIjB,OAAOuG,GAAWf,GAEhD,IAAK,IAAItH,EAAI,EAAGA,EAAIwI,EAAqBzK,OAAQiC,IAAK,CACpD,IAAI8I,EAAUN,EAAqBxI,GAEnC,GAAI8I,KAAWxG,EAAO,CACpB,IAAIyG,EAAqBxB,EAAkBjF,EAAMwG,GAAUT,GACvD1F,EAAWoG,EAAmBpG,SAC9B+E,EAAeqB,EAAmBrB,aAEtC,OAAOrB,EAAO1D,EAAUqE,EAAcA,EAAc,CAAC,EAAGtC,GAASgD,GACnE,CACF,CAEA,OAAOjJ,CACT,EStYEoK,OTuaF,SAA2BpK,GACzB,IACIiG,EAASjB,UAAU1F,OAAS,EAAI0F,UAAU,QAAKxL,EAC/CoO,EAAS5C,UAAU1F,OAAS,EAAI0F,UAAU,QAAKxL,EAG/CqK,EADcN,EAJJyB,UAAU1F,OAAS,QAAsB9F,IAAjBwL,UAAU,GAAmBA,UAAU,GAAK,IAK1DnB,MAExB,OAAI7D,KAAS6D,EACJ+D,EAAO/D,EAAM7D,GAAQiG,GACnBkD,KAAStF,EACX+D,EAAO/D,EAAMsF,GAAQlD,GAGvBjG,CACT,ISnbM,SAAUuK,IACd,MAAMzJ,GAAetD,EAAAA,EAAAA,IAAY4L,GAC3BhR,GAAaoF,EAAAA,EAAAA,IAAY+L,GACzBD,GAAgB9L,EAAAA,EAAAA,IAAY6L,GAC5BlI,GAAY3D,EAAAA,EAAAA,IAAYgM,GAkB9B,MAAO,CACLvH,GAjBQuI,EAAAA,EAAAA,cACR,CAACrM,EAAa8H,EAAS,CAAC,KACtB,MAAMwE,EAAc3J,EAAa3C,GACjC,OAAKsM,EAQEhB,EAAU7B,OAAO6C,EAAaxE,IAP/B9E,GAEJuJ,QAAQC,KACN,oBAAoBxM,2BAA6B/F,KAH7B,KAOoB,GAE9C,CAAC0I,EAAc1I,EAAY+I,IAK3B/I,aACAkR,gBAEJ,4FC3CM,SAAUsB,IACd,MAAM,EAAE3I,IAAMsI,EAAAA,EAAAA,KACRjN,GAAQE,EAAAA,EAAAA,IAAYqN,EAAAA,GACpBC,GAAWtN,EAAAA,EAAAA,IAAYuN,EAAAA,GAEvBC,GAAOC,EAAAA,EAAAA,UAAQ,KACnB,IAAKH,EACH,MAAO,CACLI,WAAO1R,EACPI,aAASJ,EACT2R,YAAQ3R,EACR4R,gBAAY5R,EACZM,mBAAeN,GAInB,MAAM,QAAES,EAAO,OAAEF,GAAWuD,EACtB4N,EAAQjJ,EAAE,GAAGhI,WACbL,EAAUqI,EAAE,GAAGhI,aACfkR,EAASlJ,EAAE,GAAGhI,YACdmR,EAAarR,EAASkI,EAAE,GAAGhI,gBAAwB,KAEzD,OAAApB,OAAAC,OAAAD,OAAAC,OAAAD,OAAAC,OAAAD,OAAAC,OAAA,GACMmB,EAAU,CAAEiR,QAAOtR,UAASuR,UAAW,CAAC,GACxCpR,EAAS,CAAEA,UAAW,CAAC,GACvBA,GAAUE,EAAU,CAAEmR,cAAe,CAAC,GAAE,CAC5CtR,cAAewD,GAAK,GAErB,CAACwN,EAAUxN,EAAO2E,IAErB,MAAO,CAAE6I,WAAUE,OAAM1N,QAC3B,sECjCO,MAAMuN,GAAcjP,EAAAA,EAAAA,KACzB,EAAGyP,eAA2BA,IAC9B,EAAG/N,WAAoCA,IAG5ByN,GAAiBnP,EAAAA,EAAAA,IAAeiP,GAAcvN,GACzDgO,QAAQhO,2HCFV,MAAM5E,EAAe,CACnB4E,WAAO9D,GAGI+R,GAAiBvP,EAAAA,EAAAA,IAAY,CACxC1C,KAAM,YACNZ,eACAuD,SAAU,CACRuP,aAAcA,CAACrP,EAAOpC,KACpBoC,EAAMmB,MAAQvD,EAAOqC,OAAO,EAE9BqP,eAAgBA,IAAM/S,GAExB2D,cAAgBC,IACdA,EACGC,QAAQd,EAAAA,EAAiBe,SAAS,IAAM9D,IACxCgT,YACCC,EAAAA,EAAAA,IACElU,EAAAA,EAAcmU,SACdnQ,EAAAA,EAAiBmQ,SACjB/K,EAAAA,EAAU+K,SACVC,EAAAA,EAAcD,SACdlQ,EAAAA,EAAqBkQ,SACrBE,EAAAA,EAAgBF,WAElB,CAACzP,GAASC,cACRD,EAAMmB,MAAQlB,CAAO,GAExB,KAIM,aAAEoP,EAAY,eAAEC,GAAmBF,EAAe5O,QAE/D,EAAe4O,EAAsB,oECrC9B,MAAMO,GAAkBpU,EAAAA,EAAAA,IAO7B,mBACA,CAAOC,GAAKC,OAASC,OAAOE,sBAAqBC,cAAA,yBAC/C,IACE,OAAOH,EAAIiU,iBACb,CAAE,MAAOxO,GACP,OAAOvF,EAAgB,CACrBuB,KAAMgE,aAAK,EAALA,EAAOhE,KACbM,QAAS0D,aAAK,EAALA,EAAO1D,QAChBK,QAASqD,aAAK,EAALA,EAAOrD,QAChBF,OAAQuD,aAAK,EAALA,EAAOvD,OACfF,cAAeyD,aAAK,EAALA,EAAOzD,cACtBC,cAAewD,aAAK,EAALA,EAAOxD,eAE1B,CACF,cAbiD,kRAahD,GACD,CACEiB,SAAAA,CAAUqB,GAAS,SAAE6E,UACnB,MACE9E,OAAO,OAAE4P,IACP9K,IAEE+K,EAAYD,EAAOA,EAAOzM,OAAS,GACnC2M,EAAuC,QAAlB/T,EAAAkE,aAAO,EAAPA,EAAS4P,iBAAS,IAAA9T,OAAA,EAAAA,EAAEgU,GAC/C,OAAOF,GAAaC,IAAuBD,EAAU5P,QAAQ8P,EAC/D,uJC7BJ,MAAMxT,EAA0B,CAC9BoI,aAAc,CACZ,6BACE,4DACF,4BACE,oFACF,2BAA4B,4BAC5B,4BAA6B,eAC7B,yBAA0B,2CAC1B,wBACE,wEACF,uBAAwB,uBACxB,+BACE,0IACF,8BACE,6KACF,6BAA8B,oBAC9B,sCAAuC,YACvC,mCACE,gEACF,kCACE,qEACF,iCAAkC,sBAEpCK,WAAW,EACXmI,mBAAe9P,EACfpB,gBAAYoB,GAGD2S,GAAYnQ,EAAAA,EAAAA,IAAY,CACnC1C,KAAM,MACNZ,eACAuD,SAAU,CACRmQ,iBAAkBA,CAACjQ,EAAOpC,KACxBoC,EAAMmN,cAAgBvP,EAAOqC,OAAO,EAEtCiQ,gBAAiBA,CAAClQ,GAASC,cACzBD,EAAM2E,aAAe1E,CAAO,GAGhCC,cAAgBC,IAEdA,EACGC,QAAQrC,EAAAA,EAASsC,SAAS,IAAM9D,IAChC6D,QAAQd,EAAAA,EAAiBgB,WAAW,CAACN,GAASC,cAC7CD,EAAMmN,cAAgBlN,EAAQe,iBAAiB,IAEhDZ,QAAQsE,EAAAA,EAAUrE,SAAUL,IAC3BA,EAAMgF,WAAY,CAAI,IAEvB5E,QAAQsE,EAAAA,EAAU+K,UAAWzP,IAC5BA,EAAMgF,WAAY,CAAK,IAExB5E,QAAQsE,EAAAA,EAAUpE,WAAW,CAACN,GAASC,cACtCD,EAAMgF,WAAY,GACb/E,aAAO,EAAPA,EAAS0E,gBAId3E,EAAM/D,WAAagE,EAAQhE,WAC3B+D,EAAM2E,aAAejI,OAAOwG,KAAKjD,EAAQ0E,cACtCwL,OACAnJ,QACC,CAACoJ,EAAOpO,IAAQtF,OAAAC,OAAAD,OAAAC,OAAC,CAAC,EACbyT,GAAK,CACR,CAACpO,GAAM/B,EAAQ0E,aAAa3C,MAE9B,CAAC,GACF,GACH,KAIK,iBAAEiO,EAAgB,gBAAEC,GAAoBF,EAAUxP,QAE/D,EAAewP,EAAiB,6DCxDZK,EAAAA,EAAAA,IAAgB,CAClCrQ,MAAOsQ,EAAAA,GACP5Q,IAAK6Q,EAAAA,GACL5U,OAAQ6U,EAAAA,GACRzL,KAAM0L,EACN9L,aAAc+L,EAAAA,GACdC,WAAYC,EAAAA,GACZC,MAAOC,EAAAA,GACP5B,UAAW6B,EAAAA,KAoCN,MAAMC,EAAoCC,EAAAA,+SC9C1C,MAAMC,EAAkBA,EAAGnU,OAAMkD,aACT,WAA7BkR,SAASC,iBACRrU,IAASsU,EAAAA,GAAW5T,UAAYwC,EAAQqR,YACxCvU,IAASsU,EAAAA,GAAWE,MAAQtR,EAAQlD,OAASyU,EAAAA,GAAaC,KAEhDC,EAAgB9B,GACpBA,EAAOO,MACZ,EACIlQ,SAAW0R,WAAYC,KACvB3R,SAAW0R,WAAYE,MACtBD,EAAcC,IAqCjBC,EAAqBA,CAACC,EAAiBnU,KAE3C,IAAKmU,EACH,MAAO,CACLC,aAAc,CAAC,EACfC,aAAc,IAIlB,MAAM,aAAED,GAAiBD,GAAmB,CAAEC,aAAc,CAAC,IACvD,GAAEjC,EAAE,OAAEmC,EAAM,KAAE/U,EAAI,aAAEgV,GAAiBvU,EAAOwU,YAC5CC,EAAiBL,EAAajC,GAE9BuC,EAAe5V,OAAAC,OAAAD,OAAAC,OAAA,GAChBqV,GAAY,CACf,CAACjC,GAAKsC,EACH3V,OAAAC,OAAAD,OAAAC,OAAAD,OAAAC,OAAAD,OAAAC,OAAA,GACM0V,GACCH,EAAS,CAAEA,UAAW,CAAC,GACvB/U,EAAO,CAAEA,QAAS,CAAC,GACnBgV,EAAe,CAAEA,gBAAiB,CAAC,GAEzCvU,EAAOwU,cAGb,OAAA1V,OAAAC,OAAAD,OAAAC,OAAA,GACKoV,GAAe,CAClBC,aAAcM,EACdL,aACEF,EAAgBE,eAAiBlC,GAAOnS,EAAO0T,WAE3CS,EAAgBE,aADhBlC,GAC4B,EAIhCwC,EAAwBA,CAC5BC,EACAC,aAEA,MAAMC,EACmB,aAAvBD,aAAY,EAAZA,EAAc1V,OACV0V,aAAY,EAAZA,EAAcxS,QAAQ0S,mBAAmBF,aAAY,EAAZA,EAAcxS,QAAQyS,OAC/D,CAAC,GAED,qBAAEE,GAAyBJ,EAC3BhS,GAA+B,QAArBzE,EAAA0W,aAAY,EAAZA,EAAcxS,eAAO,IAAAlE,OAAA,EAAAA,EAAEyE,UAAW,CAAC,EAC7CqS,GAAyC,QAArB3W,EAAAuW,aAAY,EAAZA,EAAcxS,eAAO,IAAA/D,OAAA,EAAAA,EAAE2W,oBAAqB,CAAC,EAEvE,IAAKH,EACH,OAAAhW,OAAAC,OAAAD,OAAAC,OAAA,GACK6V,GAAS,CACZM,gBAAiB,CAAC,EAClBtS,UACAqS,sBAIJ,MAAM,KAAE9V,EAAI,QAAEgW,GAAYL,EAE1B,IAAIM,EAAYR,EAAUS,OAM1B,OAJKL,GAAwB7V,IAASyV,EAAUU,eAC9CF,EAAYjW,GAGdL,OAAAC,OAAAD,OAAAC,OAAA,GACK6V,GAAS,CACZS,OAAQD,EACRF,gBAAepW,OAAAC,OAAAD,OAAAC,OAAA,GACT6V,EAAUM,iBAAmB,CAAC,GAC9B/V,EAAO,CAAE,CAACA,GAAOgW,GAAY,CAAC,GAEpCvS,UACAqS,qBAAiB,EAIRM,EAAgC,CAC3CvD,OAAQ,GACRwD,uBAAuB,EACvB7W,aAAc,CACZgE,eAAe,GAEjB8S,aAAc,EACd1T,kBAAkB,EAClB2T,oBAAqB,GACrBtO,WAAW,EACXuO,oBAAqB,CACnBC,cAAc,EACdC,UAAU,EACVC,eAAWrW,EACXsW,gBAAYtW,EACZuW,WAAOvW,EACPwW,WAAOxW,GAETyW,0BAA0B,EAC1BC,YAAa,CACXC,uBAAwB,GACxBC,mBAAmB,GAErBlC,gBAAiB,CACfC,aAAc,CAAC,EACfC,aAAc,IAEhBiC,aAAc,CACZnF,MAAO,KACPoF,SAAU,IAEZC,eAAe,EACfC,kBAAkBC,EAAAA,EAAAA,KAClBC,iBAAiBD,EAAAA,EAAAA,KACjBE,wBAAwBF,EAAAA,EAAAA,KACxBG,YAAa,CAAC,EACd1B,QAAS,CACPtS,SAAU,CACRiU,iBAAkB,CAChBtZ,SAAS,IAGbuZ,aAAa,EACbC,aAAc,GACdC,oBAAqB,CAAC,GAExBC,gBAAgB,EAChBC,eAAgB,GAChBC,sBAAuB,GACvBxC,UAAW,CACTyC,QAASC,EAAAA,GAAWzD,KACpBwB,OAAQiC,EAAAA,GAAWzD,KACnByB,aAAc,KACdN,sBAAsB,EACtBG,QAAS,CAAC,EACVD,gBAAiB,CAAC,EAClBtS,QAAS,CAAC,EACVqS,kBAAmB,CAAC,GAEtBsC,uBAAwB,MAGbC,GAAavV,EAAAA,EAAAA,IAAY,CACpC1C,KAAM,QACNZ,aAAc4W,EACdrT,SAAU,CACRuV,SAAUA,CAACrV,EAAOpC,aAChB,MAAQb,KAAMuY,EAAS,QAAErV,GAAYrC,EAAOqC,QAEtCsV,EAAoBvV,EAAM+S,QAAQtS,SAASgK,eAC/C+K,EAAAA,GAAYC,SAGd,IAAIC,EAAUhZ,OAAAC,OAAA,GAAQqD,EAAM+S,SAK5B,GACEwC,IACCD,IAAcjE,EAAAA,GAAW5T,SACxB6X,IAAcjE,EAAAA,GAAWe,eAC1BnS,EAAQqR,WACT,CACA,MAAMqE,EAA0B,YAAdL,EAAuC,QAAbvZ,EAAAkE,EAAQyS,aAAK,IAAA3W,OAAA,EAAAA,EAAEgB,KAAO,CAAC,EACnE2Y,EAAUhZ,OAAAC,OAAAD,OAAAC,OAAA,GACL+Y,GAAU,CACbjV,SAAQ/D,OAAAC,OAAAD,OAAAC,OAAA,GACH+Y,EAAWjV,UAAQ,CACtBgV,QAAO/Y,OAAAC,OAAAD,OAAAC,OAAA,GACiB,QAAnBT,EAAAwZ,EAAWjV,gBAAQ,IAAAvE,OAAA,EAAAA,EAAEuZ,SAAO,CAC/BG,iBAAkBD,IAAcT,EAAAA,GAAWW,YAInD,CAEA,MAAMC,EAAkB5E,EAAgBtT,EAAOqC,SAM/C,GADoBD,EAAM4P,OAAOmG,MAAMzY,GAAMA,EAAE2C,QAAQ8P,KAAO9P,EAAQ8P,KAEpE,OAGF,MAAMiG,EAAezD,EACnBvS,EAAMwS,UACN5U,EAAOqC,SAGTD,EAAMwS,UACH+C,GAAqBS,EAAa/C,SAAWiC,EAAAA,GAAWW,OAErDG,EADDtZ,OAAAC,OAAA,GAAMqD,EAAMwS,WAGjBxS,EAAM+S,QAAU2C,EAEZI,IACF9V,EAAMqT,cAAgB,EACJ,iBAAdiC,IACF1X,EAAOqC,QAAQA,QAAQgW,cAAgBhW,EAAQqR,WAC3C4E,EAAAA,GAAWC,KACXD,EAAAA,GAAWE,WAInBxY,EAAOqC,QAAQA,QAAQ+B,KAAMsS,EAAAA,EAAAA,KAC7BtU,EAAM4P,OAAOzH,KAAKvK,EAAOqC,SAEzBD,EAAMoT,sBAAwBnT,EAAQqR,UAAU,EAElD+E,SAAUA,CAACrW,GAASC,SAAWA,eAG7B,IAAKA,EAAQqW,cAEX,YADA/H,QAAQC,KAAK,wCAIf,MAAM+H,EAAevW,EAAM4P,OAAOmG,MAC/BS,GACCA,EAAEvW,QAAQqW,gBAAkBrW,EAAQqW,iBAClCrW,EAAQlD,MAAQyZ,EAAEzZ,OAASkD,EAAQlD,SAGnC,GAAEgT,EAAE,WAAE4B,GAAe1R,EACvBsW,IACFA,EAAatW,QAAQ8P,GAAKA,EAC1BwG,EAAatW,QAAQ0R,WAAaA,EAElC3R,EAAM4P,OAAS8B,EAAa1R,EAAM4P,QACpC,EAEF6G,YAAczW,IACZA,EAAMqT,aAAe,EACrBrT,EAAMsT,oBAAsB,GAC5BtT,EAAM4P,OAAS,EAAE,EAEnB8G,cAAeA,CAAC1W,GAASC,cACvBD,EAAMqT,aAAe,EACrBrT,EAAM4P,OAAOtD,SAASqK,KACuB,IAAvC1W,EAAQ8I,QAAQ4N,EAAM1W,QAAQ8P,MAChC4G,EAAM1W,QAAOvD,OAAAC,OAAAD,OAAAC,OAAA,GACRga,EAAM1W,SACU,iBAAf0W,EAAM5Z,MACR4Z,EAAM1W,QAAQgW,gBAAkBC,EAAAA,GAAWE,UAAY,CACrDH,cAAeC,EAAAA,GAAWC,QAI3BQ,IACP,EAEJC,uBAAwBA,CAAC5W,GAASC,cAChCD,EAAMsT,oBAAoBnL,KAAKlI,EAAQ,EAEzC4W,WAAYA,CACV7W,GAEEC,SACE2P,OAAQkH,EACR9E,eACAgC,yBACA+C,wBAAwB,CAAC,EACzBtC,cACAX,0CAIJ,MAAMlE,EA7SgBoH,EAC1BC,EACAC,KAEA,MAAMC,EAAiBF,EAAYhL,QAChCmL,GACqB,YAApBA,EAAWra,OACVqa,EAAWnX,QAAQoX,yBAGnBH,EAAcI,MACZC,GAAiBA,EAAatX,QAAQ8P,KAAOqH,EAAWnX,QAAQ8P,OAIjEyH,EAAmBN,EACtBjL,QACEsL,KAGyB,gBAAtBA,EAAaxa,OACZwa,EAAatX,QAAQmS,YAAYD,gBAOvCsF,UAEH,OAAO/F,EAAa,IAAI8F,KAAqBL,GAAgB,EA+Q1CH,CAAahX,EAAM4P,OAAQkH,GAEpCY,EAAkBhb,OAAAC,OAAAD,OAAAC,OAAA,GACnBqD,EAAM+R,gBAAgBC,cACtBA,GAGC2F,EAAuB/H,EAC1B9H,QACA2P,UACA1B,MACES,IACa,YAAXA,EAAEzZ,MAAiC,gBAAXyZ,EAAEzZ,QAC1ByZ,EAAEvW,QAAQqR,aAGjB,IAAIsG,EAAoB,KAEpBD,IACgC,YAA9BA,EAAqB5a,OACvB6a,EAAoBD,EAAqB1X,QAAQmS,aAEjB,gBAA9BuF,EAAqB5a,OACvB6a,EAAoBD,EAAqB1X,QAAQmS,YAAYrC,KAIjE,MAAM,MAAE2C,GAAUqE,EACZlB,EAAuB,QAAd9Z,EAAA2W,aAAK,EAALA,EAAOK,eAAO,IAAAhX,OAAA,EAAAA,EAAE8Z,OAEzBgC,EAAsBtF,EAAqB7V,OAAAC,OAAAD,OAAAC,OAAAD,OAAAC,OAAC,CAAD,EAE1CqD,EAAMwS,WACNE,GAAK,CACRO,QAAQP,aAAK,EAALA,EAAOuC,UAAWzD,EAAAA,GAAaC,KACvCsB,QAAOrW,OAAAC,OAAA,IAAQ+V,aAAK,EAALA,EAAOK,SAAUL,EAAMK,QAAU,CAAC,KAEnDnD,EAAOA,EAAOzM,OAAS,IAGzB,IAAI2U,EAAWpb,OAAAC,OAAA,GAAQqD,EAAM+S,QAAQtS,UAErC,MAAMsX,EAAuBD,EAAYrN,eACvC+K,EAAAA,GAAYC,SAId,GAAIsC,GAAuD,aAA/BJ,aAAoB,EAApBA,EAAsB5a,MAAoB,CACpE,MAAQkD,QAAS+X,GAAgCL,EAC3ChC,GAA8C,QAAlCzZ,EAAA8b,aAA2B,EAA3BA,EAA6BtF,aAAK,IAAAxW,OAAA,EAAAA,EAAEa,OAAQ,CAAC,EAC/D+a,EAAWpb,OAAAC,OAAAD,OAAAC,OAAA,GACNmb,GAAW,CACdrC,QAAS,CACPra,WAAYya,KAAUA,aAAM,EAANA,EAAQza,UAC9Bwa,iBAAkBD,IAAcT,EAAAA,GAAWW,SAGjD,CAEA7V,EAAMqT,aAAezD,EAAO3D,QACzB0K,GACgB,YAAfA,EAAM5Z,MACN4Z,EAAM1W,QAAQgW,gBAAkBC,EAAAA,GAAWE,WAC7CjT,OACFnD,EAAM4P,OAASA,EAAO3D,QACnB3O,GAAiB,gBAAXA,EAAEP,QAA4BO,EAAE2C,QAAQmS,YAAYD,eAE7DnS,EAAM+R,gBAAerV,OAAAC,OAAAD,OAAAC,OAAAD,OAAAC,OAAA,GAChBqD,EAAM+R,iBACL6F,EACA9F,EAAmB9R,EAAM+R,gBAAiB,CACxCK,YAAasF,EAAmBE,KAElC,CAAC,GAAE,CACP5F,aAAc0F,IAEhB1X,EAAMoU,eAAgB,EACtBpU,EAAM+T,YAAWrX,OAAAC,OAAAD,OAAAC,OAAA,GACZqD,EAAM+T,aAAW,CACpBC,yBACAC,mBAC0C,QAAxCrX,EAAAma,aAAqB,EAArBA,EAAuB9C,yBAAiB,IAAArX,OAAA,EAAAA,EAAExB,WAAW,IAGzD4E,EAAMyU,YAAW/X,OAAAC,OAAAD,OAAAC,OAAA,GACZqD,EAAMyU,aACNA,GAGLzU,EAAM+S,QAAOrW,OAAAC,OAAAD,OAAAC,OAAA,GACRqD,EAAM+S,SAAO,CAChBtS,SAAUqX,IAEZ9X,EAAMwS,UACHuF,GACDF,EAAoB5E,SAAWiC,EAAAA,GAAWW,OAEtCgC,EADDnb,OAAAC,OAAA,GAAMqD,EAAMwS,WAEjBxS,EAAM8T,yBAA2BA,IAA4B,EAEzD8D,IACF5X,EAAMkU,aAAaC,SAAWuD,EAAmBE,GAAmBza,KACtE,EAEF8a,uBAAyBjY,IACvBA,EAAMoU,eAAgB,CAAK,EAE7B8D,aAAcA,CAAClY,GAASC,cACtBD,EAAMgF,UAAY/E,CAAO,EAE3BkY,wBAAyBA,CAACnY,GAASC,cACjC,MAAM,aAAEmY,EAAY,UAAEC,GAAcpY,EAEpCD,EAAMuT,oBAAsB,CAC1BC,cAAc,EACdC,UAAU,EACVE,YAAY,EACZC,MAAOwE,EACP1E,UAAW0E,EACXvE,MAAOwE,EACR,EAEHC,oCAAsCtY,IACpC,MAAM,oBAAEuT,GAAwBvT,GAExB0T,UAAW6E,GAAkBhF,EAE/BG,EAAY6E,EAAgB,EAElCvY,EAAMuT,oBAAoBG,UAAYA,EACtC1T,EAAMuT,oBAAoBM,OAAQ2E,EAAAA,EAAAA,IAAmB9E,EAAU,EAEjE+E,+BAAiCzY,IAC/BA,EAAMuT,oBAAoBE,UAAW,EACrCzT,EAAMuT,oBAAoBI,YAAa,CAAI,EAE7C+E,yBAA2B1Y,IACzBA,EAAMuT,oBAAoBC,cAAe,EACzCxT,EAAMuT,oBAAoBE,UAAW,CAAK,EAE5CkF,6BAA+B3Y,IAC7BA,EAAM8T,0BAA2B,CAAI,EAEvC8E,8BAAgC5Y,IAC9BA,EAAM8T,0BAA2B,CAAK,EAExC+E,eAAgBA,CAAC7Y,GAASC,cACxBD,EAAM+R,gBAAkBD,EAAmB9R,EAAM+R,gBAAiB,CAChEK,YAAanS,EAAQmS,YACrBd,WAAYrR,EAAQqR,YACpB,EAEJwH,iBAAkBA,CAChB9Y,GACEC,cAEED,EAAM+T,YAAYC,yBAA2B/T,IAC/CD,EAAM+T,YAAYC,uBAAyB/T,EAC7C,EAEF8Y,eAAgBA,CAAC/Y,GAASC,cACxBD,EAAMkU,aAAanF,MAAQ9O,CAAO,EAEpC+Y,kBAAmBA,CAAChZ,GAASC,cAC3BD,EAAMkU,aAAaC,SAAWlU,CAAO,EAEvCgZ,gBAAiBA,CACfjZ,GACEC,cAEFD,EAAMzD,aAAe0D,EACrBD,EAAMqT,aAAeF,EAAkBE,YAAY,EAErD6F,mBAAoBA,CAAClZ,GAASC,cAC5BD,EAAMyU,YAAYxU,EAAQlD,MAAQkD,CAAO,EAE3CkZ,YAAaA,CAACnZ,GAASC,cAChBA,EAAQQ,WAGbT,EAAM+S,QAAQtS,SAAWR,EAAQQ,SAAQ,EAE3C2Y,uBAAwBA,CAACpZ,GAASC,cAC3BD,EAAM+S,QAAQtS,SAASgK,eAAexK,EAAQ+B,OAGnDhC,EAAM+S,QAAQtS,SAASR,EAAQ+B,KAAK5G,QAAU6E,EAAQ7E,QAAO,EAE/Die,cAAgBrZ,IACdA,EAAM+S,QAAQtS,SAAW,CACvBiU,iBAAkB1U,EAAM+S,QAAQtS,SAASiU,iBAC1C,EAEH4E,WAAYA,CAACtZ,GAASC,cACpBD,EAAM+S,QAAQ4B,aAAc,EAC5B3U,EAAM+S,QAAQ6B,aAAe3U,CAAO,EAEtCsZ,WAAavZ,IACXA,EAAM+S,QAAQ4B,aAAc,EAC5B3U,EAAM+S,QAAQ6B,aAAe,EAAE,EAEjC4E,uBAAwBA,CAACxZ,GAASC,cAChCD,EAAM+S,QAAQ8B,oBAAsB5U,CAAO,EAE7CwZ,sBAAuBA,CAACzZ,GAASC,cAC/B,MAAM,OAAEyZ,EAAM,MAAE7V,GAAU5D,EAC1BD,EAAM+S,QAAQ8B,oBAAoB6E,GAAU7V,CAAK,EAEnD8V,wBAAyBA,CAAC3Z,GAASC,cACjCD,EAAMwS,UAAUI,qBAAuB3S,CAAO,EAEhD2Z,wBAAyBA,CAAC5Z,GAASC,cACjCD,EAAMwS,UAAUS,OAAShT,EAAQgV,QACjCjV,EAAMwS,UAAUO,QAAU9S,EAAQ8S,SAAW,CAAC,EAC9C/S,EAAMwS,UAAUM,gBAAkB,CAAC,EACnC9S,EAAMwS,UAAUhS,QAAU,CAAC,EAC3BR,EAAMwS,UAAUK,kBAAoB,CAAC,CAAC,EAExCgH,mBAAoBA,CAAC7Z,GAASC,cAC5BD,EAAMwS,UAAUS,OAAShT,CAAO,EAElC6Z,iBAAkBA,CAAC9Z,GAASC,cAC1BD,EAAMwS,UAAUU,aAAejT,CAAO,EAExC8Z,sBAAwB/Z,IACtBA,EAAMwS,UAAUhS,QAAU,CAAC,EAC3BR,EAAMwS,UAAUK,kBAAoB,CAAC,CAAC,EAExCmH,eAAgBA,CACdha,GACEC,cAEFD,EAAM+U,eAAe5M,KAAK,CACxB4H,GAAI9P,EAAQga,OACZ9c,KAAM8C,EAAQia,SACdC,SAAU,EACVC,WAAW,EACXC,UAAU,EACVlZ,MAAO,GACPmZ,aAAcra,EAAQqa,cACtB,EAEJC,kBAAmBA,CACjBva,GAEEC,cAGFD,EAAM+U,eAAiB/U,EAAM+U,eAAevR,KAAKgX,GAC3CA,EAAWzK,KAAO9P,EAAQga,OAC5Bvd,OAAAC,OAAAD,OAAAC,OAAA,GACK6d,GAAU,CACbL,SAAUla,EAAQka,SAClBC,UAAgC,MAArBna,EAAQka,SACnBG,aACuB,MAArBra,EAAQka,SAAmB,KAAOK,EAAWF,eAG5CE,GACP,EAEJC,qBAAsBA,CAACza,GAASC,cAC9BD,EAAMgV,sBAAsB7M,KAAKlI,EAAQ,EAE3Cya,oBAAqBA,CAAC1a,GAASC,cAC7BD,EAAMgV,sBAAwBhV,EAAMgV,sBAAsB/I,QACvDgO,GAAWA,IAAWha,GACxB,EAEH0a,eAAgBA,CAAC3a,GAASC,cACxBD,EAAM+U,eAAiB/U,EAAM+U,eAAevR,KAAKgX,GAC3CA,EAAWzK,KAAO9P,EAAQga,OAC5Bvd,OAAAC,OAAAD,OAAAC,OAAA,GACK6d,GAAU,CACbrZ,MAAOlB,EAAQ2a,UACfT,SAAU,EACVC,WAAW,EACXE,aAAc,OAGXE,GACP,EAEJK,kBAAmBA,CACjB7a,GACEC,cAEFD,EAAM+U,eAAiB/U,EAAM+U,eAAevR,KAAKgX,GAC3CA,EAAWzK,KAAO9P,EACpBvD,OAAAC,OAAAD,OAAAC,OAAA,GACK6d,GAAU,CACbH,UAAU,IAGPG,GACP,EAEJM,gBAAkB9a,IAChBA,EAAM+U,eAAiB,EAAE,EAE3BgG,0BAA2BA,CAAC/a,GAASC,cACnCD,EAAMmV,uBAAyBlV,CAAO,EAExC+a,qBAAsBA,CACpBhb,GACEC,cAEFD,EAAM+T,YAAYE,kBAAoBhU,CAAO,GAGjDC,cAAgBC,IACdA,EACGC,QAAQrC,EAAAA,EAASsC,SAAS,IAAM8S,IAChC/S,QAAQ9E,EAAAA,EAAc+E,SAAUL,IAC/BA,EAAMgF,WAAY,CAAI,IAEvB5E,QAAQd,EAAAA,EAAiBgB,WAAW,CAACN,GAASC,oBAC7CD,EAAMkU,aAAaC,SAAmC,QAAxBpY,EAAAkE,EAAQW,wBAAgB,IAAA7E,OAAA,EAAAA,EAAEoB,KAEnD8C,EAAQQ,WAEbT,EAAM+S,QAAQtS,SAAWR,EAAQQ,SAAQ,IAE1CL,QAAQ9E,EAAAA,EAAcgF,WAAW,CAACN,GAASC,cAC1CD,EAAMgF,WAAY,EAEb/E,EAAQ1D,eACbyD,EAAMzD,aAAe0D,EAAQ1D,aAAY,IAE1CgT,YACCC,EAAAA,EAAAA,IAAQ2I,EAAyBQ,IAChC3Y,IACCA,EAAMoT,uBAAwB,CAAK,GAEtC,KAIM,SACXiD,EAAQ,SACRhB,EAAQ,gBACRyF,EAAe,YACfrE,EAAW,cACX4C,EAAa,yBACbX,EAAwB,8BACxBE,EAA6B,oCAC7BN,EAAmC,WACnCiB,EAAU,wBACVpB,EAAuB,6BACvBQ,EAA4B,eAC5BqB,EAAc,uBACd/B,EAAsB,mBACtB4B,EAAkB,iBAClBf,EAAgB,wBAChBa,EAAuB,cACvBjD,EAAa,uBACb0C,EAAsB,YACtBD,EAAW,kBACXH,EAAiB,eACjBD,EAAc,WACdlC,EAAU,gBACVoC,EAAe,aACff,EAAY,uBACZtB,EAAsB,eACtBiC,EAAc,0BACdkC,EAAyB,mBACzB7B,EAAkB,wBAClBU,EAAuB,sBACvBG,EAAqB,kBACrBc,EAAiB,eACjBF,EAAc,kBACdJ,EAAiB,qBACjBE,EAAoB,oBACpBC,EAAmB,iBACnBZ,EAAgB,sBAChBL,EAAqB,uBACrBD,EAAsB,WACtBF,EAAU,+BACVb,GAA8B,qBAC9BuC,IACE5F,EAAW5U,QAEf,GAAe4U,EAAkB,iJC5sB1B,MAAM6F,EAAsBxI,IACjChT,EAAAA,EAAAA,KACGyb,GAAqBA,EAAMvW,aAAawW,wBACxCA,GACCze,OAAOoN,OAAOqR,GAAuBC,OAClCvX,IAAS,IAAA9H,EAAC,OAAC8H,EAAMwX,SAA8B,QAArBtf,EAAA0W,aAAY,EAAZA,EAAcxS,eAAO,IAAAlE,OAAA,EAAAA,EAAEgU,GAAG,kDCgBvD,SAAUuL,IACd,MAAM,YAAE7e,IAAgB8e,EAAAA,EAAAA,MAClBrc,GAAW+R,EAAAA,EAAAA,MACXtV,GAASyF,EAAAA,EAAAA,MACToa,GAAqBnN,EAAAA,EAAAA,cACxBpS,IACCQ,EAAY,CACVR,cACA,GAEJ,CAACQ,IAEGgf,GAAsBpN,EAAAA,EAAAA,cAAY,KACtC5R,EAAY,CACVR,WAAYN,EAAOK,QAAQF,gBAE7BoD,GAASwc,EAAAA,EAAAA,MAAqB,GAC7B,CAAC/f,EAAOK,QAASkD,EAAUzC,KAExB,UAAEkf,EAAS,SAAElI,EAAQ,YAAEmI,EAAW,cAAEC,IAAkBxa,EAAAA,EAAAA,KAC1D,EAAGsD,kBAA8BA,IAGnC,MAAO,CACLgX,YACAlI,WACAmI,cACAC,gBACAL,qBACAC,sBAEJ,CAcM,SAAUK,EAAuBrJ,GAMrC,MA0BM,eAAEsJ,EAAc,YAAEzN,EAAW,KAAEpR,IArB9BuV,aAAY,EAAZA,EAAcxS,SAEO,gBAAtBwS,EAAa1V,KACR,CACLG,KAA0B,QAApBnB,EAAA0W,EAAaxS,eAAO,IAAAlE,OAAA,EAAAA,EAAEqW,YAAYD,aACxC4J,eACmC,QAAjCnf,EAAoB,QAApBV,EAAAuW,EAAaxS,eAAO,IAAA/D,OAAA,EAAAA,EAAEkW,mBAAW,IAAAxV,OAAA,EAAAA,EAAEof,uBACrC1N,YAEmC,QAAjC2N,EAAoB,QAApBC,EAAAzJ,EAAaxS,eAAO,IAAAic,OAAA,EAAAA,EAAE9J,mBAAW,IAAA6J,OAAA,EAAAA,EAAE3N,aAIlC,CACLpR,KAAMuV,EAAaxS,QAAQ/C,KAC3B6e,eAAgBtJ,EAAaxS,QAAQ8b,eAErCzN,YAAkC,QAArB6N,EAAA1J,aAAY,EAAZA,EAAcxS,eAAO,IAAAkc,OAAA,EAAAA,EAAE7N,aAhB7B,CAAEpR,UAAMG,EAAW0e,oBAAgB1e,GANtBuH,gBA2BxB,MAAMwX,IAAmBL,EACnBM,GAAehb,EAAAA,EAAAA,IAAY4Z,EAAmBxI,IAEpD,MAAO,CAELvV,KAAMkf,GAAkBC,EAAeN,EAAiB7e,EACxDkf,iBACAC,aAAcA,GAAgBD,EAC9BvX,OAAQyJ,aAAW,EAAXA,EAAazJ,OAEzB,CAEM,SAAUyX,IACd,MAAMvM,GAAK1O,EAAAA,EAAAA,KAAY,EAAGsD,kBAAmBA,EAAa4X,cAE1D,MAAO,CAAExM,KAAIyM,gBADUC,EAAAA,EAAAA,IAAuB1M,GAEhD,CAEM,SAAU2M,EAAoBzgB,GAClC,MAAM,UAAE0f,GAAcL,IAEtB,OAAOxM,EAAAA,EAAAA,UACL,KAAK,IAAA/S,EAAC,OAAqD,QAArDA,EAAA4f,aAAS,EAATA,EAAW5F,MAAM4G,GAASA,EAAK9X,SAAW5I,WAAW,IAAAF,OAAA,EAAAA,EAAE6gB,UAAU,GACvE,CAAC3gB,EAAY0f,GAEjB,CAEO,MAAMkB,EAAyBA,KACpC,MAAM,SAAEpJ,EAAQ,UAAEkI,GAAcL,IAE1Bpc,GAAW+R,EAAAA,EAAAA,OACX,WAAE6L,IAAevB,EAAAA,EAAAA,OAEjB,oBAAEwB,IAAwB1b,EAAAA,EAAAA,KAC7BrB,GAAqBA,EAAM2E,gBAExB,mBAAE6W,GAAuBF,KACzB,OAAE0B,IAAWC,EAAAA,EAAAA,OACb,WAAEhhB,IAAemS,EAAAA,EAAAA,KACjB8O,EAAiBH,aAAmB,EAAnBA,EAAqBG,eACtCC,EAA2BT,EAAoBQ,GAE/CE,GAAetO,EAAAA,EAAAA,UACnB,IAC0B,OAAxBiO,IACCtJ,GACDuJ,GACA/gB,IAAeihB,GACfvB,EAAUrE,MAAM+F,GAAaA,EAASxY,SAAWqY,KACnD,CACEH,EACAtJ,EACAuJ,EACA/gB,EACAihB,EACAvB,IAgBJ,MAAO,CACL2B,4BALkCA,KAClC9B,EAAmBuB,aAAmB,EAAnBA,EAAqBG,eAAe,EAKvDK,2BAdiCA,KACjCT,EAAW,CACT/f,KAAMC,EAAAA,GAAYwgB,QAClBtgB,KAAM,CAAEH,KAAM0gB,EAAAA,MAEhBve,GAASwe,EAAAA,EAAAA,MAAmC,EAU5CR,iBACAC,2BACAC,eACAL,sBACD,yIC7KI,MAAMY,EAA6C,CACxDlK,UAAU,EACVoI,mBAAexe,EACfue,aAAa,EACbD,UAAW,GACXY,aAAaqB,EAAAA,EAAAA,MACbzC,sBAAuB,CAAC,EACxB4B,oBAAqB,MAGjBc,EAAiBA,CAACjO,EAAwBG,KAC9C,MAAM+N,EAAa,IAAIlO,GAAQ5I,QAC7B,CAAC+W,GAAO9d,WAAW+d,EAAQ9Y,WACzB,GAAI6Y,EAAIhO,GAAK,CAIX,GAAsB,aAAlB9P,aAAO,EAAPA,EAASlD,QAAmC,QAAbhB,EAAAkE,aAAO,EAAPA,EAAS/C,YAAI,IAAAnB,OAAA,EAAAA,EAAEkiB,oBAEhD,OADA/Y,EAAIgZ,OAAO,GACJH,EAGTA,EAAIhO,GAAI5H,KAAKlI,EAAQ8P,GACvB,CAIA,OAFI9P,EAAQ8P,KAAOA,IAAIgO,EAAIhO,GAAM,IAE1BgO,CAAG,GAEZ,CAAC,KAGKI,EAASC,IAAa1hB,OAAO2hB,QAAQP,GAQ7C,MAAO,CAAEQ,YANW1O,EAEjB3D,QAAQ0K,IAAS,IAAA5a,EAAC,MAAwB,aAAX,QAAbA,EAAA4a,EAAM1W,eAAO,IAAAlE,OAAA,EAAAA,EAAEgB,KAAkB,IACnDyG,KAAKmT,GAAUA,EAAM1W,QAAQ8P,KAC7BwO,IAAI,GAEeJ,UAASC,WAAU,EAG9BI,GAAmB3e,EAAAA,EAAAA,IAAY,CAC1C1C,KAAM,cACNZ,aAAcohB,EACd7d,SAAU,CACR2e,kBAAmBA,CAACze,GAASC,cAC3BD,EAAMyT,UAAW,EACjBzT,EAAM6b,cAAgB5b,CAAO,EAE/Byb,mBAAqB1b,IACnBA,EAAMyT,UAAW,EACjBzT,EAAM6b,mBAAgBxe,CAAS,EAEjCqhB,wBAAyBA,CACvB1e,GAEEC,SAAW2P,SAAQG,iBAGd/P,EAAMmb,sBAAsBpL,GAEnC,MAAM,YAAEuO,GAAgBT,EAAejO,EAAQG,GAC/C/P,EAAMse,YAAcA,CAAW,EAEjCK,yBAA0BA,CACxB3e,GAEEC,SAAW2P,SAAQG,UAGrB,MAAM,YAAEuO,EAAW,QAAEH,EAAO,SAAEC,GAAaP,EAAejO,EAAQG,GAElE/P,EAAMse,YAAcA,EACpBte,EAAMmb,sBAAsBgD,GAAWC,CAAQ,EAEjDV,iCAAmC1d,IACjCA,EAAM+c,oBAAsB,IAAI,EAElC6B,6BAA8BA,CAC5B5e,GACEC,cAEFD,EAAM+c,oBAAsB9c,CAAO,GAGvCC,cAAgBC,IACdA,EACGC,QAAQrC,EAAAA,EAASsC,SAAS,IAAMsd,IAChCvd,QAAQd,EAAAA,EAAiBgB,WAAW,CAACN,GAASC,oBAC7C,MAAM4e,EAA2B,QAAjB9iB,EAAAkE,aAAO,EAAPA,EAASQ,gBAAQ,IAAA1E,OAAA,EAAAA,EAAEuS,YAC9BuQ,IAEL7e,EAAM4b,aAAkC,IAApBiD,EAAQzjB,QAC5B4E,EAAM2b,UAAY,IAAIkD,EAAQlD,WAAWxL,MAAK,CAAChF,EAAG2T,IAC5C3T,EAAEtG,SAAW5E,EAAQe,mBAA2B,EAChD8d,EAAEja,SAAW5E,EAAQe,kBAA0B,EAE5CmK,EAAEyR,WAAWmC,cAAcD,EAAElC,gBAAYvf,EAAW,CACzD2hB,YAAa,WAEf,IAEH5e,QAAQyW,EAAAA,IAAY,CAAC7W,GAASC,cAC7BD,EAAM+c,oBAAsB9c,EAAQ8c,mBAAmB,IAExD3c,QAAQsE,EAAAA,EAAUpE,WAAW,CAACN,GAASC,cACtCD,EAAM6b,cAAgB5b,EAAQhE,UAAU,IAEzCmE,QAAQiV,EAAAA,IAAU,CAACrV,GAASC,cACvBD,EAAMmb,sBAAsBnb,EAAMse,cACpCte,EAAMmb,sBAAsBnb,EAAMse,aAAanW,KAC7ClI,EAAQA,QAAQ8P,GAEpB,GACA,KAIK,kBACX0O,EAAiB,mBACjB/C,EAAkB,wBAClBgD,EAAuB,yBACvBC,EAAwB,6BACxBC,EAA4B,iCAC5BlB,GACEc,EAAiBhe,QAErB,EAAege,EAAwB,wIC/HvC,MAAMS,EAAwB,CAC5Bvd,EAAAA,EAAiBC,KACjBD,EAAAA,EAAiBE,UACjBF,EAAAA,EAAiBwd,QAENxP,GAAgBnU,EAAAA,EAAAA,IAK3B,iBACA,CAAC4jB,GAAuBra,WAAUrJ,OAASC,MAAK0jB,gBAC9C,MAAMpf,EAAQ8E,IACRua,EAAqBC,EAAAA,EAA2Btf,GAChDL,GAAmBH,EAAAA,EAAAA,GAAuBQ,GAC1C1D,EAAkBZ,EAAIY,kBACtBX,EAAS4jB,EAAAA,EAA6Bvf,IAEtC,mBAAEwf,EAAqBC,EAAAA,EAAmB,WAAE5kB,GAAec,GACzD0X,aAAcqM,IAAuBC,EAAAA,EAAAA,IAAY3f,GAEnD4f,EAAuBJ,EAAmB,CAC9CK,aAAclgB,EACd0f,qBACAF,sBACAxjB,WAEF,IAAKsjB,EAAsB5D,SAASuE,GAIlC,YAHArR,QAAQpN,MACN,kFAIJ,GAAIke,IAAuBO,EACzB,OAGF,MAAMjP,EAAajV,EAAIwf,MAAM4E,IAAIC,EAAAA,GAgBjC,OAbArkB,EAAIwf,MAAM8E,IAAID,EAAAA,EAAQrjB,OAAAC,OAAAD,OAAAC,OAAA,GAChBgU,GAAc,CAAC,GAAE,CACrB,CAAC9V,GAAaskB,KAEZA,GACFC,EAASa,KAAK,aAAcd,EAAqB,CAC/CxO,WAAYwO,EACZ7iB,kBACAujB,aAAclgB,EACd+f,uBAIGE,CAAoB,IAIlBrgB,GAAuBhE,EAAAA,EAAAA,IAClC,cACA,CAAOC,GAAK0D,WAAU4F,WAAUrJ,OAASC,WAAWG,cAAA,+BAElD,MAAM,WAAEhB,GAAe0kB,EAAAA,EAA6Bza,KAE9Cob,GACmB,QAAvBnkB,EAAAL,EAAIwf,MAAM4E,IAAIC,EAAAA,UAAS,IAAAhkB,OAAA,EAAAA,EAAGlB,KAAe6G,EAAAA,EAAiBye,WAG5D,OADAjhB,EAASwQ,EAAcwQ,IAChBA,CACT,cAToD,kRASnD,0DC9EI,MAAMH,EAAW,aAEXre,EAAmB,CAC9Bwd,OAAQ,SACRtd,UAAW,YACXD,KAAM,OACNwe,WAAY,qKCKP,MAAMlD,EAAgBA,KAC3B,MAAM/d,GAAW8R,EAAAA,EAAAA,KACXvP,GAAUJ,EAAAA,EAAAA,IAAY+e,EAAAA,GACtBC,IAAY5e,GAAUA,IAAYC,EAAAA,EAAiBwd,OACnDlC,EAASvb,IAAYC,EAAAA,EAAiBC,KACtC2e,EAAc7e,IAAYC,EAAAA,EAAiBE,UAE3C2e,GAAqBlS,EAAAA,EAAAA,cACxBsC,GAAkCzR,GAASwQ,EAAAA,EAAAA,GAAciB,KAC1D,CAACzR,IAWH,MAAO,CACLmhB,YACArD,SACAsD,cACA7e,UACAiO,cAAe6Q,EACfC,SAdeA,KACfD,EAAmB7e,EAAAA,EAAiBC,KAA0B,EAc9D8e,UAXgBA,KAChBF,EAAmB7e,EAAAA,EAAiBE,UAA+B,EAWpE,EAeU8e,EAAeA,EAC1BC,qBAAoB,EACpBvlB,WAAU,EACVwlB,gBAAeC,EAAAA,EAAAA,iBAEf,MAAOnO,EAAOoO,IAAYC,EAAAA,EAAAA,UAAS,MAC7BV,KAAc3N,aAAK,EAALA,EAAOsO,kBAAmB5lB,EACxC6lB,EAASZ,GAAaM,EAEtBO,EAAmBA,EAAEC,KAAkBL,EAASK,GAuBtD,OArBAC,EAAAA,EAAAA,YAAU,KACR,MAAMC,EAAOT,aAAY,EAAZA,EAAcU,QAU3B,IATuBrnB,OAAOsnB,sBASTN,IAAWI,IAASjmB,EAAS,MAAO,KAAe,EAExE,MACMomB,EAAW,IAAID,qBAAqBL,EADlB,CAAE7lB,UAAW,EAAGomB,KAAM,KAAMC,WAAY,OAKhE,OAFAF,EAASG,QAAQN,GAEV,IAAMG,EAASriB,YAAY,GACjC,CAACyhB,EAAcxlB,EAAS6lB,IAEpB,CAAEZ,YAAWO,eAAc,EAGvBgB,EAAoBA,KAC/B,MAAM1iB,GAAW+R,EAAAA,EAAAA,OACX,kBAAE/P,IAAsBE,EAAAA,EAAAA,MACxBygB,GAAiBxgB,EAAAA,EAAAA,IAAYygB,EAAAA,IAE7B,aAAElB,EAAY,UAAEP,GAAcK,EAAa,CAC/CtlB,QAAS8F,EACTyf,mBAAmB,IASrB,OANAS,EAAAA,EAAAA,YAAU,KACHf,GAELnhB,GAAS6iB,EAAAA,EAAAA,MAAoB,GAC5B,CAAC7iB,EAAUmhB,IAEP,CAAEO,eAAciB,iBAAgB,sECtGlC,MAAMzB,GAAmB3gB,EAAAA,EAAAA,KAC9B,EAAGkR,gBAA4BA,IAC9B3Q,GAAUA,EAAM2Q,aAGNmR,GAAuBriB,EAAAA,EAAAA,KAClC,EAAGkR,gBAA4BA,IAC9B3Q,GAAUA,EAAM6hB,0GCHnB,MAAMtlB,EAAgC,CACpCoU,mBAAYjP,EAAiBye,WAC7B0B,gBAAgB,GAGLG,GAAkBniB,EAAAA,EAAAA,IAAY,CACzC1C,KAAM,aACNZ,eACAuD,SAAU,CACRiiB,kBAAoB/hB,IAClBA,EAAM6hB,gBAAiB,CAAI,GAG/B3hB,cAAgBC,IACdA,EACGC,QACCsP,EAAAA,EAAcpP,WACd,CAACN,GAASC,QAAS0Q,MACbA,IACF3Q,EAAM2Q,WAAaA,EACrB,IAGHvQ,QAAQd,EAAAA,EAAiBgB,WAAW,CAACN,GAASC,cAExCA,EAAQiB,oBACXlB,EAAM6hB,gBAAkB5hB,EAAQiB,kBAClC,GACA,KAIK,kBAAE6gB,GAAsBC,EAAgBxhB,QAErD,EAAewhB,EAAuB,4ECrC/B,MAAMC,GAAmBC,EAAAA,EAAAA,eAAmB,MAEtCC,GAAwBD,EAAAA,EAAAA,eAAsB,+FCHpD,MAAME,EAAsBA,KAAMC,EAAAA,EAAAA,YAAWJ,EAAAA,GAEvCK,EAAuBA,IACtBF,IAEDlH,MAYAqH,EAA2BA,KACtC,MAAM7mB,EAAM0mB,IAMZ,OAJwB/T,EAAAA,EAAAA,cAAY,IAC3B3S,EAAIY,mBACV,CAACZ,GAEkB,wPClBjB,MAAMikB,EAAcA,EAAG3f,WAAuBA,EACxCwiB,EAAwBA,KAAMnhB,EAAAA,EAAAA,IAAYse,GAE1C8C,GAA6BhjB,EAAAA,EAAAA,IACxCkgB,EACAJ,EAAAA,EACA/f,EAAAA,GACA,EAAGoQ,SAAQ6E,eAAe9Y,EAAQ+mB,WAChC,GACEA,GACsB,WAAtB/mB,EAAOd,cACN4Z,aAAW,EAAXA,EAAakO,eACU,QAAvB5mB,EAAA0Y,aAAW,EAAXA,EAAakO,kBAAU,IAAA5mB,OAAA,EAAAA,EAAEmB,KAAKiG,QAE/B,OAAOyM,EAGT,MAAMgT,EAAqC,CACzC7lB,KAAM,eACNkD,QAASwU,EAAYkO,YAGvB,MAAO,IAAI/S,EAAQgT,EAAiB,IAI3BC,GAAepjB,EAAAA,EAAAA,IAC1BgjB,EACAlD,EAAAA,GACA,CAAC3P,EAAQjU,aACP,MAAM,QAAEP,EAAO,UAAEC,GAA6C,QAA/Ba,EAAgB,QAAhBH,EAAAJ,aAAM,EAANA,EAAQb,gBAAQ,IAAAiB,OAAA,EAAAA,EAAEZ,qBAAa,IAAAe,EAAAA,EAAI,CAAC,EACnE,IAAKd,EACH,OAAOwU,EAGT,MAAMkT,EAAe,GACrB,IAAIC,EAAgB,KAmBpB,OAlBAnT,EAAOtD,SAAQ,CAACqK,EAAOqM,KAErB,GAAY,IAARA,EACFF,EAAa3a,KAAIzL,OAAAC,OAAAD,OAAAC,OAAC,CAAC,EAAIga,GAAK,CAAExb,cAAewb,EAAM1W,QAAQ0R,kBAEtD,CACL,MAAMxW,EACJ4nB,IACAE,EAAAA,EAAAA,IACEtM,EAAM1W,QAAQ0R,WAAaoR,EAAc9iB,QAAQ0R,aAC9CtW,EACDsb,EAAM1W,QAAQ0R,gBACdtU,EACNylB,EAAa3a,KAAIzL,OAAAC,OAAAD,OAAAC,OAAC,CAAC,EAAIga,GAAK,CAAExb,kBAChC,CACA4nB,EAAgBpM,CAAK,IAGhBmM,CAAY,IAGVI,EAAYA,KAAM7hB,EAAAA,EAAAA,IAAYwhB,GAQ9BM,IANiB1jB,EAAAA,EAAAA,IAAeojB,GAAejT,GACnDA,EAAOpM,KAAKmT,GAAUA,EAAM1W,QAAQ8P,OAKXoT,IAAMX,IAAwBxd,WAEnDoe,EAAsBA,IAAMZ,IAAwBtO,aAEpDmP,EAAuBA,IAAMb,IAAwBnP,aAErDiQ,EAAyBA,IACpCd,IAAwBlP,oBAEbiQ,EAAcA,IAAMf,IAAwBnO,iBAE5CmP,EAAwBC,GACnCjB,IAAwBzQ,gBAAgBC,aAAayR,GAE1CC,EAAuBA,IAAMlB,IAAwBzO,YAE5D4P,GAA2BlkB,EAAAA,EAAAA,IAAeojB,GAAejT,UAC7D,MAAMgU,EAAiBhU,EAAO3D,QAAQ0K,GAAyB,YAAfA,EAAM5Z,OACtD,OAAgD,QAAzChB,EAAA6nB,EAAeA,EAAezgB,OAAS,UAAE,IAAApH,OAAA,EAAAA,EAAEkE,QAAQ8P,EAAE,IAEjD8T,EAAwBA,KAAMxiB,EAAAA,EAAAA,IAAYsiB,GAK1CG,EAAwBA,KACnC,MAAM,aAAE9R,EAAY,aAAEC,GAAiBuQ,IAAwBzQ,gBAE/D,OAAOE,EAAeD,EAAaC,GAAgB,IAAI,EAG5C8R,EAAwB/hB,GAC5BwgB,IAAwB/N,YAAYzS,GAGhCgiB,EAAoBA,KAC/B,MACExR,WACEO,SAAS,KAAEtB,GACXqB,iBAAmBrB,KAAMwS,KAEzBzB,KAEE,MAAE5Z,GAAUqb,GAAgBxS,GAAQ,CAAE7I,MAAO,MAEnD,MAAO,CACLsb,SAAoB,OAAVtb,EACVA,MAAiB,OAAVA,EAAiBA,EAAQ,KACjC,EAGUub,EAAsBA,KACjC,MAAM,WAAEtpB,IAAeuG,EAAAA,EAAAA,MAEvB,MAAO,CACLgjB,SAAyB,WAAfvpB,EACVwpB,SAAyB,WAAfxpB,EACVypB,MAAsB,QAAfzpB,EACP0pB,aAAc1pB,EACf,qTCtII,MAAMwW,EAAa,CACxBE,KAAM,OACN9T,QAAS,UACT2U,YAAa,cACboS,OAAQ,UAGGhT,EAAe,CAC1BiT,aAAc,gBACdhT,KAAM,OACNiT,MAAO,QACPC,MAAO,QACPvS,YAAa,cACbwS,QAAS,UACTtW,YAAa,cACb7Q,QAAS,UACTonB,UAAW,YACXhP,OAAQ,SACRiP,IAAK,MACLC,OAAQ,UAGG7P,EAAa,CACxBzD,KAAM,OACNoE,OAAQ,UAGGK,EAAa,CACxBE,SAAU,WACVD,KAAM,QAGKnZ,EAAc,CACzBgoB,WAAY,cACZC,SAAU,WACVC,OAAQ,SACRC,OAAQ,SACRhP,KAAM,OACNiP,cAAe,iBACfC,oBAAqB,uBACrB7H,QAAS,UACT8H,eAAgB,kBAChBroB,SAAU,YACVsoB,eAAgB,kBAChBC,WAAY,cACZC,SAAU,YACVC,UAAW,cAGAjI,EAAuB,uBAEvBkI,EAAe,CAC1B7R,yBAA0B,6BAC1BiJ,oBAAqBU,GASVmI,EAAiB,CAC5BC,UAAW,YACXC,OAAQ,UAGGC,EAAc,CACzBC,UAAW,WACXC,gBAAiB,kBAGNzQ,EAAc,CACzB8P,eAAgB,iBAChBY,gBAAiB,kBACjBzQ,QAAS,WAGE0Q,EAAY,CACvBC,IAAK,MACLnB,SAAU,WACVpoB,MAAO,uDCxEM,MAAMwpB,UAAwBne,MAC3CtK,OAAS,GAETE,QAAU,GAEV6H,WAAAA,CAAYhI,KAAkB2oB,GAa5B,GAZAC,SAASD,GAELpe,MAAMse,mBACRte,MAAMse,kBAAkB/c,KAAM/M,OAAO+pB,eAAehd,OAEtDA,KAAK9L,cAAgBA,EAEjBA,GAAesC,UACjBwJ,KAAK/L,cAAgBC,EACrB8L,KAAK9L,cAAgBA,EAAcsC,QAAQkB,MAC3CsI,KAAKhM,QAAW,iBAAgBE,EAAcsC,QAAQlD,qBAEnD0M,KAAKhM,SAAWE,GAAeF,QAAS,CAC3C,MAAMipB,EA5BZ,SAA6BC,GAC3B,IAEE,OADapc,KAAKqc,MAAMD,GACZxlB,KACd,CAAE,MAAO7D,GACP,OAAOqpB,CACT,CACF,CAqBoCE,CAAoBlpB,EAAcF,SAChEgM,KAAKhM,QAAUipB,CACjB,CAEI/oB,GAAewD,QACjBsI,KAAK9L,cAAgBA,EAAcwD,MAEvC,+DCjCa,MAAM2lB,UAAiCT,EAAAA,EACpD1gB,WAAAA,CAAYhI,KAAkB2oB,GAC5BC,MAAM5oB,KAAkB2oB,GAExB7c,KAAKtM,KAAO,2BACZsM,KAAK3L,QAAU,oBACjB,+DCNa,MAAMipB,UAA2BV,EAAAA,EAC9C1gB,WAAAA,CAAYhI,KAAkB2oB,GAC5BC,MAAM5oB,KAAkB2oB,GAExB7c,KAAKtM,KAAO,qBACZsM,KAAK3L,QAAU,iBACf2L,KAAK7L,OAAS,OAChB,+DCPa,MAAMopB,UAA2BX,EAAAA,EAC9C1gB,WAAAA,CAAYhI,KAAkB2oB,GAC5BC,MAAM5oB,KAAkB2oB,GAExB7c,KAAKtM,KAAO,qBACZsM,KAAK3L,QAAU,sBACjB,+DCNa,MAAMP,UAAkC8oB,EAAAA,EACrD1gB,WAAAA,CAAYhI,KAAkB2oB,GAC5BC,MAAM5oB,KAAkB2oB,GAExB7c,KAAKtM,KAAO,4BACZsM,KAAK7L,OAAS,OAChB,+DCNa,MAAMqpB,UAAgCZ,EAAAA,EACnD1gB,WAAAA,CAAYhI,KAAkB2oB,GAC5BC,MAAM5oB,KAAkB2oB,GAExB7c,KAAKtM,KAAO,0BACZsM,KAAK3L,QAAU,iBACf2L,KAAK7L,OAAS,OAChB,+DCFa,MAAMC,UAA+BwoB,EAAAA,EAClD1gB,WAAAA,CAAYhI,KAAkB2oB,GAC5BC,MAAM5oB,KAAkB2oB,GAExB7c,KAAKtM,KAAO,yBACZsM,KAAK3L,QAAU,0BACjB,yECVK,MAAMopB,EAAsBA,KAAM7lB,EAAAA,EAAAA,IAAY7B,EAAAA,+DCD9C,MAAMigB,EAAsBA,EACjCI,eACAR,qBACAF,sBACAxjB,aAEA,MAAM,SAAE+G,EAAQ,WAAE7H,EAAU,qBAAEsH,GAAyBxG,GAC/C8F,QAAS0lB,GAAsBzkB,GAAY,CAAC,EAGpD,GAAmB,QAAf7H,IAAyBwkB,EAC3B,OAAO3d,EAAAA,EAAiBC,KAI1B,GACiB,WAAf9G,GACAsH,GACAgd,IAAwBzd,EAAAA,EAAiBC,KAEzC,OAAOke,EACHV,GAAuBE,GAAsB3d,EAAAA,EAAiBC,KAC9DD,EAAAA,EAAiBwd,OAKvB,GAAmB,WAAfrkB,GAA2BglB,IAAiBV,EAC9C,OAAOE,GAAsB3d,EAAAA,EAAiBC,KAGhD,MAAMylB,EAAiB1lB,EAAAA,EAAiBE,UAExC,OACEud,GACAE,GACA8H,GACAC,CAAc,8DC9BX,MAAMC,EAAYA,IAAIC,IAC3BA,EACGC,OACA/jB,KAAKgkB,GACa,iBAANA,EACF9qB,OAAO2hB,QAAQmJ,GACnBhkB,KAAI,EAAExB,EAAK6B,KAAYA,EAAQ7B,EAAM,KACrCgI,KAAK,KAEHwd,IAERvb,QAAQub,GAAmB,iBAANA,IACrBhkB,KAAKgkB,GAAMA,EAAE9e,MAAM,OACnB6e,OACAtb,QAAQub,GAAMA,EAAErkB,SAChBK,KAAKgkB,GAEAA,EAAEze,QAAQ3O,EAAAA,KAAa,EAClBotB,EAEF,CAACptB,EAAAA,GAAUotB,GAAGxd,KAAK,OAE3BA,KAAK,eC3BRyd,EAAOC,QAAU,IAAM,IAAM,kCCJxB,SAASpT,IACd,MAAQ,KACNqT,OAAOxhB,OAAOyhB,KAAKC,UAAU/f,MAAM,IACnCuC,KAAKyd,MACLF,KAAKG,MAAMC,YAAYF,QACvB1d,SAAS,KACb,6UCUO,MA6IP,EA3EqB6d,EAAGtR,QAAOuR,cAAa5hB,MAC1C,MAAM,EAAER,IAAMsI,EAAAA,EAAAA,KACR+Z,GAAeC,EAAAA,EAAAA,OAEf,KACJlrB,EAAI,SACJmrB,EAAQ,YACRC,EAAW,YACXC,EAAW,qBACXC,EAAoB,0BACpBC,GA5E4B9R,KAC9B,MAAM,QAAE1W,GAAY0W,GACb2R,EAAaI,IAAkB3H,EAAAA,EAAAA,WAAS,IACzC,WAAEjE,EAAU,iBAAE6L,EAAgB,WAAEC,IAAerN,EAAAA,EAAAA,OAC/C,uBAAEvH,IAA2B0P,EAAAA,EAAAA,MAC7BmF,GAAchF,EAAAA,EAAAA,OACd,KAAE3mB,IAAS4e,EAAAA,EAAAA,IAAuBnF,IAClC,QAAEmS,GAAY7oB,EAEdooB,GAAWvZ,EAAAA,EAAAA,UAAQ,KAChB,IACF6H,EACH1W,QAAS,IACJ0W,EAAM1W,QACT/C,KAAMyZ,EAAM1W,QAAQ/C,MAAM6rB,OAC1BhN,eAAgBpF,EAAM1W,QAAQ8b,gBAAkB,IAC3CpF,EAAM1W,QAAQ8b,eACjBiN,KAAMrS,EAAM1W,QAAQ8b,eAAegN,YAIxC,CAACpS,IAEE4R,EACJrrB,EAAKqrB,aACLvU,IAA2B8U,EAAQG,kBACnChpB,EAAQ8P,KAAO8Y,EA8BjB,OA5BAzH,EAAAA,EAAAA,YAAU,KACRsH,EAAezoB,EAAQ8P,KAAO8Y,EAAY,GACzC,CAAC5oB,EAAS4oB,IA0BN,CACL3rB,OACAmrB,WACAC,cACAC,cACAC,qBA7B4BU,IAC5B,MAAM5S,GAAgBhC,EAAAA,EAAAA,KAElBiU,GACFK,EAAW,YAAatS,GAE1BqS,EAAiBO,EAAOzX,KAAM6E,GAC9BwG,EAAW,CACT/f,KAAMC,EAAAA,GAAYgoB,WAClBmE,cAAelpB,EAAQ8P,GACvBmZ,OAAQ,CACNnZ,GAAImZ,EAAOnZ,GACX0B,KAAMyX,EAAOzX,KACb8W,eAEFjS,kBAEFoS,GAAe,EAAM,EAarBD,0BAVgCA,KAChCC,GAAgBU,IAAOA,GAAE,EAU1B,EAcGC,CAAgB1S,GAEpB,OACE2S,EAAAA,EAAAA,MAAAC,EAAAA,SAAA,CAAArB,SAAA,EACGsB,EAAAA,EAAAA,cAAatB,GAAU1kB,KAAKimB,IAC3BA,EAAMnjB,MAAQ,IACTmjB,EAAMnjB,MACTqQ,MAAO0R,EACPF,eACAuB,uBAAuB,GAElBD,KAERlB,IACCe,EAAAA,EAAAA,MAAA,UACEvsB,KAAK,SACLsqB,WAAWA,EAAAA,EAAAA,GACT,SACA,oBACA,wBAEF,gBAAeiB,EAAc,OAAS,QACtCqB,QAASlB,EACT,mBAAkBN,EAAaD,SAAA,CAG3BpiB,EADHwiB,EACK,0CACA,sCACNsB,EAAAA,EAAAA,KAACC,EAAAA,EAAI,CAAC1sB,KAAK,cAAc2sB,KAAK,IAAIC,IAAI,QAGzCzB,IACCsB,EAAAA,EAAAA,KAACI,EAAAA,EAAgB,CACfjtB,KAAK,gBACLktB,iBAAiB,EACjBtT,MAAOA,KACHrQ,EAAK4hB,UAET0B,EAAAA,EAAAA,KAAA,MAAIvC,WAAWA,EAAAA,EAAAA,GAAU,gBAAiB,uBAAuBa,SAC9DhrB,EAAKgtB,QAAQ1mB,KAAK0lB,IACjBU,EAAAA,EAAAA,KAAA,MAEEvC,WAAWA,EAAAA,EAAAA,GAAU,sBAAuB,CAC1C,CAAE,wBAAuB6B,EAAOiB,YAAajB,EAAOiB,WACnDjC,UAEH0B,EAAAA,EAAAA,KAAA,UACE7sB,KAAK,SACLsqB,WAAWA,EAAAA,EAAAA,GAAU,SAAU,mBAC/BsC,QAASA,KACPnB,EAAqBU,EAAO,EAC5BhB,SAEDgB,EAAOzX,QAZLyX,EAAOnZ,YAmBrB,qGCpJP,MAwCA,EAxCyBqa,EAAGC,mBAC1B,MAAM,IAAQjc,EAAAA,EAAAA,MACR,WAAEkD,EAAYc,YAAaqR,GAAkB4G,EAC7CjY,GAAcoR,EAAAA,EAAAA,IAAqBC,IAAkB,CAAC,GACtD,SAAE3oB,IAAasG,EAAAA,EAAAA,MAEfkpB,EAAkBhZ,EACpBxL,EAAE,0BACFsM,GAAeA,EAAYjV,MACzB,WAAEnC,EAAU,SAAEC,GAAaH,EAASwW,EAAa,OAAS,UAAY,CAAC,EAE7E,IAAKtW,IAAeC,EAClB,OAAO,KAGT,MAAMsvB,EAAa,GAkBnB,OAhBIvvB,GAAcsvB,GAAmBlY,EAAYF,QAC/CqY,EAAWpiB,MACTyhB,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,mBAAmBa,UAC5C0B,EAAAA,EAAAA,KAAA,OAAKY,IAAKpY,EAAYF,OAAQmV,WAAWA,EAAAA,EAAAA,GAAU,UAAW0C,IAAI,QAKpE9uB,GAAYqvB,GACdC,EAAWpiB,MACTyhB,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,wBAAwBa,SAChDoC,KAMLC,EAAWpnB,OAAS,IAClBymB,EAAAA,EAAAA,KAAA,OAAKvC,WAAWA,EAAAA,EAAAA,GAAU,mBAAmBa,SAAEqC,GAChD,qGCsBL,QA1DA,UAA0B,gBACxBN,GAAkB,EAAI,MACtBtT,EAAK,KACL5Z,EAAI,UACJ0tB,EAAS,SACTvC,EAAQ,UACRwC,EAAY,CAAC,EAAC,KACdnZ,KACGjL,IAEH,MAAMqkB,GAAaC,EAAAA,EAAAA,GAAoCjU,IAEjD,eAAEyF,EAAc,aAAEC,EAAY,OAAExX,IAAWiX,EAAAA,EAAAA,IAAuBnF,GA6BxE,OA3BI5Z,GACF4tB,EAAWxiB,KAAM,iBAAgBpL,KAE/B0tB,IACuB,iBAAdA,IAETA,EAAYA,EAAU/hB,MAAM,KAAKuD,QAAQ4e,GAAMA,EAAE1nB,UAEnDsnB,EAAUne,SAASwe,IACjBH,EAAWxiB,KAAM,YAAW2iB,IAAW,KAGvCzO,GACFsO,EAAWxiB,KAAK,0BAEdiU,GACFuO,EAAWxiB,KAAK,4BAGdkU,IAEFqO,EAAY,IACPA,EACH/N,KAAM9X,KAKR+kB,EAAAA,EAAAA,KAAAL,EAAAA,SAAA,CAAArB,UACEoB,EAAAA,EAAAA,MAAA,OAAKjC,WAAWA,EAAAA,EAAAA,GAAUsD,MAAiBrkB,EAAK4hB,SAAA,CAC7C+B,IAAmBL,EAAAA,EAAAA,KAACQ,EAAAA,EAAgB,CAACC,aAAc1T,EAAM1W,WAC1D2pB,EAAAA,EAAAA,KAAA,OAAKvC,WAAWA,EAAAA,EAAAA,GAAU,oBAAsBqD,EAASxC,SACtDA,IAEF3W,IACCqY,EAAAA,EAAAA,KAAA,OAAK,cAAY,OAAOvC,WAAWA,EAAAA,EAAAA,GAAU,iBAAiBa,SAC3D3W,QAMb,gDC3DA,MAEA,GAFmC2Q,UAAAA,eAAc,oDCAjD,MAEA,GAFgCA,UAAAA,eAAc,CAAC,iDCAxC,MAAM6I,GAA0B7I,UAAAA,eAAc,0ECA9C,MAAM8I,EAAkCA,KACtC5pB,EAAAA,EAAAA,MAAYS,uBAGR+oB,EAAuCjU,IAClD,MAAM,WAAErF,GAAeqF,EAAM1W,QACvB0qB,EAAa,CAAC,WAUpB,MARmB,SAAfhU,EAAM5Z,KACR4tB,EAAWxiB,KAAK,wBACNmJ,EAGVqZ,EAAWxiB,KAAK,wBAFhBwiB,EAAWxiB,KAAK,yBAKXwiB,CAAU,kICTZ,MAAMM,EAAUA,CAACC,EAAK,IAC3B,IAAIlsB,SAAST,IACXQ,WAAWR,EAAS2sB,EAAG,IAWdC,EAA4BA,KACvC,MAAM,uBAAEhW,IAA2BqN,EAAAA,EAAAA,MAE7BtjB,GAAW+R,EAAAA,EAAAA,MASjB,MAAO,CAACkE,GAP+B9G,EAAAA,EAAAA,cACpC+c,IACClsB,GAAS6b,EAAAA,EAAAA,IAA0BqQ,GAAS,GAE9C,CAAClsB,IAG4D,EAGpDud,EAA0B4O,IACrChd,EAAAA,EAAAA,cAAY,KAxBQid,QAyBLD,EAxBfE,uBAAsBC,gBACdP,EAAQ,KACd,MAAMQ,EAAwB,iBAAPH,EAAkBna,SAASua,eAAeJ,GAAMA,GACvEK,EAAAA,EAAAA,IAAaF,EAAQ,GAqBE,GACtB,CAACJ,IAEOO,EAA4BA,KACvC,MAAMvX,GAAmBkP,EAAAA,EAAAA,MACzB,OAAO9G,EAAuBpI,EAAiB,kFCxC1C,MAGMwX,EAAgBA,KAC3B,MAAMC,GAHNzJ,EAAAA,EAAAA,YAAW0I,EAAAA,GAyBX,MAAO,CAAEgB,YArBU1d,EAAAA,EAAAA,cAChB2d,IACMA,GACLF,EAAY,CACVG,SAAUrG,EAAAA,GAAeE,OACzBkG,eACA,GAEJ,CAACF,IAakBI,eAXC7d,EAAAA,EAAAA,cACnB2d,IACMA,GACLF,EAAY,CACVG,SAAUrG,EAAAA,GAAeC,UACzBmG,eACA,GAEJ,CAACF,IAGiC,oZCxBtC,MAEaK,EAAoBA,KAC/B,MAAM,eACJrX,EACAtC,WAAW,QAAEO,EAAO,gBAAED,GACtBC,SACEtS,UAAYgV,QAAS2W,MAErB5J,EAAAA,EAAAA,OAGF6J,iBAAkBC,EAClBC,QAASC,GACP1Z,EAAgB+C,QAAU,CAAC,GAEvBza,QAASqxB,EAAgB7W,iBAAkB8W,GACjDN,GAAkB,CAAC,GAEf,iBAAEC,EAAgB,QAAEE,GAAY,IAChCxZ,EAAQ8C,QAAU,CACpBwW,iBAAkB,GAClBE,QAAS,MAEPD,EACA,CAAED,iBAAkBC,GACpB,CAAC,KACDE,EAAkB,CAAED,QAASC,GAAoB,CAAC,GAGxD,MAAO,CACL1X,iBACA6X,uBAAwBP,EACxBQ,qBAAsBF,GAA2BD,EACjDJ,mBACAE,UACD,EAGUM,EAAiBA,KAC5B,MAAM,eAAE9X,IAAmByN,EAAAA,EAAAA,MACrBtjB,GAAW+R,EAAAA,EAAAA,MACX4E,GA1CiCwM,EAAAA,EAAAA,YAAWyK,EAAAA,GAuDlD,MAAO,CACLC,YAZiB1e,EAAAA,EAAAA,cAChB2e,IACCnX,EAAOmX,EAAK,GAEd,CAACnX,IASDoX,cANmB5e,EAAAA,EAAAA,cAAY,KAC/BnP,GAAS4b,EAAAA,EAAAA,MAAkB,GAC1B,CAAC5b,IAKF6V,iBACAmY,YAAanY,EAAeuC,MAAM0V,GAASA,EAAK5S,YAChD+S,WAAYpY,EAAeqG,OAAO4R,GAASA,EAAK3S,WACjD,oCCtDI,MAAM+S,EAAmBA,KAC9B,MAAM,EAAEtnB,IAAMsI,EAAAA,EAAAA,MACR,QAAE2E,IAAYyP,EAAAA,EAAAA,OAEd,YAAE7N,EAAW,aAAEC,EAAY,oBAAEC,EAAmB,SAAEpU,GAAasS,GAE/D,cAAEsa,EAAa,eAAE/H,GAAmB7kB,EAEpC6sB,EAAa,CAAED,gBAAe/H,kBAE9BiI,EAAa7T,GACC,kBAAXA,EACH,kBACA5T,EAAG,WAAU4T,eAGb8T,EAAc9wB,OAAOwG,KAAKoqB,GAC7BrhB,QAAQjK,GACAsrB,EAAWtrB,KAEnBwB,KAAKkW,IAAM,CACVvc,KAAMuc,EACN3K,MAAOwe,EAAU7T,GACjB+T,UAAWH,EAAW5T,GAAQte,YAG5BsyB,EAAuBL,GAAiB/H,EAExCpmB,GAAW+R,EAAAA,EAAAA,OACX,IAAE6O,EAAG,IAAEE,IAAQsC,EAAAA,EAAAA,MAmCrB,MAAO,CACLoL,uBACA7Y,sBACApU,WACA+sB,cACAG,yBAtC8Btf,EAAAA,EAAAA,cAAY,KAC1C,MAAMuf,EAAgB9N,EAAI,YAAc,CAAC,EACzC5gB,GAAS2uB,EAAAA,EAAAA,IAA4BD,GAAe,GACnD,CAAC9N,EAAK5gB,IAoCPsa,wBAlC6BnL,EAAAA,EAAAA,cAC5Byf,IACC5uB,GAAS2uB,EAAAA,EAAAA,IAA4BC,IACrC9N,EAAI,UAAW8N,EAAa,GAE9B,CAAC9N,EAAK9gB,IA8BNua,uBA3B4BpL,EAAAA,EAAAA,cAC5B,CAACqL,EAAQ7V,KACP,MAAM+pB,EAAgB9N,EAAI,YAAc,CAAC,EACzCE,EAAI,UAAW,IACV4N,EACH,CAAClU,GAAS7V,IAEZ3E,GAAS6uB,EAAAA,EAAAA,IAA2B,CAAErU,SAAQ7V,UAAS,GAEzD,CAAC3E,EAAU4gB,EAAKE,IAmBhB1G,WAhBkB0U,IAClB9uB,GAAS+uB,EAAAA,EAAAA,IAAmBD,GAAY,EAgBxCzU,WAbiBA,KACjBra,GAASgvB,EAAAA,EAAAA,MAAqB,EAa9BvZ,cACAC,eACD,EAGUuZ,EAAkBA,KAC7B,MAAQ5Z,gBAAiBxE,IAAOyS,EAAAA,EAAAA,MAGhC,MAAO,CAAEzS,KAAIqe,aAFO3R,EAAAA,EAAAA,IAAuB1M,GAEjB,sIC7F5B,MAGA,EAHsCse,KACpChM,EAAAA,EAAAA,YAAWiM,EAAAA,yMCeb,MAuNA,EAvN0B/S,KACxB,MAAM7f,GAAM0mB,EAAAA,EAAAA,MACNljB,GAAW+R,EAAAA,EAAAA,MACXmO,GAAWiD,EAAAA,EAAAA,YAAWF,EAAAA,GACtBxiB,GAAmBunB,EAAAA,EAAAA,KACnB5qB,GAAkBimB,EAAAA,EAAAA,OAChB9gB,QAASkP,EAAU,cAAEjB,IAAkBuN,EAAAA,EAAAA,MACzCyC,GAAqB2D,EAAAA,EAAAA,MAErBkL,GAAYlgB,EAAAA,EAAAA,cAChB,IAAI5G,KACF2X,EAASa,QAAQxY,EAAK,GAExB,CAAC2X,IAGGoP,GAAQngB,EAAAA,EAAAA,cAAY,KACxBkgB,EAAU,iBAAkB,CAC1B5d,aACArU,gBAAiBA,IACjBujB,aAAclgB,EACd+f,uBAGFhkB,EAAIoB,KAAK,SACTyxB,EAAU,WAAY,CACpB5d,aACArU,gBAAiBA,IACjBujB,aAAclgB,EACd+f,sBACA,GACD,CACDhkB,EACA6yB,EACAjyB,EACAqD,EACA+f,EACA/O,IAGI8d,GAAQpgB,EAAAA,EAAAA,cAAYmd,UACxBtsB,EAASwvB,EAAAA,IAAsB,GAC9B,CAACxvB,IAEEyvB,GAAiBtgB,EAAAA,EAAAA,cACpBtR,IAAI,CACHA,OACAgT,IAAIuE,EAAAA,EAAAA,KACJgC,eAAehC,EAAAA,EAAAA,KACflC,YAAa/X,EAAAA,GACbiX,YAAY,EACZK,WAAyB,IAAbtH,KAAKyd,MACjBjZ,KAAM,CAAC,KAET,IAGI+f,GAAqBvgB,EAAAA,EAAAA,cACxBwgB,IAGQ,IAFMF,EAAe,QAI1BzxB,KAAM,CACJuU,KAAMod,MAIZ,CAACF,IAGG7C,GAAczd,EAAAA,EAAAA,cAClB,EAAGnR,OAAMvB,SAAS,CAAC,MACjB,GAAoB,KAAhBuB,EAAKgM,OACP,OAGF,MAAMzL,EAAU,IACXmxB,EAAmB1xB,MACnBvB,GAGLD,EAAIoB,KAAK,UAAWW,GACpB8wB,EAAU,UAAW9wB,GACrByB,GACEmW,EAAAA,EAAAA,IAAS,CACPtY,KAAM,UACNkD,QAAS,IACJxC,EACH4Z,wBAAwB,KAG7B,GAEH,CAAC3b,EAAKwD,EAAUqvB,EAAWK,IAGvBjG,GAAmBta,EAAAA,EAAAA,cACvB,CAACoD,EAAM6E,GAAgBhC,EAAAA,EAAAA,QACrBpV,GACEmW,EAAAA,EAAAA,IAAS,CACPtY,KAAM,UACNkD,QAAS,IAAK2uB,EAAmBnd,GAAO6E,mBAE3C,GAEH,CAACpX,EAAU0vB,IAGPE,GAAkBzgB,EAAAA,EAAAA,cACtB,CAAC0B,EAAIuG,EAAe3E,EAAYod,EAAaC,EAAUC,EAAUC,KAC/DhwB,GACEmW,EAAAA,EAAAA,IAAS,CACPtY,KAAM,UACNkD,QAAS,CACPlD,KAAM,SACNgT,KACAuG,gBACAlE,YAAa/X,EAAAA,GACbiX,YAAY,EACZK,aACA9C,KAAM,CAAC,EACP3R,KAAM,CAAE6xB,cAAaC,WAAUC,WAAUC,UAG9C,GAEH,CAAChwB,IAGG0pB,GAAava,EAAAA,EAAAA,cACjB,CAAC8gB,EAAS7Y,GAAgBhC,EAAAA,EAAAA,QACxB,MAAMrU,EAAU,CACd/C,KAAM,CAAEiyB,UAASpyB,KAAM,WACvBuU,YAAY,EACZ8d,aAAa,EACbrf,IAAIuE,EAAAA,EAAAA,KACJgC,gBACAvZ,KAAM,WAGRmC,GAASmW,EAAAA,EAAAA,IAAS,CAAEtY,KAAM,OAAQkD,YAAW,GAE/C,CAACf,IAGG4d,GAAazO,EAAAA,EAAAA,cAChBnR,IACC,IAAKA,EACH,OAGFxB,EAAIoB,KAAK,SAAUI,GAEnB,MAAM,KAAEH,GAASG,EACbH,IAASC,EAAAA,GAAYmoB,QAAUpoB,IAASC,EAAAA,GAAYmZ,MACtDoY,EAAW,UAASxxB,IAAQG,EAC9B,GAEF,CAACxB,EAAK6yB,IAGF9xB,GAAc4R,EAAAA,EAAAA,cACjBrS,IACCN,EAAIe,YAAYT,EAAQ,GAE1B,CAACN,IAiCH,MAAO,CACL2zB,SA/BchhB,EAAAA,EAAAA,cAAY,IACtB3S,EAAI4zB,UACCtwB,QAAQuwB,OAAO,IAAIrnB,MAAM,iCAG3BxM,EACJ2zB,UACAG,MAAMjzB,IACDA,IACF2C,GAAS+Z,EAAAA,EAAAA,IAAgB1c,IACrBA,EAAagE,gBACfrB,GAASa,EAAAA,EAAAA,IAAgBxD,EAAagE,gBACtCmP,EAAchO,EAAAA,EAAiBC,OAEnC,IAED8tB,OAAOtuB,IACNjC,GACEmQ,EAAAA,EAAAA,IAAa,CACXlS,KAAMgE,GAAOhE,KACbM,QAAS0D,GAAO1D,QAChBK,QAASqD,GAAOrD,QAChBF,OAAQuD,GAAOvD,OACfF,cAAeyD,GAAOzD,cACtBC,cAAewD,GAAOxD,gBAEzB,KAEJ,CAACjC,EAAKwD,EAAUwQ,IAIjB8e,QACA1C,cACAhP,aACArgB,cACAgyB,QACAF,YACA5F,mBACAmG,kBACAlG,aACA8G,aAAch0B,EAAI4zB,UAClBK,eAAgBj0B,EAAIk0B,YACrB,iKCnNH,MAgIA,EAhIqCC,KACnC,MAAM3wB,GAAW+R,EAAAA,EAAAA,OAEX,oBAAEsC,IAAwBiP,EAAAA,EAAAA,OAExBxF,OAAQ8S,IAAiB7S,EAAAA,EAAAA,MAE3B8S,GAAcC,EAAAA,EAAAA,QAAO,CAAC,GAE5BD,EAAYzO,QAAU,CACpB9N,aAAcD,EAAoBC,aAClCC,SAAUF,EAAoBE,SAC9BC,UAAWH,EAAoBG,UAC/BC,WAAYJ,EAAoBI,WAChCqJ,OAAQ8S,GAGV,MAAM,UAAEvB,EAAS,WAAEzR,IAAevB,EAAAA,EAAAA,MAC5B,EAAEzV,IAAMsI,EAAAA,EAAAA,MACR,cAAE8d,EAAa,WAAEH,IAAeF,EAAAA,EAAAA,KAEhCoE,GAAsB5hB,EAAAA,EAAAA,cACzBoD,IACC,MAAM,OAAEuL,GAAW+S,EAAYzO,QAC3BtE,GACFkP,EAAcza,EAChB,GAEF,CAACya,IAGGgE,GAAmB7hB,EAAAA,EAAAA,cACtBoD,IACC,MAAM,OAAEuL,GAAW+S,EAAYzO,QAC3BtE,GACF+O,EAAWta,EACb,GAEF,CAACsa,IAGGoE,GAAgB9hB,EAAAA,EAAAA,cACnB+hB,IACC,MAAMhY,GAAeiY,EAAAA,EAAAA,IAAsBD,GACrC/X,GAAYG,EAAAA,EAAAA,IAAmBJ,GAErClZ,GACEiZ,EAAAA,EAAAA,IAAwB,CACtBC,eACAC,eAGJkW,EAAU,mBACV0B,EACG,GAAEnqB,EAAE,uCAAuCA,EAC1C,sCACGA,EAAE,mCAAoCuS,KAC5C,GAEH,CAACnZ,EAAUqvB,EAAW0B,EAAqBnqB,IAGvCwqB,GAAejiB,EAAAA,EAAAA,cACnB,CAAC7L,EAAc+tB,KACb,MAAM,aAAE/c,EAAY,WAAEG,GAAeoc,EAAYzO,QAC5C9N,IAIAhR,IACE+tB,GACHzT,EAAW,CAAE/f,KAAMC,EAAAA,GAAYooB,gBAEjC6K,EAAoBnqB,EAAE,0CAGnB6N,GACH4a,EAAU,kBAGZrvB,GAASwZ,EAAAA,EAAAA,OAA2B,GAEtC,CAACxZ,EAAU4d,EAAYyR,EAAW0B,EAAqBnqB,IAGnD0qB,GAAqBniB,EAAAA,EAAAA,cAAY,KACrC,MAAM,UAAEqF,GAAcqc,EAAYzO,QAClC,GAAI5N,GAAa,EACf,OAGF,MAAM+c,EAAe/c,EAAY,EAE7B+c,EAAen2B,EAAAA,IAAqC,GACtD21B,EACG,GAAEnqB,EAAE,sCAAsCA,EACzC,oCACA0S,EAAAA,EAAAA,IAAmBiY,OAKzBvxB,GAASoZ,EAAAA,EAAAA,MAAsC,GAC9C,CAACpZ,EAAU+wB,EAAqBnqB,IAE7B4qB,GAAgBriB,EAAAA,EAAAA,cAAY,KAChC,MAAM,SAAEoF,EAAQ,UAAEC,GAAcqc,EAAYzO,QACvC7N,IAILvU,GAASuZ,EAAAA,EAAAA,OAEL/E,IACF6a,EAAU,kBACV2B,EAAiBpqB,EAAE,8CACrB,GACC,CAAC5G,EAAUqvB,EAAW2B,EAAkBpqB,IAE3C,MAAO,IACFyN,EACH4c,gBACAG,eACAE,qBACAE,gBACD,yHCzIH,MAwBA,EAxB0CC,KACxC,MAAMzxB,GAAW+R,EAAAA,EAAAA,MACX2f,GAAYpO,EAAAA,EAAAA,MAAwB1O,0BACpC,WAAEgJ,IAAevB,EAAAA,EAAAA,MACjB,EAAEzV,IAAMsI,EAAAA,EAAAA,MACR,cAAE8d,IAAkBL,EAAAA,EAAAA,KAgB1B,MAAO,CAAErpB,aAdYA,KACnBsa,EAAW,CACT/f,KAAMC,EAAAA,GAAYwgB,QAClBtgB,KAAM,CAAEH,KAAM4oB,EAAAA,GAAa7R,4BAE7B5U,GAAS0Z,EAAAA,EAAAA,MAAgC,EASpBgY,YAAWC,YANdA,KAClB3E,EAAcpmB,EAAE,iDAChBgX,EAAW,CAAE/f,KAAMC,EAAAA,GAAYooB,gBAC/BlmB,GAAS0Z,EAAAA,EAAAA,MAAgC,EAGI,2FCpB1C,MAAMkY,EAAiBA,KAI5B,MAAOt1B,EAAGu1B,IAAeC,EAAAA,EAAAA,aAAYC,GAAMA,EAAI,GAAG,GAElD,OAAO5iB,EAAAA,EAAAA,cAAY,KACjBtP,YAAW,KACTgyB,GAAa,GACb,GACD,GAAG,EAGK3I,EAAiBA,KAC5B,MAAOrY,IAAMgR,EAAAA,EAAAA,WAAS,KAAMzM,EAAAA,EAAAA,OAC5B,OAAOvE,CAAE,EAGEmhB,EAAqBC,IAChC,MAAMC,GAAcpB,EAAAA,EAAAA,QAAO,MAC3BoB,EAAY9P,QAAU6P,EACtB,MAAME,EAAiC,mBAAbF,EAC1B,OAAOriB,EAAAA,EAAAA,UAAQ,IACNuiB,EAAa,IAAI5pB,IAAS2pB,EAAY9P,WAAW7Z,QAAQpK,GAC/D,CAACg0B,GAAY,oJCjCX,MAAMC,EAAWA,CAAChoB,EAAMlL,KAC7B,IAAI6sB,EACJ,OAAO,YAAaxjB,GAClB,IAAI8pB,GAAc,EAUlB,OATA5yB,aAAassB,GACbA,EAAUlsB,YAAW,KACnBksB,EAAU,KACLsG,GACHjoB,EAAKqB,MAAMlB,KAAMhC,GAEnB8pB,GAAc,CAAK,GAClBnzB,GAEKozB,IACND,GAAc,EACVC,GACFloB,EAAKqB,MAAMlB,KAAMhC,EACnB,CAEJ,CAAC,EAiCUgqB,EAAkBA,KAC7B,MAAMC,EAAiB,GACjBC,EAAY,GAYlB,OAXAxgB,SAASygB,iBAAiB,iCAAiCtlB,SAAS+U,IAClE,MAAMwQ,EAAOxQ,EAAKyQ,aAAa,eACA,OAATD,GAA0B,UAATA,IAIvCH,EAAevpB,KAAK0pB,GACpBF,EAAUxpB,KAAKkZ,GACfA,EAAK0Q,aAAa,cAAe,QAAO,IAGnC,KACLJ,EAAUrlB,SAAQ,CAAC+U,EAAM2Q,KACvB,MAAMC,EAAgBP,EAAeM,GACf,OAAlBC,EACF5Q,EAAK6Q,gBAAgB,eAErB7Q,EAAK0Q,aAAa,cAAeE,EACnC,GACA,CACH,EAKU5B,EAAyBD,GAC7BxI,KAAKuK,KAAK/B,EAAe,KAGrBnN,EAA8BmP,GAClCxK,KAAKuK,KAAKC,EAAe,KAGrB5Z,EAAsB6Z,IACjC,MAAMC,EAAU1K,KAAK2K,MAAMF,EAAU,IAGrC,MAAO,CAAEC,UAASD,QAFKA,EAAoB,GAAVC,EAEU,EAGhCE,EAAcA,CAACC,EAAOC,EAAW,KAC5C,GAAc,IAAVD,EAAa,MAAO,UAExB,MACME,EAAKD,EAAW,EAAI,EAAIA,EAGxBttB,EAAIwiB,KAAK2K,MAAM3K,KAAKgL,IAAIH,GAAS7K,KAAKgL,IAJlC,OAMV,MAAQ,GAAEC,YAAYJ,EANZ,MAMyBrtB,GAAG0tB,QAAQH,OAJhC,CAAC,QAAS,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,MAINvtB,IAAI,EAGrD2tB,EAAW,CACtB,GAAI,SACJ,GAAI,MACJ,GAAI,OACJ,GAAI,YACJ,GAAI,UACJ,GAAI,aACJ,GAAI,aAGOC,EAAW,CACtBC,OAAQ,SACRC,IAAK,MACLC,KAAM,OACNC,UAAW,YACXC,QAAS,UACTC,WAAY,aACZC,UAAW,aAGAC,EAAUl2B,GAAOA,EAAEm2B,KAAOT,EAAS11B,EAAEm2B,MAAQV,EAASz1B,EAAEo2B,SAExD/H,EAAgBL,IACvBA,GACFA,EAAGqI,OACL,EAGWC,EAAiCA,CAACtI,EAAI6F,KAE/C7F,IACCA,EAAGuI,SAAS1iB,SAAS2iB,gBAAkBxI,IAAOna,SAAS2iB,gBAExD3C,GACF,EAIW4C,EAAkBA,CAACC,EAAMC,KACpC,MAAMC,EAAkB,IAAI7pB,KAAK4pB,GAAaE,SAAS,EAAG,EAAG,EAAG,GAC1DC,EAASJ,EAAKK,UACdC,EAAU,MAChB,OAAIF,GAAUF,EAAkBI,EAEvBN,EACEI,EAASF,EAEX,QACEE,EAASF,EAAkBI,EAE7B,YAGAN,CACT,EAGWlxB,EAAOA,CAAC+D,EAAK3D,IACxBA,EAAK8D,QAAO,CAACoJ,EAAOpO,KACdA,KAAO6E,IAAKuJ,EAAMpO,GAAO6E,EAAI7E,IAC1BoO,IACN,CAAC,s0CCxK8d,SAASmkB,EAAEtpB,EAAEnF,GAAG,IAAI,IAAIxI,KAAKwI,EAAEmF,EAAE3N,GAAGwI,EAAExI,GAAG,OAAO2N,CAAC,CAAC,SAASupB,EAAEvpB,EAAEnF,GAAG,IAAI,IAAIxI,KAAK2N,EAAE,GAAG,aAAa3N,KAAKA,KAAKwI,GAAG,OAAM,EAAG,IAAI,IAAIC,KAAKD,EAAE,GAAG,aAAaC,GAAGkF,EAAElF,KAAKD,EAAEC,GAAG,OAAM,EAAG,OAAM,CAAE,CAAC,SAAS0uB,EAAExpB,GAAGxB,KAAKnD,MAAM2E,CAAC,CAAC,SAASypB,EAAEzpB,EAAE3N,GAAG,SAASyI,EAAEkF,GAAG,IAAInF,EAAE2D,KAAKnD,MAAMquB,IAAI5uB,EAAED,GAAGmF,EAAE0pB,IAAI,OAAO5uB,GAAGD,IAAIA,EAAEG,KAAKH,EAAE,MAAMA,EAAEwb,QAAQ,MAAMhkB,GAAGA,EAAEmM,KAAKnD,MAAM2E,KAAKlF,EAAEyuB,EAAE/qB,KAAKnD,MAAM2E,EAAE,CAAC,SAASC,EAAE5N,GAAG,OAAOmM,KAAKmrB,sBAAsB7uB,GAAE,mBAAEkF,EAAE3N,EAAE,CAAC,OAAO4N,EAAE2pB,YAAY,SAAS5pB,EAAE4pB,aAAa5pB,EAAE9N,MAAM,IAAI+N,EAAEtF,UAAUkvB,kBAAiB,EAAG5pB,EAAE6pB,KAAI,EAAG7pB,CAAC,WAAEupB,EAAE7uB,UAAU,IAAI,aAAGovB,sBAAqB,EAAGP,EAAE7uB,UAAUgvB,sBAAsB,SAAS3pB,EAAEnF,GAAG,OAAO0uB,EAAE/qB,KAAKnD,MAAM2E,IAAIupB,EAAE/qB,KAAKzJ,MAAM8F,EAAE,EAAE,IAAImrB,EAAE,UAAEgE,IAAI,UAAEA,IAAI,SAAShqB,GAAGA,EAAElO,MAAMkO,EAAElO,KAAKg4B,KAAK9pB,EAAE0pB,MAAM1pB,EAAE3E,MAAMquB,IAAI1pB,EAAE0pB,IAAI1pB,EAAE0pB,IAAI,MAAM1D,GAAGA,EAAEhmB,EAAE,EAAE,IAAIiqB,EAAE,oBAAoBzvB,QAAQA,OAAO0vB,KAAK1vB,OAAO0vB,IAAI,sBAAsB,KAAK,SAASC,EAAEnqB,GAAG,SAASnF,EAAEA,GAAG,IAAIxI,EAAEi3B,EAAE,CAAC,EAAEzuB,GAAG,cAAcxI,EAAEq3B,IAAI1pB,EAAE3N,EAAEwI,EAAE6uB,KAAK,KAAK,CAAC,OAAO7uB,EAAEuvB,SAASH,EAAEpvB,EAAEwvB,OAAOxvB,EAAEA,EAAEF,UAAUkvB,iBAAiBhvB,EAAEivB,KAAI,EAAGjvB,EAAE+uB,YAAY,eAAe5pB,EAAE4pB,aAAa5pB,EAAE9N,MAAM,IAAI2I,CAAC,CAAC,IAAIyvB,EAAE,SAAStqB,EAAEnF,GAAG,OAAO,MAAMmF,EAAE,MAAK,mBAAE,kBAAEA,GAAGzH,IAAIsC,GAAG,EAAE0vB,EAAE,CAAChyB,IAAI+xB,EAAEjpB,QAAQipB,EAAE3hB,MAAM,SAAS3I,GAAG,OAAOA,GAAE,kBAAEA,GAAG9H,OAAO,CAAC,EAAEsyB,KAAK,SAASxqB,GAAG,IAAInF,GAAE,kBAAEmF,GAAG,GAAG,IAAInF,EAAE3C,OAAO,KAAK,gBAAgB,OAAO2C,EAAE,EAAE,EAAE4vB,QAAQ,gBAAGC,EAAE,UAAEC,IAAI,UAAEA,IAAI,SAAS3qB,EAAEnF,EAAExI,EAAEyI,GAAG,GAAGkF,EAAEukB,KAAK,IAAI,IAAItkB,EAAE1F,EAAEM,EAAEN,EAAEA,EAAEqwB,IAAI,IAAI3qB,EAAE1F,EAAEswB,MAAM5qB,EAAE4qB,IAAI,OAAO,MAAMhwB,EAAE8vB,MAAM9vB,EAAE8vB,IAAIt4B,EAAEs4B,IAAI9vB,EAAEiwB,IAAIz4B,EAAEy4B,KAAK7qB,EAAE4qB,IAAI7qB,EAAEnF,GAAG6vB,EAAE1qB,EAAEnF,EAAExI,EAAEyI,EAAE,EAAE,IAAIiwB,EAAE,UAAEC,QAAQ,SAASC,EAAEjrB,EAAEnF,EAAExI,GAAG,OAAO2N,IAAIA,EAAE6qB,KAAK7qB,EAAE6qB,IAAIK,MAAMlrB,EAAE6qB,IAAIK,IAAIN,GAAGvpB,SAAQ,SAASrB,GAAG,mBAAmBA,EAAE6qB,KAAK7qB,EAAE6qB,KAAK,IAAG7qB,EAAE6qB,IAAIK,IAAI,MAAM,OAAOlrB,EAAEspB,EAAE,CAAC,EAAEtpB,IAAI6qB,MAAM7qB,EAAE6qB,IAAIM,MAAM94B,IAAI2N,EAAE6qB,IAAIM,IAAItwB,GAAGmF,EAAE6qB,IAAI,MAAM7qB,EAAE8qB,IAAI9qB,EAAE8qB,KAAK9qB,EAAE8qB,IAAIvyB,KAAI,SAASyH,GAAG,OAAOirB,EAAEjrB,EAAEnF,EAAExI,EAAE,KAAI2N,CAAC,CAAC,SAASorB,EAAEprB,EAAEnF,EAAExI,GAAG,OAAO2N,GAAG3N,IAAI2N,EAAEqrB,IAAI,KAAKrrB,EAAE8qB,IAAI9qB,EAAE8qB,KAAK9qB,EAAE8qB,IAAIvyB,KAAI,SAASyH,GAAG,OAAOorB,EAAEprB,EAAEnF,EAAExI,EAAE,IAAG2N,EAAE6qB,KAAK7qB,EAAE6qB,IAAIM,MAAMtwB,IAAImF,EAAE2qB,KAAKt4B,EAAEi5B,YAAYtrB,EAAE2qB,KAAK3qB,EAAE6qB,IAAIF,KAAI,EAAG3qB,EAAE6qB,IAAIM,IAAI94B,IAAI2N,CAAC,CAAC,SAASurB,IAAI/sB,KAAKgtB,IAAI,EAAEhtB,KAAK3D,EAAE,KAAK2D,KAAKwrB,IAAI,IAAI,CAAC,SAASyB,EAAEzrB,GAAG,IAAInF,EAAEmF,EAAE4qB,GAAGC,IAAI,OAAOhwB,GAAGA,EAAE6wB,KAAK7wB,EAAE6wB,IAAI1rB,EAAE,CAAC,SAAS2rB,EAAE3rB,GAAG,IAAI3N,EAAEyI,EAAEmF,EAAE,SAAS1F,EAAEA,GAAG,GAAGlI,IAAIA,EAAE2N,KAAKukB,MAAK,SAASvkB,GAAGlF,EAAEkF,EAAEgK,SAAShK,CAAC,IAAE,SAASA,GAAGC,EAAED,CAAC,IAAGC,EAAE,MAAMA,EAAE,IAAInF,EAAE,MAAMzI,EAAE,OAAO,mBAAEyI,EAAEP,EAAE,CAAC,OAAOA,EAAEqvB,YAAY,OAAOrvB,EAAEuvB,KAAI,EAAGvvB,CAAC,CAAC,SAASqxB,IAAIptB,KAAKyB,EAAE,KAAKzB,KAAKjE,EAAE,IAAI,CAAC,UAAEywB,QAAQ,SAAShrB,GAAG,IAAInF,EAAEmF,EAAE6qB,IAAIhwB,GAAGA,EAAEgxB,KAAKhxB,EAAEgxB,MAAMhxB,GAAG,GAAGmF,EAAEwrB,MAAMxrB,EAAElO,KAAK,MAAMi5B,GAAGA,EAAE/qB,EAAE,GAAGurB,EAAE5wB,UAAU,IAAI,aAAGkwB,IAAI,SAAS7qB,EAAEnF,GAAG,IAAIxI,EAAEwI,EAAEgwB,IAAI/vB,EAAE0D,KAAK,MAAM1D,EAAED,IAAIC,EAAED,EAAE,IAAIC,EAAED,EAAEqC,KAAK7K,GAAG,IAAI4N,EAAEwrB,EAAE3wB,EAAEuwB,KAAK9wB,GAAE,EAAGJ,EAAE,WAAWI,IAAIA,GAAE,EAAGlI,EAAEw5B,IAAI,KAAK5rB,EAAEA,EAAEF,GAAGA,IAAI,EAAE1N,EAAEw5B,IAAI1xB,EAAE,IAAI4F,EAAE,WAAW,OAAMjF,EAAE0wB,IAAI,CAAC,GAAG1wB,EAAE/F,MAAM22B,IAAI,CAAC,IAAI1rB,EAAElF,EAAE/F,MAAM22B,IAAI5wB,EAAEuwB,IAAIP,IAAI,GAAGM,EAAEprB,EAAEA,EAAE6qB,IAAIM,IAAInrB,EAAE6qB,IAAIiB,IAAI,CAAC,IAAIjxB,EAAE,IAAIC,EAAEixB,SAAS,CAACL,IAAI5wB,EAAEkvB,IAAI,OAAOnvB,EAAEC,EAAED,EAAEmxB,OAAOnxB,EAAEirB,aAAa,CAAC,EAAEhrB,EAAE0wB,OAAO,GAAG3wB,EAAE2wB,KAAK1wB,EAAEixB,SAAS,CAACL,IAAI5wB,EAAEkvB,IAAIlvB,EAAEuwB,IAAIP,IAAI,KAAK9qB,EAAEukB,KAAKpqB,EAAEA,EAAE,EAAEoxB,EAAE5wB,UAAUsxB,qBAAqB,WAAWztB,KAAK3D,EAAE,EAAE,EAAE0wB,EAAE5wB,UAAU0vB,OAAO,SAASrqB,EAAE3N,GAAG,GAAGmM,KAAKwrB,IAAI,CAAC,GAAGxrB,KAAK6sB,IAAIP,IAAI,CAAC,IAAIhwB,EAAEoL,SAASgmB,cAAc,OAAO3xB,EAAEiE,KAAK6sB,IAAIP,IAAI,GAAGD,IAAIrsB,KAAK6sB,IAAIP,IAAI,GAAGG,EAAEzsB,KAAKwrB,IAAIlvB,EAAEP,EAAEuxB,IAAIvxB,EAAE4wB,IAAI,CAAC3sB,KAAKwrB,IAAI,IAAI,CAAC,IAAI7vB,EAAE9H,EAAEq5B,MAAK,mBAAE,WAAE,KAAK1rB,EAAEmsB,UAAU,OAAOhyB,IAAIA,EAAEqxB,MAAM,IAAI,EAAC,mBAAE,WAAE,KAAKn5B,EAAEq5B,IAAI,KAAK1rB,EAAEid,UAAU9iB,EAAE,EAAE,IAAIiyB,EAAE,SAASpsB,EAAEnF,EAAExI,GAAG,KAAKA,EAAE,KAAKA,EAAE,IAAI2N,EAAEzF,EAAE8xB,OAAOxxB,GAAGmF,EAAE3E,MAAMixB,cAAc,MAAMtsB,EAAE3E,MAAMixB,YAAY,KAAKtsB,EAAEzF,EAAEskB,MAAM,IAAIxsB,EAAE2N,EAAEC,EAAE5N,GAAG,CAAC,KAAKA,EAAE6F,OAAO,GAAG7F,EAAE25B,KAAF35B,GAAU,GAAGA,EAAE,GAAGA,EAAE,GAAG,MAAM2N,EAAEC,EAAE5N,EAAEA,EAAE,EAAE,CAAC,EAAE,SAASk6B,EAAEvsB,GAAG,OAAOxB,KAAKguB,gBAAgB,WAAW,OAAOxsB,EAAEjP,OAAO,EAAEiP,EAAEid,QAAQ,CAAC,SAASwP,EAAEzsB,GAAG,IAAI3N,EAAEmM,KAAK1D,EAAEkF,EAAE7F,EAAE9H,EAAE45B,qBAAqB,YAAW,YAAE,KAAK55B,EAAE0N,GAAG1N,EAAE0N,EAAE,KAAK1N,EAAE8H,EAAE,IAAI,EAAE9H,EAAE8H,GAAG9H,EAAE8H,IAAIW,GAAGzI,EAAE45B,uBAAuB55B,EAAE0N,IAAI1N,EAAE8H,EAAEW,EAAEzI,EAAE0N,EAAE,CAAC2sB,SAAS,EAAEC,WAAW7xB,EAAE8xB,WAAW,GAAGtB,YAAY,SAAStrB,GAAGxB,KAAKouB,WAAW1vB,KAAK8C,GAAG3N,EAAE8H,EAAEmxB,YAAYtrB,EAAE,EAAE6sB,aAAa,SAAS7sB,EAAEnF,GAAG2D,KAAKouB,WAAW1vB,KAAK8C,GAAG3N,EAAE8H,EAAEmxB,YAAYtrB,EAAE,EAAE8sB,YAAY,SAAS9sB,GAAGxB,KAAKouB,WAAW3Z,OAAOzU,KAAKouB,WAAW9uB,QAAQkC,KAAK,EAAE,GAAG3N,EAAE8H,EAAE2yB,YAAY9sB,EAAE,KAAI,aAAE,mBAAEusB,EAAE,CAACx7B,QAAQsB,EAAEtB,SAASiP,EAAEqrB,KAAKh5B,EAAE0N,EAAE,CAAC,SAASgtB,EAAE/sB,EAAE3N,GAAG,IAAIyI,GAAE,mBAAE2xB,EAAE,CAACpB,IAAIrrB,EAAE7F,EAAE9H,IAAI,OAAOyI,EAAEkyB,cAAc36B,EAAEyI,CAAC,EAAE8wB,EAAEjxB,UAAU,IAAI,aAAG+wB,IAAI,SAAS1rB,GAAG,IAAInF,EAAE2D,KAAKnM,EAAEo5B,EAAE5wB,EAAEwwB,KAAKvwB,EAAED,EAAEN,EAAEsa,IAAI7U,GAAG,OAAOlF,EAAE,KAAK,SAASmF,GAAG,IAAI1F,EAAE,WAAWM,EAAEQ,MAAMixB,aAAaxxB,EAAEoC,KAAK+C,GAAGmsB,EAAEvxB,EAAEmF,EAAElF,IAAImF,GAAG,EAAE5N,EAAEA,EAAEkI,GAAGA,GAAG,CAAC,EAAEqxB,EAAEjxB,UAAU0vB,OAAO,SAASrqB,GAAGxB,KAAKyB,EAAE,KAAKzB,KAAKjE,EAAE,IAAI0yB,IAAI,IAAIpyB,GAAE,kBAAEmF,EAAEid,UAAUjd,EAAEssB,aAAa,MAAMtsB,EAAEssB,YAAY,IAAIzxB,EAAE2R,UAAU,IAAI,IAAIna,EAAEwI,EAAE3C,OAAO7F,KAAKmM,KAAKjE,EAAEwa,IAAIla,EAAExI,GAAGmM,KAAKyB,EAAE,CAAC,EAAE,EAAEzB,KAAKyB,IAAI,OAAOD,EAAEid,QAAQ,EAAE2O,EAAEjxB,UAAUuyB,mBAAmBtB,EAAEjxB,UAAUwyB,kBAAkB,WAAW,IAAIntB,EAAExB,KAAKA,KAAKjE,EAAE8G,SAAQ,SAASxG,EAAExI,GAAG+5B,EAAEpsB,EAAE3N,EAAEwI,EAAE,GAAE,EAAE,IAAIuyB,EAAE,oBAAoB5yB,QAAQA,OAAO0vB,KAAK1vB,OAAO0vB,IAAI,kBAAkB,MAAMmD,EAAE,8RAA8RC,EAAE,mCAAmCC,EAAE,YAAYC,EAAE,oBAAoBtnB,SAASunB,EAAE,SAASztB,GAAG,OAAO,oBAAoBxF,QAAQ,iBAAiBA,SAAS,cAAc,cAAc+B,KAAKyD,EAAE,EAAE,SAAS0tB,EAAE1tB,EAAEnF,EAAExI,GAAG,OAAO,MAAMwI,EAAEiwB,MAAMjwB,EAAE8yB,YAAY,KAAI,YAAE3tB,EAAEnF,GAAG,mBAAmBxI,GAAGA,IAAI2N,EAAEA,EAAE6qB,IAAI,IAAI,CAAC,SAAS+C,EAAE5tB,EAAEnF,EAAExI,GAAG,OAAO,aAAE2N,EAAEnF,GAAG,mBAAmBxI,GAAGA,IAAI2N,EAAEA,EAAE6qB,IAAI,IAAI,CAAC,YAAElwB,UAAUkvB,iBAAiB,CAAC,EAAE,CAAC,qBAAqB,4BAA4B,uBAAuBxoB,SAAQ,SAASxG,GAAGpJ,OAAOiK,eAAe,YAAEf,UAAUE,EAAE,CAACW,cAAa,EAAGqZ,IAAI,WAAW,OAAOrW,KAAK,UAAU3D,EAAE,EAAEka,IAAI,SAAS/U,GAAGvO,OAAOiK,eAAe8C,KAAK3D,EAAE,CAACW,cAAa,EAAGC,UAAS,EAAG7C,MAAMoH,GAAG,GAAG,IAAG,IAAI6tB,EAAE,UAAEniB,MAAM,SAASoiB,IAAI,CAAC,SAASC,IAAI,OAAOvvB,KAAKwvB,YAAY,CAAC,SAASC,IAAI,OAAOzvB,KAAK0vB,gBAAgB,CAAC,UAAExiB,MAAM,SAAS1L,GAAG,OAAO6tB,IAAI7tB,EAAE6tB,EAAE7tB,IAAIA,EAAEmuB,QAAQL,EAAE9tB,EAAEouB,qBAAqBL,EAAE/tB,EAAEquB,mBAAmBJ,EAAEjuB,EAAEsuB,YAAYtuB,CAAC,EAAE,IAAIuuB,EAAGC,EAAG,CAACjzB,YAAW,EAAGC,cAAa,EAAGqZ,IAAI,WAAW,OAAOrW,KAAKiwB,KAAK,GAAGC,EAAG,UAAEC,MAAM,UAAEA,MAAM,SAAS3uB,GAAG,iBAAiBA,EAAElO,MAAM,SAASkO,GAAG,IAAInF,EAAEmF,EAAE3E,MAAMhJ,EAAE2N,EAAElO,KAAKmO,EAAE,CAAC,EAAE,IAAI,IAAI1F,KAAKM,EAAE,CAAC,IAAIV,EAAEU,EAAEN,GAAG,KAAK,UAAUA,GAAG,iBAAiBM,GAAG,MAAMV,GAAGqzB,GAAG,aAAajzB,GAAG,aAAalI,GAAG,UAAUkI,GAAG,cAAcA,GAAG,CAAC,IAAIwF,EAAExF,EAAEq0B,cAAc,iBAAiBr0B,GAAG,UAAUM,GAAG,MAAMA,EAAEjC,MAAM2B,EAAE,QAAQ,aAAaA,IAAG,IAAKJ,EAAEA,EAAE,GAAG,kBAAkB4F,EAAExF,EAAE,aAAa,aAAawF,GAAG,UAAU1N,GAAG,aAAaA,GAAGo7B,EAAE5yB,EAAE/I,MAAM,YAAYiO,EAAExF,EAAE,YAAY,WAAWwF,EAAExF,EAAE,aAAa+yB,EAAE/wB,KAAKhC,GAAGA,EAAEwF,GAAG,IAAI1N,EAAEyL,QAAQ,MAAMuvB,EAAE9wB,KAAKhC,GAAGA,EAAEA,EAAEs0B,QAAQtB,EAAE,OAAOqB,cAAc,OAAOz0B,IAAIA,OAAE,GAAQ4F,EAAExF,EAAE,UAAU,YAAYwF,GAAGE,EAAE1F,EAAEwF,KAAKxF,EAAE,kBAAkB0F,EAAE1F,GAAGJ,CAAC,CAAC,CAAC,UAAU9H,GAAG4N,EAAE6uB,UAAUz0B,MAAM6B,QAAQ+D,EAAErH,SAASqH,EAAErH,OAAM,kBAAEiC,EAAEoiB,UAAU5b,SAAQ,SAASrB,GAAGA,EAAE3E,MAAM0zB,UAAU,GAAG9uB,EAAErH,MAAMkF,QAAQkC,EAAE3E,MAAMzC,MAAM,KAAI,UAAUvG,GAAG,MAAM4N,EAAE+uB,eAAe/uB,EAAErH,OAAM,kBAAEiC,EAAEoiB,UAAU5b,SAAQ,SAASrB,GAAGA,EAAE3E,MAAM0zB,SAAS9uB,EAAE6uB,UAAU,GAAG7uB,EAAE+uB,aAAalxB,QAAQkC,EAAE3E,MAAMzC,OAAOqH,EAAE+uB,cAAchvB,EAAE3E,MAAMzC,KAAK,KAAIiC,EAAE4zB,QAAQ5zB,EAAEuhB,WAAWnc,EAAEwuB,MAAM5zB,EAAE4zB,MAAMh9B,OAAOiK,eAAeuE,EAAE,YAAYuuB,KAAM3zB,EAAEuhB,YAAYvhB,EAAE4zB,OAAO5zB,EAAE4zB,OAAO5zB,EAAEuhB,aAAanc,EAAEwuB,MAAMxuB,EAAEmc,UAAUvhB,EAAEuhB,WAAWpc,EAAE3E,MAAM4E,CAAC,CAA1kC,CAA4kCD,GAAGA,EAAEoqB,SAASgD,EAAEsB,GAAIA,EAAG1uB,EAAE,EAAE,IAAIivB,EAAG,UAAEC,IAAI,UAAEA,IAAI,SAASlvB,GAAGivB,GAAIA,EAAGjvB,GAAGuuB,EAAGvuB,EAAE6qB,GAAG,EAAE,IAAIsE,EAAG,UAAEC,OAAO,UAAEA,OAAO,SAASpvB,GAAGmvB,GAAIA,EAAGnvB,GAAG,IAAInF,EAAEmF,EAAE3E,MAAMhJ,EAAE2N,EAAE2qB,IAAI,MAAMt4B,GAAG,aAAa2N,EAAElO,MAAM,UAAU+I,GAAGA,EAAEjC,QAAQvG,EAAEuG,QAAQvG,EAAEuG,MAAM,MAAMiC,EAAEjC,MAAM,GAAGiC,EAAEjC,OAAO21B,EAAG,IAAI,EAAE,IAAIc,EAAG,CAACC,uBAAuB,CAACjZ,QAAQ,CAACkZ,YAAY,SAASvvB,GAAG,OAAOuuB,EAAGiB,IAAIxvB,EAAE6qB,KAAKxvB,MAAMzC,KAAK,KAAK62B,EAAG,SAAS,SAASC,EAAG1vB,GAAG,OAAO,gBAAEU,KAAK,KAAKV,EAAE,CAAC,SAAS2vB,EAAG3vB,GAAG,QAAQA,GAAGA,EAAEoqB,WAAWgD,CAAC,CAAC,SAASwC,EAAG5vB,GAAG,OAAO2vB,EAAG3vB,IAAIA,EAAElO,OAAO,UAAC,CAAC,SAAS+9B,EAAG7vB,GAAG,OAAO2vB,EAAG3vB,GAAG,eAAEN,MAAM,KAAK9B,WAAWoC,CAAC,CAAC,SAAS8vB,EAAG9vB,GAAG,QAAQA,EAAE8qB,OAAM,YAAE,KAAK9qB,IAAG,EAAG,CAAC,SAAS+vB,EAAG/vB,GAAG,OAAOA,IAAIA,EAAEgwB,MAAM,IAAIhwB,EAAE0sB,UAAU1sB,IAAI,IAAI,CAAC,IAAIiwB,EAAG,SAASjwB,EAAEnF,GAAG,OAAOmF,EAAEnF,EAAE,EAAEq1B,EAAG,SAASlwB,EAAEnF,GAAG,OAAOmF,EAAEnF,EAAE,EAAEs1B,GAAG,WAAE,SAASC,GAAGpwB,GAAGA,GAAG,CAAC,SAASqwB,GAAGrwB,GAAG,OAAOA,CAAC,CAAC,SAASswB,KAAK,MAAM,EAAC,EAAGF,GAAG,CAAC,IAAIG,GAAG,kBAAEC,GAAGb,EAAG,SAASc,GAAGzwB,EAAEnF,GAAG,IAAIxI,EAAEwI,IAAIC,GAAE,cAAE,CAAC41B,EAAE,CAAC9F,GAAGv4B,EAAEutB,EAAE/kB,KAAKoF,EAAEnF,EAAE,GAAG41B,EAAEn2B,EAAEO,EAAE,GAAG,OAAO,sBAAE,WAAWmF,EAAE2qB,GAAGv4B,EAAE4N,EAAE2f,EAAE/kB,EAAE81B,GAAG1wB,IAAI1F,EAAE,CAACm2B,EAAEzwB,GAAG,GAAE,CAACD,EAAE3N,EAAEwI,KAAI,gBAAE,WAAW,OAAO81B,GAAG1wB,IAAI1F,EAAE,CAACm2B,EAAEzwB,IAAID,GAAE,WAAW2wB,GAAG1wB,IAAI1F,EAAE,CAACm2B,EAAEzwB,GAAG,GAAE,GAAE,CAACD,IAAI3N,CAAC,CAAC,SAASs+B,GAAG3wB,GAAG,IAAInF,EAAExI,EAAEyI,EAAEkF,EAAE4f,EAAE3f,EAAED,EAAE4qB,GAAG,IAAI,IAAIrwB,EAAEO,IAAI,SAASD,EAAEoF,MAAM5N,EAAEkI,KAAK,IAAIM,GAAG,EAAEA,GAAG,EAAExI,IAAIwI,GAAGA,GAAGxI,GAAGA,EAAE,CAAC,MAAM2N,GAAG,OAAM,CAAE,CAAC,CAAC,IAAI4wB,GAAG,CAAC9a,SAAS,WAAE+a,MAAM,QAAE9K,WAAW,aAAE5P,UAAU,YAAE2a,gBAAgB,kBAAEC,mBAAmBR,GAAGS,cAAcV,GAAGW,iBAAiBZ,GAAGa,qBAAqBT,GAAGU,gBAAgBf,GAAGrL,OAAO,SAAEqM,oBAAoB,sBAAEvtB,QAAQ,UAAET,YAAY,cAAEgU,WAAW,aAAEia,cAAc,gBAAEC,QAAQ,SAASC,SAAShH,EAAEF,OAAOqD,EAAE8D,QAAQ5D,EAAE6D,uBAAuB3B,EAAG4B,aAAa3E,EAAEb,cAAc,gBAAEjV,cAAc,gBAAE0a,cAAcjC,EAAGkC,aAAa/B,EAAGja,UAAU,YAAEic,SAAS,WAAEC,eAAenC,EAAGoC,UAAUvB,GAAGwB,WAAWpC,EAAGqC,YAAYlC,EAAGmC,UAAU,YAAEC,cAAc3I,EAAE4I,KAAK3I,EAAE4I,WAAWlI,EAAEmI,UAAUpC,EAAGqC,wBAAwBtC,EAAGuC,WAAWrC,GAAGsC,SAASlH,EAAEmH,aAAa9G,EAAE+G,KAAKhH,EAAEiH,mDAAmDvD,wEC6B12R,MAAMwD,EAAQ,CACnBhhC,KAAM,CACJ,GC/BJ,qcDiCEihC,QAAS,CACP,GElCJ,4SFoCEC,SAAU,CACR,GGrCJ,2QHuCEC,eAAgB,CACd,GIxCJ,8iBJyCI,GKzCJ,mmBL2CE/rB,OAAQ,CACN,GM5CJ,6eN8CEgsB,YAAa,CACX,EO/CJ,6bPgDI,GQhDJ,0cRkDEC,aAAc,CACZ,ESnDJ,sbToDI,GUpDJ,mbVsDEC,MAAO,CACL,EWvDJ,ykBXwDI,GYxDJ,olBZ0DEC,QAAS,CACP,Ga3DJ,mhBb6DEtrB,QAAS,CACP,Gc9DJ,w3BdgEEia,KAAM,CACJ,GejEJ,offmEEnX,OAAQ,CACN,GgBpEJ,gtBhBsEEyoB,SAAU,CACR,GiBvEJ,2sBjByEEn9B,MAAO,CACL,GkB1EJ,mhBlB4EEo9B,UAAW,CACT,GmB7EJ,0uBnB+EEC,WAAY,CACV,GoBhFJ,gvBpBkFEC,MAAO,CACL,GqBnFJ,8WrBoFI,GsBpFJ,6XtB0GA,EAXa,EAAGthC,OAAM2sB,OAAO,KAAMzC,YAAW0C,UAC5C,iCACE,8BACc,OACZ1C,UAAWA,IAAa,OAAY,QACpCqX,wBAAyB,CAAEC,OAAQb,EAAM3gC,GAAM2sB,MAEhDC,IAAO,iBAAM1C,WAAW,OAAY,mBAAkB,SAAG0C,oCuB7FjD,IAAIwK,EAAE,EAAQ,KAA4EqK,EAAE,mBAAoBliC,OAAOmiC,GAAGniC,OAAOmiC,GAA1G,SAAW1zB,EAAE2T,GAAG,OAAO3T,IAAI2T,IAAI,IAAI3T,GAAG,EAAEA,GAAI,EAAE2T,IAAI3T,GAAIA,GAAG2T,GAAIA,CAAC,EAAiD6Z,EAAEpE,EAAE4H,qBAAqBp2B,EAAEwuB,EAAEvE,OAAOlqB,EAAEyuB,EAAEnT,UAAUlW,EAAEqpB,EAAEzlB,QAAQ+b,EAAE0J,EAAE+H,cACrN5U,EAAQoX,iCAAiC,SAAS3zB,EAAE2T,EAAExhB,EAAE0N,EAAE2wB,GAAG,IAAInU,EAAEzhB,EAAE,MAAM,GAAG,OAAOyhB,EAAElG,QAAQ,CAAC,IAAIlW,EAAE,CAAC2zB,UAAS,EAAGl7B,MAAM,MAAM2jB,EAAElG,QAAQlW,CAAC,MAAMA,EAAEoc,EAAElG,QAAQkG,EAAEtc,GAAE,WAAW,SAASC,EAAEA,GAAG,IAAIqc,EAAE,CAAiB,GAAhBA,GAAE,EAAGwX,EAAE7zB,EAAEA,EAAEH,EAAEG,QAAM,IAASwwB,GAAGvwB,EAAE2zB,SAAS,CAAC,IAAIjgB,EAAE1T,EAAEvH,MAAM,GAAG83B,EAAE7c,EAAE3T,GAAG,OAAOoqB,EAAEzW,CAAC,CAAC,OAAOyW,EAAEpqB,CAAC,CAAK,GAAJ2T,EAAEyW,EAAKqJ,EAAEI,EAAE7zB,GAAG,OAAO2T,EAAE,IAAIxhB,EAAE0N,EAAEG,GAAG,YAAG,IAASwwB,GAAGA,EAAE7c,EAAExhB,GAAUwhB,GAAEkgB,EAAE7zB,EAASoqB,EAAEj4B,EAAC,CAAC,IAAS0hC,EAAEzJ,EAAP/N,GAAE,EAAOhR,OAAE,IAASlZ,EAAE,KAAKA,EAAE,MAAM,CAAC,WAAW,OAAO6N,EAAE2T,IAAI,EAAE,OAAOtI,OAAE,EAAO,WAAW,OAAOrL,EAAEqL,IAAI,EAAE,GAAE,CAACsI,EAAExhB,EAAE0N,EAAE2wB,IAAI,IAAIqD,EAAErG,EAAExtB,EAAEqc,EAAE,GAAGA,EAAE,IACnc,OAAhD1hB,GAAE,WAAWsF,EAAE2zB,UAAS,EAAG3zB,EAAEvH,MAAMm7B,CAAC,GAAE,CAACA,IAAInU,EAAEmU,GAAUA,CAAC,+BCRtDvX,EAAOC,QAAU,EAAjB,6BCHFD,EAAOC,QAAUuX,QAAQ,iCCAzBxX,EAAOC,QAAUuX,QAAQ,wCCAzBxX,EAAOC,QAAUuX,QAAQ,sCCAzBxX,EAAOC,QAAUuX,QAAQ,6GCCzB,IAAIC,EAAUz5B,OAAO0vB,IAAI,iBACrBgK,EAAY15B,OAAO0vB,IAAI,mBACvBiK,EAAc35B,OAAO0vB,IAAI,eAkC7B,SAASkK,EAAIl+B,KAAUsG,GAMrB,MAAM,IAAIS,MACR,8BAA8B/G,2CAElC,CAGA,IAAIslB,EAAiB/pB,OAAO+pB,eAC5B,SAAS6Y,EAAQz7B,GACf,QAASA,KAAWA,EAAMu7B,EAC5B,CACA,SAASG,EAAY17B,GACnB,QAAKA,IAEE,EAAcA,IAAUyB,MAAM6B,QAAQtD,MAAYA,EAAMs7B,MAAgBt7B,EAAM8B,cAAcw5B,IAAcK,EAAM37B,IAAU47B,EAAM57B,GACzI,CACA,IAAI67B,EAAmBhjC,OAAOkJ,UAAUD,YAAYyE,WACpD,SAAS,EAAcvG,GACrB,IAAKA,GAA0B,iBAAVA,EACnB,OAAO,EACT,MAAM87B,EAAQlZ,EAAe5iB,GAC7B,GAAc,OAAV87B,EACF,OAAO,EAET,MAAMC,EAAOljC,OAAO+N,eAAexE,KAAK05B,EAAO,gBAAkBA,EAAMh6B,YACvE,OAAIi6B,IAASljC,QAES,mBAARkjC,GAAsBC,SAASz1B,SAASnE,KAAK25B,KAAUF,CACvE,CAMA,SAASI,EAAKj5B,EAAKk5B,GACQ,IAArBC,EAAYn5B,GACdnK,OAAO2hB,QAAQxX,GAAKyF,SAAQ,EAAEtK,EAAK6B,MACjCk8B,EAAK/9B,EAAK6B,EAAOgD,EAAI,IAGvBA,EAAIyF,SAAQ,CAACoG,EAAOsf,IAAU+N,EAAK/N,EAAOtf,EAAO7L,IAErD,CACA,SAASm5B,EAAYC,GACnB,MAAMjgC,EAAQigC,EAAMb,GACpB,OAAOp/B,EAAQA,EAAMkgC,MAAQ56B,MAAM6B,QAAQ84B,GAAS,EAAgBT,EAAMS,GAAS,EAAcR,EAAMQ,GAAS,EAAc,CAChI,CACA,SAASE,EAAIF,EAAOG,GAClB,OAA8B,IAAvBJ,EAAYC,GAAyBA,EAAME,IAAIC,GAAQ1jC,OAAOkJ,UAAU6E,eAAexE,KAAKg6B,EAAOG,EAC5G,CAIA,SAASpgB,EAAIigB,EAAOI,EAAgBx8B,GAClC,MAAMiC,EAAIk6B,EAAYC,GACZ,IAANn6B,EACFm6B,EAAMjgB,IAAIqgB,EAAgBx8B,GACb,IAANiC,EACPm6B,EAAMK,IAAIz8B,GAEVo8B,EAAMI,GAAkBx8B,CAC5B,CAQA,SAAS27B,EAAMn5B,GACb,OAAOA,aAAkB6xB,GAC3B,CACA,SAASuH,EAAMp5B,GACb,OAAOA,aAAkBlM,GAC3B,CACA,SAASomC,EAAOvgC,GACd,OAAOA,EAAMwgC,OAASxgC,EAAMygC,KAC9B,CACA,SAASC,EAAYzF,EAAM0F,GACzB,GAAInB,EAAMvE,GACR,OAAO,IAAI/C,IAAI+C,GAEjB,GAAIwE,EAAMxE,GACR,OAAO,IAAI9gC,IAAI8gC,GAEjB,GAAI31B,MAAM6B,QAAQ8zB,GAChB,OAAO31B,MAAMM,UAAUkC,MAAM7B,KAAKg1B,GACpC,IAAK0F,GAAU,EAAc1F,GAAO,CAClC,IAAKxU,EAAewU,GAAO,CACzB,MAAMp0B,EAAsBnK,OAAOkkC,OAAO,MAC1C,OAAOlkC,OAAOC,OAAOkK,EAAKo0B,EAC5B,CACA,MAAO,IAAKA,EACd,CACA,MAAM4F,EAAcnkC,OAAO6P,0BAA0B0uB,UAC9C4F,EAAYzB,GACnB,IAAIl8B,EAAO49B,QAAQl1B,QAAQi1B,GAC3B,IAAK,IAAIz7B,EAAI,EAAGA,EAAIlC,EAAKC,OAAQiC,IAAK,CACpC,MAAMpD,EAAMkB,EAAKkC,GACX27B,EAAOF,EAAY7+B,IACH,IAAlB++B,EAAKr6B,WACPq6B,EAAKr6B,UAAW,EAChBq6B,EAAKt6B,cAAe,IAElBs6B,EAAKjhB,KAAOihB,EAAK/gB,OACnB6gB,EAAY7+B,GAAO,CACjByE,cAAc,EACdC,UAAU,EAEVF,WAAYu6B,EAAKv6B,WACjB3C,MAAOo3B,EAAKj5B,IAElB,CACA,OAAOtF,OAAOkkC,OAAOna,EAAewU,GAAO4F,EAC7C,CACA,SAASG,EAAOn6B,EAAKo6B,GAAO,GAC1B,OAAIC,EAASr6B,IAAQy4B,EAAQz4B,KAAS04B,EAAY14B,KAE9Cm5B,EAAYn5B,GAAO,IACrBA,EAAImZ,IAAMnZ,EAAIy5B,IAAMz5B,EAAIs6B,MAAQt6B,EAAIywB,OAAS8J,GAE/C1kC,OAAOskC,OAAOn6B,GACVo6B,GACFnB,EAAKj5B,GAAK,CAACqD,EAAMrG,IAAUm9B,EAAOn9B,GAAO,MANlCgD,CAQX,CACA,SAASu6B,IACP/B,EAAI,EACN,CACA,SAAS6B,EAASr6B,GAChB,OAAOnK,OAAOwkC,SAASr6B,EACzB,CAGA,IAcIw6B,EAdAC,EAAU,CAAC,EACf,SAASC,EAAUC,GACjB,MAAMC,EAASH,EAAQE,GAIvB,OAHKC,GACHpC,EAAI,GAECoC,CACT,CAQA,SAASC,IACP,OAAOL,CACT,CAYA,SAASM,EAAkBC,EAAOC,GAC5BA,IACFN,EAAU,WACVK,EAAME,SAAW,GACjBF,EAAMG,gBAAkB,GACxBH,EAAMI,eAAiBH,EAE3B,CACA,SAASI,EAAYL,GACnBM,EAAWN,GACXA,EAAMO,QAAQ71B,QAAQ81B,GACtBR,EAAMO,QAAU,IAClB,CACA,SAASD,EAAWN,GACdA,IAAUP,IACZA,EAAeO,EAAMS,QAEzB,CACA,SAASC,EAAWC,GAClB,OAAOlB,EA7BA,CACLc,QAAS,GACTE,QA2BgChB,EA1BhCmB,OA0B8CD,EAvB9CE,gBAAgB,EAChBC,mBAAoB,EAuBxB,CACA,SAASN,EAAYO,GACnB,MAAM3iC,EAAQ2iC,EAAMvD,GACA,IAAhBp/B,EAAMkgC,OAA4C,IAAhBlgC,EAAMkgC,MAC1ClgC,EAAM4iC,UAEN5iC,EAAM6iC,UAAW,CACrB,CAGA,SAASC,EAAcp4B,EAAQk3B,GAC7BA,EAAMc,mBAAqBd,EAAMO,QAAQh/B,OACzC,MAAM4/B,EAAYnB,EAAMO,QAAQ,GA2BhC,YA1B8B,IAAXz3B,GAAqBA,IAAWq4B,GAE7CA,EAAU3D,GAAa4D,YACzBf,EAAYL,GACZvC,EAAI,IAEFE,EAAY70B,KACdA,EAASu4B,EAASrB,EAAOl3B,GACpBk3B,EAAMS,SACTa,EAAYtB,EAAOl3B,IAEnBk3B,EAAME,UACRP,EAAU,WAAW4B,4BACnBJ,EAAU3D,GAAaqB,MACvB/1B,EACAk3B,EAAME,SACNF,EAAMG,kBAIVr3B,EAASu4B,EAASrB,EAAOmB,EAAW,IAEtCd,EAAYL,GACRA,EAAME,UACRF,EAAMI,eAAeJ,EAAME,SAAUF,EAAMG,iBAEtCr3B,IAAWw0B,EAAUx0B,OAAS,CACvC,CACA,SAASu4B,EAASG,EAAWv/B,EAAOw/B,GAClC,GAAInC,EAASr9B,GACX,OAAOA,EACT,MAAM7D,EAAQ6D,EAAMu7B,GACpB,IAAKp/B,EAOH,OANA8/B,EACEj8B,GACA,CAAC7B,EAAKshC,IAAeC,EAAiBH,EAAWpjC,EAAO6D,EAAO7B,EAAKshC,EAAYD,KAI3Ex/B,EAET,GAAI7D,EAAMwjC,SAAWJ,EACnB,OAAOv/B,EACT,IAAK7D,EAAMgjC,UAET,OADAE,EAAYE,EAAWpjC,EAAMygC,OAAO,GAC7BzgC,EAAMygC,MAEf,IAAKzgC,EAAMyjC,WAAY,CACrBzjC,EAAMyjC,YAAa,EACnBzjC,EAAMwjC,OAAOd,qBACb,MAAMh4B,EAAS1K,EAAMwgC,MACrB,IAAIkD,EAAah5B,EACbi5B,GAAS,EACO,IAAhB3jC,EAAMkgC,QACRwD,EAAa,IAAIvpC,IAAIuQ,GACrBA,EAAOy2B,QACPwC,GAAS,GAEX7D,EACE4D,GACA,CAAC1hC,EAAKshC,IAAeC,EAAiBH,EAAWpjC,EAAO0K,EAAQ1I,EAAKshC,EAAYD,EAAMM,KAEzFT,EAAYE,EAAW14B,GAAQ,GAC3B24B,GAAQD,EAAUtB,UACpBP,EAAU,WAAWqC,iBACnB5jC,EACAqjC,EACAD,EAAUtB,SACVsB,EAAUrB,gBAGhB,CACA,OAAO/hC,EAAMwgC,KACf,CACA,SAAS+C,EAAiBH,EAAWS,EAAaC,EAAc1D,EAAMkD,EAAYS,EAAUC,GAG1F,GAAI1E,EAAQgE,GAAa,CACvB,MAEMrkC,EAAMgkC,EAASG,EAAWE,EAFnBS,GAAYF,GAAqC,IAAtBA,EAAY3D,QACnDC,EAAI0D,EAAYI,UAAW7D,GAAQ2D,EAAS78B,OAAOk5B,QAAQ,GAG5D,GADApgB,EAAI8jB,EAAc1D,EAAMnhC,IACpBqgC,EAAQrgC,GAGV,OAFAmkC,EAAUX,gBAAiB,CAG/B,MAAWuB,GACTF,EAAaxD,IAAIgD,GAEnB,GAAI/D,EAAY+D,KAAgBpC,EAASoC,GAAa,CACpD,IAAKF,EAAUZ,OAAO0B,aAAed,EAAUV,mBAAqB,EAClE,OAEFO,EAASG,EAAWE,GACfO,GAAgBA,EAAYL,OAAOnB,SACtCa,EAAYE,EAAWE,EAC3B,CACF,CACA,SAASJ,EAAYtB,EAAO/9B,EAAOo9B,GAAO,IACnCW,EAAMS,SAAWT,EAAMY,OAAO0B,aAAetC,EAAMa,gBACtDzB,EAAOn9B,EAAOo9B,EAElB,CAuCA,IAAIkD,EAAc,CAChB,GAAArkB,CAAI9f,EAAOogC,GACT,GAAIA,IAAShB,EACX,OAAOp/B,EACT,MAAMqM,EAASk0B,EAAOvgC,GACtB,IAAKmgC,EAAI9zB,EAAQ+zB,GACf,OAwGN,SAA2BpgC,EAAOqM,EAAQ+zB,GACxC,MAAMW,EAAOqD,EAAuB/3B,EAAQ+zB,GAC5C,OAAOW,EAAO,UAAWA,EAAOA,EAAKl9B,MAGnCk9B,EAAKjhB,KAAK7Z,KAAKjG,EAAMqkC,aACnB,CACN,CA/GaC,CAAkBtkC,EAAOqM,EAAQ+zB,GAE1C,MAAMv8B,EAAQwI,EAAO+zB,GACrB,OAAIpgC,EAAMyjC,aAAelE,EAAY17B,GAC5BA,EAELA,IAAU0gC,EAAKvkC,EAAMygC,MAAOL,IAC9BoE,EAAYxkC,GACLA,EAAMwgC,MAAMJ,GAAQqE,EAAY5gC,EAAO7D,IAEzC6D,CACT,EACAs8B,IAAG,CAACngC,EAAOogC,IACFA,KAAQG,EAAOvgC,GAExB4L,QAAQ5L,GACC8gC,QAAQl1B,QAAQ20B,EAAOvgC,IAEhC,GAAAggB,CAAIhgB,EAAOogC,EAAMv8B,GACf,MAAMk9B,EAAOqD,EAAuB7D,EAAOvgC,GAAQogC,GACnD,GAAIW,GAAM/gB,IAER,OADA+gB,EAAK/gB,IAAI/Z,KAAKjG,EAAMqkC,OAAQxgC,IACrB,EAET,IAAK7D,EAAMgjC,UAAW,CACpB,MAAM0B,EAAWH,EAAKhE,EAAOvgC,GAAQogC,GAC/BuE,EAAeD,IAAWtF,GAChC,GAAIuF,GAAgBA,EAAalE,QAAU58B,EAGzC,OAFA7D,EAAMwgC,MAAMJ,GAAQv8B,EACpB7D,EAAMikC,UAAU7D,IAAQ,GACjB,EAET,KAzTMnP,EAyTCptB,MAzTE+gC,EAyTKF,GAvTH,IAANzT,GAAW,EAAIA,GAAM,EAAI2T,EAEzB3T,GAAMA,GAAK2T,GAAMA,UAqTgB,IAAV/gC,GAAoBs8B,EAAIngC,EAAMygC,MAAOL,IAC/D,OAAO,EACToE,EAAYxkC,GACZ6kC,EAAY7kC,EACd,CA7TJ,IAAYixB,EAAG2T,EA8TX,OAAI5kC,EAAMwgC,MAAMJ,KAAUv8B,SACf,IAAVA,GAAoBu8B,KAAQpgC,EAAMwgC,QACnC7Y,OAAOmd,MAAMjhC,IAAU8jB,OAAOmd,MAAM9kC,EAAMwgC,MAAMJ,MAEhDpgC,EAAMwgC,MAAMJ,GAAQv8B,EACpB7D,EAAMikC,UAAU7D,IAAQ,IAFf,CAIX,EACA2E,eAAc,CAAC/kC,EAAOogC,UACY,IAA5BmE,EAAKvkC,EAAMygC,MAAOL,IAAoBA,KAAQpgC,EAAMygC,OACtDzgC,EAAMikC,UAAU7D,IAAQ,EACxBoE,EAAYxkC,GACZ6kC,EAAY7kC,WAELA,EAAMikC,UAAU7D,GAErBpgC,EAAMwgC,cACDxgC,EAAMwgC,MAAMJ,IAEd,GAIT,wBAAAj0B,CAAyBnM,EAAOogC,GAC9B,MAAM4E,EAAQzE,EAAOvgC,GACf+gC,EAAOD,QAAQ30B,yBAAyB64B,EAAO5E,GACrD,OAAKW,EAEE,CACLr6B,UAAU,EACVD,aAA8B,IAAhBzG,EAAMkgC,OAAoC,WAATE,EAC/C55B,WAAYu6B,EAAKv6B,WACjB3C,MAAOmhC,EAAM5E,IALNW,CAOX,EACA,cAAAp6B,GACE04B,EAAI,GACN,EACA5Y,eAAezmB,GACNymB,EAAezmB,EAAMygC,OAE9B,cAAAwE,GACE5F,EAAI,GACN,GAEE6F,EAAa,CAAC,EAiBlB,SAASX,EAAK5B,EAAOvC,GACnB,MAAMpgC,EAAQ2iC,EAAMvD,GAEpB,OADep/B,EAAQugC,EAAOvgC,GAAS2iC,GACzBvC,EAChB,CASA,SAASgE,EAAuB/3B,EAAQ+zB,GACtC,KAAMA,KAAQ/zB,GACZ,OACF,IAAIszB,EAAQlZ,EAAepa,GAC3B,KAAOszB,GAAO,CACZ,MAAMoB,EAAOrkC,OAAOyP,yBAAyBwzB,EAAOS,GACpD,GAAIW,EACF,OAAOA,EACTpB,EAAQlZ,EAAekZ,EACzB,CAEF,CACA,SAASkF,EAAY7kC,GACdA,EAAMgjC,YACThjC,EAAMgjC,WAAY,EACdhjC,EAAMqiC,SACRwC,EAAY7kC,EAAMqiC,SAGxB,CACA,SAASmC,EAAYxkC,GACdA,EAAMwgC,QACTxgC,EAAMwgC,MAAQE,EACZ1gC,EAAMygC,MACNzgC,EAAMwjC,OAAOhB,OAAO2C,uBAG1B,CAkJA,SAASV,EAAY5gC,EAAOuhC,GAC1B,MAAMzC,EAAQnD,EAAM37B,GAAS09B,EAAU,UAAU8D,UAAUxhC,EAAOuhC,GAAU3F,EAAM57B,GAAS09B,EAAU,UAAU+D,UAAUzhC,EAAOuhC,GAxUlI,SAA0BnK,EAAMmK,GAC9B,MAAMj+B,EAAU7B,MAAM6B,QAAQ8zB,GACxBj7B,EAAQ,CACZkgC,MAAO/4B,EAAU,EAAgB,EAEjCq8B,OAAQ4B,EAASA,EAAO5B,OAAS9B,IAEjCsB,WAAW,EAEXS,YAAY,EAEZQ,UAAW,CAAC,EAEZ5B,QAAS+C,EAET3E,MAAOxF,EAEPoJ,OAAQ,KAGR7D,MAAO,KAEPoC,QAAS,KACT2C,WAAW,GAEb,IAAIl/B,EAASrG,EACTwlC,EAAQrB,EACRh9B,IACFd,EAAS,CAACrG,GACVwlC,EAAQN,GAEV,MAAM,OAAEO,EAAM,MAAEC,GAAUC,MAAMC,UAAUv/B,EAAQm/B,GAGlD,OAFAxlC,EAAMqkC,OAASqB,EACf1lC,EAAM4iC,QAAU6C,EACTC,CACT,CAqS4IG,CAAiBhiC,EAAOuhC,GAGlK,OAFcA,EAASA,EAAO5B,OAAS9B,KACjCS,QAAQh6B,KAAKw6B,GACZA,CACT,CAGA,SAASrhB,EAAQzd,GAGf,OAFKy7B,EAAQz7B,IACXw7B,EAAI,IACCyG,EAAYjiC,EACrB,CACA,SAASiiC,EAAYjiC,GACnB,IAAK07B,EAAY17B,IAAUq9B,EAASr9B,GAClC,OAAOA,EACT,MAAM7D,EAAQ6D,EAAMu7B,GACpB,IAAI2G,EACJ,GAAI/lC,EAAO,CACT,IAAKA,EAAMgjC,UACT,OAAOhjC,EAAMygC,MACfzgC,EAAMyjC,YAAa,EACnBsC,EAAOrF,EAAY78B,EAAO7D,EAAMwjC,OAAOhB,OAAO2C,sBAChD,MACEY,EAAOrF,EAAY78B,GAAO,GAQ5B,OANAi8B,EAAKiG,GAAM,CAAC/jC,EAAKshC,KACftjB,EAAI+lB,EAAM/jC,EAAK8jC,EAAYxC,GAAY,IAErCtjC,IACFA,EAAMyjC,YAAa,GAEdsC,CACT,CA3OAjG,EAAKqE,GAAa,CAACniC,EAAK44B,KACtBsK,EAAWljC,GAAO,WAEhB,OADA6G,UAAU,GAAKA,UAAU,GAAG,GACrB+xB,EAAGjwB,MAAMlB,KAAMZ,UACxB,CAAC,IAEHq8B,EAAWH,eAAiB,SAAS/kC,EAAOogC,GAG1C,OAAO8E,EAAWllB,IAAI/Z,KAAKwD,KAAMzJ,EAAOogC,OAAM,EAChD,EACA8E,EAAWllB,IAAM,SAAShgB,EAAOogC,EAAMv8B,GAGrC,OAAOsgC,EAAYnkB,IAAI/Z,KAAKwD,KAAMzJ,EAAM,GAAIogC,EAAMv8B,EAAO7D,EAAM,GACjE,EAqsBA,IAAIgmC,EAAQ,IAzpBC,MACX,WAAArgC,CAAYhK,GACV8N,KAAKy6B,aAAc,EACnBz6B,KAAK07B,uBAAwB,EAoB7B17B,KAAKw8B,QAAU,CAAChL,EAAMiL,EAAQrE,KAC5B,GAAoB,mBAAT5G,GAAyC,mBAAXiL,EAAuB,CAC9D,MAAMC,EAAcD,EACpBA,EAASjL,EACT,MAAMjhC,EAAOyP,KACb,OAAO,SAAwB28B,EAAQD,KAAgB1+B,GACrD,OAAOzN,EAAKisC,QAAQG,GAAQzD,GAAUuD,EAAOjgC,KAAKwD,KAAMk5B,KAAUl7B,IACpE,CACF,CAKA,IAAIiD,EACJ,GALsB,mBAAXw7B,GACT7G,EAAI,QACgB,IAAlBwC,GAAqD,mBAAlBA,GACrCxC,EAAI,GAEFE,EAAYtE,GAAO,CACrB,MAAM2G,EAAQU,EAAW74B,MACnBi8B,EAAQjB,EAAYxJ,OAAM,GAChC,IAAItsB,GAAW,EACf,IACEjE,EAASw7B,EAAOR,GAChB/2B,GAAW,CACb,CAAE,QACIA,EACFszB,EAAYL,GAEZM,EAAWN,EACf,CAEA,OADAD,EAAkBC,EAAOC,GAClBiB,EAAcp4B,EAAQk3B,EAC/B,CAAO,IAAK3G,GAAwB,iBAATA,EAAmB,CAQ5C,GAPAvwB,EAASw7B,EAAOjL,QACD,IAAXvwB,IACFA,EAASuwB,GACPvwB,IAAWw0B,IACbx0B,OAAS,GACPjB,KAAKy6B,aACPlD,EAAOt2B,GAAQ,GACbm3B,EAAe,CACjB,MAAMjD,EAAI,GACJyH,EAAK,GACX9E,EAAU,WAAW4B,4BAA4BlI,EAAMvwB,EAAQk0B,EAAGyH,GAClExE,EAAcjD,EAAGyH,EACnB,CACA,OAAO37B,CACT,CACE20B,EAAI,EAAQ,EAEhB51B,KAAK68B,mBAAqB,CAACrL,EAAMiL,KAC/B,GAAoB,mBAATjL,EACT,MAAO,CAACj7B,KAAUyH,IAASgC,KAAK68B,mBAAmBtmC,GAAQ2iC,GAAU1H,EAAK0H,KAAUl7B,KAEtF,IAAI8+B,EAASC,EAKb,MAAO,CAJQ/8B,KAAKw8B,QAAQhL,EAAMiL,GAAQ,CAACtH,EAAGyH,KAC5CE,EAAU3H,EACV4H,EAAiBH,CAAE,IAELE,EAASC,EAAe,EAER,kBAAvB7qC,GAAQ8qC,YACjBh9B,KAAKi9B,cAAc/qC,EAAO8qC,YACgB,kBAAjC9qC,GAAQgrC,sBACjBl9B,KAAKm9B,wBAAwBjrC,EAAOgrC,qBACxC,CACA,WAAAE,CAAY5L,GACLsE,EAAYtE,IACfoE,EAAI,GACFC,EAAQrE,KACVA,EAAO3Z,EAAQ2Z,IACjB,MAAM2G,EAAQU,EAAW74B,MACnBi8B,EAAQjB,EAAYxJ,OAAM,GAGhC,OAFAyK,EAAMtG,GAAamG,WAAY,EAC/BrD,EAAWN,GACJ8D,CACT,CACA,WAAAoB,CAAYnE,EAAOd,GACjB,MAAM7hC,EAAQ2iC,GAASA,EAAMvD,GACxBp/B,GAAUA,EAAMulC,WACnBlG,EAAI,GACN,MAAQmE,OAAQ5B,GAAU5hC,EAE1B,OADA2hC,EAAkBC,EAAOC,GAClBiB,OAAc,EAAQlB,EAC/B,CAMA,aAAA8E,CAAc7iC,GACZ4F,KAAKy6B,YAAcrgC,CACrB,CAMA,uBAAA+iC,CAAwB/iC,GACtB4F,KAAK07B,sBAAwBthC,CAC/B,CACA,YAAAkjC,CAAa9L,EAAMsL,GACjB,IAAInhC,EACJ,IAAKA,EAAImhC,EAAQpjC,OAAS,EAAGiC,GAAK,EAAGA,IAAK,CACxC,MAAM4hC,EAAQT,EAAQnhC,GACtB,GAA0B,IAAtB4hC,EAAM3D,KAAKlgC,QAA6B,YAAb6jC,EAAMC,GAAkB,CACrDhM,EAAO+L,EAAMnjC,MACb,KACF,CACF,CACIuB,GAAK,IACPmhC,EAAUA,EAAQz+B,MAAM1C,EAAI,IAE9B,MAAM8hC,EAAmB3F,EAAU,WAAW4F,cAC9C,OAAI7H,EAAQrE,GACHiM,EAAiBjM,EAAMsL,GAEzB98B,KAAKw8B,QACVhL,GACC0H,GAAUuE,EAAiBvE,EAAO4D,IAEvC,GA6gBEN,EAAUD,EAAMC,QACKD,EAAMM,mBAAmB36B,KAChDq6B,GAEkBA,EAAMU,cAAc/6B,KAAKq6B,GACfA,EAAMY,wBAAwBj7B,KAAKq6B,GAC9CA,EAAMe,aAAap7B,KAAKq6B,GACzBA,EAAMa,YAAYl7B,KAAKq6B,GACvBA,EAAMc,YAAYn7B,KAAKq6B,2BCloCrCoB,GAvCiC,KAAI3/B,KACvC,MAAM4/B,GAAkB,WAAyB5/B,GAC3C6/B,EAA2B5qC,OAAOC,QAAO,IAAI4qC,KACjD,MAAMC,EAAWH,KAAmBE,GAC9BE,EAAkB,CAAC5jC,KAAU6jC,IAASF,EAASlI,EAAQz7B,GAASyd,EAAQzd,GAASA,KAAU6jC,GAEjG,OADAhrC,OAAOC,OAAO8qC,EAAiBD,GACxBC,CAAe,GACrB,CACDE,UAAW,IAAML,GAEY,EAEHM,CAA+B,MAOjB,oBAAX3tC,QAA0BA,OAAO4tC,sCAAuC5tC,OAAO4tC,qCAOvE,oBAAX5tC,QAA0BA,OAAO6tC,8BAA+B7tC,OAAO6tC,6BAa7Ejd,GACfA,GAAwB,mBAAZA,EAAEkd,OAIvB,SAAStkC,EAAa1G,EAAMirC,GAC1B,SAASC,KAAiBxgC,GACxB,GAAIugC,EAAe,CACjB,IAAIE,EAAWF,KAAiBvgC,GAChC,IAAKygC,EACH,MAAM,IAAIhgC,MAA8CigC,GAAuB,IAEjF,MAAO,CACLprC,OACAkD,QAASioC,EAASjoC,WACf,SAAUioC,GAAY,CACvBr5B,KAAMq5B,EAASr5B,SAEd,UAAWq5B,GAAY,CACxB/mC,MAAO+mC,EAAS/mC,OAGtB,CACA,MAAO,CACLpE,OACAkD,QAASwH,EAAK,GAElB,CAIA,OAHAwgC,EAAc79B,SAAW,IAAM,GAAGrN,IAClCkrC,EAAclrC,KAAOA,EACrBkrC,EAAcF,MAASnqC,IAAW,QAASA,IAAWA,EAAOb,OAASA,EAC/DkrC,CACT,CAmFA,SAASG,EAAgBC,GACvB,OAAO9I,EAAY8I,GAAO,EAAgBA,GAAK,SAC1CA,CACP,CACA,SAASC,EAAQ9kC,EAAKxB,EAAKumC,GACzB,GAAI/kC,EAAI28B,IAAIn+B,GAAM,CAChB,IAAI6B,EAAQL,EAAIsc,IAAI9d,GAKpB,OAJIumC,EAAQC,SACV3kC,EAAQ0kC,EAAQC,OAAO3kC,EAAO7B,EAAKwB,GACnCA,EAAIwc,IAAIhe,EAAK6B,IAERA,CACT,CACA,IAAK0kC,EAAQE,OACX,MAAM,IAAIvgC,MAA8CigC,GAAuB,KACjF,MAAMO,EAAWH,EAAQE,OAAOzmC,EAAKwB,GAErC,OADAA,EAAIwc,IAAIhe,EAAK0mC,GACNA,CACT,CA/BcjjC,OAAOkjC,QAwdrB,SAASC,EAA8BC,GACrC,MAAMC,EAAa,CAAC,EACdC,EAAiB,GACvB,IAAIC,EACJ,MAAM7oC,EAAU,CACd,OAAAC,CAAQ6oC,EAAqBC,GAS3B,MAAMnsC,EAAsC,iBAAxBksC,EAAmCA,EAAsBA,EAAoBlsC,KACjG,IAAKA,EACH,MAAM,IAAImL,MAA8CigC,GAAuB,KAEjF,GAAIprC,KAAQ+rC,EACV,MAAM,IAAI5gC,MAA8CigC,GAAuB,KAGjF,OADAW,EAAW/rC,GAAQmsC,EACZ/oC,CACT,EACAoP,WAAU,CAAC45B,EAASD,KAMlBH,EAAe5gC,KAAK,CAClBghC,UACAD,YAEK/oC,GAETipC,eAAeF,IAMbF,EAAqBE,EACd/oC,IAIX,OADA0oC,EAAgB1oC,GACT,CAAC2oC,EAAYC,EAAgBC,EACtC,CA9K4B,oBAAX/uC,QAA0BA,OAAOsxB,uBAAwBtxB,OAAOsxB,sBA2OjF,IACI3N,GAAS,CAACkM,EAAO,MACnB,IAAI/Z,EAAK,GACL3K,EAAI0kB,EACR,KAAO1kB,KACL2K,GALc,mEAKoB,GAAhB6X,KAAKC,SAAgB,GAEzC,OAAO9X,CAAE,EAIPs5B,GAAU,CAACF,EAASvrC,IAClBwpC,EAAiB+B,GACZA,EAAQpB,MAAMnqC,GAEdurC,EAAQvrC,GAGnB,SAAS4R,MAAW85B,GAClB,OAAQ1rC,GACC0rC,EAAShyB,MAAM6xB,GAAYE,GAAQF,EAASvrC,IAEvD,CA2FA,IAAI2rC,GAAmB,CAAC,OAAQ,UAAW,QAAS,QAChDC,GAAkB,MACpB,WAAA7jC,CAAY1F,EAAS4O,GACnBpF,KAAKxJ,QAAUA,EACfwJ,KAAKoF,KAAOA,CACd,CAKA46B,OAEEC,GAAkB,MACpB,WAAA/jC,CAAY1F,EAAS4O,GACnBpF,KAAKxJ,QAAUA,EACfwJ,KAAKoF,KAAOA,CACd,CAKA46B,OAEEE,GAAsB9lC,IACxB,GAAqB,iBAAVA,GAAgC,OAAVA,EAAgB,CAC/C,MAAM+lC,EAAc,CAAC,EACrB,IAAK,MAAMC,KAAYN,GACU,iBAApB1lC,EAAMgmC,KACfD,EAAYC,GAAYhmC,EAAMgmC,IAGlC,OAAOD,CACT,CACA,MAAO,CACLnsC,QAAS0I,OAAOtC,GACjB,EAECtI,GAAmC,MACrC,SAASuuC,EAAkB7rC,EAAYC,EAAgB6U,GACrD,MAAMzS,EAAYmD,EAAaxF,EAAa,cAAc,CAACgC,EAAS8pC,EAAW5/B,EAAK0E,KAAS,CAC3F5O,UACA4O,KAAM,IACDA,GAAQ,CAAC,EACZ1E,MACA4/B,YACAC,cAAe,iBAGb3pC,EAAUoD,EAAaxF,EAAa,YAAY,CAAC8rC,EAAW5/B,EAAK0E,KAAS,CAC9E5O,aAAS,EACT4O,KAAM,IACDA,GAAQ,CAAC,EACZ1E,MACA4/B,YACAC,cAAe,eAGbv6B,EAAWhM,EAAaxF,EAAa,aAAa,CAACkD,EAAO4oC,EAAW5/B,EAAKlK,EAAS4O,KAAS,CAChG5O,UACAkB,OAAQ4R,GAAWA,EAAQk3B,gBAAkBN,IAAoBxoC,GAAS,YAC1E0N,KAAM,IACDA,GAAQ,CAAC,EACZ1E,MACA4/B,YACAG,oBAAqBjqC,EACrB+pC,cAAe,WACfG,QAAyB,eAAhBhpC,GAAOhE,KAChByB,UAA2B,mBAAhBuC,GAAOhE,UA0FtB,OAAOT,OAAOC,QAvFd,SAAuBwN,GACrB,MAAO,CAACjL,EAAU4F,EAAUrJ,KAC1B,MAAMsuC,EAAYh3B,GAASq3B,YAAcr3B,EAAQq3B,YAAYjgC,GAAOyT,KAC9DysB,EAAkB,IAAIC,gBAC5B,IAAIC,EACAC,EACJ,SAASC,EAAMC,GACbF,EAAcE,EACdL,EAAgBI,OAClB,CACA,MAAME,EAAUnf,iBACd,IAAIof,EACJ,IACE,IAAIC,EAAkB93B,GAASnU,YAAYuL,EAAK,CAC9CrF,WACArJ,UAKF,GAwFO,QADCoI,EA1FOgnC,IA2FiB,iBAAVhnC,GAA4C,mBAAfA,EAAM2rB,OA1FvDqb,QAAwBA,IAEF,IAApBA,GAA6BR,EAAgBS,OAAOX,QACtD,KAAM,CACJhtC,KAAM,iBACNM,QAAS,sDAGb,MAAMstC,EAAiB,IAAI/rC,SAAQ,CAACxD,EAAG+zB,KACrCgb,EAAe,KACbhb,EAAO,CACLpyB,KAAM,aACNM,QAAS+sC,GAAe,WACxB,EAEJH,EAAgBS,OAAOE,iBAAiB,QAAST,EAAa,IAEhErrC,EAASmB,EAAQ0pC,EAAW5/B,EAAK4I,GAASk4B,iBAAiB,CACzDlB,YACA5/B,OACC,CACDrF,WACArJ,YAEFmvC,QAAoB5rC,QAAQksC,KAAK,CAACH,EAAgB/rC,QAAQT,QAAQL,EAAeiM,EAAK,CACpFjL,WACA4F,WACArJ,QACAsuC,YACAe,OAAQT,EAAgBS,OACxBL,QACA7uC,gBAAiB,CAACiI,EAAOgL,IAChB,IAAI26B,GAAgB3lC,EAAOgL,GAEpCs8B,iBAAkB,CAACtnC,EAAOgL,IACjB,IAAI66B,GAAgB7lC,EAAOgL,MAElC2gB,MAAM9kB,IACR,GAAIA,aAAkB8+B,GACpB,MAAM9+B,EAER,OAAIA,aAAkBg/B,GACbppC,EAAUoK,EAAOzK,QAAS8pC,EAAW5/B,EAAKO,EAAOmE,MAEnDvO,EAAUoK,EAAQq/B,EAAW5/B,EAAI,KAE5C,CAAE,MAAO3M,GACPotC,EAAcptC,aAAegsC,GAAkB/5B,EAAS,KAAMs6B,EAAW5/B,EAAK3M,EAAIyC,QAASzC,EAAIqR,MAAQY,EAASjS,EAAKusC,EAAW5/B,EAClI,CAAE,QACIogC,GACFF,EAAgBS,OAAOM,oBAAoB,QAASb,EAExD,CAqCV,IAAoB1mC,EAhCV,OAJqBkP,IAAYA,EAAQs4B,4BAA8B57B,EAASs4B,MAAM6C,IAAgBA,EAAY/7B,KAAKjQ,WAErHM,EAAS0rC,GAEJA,CACT,CAlEgBpf,GAmEhB,OAAO9uB,OAAOC,OAAOguC,EAAS,CAC5BF,QACAV,YACA5/B,MACAmhC,OAAM,IACGX,EAAQnb,KAAK+b,KAEtB,CAEN,GACoC,CAClClrC,UACAoP,WACAnP,YACAkrC,QAASh8B,GAAQC,EAAUnP,GAC3BrC,cAEJ,CAEA,OADA6rC,EAAkBnC,UAAY,IAAMmC,EAC7BA,CACR,EAlIsC,GAmIvC,SAASyB,GAAa3tC,GACpB,GAAIA,EAAOiR,MAAQjR,EAAOiR,KAAKq7B,kBAC7B,MAAMtsC,EAAOqC,QAEf,GAAIrC,EAAOuD,MACT,MAAMvD,EAAOuD,MAEf,OAAOvD,EAAOqC,OAChB,CAMA,IAAIwrC,GAAmBhmC,OAAO0vB,IAAI,8BAUlC,SAASuW,GAAQ5jC,EAAO6jC,GACtB,MAAO,GAAG7jC,KAAS6jC,GACrB,CAsKA,SAASC,GAAapE,EAAU7nB,EAAaksB,EAAiBC,GAC5D,SAASC,EAAQC,KAAcvkC,GAC7B,IAAIwkC,EAAatsB,EAAYqsB,GAQ7B,YAP0B,IAAfC,GACLH,IACFG,EAAaJ,KAKVrE,EAASyE,KAAexkC,EACjC,CAEA,OADAskC,EAAQG,UAAY1E,EACbuE,CACT,CACA,IAAIlsC,GApLJ,UAA0B,SACxBssC,GACE,CAAC,GACH,MAAMC,EAAMD,GAAUE,aAAaZ,IACnC,OAAO,SAAsB14B,GAC3B,MAAM,KACJ5V,EAAI,YACJmvC,EAAcnvC,GACZ4V,EACJ,IAAK5V,EACH,MAAM,IAAI+K,MAA8CigC,GAAuB,KAOjF,MAAMroC,GAAwC,mBAArBiT,EAAQjT,SAA0BiT,EAAQjT,SAoKvE,WACE,SAASusC,EAAWnuC,EAAgBvC,GAClC,MAAO,CACL4wC,uBAAwB,aACxBruC,oBACGvC,EAEP,CAEA,OADA0wC,EAAW1E,UAAY,IAAM0E,EACtB,CACLnD,QAAQsD,GACC9vC,OAAOC,OAAO,CAGnB,CAAC6vC,EAAYrvC,MAAK,IAAIsK,IACb+kC,KAAe/kC,IAExB+kC,EAAYrvC,MAAO,CACnBovC,uBAAwB,YAG5BE,gBAAe,CAACC,EAASxD,KAChB,CACLqD,uBAAwB,qBACxBG,UACAxD,YAGJmD,aAEJ,CAlMgFM,IAA0B55B,EAAQjT,WAAa,CAAC,EACtH8sC,EAAelwC,OAAOwG,KAAKpD,GAC3B9D,EAAU,CACd6wC,wBAAyB,CAAC,EAC1BC,wBAAyB,CAAC,EAC1BC,eAAgB,CAAC,EACjBC,cAAe,IAEXC,EAAiB,CACrB,OAAA7sC,CAAQ6oC,EAAqBiE,GAC3B,MAAMnwC,EAAsC,iBAAxBksC,EAAmCA,EAAsBA,EAAoBlsC,KACjG,IAAKA,EACH,MAAM,IAAImL,MAA8CigC,GAAuB,KAEjF,GAAIprC,KAAQf,EAAQ8wC,wBAClB,MAAM,IAAI5kC,MAA8CigC,GAAuB,KAGjF,OADAnsC,EAAQ8wC,wBAAwB/vC,GAAQmwC,EACjCD,CACT,EACA19B,WAAU,CAAC45B,EAAS+D,KAClBlxC,EAAQgxC,cAAc7kC,KAAK,CACzBghC,UACAD,QAASgE,IAEJD,GAETE,aAAY,CAACC,EAAOnF,KAClBjsC,EAAQ+wC,eAAeK,GAASnF,EACzBgF,GAETI,kBAAiB,CAACD,EAAOF,KACvBlxC,EAAQ6wC,wBAAwBO,GAASF,EAClCD,IAgBX,SAASK,IAMP,MAAOptC,EAAgB,CAAC,EAAG6oC,EAAiB,GAAIC,GAAgE,mBAA1Bj2B,EAAQ7S,cAA+B0oC,EAA8B71B,EAAQ7S,eAAiB,CAAC6S,EAAQ7S,eACvLqtC,EAAoB,IACrBrtC,KACAlE,EAAQ8wC,yBAEb,OAxbN,SAAuBvwC,EAAcixC,GAMnC,IACI3B,GADC/C,EAAY2E,EAAqBC,GAA2B9E,GAkbjBzoC,IAC1C,IAAK,IAAI6B,KAAOurC,EACdptC,EAAQC,QAAQ4B,EAAKurC,EAAkBvrC,IAEzC,IAAK,IAAI2rC,KAAM3xC,EAAQgxC,cACrB7sC,EAAQoP,WAAWo+B,EAAGxE,QAASwE,EAAGzE,SAEpC,IAAK,IAAI1yB,KAAKuyB,EACZ5oC,EAAQoP,WAAWiH,EAAE2yB,QAAS3yB,EAAE0yB,SAE9BF,GACF7oC,EAAQipC,eAAeJ,EACzB,IA5bN,GAVoB,mBAUAzsC,EAClBsvC,EAAkB,IAAMzD,EAAgB7rC,SACnC,CACL,MAAMqxC,EAAqBxF,EAAgB7rC,GAC3CsvC,EAAkB,IAAM+B,CAC1B,CACA,SAAS1E,EAAQlpC,EAAQ6rC,IAAmBjuC,GAC1C,IAAIiwC,EAAe,CAAC/E,EAAWlrC,EAAOb,SAAU0wC,EAAoBxhC,QAAO,EACzEk9B,aACIA,EAAQvrC,KAAS4F,KAAI,EACzB0lC,QAASgE,KACLA,KAIN,OAHiD,IAA7CW,EAAa5hC,QAAQ6hC,KAASA,IAAI3qC,SACpC0qC,EAAe,CAACH,IAEXG,EAAa7mC,QAAO,CAAC+mC,EAAevB,KACzC,GAAIA,EAAa,CACf,GAAIlN,EAASyO,GAAgB,CAC3B,MACMrjC,EAAS8hC,EADDuB,EACoBnwC,GAClC,YAAe,IAAX8M,EACKqjC,EAEFrjC,CACT,CAAO,GAAK60B,EAAawO,GAUvB,OAAO,EAAiBA,GAAgBpL,GAC/B6J,EAAY7J,EAAO/kC,KAXW,CACvC,MAAM8M,EAAS8hC,EAAYuB,EAAenwC,GAC1C,QAAe,IAAX8M,EAAmB,CACrB,GAAsB,OAAlBqjC,EACF,OAAOA,EAET,MAAM,IAAI7lC,MAA8CigC,GAAuB,GACjF,CACA,OAAOz9B,CACT,CAKF,CACA,OAAOqjC,CAAa,GACnB/tC,EACL,CAEA,OADAkpC,EAAQ2C,gBAAkBA,EACnB3C,CACT,CAoYa8E,CAAcj7B,EAAQxW,aAc/B,CAtCAqwC,EAAatgC,SAAS2hC,IACpB,MAAMC,EAAoBpuC,EAASmuC,GAC7BE,EAAiB,CACrBF,cACAlxC,KAAM2uC,GAAQvuC,EAAM8wC,GACpBG,eAA4C,mBAArBr7B,EAAQjT,WA4KvC,SAA4CouC,GAC1C,MAAoD,eAA7CA,EAAkB3B,sBAC3B,CA5KU8B,CAAmCH,GAwJ7C,UAAuC,KACrCnxC,EAAI,YACJkxC,EAAW,eACXG,GACCE,EAAyBtyC,GAC1B,IAAIwwC,EACA+B,EACJ,GAAI,YAAaD,EAAyB,CACxC,GAAIF,IAaR,SAA4CF,GAC1C,MAAoD,uBAA7CA,EAAkB3B,sBAC3B,CAf2BiC,CAAmCF,GACxD,MAAM,IAAIpmC,MAA8CigC,GAAuB,KAEjFqE,EAAc8B,EAAwBpF,QACtCqF,EAAkBD,EAAwB5B,OAC5C,MACEF,EAAc8B,EAEhBtyC,EAAQoE,QAAQrD,EAAMyvC,GAAaa,kBAAkBY,EAAazB,GAAaW,aAAac,EAAaM,EAAkB9qC,EAAa1G,EAAMwxC,GAAmB9qC,EAAa1G,GAChL,CAtKQ0xC,CAA8BN,EAAgBD,EAAmBjB,GA6KzE,UAA0C,KACxClwC,EAAI,YACJkxC,GACCC,EAAmBlyC,EAASowC,GAC7B,IAAKA,EACH,MAAM,IAAIlkC,MAA8CigC,GAAuB,KAEjF,MAAM,eACJjqC,EAAc,UACdoC,EAAS,QACTD,EAAO,SACPoP,EAAQ,QACR+7B,EAAO,QACPz4B,GACEm7B,EACEQ,EAAQtC,EAAIrvC,EAAMmB,EAAgB6U,GACxC/W,EAAQmxC,aAAac,EAAaS,GAC9BpuC,GACFtE,EAAQoE,QAAQsuC,EAAMpuC,UAAWA,GAE/BD,GACFrE,EAAQoE,QAAQsuC,EAAMruC,QAASA,GAE7BoP,GACFzT,EAAQoE,QAAQsuC,EAAMj/B,SAAUA,GAE9B+7B,GACFxvC,EAAQuT,WAAWm/B,EAAMlD,QAASA,GAEpCxvC,EAAQqxC,kBAAkBY,EAAa,CACrC3tC,UAAWA,GAAaquC,GACxBtuC,QAASA,GAAWsuC,GACpBl/B,SAAUA,GAAYk/B,GACtBnD,QAASA,GAAWmD,IAExB,CAlNQC,CAAiCT,EAAgBD,EAAmBjB,EAAgBb,EAGtF,IA4BF,MAAMyC,EAAc7uC,GAAUA,EACxB8uC,EAAwC,IAAI5W,IAClD,IAAI6W,EACJ,SAAS7F,EAAQlpC,EAAOpC,GAGtB,OAFKmxC,IACHA,EAAWzB,KACNyB,EAAS/uC,EAAOpC,EACzB,CACA,SAASiuC,IAGP,OAFKkD,IACHA,EAAWzB,KACNyB,EAASlD,iBAClB,CACA,SAASmD,EAAkBC,EAAcnD,GAAW,GAClD,SAASoD,EAAYlvC,GACnB,IAAIisC,EAAajsC,EAAMivC,GAQvB,YAP0B,IAAfhD,GACLH,IACFG,EAAaJ,KAKVI,CACT,CACA,SAASkD,EAAaxvB,EAAckvB,GAClC,MAAMO,EAAgB9G,EAAQwG,EAAuBhD,EAAU,CAC7DrD,OAAQ,IAAsB,IAAI4G,UAEpC,OAAO/G,EAAQ8G,EAAezvB,EAAa,CACzC8oB,OAAQ,KACN,MAAMjlC,EAAM,CAAC,EACb,IAAK,MAAO4pC,EAAO5F,KAAa9qC,OAAO2hB,QAAQtL,EAAQu8B,WAAa,CAAC,GACnE9rC,EAAI4pC,GAASxB,GAAapE,EAAU7nB,EAAaksB,EAAiBC,GAEpE,OAAOtoC,CAAG,GAGhB,CACA,MAAO,CACL8oC,YAAa2C,EACbE,eACA,aAAIG,GACF,OAAOH,EAAaD,EACtB,EACAA,cAEJ,CACA,MAAMpnC,EAAQ,CACZ3K,OACA+rC,UACA1oC,QAASxE,EAAQ+wC,eACjBc,aAAc7xC,EAAQ6wC,wBACtBhB,qBACGmD,EAAkB1C,GACrB,UAAAiD,CAAWC,GACTlD,YAAamD,KACV9zC,GACD,CAAC,GACH,MAAM+zC,EAAiBD,GAAWnD,EAKlC,OAJAkD,EAAWG,OAAO,CAChBrD,YAAaoD,EACbxG,WACCvtC,GACI,IACFmM,KACAknC,EAAkBU,GAAgB,GAEzC,GAEF,OAAO5nC,CACT,CACF,CAgBkB8nC,GA4FlB,SAASjB,KACT,CAkXA,IA6GEhyC,OAAM,IACJD,OAEAmzC,GAAM,qBA6DNC,GAA6B/8B,IAC/B,IAAI,KACFhW,EAAI,cACJkrC,EAAa,QACbkB,EAAO,UACP4G,EAAS,OACTC,GACEj9B,EACJ,GAAIhW,EACFgzC,EAAYtsC,EAAa1G,GAAMgrC,WAC1B,GAAIE,EACTlrC,EAAOkrC,EAAclrC,KACrBgzC,EAAY9H,EAAcF,WACrB,GAAIoB,EACT4G,EAAY5G,OACP,IAAI4G,EAET,MAAM,IAAI7nC,MAA8CigC,GAAuB,KAGjF,MA/KmB,EAAC7+B,EAAM2mC,KAC1B,GAAoB,mBAAT3mC,EACT,MAAM,IAAIpB,MAA8CigC,GAAuB,IACjF,EA2KA+H,CAAeF,GACR,CACLD,YACAhzC,OACAizC,SACD,EAECG,GAAsBzzC,OAAOC,QAAQoW,IACvC,MAAM,KACJhW,EAAI,UACJgzC,EAAS,OACTC,GACEF,GAA0B/8B,GAY9B,MAVc,CACZhD,GAFS6N,KAGToyB,SACAjzC,OACAgzC,YACA1vC,QAAyB,IAAIlG,IAC7Bi2C,YAAa,KACX,MAAM,IAAIloC,MAA8CigC,GAAuB,IAAoC,EAG3G,GACX,CACDR,UAAW,IAAMwI,KAsBfE,GAAc3zC,OAAOC,OAAO8G,EAAa,GAAGosC,UAAY,CAC1DlI,UAAW,IAAM0I,KAGfC,IADoB7sC,EAAa,GAAGosC,gBACnBnzC,OAAOC,OAAO8G,EAAa,GAAGosC,aAAe,CAChElI,UAAW,IAAM2I,MA8RnB,SAASnI,GAAuB1U,GAC9B,MAAO,iCAAiCA,qDAAwDA,kFAClG,CAvEqBhuB,OAAO0vB,IAAI,2GCzlE5Bob,EAG2B,UAI3BC,EAAa/qC,OAAO0vB,IAAI,uBACxBsb,EAA2B,oBAAfC,WAA6BA,WAAa,CAG1D,EACA,SAASC,IACP,IAAKJ,EAAMruB,cACT,MAAO,CAAC,EACV,MAAM0uB,EAAaH,EAAGD,KAAgBC,EAAGD,GAA8B,IAAItY,KAC3E,IAAI2Y,EAAcD,EAAW9wB,IAAIywB,EAAMruB,eAUvC,OATK2uB,IACHA,EAAcN,EAAMruB,cAClB,MAKF0uB,EAAW5wB,IAAIuwB,EAAMruB,cAAe2uB,IAE/BA,CACT,CACA,IAAIC,EAAoCH,IAQxC,SAASI,EAAuB/0C,EAAU80C,GACxC,OAAO,WAOL,OANqBP,EAAMluB,WAAWrmB,EAOxC,CACF,CACA,IAAIg1C,EAAkCD,IAGlCjS,EAnBiB,KACnB,MAAM,IAAI52B,MAAM,wBAAwB,EAsBtC+oC,EAAc,CAAC9lC,EAAG2T,IAAM3T,IAAM2T,EAClC,SAASoyB,EAAmBl1C,EAAU80C,GACpC,MAAMK,EAAmBn1C,IAAY80C,EAAoBE,EAAkBD,EAAuB/0C,GAC5Fo1C,EAAe,CAAC5J,EAAU6J,EAAsB,CAAC,KACrD,MAAM,WAAEC,EAAaL,EAAW,cAAEM,EAAgB,CAAC,GAAqC,mBAAxBF,EAAqC,CAAEC,WAAYD,GAAwBA,GAcrI,MACJn2B,EAAK,aACLs2B,EAAY,eACZC,EAAc,eACdC,EAAc,sBACdC,GACER,IAEE1J,GADW8I,EAAMvgB,QAAO,GACNugB,EAAMliC,YAC5B,CACE,CAACm5B,EAASrqC,MAAM6C,GACGwnC,EAASxnC,IAmD5BwnC,EAASrqC,MACX,CAACqqC,EAAUkK,EAAgBH,EAAcG,kBAErCE,EAAgB9S,EACpB0S,EAAaK,aACb32B,EAAMpW,SACN2sC,GAAkBv2B,EAAMpW,SACxB2iC,EACA6J,GAGF,OADAf,EAAMjU,cAAcsV,GACbA,CAAa,EAKtB,OAHAl1C,OAAOC,OAAOy0C,EAAc,CAC1BzJ,UAAW,IAAMyJ,IAEZA,CACT,CACA,IAAI/vC,EAA8B6vC,IA64BlC,SAASY,EAAgB91C,EAAU80C,GACjC,MAAMK,EAAmBn1C,IAAY80C,EAAoBE,EAEvDD,EAAuB/0C,GAEnB+1C,EAAY,KAChB,MAAM,MAAE72B,GAAUi2B,IAClB,OAAOj2B,CAAK,EAKd,OAHAxe,OAAOC,OAAOo1C,EAAW,CACvBpK,UAAW,IAAMoK,IAEZA,CACT,CAv5ByBtsC,OAAO0vB,IAAI,iBACZ1vB,OAAO0vB,IAAI,gBACT1vB,OAAO0vB,IAAI,kBACR1vB,OAAO0vB,IAAI,qBACd1vB,OAAO0vB,IAAI,kBACX1vB,OAAO0vB,IAAI,kBACZ1vB,OAAO0vB,IAAI,iBACJ1vB,OAAO0vB,IAAI,wBACd1vB,OAAO0vB,IAAI,qBACd1vB,OAAO0vB,IAAI,kBACN1vB,OAAO0vB,IAAI,uBACpB1vB,OAAO0vB,IAAI,cACX1vB,OAAO0vB,IAAI,cACN1vB,OAAO0vB,IAAI,mBACT1vB,OAAO0vB,IAAI,0BAybH,oBAAXl7B,aAAqD,IAApBA,OAAOkX,eAAqE,IAAlClX,OAAOkX,SAASgmB,cACzEoZ,EAAMxU,gBAAkBwU,EAAMnvB,UA4ErD1kB,OAAOiK,eACFjK,OAAOs1C,oBACLt1C,OAAOqP,sBACJrP,OAAOyP,yBACjBzP,OAAO+pB,eACN/pB,OAAOkJ,UA+X7B,IAAIqsC,EAA2BH,IAG/B,SAASI,EAAmBl2C,EAAU80C,GACpC,MAAMiB,EAAY/1C,IAAY80C,EAAoBmB,EAAWH,EAAgB91C,GACvEm2C,EAAe,IACLJ,IACD7yC,SAKf,OAHAxC,OAAOC,OAAOw1C,EAAc,CAC1BxK,UAAW,IAAMwK,IAEZA,CACT,CACA,IA9gC6BvX,EA8gCzB3pB,EAA8BihC,IA9gCLtX,EAohCP,EAAAkE,iCAnhCpBA,EAAmClE,EAohCnB,oDC7kClB,SAASuN,EAAuB1U,GAC9B,MAAO,yBAAyBA,6CAAgDA,kFAClF,qCAGA,IAII2e,EAAe,IAAMxqB,KAAKC,SAASzd,SAAS,IAAInB,UAAU,GAAGP,MAAM,IAAIsB,KAAK,KAM5EqoC,EALc,CAChBC,KAAM,eAA+BF,MACrCG,QAAS,kBAAkCH,MAC3CI,qBAAsB,IAAM,+BAA+BJ,OAmQ7D,SAAS/hC,EAAgBvQ,GACvB,MAAM2yC,EAAc/1C,OAAOwG,KAAKpD,GAC1B4yC,EAAgB,CAAC,EACvB,IAAK,IAAIttC,EAAI,EAAGA,EAAIqtC,EAAYtvC,OAAQiC,IAAK,CAC3C,MAAMpD,EAAMywC,EAAYrtC,GAMK,mBAAlBtF,EAASkC,KAClB0wC,EAAc1wC,GAAOlC,EAASkC,GAElC,CACA,MAAM2wC,EAAmBj2C,OAAOwG,KAAKwvC,GACrC,IAIIE,EACJ,KApCF,SAA4B9yC,GAC1BpD,OAAOwG,KAAKpD,GAAUwM,SAAStK,IAC7B,MAAMknC,EAAUppC,EAASkC,GAIzB,QAA4B,IAHPknC,OAAQ,EAAQ,CACnCnsC,KAAMs1C,EAAoBC,OAG1B,MAAM,IAAIpqC,MAA8CigC,EAAuB,KAEjF,QAEO,IAFIe,OAAQ,EAAQ,CACzBnsC,KAAMs1C,EAAoBG,yBAE1B,MAAM,IAAItqC,MAA8CigC,EAAuB,IACjF,GAEJ,CAsBI0K,CAAmBH,EACrB,CAAE,MAAOp1C,GACPs1C,EAAsBt1C,CACxB,CACA,OAAO,SAAqB0C,EAAQ,CAAC,EAAGpC,GACtC,GAAIg1C,EACF,MAAMA,EAQR,IAAIE,GAAa,EACjB,MAAMC,EAAY,CAAC,EACnB,IAAK,IAAI3tC,EAAI,EAAGA,EAAIutC,EAAiBxvC,OAAQiC,IAAK,CAChD,MAAMpD,EAAM2wC,EAAiBvtC,GACvB8jC,EAAUwJ,EAAc1wC,GACxBgxC,EAAsBhzC,EAAMgC,GAC5BixC,EAAkB/J,EAAQ8J,EAAqBp1C,GACrD,QAA+B,IAApBq1C,EAET,MADmBr1C,GAAUA,EAAOb,KAC9B,IAAImL,MAA8CigC,EAAuB,KAEjF4K,EAAU/wC,GAAOixC,EACjBH,EAAaA,GAAcG,IAAoBD,CACjD,CAEA,OADAF,EAAaA,GAAcH,EAAiBxvC,SAAWzG,OAAOwG,KAAKlD,GAAOmD,OACnE2vC,EAAaC,EAAY/yC,CAClC,CACF,CA0BA,SAASkzC,KAAWC,GAClB,OAAqB,IAAjBA,EAAMhwC,OACAgH,GAAQA,EAEG,IAAjBgpC,EAAMhwC,OACDgwC,EAAM,GAERA,EAAMnsC,QAAO,CAACmE,EAAG2T,IAAM,IAAIrX,IAAS0D,EAAE2T,KAAKrX,KACpD,CAuBA,SAAS2rC,EAASx1C,GAChB,OA5WF,SAAuBiJ,GACrB,GAAmB,iBAARA,GAA4B,OAARA,EAC7B,OAAO,EACT,IAAI84B,EAAQ94B,EACZ,KAAwC,OAAjCnK,OAAO+pB,eAAekZ,IAC3BA,EAAQjjC,OAAO+pB,eAAekZ,GAEhC,OAAOjjC,OAAO+pB,eAAe5f,KAAS84B,GAAwC,OAA/BjjC,OAAO+pB,eAAe5f,EACvE,CAoWSwsC,CAAcz1C,IAAW,SAAUA,GAAiC,iBAAhBA,EAAOb,IACpE,mEC/SA,IAAIu2C,EAAiBC,GACZjuC,MAAM6B,QAAQosC,GAAQA,EAAO,CAACA,GAsJf9tC,SAEZ/I,OAAO+pB,eAAe,CAAC,GAiSnC,IAQI+sB,EAAyB,oBAAZC,QAA0BA,QAR3B,MACd,WAAA9tC,CAAY9B,GACV4F,KAAK5F,MAAQA,CACf,CACA,KAAA6vC,GACE,OAAOjqC,KAAK5F,KACd,GAGE8vC,EAAe,EACfC,EAAa,EACjB,SAASC,IACP,MAAO,CACLzqB,EAAGuqB,EACH9oB,OAAG,EACHrlB,EAAG,KACHo5B,EAAG,KAEP,CACA,SAASkV,EAAexqC,EAAMyJ,EAAU,CAAC,GACvC,IAAIghC,EAASF,IACb,MAAM,oBAAEG,GAAwBjhC,EAChC,IAAIkhC,EACAC,EAAe,EACnB,SAASC,IACP,IAAIC,EAAYL,EAChB,MAAM,OAAE5wC,GAAW0F,UACnB,IAAK,IAAIzD,EAAI,EAAG4F,EAAI7H,EAAQiC,EAAI4F,EAAG5F,IAAK,CACtC,MAAM+E,EAAMtB,UAAUzD,GACtB,GAAmB,mBAAR+E,GAAqC,iBAARA,GAA4B,OAARA,EAAc,CACxE,IAAIkqC,EAAcD,EAAU5uC,EACR,OAAhB6uC,IACFD,EAAU5uC,EAAI6uC,EAA8B,IAAIhF,SAElD,MAAMiF,EAAaD,EAAYv0B,IAAI3V,QAChB,IAAfmqC,GACFF,EAAYP,IACZQ,EAAYr0B,IAAI7V,EAAKiqC,IAErBA,EAAYE,CAEhB,KAAO,CACL,IAAIC,EAAiBH,EAAUxV,EACR,OAAnB2V,IACFH,EAAUxV,EAAI2V,EAAiC,IAAIrc,KAErD,MAAMsc,EAAgBD,EAAez0B,IAAI3V,QACnB,IAAlBqqC,GACFJ,EAAYP,IACZU,EAAev0B,IAAI7V,EAAKiqC,IAExBA,EAAYI,CAEhB,CACF,CACA,MAAMC,EAAiBL,EACvB,IAAI1pC,EAQJ,GAPI0pC,EAAUhrB,IAAMwqB,EAClBlpC,EAAS0pC,EAAUvpB,GAEnBngB,EAASpB,EAAKqB,MAAM,KAAM9B,WAC1BqrC,KAEFO,EAAerrB,EAAIwqB,EACfI,EAAqB,CACvB,MAAMU,EAAkBT,GAAYP,WAAaO,EAC1B,MAAnBS,GAA2BV,EAAoBU,EAAiBhqC,KAClEA,EAASgqC,EACQ,IAAjBR,GAAsBA,KAGxBD,EADuC,iBAAXvpC,GAAkC,OAAXA,GAAqC,mBAAXA,EACjD,IAAI8oC,EAAI9oC,GAAUA,CAChD,CAEA,OADA+pC,EAAe5pB,EAAIngB,EACZA,CACT,CASA,OARAypC,EAASQ,WAAa,KACpBZ,EAASF,IACTM,EAASS,mBAAmB,EAE9BT,EAASD,aAAe,IAAMA,EAC9BC,EAASS,kBAAoB,KAC3BV,EAAe,CAAC,EAEXC,CACT,CAGA,SAASU,EAAsBC,KAAqBC,GAClD,MAAMC,EAA2D,mBAArBF,EAAkC,CAC5EG,QAASH,EACTI,eAAgBH,GACdD,EACEzN,EAAkB,IAAI8N,KAC1B,IAEIlB,EAFAmB,EAAiB,EACjBC,EAA2B,EAE3BC,EAAwB,CAAC,EACzBC,EAAaJ,EAAmBle,MACV,iBAAfse,IACTD,EAAwBC,EACxBA,EAAaJ,EAAmBle,OAjjBtC,SAA0B3tB,EAAMksC,EAAe,gDAAgDlsC,GAC7F,GAAoB,mBAATA,EACT,MAAM,IAAIpD,UAAUsvC,EAExB,CA+iBIC,CACEF,EACA,qFAAqFA,MAEvF,MAAMG,EAAkB,IACnBV,KACAM,IAEC,QACJL,EAAO,eACPC,EAAiB,GAAE,YACnBS,EAAc7B,EAAc,mBAC5B8B,EAAqB,GAAE,cACvBrE,EAAgB,CAAC,GACfmE,EACEG,EAAsBvC,EAAc4B,GACpCY,EAA0BxC,EAAcsC,GACxCG,EA/iBV,SAAyBZ,GACvB,MAAMY,EAAezwC,MAAM6B,QAAQguC,EAAmB,IAAMA,EAAmB,GAAKA,EAKpF,OAjBF,SAAkCpuC,EAAOyuC,EAAe,8EACtD,IAAKzuC,EAAMqU,OAAOm4B,GAAyB,mBAATA,IAAsB,CACtD,MAAMyC,EAAYjvC,EAAMvD,KACrB+vC,GAAyB,mBAATA,EAAsB,YAAYA,EAAKp2C,MAAQ,qBAAuBo2C,IACvFvpC,KAAK,MACP,MAAM,IAAI9D,UAAU,GAAGsvC,KAAgBQ,KACzC,CACF,CAMEC,CACEF,EACA,kGAEKA,CACT,CAwiByBG,CAAgBf,GAC/BgB,EAAqBlB,GAAQ,WAEjC,OADAG,IACOG,EAAW5qC,MAChB,KACA9B,UAEJ,MAAMgtC,GAEArO,EAAWmO,GAAY,WAC3BN,IACA,MAAMe,EAljBZ,SAAqCL,EAAcM,GACjD,MAAMD,EAAuB,IACvB,OAAEjzC,GAAW4yC,EACnB,IAAK,IAAI3wC,EAAI,EAAGA,EAAIjC,EAAQiC,IAC1BgxC,EAAqBjuC,KAAK4tC,EAAa3wC,GAAGuF,MAAM,KAAM0rC,IAExD,OAAOD,CACT,CA2iBmCE,CAC3BP,EACAltC,WA0BF,OAxBAorC,EAAakC,EAAmBxrC,MAAM,KAAMyrC,GAwBrCnC,CACT,MAAM6B,GACN,OAAOp5C,OAAOC,OAAO6qC,EAAU,CAC7B+N,aACAY,qBACAJ,eACAV,yBAA0B,IAAMA,EAChCkB,8BAA+B,KAC7BlB,EAA2B,CAAC,EAE9BpB,WAAY,IAAMA,EAClBmB,eAAgB,IAAMA,EACtBoB,oBAAqB,KACnBpB,EAAiB,CAAC,EAEpBH,UACAU,eACA,EAKJ,OAHAj5C,OAAOC,OAAO0qC,EAAiB,CAC7BM,UAAW,IAAMN,IAEZA,CACT,CACA,IAAI5nC,EAAiCo1C,EAAsBf,GAGvD2C,EAA2B/5C,OAAOC,QACpC,CAAC+5C,EAAsBC,EAAkBl3C,MAloB3C,SAAwBoM,EAAQ2pC,EAAe,+CAA+C3pC,GAC5F,GAAsB,iBAAXA,EACT,MAAM,IAAI3F,UAAUsvC,EAExB,CA+nBIoB,CACEF,EACA,gIAAgIA,GAElI,MAAMG,EAAoBn6C,OAAOwG,KAAKwzC,GAatC,OAT2BC,EAHNE,EAAkBrzC,KACpCxB,GAAQ00C,EAAqB10C,MAI9B,IAAIo0C,IACKA,EAAqBpvC,QAAO,CAAC8vC,EAAajzC,EAAOmuB,KACtD8kB,EAAYD,EAAkB7kB,IAAUnuB,EACjCizC,IACN,CAAC,IAGiB,GAE3B,CAAEnP,UAAW,IAAM8O,MCztBjBM,EAA2B,CAAC,EAGhC,SAASC,EAAoBC,GAE5B,IAAIC,EAAeH,EAAyBE,GAC5C,QAAqB55C,IAAjB65C,EACH,OAAOA,EAAaxvB,QAGrB,IAAID,EAASsvB,EAAyBE,GAAY,CAGjDvvB,QAAS,CAAC,GAOX,OAHAyvB,EAAoBF,GAAUxvB,EAAQA,EAAOC,QAASsvB,GAG/CvvB,EAAOC,OACf,CCrBAsvB,EAAoB/rC,EAAKwc,IACxB,IAAI2vB,EAAS3vB,GAAUA,EAAO4vB,WAC7B,IAAO5vB,EAAiB,QACxB,IAAM,EAEP,OADAuvB,EAAoBhY,EAAEoY,EAAQ,CAAEjsC,EAAGisC,IAC5BA,CAAM,ECLdJ,EAAoBhY,EAAI,CAACtX,EAAS4vB,KACjC,IAAI,IAAIt1C,KAAOs1C,EACXN,EAAoBxxC,EAAE8xC,EAAYt1C,KAASg1C,EAAoBxxC,EAAEkiB,EAAS1lB,IAC5EtF,OAAOiK,eAAe+gB,EAAS1lB,EAAK,CAAEwE,YAAY,EAAMsZ,IAAKw3B,EAAWt1C,IAE1E,ECNDg1C,EAAoBziB,EAAI,WACvB,GAA0B,iBAAfmc,WAAyB,OAAOA,WAC3C,IACC,OAAOjnC,MAAQ,IAAIo2B,SAAS,cAAb,EAChB,CAAE,MAAOviC,GACR,GAAsB,iBAAXrD,OAAqB,OAAOA,MACxC,CACA,CAPuB,GCAxB+8C,EAAoBxxC,EAAI,CAACqB,EAAKu5B,IAAU1jC,OAAOkJ,UAAU6E,eAAexE,KAAKY,EAAKu5B,GCClF4W,EAAoBjxC,EAAK2hB,IACH,oBAAXjiB,QAA0BA,OAAO8xC,aAC1C76C,OAAOiK,eAAe+gB,EAASjiB,OAAO8xC,YAAa,CAAE1zC,MAAO,WAE7DnH,OAAOiK,eAAe+gB,EAAS,aAAc,CAAE7jB,OAAO,GAAO,QCL9D,IAAI2zC,EACAR,EAAoBziB,EAAEkjB,gBAAeD,EAAYR,EAAoBziB,EAAEmjB,SAAW,IACtF,IAAIvmC,EAAW6lC,EAAoBziB,EAAEpjB,SACrC,IAAKqmC,GAAarmC,IACbA,EAASwmC,gBACZH,EAAYrmC,EAASwmC,cAAcntB,MAC/BgtB,GAAW,CACf,IAAII,EAAUzmC,EAAS0mC,qBAAqB,UAC5C,GAAGD,EAAQz0C,OAEV,IADA,IAAIiC,EAAIwyC,EAAQz0C,OAAS,EAClBiC,GAAK,IAAMoyC,GAAWA,EAAYI,EAAQxyC,KAAKolB,GAExD,CAID,IAAKgtB,EAAW,MAAM,IAAItvC,MAAM,yDAChCsvC,EAAYA,EAAU1d,QAAQ,OAAQ,IAAIA,QAAQ,QAAS,IAAIA,QAAQ,YAAa,KACpFkd,EAAoBpY,EAAI4Y,qSCdxB,MAmBA,EAnB0BM,KACxB,MAAM,EAAEhyC,IAAMsI,EAAAA,EAAAA,MACR,eAAEhM,IAAmBhB,EAAAA,EAAAA,MAE3B,OACEgB,IACEknB,EAAAA,EAAAA,MAAA,OAAKjC,WAAWA,EAAAA,EAAAA,GAAU,cAAe0wB,SAAS,IAAG7vB,SAAA,EACnD0B,EAAAA,EAAAA,KAAA,MAAIvC,WAAWA,EAAAA,EAAAA,GAAU,qBAAqBa,SAC3CpiB,EAAE,uBAEL8jB,EAAAA,EAAAA,KAAA,OACEvC,WAAWA,EAAAA,EAAAA,GAAU,uBACrBqX,wBAAyB,CAAEC,OAAQ74B,EAAE,2BAG1C,0FChBL,MAEakyC,GAAcv4C,EAAAA,EAAAA,IACzB,CAHeqF,EAAG+L,WAAuBA,EAG9B,CAACrV,GAAK0I,YAAqBA,IACtC,CAAC2M,EAAO3M,IAAW2M,EAAM3M,KAGrB+zC,GAA0Bx4C,EAAAA,EAAAA,IAC9Bu4C,GACCzzC,IAASA,aAAI,EAAJA,EAAMZ,WAAY,CAAC,IAGlBu0C,GAAwBz4C,EAAAA,EAAAA,IACnCw4C,GACCt0C,IACC,MAAMw0C,EAAY,CAAC,EAKnB,OAJAz7C,OAAO2hB,QAAQ1a,GAAU2I,SAAQ,EAAEtK,GAAO6B,aACxCs0C,EAAUn2C,GAAO6B,CAAK,IAGjBs0C,CAAS,IAIPC,GAAwB34C,EAAAA,EAAAA,IACnC,CAACw4C,EAAyB,CAACz8C,GAAK2B,UAAmBA,IACnD,CAACwG,EAAUxG,KAAQ,IAAApB,EAAC,OAAc,QAAdA,EAAA4H,EAASxG,UAAK,IAAApB,OAAA,EAAAA,EAAE8H,KAAK,IAG9Bw0C,GAA0B54C,EAAAA,EAAAA,IACrC,CAACw4C,EAAyB,CAACz8C,GAAK2B,UAAmBA,IACnD,CAACwG,EAAUxG,KAAQ,IAAApB,EAAC,OAAc,QAAdA,EAAA4H,EAASxG,UAAK,IAAApB,OAAA,EAAAA,EAAE+H,OAAO,4BC/B7C,MAAMw0C,GAAcp2B,EAAAA,EAAAA,eAA+B,CACjDq2B,aAAcA,KAAe,EAC7BC,aAAa,EACbC,SAAS,EACTj0C,mBAAoBA,KAAe,EACnCC,qBAAsBA,KAAe,EACrCi0C,YAAQr7C,IAGV,KACa,SAAEs7C,EAAQ,SAAEC,GAAaN,ECMhC,SAAUO,IACd,OAAOx2B,EAAAA,EAAAA,YAAWi2B,EACpB,CAuBM,SAAUQ,EAAe37C,GAS7B,MAAM+B,GAAW+R,EAAAA,EAAAA,OACX,OAAE/M,EAAM,mBAAEM,EAAkB,qBAAEC,EAAoB,OAAEi0C,GACxDG,IAEIE,KADO13C,EAAAA,EAAAA,KAAarB,GAAqBg4C,EAAYh4C,EAAO,CAAEkE,aAE9DL,GAAQxC,EAAAA,EAAAA,KAAarB,GAClBo4C,EAAsBp4C,EAAO,CAAEkE,SAAQ/G,WAG1C2G,GAAUzC,EAAAA,EAAAA,KAAarB,GAC3Bq4C,EAAwBr4C,EAAO,CAAEkE,SAAQ/G,WAErCgE,EAAQu3C,aAAM,EAANA,EAASv7C,GACjBs7C,GAAWt3C,GAEjBigB,EAAAA,EAAAA,YAAU,KAGJ23B,GACF75C,GAASmF,EAAAA,EAAAA,IAAgB,CAAEH,SAAQ/G,SACrC,GACC,CAAC47C,EAAc70C,EAAQ/G,EAAM+B,KAChC68B,EAAAA,EAAAA,kBAAgB,IACP,KACL78B,GAASoF,EAAAA,EAAAA,IAAkB,CAAEJ,SAAQ/G,SAAQ,GAE9C,CAAC47C,EAAc70C,EAAQ/G,EAAM+B,IAGhC,MAAM85C,GAAU3qC,EAAAA,EAAAA,cACb/Q,GAAMkH,EAAmBrH,EAAMG,EAAE+I,OAAOxC,QACzC,CAAC1G,EAAMqH,IAGHy0C,GAAS5qC,EAAAA,EAAAA,cAAY,KACzB5J,EAAqBtH,GAAM,EAAK,GAC/B,CAACsH,EAAsBtH,IAqB1B,MAAO,EAnBO2R,EAAAA,EAAAA,UACZ,KAAM,CACJ3R,OACA67C,UACAC,SACAp1C,WAEF,CAAC1G,EAAM67C,EAASC,EAAQp1C,KAGbiL,EAAAA,EAAAA,UACX,KAAM,CACJ2pC,UACAt3C,QACA2C,aAEF,CAAC20C,EAASt3C,EAAO2C,IAIrB,mCCjGM,SAAUo1C,EAAkBC,GAChC,MAAM,EAAErzC,IAAMsI,EAAAA,EAAAA,MACR,cAAE8d,IAAkBL,EAAAA,EAAAA,MACpB,SAAE3H,EAAQ,MAAEtb,IAAUob,EAAAA,EAAAA,MAEtBo1B,GAAyBtqC,EAAAA,EAAAA,UAC7B,KAAMwiB,EAAAA,EAAAA,IAASpF,EAAe1xB,EAAAA,KAC9B,CAAC0xB,IAEGmtB,GAAgBvqC,EAAAA,EAAAA,UAAQ,KACrBwiB,EAAAA,EAAAA,KAAS,CAACgoB,EAA0BC,KACrCD,GACFF,EACEtzC,EAAE,6BAA8B,CAAE8C,MAAO2wC,IAE7C,GACC/+C,EAAAA,KACF,CAAC4+C,EAAwBtzC,MAErB,MAAEjC,IAAWi1C,EAAeK,GAC7BK,EAAiBt1B,GAAYrgB,EAAQ+E,EAAQ/E,EAAMV,OAASyF,EAC5D6wC,IAA0Bv1B,GAC5Bs1B,GAAkBj/C,EAAAA,GAEhBm/C,IAAwBx1B,GAAWs1B,EAAiB,EAM1D,OAJAp4B,EAAAA,EAAAA,YAAU,KACRi4B,EAAcI,EAAyBD,EAAe,GACrD,CAACC,EAAyBD,EAAgBH,IAEtC,CACLM,kBAAmBz1B,EACnB01B,eAAgBhxC,EAChB6wC,0BACAC,wBACAF,iBAEJ,CAEO,MAAMK,EAA2BV,IACtC,MAAM,kBAAEQ,EAAiB,eAAEC,GAAmBV,EAAkBC,IAG9D3mC,WACEM,iBAAiB,KAAErB,MAEnB+Q,EAAAA,EAAAA,OAEE,EAAE1c,IAAMsI,EAAAA,EAAAA,KA2Bd,MAAO,CAAE0rC,aAzBmBhrC,EAAAA,EAAAA,UAC1B,IACEhJ,EAAE,yBAA0B,CAC1Boe,SAAUy1B,EACVloC,MAAMA,aAAI,EAAJA,EAAMqoC,cAAeh0C,EAAE,8BAC7B8C,MAAO+wC,EAAoBC,EAAiB,QAEhD,CAAC9zC,EAAG6zC,EAAmBC,EAAgBnoC,aAAI,EAAJA,EAAMqoC,cAkBzBC,OAfAjrC,EAAAA,EAAAA,UACpB,IACEhJ,EAAE,mBAAoB,CACpBoe,WAAWzS,aAAI,EAAJA,EAAMsoC,QAAQJ,EACzBloC,MAAMA,aAAI,EAAJA,EAAMsoC,QAASj0C,EAAE,wBACvB8C,QAAQ6I,aAAI,EAAJA,EAAMsoC,QAASJ,EAAoBC,EAAiB,QAEhE,CAAC9zC,EAAG6zC,EAAmBC,EAAgBnoC,aAAI,EAAJA,EAAMsoC,QAQlBC,YALVlrC,EAAAA,EAAAA,UACjB,KAAO2C,aAAI,EAAJA,EAAMsoC,OAAQ,QAAU,mBAC/B,CAACtoC,aAAI,EAAJA,EAAMsoC,QAGgC,ECpF5B,SAASE,IACtB,MAAM,iBAAEC,EAAgB,2BAAEC,GDsFYC,MACtC,MAAMl7C,GAAW+R,EAAAA,EAAAA,OAGfuB,WAAW,QAAEhS,EAAO,kBAAEqS,KACpB2P,EAAAA,EAAAA,MASJ,MAAO,CACL03B,kBAHArnC,aAAiB,EAAjBA,EAAmBqnC,oBAAoB15C,aAAO,EAAPA,EAAS05C,kBAIhDC,2BATiCA,KACjCj7C,GAAS6a,EAAAA,EAAAA,MAAwB,EASlC,ECtGCqgC,GACI1+C,GAAM,UAEZ,OAAKw+C,GAeH,eACE7yB,WAAW,OAAU,CACnB,0BACA,+CACA,UAEF,mBACEA,WAAW,OAAU,CACnB,SACA,oBACA,8BAEFtqB,KAAK,SACL4sB,QA1ByB,KAC7BjuB,EAAIoB,KAAK,SAAU,CACjBC,KAAM,KAAYE,SAClBC,KAAM,CACJC,KAAM+8C,EAAiBG,UACvBj9C,gBAAiB88C,EAAiBI,wBAItCH,GAA4B,EAiBO,SAE9BD,EAAiBH,UA9BM,IAkChC,CC1CA,MAEA,GAFyB73B,EAAAA,EAAAA,eAAc,CAAC,2BCGxC,MAkGA,EAlGsB,EACpBnS,KACAnS,SACAqR,aACAsrC,cACAC,WACA91B,QACA3V,QACA0rC,qBAEA,MAAMC,GAAU,IAAA1qB,QAAO,OACjB,YAAElE,EAAW,WAAEhP,EAAU,UAAEyR,IAAc,UACzCosB,GAAgB,UAChBC,GAAY,IAAA5qB,SAAO,GAEnB6qB,EACJj9C,EAAOb,OAAS,KAAUkoB,SAAW,IAAM,SAEvC61B,GAAgB,IAAAzsC,cACpB,IACEkgB,EAAU,UAAU,KAAY7I,YAAa,CAC3C3oB,KAAM,KAAY0oB,SAClB0D,cAAepZ,EACfnS,YAEJ,CAAC2wB,EAAWxe,EAAInS,IAGZm9C,GAAc,IAAA1sC,cAAY,KAE9B,GADAysC,IACIl9C,EAAOb,OAAS,KAAUqpB,IAC5B0F,EAAY,CAAE5uB,KAAMU,EAAOwoB,WACtB,GAAIxoB,EAAOb,OAAS,KAAUF,MAAO,CAC1C,MAAQA,MAAOM,EAAI,gBAAEC,GAAoBQ,EACzCkf,EAAW,CACT/f,KAAM,KAAYE,SAClBC,KAAM,CAAEC,OAAMC,oBAElB,IACC,CAAC0uB,EAAaluB,EAAQkf,EAAYg+B,IAE/BE,GAAc,IAAAlsC,UAClB,IACElR,EAAOb,OAAS,KAAUkoB,SACtB,CACEg2B,KAAMr9C,EAAOs9C,KACbC,IAAK,sBACL90C,OAAQzI,EAAOw9C,OAAS,SAAW,QACnCzxB,QAASmxB,GAEX,CACEnxB,QAASoxB,IAEjB,CAACn9C,EAAQm9C,EAAaD,IAcxB,OAXA,IAAA15B,YAAU,KACJq5B,IACED,GAAYI,EAAUt5B,QACxBrnB,OAAOsxB,uBAAsB,IAAMmvB,EAAQp5B,QAAQqS,UAEnD+mB,EAAQp5B,QAAQ+5B,QAGpBT,EAAUt5B,SAAU,CAAI,GACvB,CAACk5B,EAAUC,KAGZ,iBACEpzB,WAAW,OAAU,iBACrBtX,GAAIA,EACJgoC,UAAW,EACXpjB,IAAK+lB,EAAO,UAEXh2B,GACC,gBAAK2C,WAAW,OAAU,eAAgBmD,IAAK9F,EAAOqF,IAAI,KACxD,MACJ,iBAAK1C,WAAW,OAAU,iBAAkBtX,GAAIA,EAAE,UAC/ChB,IAAS,eAAIsY,WAAW,OAAU,eAAc,SAAGtY,IACnDwrC,IACC,gBACElzB,WAAW,OAAU,qBACrBqX,wBAAyB,CAAEC,OAAQ4b,MAGvC,SAACM,EAAmB,eAClB9C,SAAU0C,IAAmBD,GAAY,OAAIn9C,EAC7CgqB,WAAW,OAAU,SAAU,mBAAkB,mBAC/BszB,GACdK,EAAW,UAEd/rC,UAIR,EChGY,SAASqsC,GACtB/H,KAAMgI,EAAK,MACXC,EAAK,MACLxpB,EAAK,SACLve,IAEA,MAAM,EAAE3N,IAAMsI,EAAAA,EAAAA,KACd,OACEwb,EAAAA,EAAAA,KAAA,OACEvC,WAAWA,EAAAA,EAAAA,GAAU,gBAAkB,kBAAiBk0B,EAAMx+C,QAC9D0+C,KAAK,QACL,uBAAqB,QACrB,aAAY31C,EAAE,uBAAwB,CACpCksB,MAAOA,EAAQ,EACf0pB,MAAOF,EAAMr4C,SACZ+kB,UAEH0B,EAAAA,EAAAA,KAAC+xB,EAAa,IAAKJ,EAAOd,gBAAgB,EAAMD,SAAU/mC,KAGhE,yBCpBe,SAASmoC,GAAiB,MACvCJ,EAAK,aACLK,EAAY,SACZC,EAAQ,SACR5zB,IAEA,MAAM,EAAEpiB,IAAMsI,EAAAA,EAAAA,KACR2tC,EAAYP,EAAMr4C,OAQxB,OACEmmB,EAAAA,EAAAA,MAAA,OAAKjC,WAAWA,EAAAA,EAAAA,GAAU,qBAAqBa,SAAA,EAC7C0B,EAAAA,EAAAA,KAAA,UACEvC,WAAWA,EAAAA,EAAAA,GAAU,SAAU,oBAC/B,aAAYvhB,EAAE,8BACd6jB,QAZiBqyB,KACrBF,GAAUD,EAAe,EAAIE,GAAaA,EAAU,EAWxB7zB,UAExB0B,EAAAA,EAAAA,KAACC,EAAAA,EAAI,CAAC1sB,KAAK,YAAY2sB,KAAK,KAAKC,IAAI,OAEtC7B,GACD0B,EAAAA,EAAAA,KAAA,UACEvC,WAAWA,EAAAA,EAAAA,GAAU,SAAU,gBAC/B,aAAYvhB,EAAE,0BACd6jB,QAjBasyB,KACjBH,GAAUD,EAAe,GAAKE,EAAU,EAgBhB7zB,UAEpB0B,EAAAA,EAAAA,KAACC,EAAAA,EAAI,CAAC1sB,KAAK,aAAa2sB,KAAK,KAAKC,IAAI,SAI9C,CCnCe,SAASmyB,GAAmB,MACzCV,EAAK,aACLK,EAAY,SACZC,EAAQ,WACRK,EAAU,aACVC,IAEA,MAAML,EAAYP,EAAMr4C,OAClBk5C,GAAiBhuC,EAAAA,EAAAA,cACpBsI,IACC,MAAM2lC,EAAa30B,OAAOhR,EAAMtQ,OAAOk2C,QAAQhJ,MAAQ,KACjDiJ,EAAY50B,KAAK60B,IAAIV,EAAY,EAAGn0B,KAAK80B,IAAI,EAAGJ,IAClDE,IAAcX,GAChBC,EAASU,EACX,GAEF,CAACT,EAAWF,EAAcC,IAG5B,OACElyB,EAAAA,EAAAA,KAAA,OAAKvC,WAAWA,EAAAA,EAAAA,GAAU,gCAAiCo0B,KAAK,QAAOvzB,UACrE0B,EAAAA,EAAAA,KAAA,MAAIvC,WAAWA,EAAAA,EAAAA,GAAU,uBAAuBa,SAC7CszB,EAAMh4C,KAAI,CAAC+vC,EAAMvwB,KAChB,MAAMvP,EAAWooC,IAAiB74B,EAClC,OACE4G,EAAAA,EAAAA,KAAA,MAEEvC,WAAWA,EAAAA,EAAAA,GACT,4BACA5T,EAAW,iBAAcpW,GACzB6qB,UAEF0B,EAAAA,EAAAA,KAAA,UACEvC,WAAWA,EAAAA,EAAAA,GAAU,+BACrBtqB,KAAK,SACL4sB,QAAS0yB,EACT,YAAWr5B,EACX,gBAAevP,EAAW,YAASpW,EACnC,aAAY++C,EAAa7I,EAAMvwB,MAZ5Bm5B,EAAW5I,EAAMvwB,EAAK,oBAcxB,OAMjB,CCzCA,MAAM25B,EAAoBA,CAACpJ,EAAMvwB,EAAK45B,IAAY,GAAEA,IAAS55B,IACvD65B,EAAuBtJ,GAASA,EAAKwG,MACrC+C,EAAgBA,EAAGz2C,aACvBA,EAAO02C,WAAa,CAAC,EAGR,SAASC,GACtBnB,aAAcoB,EAAa,SAC3BnB,EAAQ,WACRK,EAAaQ,EAAiB,aAC9BP,EAAeS,EAAmB,MAClCrB,IAEA,MAAM0B,GAAkB90B,EAAAA,EAAAA,MAClB2zB,EAAYP,EAAMr4C,QACjB04C,EAAcsB,IAAmBp8B,EAAAA,EAAAA,UAAS4G,OAAOs1B,GAAiB,OAEzE77B,EAAAA,EAAAA,YAAU,KACR+7B,EAAgBx1B,OAAOs1B,GAAiB,KAAK,GAC5C,CAACE,EAAiBF,IAErB,MAAMG,GAAYptB,EAAAA,EAAAA,QAAO,IACzBotB,EAAU97B,SAAUxS,EAAAA,EAAAA,UAAQ,IACnBxJ,MAAMy2C,GACVsB,KAAK,GACL75C,KAAI,KAAMqd,EAAAA,EAAAA,gBACZ,CAACk7B,IAEJ,MAAMuB,GAAattB,EAAAA,EAAAA,SAAO,GACpButB,GAAcvtB,EAAAA,EAAAA,UAapB,OAZAutB,EAAYj8B,QAAUw6B,GACtB16B,EAAAA,EAAAA,YAAU,KACJk8B,EAAWh8B,QACbg8B,EAAWh8B,SAAU,EAInBi8B,EAAYj8B,SACdi8B,EAAYj8B,QAAQu6B,EACtB,GACC,CAACA,KAGFvyB,EAAAA,EAAAA,MAAA,OACEjC,WAAWA,EAAAA,EAAAA,GAAU,YACrBo0B,KAAK,QACL,uBAAqB,WAAUvzB,SAAA,EAE/B0B,EAAAA,EAAAA,KAAA,OACEvC,WAAWA,EAAAA,EAAAA,GAAU,4BACrBm2B,SAAUV,EAAc50B,UAExB0B,EAAAA,EAAAA,KAAA,OACE7Z,GAAImtC,EACJ71B,WAAWA,EAAAA,EAAAA,GAAU,oBACrBo2B,MAAO,CACLC,MAAsB,IAAZ3B,EAAF,IACR4B,MAAyB,IAAhB9B,EAAF,KAET,YAAU,SACV,cAAY,QAAO3zB,SAElBszB,EAAMh4C,KAAI,CAAC+vC,EAAMvwB,KAChB,MAAMvP,EAAWooC,IAAiB74B,EAClC,OACE4G,EAAAA,EAAAA,KAAA,OAEE+K,IAAKyoB,EAAU97B,QAAQ0B,GACvBqE,WAAWA,EAAAA,EAAAA,GACT,kBACA5T,EAAW,iBAAcpW,GAE3B,cAAcoW,OAAoBpW,EAAT,OAAmB6qB,UAE5C0B,EAAAA,EAAAA,KAAC0xB,EAAoB,CACnB/H,KAAMA,EACNiI,MAAOA,EACPK,aAAcA,EACd7pB,MAAOhP,EACPvP,SAAUA,KAbP0oC,EAAW5I,EAAMvwB,EAAK,SAevB,SAKd4G,EAAAA,EAAAA,KAAA,OAAKvC,WAAWA,EAAAA,EAAAA,GAAU,sBAAsBa,UAC9C0B,EAAAA,EAAAA,KAACgyB,EAAgB,CACfC,aAAcA,EACdL,MAAOA,EACPM,SAAUqB,EACVS,UAAWV,EAAgBh1B,UAE3B0B,EAAAA,EAAAA,KAAA,OAAKvC,WAAWA,EAAAA,EAAAA,GAAU,wBAAwBa,UAChD0B,EAAAA,EAAAA,KAACsyB,EAAkB,CACjBL,aAAcA,EACdL,MAAOA,EACPM,SAAUqB,EACVhB,WAAYA,EACZC,aAAcA,YAO5B,CC7GA,MAAMD,EAAaA,CAAC5I,EAAMvwB,EAAK45B,EAAS,KAAQ,GAAEA,IAASrJ,EAAKxkC,SAASiU,IACnEo5B,EAAgB7I,GAASA,EAAKxkC,uCCF7B,MAAM8uC,EAAsB1zB,GAChC,sBAAqBhkB,OAAOgkB,GAC1B0P,cACAC,QAAQ,gBAAiB,MAgC9B,GA9BwBgkB,EACtB/tC,KACAguC,aAAa,GACbC,WACAr0B,UACAs0B,cAEA,MAAMC,GAAmBpvC,EAAAA,EAAAA,UAAQ,IACxB,CAAC,uBAAwBivC,EAAWv6C,IAAIq6C,KAC9C,CAACE,IAEEhD,GAAc1sC,EAAAA,EAAAA,cAAY,KAC1Bsb,GACFA,EAAQ,CAAE5Z,KAAIiuC,YAChB,GACC,CAACjuC,EAAIiuC,EAAUr0B,IAClB,OACEC,EAAAA,EAAAA,KAAA,MAAIvC,WAAWA,EAAAA,EAAAA,GAAU62B,GAAkBh2B,UACzCoB,EAAAA,EAAAA,MAAA,UACEvsB,KAAK,SACL4sB,QAASoxB,EACT1zB,WAAWA,EAAAA,EAAAA,GAAU,SAAU,mBAAmBa,SAAA,CAEjD+1B,IAAWr0B,EAAAA,EAAAA,KAACC,EAAAA,EAAI,CAAC1sB,KAAK,eAAe2sB,KAAK,IAAIC,IAAI,KAClDi0B,MAEA,ECdT,GAlBwBG,EACtB92B,UAAW+2B,EACXC,cAAc,GACdC,oBACAL,WAAU,MAEVr0B,EAAAA,EAAAA,KAAA,MAAIvC,WAAWA,EAAAA,EAAAA,GAAU,oBAAqB+2B,GAAgBl2B,SAC3Dm2B,EAAY76C,KAAKmf,IAChBiH,EAAAA,EAAAA,KAACk0B,GAAe,CACdG,QAASA,EAETt0B,QAAS20B,KACL37B,GAFCA,EAAW5S,QCSxB,GAnBkCwuC,IAChC,MAAM,WAAEzhC,IAAevB,EAAAA,EAAAA,MAevB,OAboBje,IACdA,EAAE+I,QAAU/I,EAAE+I,OAAOk2C,QAAQiC,QAC/B1hC,EAAW,CACT/f,KAAMC,EAAAA,GAAYioB,SAClBkE,cAAeo1B,EACfrD,KAAM,CACJnrC,GAAIzS,EAAE+I,OAAOk2C,QAAQiC,OACrBtvB,IAAK5xB,EAAE+I,OAAOyrB,aAAa,UAGjC,CAGe,EChBJ,SAAS2sB,IAAa,SACnCv2B,EAAQ,aACRw2B,EACAr3B,UAAWs3B,EAAiB,WAE5BC,EAAU,YACVC,EAAc,OAAM,SACpBC,EAAQ,SACRC,EAAQ,cACRC,EAAa,YAEbC,IAEA,MAAMC,EAAa/vC,QAAQ2vC,GAAYF,GAEjCl0B,EAAYg0B,EACd,CAAEhgB,wBAAyB,CAAEC,OAAQ+f,IACrC,CAAEx2B,YAEN,OACEoB,EAAAA,EAAAA,MAAA,OACEjC,WAAWA,EAAAA,EAAAA,GACT,UACA43B,GAAgB,iBAAgBA,IAChCN,GACAz2B,SAAA,CAEDg3B,IACCt1B,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,oBAAoBa,SAC5C42B,GACCl1B,EAAAA,EAAAA,KAACC,EAAAA,EAAI,CACH1sB,KAAM2hD,EACNh1B,KAAMi1B,EACN13B,UAAW23B,EACXj1B,IAAI,MAGNH,EAAAA,EAAAA,KAAA,OACEY,IAAKo0B,EACLv3B,WAAWA,EAAAA,EAAAA,GACT,CACE83B,KAAsB,SAAhBN,EACN3sC,OAAwB,WAAhB2sC,GAEVG,QAOVp1B,EAAAA,EAAAA,KAAA,OAAKvC,WAAWA,EAAAA,EAAAA,GAAU,oBAAsBqD,MAGtD,CCrDA,MAAM00B,GAAe,CACnB,CAACr5B,EAAAA,GAAYC,WAAY,2BCM3B,MCPMq5B,GAAW,CACfpqC,QFGcqqC,EAAG3oC,YACjB,MAAM,EAAE7Q,IAAMsI,EAAAA,EAAAA,MAER,QAAE+gB,GAAYxY,EAAM1W,QAAQ/C,KAC5B+hD,EAAcG,GAAar5B,EAAAA,GAAYoJ,IAE7C,OACEvF,EAAAA,EAAAA,KAAC60B,GAAY,CAACQ,YAAaA,EAAaH,SAAU/4B,EAAAA,GAAYoJ,GAASjH,UACrE0B,EAAAA,EAAAA,KAAA,KAAA1B,SAAIpiB,EAAG,eAAcigB,EAAAA,GAAYoJ,SACpB,EEXjB,CAACpJ,EAAAA,GAAYE,iBDKes5B,EAAG5oC,YAC/B,MAAM,EAAE7Q,IAAMsI,EAAAA,EAAAA,KACRwB,GAASsT,EAAAA,EAAAA,OAEbhmB,MAAM,mBAAE+gB,EAAkB,KAAExM,EAAI,MAAE1C,GAAO,GACzCgB,GACE4G,EAAM1W,QACJkb,GAAwB9Z,EAAAA,EAAAA,KAC3BrB,GAAUA,EAAM2E,aAAawW,wBAG1Bjc,GAAW+R,EAAAA,EAAAA,MACXuuC,GAAqBnxC,EAAAA,EAAAA,cAAY,KAChC8M,EAAsBpL,GAK3B7Q,GAASwf,EAAAA,GAAAA,IAAwB,CAAE9O,SAAQG,QAJzC7Q,GAASyf,EAAAA,GAAAA,IAAyB,CAAE/O,SAAQG,OAIG,GAChD,CAAC7Q,EAAU0Q,EAAQG,EAAIoL,IAE1B,OACEmO,EAAAA,EAAAA,MAACm1B,GAAY,CAACK,SAAS,iBAAiBG,YAAY,iBAAgB/2B,SAAA,EAClE0B,EAAAA,EAAAA,KAAA,KAAGvC,WAAWA,EAAAA,EAAAA,GAAU,kBAAkBa,SAAEnZ,IAC3C0C,IAAQmY,EAAAA,EAAAA,KAAA,KAAA1B,SAAIzW,IACZwM,GACC2L,EAAAA,EAAAA,KAAAL,EAAAA,SAAA,CAAArB,UACE0B,EAAAA,EAAAA,KAAA,UACEvC,WAAWA,EAAAA,EAAAA,GAAU,SAAU,qBAC/BsC,QAAS61B,EAAmBt3B,SAE3BpiB,EACEqV,EAAsBpL,GAEnB,iDADA,sDAKR,OACS,GE9Cb0vC,GAAoB,CAAEC,MAAO,OAAQC,IAAK,UAAWC,KAAM,WAC3DC,GAAoB,CAAEC,KAAM,UAAWC,OAAQ,WC8BrD,GA5BsBC,EAAGrpC,YACvB,MAAMoa,GAAcD,EAAAA,EAAAA,OACd,KAAEkD,EAAI,KAAEisB,EAAI,kBAAEC,EAAiB,OAAElxC,GDFRglB,KAC/B,MAAM,EAAEluB,IAAMsI,EAAAA,EAAAA,KACRzS,GAASyF,EAAAA,EAAAA,MACTyD,EAASlJ,GAAQK,SAAS6I,QAAU,GACpCs7C,EAAY,IAAI91C,KAAK2pB,GACrBC,EAAc,IAAI5pB,KAClB+1C,EAAW,IAAI/1C,KAAK4pB,GAC1BmsB,EAASjsB,SAAS,GAAI,EAAG,EAAG,GAC5B,MAAM+rB,EAAoBE,EAAWnsB,EAC/BosB,EAAeF,EAAU/1C,WACzB61C,EAAO,IAAIpyC,KAAKyyC,eAAez7C,EAAQg7C,IAAmBp0C,OAC9D00C,GAGF,IAAII,GAAexsB,EAAAA,EAAAA,IAAgBosB,EAAWlsB,GAC9C,OAAQssB,GACN,IAAK,QACHA,EAAez6C,EAAE,kBACjB,MACF,IAAK,YACHy6C,EAAez6C,EAAE,sBACjB,MACF,QACEy6C,EAAe,IAAI1yC,KAAKyyC,eAAez7C,EAAQ46C,IAAmBh0C,OAChE00C,GAMN,MAAO,CACLnsB,KAAMusB,EACNvxC,OAJalJ,EAAE,kBAAmB,CAAEkuB,KAAMusB,EAAcN,SAKxDA,OACAI,eACAH,oBACD,EClCiDM,EAChDv9B,EAAAA,EAAAA,IAA2BtM,EAAMxb,gBAcnC,OAVAimB,EAAAA,EAAAA,YAAU,KACR,MAAM6J,EAAUlsB,YAAW,KACzBgyB,GAAa,GACZmvB,GAEH,MAAO,KACLvhD,aAAassB,EAAQ,CACtB,GACA,CAAC8F,EAAamvB,KAGf52B,EAAAA,EAAAA,MAACm1B,GAAY,CAACQ,YAAY,iBAAgB/2B,SAAA,EACxCoB,EAAAA,EAAAA,MAAA,KAAGjC,WAAWA,EAAAA,EAAAA,GAAU,iBAAkB,cAAY,OAAMa,SAAA,EAC1D0B,EAAAA,EAAAA,KAAA,QAAA1B,SAAO8L,KACPpK,EAAAA,EAAAA,KAAA,QAAA1B,SAAO+3B,QAETr2B,EAAAA,EAAAA,KAAA,KAAGvC,WAAWA,EAAAA,EAAAA,GAAU,mBAAmBa,SAAElZ,MAChC,ECtBnB,IAAIyxC,GAAqB,CAAC,qBAAsB,sBAAuB,wBAAyB,uBAAwB,sBAAuB,oCAAqC,+BAAgC,+BAAgC,gEAAiE,6CAA8C,wBAC/VC,GAAmCD,GAAmBz2C,KAAK,KAC3D22C,GAA+B,oBAAZC,QACnBvX,GAAUsX,GAAY,WAAa,EAAIC,QAAQh7C,UAAUyjC,SAAWuX,QAAQh7C,UAAUi7C,mBAAqBD,QAAQh7C,UAAUk7C,sBAC7HC,IAAeJ,IAAaC,QAAQh7C,UAAUm7C,YAAc,SAAU31B,GACxE,IAAI41B,EACJ,OAAO51B,SAAmG,QAAhD41B,EAAuB51B,EAAQ21B,mBAAkD,IAAzBC,OAAlE,EAA6GA,EAAqB/6C,KAAKmlB,EACzL,EAAI,SAAUA,GACZ,OAAOA,aAAyC,EAASA,EAAQ61B,aACnE,EAUIC,GAAU,SAASA,EAAQ7/B,EAAM8/B,GACnC,IAAIC,OACW,IAAXD,IACFA,GAAS,GAKX,IAAIE,EAAWhgC,SAAyF,QAA5C+/B,EAAqB//B,EAAKyQ,oBAAiD,IAAvBsvB,OAA9D,EAAuGA,EAAmBn7C,KAAKob,EAAM,SAUvL,MATyB,KAAbggC,GAAgC,SAAbA,GAOTF,GAAU9/B,GAAQ6/B,EAAQ7/B,EAAKuW,WAGvD,EAsBI0pB,GAAgB,SAAuBh2B,EAAIi2B,EAAkBt1C,GAG/D,GAAIi1C,GAAQ51B,GACV,MAAO,GAET,IAAIk2B,EAAal8C,MAAMM,UAAUkC,MAAM6C,MAAM2gB,EAAGsG,iBAAiB8uB,KAKjE,OAJIa,GAAoBlY,GAAQpjC,KAAKqlB,EAAIo1B,KACvCc,EAAWC,QAAQn2B,GAERk2B,EAAWv1C,OAAOA,EAEjC,EAoCIy1C,GAA2B,SAASA,EAAyBC,EAAUJ,EAAkBxuC,GAG3F,IAFA,IAAIyuC,EAAa,GACbI,EAAkBt8C,MAAMkG,KAAKm2C,GAC1BC,EAAgBz+C,QAAQ,CAC7B,IAAIioB,EAAUw2B,EAAgBC,QAC9B,IAAIX,GAAQ91B,GAAS,GAKrB,GAAwB,SAApBA,EAAQ02B,QAAoB,CAE9B,IAAIC,EAAW32B,EAAQ42B,mBAEnBC,EAAmBP,EADTK,EAAS5+C,OAAS4+C,EAAW32B,EAAQlD,UACM,EAAMnV,GAC3DA,EAAQjM,QACV06C,EAAWr5C,KAAKwC,MAAM62C,EAAYS,GAElCT,EAAWr5C,KAAK,CACd+5C,YAAa92B,EACbo2B,WAAYS,GAGlB,KAAO,CAEgB5Y,GAAQpjC,KAAKmlB,EAASs1B,KACrB3tC,EAAQ9G,OAAOmf,KAAam2B,IAAqBI,EAAStmC,SAAS+P,KACvFo2B,EAAWr5C,KAAKijB,GAIlB,IAAI+2B,EAAa/2B,EAAQ+2B,YAEQ,mBAA1BpvC,EAAQqvC,eAAgCrvC,EAAQqvC,cAAch3B,GAKjEi3B,GAAmBnB,GAAQiB,GAAY,MAAYpvC,EAAQuvC,kBAAoBvvC,EAAQuvC,iBAAiBl3B,IAC5G,GAAI+2B,GAAcE,EAAiB,CAOjC,IAAIE,EAAoBb,GAAwC,IAAfS,EAAsB/2B,EAAQlD,SAAWi6B,EAAWj6B,UAAU,EAAMnV,GACjHA,EAAQjM,QACV06C,EAAWr5C,KAAKwC,MAAM62C,EAAYe,GAElCf,EAAWr5C,KAAK,CACd+5C,YAAa92B,EACbo2B,WAAYe,GAGlB,MAGEX,EAAgBH,QAAQ92C,MAAMi3C,EAAiBx2B,EAAQlD,SAE3D,CACF,CACA,OAAOs5B,CACT,EAQIgB,GAAc,SAAqBnhC,GACrC,OAAQyjB,MAAMp3B,SAAS2T,EAAKyQ,aAAa,YAAa,IACxD,EAQI2wB,GAAc,SAAqBphC,GACrC,IAAKA,EACH,MAAM,IAAInZ,MAAM,oBAElB,OAAImZ,EAAK02B,SAAW,IAQb,0BAA0BvwC,KAAK6Z,EAAKygC,UA5JrB,SAA2BzgC,GACjD,IAAIqhC,EAIAC,EAAWthC,SAA0F,QAA7CqhC,EAAsBrhC,EAAKyQ,oBAAkD,IAAxB4wB,OAA/D,EAAyGA,EAAoBz8C,KAAKob,EAAM,mBAC1L,MAAoB,KAAbshC,GAAgC,SAAbA,CAC5B,CAqJyDC,CAAkBvhC,MAAWmhC,GAAYnhC,GACrF,EAGJA,EAAK02B,QACd,EAiBI8K,GAAuB,SAA8B13C,EAAG2T,GAC1D,OAAO3T,EAAE4sC,WAAaj5B,EAAEi5B,SAAW5sC,EAAE23C,cAAgBhkC,EAAEgkC,cAAgB33C,EAAE4sC,SAAWj5B,EAAEi5B,QACxF,EACIgL,GAAU,SAAiB1hC,GAC7B,MAAwB,UAAjBA,EAAKygC,OACd,EA8FIkB,GAAa,SAAoB3hC,GACnC,IAAI4hC,EAAwB5hC,EAAK6hC,wBAC/BxF,EAAQuF,EAAsBvF,MAC9ByF,EAASF,EAAsBE,OACjC,OAAiB,IAAVzF,GAA0B,IAAXyF,CACxB,EA6HIC,GAAkC,SAAyCrwC,EAASsO,GACtF,QAAIA,EAAKgiC,UAITnC,GAAQ7/B,IApOU,SAAuBA,GACzC,OAAO0hC,GAAQ1hC,IAAuB,WAAdA,EAAKtkB,IAC/B,CAkOmBumD,CAAcjiC,IAjIlB,SAAkBA,EAAMkiC,GACrC,IAAIC,EAAeD,EAAKC,aACtBpB,EAAgBmB,EAAKnB,cAMvB,GAA0C,WAAtCqB,iBAAiBpiC,GAAM1Q,WACzB,OAAO,EAET,IACI+yC,EADkBra,GAAQpjC,KAAKob,EAAM,iCACAA,EAAKsiC,cAAgBtiC,EAC9D,GAAIgoB,GAAQpjC,KAAKy9C,EAAkB,yBACjC,OAAO,EAET,GAAKF,GAAiC,SAAjBA,GAA4C,gBAAjBA,GAgEzC,GAAqB,kBAAjBA,EAMT,OAAOR,GAAW3hC,OAtE4D,CAC9E,GAA6B,mBAAlB+gC,EAA8B,CAIvC,IADA,IAAIwB,EAAeviC,EACZA,GAAM,CACX,IAAIsiC,EAAgBtiC,EAAKsiC,cACrBE,EAAW9C,GAAY1/B,GAC3B,GAAIsiC,IAAkBA,EAAcxB,aAA+C,IAAjCC,EAAcuB,GAI9D,OAAOX,GAAW3hC,GAGlBA,EAFSA,EAAKyiC,aAEPziC,EAAKyiC,aACFH,GAAiBE,IAAaxiC,EAAK4/B,cAKtC0C,EAHAE,EAASE,IAKpB,CACA1iC,EAAOuiC,CACT,CAWA,GAxGiB,SAAwBviC,GAC3C,IAAI2iC,EA+BEC,EAAeC,EAAuBC,EAPxCC,EAAW/iC,GAAQ0/B,GAAY1/B,GAC/BgjC,EAA0C,QAA1BL,EAAYI,SAAoC,IAAdJ,OAAuB,EAASA,EAAUD,KAI5FO,GAAW,EACf,GAAIF,GAAYA,IAAa/iC,EAG3B,IADAijC,KAAiD,QAAlCL,EAAgBI,SAA4C,IAAlBJ,GAAsF,QAAzDC,EAAwBD,EAAchD,qBAAqD,IAA1BiD,GAAoCA,EAAsBrwB,SAASwwB,IAAiBhjC,SAAmF,QAA9C8iC,EAAsB9iC,EAAK4/B,qBAAmD,IAAxBkD,GAAkCA,EAAoBtwB,SAASxS,KAC7XijC,GAAYD,GAAc,CAChC,IAAIE,EAAYC,EAAgBC,EAMhCH,IAAkD,QAAnCE,EADfH,EAA2C,QAA3BE,EADhBH,EAAWrD,GAAYsD,UAC2C,IAAfE,OAAwB,EAASA,EAAWR,YAClB,IAAnBS,GAAwF,QAA1DC,EAAwBD,EAAevD,qBAAqD,IAA1BwD,IAAoCA,EAAsB5wB,SAASwwB,GAC/N,CAEF,OAAOC,CACT,CA2DQI,CAAerjC,GAKjB,OAAQA,EAAKsjC,iBAAiBxhD,OAmBhC,GAAqB,gBAAjBqgD,EACF,OAAO,CAGX,CAWA,OAAO,CACT,CAqC0CoB,CAASvjC,EAAMtO,IAjO9B,SAA8BsO,GAIvD,MAHyB,YAAjBA,EAAKygC,SAAyBx8C,MAAMM,UAAUkC,MAAM6C,MAAM0W,EAAK6G,UAAU5Q,MAAK,SAAUmS,GAC9F,MAAyB,YAAlBA,EAAMq4B,OACf,GAEF,CA8NE+C,CAAqBxjC,IAlCM,SAAgCA,GAC3D,GAAI,mCAAmC7Z,KAAK6Z,EAAKygC,SAG/C,IAFA,IAAIlqB,EAAavW,EAAKsiC,cAEf/rB,GAAY,CACjB,GAA2B,aAAvBA,EAAWkqB,SAA0BlqB,EAAWyrB,SAAU,CAE5D,IAAK,IAAIj+C,EAAI,EAAGA,EAAIwyB,EAAW1P,SAAS/kB,OAAQiC,IAAK,CACnD,IAAIqkB,EAAQmO,EAAW1P,SAASqrB,KAAKnuC,GAErC,GAAsB,WAAlBqkB,EAAMq4B,QAGR,QAAOzY,GAAQpjC,KAAK2xB,EAAY,0BAAkCnO,EAAMoK,SAASxS,EAErF,CAEA,OAAO,CACT,CACAuW,EAAaA,EAAW+rB,aAC1B,CAKF,OAAO,CACT,CAQgCmB,CAAuBzjC,GAIvD,EACI0jC,GAAiC,SAAwChyC,EAASsO,GACpF,QAlMuB,SAA4BA,GACnD,OAJY,SAAiBA,GAC7B,OAAO0hC,GAAQ1hC,IAAuB,UAAdA,EAAKtkB,IAC/B,CAESioD,CAAQ3jC,KA3BK,SAAyBA,GAC7C,IAAKA,EAAKlkB,KACR,OAAO,EAET,IAII8nD,EAJAC,EAAa7jC,EAAK9c,MAAQw8C,GAAY1/B,GACtC8jC,EAAc,SAAqBhoD,GACrC,OAAO+nD,EAAWtzB,iBAAiB,6BAA+Bz0B,EAAO,KAC3E,EAEA,GAAsB,oBAAXlD,aAAgD,IAAfA,OAAOmrD,KAAoD,mBAAtBnrD,OAAOmrD,IAAIC,OAC1FJ,EAAWE,EAAYlrD,OAAOmrD,IAAIC,OAAOhkC,EAAKlkB,YAE9C,IACE8nD,EAAWE,EAAY9jC,EAAKlkB,KAC9B,CAAE,MAAOK,GAGP,OADA+Q,QAAQpN,MAAM,2IAA4I3D,EAAIC,UACvJ,CACT,CAEF,IAAI6nD,EA3BgB,SAAyBC,EAAOhhD,GACpD,IAAK,IAAIa,EAAI,EAAGA,EAAImgD,EAAMpiD,OAAQiC,IAChC,GAAImgD,EAAMngD,GAAGkgD,SAAWC,EAAMngD,GAAGb,OAASA,EACxC,OAAOghD,EAAMngD,EAGnB,CAqBgBogD,CAAgBP,EAAU5jC,EAAK9c,MAC7C,OAAQ+gD,GAAWA,IAAYjkC,CACjC,CAK2BokC,CAAgBpkC,EAC3C,CAgMMqkC,CAAmBrkC,IAASohC,GAAYphC,GAAQ,IAAM+hC,GAAgCrwC,EAASsO,GAIrG,EACIskC,GAA4B,SAAmCC,GACjE,IAAI7N,EAAWrqC,SAASk4C,EAAe9zB,aAAa,YAAa,IACjE,SAAIgT,MAAMiT,IAAaA,GAAY,EAMrC,EAMI8N,GAAc,SAASA,EAAYrE,GACrC,IAAIsE,EAAmB,GACnBC,EAAmB,GAkBvB,OAjBAvE,EAAWl1C,SAAQ,SAAUinC,EAAMnuC,GACjC,IAAI4gD,IAAYzS,EAAK2O,YACjB92B,EAAU46B,EAAUzS,EAAK2O,YAAc3O,EACvC0S,EAlRmB,SAA8B5kC,EAAM2kC,GAC7D,IAAIjO,EAAW0K,GAAYphC,GAC3B,OAAI02B,EAAW,GAAKiO,IAAYxD,GAAYnhC,GACnC,EAEF02B,CACT,CA4Q4BmO,CAAqB96B,EAAS46B,GAClDrE,EAAWqE,EAAUH,EAAYtS,EAAKiO,YAAcp2B,EAC9B,IAAtB66B,EACFD,EAAUF,EAAiB39C,KAAKwC,MAAMm7C,EAAkBnE,GAAYmE,EAAiB39C,KAAKijB,GAE1F26B,EAAiB59C,KAAK,CACpB26C,cAAe19C,EACf2yC,SAAUkO,EACV1S,KAAMA,EACNyS,QAASA,EACTG,QAASxE,GAGf,IACOoE,EAAiB51C,KAAK0yC,IAAsB77C,QAAO,SAAU+W,EAAKqoC,GAEvE,OADAA,EAASJ,QAAUjoC,EAAI5V,KAAKwC,MAAMoT,EAAKqoC,EAASD,SAAWpoC,EAAI5V,KAAKi+C,EAASD,SACtEpoC,CACT,GAAG,IAAI7W,OAAO4+C,EAChB,EA8BIO,GAAa,SAAoBhlC,EAAMtO,GAEzC,GADAA,EAAUA,GAAW,CAAC,GACjBsO,EACH,MAAM,IAAInZ,MAAM,oBAElB,OAA8C,IAA1CmhC,GAAQpjC,KAAKob,EAAMq/B,KAGhBqE,GAA+BhyC,EAASsO,EACjD,EACIilC,GAA4C7F,GAAmBv5C,OAAO,UAAU8C,KAAK,KACrFu8C,GAAc,SAAqBllC,EAAMtO,GAE3C,GADAA,EAAUA,GAAW,CAAC,GACjBsO,EACH,MAAM,IAAInZ,MAAM,oBAElB,OAAuD,IAAnDmhC,GAAQpjC,KAAKob,EAAMilC,KAGhBlD,GAAgCrwC,EAASsO,EAClD,ECjjBA,SAASzV,GAAQtO,EAAGyI,GAClB,IAAID,EAAIpJ,OAAOwG,KAAK5F,GACpB,GAAIZ,OAAOqP,sBAAuB,CAChC,IAAIvG,EAAI9I,OAAOqP,sBAAsBzO,GACrCyI,IAAMP,EAAIA,EAAEyG,QAAO,SAAUlG,GAC3B,OAAOrJ,OAAOyP,yBAAyB7O,EAAGyI,GAAGS,UAC/C,KAAKV,EAAEqC,KAAKwC,MAAM7E,EAAGN,EACvB,CACA,OAAOM,CACT,CACA,SAAS0gD,GAAelpD,GACtB,IAAK,IAAIyI,EAAI,EAAGA,EAAI8C,UAAU1F,OAAQ4C,IAAK,CACzC,IAAID,EAAI,MAAQ+C,UAAU9C,GAAK8C,UAAU9C,GAAK,CAAC,EAC/CA,EAAI,EAAI6F,GAAQlP,OAAOoJ,IAAI,GAAIwG,SAAQ,SAAUvG,GAQrD,IAAyBc,EAAK7E,EAAK6B,EAAVgD,EAPHvJ,EAOQ0E,EAPL+D,EAOUlC,EAPPiC,EAAEC,GAQ5B/D,EAuBF,SAAwBmI,GACtB,IAAInI,EAXN,SAAsBykD,EAAOC,GAC3B,GAAqB,iBAAVD,GAAgC,OAAVA,EAAgB,OAAOA,EACxD,IAAIE,EAAOF,EAAMhhD,OAAOO,aACxB,QAAa3I,IAATspD,EAAoB,CACtB,IAAI1nD,EAAM0nD,EAAK1gD,KAAKwgD,EAAOC,UAC3B,GAAmB,iBAARznD,EAAkB,OAAOA,EACpC,MAAM,IAAIiH,UAAU,+CACtB,CACA,OAA4BC,OAAiBsgD,EAC/C,CAEYG,CAAaz8C,GACvB,MAAsB,iBAARnI,EAAmBA,EAAMmE,OAAOnE,EAChD,CA1BQ6kD,CAAe7kD,GACjBA,KAAO6E,EACTnK,OAAOiK,eAAeE,EAAK7E,EAAK,CAC9B6B,MAAOA,EACP2C,YAAY,EACZC,cAAc,EACdC,UAAU,IAGZG,EAAI7E,GAAO6B,CAhBX,IAAKnH,OAAO6P,0BAA4B7P,OAAO8P,iBAAiBlP,EAAGZ,OAAO6P,0BAA0BzG,IAAM8F,GAAQlP,OAAOoJ,IAAIwG,SAAQ,SAAUvG,GAC7IrJ,OAAOiK,eAAerJ,EAAGyI,EAAGrJ,OAAOyP,yBAAyBrG,EAAGC,GACjE,GACF,CACA,OAAOzI,CACT,CA8BA,IAiCIwpD,GAAa,SAAoBxpD,GACnC,MAAyD,SAAjDA,aAA6B,EAASA,EAAE0E,MAAwE,KAArD1E,aAA6B,EAASA,EAAEo2B,QAC7G,EAGIqzB,GAAe,SAAsBzpD,GACvC,OAAOwpD,GAAWxpD,KAAOA,EAAE0pD,QAC7B,EAGIC,GAAgB,SAAuB3pD,GACzC,OAAOwpD,GAAWxpD,IAAMA,EAAE0pD,QAC5B,EACIE,GAAQ,SAAetsB,GACzB,OAAO77B,WAAW67B,EAAI,EACxB,EAIIusB,GAAY,SAAmBjiD,EAAK01B,GACtC,IAAI5X,GAAO,EAUX,OATA9d,EAAIkW,OAAM,SAAUvX,EAAOuB,GACzB,OAAIw1B,EAAG/2B,KACLmf,EAAM5d,GACC,EAIX,IAEO4d,CACT,EASIokC,GAAiB,SAAwBvjD,GAC3C,IAAK,IAAIoG,EAAOpB,UAAU1F,OAAQmjB,EAAS,IAAIhhB,MAAM2E,EAAO,EAAIA,EAAO,EAAI,GAAIC,EAAO,EAAGA,EAAOD,EAAMC,IACpGoc,EAAOpc,EAAO,GAAKrB,UAAUqB,GAE/B,MAAwB,mBAAVrG,EAAuBA,EAAM8G,WAAM,EAAQ2b,GAAUziB,CACrE,EACIwjD,GAAkB,SAAyB1wC,GAQ7C,OAAOA,EAAMtQ,OAAO87C,YAA4C,mBAAvBxrC,EAAM2wC,aAA8B3wC,EAAM2wC,eAAe,GAAK3wC,EAAMtQ,MAC/G,EAIIkhD,GAAoB,GACpBC,GAAkB,SAAyB7F,EAAU8F,GAGvD,IA+CIC,EA/CAC,GAAOF,aAAiD,EAASA,EAAYt2C,WAAaA,SAC1Fy2C,GAAaH,aAAiD,EAASA,EAAYG,YAAcL,GACjG5rD,EAAS6qD,GAAe,CAC1BqB,yBAAyB,EACzBC,mBAAmB,EACnBC,mBAAmB,EACnBhB,aAAcA,GACdE,cAAeA,IACdQ,GACCznD,EAAQ,CAGVgoD,WAAY,GAiBZC,gBAAiB,GAOjBC,eAAgB,GAChBC,4BAA6B,KAC7BC,wBAAyB,KACzBn1C,QAAQ,EACRo1C,QAAQ,EAGRC,4BAAwBjrD,EAExBkrD,oBAAgBlrD,GAYdmrD,EAAY,SAAmBC,EAAuBz6B,EAAY06B,GACpE,OAAOD,QAA+DprD,IAAtCorD,EAAsBz6B,GAA4By6B,EAAsBz6B,GAAcryB,EAAO+sD,GAAoB16B,EACnJ,EAYI26B,EAAqB,SAA4Bv9B,EAASzU,GAC5D,IAAI2wC,EAA6F,mBAAtE3wC,aAAqC,EAASA,EAAM2wC,cAA+B3wC,EAAM2wC,oBAAiBjqD,EAIrI,OAAO2C,EAAMioD,gBAAgBd,WAAU,SAAU5D,GAC/C,IAAIqF,EAAYrF,EAAKqF,UACnBC,EAAgBtF,EAAKsF,cACvB,OAAOD,EAAU/0B,SAASzI,KAI1Bk8B,aAAmD,EAASA,EAAajsC,SAASutC,KAAeC,EAAc9yC,MAAK,SAAUsL,GAC5H,OAAOA,IAAS+J,CAClB,GACF,GACF,EAeI09B,EAAmB,SAA0B96B,GAC/C,IAAI+6B,EAAcptD,EAAOqyB,GACzB,GAA2B,mBAAhB+6B,EAA4B,CACrC,IAAK,IAAIC,EAAQngD,UAAU1F,OAAQmjB,EAAS,IAAIhhB,MAAM0jD,EAAQ,EAAIA,EAAQ,EAAI,GAAIC,EAAQ,EAAGA,EAAQD,EAAOC,IAC1G3iC,EAAO2iC,EAAQ,GAAKpgD,UAAUogD,GAEhCF,EAAcA,EAAYp+C,WAAM,EAAQ2b,EAC1C,CAKA,IAJoB,IAAhByiC,IACFA,OAAc1rD,IAGX0rD,EAAa,CAChB,QAAoB1rD,IAAhB0rD,IAA6C,IAAhBA,EAC/B,OAAOA,EAIT,MAAM,IAAI7gD,MAAM,IAAIhB,OAAO8mB,EAAY,gEACzC,CACA,IAAI3M,EAAO0nC,EAEX,GAA2B,iBAAhBA,KACT1nC,EAAOsmC,EAAIuB,cAAcH,IAEvB,MAAM,IAAI7gD,MAAM,IAAIhB,OAAO8mB,EAAY,0CAG3C,OAAO3M,CACT,EACI8nC,EAAsB,WACxB,IAAI9nC,EAAOynC,EAAiB,gBAG5B,IAAa,IAATznC,EACF,OAAO,EAET,QAAahkB,IAATgkB,IAAuBklC,GAAYllC,EAAM1lB,EAAOytD,iBAElD,GAAIT,EAAmBhB,EAAI7zB,gBAAkB,EAC3CzS,EAAOsmC,EAAI7zB,kBACN,CACL,IAAIu1B,EAAqBrpD,EAAMkoD,eAAe,GAI9C7mC,EAHwBgoC,GAAsBA,EAAmBC,mBAGrCR,EAAiB,gBAC/C,CAEF,IAAKznC,EACH,MAAM,IAAInZ,MAAM,gEAElB,OAAOmZ,CACT,EACIkoC,EAAsB,WA4ExB,GA3EAvpD,EAAMioD,gBAAkBjoD,EAAMgoD,WAAWxkD,KAAI,SAAUolD,GACrD,IAAIC,EDgNK,SAAkBD,EAAW71C,GAE1C,IAAIyuC,EAWJ,OATEA,GAHFzuC,EAAUA,GAAW,CAAC,GAEVqvC,cACGV,GAAyB,CAACkH,GAAY71C,EAAQwuC,iBAAkB,CAC3Et1C,OAAQ84C,GAA+Bp5C,KAAK,KAAMoH,GAClDjM,SAAS,EACTs7C,cAAervC,EAAQqvC,cACvBE,iBAAkBqD,KAGPrE,GAAcsH,EAAW71C,EAAQwuC,iBAAkBwD,GAA+Bp5C,KAAK,KAAMoH,IAErG8yC,GAAYrE,EACrB,CC9N0BgI,CAASZ,EAAWjtD,EAAOytD,iBAK3CK,ED0NM,SAAmBb,EAAW71C,GAY5C,OAXAA,EAAUA,GAAW,CAAC,GAEVqvC,cACGV,GAAyB,CAACkH,GAAY71C,EAAQwuC,iBAAkB,CAC3Et1C,OAAQm3C,GAAgCz3C,KAAK,KAAMoH,GACnDjM,SAAS,EACTs7C,cAAervC,EAAQqvC,gBAGZd,GAAcsH,EAAW71C,EAAQwuC,iBAAkB6B,GAAgCz3C,KAAK,KAAMoH,GAG/G,CCvO2B22C,CAAUd,EAAWjtD,EAAOytD,iBAC7CE,EAAoBT,EAAc1lD,OAAS,EAAI0lD,EAAc,QAAKxrD,EAClEssD,EAAmBd,EAAc1lD,OAAS,EAAI0lD,EAAcA,EAAc1lD,OAAS,QAAK9F,EACxFusD,EAAuBH,EAAe1zC,MAAK,SAAUsL,GACvD,OAAOglC,GAAWhlC,EACpB,IACIwoC,EAAsBJ,EAAe3hD,QAAQ2P,UAAU1B,MAAK,SAAUsL,GACxE,OAAOglC,GAAWhlC,EACpB,IACIyoC,IAAuBjB,EAAc9yC,MAAK,SAAUsL,GACtD,OAAOohC,GAAYphC,GAAQ,CAC7B,IACA,MAAO,CACLunC,UAAWA,EACXC,cAAeA,EACfY,eAAgBA,EAEhBK,mBAAoBA,EAEpBR,kBAAmBA,EAEnBK,iBAAkBA,EASlBC,qBAAsBA,EAEtBC,oBAAqBA,EASrBE,iBAAkB,SAA0B1oC,GAC1C,IAAI2oC,IAAUnhD,UAAU1F,OAAS,QAAsB9F,IAAjBwL,UAAU,KAAmBA,UAAU,GACzEohD,EAAUpB,EAAc9/C,QAAQsY,GACpC,OAAI4oC,EAAU,EAORD,EACKP,EAAe3hD,MAAM2hD,EAAe1gD,QAAQsY,GAAQ,GAAGtL,MAAK,SAAUuV,GAC3E,OAAO+6B,GAAW/6B,EACpB,IAEKm+B,EAAe3hD,MAAM,EAAG2hD,EAAe1gD,QAAQsY,IAAO5J,UAAU1B,MAAK,SAAUuV,GACpF,OAAO+6B,GAAW/6B,EACpB,IAEKu9B,EAAcoB,GAAWD,EAAU,GAAK,GACjD,EAEJ,IACAhqD,EAAMkoD,eAAiBloD,EAAMioD,gBAAgBh8C,QAAO,SAAUi+C,GAC5D,OAAOA,EAAMrB,cAAc1lD,OAAS,CACtC,IAGInD,EAAMkoD,eAAe/kD,QAAU,IAAM2lD,EAAiB,iBAExD,MAAM,IAAI5gD,MAAM,uGAUlB,GAAIlI,EAAMioD,gBAAgBlyC,MAAK,SAAUwe,GACvC,OAAOA,EAAEu1B,kBACX,KAAM9pD,EAAMioD,gBAAgB9kD,OAAS,EACnC,MAAM,IAAI+E,MAAM,gLAEpB,EAUIiiD,EAAmB,SAASA,EAAiB7+B,GAC/C,IAAIwI,EAAgBxI,EAAGwI,cACvB,GAAKA,EAGL,OAAIA,EAAcquB,YAAyD,OAA3CruB,EAAcquB,WAAWruB,cAChDq2B,EAAiBr2B,EAAcquB,YAEjCruB,CACT,EACIs2B,EAAW,SAASA,EAAS/oC,IAClB,IAATA,GAGAA,IAAS8oC,EAAiBh5C,YAGzBkQ,GAASA,EAAKsS,OAInBtS,EAAKsS,MAAM,CACTmpB,gBAAiBnhD,EAAOmhD,gBAG1B98C,EAAMooD,wBAA0B/mC,EAjWZ,SAA2BA,GACjD,OAAOA,EAAKygC,SAA0C,UAA/BzgC,EAAKygC,QAAQjoB,eAAoD,mBAAhBxY,EAAKpT,MAC/E,CAgWQo8C,CAAkBhpC,IACpBA,EAAKpT,UATLm8C,EAASjB,KAWb,EACImB,EAAqB,SAA4BC,GACnD,IAAIlpC,EAAOynC,EAAiB,iBAAkByB,GAC9C,OAAOlpC,IAAuB,IAATA,GAAyBkpC,CAChD,EAaIC,EAAkB,SAAyBC,GAC7C,IAAIpkD,EAASokD,EAAMpkD,OACjBsQ,EAAQ8zC,EAAM9zC,MACd+zC,EAAmBD,EAAME,WACzBA,OAAkC,IAArBD,GAAsCA,EACrDrkD,EAASA,GAAUghD,GAAgB1wC,GACnC4yC,IACA,IAAIqB,EAAkB,KACtB,GAAI5qD,EAAMkoD,eAAe/kD,OAAS,EAAG,CAInC,IAAI0nD,EAAiBlC,EAAmBtiD,EAAQsQ,GAC5Cm0C,EAAiBD,GAAkB,EAAI7qD,EAAMioD,gBAAgB4C,QAAkBxtD,EACnF,GAAIwtD,EAAiB,EAKjBD,EAFED,EAEgB3qD,EAAMkoD,eAAeloD,EAAMkoD,eAAe/kD,OAAS,GAAGwmD,iBAGtD3pD,EAAMkoD,eAAe,GAAGoB,uBAEvC,GAAIqB,EAAY,CAIrB,IAAII,EAAoB5D,GAAUnnD,EAAMkoD,gBAAgB,SAAU8C,GAChE,IAAI1B,EAAoB0B,EAAM1B,kBAC9B,OAAOjjD,IAAWijD,CACpB,IAUA,GATIyB,EAAoB,IAAMD,EAAelC,YAAcviD,GAAUkgD,GAAYlgD,EAAQ1K,EAAOytD,mBAAqB/C,GAAWhgD,EAAQ1K,EAAOytD,mBAAqB0B,EAAef,iBAAiB1jD,GAAQ,MAO1M0kD,EAAoBF,GAElBE,GAAqB,EAAG,CAI1B,IAAIE,EAA8C,IAAtBF,EAA0B/qD,EAAMkoD,eAAe/kD,OAAS,EAAI4nD,EAAoB,EACxGG,EAAmBlrD,EAAMkoD,eAAe+C,GAC5CL,EAAkBnI,GAAYp8C,IAAW,EAAI6kD,EAAiBvB,iBAAmBuB,EAAiBrB,mBACpG,MAAY/C,GAAWnwC,KAGrBi0C,EAAkBE,EAAef,iBAAiB1jD,GAAQ,GAE9D,KAAO,CAIL,IAAI8kD,EAAmBhE,GAAUnnD,EAAMkoD,gBAAgB,SAAUkD,GAC/D,IAAIzB,EAAmByB,EAAMzB,iBAC7B,OAAOtjD,IAAWsjD,CACpB,IAUA,GATIwB,EAAmB,IAAML,EAAelC,YAAcviD,GAAUkgD,GAAYlgD,EAAQ1K,EAAOytD,mBAAqB/C,GAAWhgD,EAAQ1K,EAAOytD,mBAAqB0B,EAAef,iBAAiB1jD,MAOjM8kD,EAAmBN,GAEjBM,GAAoB,EAAG,CAIzB,IAAIE,EAAyBF,IAAqBnrD,EAAMkoD,eAAe/kD,OAAS,EAAI,EAAIgoD,EAAmB,EACvGG,EAAoBtrD,EAAMkoD,eAAemD,GAC7CT,EAAkBnI,GAAYp8C,IAAW,EAAIilD,EAAkBhC,kBAAoBgC,EAAkB1B,oBACvG,MAAY9C,GAAWnwC,KAGrBi0C,EAAkBE,EAAef,iBAAiB1jD,GAEtD,CACF,MAGEukD,EAAkB9B,EAAiB,iBAErC,OAAO8B,CACT,EAIIW,EAAmB,SAA0BjuD,GAC/C,IAAI+I,EAASghD,GAAgB/pD,GACzBqrD,EAAmBtiD,EAAQ/I,IAAM,IAIjC8pD,GAAezrD,EAAO6vD,wBAAyBluD,GAEjDoqD,EAAK+D,WAAW,CAOdC,YAAa/vD,EAAOksD,0BAQpBT,GAAezrD,EAAOgwD,kBAAmBruD,IAM7CA,EAAEsuD,iBACJ,EAMIC,EAAe,SAAsBl1C,GACvC,IAAItQ,EAASghD,GAAgB1wC,GACzBm1C,EAAkBnD,EAAmBtiD,EAAQsQ,IAAU,EAG3D,GAAIm1C,GAAmBzlD,aAAkB0lD,SACnCD,IACF9rD,EAAMooD,wBAA0B/hD,OAE7B,CAOL,IAAI2lD,EALJr1C,EAAMs1C,2BAMN,IAAIC,GAAsB,EAC1B,GAAIlsD,EAAMooD,wBACR,GAAI3F,GAAYziD,EAAMooD,yBAA2B,EAAG,CAElD,IAAI+D,EAAkBxD,EAAmB3oD,EAAMooD,yBAK3CS,EAAgB7oD,EAAMioD,gBAAgBkE,GAAiBtD,cAC3D,GAAIA,EAAc1lD,OAAS,EAAG,CAE5B,IAAIipD,EAAYvD,EAAc1B,WAAU,SAAU9lC,GAChD,OAAOA,IAASrhB,EAAMooD,uBACxB,IACIgE,GAAa,IACXzwD,EAAOorD,aAAa/mD,EAAMuoD,gBACxB6D,EAAY,EAAIvD,EAAc1lD,SAChC6oD,EAAWnD,EAAcuD,EAAY,GACrCF,GAAsB,GAKpBE,EAAY,GAAK,IACnBJ,EAAWnD,EAAcuD,EAAY,GACrCF,GAAsB,GAO9B,CAKF,MAKOlsD,EAAMioD,gBAAgB3wC,MAAK,SAAUid,GACxC,OAAOA,EAAEs0B,cAAcvxC,MAAK,SAAUrM,GACpC,OAAOw3C,GAAYx3C,GAAK,CAC1B,GACF,MAIEihD,GAAsB,QAQ1BA,GAAsB,EAEpBA,IACFF,EAAWxB,EAAgB,CAGzBnkD,OAAQrG,EAAMooD,wBACduC,WAAYhvD,EAAOsrD,cAAcjnD,EAAMuoD,mBAIzC6B,EADE4B,GAGOhsD,EAAMooD,yBAA2Be,IAE9C,CACAnpD,EAAMuoD,oBAAiBlrD,CACzB,EA0BIgvD,EAAW,SAAkB11C,GAC/B,IA3mBuD,YAAjDrZ,OADiCA,EA4mBrBqZ,QA3mBiB,EAASrZ,EAAE0E,MAAuE,SAAjD1E,aAA6B,EAASA,EAAE0E,MAAwE,MAArD1E,aAA6B,EAASA,EAAEo2B,YA2mBvF,IAApD0zB,GAAezrD,EAAOmsD,kBAAmBnxC,GAGnE,OAFAA,EAAMi1C,sBACNlE,EAAK+D,aA9mBS,IAAuBnuD,GAinBnC3B,EAAOorD,aAAapwC,IAAUhb,EAAOsrD,cAActwC,KA1BvC,SAAqBA,GACrC,IAAIg0C,EAAa9hD,UAAU1F,OAAS,QAAsB9F,IAAjBwL,UAAU,IAAmBA,UAAU,GAChF7I,EAAMuoD,eAAiB5xC,EACvB,IAAIi0C,EAAkBJ,EAAgB,CACpC7zC,MAAOA,EACPg0C,WAAYA,IAEVC,IACE9D,GAAWnwC,IAKbA,EAAMi1C,iBAERxB,EAASQ,GAGb,CASI0B,CAAY31C,EAAOhb,EAAOsrD,cAActwC,GAE5C,EACI41C,EAAa,SAAoBjvD,GACnC,IAAI+I,EAASghD,GAAgB/pD,GACzBqrD,EAAmBtiD,EAAQ/I,IAAM,GAGjC8pD,GAAezrD,EAAO6vD,wBAAyBluD,IAG/C8pD,GAAezrD,EAAOgwD,kBAAmBruD,KAG7CA,EAAEsuD,iBACFtuD,EAAE2uD,2BACJ,EAMIO,EAAe,WACjB,GAAKxsD,EAAMiT,OA6BX,OAnsBY,SAAsB20C,EAAWF,GAC7C,GAAIE,EAAUzkD,OAAS,EAAG,CACxB,IAAIspD,EAAa7E,EAAUA,EAAUzkD,OAAS,GAC1CspD,IAAe/E,GACjB+E,EAAWC,OAEf,CACA,IAAIC,EAAY/E,EAAU7+C,QAAQ2+C,IACf,IAAfiF,GAIF/E,EAAU1pC,OAAOyuC,EAAW,GAH5B/E,EAAUz/C,KAAKu/C,EAMnB,CA4pBEkF,CAA8BhF,EAAWF,GAIzC1nD,EAAMsoD,uBAAyB3sD,EAAOosD,kBAAoBb,IAAM,WAC9DkD,EAASjB,IACX,IAAKiB,EAASjB,KACdxB,EAAI3c,iBAAiB,UAAW6gB,GAAc,GAC9ClE,EAAI3c,iBAAiB,YAAaugB,EAAkB,CAClDsB,SAAS,EACTC,SAAS,IAEXnF,EAAI3c,iBAAiB,aAAcugB,EAAkB,CACnDsB,SAAS,EACTC,SAAS,IAEXnF,EAAI3c,iBAAiB,QAASuhB,EAAY,CACxCM,SAAS,EACTC,SAAS,IAEXnF,EAAI3c,iBAAiB,UAAWqhB,EAAU,CACxCQ,SAAS,EACTC,SAAS,IAEJpF,CACT,EACIqF,EAAkB,WACpB,GAAK/sD,EAAMiT,OAQX,OALA00C,EAAIvc,oBAAoB,UAAWygB,GAAc,GACjDlE,EAAIvc,oBAAoB,YAAamgB,GAAkB,GACvD5D,EAAIvc,oBAAoB,aAAcmgB,GAAkB,GACxD5D,EAAIvc,oBAAoB,QAASmhB,GAAY,GAC7C5E,EAAIvc,oBAAoB,UAAWihB,GAAU,GACtC3E,CACT,EAuBIsF,EAAqC,oBAAX/yD,QAA0B,qBAAsBA,OAAS,IAAIgzD,kBAjBrE,SAAyBC,GAClBA,EAAU51C,MAAK,SAAU61C,GAElD,OADmB7nD,MAAMkG,KAAK2hD,EAASC,cACnB91C,MAAK,SAAU+J,GACjC,OAAOA,IAASrhB,EAAMooD,uBACxB,GACF,KAKEgC,EAASjB,IAEb,SAI+H9rD,EAC3HgwD,EAAsB,WACnBL,IAGLA,EAAiB7tD,aACba,EAAMiT,SAAWjT,EAAMqoD,QACzBroD,EAAMgoD,WAAWxkD,KAAI,SAAUolD,GAC7BoE,EAAiBrrC,QAAQinC,EAAW,CAClC0E,SAAS,EACTC,WAAW,GAEf,IAEJ,EAwHA,OAlHA7F,EAAO,CACL,UAAIz0C,GACF,OAAOjT,EAAMiT,MACf,EACA,UAAIo1C,GACF,OAAOroD,EAAMqoD,MACf,EACAmF,SAAU,SAAkBC,GAC1B,GAAIztD,EAAMiT,OACR,OAAOxJ,KAET,IAAIikD,EAAalF,EAAUiF,EAAiB,cACxCE,EAAiBnF,EAAUiF,EAAiB,kBAC5CG,EAAoBpF,EAAUiF,EAAiB,qBAC9CG,GACHrE,IAEFvpD,EAAMiT,QAAS,EACfjT,EAAMqoD,QAAS,EACfroD,EAAMmoD,4BAA8BR,EAAI7zB,cACxC45B,SAAgDA,IAChD,IAAIG,EAAmB,WACjBD,GACFrE,IAEFiD,IACAa,IACAM,SAAwDA,GAC1D,EACA,OAAIC,GACFA,EAAkB5tD,EAAMgoD,WAAW9gD,UAAUsoB,KAAKq+B,EAAkBA,GAC7DpkD,OAETokD,IACOpkD,KACT,EACAgiD,WAAY,SAAoBqC,GAC9B,IAAK9tD,EAAMiT,OACT,OAAOxJ,KAET,IAAIsJ,EAAUyzC,GAAe,CAC3BuH,aAAcpyD,EAAOoyD,aACrBC,iBAAkBryD,EAAOqyD,iBACzBC,oBAAqBtyD,EAAOsyD,qBAC3BH,GACHnvD,aAAaqB,EAAMsoD,wBACnBtoD,EAAMsoD,4BAAyBjrD,EAC/B0vD,IACA/sD,EAAMiT,QAAS,EACfjT,EAAMqoD,QAAS,EACfgF,IA5xBY,SAAwBzF,EAAWF,GACjD,IAAIiF,EAAY/E,EAAU7+C,QAAQ2+C,IACf,IAAfiF,GACF/E,EAAU1pC,OAAOyuC,EAAW,GAE1B/E,EAAUzkD,OAAS,GACrBykD,EAAUA,EAAUzkD,OAAS,GAAG+qD,SAEpC,CAqxBItB,CAAgChF,EAAWF,GAC3C,IAAIqG,EAAevF,EAAUz1C,EAAS,gBAClCi7C,EAAmBxF,EAAUz1C,EAAS,oBACtCk7C,EAAsBzF,EAAUz1C,EAAS,uBACzC24C,EAAclD,EAAUz1C,EAAS,cAAe,2BACpDg7C,SAAoDA,IACpD,IAAII,EAAqB,WACvBjH,IAAM,WACAwE,GACFtB,EAASE,EAAmBtqD,EAAMmoD,8BAEpC6F,SAA4DA,GAC9D,GACF,EACA,OAAItC,GAAeuC,GACjBA,EAAoB3D,EAAmBtqD,EAAMmoD,8BAA8B34B,KAAK2+B,EAAoBA,GAC7F1kD,OAET0kD,IACO1kD,KACT,EACAijD,MAAO,SAAe0B,GACpB,GAAIpuD,EAAMqoD,SAAWroD,EAAMiT,OACzB,OAAOxJ,KAET,IAAI4kD,EAAU7F,EAAU4F,EAAc,WAClCE,EAAc9F,EAAU4F,EAAc,eAM1C,OALApuD,EAAMqoD,QAAS,EACfgG,SAA0CA,IAC1CtB,IACAM,IACAiB,SAAkDA,IAC3C7kD,IACT,EACAykD,QAAS,SAAiBK,GACxB,IAAKvuD,EAAMqoD,SAAWroD,EAAMiT,OAC1B,OAAOxJ,KAET,IAAI+kD,EAAYhG,EAAU+F,EAAgB,aACtCE,EAAgBjG,EAAU+F,EAAgB,iBAO9C,OANAvuD,EAAMqoD,QAAS,EACfmG,SAA8CA,IAC9CjF,IACAiD,IACAa,IACAoB,SAAsDA,IAC/ChlD,IACT,EACAilD,wBAAyB,SAAiCC,GACxD,IAAIC,EAAkB,GAAG1nD,OAAOynD,GAAmB1iD,OAAOkD,SAQ1D,OAPAnP,EAAMgoD,WAAa4G,EAAgBprD,KAAI,SAAU4nB,GAC/C,MAA0B,iBAAZA,EAAuBu8B,EAAIuB,cAAc99B,GAAWA,CACpE,IACIprB,EAAMiT,QACRs2C,IAEF8D,IACO5jD,IACT,GAIFi+C,EAAKgH,wBAAwB/M,GACtB+F,CACT,ECh6BA,MAsGA,GAtGcmH,EACZ3mC,WACA4mC,UACA,aAAcC,EACd,kBAAmBC,EACnBC,uBAEA,MAAMC,GAAU9mC,EAAAA,EAAAA,MACV+mC,GAAiBn/B,EAAAA,EAAAA,QAAO,MACxBo/B,GAAYp/B,EAAAA,EAAAA,QAAO,OAClBq/B,EAAgBC,IAAqBvuC,EAAAA,EAAAA,WAAS,GA4ErD,OA1EAK,EAAAA,EAAAA,YAAU,KACJiuC,IACFD,EAAU9tC,QAAUkmC,GAAgB2H,EAAe7tC,QAAS,CAC1DiuC,aACEN,GAAoBA,EAAiB3tC,QACjC2tC,EAAiB3tC,QACjB,OAER8tC,EAAU9tC,QAAQksC,YAEb,KACD4B,EAAU9tC,SACZ8tC,EAAU9tC,QAAQmqC,YACpB,IAED,CAAC4D,EAAgBJ,KAEpB7tC,EAAAA,EAAAA,YAAU,KACR,MAAMouC,GAAmB/9B,EAAAA,EAAAA,MACzB,MAAO,KACL+9B,GAAkB,CACnB,GACA,CAACH,KAEJjuC,EAAAA,EAAAA,YAAU,KACJiuC,GACFF,EAAe7tC,QAAQ0pB,iBAAiB,WAAYr0B,KAC7CA,EAAM8c,MAAuB,WAAf9c,EAAM8c,MAAwC,KAAlB9c,EAAM+c,UACnDo7B,GACF,GAEJ,GACC,CAACO,EAAgBP,KAEpB/yB,EAAAA,EAAAA,kBAAgB,KACd,MAAM0zB,EAAct+C,SAAS0mC,qBAAqB,QAAQ,GACpD+Q,EAAYz3C,SAASgmB,cAAc,OAczC,OAbAyxB,EAAU72B,aAAa,KAAMm9B,GAC7BtG,EAAU72B,aAAa,OAAQ,UAC/B62B,EAAU72B,aAAa,iBAAkB,QACzC62B,EAAU72B,aAAa,aAAc,QACjCg9B,GACFnG,EAAU72B,aAAa,aAAcg9B,GAEnCC,GACFpG,EAAU72B,aAAa,kBAAmBi9B,GAE5CS,EAAYl5B,YAAYqyB,GACxBuG,EAAe7tC,QAAUsnC,EACzB0G,GAAkB,GACX,KACDH,EAAe7tC,UACjBmuC,EAAY13B,YAAYo3B,EAAe7tC,SACvC6tC,EAAe7tC,QAAU,KAC3B,CACD,GACA,CAACytC,EAAWC,EAAgBE,IAkBJ,mBAAbhnC,EACVA,EAAS,CACP4mC,UACAY,cAAgBC,GACdR,EAAe7tC,UAAWgU,EAAAA,EAAAA,QAAOq6B,EAAKR,EAAe7tC,WAEzD6tC,EAAe7tC,UACbgU,EAAAA,EAAAA,SACE9L,EAAAA,EAAAA,cAAatB,GAAU1kB,KAAKimB,IAC1BA,EAAMnjB,MAAQ,IAAKmjB,EAAMnjB,MAAOwoD,WACzBrlC,KAET0lC,EAAe7tC,QAChB,ECnBT,GA3EiBsuC,EAAG1gC,MAAKqrB,cAAauU,QAASe,MAC7C,MAAM,OAAEC,EAAM,WAAEj1D,EAAU,UAAED,IAAcwG,EAAAA,EAAAA,MACpC2uD,GAAoB1hC,EAAAA,EAAAA,MACpBxsB,GAAyBmpB,EAAAA,EAAAA,MACzBxO,GAAiBwT,EAAAA,EAAAA,QAAO,OACxB,EAAElqB,IAAMsI,EAAAA,EAAAA,KAORuc,EAAa,CAAC,QAHjB,eAAc9vB,IACd,cAAaD,OAEsCiH,GAEhDmuD,EAAuB1yD,IAC3BA,EAAE2yD,iBAAiB,EAGfC,EAAsBA,KAC1BL,GAAgB,EAGZpS,EAAQqS,EAAS,CAAEA,OAAQA,EAAS,QAAMzyD,EA0ChD,OACEusB,EAAAA,EAAAA,KAACilC,GAAK,CACJC,QAASe,EACT,aAAY/pD,EAAE,oBACdmpD,iBAAkBzyC,EAAe0L,SAEhCA,EAAG4mC,UAASY,mBAAoBA,EA9CZZ,KACvBllC,EAAAA,EAAAA,KAAA,OACEvC,WAAWA,EAAAA,EAAAA,GAAUsD,GACrBhB,QAASumC,EACTzS,MAAOA,EAAMv1B,UAEboB,EAAAA,EAAAA,MAAA,OACEjC,WAAWA,EAAAA,EAAAA,GAAU,gBACrB0wB,SAAS,KACToY,YAAaJ,EACbK,UAAWL,EACXM,aAAcN,EACdO,YAAaP,EACbQ,QAASR,EACTS,cAAeT,EACfU,cAAeV,EACfp7B,IAAKnY,EAAe0L,SAAA,EAEpB0B,EAAAA,EAAAA,KAAA,OACEvC,WAAWA,EAAAA,EAAAA,GAAU,gBACrBsC,QAASqmC,EAAoB9nC,UAE7B0B,EAAAA,EAAAA,KAAA,OACEvC,WAAWA,EAAAA,EAAAA,GAAU,gBACrBmD,IAAK0E,EACLnF,IAAKwwB,OAGTjxB,EAAAA,EAAAA,MAAA,UACEvsB,KAAK,SACLsqB,WAAWA,EAAAA,EAAAA,GAAU,gBACrBsC,QAASmlC,EAAQ5mC,SAAA,EAEjB0B,EAAAA,EAAAA,KAACC,EAAAA,EAAI,CAAC1sB,KAAK,QAAQ2sB,KAAK,KAAKC,IAAI,KAChCjkB,EAAE,+BAYwC4qD,CAAgB5B,KACzD,EC3CZ,GAjCsB6B,EAAGpW,cAAarrB,UACpC,MAAM,EAAEppB,IAAMsI,EAAAA,EAAAA,MACPwiD,EAAcC,IAAmB9vC,EAAAA,EAAAA,WAAS,GAUjD,OACEuI,EAAAA,EAAAA,MAAAC,EAAAA,SAAA,CAAArB,SAAA,EACEoB,EAAAA,EAAAA,MAAA,UACEvsB,KAAK,SACLsqB,WAAWA,EAAAA,EAAAA,GAAU,kBACrBsC,QAbwBmnC,KAC5BD,GAAgB,EAAK,EAYc3oC,SAAA,CAE9BpiB,EAAE,yCAA0C,CAAEy0C,iBAC/C3wB,EAAAA,EAAAA,KAACC,EAAAA,EAAI,CAAC1sB,KAAK,UAAU2sB,KAAK,KAAKC,IAAI,QAEpC6mC,IACChnC,EAAAA,EAAAA,KAACgmC,GAAQ,CACP1gC,IAAKA,EACLqrB,YAAaA,EACbuU,QAlBuBiC,KAC7BF,GAAgB,EAAM,MAoBnB,ECCP,GA/BaG,EAAGr6C,WAAUrQ,MACxB,MAAM,KAAEpJ,IAAS4e,EAAAA,EAAAA,IAAuBnF,GAClCs6C,EAAaC,GAAyBv6C,EAAM1W,QAAQ8P,IAEpDohD,GAAiBriD,EAAAA,EAAAA,UAAQ,IACzB6H,EAAM1W,QAAQoX,uBACT,CACL6Q,UAAU0B,EAAAA,EAAAA,KAAA,KAAA1B,SAAIhrB,EAAKuU,QAIhB,CACLiZ,UAAW,CACTgU,wBAAyB,CACvBC,OAAQzhC,GAAM8rB,MAAMvX,MAAQvU,EAAKuU,SAItC,CAACvU,EAAMyZ,IAEV,OACEiT,EAAAA,EAAAA,KAACI,EAAAA,EAAgB,CACfjtB,KAAK,OACL4Z,MAAOA,EACPgT,QAASsnC,KACL3qD,KACA6qD,GACJ,ECxBAC,GAAmB,mBAoBnBC,GAAgBA,EAAGC,MAAKtiC,eAC5B,MAAM,EAAElpB,IAAMsI,EAAAA,EAAAA,KACRY,EAASlJ,EAAE,gCAAiC,CAAEoU,SAAU8U,IAE9D,OACEpF,EAAAA,EAAAA,KAAAL,EAAAA,SAAA,CAAArB,UACEoB,EAAAA,EAAAA,MAAA,QAAMjC,WAAWA,EAAAA,EAAAA,GAAU,CAAC,WAAY,sBAAsBa,SAAA,EAC5D0B,EAAAA,EAAAA,KAAA,OAAKY,IAAK8mC,EAAKvnC,IAAK/a,KACpB4a,EAAAA,EAAAA,KAAA,QAAM,cAAY,OAAOvC,WAAWA,EAAAA,EAAAA,GAAU,iBAAiBa,SAC5D8G,QAGJ,EAIDuiC,GAAgBA,EAAGrpC,WAAUgH,MAAK7oB,YACtC6oB,GACEtF,EAAAA,EAAAA,KAAA,KACEqxB,KAAM/rB,EACNoP,UAAQ,EACRj4B,OAAQA,EACRghB,WAAWA,EAAAA,EAAAA,GAAU,CAAC,WAAY,kBAAkBa,SAEnDA,KAGH0B,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,YAAYa,SAAEA,ICrCvCspC,GAAmB,CACvB/zD,QAAS,CACPg0D,cAAexpC,EAAAA,EACfxW,KAAMu/C,GACNtsC,MCfUgtC,EAAG/6C,QAAOwR,kBAAiB7hB,MACvC,MAAM,KAAEpJ,IAAS4e,EAAAA,EAAAA,IAAuBnF,IAClC,YAAE4jC,EAAW,IAAErrB,EAAG,WAAEyiC,GAAez0D,GAClC00D,EAAaC,IAAmB9wC,EAAAA,EAAAA,WAAS,GAC1C7hB,GAAW+R,EAAAA,EAAAA,MAOjB,OACEqY,EAAAA,EAAAA,MAACU,EAAAA,EAAgB,CAACrT,MAAOA,EAAO5Z,KAAK,WAAYuJ,EAAK4hB,SAAA,EACpD0B,EAAAA,EAAAA,KAAA,OACEY,IAAK0E,EACLnf,GAAIoY,EACJ4B,IAAKwwB,EACLuX,OAXeC,KACnB7yD,GAAS0X,EAAAA,EAAAA,IAAuBD,EAAM1W,QAAQ8P,KAC9C8hD,GAAgB,EAAK,IAWlBF,GAAcC,IACbhoC,EAAAA,EAAAA,KAAC+mC,GAAa,CAACpW,YAAaA,EAAarrB,IAAKA,MAE/B,EDNnBnK,OEnBWitC,EAAGr7C,WAAUrQ,MAC1B,MAAM,QAAErG,GAAY0W,GACd,KAAEzZ,IAAS4e,EAAAA,EAAAA,IAAuBnF,GAClCs6C,EAAaC,GAAyBjxD,EAAQ8P,IAEpD,OACE6Z,EAAAA,EAAAA,KAACI,EAAAA,EAAgB,CACfjtB,KAAK,SACL4Z,MAAOA,EACPgT,QAASsnC,KACL3qD,EACJokB,UAAW,CACTgU,wBAAyB,CACvBC,OAAQzhC,EAAKuU,QAGjB,EFIFkT,MGnBUstC,EAAGt7C,QAAOwR,kBAAiB7hB,MACvC,MAAM,KAAEpJ,IAAS4e,EAAAA,EAAAA,IAAuBnF,IAClC,YAAE4jC,EAAW,IAAErrB,GAAQhyB,EAK7B,OAJmB0tB,EAAAA,EAAAA,IAAoCjU,GAE5CxO,KAAK,wBAGdmhB,EAAAA,EAAAA,MAACU,EAAAA,EAAgB,CAACrT,MAAOA,EAAO5Z,KAAK,WAAYuJ,EAAK4hB,SAAA,EACpD0B,EAAAA,EAAAA,KAAA,OAAK7Z,GAAIoY,EAAcd,WAAWA,EAAAA,EAAAA,GAAU,mBAAmBa,SAC5DqyB,KAEH3wB,EAAAA,EAAAA,KAAA,UACE7a,MAAOwrC,EACP/vB,IAAK0E,EACLgjC,MAAM,4BACNC,iBAAe,MAEA,EHEnBt8C,ODiCWu8C,EAAGz7C,WAAUrQ,MAC1B,MAAM,EAAER,IAAMsI,EAAAA,EAAAA,MACR,KAAElR,IAAS4e,EAAAA,EAAAA,IAAuBnF,IAClC,WAAErF,EAAU,GAAEvB,GAAO4G,EAAM1W,SAC3B,SAAE+uB,EAAQ,IAAEE,GAAQhyB,EACpBo0D,EArDqBe,KAC3B,MAAM,sBAAEr9C,IAA0B3T,EAAAA,EAAAA,KAAY,EAAGrB,WAAYA,IAE7D,OAAO8O,EAAAA,EAAAA,UAAQ,KAKb,GAJwBkG,EAAsBsC,MAC3C2C,GAAWA,IAAWo4C,IAGJ,OAAOjB,GAE5B,IACE,OAAOkB,eAAeC,QAAS,SAAQF,IACzC,CAAE,MAAOlxD,GACP,MACF,IACC,CAACkxD,EAAer9C,GAAuB,EAsC9Bw9C,CAAoBziD,GAE1Bf,GAASF,EAAAA,EAAAA,UACb,IAEMhJ,EADJopB,EACM,gCACA,gCADiC,CAAEhV,SAAU8U,KAErD,CAACE,EAAKF,EAAUlpB,IAGlB,OACE8jB,EAAAA,EAAAA,KAACI,EAAAA,EAAgB,CAACrT,MAAOA,EAAO5Z,KAAK,YAAauJ,EAAK4hB,SACpDopC,GAAOA,IAAQF,IACdxnC,EAAAA,EAAAA,KAACynC,GAAa,CAACC,IAAKA,EAAKtiC,SAAUA,KAEnC1F,EAAAA,EAAAA,MAACioC,GAAa,CAACriC,IAAKA,EAAK7oB,OAASiL,OAAwBjU,EAAX,SAAqB6qB,SAAA,EAClE0B,EAAAA,EAAAA,KAACC,EAAAA,EAAI,CAAC1sB,KAAK,WAAW2sB,KAAK,KAAKC,IAAK/a,KACrC4a,EAAAA,EAAAA,KAAA,QAAM,cAAY,OAAOvC,WAAWA,EAAAA,EAAAA,GAAU,iBAAiBa,SAC5D8G,QAIU,EC3DnBlK,IIlBQ2tC,EAAG97C,YACb,MAAM,KAAEzZ,IAAS4e,EAAAA,EAAAA,IAAuBnF,GAClCs6C,EAAaC,GAAyBv6C,EAAM1W,QAAQ8P,KACpD,UAAEwe,IAAchT,EAAAA,EAAAA,MAEhBo/B,GAAgBvyB,EAAAA,EAAAA,MAEhBsqC,GAAiBrkD,EAAAA,EAAAA,cACrB,IACEkgB,EAAW,UAASvxB,EAAAA,GAAYyoB,WAAY,CAC1C1oB,KAAMC,EAAAA,GAAYyoB,SAClB0D,cAAexS,EAAM1W,QAAQ8P,GAC7BmrC,KAAM,CACJhsB,IAAKhyB,EAAKy1D,eAGhB,CAACpkC,EAAWrxB,EAAMyZ,IAGpB,OACE2S,EAAAA,EAAAA,MAACU,EAAAA,EAAgB,CAACjtB,KAAK,MAAM4Z,MAAOA,EAAMuR,SAAA,EACxC0B,EAAAA,EAAAA,KAAA,OACEvC,WAAWA,EAAAA,EAAAA,GAAU,gBACrBtX,GAAI4qC,EACJjc,wBAAyB,CAAEC,OAAQzhC,EAAKq9C,aACxC5wB,QAASsnC,KAEXrnC,EAAAA,EAAAA,KAAA,KACEvC,WAAWA,EAAAA,EAAAA,GAAU,SAAU,mBAC/B,mBAAkBszB,EAClBM,KAAM/9C,EAAKy1D,WACXxX,IAAI,aACJ90C,OAAQnJ,EAAK01D,aAAe,SAAW,QACvCjpC,QAAS+oC,EAAexqC,SAEvBhrB,EAAK+R,eAES,EJlBnB4jD,SjBpBoBC,EAAGn8C,YACzB,MAAM,KAAEzZ,IAAS4e,EAAAA,EAAAA,IAAuBnF,GAClCo8C,EAAS71D,EAAK81D,MAEpB,OACEppC,EAAAA,EAAAA,KAACI,EAAAA,EAAgB,CAACrT,MAAOA,EAAO8T,UAAW,gBAAgBvC,UACzD0B,EAAAA,EAAAA,KAACozB,EAAiB,CAChBxB,MAAOuX,EACPE,cAAe3X,EACfa,WAAYA,EACZC,aAAcA,KAEC,EiBSnB8W,KKvBgBC,EAAGx8C,YACrB,MAAM,KAAEzZ,IAAS4e,EAAAA,EAAAA,IAAuBnF,GAClCgkC,GAAgBvyB,EAAAA,EAAAA,MAEtB,OACEwB,EAAAA,EAAAA,KAACI,EAAAA,EAAgB,CAACjtB,KAAK,OAAO4Z,MAAOA,EAAMuR,UACzC0B,EAAAA,EAAAA,KAAC+xB,EAAa,CAAC5rC,GAAI4qC,KAAmBz9C,KACrB,GLkBrBqU,KAAM,CACJE,KAAMu/C,GACNpsC,QVvBY06B,EAAG3oC,WAAUrQ,MAC3B,MAAM62B,EACJkiB,GAASt5B,EAAAA,GAAYpP,EAAM1W,QAAQ/C,KAAKiyB,WAAakwB,GAASpqC,QAChE,OAAO2U,EAAAA,EAAAA,KAACuT,EAAS,CAACxmB,MAAOA,KAAWrQ,GAAS,EUqB3CgI,YM7BgB8kD,EAAGz8C,WAAUrQ,MAC/B,MAAM,EAAER,IAAMsI,EAAAA,EAAAA,MACR,KAAElR,IAAS4e,EAAAA,EAAAA,IAAuBnF,GACxC,OACEiT,EAAAA,EAAAA,KAACI,EAAAA,EAAgB,CAACjtB,KAAK,OAAO4Z,MAAOA,KAAWrQ,EAAK4hB,SAClDpiB,EAAE5I,EAAK8E,IAAIgI,KAAK,KAAM9M,EAAKm2D,YACX,ENwBnBl4D,cAAe6kD,IAEjB5tC,YAAa,CACXA,YOlCgBkhD,EAAG38C,YACrB,MAAM,YAAEvE,GAAgBuE,EAAM1W,SACtB/C,KAAMiV,IAAiB2J,EAAAA,EAAAA,IAAuBnF,GAEtD,OAAKxE,GAKHyX,EAAAA,EAAAA,KAAC60B,GAAY,CACXG,WAAYxsC,EAAYF,OACxB2sC,YAAazsC,EAAYF,OAAS,cAAW7U,EAC7CyhD,SAAW1sC,EAAYF,YAAqB7U,EAAZ,UAChCqhD,aAAcvsC,EACd8sC,YAAY,gBATP,IAUL,GPqBJsU,aAAc,CACZ5wC,WQjB4B6wC,EAAG78C,WAAUrQ,MAC3C,MAAOmtD,EAAYC,IAAiB3yC,EAAAA,EAAAA,WAAS,GACvC7hB,GAAW+R,EAAAA,EAAAA,MACXtR,GAAmBunB,EAAAA,EAAAA,MACnB,WAAEpK,EAAU,iBAAE6L,IAAqBpN,EAAAA,EAAAA,OACnC,YAAE8iC,EAAW,QAAEp+C,GAfQ0W,KAC7B,MAAM,QAAE1W,GAAY0W,GACZzZ,KAAMmhD,IAAgBviC,EAAAA,EAAAA,IAAuBnF,GAErD,MAAO,CACL0nC,cACAp+C,UACD,EAQgC0zD,CAAeh9C,IAC1C,gBAAEtU,IAAoBjB,EAAAA,EAAAA,MACtBwO,GAASsT,EAAAA,EAAAA,OAET,EAAEpd,IAAMsI,EAAAA,EAAAA,KACRwlD,EAAc9tD,EAAE,2BAChB+tD,EAAa/tD,EAAE,0BAIfguD,GAA0BhlD,EAAAA,EAAAA,UAC9B,IACEc,EAAO0H,MAAK,EAAGrX,QAASoqB,KAAmBA,GAAc0pC,mBAC3D,CAACnkD,IAGGmrC,GAAc1sC,EAAAA,EAAAA,cAClB,EAAG0B,KAAIiuC,eACL0V,GAAc,GACdx0D,GAASa,EAAAA,EAAAA,KAAgB,IAGzB+c,EAAW,CACT/f,KAAMC,EAAAA,GAAYkoB,OAClBiE,cAAelpB,EAAQ8P,GACvB7S,KAAM,CACJH,KAAM,WACNG,KAAM,CACJ82D,MAAOjkD,EACPkkD,YAAajW,MAKnBr1B,EAAiBq1B,EAAS,GAE5B,CAAC9+C,EAAU4d,EAAY7c,EAAQ8P,GAAI4Y,IAGrC,OACG8qC,IACD9zD,GACCm0D,GACAzxD,GAMDinB,EAAAA,EAAAA,MAAA,OAAKjC,WAAWA,EAAAA,EAAAA,GAAU,cAAe,6BAA6Ba,SAAA,CACnE0rC,IACChqC,EAAAA,EAAAA,KAAA,KAAGvC,WAAWA,EAAAA,EAAAA,GAAU,wBAAwBa,SAAE0rC,KAEpDtqC,EAAAA,EAAAA,MAACU,EAAAA,EAAgB,CACfjtB,KAAK,cACLktB,iBAAiB,EACjBtT,MAAOA,KACHrQ,EAAK4hB,SAAA,EAET0B,EAAAA,EAAAA,KAACu0B,GAAe,CACd92B,UAAU,kCACVi3B,kBAAmBvD,EACnBsD,YAAaA,IAEdwV,IACCjqC,EAAAA,EAAAA,KAAA,KAAGvC,WAAWA,EAAAA,EAAAA,GAAU,uBAAuBa,SAAE2rC,UApBhD,IAuBD,IRzBV,GA3BwBK,EAAGhsC,eACzB,MAAM,iBAAEzlB,IAAqBrB,EAAAA,EAAAA,MAEvB+yD,GAAqBrlD,EAAAA,EAAAA,UAAQ,IAG1BpS,OAAOwG,KAAKsuD,IAAkBxqD,QACnC,CAAC+W,EAAK/b,KACG,IACF+b,EACH,CAAC/b,GAAM,IACFwvD,GAAiBxvD,MAChBS,EAAmBA,EAAiBT,GAAO,CAAC,MAItD,CAAEo1B,SAAU45B,MAEb,CAACvuD,IAEJ,OACEmnB,EAAAA,EAAAA,KAACwqC,EAAiBzb,SAAQ,CAAC90C,MAAOswD,EAAmBjsC,SAClDA,GACyB,iBShEhC,MAQA,IAR0BhG,EAAAA,EAAAA,eAMvB,MCgBH,GArBkCvL,IAChC,MAAM09C,GAAahyC,EAAAA,EAAAA,YAAW+xC,GACxBE,EAAgBD,EAAW19C,EAAM5Z,MACvC,IAAIogC,EAAYm3B,EAAc39C,EAAM1W,QAAQlD,MACxCw3D,EAAe,KAcnB,OAZI59C,EAAM1W,QAAQlD,OAASyU,EAAAA,GAAaiT,eACtC8vC,EAAeD,EAAc39C,EAAM1W,QAAQ/C,KAAK6rB,OAAOhsB,OAGtC,gBAAf4Z,EAAM5Z,OACRogC,EAAYm3B,EAAc39C,EAAM5Z,OAG9BogC,GAAkC,mBAAdA,IACtBA,EAAYA,EAAUxmB,EAAM1W,QAAQ/C,KAAKH,OAGpC,CAACogC,GAAak3B,GAAYj9B,SAAUm9B,EAAa,EC2C1D,GAnDK,EAAG59C,QAAO69C,qBACb,MAAM,UAAEC,EAAS,UAAEC,IAAc,KAAAryC,YAAW,KACtC,WAAEvF,IAAe,UACjB6X,EAAM8/B,EAAU99C,EAAM1W,QAAQ8P,KAC9B,aAAE6Q,EAAY,UAAEP,IAAc,QAAa,CAC/CO,aAAc+T,EACdhU,mBAAmB,IAEfzhB,GAAW,WACVi+B,EAAWo3B,GAAgB,GAAyB59C,GAc3D,IAZA,KAAAyK,YAAU,KACR,GAAIf,IAAaq0C,aAAS,EAATA,EAAWr5C,SAAS1E,EAAM1W,QAAQ8P,KAAK,CACtD,MAAM4kD,EAAUD,EAAU1tD,QACxB,CAAC9B,EAAK6K,IAAS7K,EAAImW,SAAS1E,EAAM1W,QAAQ8P,IAAuB7K,EAAjBA,EAAIgC,OAAO6I,IAC3D,IAGF7Q,GAAS,QAAcy1D,IACvB73C,EAAW,CAAE/f,KAAM,KAAYoZ,KAAMvG,OAAQ+kD,GAC/C,IACC,CAACz1D,EAAUyX,EAAM1W,QAAQ8P,GAAIsQ,EAAWvD,EAAY43C,KAElDv3B,EACH,OAAO,KAGT,MAAMxS,EAAa,CAAC,sBAcpB,MAZmB,SAAfhU,EAAM5Z,KACR4tB,EAAWxiB,KAAK,mCACPwO,EAAM1W,QAAQqR,WACvBqZ,EAAWxiB,KAAK,mCAEhBwiB,EAAWxiB,KAAK,oCAGdqsD,GACF7pC,EAAWxiB,KAAK,wCAIhB,gBAAIkf,WAAW,OAAUsD,GAAagK,IAAK/T,EAAY,UACpDjK,EAAMxb,gBAAiB,SAAC,GAAa,CAACwb,MAAOA,KAC9C,SAACwmB,EAAS,CAACxmB,MAAOA,EAAK,UACrB,SAAC49C,EAAY,CAAC59C,MAAOA,QAG1B,iBC1DH,MAoCA,GApCei+C,KACb,MAAM,GAAE7kD,IAAO+T,EAAAA,EAAAA,OAA2B,CAAC,EAE3C,OACE8F,EAAAA,EAAAA,KAAA,MACEvC,WAAWA,EAAAA,EAAAA,GACT,qBACA,oCACAa,UAEFoB,EAAAA,EAAAA,MAAA,OACEjC,WAAWA,EAAAA,EAAAA,GACT,UACA,wBACA,yBACAa,SAAA,EAEF0B,EAAAA,EAAAA,KAACQ,GAAAA,EAAgB,CACfC,aAAc,CACZ/Y,YAAY,EACZc,YAAarC,MAGjB6Z,EAAAA,EAAAA,KAAA,OAAKvC,WAAWA,EAAAA,EAAAA,GAAU,iBAAiBa,UACzCoB,EAAAA,EAAAA,MAAA,QAAMjC,WAAWA,EAAAA,EAAAA,GAAU,UAAUa,SAAA,EACnC0B,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,eAAgB,UAC3CuC,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,eAAgB,UAC3CuC,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,eAAgB,YAC3CuC,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,eAAgB,mBAI9C,ECpBHwtC,GAAS,KACb,MAAMjlD,GAAS,UAEf,IAAIklD,EAAkB,KACtB,OACE,8BACGllD,EAAOpM,KAAKmT,IACX,MAAM,KAAE5Z,EAAI,QAAEkD,GAAY0W,EAE1B,IAAIo+C,GAAqB,EACzB,GAAa,gBAATh4D,GAAmC,iBAATA,EAAyB,CACrD,MAAM,YAAEqV,EAAW,WAAEd,GAAerR,EAC9B+0D,EAAqB1jD,EACvB,4BACAc,EACe,SAAfuE,EAAM5Z,MAAmB+3D,IAAoBE,IAC/CD,GAAqB,GAEvBD,EAAkBE,CACpB,CAEA,OACE,SAAC,GAAK,CAEJr+C,MAAOA,EACP69C,eAAgBO,GAFXp+C,EAAM1W,QAAQ+B,KAAO2U,EAAM1W,QAAQ8P,GAI3C,KAGN,EA4CH,GAzCqB,KACnB,MAAM,EAAEjK,IAAM,SACRd,GAAY,UACZiwD,EClDYC,EAAoBrxD,EAAUqjD,EAAQ,MACxD,MAAOiO,EAAgBC,IAAqBr0C,EAAAA,EAAAA,UAAYld,GAClDwxD,GAAarlC,EAAAA,EAAAA,QAAsC,MAUzD,OARA5O,EAAAA,EAAAA,YAAU,KACRi0C,EAAW/zC,QAAUviB,YAAW,IAAMq2D,EAAkBvxD,IAAQqjD,GAEzD,KACLvoD,aAAa02D,EAAW/zC,QAAQ,IAEjC,CAACzd,EAAOqjD,IAEJiO,CAAc,EDsCM,CAAYnwD,EAAWA,EAAY,EAAI,KAC5D,OAAEgY,IAAW,UACb3I,GAAmB,UACnBihD,GAAsB,UAO5B,OACE,gCACGt4C,IACC,cACEqK,WAAW,OAAU,aACrB4zB,KAAM,IAAI5mC,IACVsV,QAXgBrsB,IACtBA,EAAEsuD,iBACF0J,GAAqB,EASQ,SAEtBxvD,EAAE,mBAIP,gBAAKuhB,WAAW,OAAU,cAAa,UACrC,iBAAKA,WAAW,OAAU,2BAA0B,WAClD,SAAC,EAAiB,KAClB,gBAAIA,WAAW,OAAU,gBAAe,WACtC,SAAC,GAAe,WACd,SAACwtC,GAAM,MAERI,GAAqB,SAAC,GAAM,IAAM,MACnC,SAAChb,EAAsB,cAKhC,iDEpFH,MAsBA,GAtBesb,EAAGC,gBAAettC,WAAUnZ,YACzC,MAAMsF,GAAmBkP,EAAAA,EAAAA,MACnBkyC,GAAqBrtC,EAAAA,EAAAA,MAE3B,OACEkB,EAAAA,EAAAA,MAAA,WACEvZ,GAAIsE,EACJgT,WAAWA,EAAAA,EAAAA,GAAUmuC,GACrB,mBAAkBC,EAClB1d,SAAS,KAAI7vB,SAAA,EAEb0B,EAAAA,EAAAA,KAAA,MACEvC,WAAWA,EAAAA,EAAAA,GAAW,GAAEmuC,YACxBzlD,GAAI0lD,EAAmBvtC,SAEtBnZ,IAEFmZ,IACO,ECoDd,GAjE0BwtC,KACxB,MAAM,EAAE5vD,IAAMsI,EAAAA,EAAAA,KACRknD,GAAsB1pC,EAAAA,GAAAA,MACtB+pC,GAAetnC,EAAAA,GAAAA,MACf,UAAEE,IAAchT,EAAAA,GAAAA,MAEhB,SAAE9H,EAAQ,UAAEC,EAAS,MAAEG,EAAK,aAAEyc,IAClCT,EAAAA,GAAAA,KAeI+lC,EAAoBliD,EAAY,EAChC3E,EACFjJ,EADU8vD,EACR,mCACA,wCAEN,OACEhsC,EAAAA,EAAAA,KAAC2rC,GAAM,CAACC,cAAc,OAAOzmD,MAAOA,EAAMmZ,SACvC0tC,IACCtsC,EAAAA,EAAAA,MAAAC,EAAAA,SAAA,CAAArB,SAAA,EACE0B,EAAAA,EAAAA,KAAA,OAAKvC,WAAWA,EAAAA,EAAAA,GAAU,yBAAyBa,SAChDzU,IACC6V,EAAAA,EAAAA,MAAAC,EAAAA,SAAA,CAAArB,SAAA,EACE0B,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,oBAAoBa,SAC5CpiB,EAAE,sCAEL8jB,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,qBAAqBa,SAC7CpiB,EAAE,mCAAoC+N,WAK/CyV,EAAAA,EAAAA,MAAA,OAAKjC,WAAWA,EAAAA,EAAAA,GAAU,iBAAiBa,SAAA,EACzC0B,EAAAA,EAAAA,KAAA,UACE7sB,KAAK,SACLsqB,WAAWA,EAAAA,EAAAA,GAAU,SAAU,mBAC/BsC,QAtCSnnB,KACnBmzD,IACArlC,GAAa,GACbglC,IACA/mC,EAAU,2BAA2B,EAkCLrG,SAErBpiB,EAAE,uCAEL8jB,EAAAA,EAAAA,KAAA,UACE7sB,KAAK,SACLsqB,WAAWA,EAAAA,EAAAA,GAAU,SAAU,mBAC/BsC,QAtCSksC,KACnBvlC,IACAglC,IACA/mC,EAAU,sBAAsB,EAmCArG,SAErBpiB,EAAE,2CAKJ,gBC9Db,MAqCA,GArCiCgwD,KAC/B,MAAM,EAAEhwD,IAAMsI,EAAAA,EAAAA,KACRunD,GAAetnC,EAAAA,GAAAA,MACblxB,KAAM44D,IAAqBjyC,EAAAA,EAAAA,OAA2B,CAAC,GAEzD,aAAEthB,EAAY,YAAEquB,IAAgBF,EAAAA,GAAAA,KAOtC,OACE/G,EAAAA,EAAAA,KAAC2rC,GAAM,CACLC,cAAc,SACdzmD,MAAOjJ,EAAE,iCAAkC,CAAE3I,KAAM44D,IAAoB7tC,UAEvEoB,EAAAA,EAAAA,MAAA,OAAKjC,WAAWA,EAAAA,EAAAA,GAAU,mBAAmBa,SAAA,EAC3C0B,EAAAA,EAAAA,KAAA,UACE7sB,KAAK,SACLsqB,WAAWA,EAAAA,EAAAA,GAAU,SAAU,mBAC/BsC,QAdoBqsC,KAC1BL,IACAnzD,GAAc,EAYqB0lB,SAE5BpiB,EAAE,8CAEL8jB,EAAAA,EAAAA,KAAA,UACE7sB,KAAK,SACLsqB,WAAWA,EAAAA,EAAAA,GAAU,SAAU,mBAC/BsC,QAASkH,EAAY3I,SAEpBpiB,EAAE,+CAGA,EC5BAmwD,GAAkBA,KAC7B,MAAM,WAAEn5C,IAAevB,EAAAA,EAAAA,OACjB,SAAE9a,IAAa2sB,EAAAA,EAAAA,OACf,gBAAElH,GAAoBzlB,GAAY,CAAC,EACnCy1D,GAAgBlmC,EAAAA,EAAAA,QAAO,MACvBmmC,GAAuBnmC,EAAAA,EAAAA,QAAO,MAC9BomC,GAAWpmC,EAAAA,EAAAA,SAAO,GAClBqmC,GAAmBrmC,EAAAA,EAAAA,QAAO,OAEhC5O,EAAAA,EAAAA,YAAU,IACD,KACLk1C,cAAcD,EAAiB/0C,SAC/B3iB,aAAau3D,EAAc50C,SAC3B3iB,aAAaw3D,EAAqB70C,QAAQ,GAE3C,IAEH,MAAMi1C,EAAkBA,CAACv2D,EAAOw2D,KAC9B15C,EAAW,CACT/f,KAAMC,EAAAA,GAAYmoB,OAClBnlB,WACIkmB,GAAmBA,EAAgB9qB,QACnC,CACE8B,KAAM,CACJs5D,mBAGJ,CAAC,GACL,EAGJ,OAAQl5D,IACDA,EAAEm2B,MAAmB,UAAXn2B,EAAEm2B,MAAmC,KAAdn2B,EAAEo2B,UAIxC0iC,EAAS90C,SAAU,EACd+0C,EAAiB/0C,UACpBi1C,GAAgB,EAAMj5D,EAAE+I,OAAOxC,OAC/BwyD,EAAiB/0C,QAAUm1C,aAAY,KAChCL,EAAS90C,QAGH4E,GAAmBA,EAAgB9qB,SAC5Cm7D,GAAgB,EAAMj5D,EAAE+I,OAAOxC,QAH/ByyD,cAAcD,EAAiB/0C,SAC/B+0C,EAAiB/0C,QAAU,KAG7B,GACC5mB,EAAAA,IAGLiE,aAAau3D,EAAc50C,SAC3B3iB,aAAaw3D,EAAqB70C,SAElC40C,EAAc50C,QAAUviB,YAAW,KACjCq3D,EAAS90C,SAAU,CAAK,GACvB,KAEH60C,EAAqB70C,QAAUviB,YAAW,KACxCw3D,GAAgB,EAAOj5D,EAAE+I,OAAOxC,MAAM,GACrCnJ,EAAAA,GAAc,CAClB,EAGUg8D,GAAiBA,KAC5B,MACEzhD,QAAS0hD,EAAY,OACrB1jD,EAAM,aACNC,EACAH,QAAS6jD,EACT9jD,gBAAiB+jD,IACfr0C,EAAAA,EAAAA,MAAwBhQ,UACtBtT,GAAW+R,EAAAA,EAAAA,MAEX6lD,EAAc5jD,GAAgBD,GAAU0jD,EACxCI,EACJF,EAAqBC,IAAgBF,EAAaE,IAAgB,CAAC,EAE/DE,GAA+B3oD,EAAAA,EAAAA,cAClCxK,IACC3E,GAASya,EAAAA,EAAAA,IAAwB9V,GAAO,GAE1C,CAAC3E,IAGG+3D,GAA0B5oD,EAAAA,EAAAA,cAC7BsH,IACCzW,GAAS2a,EAAAA,EAAAA,IAAmBlE,GAAW,GAEzC,CAACzW,IAGGg4D,GAAwB7oD,EAAAA,EAAAA,cAC3BsH,IACCzW,GAAS4a,EAAAA,EAAAA,IAAiBnE,GAAW,GAEvC,CAACzW,IAGGi4D,GAAuB9oD,EAAAA,EAAAA,cAAY,KACnC6E,EACFgkD,EAAsB,MAEtBD,EAAwBN,EAC1B,GACC,CACDzjD,EACAyjD,EACAO,EACAD,IAGF,MAAO,CACLH,cACAC,qBACAl9C,mBAAoBo9C,EACpBn9C,iBAAkBo9C,EAClBC,uBACAx9C,wBAAyBq9C,EAC1B,mVC7GY,SAASI,GAAa,gBACnClvC,EAAQ,OACRhkB,EAAM,YACND,EAAW,QACXozD,EAAO,SACPC,EAAQ,iBACRC,GAAgB,EACbjxD,EAAK,KAP2B,6EASnC,MAAMpH,GAAW,UACX4K,GAAS,SAAaoR,GAC1Bg9B,EAAsBh9B,EAAO,CAAEhX,cAE1Bs0C,EAAagf,IAAkB,IAAAz2C,WAAS,IACxC02C,EAAgBC,IAAqB,IAAA32C,UAAS,CAAC,IAC9C03B,QAASkf,EAAmBjf,OAAQkf,G7CFxC,SAAyB9tD,EAAQytD,GACrC,MAAM7e,GAAS5pC,EAAAA,EAAAA,UACb,I8CnCE,SAAmBhF,EAAQ+tD,EAAkC,CAAC,GAClE,OAAOn7D,OAAO2hB,QAAQw5C,GAAQ7wD,QAAO,CAAC0xC,GAAS12C,EAAK81D,YAClD,MAAMC,EAAkBzyD,MAAM6B,QAAQ2wD,GAElCA,EADA,CAACA,GAGL,IAAK,IAAI1yD,EAAI,EAA6B,QAA1BrJ,EAAAqJ,GAAI2yD,aAAc,EAAdA,EAAgB50D,eAAM,IAAApH,GAAAA,EAAOqJ,IAC/C,IAAK2yD,EAAe3yD,GAAGw1B,GAAG9wB,EAAO9H,GAAM+1D,EAAe3yD,GAAG4yD,cAAe,CACtEtf,EAAO12C,GAAO+1D,EAAe3yD,GAAGwV,UAChC,KACF,CAEF,OAAO89B,CAAM,GACZ,CAAC,EACN,C9CqBUuf,CAASnuD,EAAQytD,IACvB,CAACztD,EAAQytD,IAEX,MAAO,CACL9e,QAAwC,IAA/B/7C,OAAOwG,KAAKw1C,GAAQv1C,OAC7Bu1C,SAEJ,C6CNIwf,CAAepuD,EAAQytD,GACnB7e,GAAS,IAAA5pC,UACb,IAAO,OAAD,wBACD8oD,GACAH,IAEL,CAACG,EAAkBH,KAIrB,IAAA17B,kBAAgB,KAEd78B,GAAS,QAAa,CAAEgF,SAAQD,gBAAe,GAC9C,CAACC,EAAQD,EAAa/E,KAGzB,IAAAkiB,YAAU,IACD,KAELliB,GAAS,QAAe,CAAEgF,WAAU,GAErC,CAACA,EAAQD,EAAa/E,IAEzB,MAAMsF,GAAqB,IAAA6J,cACzB,CAAClR,EAAM0G,KACL3E,GAAS,QAAqB,CAAEgF,SAAQ/G,OAAM0G,UAAS,GAEzD,CAACK,EAAQhF,IAGLuF,GAAuB,IAAA4J,cAC3B,CAAClR,EAAM2G,KACL5E,GAAS,QAAuB,CAAEgF,SAAQ/G,OAAM2G,YAAW,GAE7D,CAAC5E,EAAUgF,IAIPi0D,GAAW,IAAA9pD,cACf,CAAClR,EAAMgE,KACLu2D,GAAmBrvB,GACV,OAAP,wBACKA,GAAG,CACN,CAAClrC,GAAOgE,KAEV,GAEJ,CAACu2D,IAGGnf,GAAe,IAAAlqC,cAClB/Q,IACCA,EAAEsuD,iBAEF,MAAMwM,EAA6D,SAA9C96D,EAAE+6D,UAAUvmC,aAAa,iBAC9C0lC,GAAgBY,IACXA,GAAgBT,IACnBz4D,GAAS,SAAgB,IACzBo4D,EAASxtD,EAAQ,CAAEtF,qBAAoB2zD,aACzC,GAEF,CACER,EACAz4D,EACAo4D,EACAxtD,EACAtF,EACA2zD,KAIJ,IAAA/2C,YAAU,KACJi2C,GACFA,EAAQ,CACN3e,SACAF,cACAC,QAAwC,IAA/B/7C,OAAOwG,KAAKw1C,GAAQv1C,QAEjC,GACC,CAACq1C,EAAaE,EAAQ2e,IAEzB,MAAMiB,GAAe,IAAAxpD,UACnB,KAAM,CACJ5K,SACA4F,SACA4uC,SACAD,QAAwC,IAA/B/7C,OAAOwG,KAAKw1C,GAAQv1C,OAC7Bq1C,cACAD,eACAgf,mBACA/yD,qBACAC,0BAEF,CACEP,EACA4F,EACA4uC,EACAF,EACAD,EACAgf,EACA/yD,EACAC,IAIJ,OAAKP,EAIAozD,GAMH,SAAC3e,EAAQ,iBAAKryC,EAAK,CAAEzC,MAAOy0D,EAAY,SACrCpwC,MANH3Z,QAAQpN,MAAM,2BACP,OALPoN,QAAQpN,MAAM,yBACP,KAYX,gBE5HA,SA5BA,UACEkmB,UAAW+2B,EAAc,yBACzBma,KACGjyD,IAEH,MAAM,aAAEiyC,EAAY,QAAEE,EAAO,YAAED,G/Ce3B,WACJ,MAAM,aAAED,EAAY,YAAEC,EAAW,QAAEC,GAAYI,IAE/C,MAAO,CACLN,eACAC,cACAC,UAEJ,C+CvBiD+f,GAEzCC,EAAc,CAAC,QAYrB,OAVKF,GAA4B/f,IAC/BigB,EAAYtwD,KAAK,mBAEbswC,EACFggB,EAAYtwD,KAAK,eAEjBswD,EAAYtwD,KAAK,mBAKnByhB,EAAAA,EAAAA,KAAA,QACE0tC,SAAU/e,EACVlxB,WAAWA,EAAAA,EAAAA,GAAU,IAAIoxC,EAAara,OAClC93C,GAGV,ECzBe,SAAS4B,IAAM,GAAE6H,EAAE,MAAE5O,IAClC,MAAOya,EAAa88C,IAAkB33C,EAAAA,EAAAA,WAAS,GAM/C,OALAK,EAAAA,EAAAA,YAAU,KACR,MAAMu3C,EAAU55D,YAAW,IAAM25D,GAAe,IAAO,KACvD,MAAO,IAAM/5D,aAAag6D,EAAQ,GACjC,KAGD/uC,EAAAA,EAAAA,KAAA,OACEvC,WAAWA,EAAAA,EAAAA,GAAU,SACrB,YAAU,YACV,cAAY,OAAMa,SAEjBtM,GAAeza,IACdmoB,EAAAA,EAAAA,MAAA,QAAMvZ,GAAIA,EAAIsX,WAAWA,EAAAA,EAAAA,GAAU,kBAAkBa,SAAA,EACnD0B,EAAAA,EAAAA,KAACC,EAAAA,EAAI,CAAC1sB,KAAK,QAAQ2sB,KAAK,KAAKC,IAAI,KAChC5oB,MAKX,CCZA,MAgCA,GAhCwD,EACtDy3D,cACA7oD,KACA8oD,YACA7e,aACA8e,WACAl+C,YACAsN,eAGE,gCACG0wC,IACC,iBACE7oD,GAAI,GAAGA,iBACPsX,WAAW,OAAU,uBAAsB,SAE1CuxC,KAIL,SAAC,GAAK,CAAC7oD,GAAI,GAAGA,UAAY5O,OAAQ23D,GAAYl+C,KAE9C,iBAAKyM,WAAW,OAAU,yBAAwB,WAChD,kBAAO0xC,QAAShpD,EAAIsX,WAAW,OAAU2yB,GAAW,SACjD6e,IAEF3wC,QCuBT,SAhDA,SAAe,UACbnY,EAAE,KACF5S,EAAI,KACJJ,EAAI,UACJ87D,EAAS,WACT7e,EAAU,YACV4e,EAAc,KACd,mBAAoBI,GAAe,EAChC1yD,2UAAK,GARK,gFAUb,MAAM,YAAEkyC,GAAgBK,KACjBogB,GAAO,MAAE93D,IAAW23C,EAAe37C,GACpCwR,EAAW6pC,GAAer3C,EAE1B+3D,EAAiB,GAYvB,OAXIF,GACFE,EAAe/wD,KAAK6wD,GAElBJ,GACFM,EAAe/wD,KAAK,GAAG4H,kBAErBpB,GACFuqD,EAAe/wD,KAAK,GAAG4H,YAKvB,SAAC,GAAkB,CACjBA,GAAIA,EACJ6oD,YAAaA,EACbE,UAAWnqD,EACXiM,UAAWzZ,EACX03D,UAAWA,EACX7e,WAAYA,EAAU,UAEtB,gCACEjqC,GAAIA,EACJ5S,KAAMA,EACNJ,KAAMA,EAAI,eACI4R,EAAW,OAAS,QAAO,mBACvBuqD,EAAelvD,KAAK,MAAQ,MAC1CivD,EACA3yD,KAIZ,ECjDe,SAAS6yD,IAAc,YAAEhgB,EAAW,WAAEigB,IACnD,MAAM,EAAEtzD,IAAM,UACR,cAAEomB,IAAkB,WACpB,UAAEqC,IAAc,UAChB8qC,EAAcpD,MACd,wBAAEt8C,GAA4B+8C,MAC9B,YAAE5c,EAAW,MAAEC,EAAK,WAAEC,GAC1BH,EAAwBV,IAEpB,kBACJQ,EAAiB,wBACjBF,EAAuB,sBACvBC,EAAqB,eACrBF,GACEN,EAAkBC,KACf,MAAEt1C,IAAWi1C,EAAeK,GAE7Bpa,IAAal7B,EAEby1D,GAAc,IAAAjrD,cAAY,KAC1BorC,GACFvtB,EAAcpmB,EAAE,6BAA8B,CAAE8C,MAAO4wC,KAGzDjrB,EAAU,gBAAgB,GACzB,CAACzoB,EAAGomB,EAAeutB,EAAyBD,EAAgBjrB,IAiB/D,OAbA,IAAAwN,kBAAgB,KACdpiB,EAAwBolB,GAEjB,KACLplB,GAAwB,EAAM,IAE/B,CAACA,EAAyBolB,KAQ3B,UAAC,GAAI,CACH1X,WAAW,OAAU,cACrBkxC,0BAAwB,EACxBgB,WAAW,OAAM,WAEjB,iBACElyC,WAAW,OAAU,CACnB,4BACIoyB,IAA4BC,EAC5B,CAAC,qBACD,MACAA,EAAwB,CAAC,sBAAwB,KACrD,WAEF,SAAC,GAAK,CACJ3pC,GAAIqpD,EACJr8D,KAAK,OACLI,KAAMg8C,EACN9xB,WAAW,OAAU,eACrBmyC,aAAa,MACb1f,YAAaA,EACb+e,UAAW9e,EACXC,YAAY,OAAUA,GAAW,eACnBL,EAAoBD,EAAwB,KAC1D+f,QAASJ,EACTK,QAASJ,KAEX,gBAAKjyC,WAAW,OAAU,mBAAkB,SACzCoyB,IAA2B,0BAAOD,UAGvC,mBACEnyB,WAAW,OAAU,SAAU,iBAC/BtqB,KAAK,SACLyzD,cAxCqB75C,IAEzBA,EAAMi1C,gBAAgB,EAsCc,iBAChB7sB,GAAY2a,EAAwB,OAAS,KAAI,UAEjE,SAAC,IAAI,CAACv8C,KAAK,OAAO2sB,KAAK,KAAKC,IAAKjkB,EAAE,2BAI3C,CCpFO,MAAM6zD,GAAuB,mBAErB,SAASC,OAAetzD,IACrC,MAAM,OAAE0W,EAAM,cAAEtN,IAAkBuN,EAAAA,EAAAA,MAC5Bm8C,GAAa71C,EAAAA,EAAAA,MACbs2C,GAAsBjuC,EAAAA,EAAAA,OACtB,YAAEE,IAAgBvQ,EAAAA,EAAAA,MAClBg9B,GAAelqC,EAAAA,EAAAA,cACnB,CAACvE,GAAUtF,yBACTsnB,EAAY,CAAE5uB,KAAM4M,EAAO6vD,MAC3Bn1D,EAAmBm1D,GAAsB,IACzCE,IAEK78C,GACHtN,EAAchO,GAAAA,EAAiBC,KACjC,GAEF,CAACmqB,EAAa+tC,EAAqB78C,EAAQtN,IAG7C,OACEka,EAAAA,EAAAA,KAACwtC,GAAY,IACP9wD,EACJpC,OAAO,YACPD,aAAa,EACbqzD,SAAU/e,EAAarwB,UAEvB0B,EAAAA,EAAAA,KAACuvC,GAAa,CACZhgB,YAAawgB,GACbP,WAAYA,KAIpB,CCvCA,MAoCA,GApCuBU,KACrB,MAAM,EAAEh0D,IAAMsI,EAAAA,EAAAA,MACR,eAAE2G,IAAmB8X,EAAAA,EAAAA,MAE3B,OACEjD,EAAAA,EAAAA,KAAA,OAAKvC,WAAWA,EAAAA,EAAAA,GAAU,YAAYa,SACnCnT,EAAevR,KAAI,EAAGuM,KAAI5S,OAAMgd,WAAUC,YAAWjZ,YACpDmoB,EAAAA,EAAAA,MAAA,OAAcjC,WAAWA,EAAAA,EAAAA,GAAU,sBAAsBa,SAAA,EACvDoB,EAAAA,EAAAA,MAAA,OAAKjC,WAAWA,EAAAA,EAAAA,GAAU,kBAAkBa,SAAA,EAC1C0B,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,6BAA6Ba,SACrD/qB,KAEHysB,EAAAA,EAAAA,KAAA,QACEvC,WAAWA,EAAAA,EAAAA,GAAU,8BAA8Ba,SAClD,GAAE/N,WAEPyP,EAAAA,EAAAA,KAAC1hB,GAAK,CAAC/G,MAAOA,KACdyoB,EAAAA,EAAAA,KAAA,YACEvC,WAAWA,EAAAA,EAAAA,GAAU,iBACrBo0B,KAAK,cACL,gBAAc,IACd,gBAAc,MACd,aAAY31C,EAAE,6BAA8B,CAAEoU,SAAU/c,IACxDu/C,IAAI,MACJ,gBAAeviC,EACftW,MAAOsW,EACP,YAAWC,EAAU8N,SAEnB,GAAE/N,SArBEpK,MAyBR,ECrCGgqD,GAAeA,CAACn/B,EAAIhgB,EAAWo9C,EAAe,QAAS,CAClEp9B,KACAhgB,YACAo9C,iBCHWgC,GAAmBA,CAACC,EAAU1tC,KACzC,IAAIksB,GAAU,EACd,IAAK,IAAIrzC,EAAI,EAAGA,EAAI60D,EAAS92D,OAAQiC,IAC/B60D,EAAS70D,GAAG0kB,KAAOyC,IACrBksB,GAAU,GAId,OAAOA,CAAO,EAGHyhB,GAA4BC,KACrCA,GAAah3D,OAAS,EAGbi3D,GAAiB/xB,IAC5B,MAEMgyB,EAAahyB,GAAOA,EAAIn/B,OAC9B,SAAUmxD,IAAcA,EAAWtyB,MAFjC,ibAE8C,EAIrCuyB,GAAoBjyB,KAAUA,EChB5B,SAASkyB,IAAU,GAChCxqD,EAAE,KACF5S,EAAI,UACJ07D,EAAS,YACTD,EAAW,WACX4B,EAAU,OACVC,IAEA,MAAM,YAAEjiB,GAAgBK,KACjB6hB,EAAaC,IAAkB55C,EAAAA,EAAAA,WAAS,KACxC,QAAEi4B,EAAO,OAAEC,IAAU,MAAE93C,IAAW23C,EAAe37C,GAClDy9D,GAAUxyC,EAAAA,EAAAA,MACVyyC,GAAgBzyC,EAAAA,EAAAA,MAChB0yC,GAAW1yC,EAAAA,EAAAA,MACXzZ,EAAW6pC,GAAer3C,EAE1B+3D,EAAiB,CAAC4B,GACpBlC,GACFM,EAAe/wD,KAAK0yD,GAElBlsD,GACFuqD,EAAe/wD,KAAKyyD,GAGtB,MAAMtB,GAAcjrD,EAAAA,EAAAA,cAAY,KAC9BssD,GAAe,EAAK,GACnB,CAACA,IAEEI,GAAa1sD,EAAAA,EAAAA,cAAY,KAC7BssD,GAAe,GACf1hB,GAAQ,GACP,CAAC0hB,EAAgB1hB,IAEd+hB,GAAe3sD,EAAAA,EAAAA,cAClB/Q,IACC,MAAM29D,EAAc,CAClB50D,OAAQ,CACNxC,MAAOvG,EAAE+I,OAAO60D,QAIpBliB,EAAQiiB,EAAY,GAEtB,CAACjiB,IAGH,OACE1vB,EAAAA,EAAAA,MAAA,OAAKjC,WAAWA,EAAAA,EAAAA,GAAU,qBAAqBa,SAAA,CAC5C0wC,IACChvC,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,wBAAyBtX,GAAI8qD,EAAc3yC,SACnE0wC,KAGLhvC,EAAAA,EAAAA,KAAC1hB,GAAK,CAAC6H,GAAI6qD,EAASz5D,MAAOwN,GAAYxN,KACvCyoB,EAAAA,EAAAA,KAAA,OACEvC,WAAWA,EAAAA,EAAAA,GAAU,CACnB,iBACIqzC,EAAc,CAAC,gBAAkB,KACpCxyC,UAEHoB,EAAAA,EAAAA,MAAA,SAAOyvC,QAAShpD,EAAIsX,WAAWA,EAAAA,EAAAA,GAAU,iBAAiBa,SAAA,EACxD0B,EAAAA,EAAAA,KAACC,EAAAA,EAAI,CAAC1sB,KAAK,SAAS2sB,KAAK,KAAKC,IAAI,MAClCT,EAAAA,EAAAA,MAAA,OAAApB,SAAA,EACE0B,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,CAAC,wBAAwBa,SACjD2wC,KAEHjvC,EAAAA,EAAAA,KAAA,SACE7Z,GAAIA,EACJsX,WAAWA,EAAAA,EAAAA,GAAU,iBACrBtqB,KAAK,OACLI,KAAMA,EACN2+C,SAAUkf,EACV,eAAcrsD,EAAW,OAAS,QAClC,mBAAkBuqD,EAAelvD,KAAK,KACtCywD,OAAQA,GAAU,KAClBf,QAASJ,EACTrgB,OAAQ8hB,KAEVnxC,EAAAA,EAAAA,KAAA,QACEvC,WAAWA,EAAAA,EAAAA,GAAU,kBACrB,cAAY,OACZtX,GAAI+qD,EAAS5yC,SAEZsyC,cAOf,CC3Fe,SAASW,IAAc,WACpCC,EAAU,YACVjiB,EAAW,OACXshB,EAAM,YACN7B,EAAW,YACX1rC,EAAW,WACXC,EAAU,cACVkuC,IAEA,MAAM,EAAEv1D,IAAMsI,EAAAA,EAAAA,OACLvK,MAAOo2D,IAAcnhB,EAAeK,GACvCmiB,EAAUrB,GAAYA,EAAS92D,OAAS,EACxCo4D,EAAmBD,EAAUrB,EAAS,GAAG98D,KAAO,GAEtD,OACEmsB,EAAAA,EAAAA,MAACkyC,GAAI,CAACn0C,WAAWA,EAAAA,EAAAA,GAAU,eAAea,SAAA,EACxC0B,EAAAA,EAAAA,KAAC2wC,GAAS,CACRp9D,KAAMg8C,EACNppC,GAAIqrD,EACJX,OAAQA,EACR5B,UAAW/yD,EAAE,wBACb00D,WAAY10D,EAAE,0BAA2B,CACvCw1D,UACAtsC,SAAUusC,IAEZ3C,YAAaA,KAEftvC,EAAAA,EAAAA,MAAA,OAAKjC,WAAWA,EAAAA,EAAAA,GAAU,4BAA4Ba,SAAA,EACpD0B,EAAAA,EAAAA,KAAA,UACE7Z,GAAImd,IAAgBC,EAAaiuC,OAAa/9D,EAC9CN,KAAK,SACL4sB,QAAS0xC,EACTh0C,WAAWA,EAAAA,EAAAA,GAAU,SAAU,oBAAqB,kBAAkBa,SAErEpiB,EAAE,kCAEL8jB,EAAAA,EAAAA,KAAA,UACEvC,WAAWA,EAAAA,EAAAA,GAAU,SAAU,mBAC/BtqB,KAAK,SAAQmrB,SAEZpiB,EAAE,sCAKb,CC5BA,MAAM21D,GAAW,eACXC,GAAgB,WA+LtB,GA7LetJ,KACb,MAAM,EAAEtsD,IAAMsI,EAAAA,EAAAA,MACR,WAAE2d,EAAU,cAAEG,IAAkBL,EAAAA,EAAAA,MAChCxX,GAAmBkP,EAAAA,EAAAA,MACnB+xC,GAAsB1pC,EAAAA,EAAAA,OAEtB,qBAAEgB,EAAoB,iBAAEP,EAAgB,QAAEE,IAC9CJ,EAAAA,EAAAA,MACIwvC,GAAkB3rC,EAAAA,EAAAA,QAAO,MACzB4rC,GAAY5rC,EAAAA,EAAAA,QAAOpD,IAEnB,qBAAEuqC,GAAyBT,MAC3B,WAAE3pC,EAAU,aAAEE,EAAY,YAAEC,EAAW,WAAEC,IAAeN,EAAAA,EAAAA,OAIxD,QAAEyuC,EAAO,iBAAEC,EAAgB,aAAEjhD,EAAY,eAAEuhD,EAAc,SAAE1hD,GCtCvC2hD,EAAC53D,EAAQ/G,KACnC,MAAM88D,GAAW54D,EAAAA,EAAAA,KAAa6Z,GAC5Bk9B,EAAsBl9B,EAAO,CAAEhX,SAAQ/G,YAKnC,eAAE4X,IAAmB8X,EAAAA,EAAAA,MAErByuC,EAAUrB,GAAYA,EAAS92D,OAAS,EAE9C,IAAImX,EAAe,KACfuhD,GAAiB,EACjB1hD,EAAW,EACf,GAAIpF,GAAkBA,EAAe5R,OAAS,EAAG,CAC/C,MAAM44D,EAAgBhnD,EAAe,GACrCuF,EAAeyhD,EAAczhD,aAC7BuhD,IAAmBE,EAAc56D,MACjCgZ,EAAW4hD,EAAc5hD,QAC3B,CAEA,MAAO,CACLmhD,UACAC,iBAAkBD,EAAUrB,EAAS,GAAG98D,KAAO,GAC/Cmd,eACAuhD,iBACA1hD,WACD,EDYC2hD,CAAoBL,GAAUC,IAC1BM,GAAiB5zC,EAAAA,EAAAA,MACjB6zC,GAAiBjsC,EAAAA,EAAAA,SAAO,GAExBksC,EAAkBp2D,EAAE,yBAA0B,CAClDgkB,MAAM0I,EAAAA,EAAAA,IAAYjG,KAEd4vC,GAAsBnsC,EAAAA,EAAAA,QAAO,IAC7BpP,GAAeoP,EAAAA,EAAAA,QAAO,OAE5B5O,EAAAA,EAAAA,YAAU,KAEN+6C,EAAoB76C,SACpBV,EAAaU,SAASuS,SAAS1iB,SAAS2iB,gBACL,UAAnC3iB,SAAS2iB,cAAcguB,SAEvB51B,EAAcgwC,GAEhBC,EAAoB76C,QAAU46C,CAAe,GAC5C,CAACA,EAAiBhwC,KAGrB9K,EAAAA,EAAAA,YAAU,KACJjH,EAAW,GAGT4R,EADG,IADC5R,EAEOrU,EAAE,4BAGD,GAAEqU,KAEpB,GACC,CAACA,EAAU4R,EAAYjmB,KAG1Bsb,EAAAA,EAAAA,YAAU,KACH66C,EAAe36C,SAAY4L,IAAeC,IAC7CF,IACAkqC,IACA7B,IAGAv2D,YAAW,KACTgtB,EAAWjmB,EAAE,6BAA6B,GACzC,MAELm2D,EAAe36C,QAAU6L,CAAU,GAClC,CACDD,EACAC,EACAF,EACAkqC,EACA7B,EACAvpC,EACAjmB,IAGF,MAAMyyC,GAAelqC,EAAAA,EAAAA,cACnB,EAAG4rD,eACDltC,EAAWktC,EAAS,IAGlB3E,GACF,GAEF,CAACvoC,GApEc,EAoEQuoC,IAGnB8G,GAAsB/tD,EAAAA,EAAAA,cAAY,KAClCiM,GACFA,EAAamwB,QAEfxd,IACAkqC,IACA7B,GAAqB,GACpB,CAACh7C,EAAc2S,EAAckqC,EAAsB7B,IAEhDiC,GAAmBzoD,EAAAA,EAAAA,UACvB,KAAM,CACJ,CAAC4sD,IAAgB,CAEf3B,IACE,IAAMntC,GACN9mB,EAAE,kCAEJi0D,GAAaG,GAA0Bp0D,EAAE,6BACzCi0D,GACEC,GACAl0D,EAAE,8BACFymB,OAIN,CAACA,EAASK,EAAsB9mB,IAGlC,OACE8jB,EAAAA,EAAAA,KAAA,OACEvC,WAAWA,EAAAA,EAAAA,GAAU,CACnB,YACgBw0C,EAAiB,CAAC,iBAAmB,KAEvDlnC,IAAK/T,EAAasH,UAElBoB,EAAAA,EAAAA,MAAC8tC,GAAY,CACXlzD,OAAQu3D,GACRx3D,aAAa,EACbqzD,SAAU/e,EACVgf,iBAAkBA,EAAiBrvC,SAAA,EAEjCgF,IAAgBC,KAChB7D,EAAAA,EAAAA,MAAAC,EAAAA,SAAA,CAAArB,SAAA,EACE0B,EAAAA,EAAAA,KAACkwC,GAAc,KACflwC,EAAAA,EAAAA,KAAA,OAAKvC,WAAWA,EAAAA,EAAAA,GAAU,4BAA4Ba,UACpD0B,EAAAA,EAAAA,KAAA,UACE7Z,GAAImd,IAAgBC,EAAa9Y,OAAmBhX,EACpDN,KAAK,SACL4sB,QAASyyC,EACTznC,IAAKgnC,EACLt0C,WAAWA,EAAAA,EAAAA,GACT,SACA,oBACA,kBACAa,SAEDpiB,EAAE,uCAKTonB,GAAeC,IACfvD,EAAAA,EAAAA,KAACuxC,GAAa,CACZhiB,YAAauiB,GACbN,WAAY/mD,EACZomD,OAAQpuC,EAAiBriB,KAAK,MAC9B4uD,YAAasD,EACb/uC,WAAYA,EACZD,YAAaA,EACbstC,WAAY10D,EAAE,0BAA2B,CACvCw1D,UACAtsC,SAAUusC,IAEZF,cAAee,KAIjBR,EAAUt6C,UACVgI,EAAAA,EAAAA,MAAAC,EAAAA,SAAA,CAAArB,SAAA,EACE0B,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,gBAAiBtX,GAAIisD,EAAe9zC,SAC5DpiB,EAAE,iCAEL8jB,EAAAA,EAAAA,KAAA,OAAKvC,WAAWA,EAAAA,EAAAA,GAAU,4BAA4Ba,UACpD0B,EAAAA,EAAAA,KAAA,UACE7Z,GAAImd,IAAgBC,EAAa9Y,OAAmBhX,EACpDN,KAAK,SACL4sB,QAASyyC,EACT/0C,WAAWA,EAAAA,EAAAA,GACT,SACA,oBACA,kBACAa,SAEDpiB,EAAE,0CAMT,EEjNI,SAAUu2D,GAAWlrC,EAAoB+1B,GACrD,MAAMmO,GAAarlC,EAAAA,EAAAA,QAAsB,MACnCssC,GAAgBtsC,EAAAA,EAAAA,QAAOmB,GAc7B,OAZA/P,EAAAA,EAAAA,YAAU,KACRk7C,EAAch7C,QAAU6P,CAAQ,GAC/B,CAACA,KAEJ/P,EAAAA,EAAAA,YAAU,IACa,iBAAV8lC,EAA2B,KAAe,GAErDmO,EAAW/zC,QAAUviB,WAAWu9D,EAAch7C,QAAS4lC,GAEhD,IAAMvoD,aAAa02D,EAAW/zC,WACpC,CAAC4lC,IAEGmO,CACT,CCTA,SAASkH,GACP9yC,GAEA,MAAwB,iBAAVA,CAChB,CAEA,MAAM+yC,GAAoB,CACxB/6D,SAAS,OAAU,uBACnBg7D,IAAI,OAAU,kBACdC,gBAAgB,OAAU,oBAGtBC,GAAyBjgE,OAAOoN,OAAO0yD,IAEhCI,GAAwB,CACnCC,YAAa,cACbC,SAAU,WACVJ,eAAgB,kBAgIlB,GAnHkD,EAChDx0C,WACAzU,WACAwX,UAAU,KACV8xC,uBAAuBH,GAAsBC,YAC7CG,yBAAyB,SACzBC,0BAA0B,SAC1B16D,YACAD,aAAa,MAEb,MAAM46D,GAAe,IAAAltC,SAAO,GAEtBmtC,EACJJ,IAAyBH,GAAsBF,gBAE1CU,EAAyBC,IAA8B,IAAAt8C,WAE5D,IAAOo8C,EAAmB,CAACX,GAAkBE,gBAAkB,MAE1DY,EAASC,IAAc,IAAAx8C,WAAS,IAAqB,IAAfze,IAEvCk7D,GAAqB,IAAA1uD,UACzB,IAAOvM,EAAYA,EAAYD,EAAaC,GAC5C,CAACD,EAAYC,IAGf85D,IAAW,IAAMkB,GAAW,IAAQ9pD,EAAW+pD,OAAqBngE,GACpEg/D,IAAW,IAAMkB,GAAW,IAAO9pD,EAAWnR,OAAajF,GAE3D,MAAMogE,GAAe,IAAA3uD,UAAQ,IAAMwuD,GAAW7pD,GAAU,CAACA,EAAU6pD,IAE7DI,GAAgC,QACpCV,GAGIW,GAAiC,QACrCV,GAGIW,EACqB,gBAAzBb,GAA0CK,EAAwBj6D,OAAS,EAsD7E,OApDA,IAAAie,YAAU,KACR,IAAIy8C,EAAgB,KAChBC,EAAY,KAsChB,OApCIZ,EAAa57C,UAAYm8C,IAC3BJ,EAA2B,CAACb,GAAkB/6D,UAC9Co8D,EAAgB9+D,YAAW,KACzBs+D,EAA2B,IACrBF,EAAmB,CAACX,GAAkBE,gBAAkB,KAG1DiB,IACFG,EAAYvyC,uBAAsB,KAChCoyC,GAAgC,IAEpC,GACC1yC,KAGAiyC,EAAa57C,SAAWm8C,IAC3BJ,EAA2B,CAACb,GAAkB/6D,UAG9Cq8D,EAAYvyC,uBAAsB,KAChCuyC,EAAYvyC,uBAAsB,KAChC8xC,EAA2B,CACzBb,GAAkB/6D,QAClB+6D,GAAkBC,KAEhBiB,IACFG,EAAgB9+D,YAAW,KACzB2+D,GAA+B,GAC9BzyC,GACL,GACA,KAINiyC,EAAa57C,QAAUm8C,EAEhB,KACL9+D,aAAak/D,GACbE,qBAAqBD,EAAU,CAChC,GACA,CACDX,EACAO,EACAC,EACA1yC,EACAwyC,KAIA,8BACGG,IACC,IAAAp0C,cAAatB,GACVjc,OAAOswD,IACP/4D,KAAKimB,IACJ,MAAQpC,UAAW22C,EAAiB,IAAOv0C,EAAMnjB,MAC3C23D,EAAeD,EAClBt1D,MAAM,KACNuD,QAAQiyD,IAAQvB,GAAuBthD,SAAS6iD,KAEnD,OAAO,IAAArhC,cAAapT,EAAO,CACzBpC,UAAW,IAAI42C,KAAiBb,GAAyBpzD,KACvD,MAEF,KAGX,ECxDH,GA/EqBm0D,KACnB,MAAM,EAAEr4D,IAAMsI,EAAAA,EAAAA,MACR,eAAE0G,EAAc,qBAAE8X,IAAyBT,EAAAA,EAAAA,OAC1CiyC,EAAkBC,IAAuBt9C,EAAAA,EAAAA,UAAS6L,GACnD0oC,GAAsB1pC,EAAAA,EAAAA,MACtB0yC,GAA2BtuC,EAAAA,EAAAA,QAAO,OAClC,iBAAElW,EAAgB,YAAEg9C,GAAgBJ,KACpC6H,GAAevuC,EAAAA,EAAAA,QAAO,OACtB,WAAEjE,IAAeF,EAAAA,EAAAA,MACjB2yC,KAAa16C,EAAAA,EAAAA,MAkCnB,OAhCA1C,EAAAA,EAAAA,YAAU,MAMRwS,EAAAA,EAAAA,IAA+B2qC,EAAaj9C,SAL5Bm9C,KACT7xC,GACH0oC,GACF,IAGF+I,EAAoBzxC,EAAqB,GACxC,CAACA,EAAsB0oC,KAE1Bl0C,EAAAA,EAAAA,YAAU,KACJk9C,EAAyBh9C,UAAYsL,GACvCb,EAAWjmB,EAAE,kCAG0B,IAArCw4D,EAAyBh9C,SAAqBsL,GAChDb,EAAWjmB,EAAE,+BAMX04D,IACFF,EAAyBh9C,QAAUsL,EACrC,GACC,CAACA,EAAsB4xC,EAAUzyC,EAAYjmB,KAQ7CgP,GACDgiD,IAAgB5hD,EAAAA,GAAWW,SACzB+T,EAAAA,EAAAA,KAAC80C,GAAe,CACdjrD,SAAU2qD,EACVrB,qBAAsBH,GAAsBE,SAAS50C,UAErD0B,EAAAA,EAAAA,KAAA,OAAKvC,WAAWA,EAAAA,EAAAA,GAAU,yBAAyBa,UACjD0B,EAAAA,EAAAA,KAAC80C,GAAe,CACdjrD,SAAU2qD,EACVrB,qBAAsBH,GAAsBF,eAAex0C,UAE3D0B,EAAAA,EAAAA,KAAA,UACEvC,WAAWA,EAAAA,EAAAA,GAAU,CACnB,SACA,oBACA,kBAEFsN,IAAK4pC,EACL,gBAAgBH,EAA4B,KAAT,OACnCrhE,KAAK,SACL4sB,QAASy0C,EA1BE1L,KACrB54C,EAAiB5E,EAAAA,GAAWW,QAC5By/C,GAAqB,EAwBkC,KAAKptC,UAElD0B,EAAAA,EAAAA,KAACC,EAAAA,EAAI,CACH1sB,KAAK,OACL2sB,KAAK,KACLC,IAAKjkB,EAAE,wCAMlB,ECOL,GAhFuB64D,KACrB,MAAM,OAAE3hD,IAAWC,EAAAA,EAAAA,MACb2hD,GAAiB5uC,EAAAA,EAAAA,QAAO,OACxB,aAAExc,IAAiBqc,EAAAA,EAAAA,OAClBgvC,EAAeC,IAAoB/9C,EAAAA,EAAAA,UAASvN,IAC3Cod,UAAWmuC,IACjBpuC,EAAAA,EAAAA,OACKquC,EAA8BC,IACnCl+C,EAAAA,EAAAA,UAASg+C,GACLzJ,GAAsB1pC,EAAAA,EAAAA,MACtBszC,GAAiBlvC,EAAAA,EAAAA,SAAO,IACxB,YAAE8mC,GAAgBJ,MACjByI,EAAiBC,IAAsBr+C,EAAAA,EAAAA,UAAS,CACrDtP,KAAMmoD,GACN/jD,OAAQu8C,MAEHiN,EAAaC,IAAkBv+C,EAAAA,EAAAA,WAAS,IAAM+1C,IAC/Cn7D,GAASyF,EAAAA,EAAAA,OACT,qBAAEurB,IAAyBR,EAAAA,EAAAA,MAE3BsyC,GAAUpwD,EAAAA,EAAAA,cAAY,MAC1BulB,EAAAA,EAAAA,IAA+BgrC,EAAet9C,QAASg0C,EAAoB,GAC1E,CAACA,KAEJl0C,EAAAA,EAAAA,YAAU,KACR,MAAM,iBAAE3e,GAAqB9G,GACvB,MAAE+W,GAAUjQ,GAAoB,CAAC,EAEnCiQ,GACF0sD,GAAoB53C,IAAC,IAChBA,KACA9U,KAEP,GACC,CAAC/W,KAEJylB,EAAAA,EAAAA,YAAU,KAGRq9C,IACAK,EAAiBtrD,GACjByrD,EAAgCF,EAA4B,GAC3D,CAACvrD,EAAcurD,EAA6BN,KAE/Cr9C,EAAAA,EAAAA,YAAU,KACRk+C,EAAexI,GAGf2H,GAAS,GACR,CAAC3H,EAAa2H,EAASG,IAG1BM,EAAe59C,WACbs9C,EAAet9C,UACfs9C,EAAet9C,QAAQuS,SAAS1iB,SAAS2iB,gBAG3C,MAAMyrC,EAAiBJ,EAAgBE,GAEvC,OACE/1C,EAAAA,EAAAA,MAAA,OAAKjC,WAAWA,EAAAA,EAAAA,GAAU,eAAgBsN,IAAKiqC,EAAe12C,SAAA,CAC3D22C,IAAiBj1C,EAAAA,EAAAA,KAAC8rC,GAAiB,IACnCsJ,IAAgCp1C,EAAAA,EAAAA,KAACksC,GAAwB,KAC1DxsC,EAAAA,EAAAA,MAAA,OACEjC,WAAWA,EAAAA,EAAAA,GAAU,CACnB,iBACI7T,GAAgBurD,EAChB,CAAC,uBACD,KACH72C,SAAA,CAEFm3C,IAAgBnqD,EAAAA,GAAWW,QAC1B8W,GACA3P,IAAU4M,EAAAA,EAAAA,KAACu0C,GAAY,KACzBv0C,EAAAA,EAAAA,KAAC21C,EAAc,SAEb,iBClFV,MAkDA,GAlDkBC,KAChB,MAAM,EAAE15D,IAAMsI,EAAAA,EAAAA,MACR,MAAEW,EAAK,SAAEoF,IAAaiP,EAAAA,EAAAA,MACtB1D,GAAqB2D,EAAAA,EAAAA,OACrB,OAAErG,IAAWC,EAAAA,EAAAA,MACbhL,GAAe6R,EAAAA,EAAAA,MACfnV,GAAWtN,EAAAA,EAAAA,IAAYuN,GAAAA,GACvB9N,GAAgBS,EAAAA,EAAAA,MAChBipB,EAAMvY,GAAcC,QAAUpR,EAC9B2+D,EAAkB9wD,EAAW,GAAKwF,EAElCwW,EAAa,CAAC,iBAUpB,OARI3N,GACF2N,EAAWxiB,KAAK,uBAGS,IAAvBuX,GACFiL,EAAWxiB,KAAK,yBAIfs3D,IAAoBziD,KACnBsM,EAAAA,EAAAA,MAAA,OAAKjC,WAAWA,EAAAA,EAAAA,GAAU,cAAca,SAAA,EACtCoB,EAAAA,EAAAA,MAAA,OAAKjC,WAAWA,EAAAA,EAAAA,GAAU,uBAAuBa,SAAA,CAC9CsC,GACCZ,EAAAA,EAAAA,KAAA,OACEvC,WAAWA,EAAAA,EAAAA,GAAUpV,GAAcC,OAAS,SAAW,QACvDsY,IAAKA,EACLT,IAAI,MAGNH,EAAAA,EAAAA,KAACC,EAAAA,EAAI,CAAC1sB,KAAK,SAAS2sB,KAAK,KAAKC,IAAI,MAEpCH,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAUsD,GAAa,cAAY,OAAMzC,SACvDxI,QAIL4J,EAAAA,EAAAA,MAAA,OAAKjC,WAAWA,EAAAA,EAAAA,GAAU,oBAAoBa,SAAA,EAC5C0B,EAAAA,EAAAA,KAAA,KAAGvC,WAAWA,EAAAA,EAAAA,GAAU,uBAAuBa,SAC5CnZ,GAASjJ,EAAE,mBAEd8jB,EAAAA,EAAAA,KAAA,KAAGvC,WAAWA,EAAAA,EAAAA,GAAU,oBAAoBa,SAAEu3C,SAGnD,ECiIL,GAjKoBC,EAAGC,WAAU,MAE/B,MAAM,SAAEv7C,IAAaD,EAAAA,EAAAA,OACf,EAAEre,IAAMsI,EAAAA,EAAAA,MACR,WAAE0O,EAAU,iBAAE6L,IAAqBpN,EAAAA,GAAAA,MACnC,OAAEyB,EAAM,cAAEtN,IAAkBuN,EAAAA,EAAAA,OAC5B,gBAAE5a,IAAoBjB,EAAAA,EAAAA,MAEtBw+D,GAAYx3C,EAAAA,EAAAA,MACZktC,GAAsB1pC,EAAAA,GAAAA,MACtBhL,GAAeoP,EAAAA,EAAAA,QAAO,OACtB,WAAEjE,IAAeF,EAAAA,EAAAA,KAEjBld,GAAWtN,EAAAA,EAAAA,IAAYuN,GAAAA,IACvB,aAAE4E,EAAY,aAAE8c,IAAiBT,EAAAA,GAAAA,MACjC,UAAEe,EAAS,aAAEpuB,IAAiBmuB,EAAAA,GAAAA,KAE9BhxB,GAAmBunB,EAAAA,EAAAA,KACnBjnB,GAAU8jB,EAAAA,EAAAA,IAAqB,eAC7B7mB,KAAM2iE,IAAc/jD,EAAAA,EAAAA,IAAuB,CAAE7b,YAC/Co+C,GAAcvvC,EAAAA,EAAAA,UAClB,IAAO7O,IAAY0O,EAAWkxD,EAAY,IAC1C,CAAC5/D,EAAS0O,EAAUkxD,IAGhBC,GAAkB9vC,EAAAA,EAAAA,QAAO,MACzB+vC,GAAqB/vC,EAAAA,EAAAA,SAAO,GAE5BgwC,GAA8BhwC,EAAAA,EAAAA,QAAO,IACrCiwC,IAAmB5hB,EAAYl7C,OAC/B+8D,EAAkB97C,GACnBzkB,GAAoBqd,KAAY2iD,EACjChgE,EACEwgE,GAAsBnwC,EAAAA,EAAAA,QAAOkwC,GAC7BE,EACJH,IAAmBC,GAAmB79D,EAClCg+D,EAAsBJ,EACxB5hB,EACA2hB,EAA4B1+C,QAChC0+C,EAA4B1+C,QAAU++C,EAEtC,MAAMC,GAAwBxxD,EAAAA,EAAAA,UAAQ,KACpC,MAAM6b,EAAa,CAAC,eAMpB,OAJIg1C,GACFh1C,EAAWxiB,KAAK,uBAGXkf,EAAAA,EAAAA,GAAUsD,EAAW,GAC3B,CAACg1C,IAGE5kB,GAAc1sC,EAAAA,EAAAA,cAClB,EAAG0B,KAAIiuC,eACDxqC,GACF8c,GAAa,GAGXM,GACFpuB,IAIFsa,EAAW,CACT/f,KAAMC,EAAAA,GAAYkoB,OAClBiE,cAAelpB,EAAQ8P,GACvB7S,KAAM,CACJH,KAAM,WACNG,KAAM,CACJ82D,MAAOjkD,EACPkkD,YAAajW,MAKnBr1B,EAAiBq1B,GACZhhC,GACHtN,EAAchO,GAAAA,EAAiBC,MAEjC2zD,GAAqB,GAEvB,CACE3sC,EACAnmB,EACA8tB,EACAglC,EACA9hD,EACAod,EACA3wB,EACA6c,EACApN,EACAsN,KAIJoE,EAAAA,EAAAA,YAAU,KACR,GAAI0+C,EAAgBx+C,UAAY+8B,IAAgB6hB,EAAiB,CAC/D,GAAID,EAAgB,CAClB,MAAMM,EAAaR,EAAmBz+C,QAClCxb,EAAE,6BACFA,EAAE,+BACN/G,YAAW,KACTgtB,EAAWw0C,EAAW,GACrB,GACL,MAAWR,EAAmBz+C,SAC5ByK,EAAWjmB,EAAE,kCAGfg6D,EAAgBx+C,QAAU+8B,CAC5B,EAEK8hB,EAAoB7+C,SAAW4+C,IAClCtsC,EAAAA,EAAAA,IAA+BhT,EAAaU,QAASg0C,GACrDvpC,EAAWjmB,EAAE,oCACHm6D,GAAkBF,EAAmBz+C,UAC/CsS,EAAAA,EAAAA,IAA+BhT,EAAaU,QAASg0C,GAEvDyK,EAAmBz+C,QAAU2+C,EAC7BE,EAAoB7+C,QAAU4+C,CAAe,GAC5C,CACD7hB,EACA4hB,EACAC,EACA5K,EACAvpC,EACAjmB,IAGF,MAAM8tD,EAAc9tD,EAAE,2BAChB+tD,EAAa/tD,EAAE,0BACf06D,EAAmB5M,EAAc,UAAY,MAEnD,OACEhqC,EAAAA,EAAAA,KAAC80C,GAAe,CACdjrD,SAAU2sD,EACVrD,qBAAsBH,GAAsBC,YAAY30C,UAExDoB,EAAAA,EAAAA,MAACk3C,EAAgB,CACfn5C,UAAWi5C,EACX,kBAAiB1M,EAAcgM,EAAY,KAC3CjrC,IAAK/T,EAAasH,SAAA,CAEjB0rC,IACChqC,EAAAA,EAAAA,KAAA,KAAG7Z,GAAI6vD,EAAWv4C,WAAWA,EAAAA,EAAAA,GAAU,wBAAwBa,SAC5D0rC,MAGFyM,EAAoBl9D,SACrBymB,EAAAA,EAAAA,KAACu0B,GAAe,CACdE,YAAagiB,EACb/hB,kBAAmBvD,IAGtB8Y,IAAe72C,IACd4M,EAAAA,EAAAA,KAAA,KAAGvC,WAAWA,EAAAA,EAAAA,GAAU,uBAAuBa,SAAE2rC,QAGrC,iBC7KtB,MAqDA,IArDav2B,EAAAA,GAAAA,aACX,EAAGpV,WAAUb,UAAW+2B,EAAiB,IAAMqiB,KAC7C,MAAM,OAAEzjD,EAAM,UAAEqD,EAAS,cAAE3Q,IAAkBuN,EAAAA,EAAAA,OACvC,UAAEriB,EAAS,WAAEC,IAAeuG,EAAAA,EAAAA,OAC5B,SAAEgjB,IAAaD,EAAAA,EAAAA,MACftiB,GAAyBmpB,EAAAA,GAAAA,KACzBrrB,GAAmBunB,EAAAA,EAAAA,MACnB,EAAEphB,IAAMsI,EAAAA,EAAAA,KAQRuc,EAAa,CALjB,OACC,gBAAe9vB,IACf,cAAaD,OAKXiH,EACHu8C,GAkBF,OAfKphC,GAAyB,QAAfniB,GACb8vB,EAAWxiB,KAAK,mBAGdxI,GACFgrB,EAAWxiB,KAAK,wBAWhBkY,IACEiJ,EAAAA,EAAAA,MAAA,WACEjC,WAAWA,EAAAA,EAAAA,GAAUsD,GACrBylC,UAXoB9yD,KACnBA,EAAEm2B,MAAmB,WAAXn2B,EAAEm2B,MAAoC,KAAdn2B,EAAEo2B,WAClCtP,GAAYpH,GACftN,EAAchO,GAAAA,EAAiBE,UACjC,EAQEm2C,SAAS,KACTpjB,IAAK8rC,EACL,aAAY36D,EAAE,gBAAgBoiB,SAAA,EAE9B0B,EAAAA,EAAAA,KAAA,OAAKvC,WAAWA,EAAAA,EAAAA,GAAU,gBAAgBa,SAAEA,IAC5B,WAAfrtB,GAA2BmiB,IAAU4M,EAAAA,EAAAA,KAAC81C,GAAW,CAACC,SAAS,MAE/D,ICCP,GA/CwC,EACtCz3C,WACAw4C,cACA3xD,QACA4xD,kBACAC,oBACA7wD,SAEA,MAAM8wD,GAAY,UAElB,OACE,qBACE9oB,UAAW,EACXhoC,GAAIA,EAAE,kBACWhB,EAAQ8xD,OAAYxjE,EACrCgqB,WAAW,OAAU,eAAgBtY,GAAS,0BAAyB,WAEvE,iBAAKsY,WAAW,OAAU,qBAAoB,UAC3CtY,GACC,eAAIsY,WAAW,OAAU,sBAAuBtX,GAAI8wD,EAAS,SAC1D9xD,IAED,KACHmZ,KAEqB,mBAAhBw4C,IACN,oBACE3jE,KAAK,SACL4sB,QAAS+2C,EACTr5C,WAAW,OACT,SACA,mBACA,sBACD,UAEAs5C,IAAmB,SAAC,IAAI,CAACxjE,KAAK,QAAQ2sB,KAAK,KAAKC,IAAI,KACpD62C,IACC,iBAAMv5C,WAAW,OAAU,mBAAkB,SAC1Cu5C,SAMZ,EC5BH,GAnByB,EACvB7lB,cACAoE,OACApwC,QACA+xD,mBAEA,oBACE/jE,KAAK,SACL4sB,QAASoxB,EACT1zB,WAAW,OAAU,SAAU,kBAAmB,uBAAsB,WAExE,SAAC,IAAI,CAAClqB,KAAMgiD,EAAMr1B,KAAK,KAAKC,IAAI,KAC/Bhb,EACA+xD,IACC,iBAAMz5C,WAAW,OAAU,mBAAkB,SAAGy5C,OCjBvC,SAASC,KACtB,MAAM,aACJ3jD,EAAY,oBACZL,EAAmB,2BACnBQ,EAA0B,4BAC1BD,IACE,WAEE,GAAEvN,IAAO,UAEf,OAAKqN,GAKH,SAAC,GAAU,CACTsjD,YAAanjD,EACbqjD,kBAAmB7jD,EAAoBikD,oBACvCjxD,GAAIA,EACJhB,MAAOgO,EAAoBkkD,WAAU,UAErC,SAAC,GAAgB,CACflmB,YAAaz9B,EACb6hC,KAAK,iBACLpwC,MAAOgO,EAAoBmkD,gBAbxB,IAiBX,CC9Be,SAASC,KACtB,MAAMxyD,GAAW,QAAY,OAEvB,SAAE8E,IAAa,UACrB,OAAI9E,GAII8E,EAHC,MAGU,SAACstD,GAAmB,GACzC,CCDA,MA+BA,GA/BsD,EACpDhnB,QACAuL,UACA/K,cACAuB,WACA/rC,KACAqxD,oBAUE,gBACE/5C,WAAW,OAAU,CAAC+5C,EAAe,8BAA6B,gBACnD9b,EACf7J,KAAK,SACL1D,SAAU,EACVpuB,QAASmyB,EACTsU,UAde9yD,IACF,UAAXA,EAAEm2B,MAA+B,UAAXn2B,EAAEm2B,OAC1Bn2B,EAAEsuD,iBACF9P,IACF,EAWE/rC,GAAIA,EAAE,WAEN,SAAC,IAAI,CAAC5S,KAAK,QAAQ2sB,KAAK,KAAKC,IAAI,KAChCgwB,EAAK,IAAGQ,IAAe,gCAAQA,EAAW,UCoEjD,GA1FwD,EACtDuB,WACAulB,oBAEA,MACErlE,SAAS,WAAEC,EAAU,cAAEH,KACrB,WAEE,EAAEgK,IAAM,UACR,UAAE6V,EAAS,cAAEE,EAAa,mBAAEL,EAAkB,oBAAEC,IACpD,UACI65C,GAAsB,WAEtB0F,EAAgBn2D,GAA+B,KAC/CA,IAAWgX,GAAiB/f,IAAkB+I,EAChD4W,IAEAD,EAAmB3W,GAGrBi3C,IACAwZ,GAAqB,GAGjB,iBAAEgM,EAAgB,mBAAEC,IAAuB,KAAAzyD,UAC/C,IACE6M,EAAU3U,QACR,CAAC+W,EAAKV,KACJ,MAAMmkD,EAAankD,EAASxY,SAAW/I,EACjCwpD,EAhCE,EAACjoC,EAAUxB,EAAe2lD,IAC1C3lD,IAAkBwB,EAASxY,SAAYgX,GAAiB2lD,EA+BhCC,CAAUpkD,EAAUxB,EAAe2lD,GAE/CnkD,EAASxY,SAAW/I,GACtBiiB,EAAIwjD,mBAAmBp5D,KAAK,OAAD,wBAAMkV,GAAQ,CAAEioC,UAASkc,gBAGtD,MAAME,EAAc3jD,EAAIwjD,mBAAmBpa,WACxCn8C,GAAMA,EAAEnG,SAAWgX,IAOtB,OAJI2lD,GAAelc,GAAWoc,EAAc,IAC1C3jD,EAAIujD,iBAAiBn5D,KAAK,OAAD,wBAAMkV,GAAQ,CAAEioC,UAASkc,gBAG7CzjD,CAAG,GAEZ,CACEujD,iBAAkB,GAClBC,mBAAoB,MAG1B,CAAC1lD,EAAe/f,EAAe6f,IAGjC,OACE,mCACoB0lD,EAClB5lB,KAAK,UACL1D,UAAW,EACX1wB,WAAW,OAAU,uBAAsB,UAE1Ci6C,EAAiB99D,KAChB,EAAGqB,SAAQ+X,aAAY0oC,UAASkc,cAAcx+C,KAC5C,SAAC,GAAiB,CAEhBjT,GAAIlL,EACJk1C,MAAOn9B,EACP0oC,QAASA,EACT/K,YAAainB,GAAc17D,EAAE,kCAC7Bg2C,SAAUkf,EAAan2D,GACvBu8D,eAAe,OAAU,CACvB,sCAAuCI,EACvC,sCAAuClc,GAAmB,IAARtiC,KAR/Cne,KAaV08D,EAAmB/9D,KAAI,EAAGqB,SAAQ+X,aAAY0oC,UAASkc,iBACtD,SAAC,GAAiB,CAEhBzxD,GAAIlL,EACJk1C,MAAOn9B,EACP0oC,QAASA,EACT/K,YAAainB,GAAc17D,EAAE,kCAC7Bg2C,SAAUkf,EAAan2D,IALlBA,OASZ,ECYH,GAvF4C,EAC1CwiB,UAAW+2B,EACXl2B,WACAy5C,WACA/N,cACArZ,cACAI,gBACAinB,mBACAjG,kBACAkG,wBACAC,WAAW,CACTC,WAAY,OACZC,SAAU,WAGZ,MAAMC,GAAgB,WAGhB,WAAE1oD,IAAe,WACjB,YAAE6U,IAAgB,SAElB8zC,GAAa,IAAA7zD,cAAY,KAC7BkL,IACKsoD,GACHzzC,GACF,GACC,CAACyzC,EAAuBzzC,EAAa7U,IAElC4oD,GAAkB,IAAA9zD,cAAY,KAC9BszD,GACFA,IAEFO,GAAY,GACX,CAACA,EAAYP,IAEV/Y,EC9DiBz3B,KACvB,MAAMwD,GAAM3E,EAAAA,EAAAA,QAAoB,MAwBhC,OAtBA5O,EAAAA,EAAAA,YAAU,KACR,MAAMmnB,EAAWjd,IAEbqJ,EAAIrT,SACJgK,EAAGjlB,kBAAkB+7D,cACpBztC,EAAIrT,QAAQuS,SAASvI,EAAGjlB,UAEzBilB,EAAGsgC,iBACHtgC,EAAG2kC,kBACH9+B,IACF,EAMF,OAHAhgB,SAAS65B,iBAAiB,QAASzC,GAAS,GAC5Cp3B,SAAS65B,iBAAiB,aAAczC,GAAS,GAE1C,KACLp3B,SAASi6B,oBAAoB,QAAS7C,GAAS,GAC/Cp3B,SAASi6B,oBAAoB,aAAc7C,GAAS,EAAK,CAC1D,GACA,CAACpX,EAAUwD,IAEPA,CAAG,EDqCQ,CAAgBwtC,GAMlC,OAJA,IAAA/gD,YAAU,MACR,QAAawnC,EAAUtnC,QAAQ,GAC9B,CAACsnC,KAGF,oBACEvhC,WAAW,OACT,UACA,CACE,iBAA0C,UAAxBy6C,EAASC,WAC3B,gBAAyC,SAAxBD,EAASC,WAC1B,eAAsC,QAAtBD,EAASE,SACzB,kBAAyC,WAAtBF,EAASE,UAE9B5jB,GACD,kBACgB6jB,EACjBlqB,UAAW,EACXpjB,IAAKi0B,EAAS,UAEd,iBAAKvhC,WAAW,OAAU,iBAAgB,WACxC,eAAItX,GAAIkyD,EAAe56C,WAAW,OAAU,kBAAiB,SAC1DusC,KAEH,oBACE72D,KAAK,SACL4sB,QAASw4C,EAAe,mBACNF,EAClB56C,WAAW,OAAU,SAAU,kBAC/BsN,IAAM0tC,IACA1G,IACFA,EAAgBr6C,QAAU+gD,EAC5B,EACD,WAED,SAAC,IAAI,CAACllE,KAAK,QAAQ2sB,KAAK,KAAKC,IAAI,MACjC,0BAAO63C,OAGRrnB,GACC,cAAGlzB,WAAW,OAAU,wBAAyBtX,GAAI4qC,EAAa,SAC/DJ,IAED,MACJ,gBAAKlzB,WAAW,OAAU,oBAAmB,SAAGa,QAGrD,EEjFH,GArBA,UAAmC,QACjC4mC,EAAO,SACPgT,IAEA,MAAM,EAAEh8D,IAAM,SACR60C,GAAgB,UACtB,OACE,SAAC,GAAY,CACXgnB,SAAU7S,EACV8E,YAAa9tD,EAAE,2BACf87D,iBAAkB97D,EAAE,0CACpBy0C,YAAaz0C,EAAE,iCACf60C,cAAeA,EACfmnB,SAAUA,EACVD,uBAAqB,YAErB,SAAC,GAAkB,CAACR,cAAe1mB,EAAemB,SAAUgT,KAGlE,ECbe,SAASwT,IAA0B,SAChDp6C,EAAQ,SACR45C,EAAW,CACTC,WAAY,OACZC,SAAU,OACX,WACDr3C,IAEA,MAAO43C,EAAYC,IAAiB,IAAAzhD,WAAS,GACvC0hD,GAAe,IAAAzyC,QAAO,MACtB0yC,GAAiB,UA2BvB,OACE,iBACEr7C,WAAW,OAAU,2BACrB+oC,UA5B0B9yD,IACvBilE,IAID,QAAOjlE,KAAO,KAAS21B,SACzBuvC,GAAc,IACd,QAAaC,EAAanhD,SAC5B,EAoBiC,WAE/B,SAAC,GAAe,CACdy7C,qBAAsBH,GAAsBC,YAC5CppD,SAAU8uD,EAAU,UAEpB,gBAAKl7C,WAAW,OAAU,mBAAoBo0B,KAAK,SAAQ,UACzD,SAAC,GAAyB,CACxBqT,QAzBgB,KACxB0T,GAAc,EAAM,EAyBZV,SAAUA,SAIhB,mBACE/kE,KAAK,SACLsqB,WAAW,OAAU,CACnB,SACA,2BACGsD,IAEL5a,GAAI2yD,EACJ/4C,QAlCoB,KACxB64C,GAAeD,EAAW,EAkCtBnS,UA/BuB9yD,KACvB,QAAOA,KAAO,KAASi2B,YACzBivC,GAAc,GACdllE,EAAEsuD,iBACJ,EA4BIj3B,IAAK8tC,EAAY,gBACH,SAAQ,gBACPF,EAAU,SAExBr6C,MAIT,CCnFe,SAASy6C,IAAe,YAAExpB,EAAW,cAAEkoB,IACpD,MAAM,EAAEv7D,IAAMsI,EAAAA,EAAAA,KACd,OACEkb,EAAAA,EAAAA,MAACkyC,GAAI,CAACjC,WAAW,OAAOlyC,WAAWA,EAAAA,EAAAA,GAAU,iBAAiBa,SAAA,EAC5D0B,EAAAA,EAAAA,KAACg5C,GAAK,CACJzlE,KAAMg8C,EACNp8C,KAAK,QACLsqB,WAAWA,EAAAA,EAAAA,GAAU,qBACrB,mBAAkBg6C,EAClBrnB,YAAY3yB,EAAAA,EAAAA,GAAU,SACtBwxC,UAAW/yD,EAAE,mCAEf8jB,EAAAA,EAAAA,KAAA,OAAKvC,WAAWA,EAAAA,EAAAA,GAAU,oBAAoBa,UAC5C0B,EAAAA,EAAAA,KAAA,UACE7sB,KAAK,SACLsqB,WAAWA,EAAAA,EAAAA,GAAU,SAAU,kBAAmB,mBAAmBa,SAEpEpiB,EAAE,+CAKb,CCZA,MACMqzC,GAAc,QCZd0pB,GAAS,CACbv9C,eDaiBw9C,KACjB,MAAOC,EAAYC,IAAiBjiD,EAAAA,EAAAA,eAAS1jB,IACvC,WAAEkc,IAAe6T,EAAAA,EAAAA,OACjB,YAAEgB,IAAgBD,EAAAA,EAAAA,MAClB,EAAEroB,IAAMsI,EAAAA,EAAAA,KACR60D,GAA0B76C,EAAAA,EAAAA,OAC1B,WAAEtL,IAAevB,EAAAA,EAAAA,MAEjBg8C,GAAmBzoD,EAAAA,EAAAA,UACvB,KAAM,CACJ,CAACqqC,IAAc,CACb4gB,GAAaO,GAAkBx0D,EAAE,uCACjCi0D,GACEK,GACAt0D,EAAE,gDAIR,CAACA,IAGGyyC,GAAelqC,EAAAA,EAAAA,cAClBvE,IACC,MAAMo5D,EAAep5D,EAAOqvC,IAAajwC,OACzC4T,EAAW,CACT/f,KAAMC,EAAAA,GAAYsoB,eAClBpoB,KAAM,CAAEgmE,kBAEV3pD,IACA6U,GAAa,GAEf,CAACtR,EAAYvD,EAAY6U,IAGrB+0C,GAAc90D,EAAAA,EAAAA,cAClB,EAAGoqC,UAASD,kBAERwqB,EADExqB,IAAgBC,EACJ,sBAEAp7C,EAChB,GAEF,CAAC2lE,IAGH,OACEp5C,EAAAA,EAAAA,KAACw5C,GAAY,CACX/7C,UAAW07C,EACXnP,YAAa9tD,EAAE,gCACf87D,iBAAkB97D,EAAE,4BACpBy0C,YAAaz0C,EAAE,sCACf60C,cAAesoB,EACfnB,SAAU,CACRE,SAAU,MACVD,WAAY,SACZ75C,UAEF0B,EAAAA,EAAAA,KAACwtC,GAAY,CACXlzD,OA7DO,iBA8DPozD,SAAU/e,EACVgf,iBAAkBA,EAClBF,QAAS8L,EAAYj7C,UAErB0B,EAAAA,EAAAA,KAAC+4C,GAAc,CACbxpB,YAAaA,GACbkoB,cAAe4B,OAGN,GCjEnB,GAbgBI,KACd,MAAM,aAAEzuD,IAAiBwY,EAAAA,EAAAA,MACnBk2C,GAAmBtzC,EAAAA,EAAAA,QAAO,MAG1BuzC,EAAeV,GAAOjuD,GAAgB0uD,EAAiBhiD,SAK7D,OAHI1M,IACF0uD,EAAiBhiD,QAAU1M,GAEtB2uD,GAAe35C,EAAAA,EAAAA,KAAC25C,EAAY,IAAM,IAAI,EC4O/C,GAjPsBC,KACpB,MAAM,EAAE19D,IAAMsI,EAAAA,EAAAA,MACR,YAAEof,EAAW,WAAElU,EAAU,YAAE3E,EAAW,WAAE4E,IAC5C6T,EAAAA,EAAAA,OACI,GAAErd,IAAOoe,EAAAA,EAAAA,KACTs1C,GAAyBzzC,EAAAA,EAAAA,QAAO,OAE/BuyC,EAAYC,IAAiBzhD,EAAAA,EAAAA,WAAS,GAEvC0hD,GAAezyC,EAAAA,EAAAA,QAAO,MACtB0zC,EAAgBl2C,EAAYrqB,OAC5BwgE,GAAkB3zC,EAAAA,EAAAA,QACtB1qB,MAAMkG,KAAK,CAAErI,OAAQugE,IAAiB,KAAM7iD,EAAAA,EAAAA,gBAExC+iD,GAAiB5zC,EAAAA,EAAAA,SAAO,GAExB6zC,EAAYH,EAAgB,EAC5BI,EAAct2C,EAAY,GAC1Bu2C,GAAkBj1D,EAAAA,EAAAA,UACtB,IAAMg1D,GAAa3mE,MAAM+L,OAAO4wB,QAAQ,OAAQ,KAChD,CAACgqC,IA0HH,OAvHA1iD,EAAAA,EAAAA,YAAU,IACD,KACLziB,aAAa8kE,EAAuBniD,QAAQ,GAE7C,KAEHF,EAAAA,EAAAA,YAAU,KACJmhD,IAAeqB,EAAetiD,SAChCiK,uBAAsBC,gBACdP,EAAAA,GAAAA,IAAQ,IACd,MAAM+4C,EAAyBx2C,EAAY25B,WACxCztC,GAAWA,EAAO+T,YAGfw2C,GACwB,IAA5BD,EAAgC,EAAIA,GACtCr4C,EAAAA,EAAAA,IAAag4C,EAAgBriD,QAAQ2iD,GAAY,IAGrDL,EAAetiD,QAAUihD,CAAU,GAClC,CAACA,EAAY/0C,IAmGXk2C,GAKHp6C,EAAAA,EAAAA,MAAA,OACEjC,WAAWA,EAAAA,EAAAA,GAAU,sBACrB+oC,UA7F0B9yD,IACvBilE,KAID/uC,EAAAA,EAAAA,IAAOl2B,KAAO01B,EAAAA,GAASC,SACzBuvC,GAAc,IACd72C,EAAAA,EAAAA,IAAa82C,EAAanhD,WAExBkS,EAAAA,EAAAA,IAAOl2B,KAAO01B,EAAAA,GAASG,QACzBxH,EAAAA,EAAAA,IAAag4C,EAAgBriD,QAAQ,IACrChkB,EAAEsuD,mBAEAp4B,EAAAA,EAAAA,IAAOl2B,KAAO01B,EAAAA,GAASE,OACzBvH,EAAAA,EAAAA,IAAag4C,EAAgBriD,QAAQoiD,EAAgB,IACrDpmE,EAAEsuD,kBACJ,EA+EEsY,WApDsBC,KACpBN,IACFJ,EAAuBniD,QAAUviB,YAAW,KAC1CyjE,GAAc,EAAM,GACnB,KACL,EAiDE4B,UA9CqBC,KACvB1lE,aAAa8kE,EAAuBniD,QAAQ,EA6Cd4G,SAAA,EAE5B0B,EAAAA,EAAAA,KAAC80C,GAAe,CACd3B,qBAAsBH,GAAsBC,YAC5CppD,SAAUkB,EAAYuT,UAEtB0B,EAAAA,EAAAA,KAAA,OAAKvC,WAAWA,EAAAA,EAAAA,GAAU,mBAAmBa,UAC3C0B,EAAAA,EAAAA,KAACy5C,GAAO,QAGXQ,IACCj6C,EAAAA,EAAAA,KAAC80C,GAAe,CACdjrD,SAAU8uD,EACVxF,qBAAsBH,GAAsBC,YAAY30C,UAExD0B,EAAAA,EAAAA,KAAA,MACEvC,WAAWA,EAAAA,EAAAA,GAAU,CAAC,kBACtBo0B,KAAK,OACL1D,SAAS,KACT,kBAAiBhoC,EAAGmY,SAEnBsF,EAAYhqB,KAAI,EAAGrG,OAAM4R,QAAO0e,aAAaroB,KAC5CwkB,EAAAA,EAAAA,KAAA,MACEvC,WAAWA,EAAAA,EAAAA,GAAU,uBAErBo0B,KAAK,WACL,cAAat+C,EAAK+qB,UAElBoB,EAAAA,EAAAA,MAAA,UACEvsB,KAAK,SACL43B,IAAM4e,IACJowB,EAAgBriD,QAAQlc,GAAKmuC,CAAI,EAEnClsB,WAAWA,EAAAA,EAAAA,GAAU,CAAC,SAAU,sBAChC+oC,UAAY9yD,GAzGKgnE,EAAChnE,EAAG00B,KACnC,IAAIwB,EAAAA,EAAAA,IAAOl2B,KAAO01B,EAAAA,GAASO,UAAW,CACpC,MAAMgxC,EAAW38C,KAAK60B,IAAIinB,EAAgB,EAAG1xC,EAAQ,IACrDrG,EAAAA,EAAAA,IAAag4C,EAAgBriD,QAAQ0Q,IAAUuyC,EAAW,EAAIA,IAC9DjnE,EAAEsuD,gBACJ,CACA,IAAIp4B,EAAAA,EAAAA,IAAOl2B,KAAO01B,EAAAA,GAASK,QAAS,CAClC,MAAMkxC,EAAW38C,KAAK80B,IAAI,EAAG1qB,EAAQ,IACrCrG,EAAAA,EAAAA,IACEg4C,EAAgBriD,QACd0Q,IAAUuyC,EAAWb,EAAgB,EAAIa,IAG7CjnE,EAAEsuD,gBACJ,GA2FgC0Y,CAAyBhnE,EAAG8H,GAC9Co/D,WAAalnE,GA7EHmnE,EAACnnE,EAAG00B,KAC5B,MAAM1pB,EAAOnC,OAAOu+D,aAAapnE,EAAEqnE,UAGnC,GAF2C,IAAhBr8D,EAAKnF,SAAgBmF,EAAKy/B,MAAM,MAGzD,OAGF,IAAI68B,GAAc,EAElBp3C,EAAYlhB,SAAQ,CAACoN,EAAQtU,KAEzBA,EAAI4sB,GACJtY,EAAO3K,MAAMxG,OAAO,GAAGsxB,gBAAkBvxB,EAAKuxB,gBAC9B,IAAhB+qC,IAEAA,EAAax/D,EACf,KAGkB,IAAhBw/D,IACFj5C,EAAAA,EAAAA,IAAag4C,EAAgBriD,QAAQsjD,GACvC,EAuDiCH,CAAkBnnE,EAAG8H,GACxCukB,QAASA,IArDMk7C,EAAC1nE,EAAMswB,KAChCA,IACF+0C,GAAc,GACdlpD,EAAWnc,GACb,EAiD6B0nE,CAAuB1nE,EAAMswB,GAC5C,gBAAgBA,EAAqB,KAAT,OAAcvF,SAAA,EAE1CoB,EAAAA,EAAAA,MAAA,QAAMjC,WAAWA,EAAAA,EAAAA,GAAU,gBAAgBa,SAAA,CACxCnZ,GACC0e,GAAa,QAEfA,IACA7D,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,iBAAiBa,SACzCpiB,EAAE,iCArBJ3I,UA8BfmsB,EAAAA,EAAAA,MAAA,UACEvsB,KAAK,SACLsqB,WAAWA,EAAAA,EAAAA,GAAU,CACnB,SACA,oBACA,4BACKw8C,GAAaE,EACd,CAAE,0BAAyBA,KAC3B,KAENh0D,GAAIA,EACJ4Z,QA7KiB+oC,KACjB/9C,GACF4E,IAEEsqD,EACFrB,GAAeh9D,IAAOA,IACbs+D,EAAYr2C,YAAc9Y,GACnC2E,EAAWwqD,EAAY3mE,KACzB,EAsKIizD,UAAWyT,EAhJevmE,KAC1Bk2B,EAAAA,EAAAA,IAAOl2B,KAAO01B,EAAAA,GAASO,YACzBivC,GAAc,GACdllE,EAAEsuD,iBACJ,EA4IoD,KAChDj3B,IAAK8tC,EACL,gBAAeoB,EAAY,OAAS,KACpC,gBAAeA,EAAYtB,EAAWn4D,WAAa,KACnD,gBAAgBy5D,GAAcC,EAAYr2C,UAAqB,KAAT,OAAcvF,SAAA,CAEnE27C,IAAaj6C,EAAAA,EAAAA,KAACC,EAAAA,EAAI,CAAC1sB,KAAK,UAAU2sB,KAAK,KAAKC,IAAI,MACjDH,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,gBAAgBa,SACxC27C,EACG/9D,EAAE,0BACD,GAAEg+D,EAAY/0D,QAAS+0D,EAAYr2C,UAAkB,GAAN,SAEpDo2C,IAAcC,EAAYr2C,YAC1B7D,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,iBAAiBa,SACzCpiB,EAAE,mCA1FJ,IA8FD,EC7OK,SAASg/D,KACtB,MAAM,YAAEt3C,EAAW,qBAAEE,IAAyBN,EAAAA,EAAAA,OACtCxR,YAAampD,IAA4BzpD,EAAAA,EAAAA,MAC3C3M,GAAWtN,EAAAA,EAAAA,IAAYuN,GAAAA,IACvB,EAAE9I,EAAC,OAAEjB,IAAWuJ,EAAAA,EAAAA,KAChB42D,GAAmBtoD,EAAAA,EAAAA,IAAoB7X,GAE7C,IACIkgE,KACEr3C,IAAyBF,EAAYrqB,SACzCwL,EAEA,OAAO,KAGT,MAAMs2D,EAAiBn/D,EAAE,uCAAwC,CAC/Do/D,cAAeF,EACf3nD,SAAU2nD,IAGZ,OACE17C,EAAAA,EAAAA,MAAA,OAAKjC,WAAWA,EAAAA,EAAAA,GAAU,iBAAiBa,SAAA,CACxC68C,IACCn7C,EAAAA,EAAAA,KAAA,OACEvC,WAAWA,EAAAA,EAAAA,GACT,qBACA,4BACAa,UAEFoB,EAAAA,EAAAA,MAACg5C,GAAyB,CAAC33C,WAAY,CAAC,qBAAqBzC,SAAA,EAC3D0B,EAAAA,EAAAA,KAACC,EAAAA,EAAI,CAACE,IAAKk7C,EAAgB9nE,KAAK,iBAAiB2sB,KAAK,QACtDF,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,gBAAgBa,SAAE+8C,SAIlDv3C,IACC9D,EAAAA,EAAAA,KAAA,OACEvC,WAAWA,EAAAA,EAAAA,GACT,qBACA,6BACAa,UAEF0B,EAAAA,EAAAA,KAAC45C,GAAa,QAKxB,CCpDA,MAqBA,GArB6B,KAC3B,MAAM,YAAE2B,EAAW,UAAEzQ,IAAc,IAAAryC,YAAW,KACxC,YAAE/B,IAAgB,WAClB,EAAExa,IAAM,SAEd,OACE,SAAC,GAAe,CAAC2N,WAAYihD,EAAUvxD,SAAWmd,EAAW,UAC3D,gBAAK+G,WAAW,OAAU,mBAAkB,UAC1C,oBACEtqB,KAAK,SACLsqB,WAAW,OAAU,SAAU,mBAC/BsC,QAASw7C,EAAW,UAEnBr/D,EAAE,8BAA+B,CAAEs/D,YAAa1Q,EAAUvxD,UAC3D,SAAC,IAAI,CAAChG,KAAK,cAAc2sB,KAAK,KAAKC,IAAI,WAI9C,ECpBUs7C,IAAqB5lE,EAAAA,EAAAA,IAAeojB,EAAAA,IAAejT,GACvDA,EAAO3D,QAAQ0K,UACpB,OACEzF,EAAAA,EAAAA,IAAgByF,IACD,iBAAfA,EAAM5Z,OACO,QAAbhB,EAAA4a,EAAM1W,eAAO,IAAAlE,OAAA,EAAAA,EAAEka,iBAAkBC,EAAAA,GAAWE,QAAQ,MAI7CkvD,IAAwB7lE,EAAAA,EAAAA,IACnC4lE,IACCz1D,GAAWA,EAAO2O,IAAI,KAGZgnD,IAAuB9lE,EAAAA,EAAAA,IAClC4lE,IACCz1D,GAAWA,EAAOpM,KAAKmT,GAAUA,EAAM1W,QAAQ8P,OAGrCy1D,IAA0B/lE,EAAAA,EAAAA,KACrC,EAAGO,YAAsB,IAAAjE,EAAC,OAAsB,QAAtBA,EAAAiE,EAAM+S,QAAQtS,gBAAQ,IAAA1E,OAAA,EAAAA,EAAE2Y,gBAAgB,IACjEA,GAAqBA,aAAgB,EAAhBA,EAAkBtZ,UCL1C,MAsFA,GAnFEq5D,IAOA,MAAM7zC,GAAeoP,EAAAA,EAAAA,WACdy1C,EAAqBC,IAA0B3kD,EAAAA,EAAAA,WAAS,GACzD2zC,GAAYrzD,EAAAA,EAAAA,IAAYkkE,IACxB31D,GAASsT,EAAAA,EAAAA,MACTle,GAAYme,EAAAA,EAAAA,OACZ,OAAEnG,IAAWC,EAAAA,EAAAA,MACb3J,GAAsBgQ,EAAAA,EAAAA,OACtB,sBAAEtO,EAAqB,sBAAE5B,IAA0B/R,EAAAA,EAAAA,KACvD,EAAGrB,WAAuBA,KAG5BohB,EAAAA,EAAAA,YAAU,KACR,MAAMgK,EAAUxK,EAAaU,QACvBk8B,EAAWA,KACf,MAAM,aAAEmoB,EAAY,UAAEC,EAAS,aAAEC,GAAiBz6C,EAC5C06C,EACJl+C,KAAKm+C,IAAIJ,EAAeC,EAAYC,GA1B1B,GA4BZH,GAAwBI,EAAc,EAKxC,OAFA16C,EAAQ4f,iBAAiB,SAAUwS,GAE5B,IAAMpyB,EAAQggB,oBAAoB,SAAUoS,EAAS,GAC3D,IAEH,MAAMwoB,GAAiB33D,EAAAA,EAAAA,cAAY,KACjCkd,uBAAsB,KAAW1vB,cAAA,uCACzBovB,EAAAA,GAAAA,IAAQ,IACM,QAApBlvB,EAAA6kB,EAAaU,eAAO,IAAAvlB,GAAAA,EAAEkqE,SAAS,CAC7BC,IAAyB,QAApBhqE,EAAA0kB,EAAaU,eAAO,IAAAplB,OAAA,EAAAA,EAAEypE,aAC3BhoB,KAAM,EACNwoB,SAAU,QAEd,cAPiC,kRAO/B,MACD,IAiCH,OA/BA/kD,EAAAA,EAAAA,YAAU,KACJhO,GACF4yD,GACF,GACC,CAAC5yD,EAAuB4yD,KAE3B5kD,EAAAA,EAAAA,YAAU,KACJqkD,GACFO,GACF,GACC,CACDP,EACA/Q,EACA9kD,EACA5K,EACAgY,EACA1J,EACA0B,EACAgxD,IAaK,CACLplD,eACA8zC,YACAyQ,YAbkBA,aAClB,MAAMxwC,EAAiC,QAA3B54B,EAAA04D,EAAUC,aAAS,EAATA,EAAWn2C,GAAG,WAAG,IAAAxiB,OAAA,EAAAA,EAAEulB,QAErB,QAApBplB,EAAA0kB,EAAaU,eAAO,IAAAplB,GAAAA,EAAE+pE,SAAS,CAC7BC,IAAKvxC,aAAG,EAAHA,EAAKyxC,UACVD,SAAU,OACVxoB,KAAM,GACN,EAOFqoB,iBACD,EC1DH,GAvC2B,EAAG99C,eAC5B,MAAMtY,GAAS,UACT6kD,GAAY,IAAA3lD,UAChB,IACEc,EAAO5I,QAA+C,CAAC+W,EAAKla,IACrDA,EAAM5D,QAAQ8P,IAEnBgO,EAAIla,EAAM5D,QAAQ8P,KAAM,IAAA8Q,aACjB9C,GAHuBA,GAI7B,CAAC,IACN,CAACnO,KAGG,YAAEu1D,EAAW,eAAEa,EAAc,aAAEplD,EAAY,UAAE8zC,GACjD,GAAcD,GAEhB,OACE,SAAC,GAAkB9b,SAAQ,CACzB90C,MAAO,CACL4wD,YACAC,YACAyQ,cACAa,iBACAplD,gBACD,UAED,iBAAKyG,WAAW,OAAU,mBAAkB,WAC1C,gBACEA,WAAW,OAAU,gCACrBsN,IAAK/T,EAAY,SAEhBsH,KAEH,SAAC,GAAoB,QAG1B,ECvBH,GAfuBm+C,KACrB,MAAM,EAAEvgE,IAAMsI,EAAAA,EAAAA,MACR,OAAE4O,EAAM,UAAEyD,IAAcxD,EAAAA,EAAAA,OACxB,SAAEoH,IAAaF,EAAAA,EAAAA,MACrB,OAAOnH,GAAUqH,GACfuF,EAAAA,EAAAA,KAAA,UACE7sB,KAAK,SACLsqB,WAAWA,EAAAA,EAAAA,GAAU,SAAU,mBAC/BsC,QAASlJ,EAAUyH,UAEnB0B,EAAAA,EAAAA,KAACC,EAAAA,EAAI,CAAC1sB,KAAK,cAAc2sB,KAAK,KAAKC,IAAKjkB,EAAE,+BAE1C,IAAI,iBCPV,MAqDA,GArDkBwgE,KAChB,MACEz3D,MAAM,cAAElR,EAAa,MAAEoR,EAAK,QAAEtR,EAAO,WAAEwR,EAAU,OAAErR,EAAM,OAAEoR,KACzDP,EAAAA,GAAAA,KACE83D,GAAiBhrD,EAAAA,EAAAA,MACjBslD,GAAYz4C,EAAAA,EAAAA,OACZ,WAAE2D,IAAeF,EAAAA,EAAAA,MACjBypC,GAAsB1pC,EAAAA,EAAAA,MACtB46C,EAAyC,8BAAxB7oE,GAAeR,KAmBtC,OAjBAikB,EAAAA,EAAAA,YAAU,MACHolD,GAAkBx3D,GAGrBjQ,YAAW,KACTgtB,EAAW/c,EAAO,GACjB,IACL,GACC,CAAC+c,EAAY/c,EAAQw3D,IAShBA,GAsBN58C,EAAAA,EAAAA,KAAAL,EAAAA,SAAA,KArBAD,EAAAA,EAAAA,MAAA,WAASjC,WAAWA,EAAAA,EAAAA,GAAU,aAAc,kBAAiBw5C,EAAU34C,SAAA,EACrE0B,EAAAA,EAAAA,KAACy8C,GAAc,KACf/8C,EAAAA,EAAAA,MAAA,OAAKjC,WAAWA,EAAAA,EAAAA,GAAU,mBAAmBa,SAAA,EAC3C0B,EAAAA,EAAAA,KAAA,MAAI7Z,GAAI8wD,EAAWx5C,WAAWA,EAAAA,EAAAA,GAAU,oBAAoBa,SACzDnZ,KAEH6a,EAAAA,EAAAA,KAAA,KAAGvC,WAAWA,EAAAA,EAAAA,GAAU,sBAAsBa,SAAEzqB,IAC/CwR,GAAcrR,IACbgsB,EAAAA,EAAAA,KAAA,OAAKvC,WAAWA,EAAAA,EAAAA,GAAU,sBAAsBa,UAC9C0B,EAAAA,EAAAA,KAAA,UACE7sB,KAAK,SACLsqB,WAAWA,EAAAA,EAAAA,GAAU,SAAU,mBAC/BsC,QApBW+oC,KACjB6T,EAAe3oE,IACjB2oE,EAAe3oE,KAEjB03D,GAAqB,EAgBaptC,SAEvBjZ,WAQZ,EC3BH,GAvBA,UAAmB,SAAEiZ,IACnB,MAAMvZ,GAAWtN,EAAAA,EAAAA,IAAYuN,GAAAA,IACvB,OAAEoO,IAAWC,EAAAA,EAAAA,MAEnB,OAAItO,GACKib,EAAAA,EAAAA,KAAC08C,GAAS,KAIjBh9C,EAAAA,EAAAA,MAAAC,EAAAA,SAAA,CAAArB,SAAA,EACEoB,EAAAA,EAAAA,MAACm9C,GAAkB,CAAAv+C,SAAA,EACjBoB,EAAAA,EAAAA,MAAA,OAAKjC,WAAWA,EAAAA,EAAAA,GAAU,2BAA2Ba,SAAA,EACnD0B,EAAAA,EAAAA,KAACu3C,GAAiB,KAClBv3C,EAAAA,EAAAA,KAACy8C,GAAc,OAEhBn+C,MAEH0B,EAAAA,EAAAA,KAAC+0C,GAAc,IACd3hD,IAAU4M,EAAAA,EAAAA,KAACk7C,GAAU,MAG5B,ECHA,GAvBe4B,EAAGx+C,WAAUy+C,kBAC1B,MAAM,uBAAEnyD,IAA2BgO,EAAAA,EAAAA,MAC7BokD,GAAc52C,EAAAA,EAAAA,QAAO,OAErB,EAAElqB,IAAMsI,EAAAA,EAAAA,KACd,OACEkb,EAAAA,EAAAA,MAAA,UAAQjC,WAAWA,EAAAA,EAAAA,GAAU,gBAAgBa,SAAA,CAC1CA,GACD0B,EAAAA,EAAAA,KAAA,OAAKvC,WAAWA,EAAAA,EAAAA,GAAU,mBAAmBa,UAC3C0B,EAAAA,EAAAA,KAAA,UACE7sB,KAAK,SACLsqB,WAAWA,EAAAA,EAAAA,GAAU,SAAU,6BAC/BsC,QAASg9C,EACThyC,IAAKiyC,EACL72D,GAAIyE,EAAuB0T,UAE3B0B,EAAAA,EAAAA,KAACC,EAAAA,EAAI,CAAC1sB,KAAK,cAAc2sB,KAAK,KAAKC,IAAKjkB,EAAE,8BAGvC,eCrBb,SAAS+gE,IAAqB,MAAElwD,IAC9B,MAAOwmB,GAAa,GAAyBxmB,GAE7C,OACE,yBACE,SAACwmB,EAAS,CAACxmB,MAAOA,KAGxB,CAEO,SAASmwD,IAAsB,OAAEl3D,IACtC,OACE,eAAIyX,WAAW,OAAU,2BAA0B,SAChDzX,EAAOpM,KAAKmT,IACX,SAACkwD,GAAoB,CAAwBlwD,MAAOA,GAAzBA,EAAM1W,QAAQ8P,OAIjD,CChBe,SAASg3D,KACtB,MAAM,cAAEpkE,IAAkB,UACpBgM,GAAW,QAAY,OACvB,OAAEqO,IAAW,UAInB,QAFoBrO,KAAahM,aAAa,EAAbA,EAAeQ,SAAU6Z,KAEtC,SAAC8pD,GAAqB,CAACl3D,OAAQjN,GACrD,CCTe,SAASqkE,KACtB,MAAM,IAAQ,KAAA54D,WACR64D,EAAmBnhE,EAAE,wBACrBohE,GAAoB,IAAAp4D,UACxB,KAAoB,CAClB/R,KAAM,UACNkD,QAAS,CACP/C,KAAM,CACJuU,KAAMw1D,OAIZ,CAACA,IAGH,OAAO,SAACH,GAAqB,CAACl3D,OAAQ,CAACs3D,IACzC,CCHA,MAAMC,GAAaA,KACjB,MAAMrmE,GAAgBS,EAAAA,EAAAA,MAChB0Q,GAAe6R,EAAAA,EAAAA,MACfnV,GAAWtN,EAAAA,EAAAA,IAAYuN,GAAAA,GACvBw4D,EAAuBn1D,IAAiBtD,EACxC6b,EAAM48C,EAAuBn1D,EAAaC,OAASpR,EACzD,OAAO0pB,GACLZ,EAAAA,EAAAA,KAAA,OACEvC,WAAWA,EAAAA,EAAAA,GAAU+/C,EAAuB,SAAW,QACvD58C,IAAKA,EACLT,IAAI,MAGNH,EAAAA,EAAAA,KAACC,EAAAA,EAAI,CAAC1sB,KAAK,SAAS2sB,KAAK,KAAKC,IAAI,IACnC,EAyCH,GAtCyBs9C,EAAG19C,cAC1B,MAAMrtB,GAAkBimB,EAAAA,EAAAA,OAClB,EAAEzc,IAAMsI,EAAAA,EAAAA,KACR2gD,EAAYzyD,IACdwJ,EAAE,gCACFA,EAAE,6BACAwvD,GAAsB1pC,EAAAA,GAAAA,OACtB,OAAE5O,IAAWC,EAAAA,EAAAA,MACbrJ,GAAQyP,EAAAA,EAAAA,MACR03B,GAAc1sC,EAAAA,EAAAA,cAAY,KAC9Bsb,IACA2rC,GAAqB,GACpB,CAACA,EAAqB3rC,IACzB,OACEC,EAAAA,EAAAA,KAAC80C,GAAe,CACdjrD,UAAWuJ,EACX+/C,qBAAsBH,GAAsBE,SAAS50C,UAErDoB,EAAAA,EAAAA,MAAA,UACEjC,WAAWA,EAAAA,EAAAA,GAAU,sBACrB,aAAY0nC,EACZ,cAAa/xC,EACb2M,QAASoxB,EAAY7yB,SAAA,EAErB0B,EAAAA,EAAAA,KAAC80C,GAAe,CACdjrD,WAAYG,EACZmpD,qBAAsBH,GAAsBC,YAAY30C,UAExD0B,EAAAA,EAAAA,KAAA,QAAMvC,WAAWA,EAAAA,EAAAA,GAAU,iBAAkB,cAAY,OAAMa,SAC5DtU,OAGLgW,EAAAA,EAAAA,KAACu9C,GAAU,QAEG,ECvDhBG,GAAW,CACflnC,EACAiI,EACAk/B,IACoB,iBAATnnC,EAAoBA,EAAKiI,GAAOk/B,EClB7C,GAAe,IAA0B,6TCQzC,MAAMC,KAA2BvtE,OAAOwtE,aCYlCC,GAAoB,CACxBhoE,ICjBcioE,KAEZ/9C,EAAAA,EAAAA,KAACg+C,GAAI,CAAA1/C,UACH0B,EAAAA,EAAAA,KAACi+C,GAAS,CAAA3/C,UACR0B,EAAAA,EAAAA,KAACk+C,GAAY,QDcnBC,OEXiBC,KACjB,MAAM,eAAEnmD,EAAc,aAAEjB,IAAiBgB,EAAAA,EAAAA,OAEnC,OAAE5E,IAAWC,EAAAA,EAAAA,MACnB,OACEqM,EAAAA,EAAAA,MAAAC,EAAAA,SAAA,CAAArB,SAAA,EACE0B,EAAAA,EAAAA,KAAC80C,GAAe,CACdjrD,UAAWuJ,EACX+/C,qBAAsBH,GAAsBE,SAAS50C,UAErDoB,EAAAA,EAAAA,MAAA,OACEqL,IAAK/T,EACLyG,WAAWA,EAAAA,EAAAA,GACT,oBACA,6BACAa,SAAA,EAEF0B,EAAAA,EAAAA,KAACm9C,GAAe,KAChBn9C,EAAAA,EAAAA,KAAC81C,GAAW,UAGhB91C,EAAAA,EAAAA,KAAC80C,GAAe,CACdjrD,SAAUuJ,EACV+/C,qBAAsBH,GAAsBE,SAAS50C,UAErD0B,EAAAA,EAAAA,KAACg+C,GAAI,CAACjzC,IAAK/T,EAAasH,SACrBrG,IACC+H,EAAAA,EAAAA,KAACi+C,GAAS,CAAA3/C,SAAElL,IAAU4M,EAAAA,EAAAA,KAACk+C,GAAY,YAIxC,EFnBL7tE,OHHiB,KACjB,MAAM,OAAE+iB,EAAM,SAAEwD,IAAa,UACvB7gB,GAAmB,UACnB,aAAE6C,EAAY,QAAE7B,IAAY,UAElC,OACE,iCACE,SAAC,GAAgB,CAACgpB,QAASnJ,KAC3B,SAAC,GAAe,CACd/M,SAAU9S,IAAYqc,IAAWrd,EACjC4C,UAAW+kE,GAAS3mE,EAAS,aAC7B2B,WAAYglE,GAAS3mE,EAAS,cAC9Bo8D,qBAAsBH,GAAsBC,YAAW,UAEvD,gBACEx1C,WAAW,OACT,oBACA,6BACD,UAED,SAAC0/C,GAAe,SAGpB,SAAC,GAAe,CACdtzD,SAAUjR,IAAiBwa,GAAUrd,EACrC4C,UAAW+kE,GAAS9kE,EAAc,aAClCF,WAAYglE,GAAS9kE,EAAc,cACnCu6D,qBAAsBH,GAAsBC,YAAW,UAEvD,gBACEx1C,WAAW,OACT,oBACA,4BACA,+BACD,UAED,SAAC2/C,GAAoB,SAGzB,SAAC,GAAe,CACdvzD,SAAUuJ,EACV+/C,qBAAsBH,GAAsBC,YAAW,UAEvD,SAAC,GAAI,WACH,SAAC,GAAS,WACR,SAAC,GAAY,YAKtB,GGsEH,GA5Ga,EAAG30C,eACd,MAAM,iBAAE+/C,GDvBcC,MACtB,MAAM,kBAAEj0D,IAAsByP,EAAAA,EAAAA,OAExB,qBAAExhB,IAAyBd,EAAAA,EAAAA,OAC1B+mE,EAAYC,IAAiBrnD,EAAAA,EAAAA,UAClCymD,GAAyBC,aAAaU,WAAa,YAE9C/2D,EAAiBi3D,IAAsBtnD,EAAAA,EAAAA,UAC5C5P,SAASC,iBAGLk3D,GAAoBjnE,EAAAA,EAAAA,IAAYmkE,IAEhC+C,GAAoBl6D,EAAAA,EAAAA,cAAY,IAAWxS,QAAA,6BAC/C,GAAI2rE,IAAyC,YAAfW,EAA0B,CACtD,MAAMK,QAA+Bf,aAAac,oBAClDH,EAAcI,EAChB,CACF,KAAG,CAACL,IAEEM,GAAoB35D,EAAAA,EAAAA,UACxB,IAAqB,YAAfq5D,GACN,CAACA,IAGGO,GAAwB55D,EAAAA,EAAAA,UAC5B,IAA0B,WAApBsC,GACN,CAACA,KAGHgQ,EAAAA,EAAAA,YAAU,KACW,YAAf+mD,GAA4Bl0D,GAC9Bs0D,GACF,GACC,CAACJ,EAAYl0D,EAAmBs0D,IAEnC,MAAMN,GAAmB55D,EAAAA,EAAAA,cAEvB,CAAOU,EAAegE,IAAiClX,QAAA,6BACrD,GAAKysE,GAAsBd,GAA3B,CAMA,GAJmB,YAAfW,GACFI,KAIyB,IAAzBrmE,IACCumE,IACAC,IAA0Bv3D,SAASqpC,YAEpC,IACE,MAAMmuB,EAAY,IAAIC,MAAM1mE,GAAwB2mE,UAC9CF,EAAUG,MAClB,CAAE,MAAO3nE,GAGPoN,QAAQC,KAAKrN,EACf,CAGF,GACEsnE,IACCC,IAA0Bv3D,SAASqpC,YACpC,CACA,MAAMuuB,EAAe,IAAItB,aAAa14D,EAAOgE,GAE7Cg2D,EAAaC,QAAU,WACrB/uE,OAAOmrC,OAAOzR,QACd15B,OAAO05B,QACPo1C,EAAa3qC,QAEb,MAAM1rB,EAAQvB,SAAS+3C,cACrB,cAAcyQ,OAEZjnD,GAAOA,EAAMihB,OACnB,CACF,CArCyD,CAsC3D,KACA,CACEzxB,EACAimE,EACAM,EACAF,EACAD,EACAI,IAkBJ,OAdAtnD,EAAAA,EAAAA,YAAU,KACR,IAAKknD,EAAmB,MAAO,OAE/B,SAASW,IACPZ,EAAmBl3D,SAASC,gBAC9B,CAIA,OAFAD,SAAS65B,iBAAiB,mBAAoBi+B,GAAwB,GAE/D,KACL93D,SAASi6B,oBAAoB,mBAAoB69B,EAAuB,CACzE,GACA,CAACX,IAEG,CACLH,aACAI,oBACAN,mBACD,ECnF4B,IACtB,CAAEltD,IAA6B,YAChC,UAAEngB,EAAS,WAAEC,EAAU,OAAEi1D,IAAW,UACpC79C,GAAe,WACf,kBAAEgC,IAAsB,WACxB,OAAE+I,EAAM,UAAEqD,IAAc,UACxBxe,GAAyB,UACzBlC,GAAmB,SACnBupE,GAAkB,QAAY5D,KAC9B,KAAEpoE,IAAS,KAAA4e,wBAAuBotD,IAClC,WAAEjtE,IAAe,SACjBktE,GAAwB,IAAAn5C,aAA2B3yB,GAEnD+rE,GAAmB,IAAAt6D,UAAQ,WAC/B,OAAO5R,EArBX,SAAmBmsE,GACjB,MAAMC,EAAMn4D,SAASgmB,cAAc,OAEnC,OADAmyC,EAAIC,UAAYF,EACTC,EAAI1wC,aAAe0wC,EAAIE,WAAa,EAC7C,CAmBQC,EAAUvsE,aAAI,EAAJA,EAAMuU,QAAoB,QAAZ,EAAAvU,aAAI,EAAJA,EAAM6rB,cAAM,eAAEtX,OAAQvU,QAC9CG,CAAS,GACZ,CAACH,KAEJ,IAAAkkB,YAAU,YAELnP,aAAY,EAAZA,EAAc9U,OACdisE,GACAn1D,GACAi1D,GACDC,EAAsB7nD,WAAmC,QAAvB,EAAA4nD,EAAgBjpE,eAAO,eAAE8P,MAK7Dk4D,EAAiBh2D,EAAa9U,KAAM,CAClCD,KAAMksE,EACNjqB,KAAMltC,aAAY,EAAZA,EAAcC,SAGtBi3D,EAAsB7nD,QAAU4nD,EAAgBjpE,QAAQ8P,GAAE,GACzD,CACDkC,aAAY,EAAZA,EAAcC,OACdD,aAAY,EAAZA,EAAc9U,KACd+rE,EACAE,EACAn1D,EACAg0D,IAEF,MAAMyB,EAAgBhC,GAAkB7sE,GAElC8uE,GAAsB,IAAAt7D,cACzBu6C,IAC0C,mBAA9B7tC,GACXA,EAA0B6tC,EAAU,GAEtC,CAAC7tC,IAGG6uD,GAAY,IAAA96D,UAAQ,KACxB,GAAI7S,GACsBkV,SACrB+3C,cAAc,QACdp3B,aAAa,UACQ71B,EACtB,OAAOA,CAGK,GACf,CAACA,IAEJ,IAAKytE,EAEH,OADAn7D,QAAQC,KAAK,6DACN,KAGT,MAKMmc,EAAa,CAAC,MAJlB,eAAe9vB,IACf,cAAcD,KAiBhB,MAZsC,mBAA3BiH,GACT8oB,EAAWxiB,QAAQtG,GAGhBmb,GAAyB,QAAfniB,GACb8vB,EAAWxiB,KAAK,kBAGdxI,GACFgrB,EAAWxiB,KAAK,uBAIhBkY,IACE,gBACEgH,WAAW,OAAUsD,GACrBhO,KAAMitD,EACN7xB,UAAW,EAAC,oBAEZ0F,MAAO,CAAEqS,UACTn7B,IAAKg1C,EAAmB,SAEvBzhD,IAAY,SAACwhD,EAAa,KAGhC","sources":["webpack:///./node_modules/phoenix/priv/static/phoenix.mjs","webpack:///./src/javascripts/api/conversation-connector.ts","webpack:///./src/javascripts/config.ts","webpack:///./src/javascripts/domains/app/actions.ts","webpack:///./src/javascripts/domains/redux/create-debounced-async-thunk.ts","webpack:///./src/javascripts/domains/app/selectors.ts","webpack:///./src/javascripts/domains/app/slice.ts","webpack:///./src/javascripts/domains/config/actions.ts","webpack:///./src/javascripts/domains/config/hooks.ts","webpack:///./src/javascripts/domains/config/selectors.ts","webpack:///./src/javascripts/domains/config/slice.ts","webpack:///./src/javascripts/domains/errors/index.ts","webpack:///./src/javascripts/domains/forms/slice.ts","webpack:///./src/javascripts/domains/i18n/actions.ts","webpack:///./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js","webpack:///./node_modules/@babel/runtime/helpers/esm/typeof.js","webpack:///./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","webpack:///./node_modules/@babel/runtime/helpers/esm/toPrimitive.js","webpack:///./node_modules/@babel/runtime/helpers/esm/createClass.js","webpack:///./node_modules/@babel/runtime/helpers/esm/defineProperty.js","webpack:///./node_modules/@ultraq/array-utils/array-utils.es.js","webpack:///./node_modules/@ultraq/icu-message-formatter/lib/icu-message-formatter.es.js","webpack:///./node_modules/@ultraq/function-utils/function-utils.es.js","webpack:///./node_modules/@babel/runtime/helpers/esm/classCallCheck.js","webpack:///./node_modules/@babel/runtime/helpers/esm/slicedToArray.js","webpack:///./node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js","webpack:///./node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js","webpack:///./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js","webpack:///./node_modules/@babel/runtime/helpers/esm/nonIterableRest.js","webpack:///./src/javascripts/domains/i18n/selectors.ts","webpack:///./src/javascripts/domains/i18n/hooks.ts","webpack:///./src/javascripts/domains/interrupt/hooks.ts","webpack:///./src/javascripts/domains/interrupt/selectors.ts","webpack:///./src/javascripts/domains/interrupt/slice.ts","webpack:///./src/javascripts/domains/store/actions.ts","webpack:///./src/javascripts/domains/i18n/slice.ts","webpack:///./src/javascripts/domains/store/index.ts","webpack:///./src/javascripts/domains/store/slice.ts","webpack:///./src/javascripts/domains/translations/selectors.ts","webpack:///./src/javascripts/domains/translations/hooks.ts","webpack:///./src/javascripts/domains/translations/slice.ts","webpack:///./src/javascripts/domains/visibility/actions.ts","webpack:///./src/javascripts/domains/visibility/constants.ts","webpack:///./src/javascripts/domains/visibility/hooks.ts","webpack:///./src/javascripts/domains/visibility/selectors.ts","webpack:///./src/javascripts/domains/visibility/slice.ts","webpack:///./src/javascripts/ui/components/core/seamly-api-context.ts","webpack:///./src/javascripts/ui/hooks/seamly-api-hooks.ts","webpack:///./src/javascripts/ui/hooks/seamly-state-hooks.ts","webpack:///./src/javascripts/ui/utils/seamly-utils.ts","webpack:///./src/javascripts/api/errors/seamly-base-error.js","webpack:///./src/javascripts/api/errors/seamly-configuration-error.js","webpack:///./src/javascripts/api/errors/seamly-general-error.js","webpack:///./src/javascripts/api/errors/seamly-offline-error.js","webpack:///./src/javascripts/api/errors/seamly-session-expired-error.js","webpack:///./src/javascripts/api/errors/seamly-unauthorized-error.js","webpack:///./src/javascripts/api/errors/seamly-unavailable-error.js","webpack:///./src/javascripts/domains/app/hooks.js","webpack:///./src/javascripts/domains/visibility/utils.js","webpack:///./src/javascripts/lib/css.js","webpack:///./src/javascripts/lib/debug.js","webpack:///./src/javascripts/lib/id.js","webpack:///./src/javascripts/ui/components/conversation/event/choice-prompt.js","webpack:///./src/javascripts/ui/components/conversation/event/event-participant.js","webpack:///./src/javascripts/ui/components/conversation/message-container.js","webpack:///./src/javascripts/ui/components/core/seamly-activity-event-context.js","webpack:///./src/javascripts/ui/components/core/seamly-file-upload-context.js","webpack:///./src/javascripts/ui/components/core/seamly-live-region-context.js","webpack:///./src/javascripts/ui/hooks/component-helper-hooks.js","webpack:///./src/javascripts/ui/hooks/focus-helper-hooks.js","webpack:///./src/javascripts/ui/hooks/live-region-hooks.js","webpack:///./src/javascripts/ui/hooks/file-upload-hooks.js","webpack:///./src/javascripts/ui/hooks/seamly-option-hooks.js","webpack:///./src/javascripts/ui/hooks/use-seamly-activity-event-handler.js","webpack:///./src/javascripts/ui/hooks/use-seamly-commands.js","webpack:///./src/javascripts/ui/hooks/use-seamly-idle-detach-countdown.js","webpack:///./src/javascripts/ui/hooks/use-seamly-resume-conversation-prompt.js","webpack:///./src/javascripts/ui/hooks/utility-hooks.js","webpack:///./src/javascripts/ui/utils/general-utils.js","webpack:///./node_modules/preact/compat/dist/compat.module.js","webpack:///./src/javascripts/ui/components/layout/icon.tsx","webpack:///./src/icons/icon_send-32.svg","webpack:///./src/icons/icon_balloon-32.svg","webpack:///./src/icons/icon_newtopic-32.svg","webpack:///./src/icons/icon_newtranslation-16.svg","webpack:///./src/icons/icon_newtranslation-32.svg","webpack:///./src/icons/avatar_bot-32.svg","webpack:///./src/icons/icon_chevron_down-8.svg","webpack:///./src/icons/icon_chevron_down-32.svg","webpack:///./src/icons/icon_chevron_right-8.svg","webpack:///./src/icons/icon_chevron_right-16.svg","webpack:///./src/icons/icon_close-8.svg","webpack:///./src/icons/icon_close-16.svg","webpack:///./src/icons/icon_enlarge-32.svg","webpack:///./src/icons/icon_options-32.svg","webpack:///./src/icons/icon_file-32.svg","webpack:///./src/icons/icon_upload-32.svg","webpack:///./src/icons/icon_download-16.svg","webpack:///./src/icons/icon_error-16.svg","webpack:///./src/icons/icon_arrow_left-16.svg","webpack:///./src/icons/icon_arrow_right-16.svg","webpack:///./src/icons/icon_check-16.svg","webpack:///./src/icons/icon_check-32.svg","webpack:///./node_modules/use-sync-external-store/cjs/use-sync-external-store-with-selector.production.min.js","webpack:///./node_modules/use-sync-external-store/with-selector.js","webpack:///external commonjs2 \"preact\"","webpack:///external commonjs2 \"preact/compat\"","webpack:///external commonjs2 \"preact/hooks\"","webpack:///external commonjs2 \"preact/jsx-runtime\"","webpack:///./node_modules/immer/dist/immer.mjs","webpack:///./node_modules/@reduxjs/toolkit/dist/redux-toolkit.modern.mjs","webpack:///./node_modules/react-redux/dist/react-redux.mjs","webpack:///./node_modules/redux/dist/redux.mjs","webpack:///./node_modules/reselect/dist/reselect.mjs","webpack:///webpack/bootstrap","webpack:///webpack/runtime/compat get default export","webpack:///webpack/runtime/define property getters","webpack:///webpack/runtime/global","webpack:///webpack/runtime/hasOwnProperty shorthand","webpack:///webpack/runtime/make namespace object","webpack:///webpack/runtime/publicPath","webpack:///./src/javascripts/ui/components/layout/privacy-disclaimer.js","webpack:///./src/javascripts/domains/forms/selectors.ts","webpack:///./src/javascripts/domains/forms/context.ts","webpack:///./src/javascripts/domains/forms/hooks.ts","webpack:///./src/javascripts/ui/components/entry/text-entry/hooks.ts","webpack:///./src/javascripts/ui/components/entry/abort-transaction-button/abort-transaction-button.tsx","webpack:///./src/javascripts/ui/components/conversation/component-context.js","webpack:///./src/javascripts/ui/components/conversation/event/card-component.tsx","webpack:///./src/javascripts/ui/components/conversation/event/carousel-message/components/slide.js","webpack:///./src/javascripts/ui/components/conversation/event/carousel-component/components/controls.js","webpack:///./src/javascripts/ui/components/conversation/event/carousel-component/components/pagination.js","webpack:///./src/javascripts/ui/components/conversation/event/carousel-component/index.js","webpack:///./src/javascripts/ui/components/conversation/event/carousel-message/index.js","webpack:///./src/javascripts/ui/components/suggestions/suggestions-item.js","webpack:///./src/javascripts/ui/components/suggestions/suggestions-list.js","webpack:///./src/javascripts/ui/components/conversation/event/hooks/use-event-link-click-handler.js","webpack:///./src/javascripts/ui/components/conversation/event-divider.js","webpack:///./src/javascripts/ui/components/conversation/event/divider/variants/default.js","webpack:///./src/javascripts/ui/components/conversation/event/divider/variants/new-translation.js","webpack:///./src/javascripts/ui/components/conversation/event/divider/index.js","webpack:///./src/javascripts/ui/components/conversation/event/hooks/use-formatted-date.js","webpack:///./src/javascripts/ui/components/conversation/event/divider/variants/time-indicator.js","webpack:///./node_modules/tabbable/dist/index.esm.js","webpack:///./node_modules/focus-trap/dist/focus-trap.esm.js","webpack:///./src/javascripts/ui/components/widgets/modal.js","webpack:///./src/javascripts/ui/components/widgets/lightbox.js","webpack:///./src/javascripts/ui/components/conversation/event/image-lightbox.js","webpack:///./src/javascripts/ui/components/conversation/event/text.js","webpack:///./src/javascripts/ui/components/conversation/event/upload.js","webpack:///./src/javascripts/ui/components/conversation/component-filter.js","webpack:///./src/javascripts/ui/components/conversation/event/image.js","webpack:///./src/javascripts/ui/components/conversation/event/splash.js","webpack:///./src/javascripts/ui/components/conversation/event/video.js","webpack:///./src/javascripts/ui/components/conversation/event/cta.js","webpack:///./src/javascripts/ui/components/conversation/event/card-message.js","webpack:///./src/javascripts/ui/components/conversation/event/translation.js","webpack:///./src/javascripts/ui/components/conversation/event/participant.js","webpack:///./src/javascripts/ui/components/conversation/event/conversation-suggestions.js","webpack:///./src/javascripts/ui/components/conversation/event/chat-scroll/chat-scroll-context.ts","webpack:///./src/javascripts/ui/hooks/use-event-component-mapping.js","webpack:///./src/javascripts/ui/components/conversation/event/event.tsx","webpack:///./src/javascripts/ui/components/conversation/loader.js","webpack:///./src/javascripts/ui/components/conversation/conversation.tsx","webpack:///./src/javascripts/ui/hooks/use-debounce.ts","webpack:///./src/javascripts/ui/components/warnings/prompt.js","webpack:///./src/javascripts/ui/components/warnings/idle-detach-warning.js","webpack:///./src/javascripts/ui/components/warnings/resume-conversation-prompt.js","webpack:///./src/javascripts/ui/hooks/seamly-entry-hooks.js","webpack:///./src/javascripts/domains/forms/provider.tsx","webpack:///./src/javascripts/domains/forms/utils.ts","webpack:///./src/javascripts/ui/components/form-controls/form.js","webpack:///./src/javascripts/ui/components/form-controls/error.js","webpack:///./src/javascripts/ui/components/form-controls/wrapper.tsx","webpack:///./src/javascripts/ui/components/form-controls/input.tsx","webpack:///./src/javascripts/ui/components/entry/text-entry/text-entry-form.tsx","webpack:///./src/javascripts/ui/components/entry/text-entry/index.js","webpack:///./src/javascripts/ui/components/widgets/upload-progress.js","webpack:///./src/javascripts/ui/utils/form-utils.js","webpack:///./src/javascripts/ui/utils/validations.js","webpack:///./src/javascripts/ui/components/form-controls/file-input.js","webpack:///./src/javascripts/ui/components/entry/upload/file-upload-form.js","webpack:///./src/javascripts/ui/components/entry/upload/index.js","webpack:///./src/javascripts/ui/hooks/use-single-file-upload.js","webpack:///./src/javascripts/ui/hooks/use-timeout.ts","webpack:///./src/javascripts/ui/components/widgets/in-out-transition.tsx","webpack:///./src/javascripts/ui/components/entry/upload-toggle.js","webpack:///./src/javascripts/ui/components/entry/entry-container.js","webpack:///./src/javascripts/ui/components/layout/agent-info.js","webpack:///./src/javascripts/ui/components/suggestions/index.js","webpack:///./src/javascripts/ui/components/layout/chat.js","webpack:///./src/javascripts/ui/components/chat-status/index.tsx","webpack:///./src/javascripts/ui/components/chat-status/chat-status-action.tsx","webpack:///./src/javascripts/ui/components/translation-proposal/index.tsx","webpack:///./src/javascripts/domains/translations/components/translation-status.tsx","webpack:///./src/javascripts/domains/translations/components/options-dialog/translation-option.tsx","webpack:///./src/javascripts/domains/translations/components/options-dialog/translation-options.tsx","webpack:///./src/javascripts/ui/components/options/options-frame.tsx","webpack:///./src/javascripts/ui/hooks/use-click-outside.ts","webpack:///./src/javascripts/domains/translations/components/options-dialog/index.tsx","webpack:///./src/javascripts/domains/translations/components/options-button.tsx","webpack:///./src/javascripts/ui/components/options/transcript/transcript-form.js","webpack:///./src/javascripts/ui/components/options/transcript/index.js","webpack:///./src/javascripts/ui/components/options/options.js","webpack:///./src/javascripts/ui/components/options/options-button.js","webpack:///./src/javascripts/ui/components/app-options/index.js","webpack:///./src/javascripts/ui/components/conversation/event/chat-scroll/unread-messages-button.tsx","webpack:///./src/javascripts/domains/store/selectors.ts","webpack:///./src/javascripts/ui/components/conversation/use-chat-scroll.ts","webpack:///./src/javascripts/ui/components/conversation/event/chat-scroll/chat-scroll-provider.tsx","webpack:///./src/javascripts/ui/components/view/window-view/collapse-button.js","webpack:///./src/javascripts/ui/components/layout/interrupt.js","webpack:///./src/javascripts/ui/components/layout/chat-frame.js","webpack:///./src/javascripts/ui/components/layout/header.js","webpack:///./src/javascripts/ui/components/layout/collapsed-chat-messages.tsx","webpack:///./src/javascripts/ui/components/layout/pre-chat-messages.tsx","webpack:///./src/javascripts/ui/components/layout/continue-chat-messages.tsx","webpack:///./src/javascripts/ui/components/view/window-view/window-open-button.js","webpack:///./src/javascripts/ui/components/view/window-view/index.tsx","webpack:///./src/javascripts/ui/hooks/sounds/beep.mp3","webpack:///./src/javascripts/ui/hooks/use-notifications.ts","webpack:///./src/javascripts/ui/components/view/index.tsx","webpack:///./src/javascripts/ui/components/view/app-view.js","webpack:///./src/javascripts/ui/components/view/inline-view.js"],"sourcesContent":["// js/phoenix/utils.js\nvar closure = (value) => {\n if (typeof value === \"function\") {\n return value;\n } else {\n let closure2 = function() {\n return value;\n };\n return closure2;\n }\n};\n\n// js/phoenix/constants.js\nvar globalSelf = typeof self !== \"undefined\" ? self : null;\nvar phxWindow = typeof window !== \"undefined\" ? window : null;\nvar global = globalSelf || phxWindow || global;\nvar DEFAULT_VSN = \"2.0.0\";\nvar SOCKET_STATES = { connecting: 0, open: 1, closing: 2, closed: 3 };\nvar DEFAULT_TIMEOUT = 1e4;\nvar WS_CLOSE_NORMAL = 1e3;\nvar CHANNEL_STATES = {\n closed: \"closed\",\n errored: \"errored\",\n joined: \"joined\",\n joining: \"joining\",\n leaving: \"leaving\"\n};\nvar CHANNEL_EVENTS = {\n close: \"phx_close\",\n error: \"phx_error\",\n join: \"phx_join\",\n reply: \"phx_reply\",\n leave: \"phx_leave\"\n};\nvar TRANSPORTS = {\n longpoll: \"longpoll\",\n websocket: \"websocket\"\n};\nvar XHR_STATES = {\n complete: 4\n};\n\n// js/phoenix/push.js\nvar Push = class {\n constructor(channel, event, payload, timeout) {\n this.channel = channel;\n this.event = event;\n this.payload = payload || function() {\n return {};\n };\n this.receivedResp = null;\n this.timeout = timeout;\n this.timeoutTimer = null;\n this.recHooks = [];\n this.sent = false;\n }\n /**\n *\n * @param {number} timeout\n */\n resend(timeout) {\n this.timeout = timeout;\n this.reset();\n this.send();\n }\n /**\n *\n */\n send() {\n if (this.hasReceived(\"timeout\")) {\n return;\n }\n this.startTimeout();\n this.sent = true;\n this.channel.socket.push({\n topic: this.channel.topic,\n event: this.event,\n payload: this.payload(),\n ref: this.ref,\n join_ref: this.channel.joinRef()\n });\n }\n /**\n *\n * @param {*} status\n * @param {*} callback\n */\n receive(status, callback) {\n if (this.hasReceived(status)) {\n callback(this.receivedResp.response);\n }\n this.recHooks.push({ status, callback });\n return this;\n }\n /**\n * @private\n */\n reset() {\n this.cancelRefEvent();\n this.ref = null;\n this.refEvent = null;\n this.receivedResp = null;\n this.sent = false;\n }\n /**\n * @private\n */\n matchReceive({ status, response, _ref }) {\n this.recHooks.filter((h) => h.status === status).forEach((h) => h.callback(response));\n }\n /**\n * @private\n */\n cancelRefEvent() {\n if (!this.refEvent) {\n return;\n }\n this.channel.off(this.refEvent);\n }\n /**\n * @private\n */\n cancelTimeout() {\n clearTimeout(this.timeoutTimer);\n this.timeoutTimer = null;\n }\n /**\n * @private\n */\n startTimeout() {\n if (this.timeoutTimer) {\n this.cancelTimeout();\n }\n this.ref = this.channel.socket.makeRef();\n this.refEvent = this.channel.replyEventName(this.ref);\n this.channel.on(this.refEvent, (payload) => {\n this.cancelRefEvent();\n this.cancelTimeout();\n this.receivedResp = payload;\n this.matchReceive(payload);\n });\n this.timeoutTimer = setTimeout(() => {\n this.trigger(\"timeout\", {});\n }, this.timeout);\n }\n /**\n * @private\n */\n hasReceived(status) {\n return this.receivedResp && this.receivedResp.status === status;\n }\n /**\n * @private\n */\n trigger(status, response) {\n this.channel.trigger(this.refEvent, { status, response });\n }\n};\n\n// js/phoenix/timer.js\nvar Timer = class {\n constructor(callback, timerCalc) {\n this.callback = callback;\n this.timerCalc = timerCalc;\n this.timer = null;\n this.tries = 0;\n }\n reset() {\n this.tries = 0;\n clearTimeout(this.timer);\n }\n /**\n * Cancels any previous scheduleTimeout and schedules callback\n */\n scheduleTimeout() {\n clearTimeout(this.timer);\n this.timer = setTimeout(() => {\n this.tries = this.tries + 1;\n this.callback();\n }, this.timerCalc(this.tries + 1));\n }\n};\n\n// js/phoenix/channel.js\nvar Channel = class {\n constructor(topic, params, socket) {\n this.state = CHANNEL_STATES.closed;\n this.topic = topic;\n this.params = closure(params || {});\n this.socket = socket;\n this.bindings = [];\n this.bindingRef = 0;\n this.timeout = this.socket.timeout;\n this.joinedOnce = false;\n this.joinPush = new Push(this, CHANNEL_EVENTS.join, this.params, this.timeout);\n this.pushBuffer = [];\n this.stateChangeRefs = [];\n this.rejoinTimer = new Timer(() => {\n if (this.socket.isConnected()) {\n this.rejoin();\n }\n }, this.socket.rejoinAfterMs);\n this.stateChangeRefs.push(this.socket.onError(() => this.rejoinTimer.reset()));\n this.stateChangeRefs.push(\n this.socket.onOpen(() => {\n this.rejoinTimer.reset();\n if (this.isErrored()) {\n this.rejoin();\n }\n })\n );\n this.joinPush.receive(\"ok\", () => {\n this.state = CHANNEL_STATES.joined;\n this.rejoinTimer.reset();\n this.pushBuffer.forEach((pushEvent) => pushEvent.send());\n this.pushBuffer = [];\n });\n this.joinPush.receive(\"error\", () => {\n this.state = CHANNEL_STATES.errored;\n if (this.socket.isConnected()) {\n this.rejoinTimer.scheduleTimeout();\n }\n });\n this.onClose(() => {\n this.rejoinTimer.reset();\n if (this.socket.hasLogger())\n this.socket.log(\"channel\", `close ${this.topic} ${this.joinRef()}`);\n this.state = CHANNEL_STATES.closed;\n this.socket.remove(this);\n });\n this.onError((reason) => {\n if (this.socket.hasLogger())\n this.socket.log(\"channel\", `error ${this.topic}`, reason);\n if (this.isJoining()) {\n this.joinPush.reset();\n }\n this.state = CHANNEL_STATES.errored;\n if (this.socket.isConnected()) {\n this.rejoinTimer.scheduleTimeout();\n }\n });\n this.joinPush.receive(\"timeout\", () => {\n if (this.socket.hasLogger())\n this.socket.log(\"channel\", `timeout ${this.topic} (${this.joinRef()})`, this.joinPush.timeout);\n let leavePush = new Push(this, CHANNEL_EVENTS.leave, closure({}), this.timeout);\n leavePush.send();\n this.state = CHANNEL_STATES.errored;\n this.joinPush.reset();\n if (this.socket.isConnected()) {\n this.rejoinTimer.scheduleTimeout();\n }\n });\n this.on(CHANNEL_EVENTS.reply, (payload, ref) => {\n this.trigger(this.replyEventName(ref), payload);\n });\n }\n /**\n * Join the channel\n * @param {integer} timeout\n * @returns {Push}\n */\n join(timeout = this.timeout) {\n if (this.joinedOnce) {\n throw new Error(\"tried to join multiple times. 'join' can only be called a single time per channel instance\");\n } else {\n this.timeout = timeout;\n this.joinedOnce = true;\n this.rejoin();\n return this.joinPush;\n }\n }\n /**\n * Hook into channel close\n * @param {Function} callback\n */\n onClose(callback) {\n this.on(CHANNEL_EVENTS.close, callback);\n }\n /**\n * Hook into channel errors\n * @param {Function} callback\n */\n onError(callback) {\n return this.on(CHANNEL_EVENTS.error, (reason) => callback(reason));\n }\n /**\n * Subscribes on channel events\n *\n * Subscription returns a ref counter, which can be used later to\n * unsubscribe the exact event listener\n *\n * @example\n * const ref1 = channel.on(\"event\", do_stuff)\n * const ref2 = channel.on(\"event\", do_other_stuff)\n * channel.off(\"event\", ref1)\n * // Since unsubscription, do_stuff won't fire,\n * // while do_other_stuff will keep firing on the \"event\"\n *\n * @param {string} event\n * @param {Function} callback\n * @returns {integer} ref\n */\n on(event, callback) {\n let ref = this.bindingRef++;\n this.bindings.push({ event, ref, callback });\n return ref;\n }\n /**\n * Unsubscribes off of channel events\n *\n * Use the ref returned from a channel.on() to unsubscribe one\n * handler, or pass nothing for the ref to unsubscribe all\n * handlers for the given event.\n *\n * @example\n * // Unsubscribe the do_stuff handler\n * const ref1 = channel.on(\"event\", do_stuff)\n * channel.off(\"event\", ref1)\n *\n * // Unsubscribe all handlers from event\n * channel.off(\"event\")\n *\n * @param {string} event\n * @param {integer} ref\n */\n off(event, ref) {\n this.bindings = this.bindings.filter((bind) => {\n return !(bind.event === event && (typeof ref === \"undefined\" || ref === bind.ref));\n });\n }\n /**\n * @private\n */\n canPush() {\n return this.socket.isConnected() && this.isJoined();\n }\n /**\n * Sends a message `event` to phoenix with the payload `payload`.\n * Phoenix receives this in the `handle_in(event, payload, socket)`\n * function. if phoenix replies or it times out (default 10000ms),\n * then optionally the reply can be received.\n *\n * @example\n * channel.push(\"event\")\n * .receive(\"ok\", payload => console.log(\"phoenix replied:\", payload))\n * .receive(\"error\", err => console.log(\"phoenix errored\", err))\n * .receive(\"timeout\", () => console.log(\"timed out pushing\"))\n * @param {string} event\n * @param {Object} payload\n * @param {number} [timeout]\n * @returns {Push}\n */\n push(event, payload, timeout = this.timeout) {\n payload = payload || {};\n if (!this.joinedOnce) {\n throw new Error(`tried to push '${event}' to '${this.topic}' before joining. Use channel.join() before pushing events`);\n }\n let pushEvent = new Push(this, event, function() {\n return payload;\n }, timeout);\n if (this.canPush()) {\n pushEvent.send();\n } else {\n pushEvent.startTimeout();\n this.pushBuffer.push(pushEvent);\n }\n return pushEvent;\n }\n /** Leaves the channel\n *\n * Unsubscribes from server events, and\n * instructs channel to terminate on server\n *\n * Triggers onClose() hooks\n *\n * To receive leave acknowledgements, use the `receive`\n * hook to bind to the server ack, ie:\n *\n * @example\n * channel.leave().receive(\"ok\", () => alert(\"left!\") )\n *\n * @param {integer} timeout\n * @returns {Push}\n */\n leave(timeout = this.timeout) {\n this.rejoinTimer.reset();\n this.joinPush.cancelTimeout();\n this.state = CHANNEL_STATES.leaving;\n let onClose = () => {\n if (this.socket.hasLogger())\n this.socket.log(\"channel\", `leave ${this.topic}`);\n this.trigger(CHANNEL_EVENTS.close, \"leave\");\n };\n let leavePush = new Push(this, CHANNEL_EVENTS.leave, closure({}), timeout);\n leavePush.receive(\"ok\", () => onClose()).receive(\"timeout\", () => onClose());\n leavePush.send();\n if (!this.canPush()) {\n leavePush.trigger(\"ok\", {});\n }\n return leavePush;\n }\n /**\n * Overridable message hook\n *\n * Receives all events for specialized message handling\n * before dispatching to the channel callbacks.\n *\n * Must return the payload, modified or unmodified\n * @param {string} event\n * @param {Object} payload\n * @param {integer} ref\n * @returns {Object}\n */\n onMessage(_event, payload, _ref) {\n return payload;\n }\n /**\n * @private\n */\n isMember(topic, event, payload, joinRef) {\n if (this.topic !== topic) {\n return false;\n }\n if (joinRef && joinRef !== this.joinRef()) {\n if (this.socket.hasLogger())\n this.socket.log(\"channel\", \"dropping outdated message\", { topic, event, payload, joinRef });\n return false;\n } else {\n return true;\n }\n }\n /**\n * @private\n */\n joinRef() {\n return this.joinPush.ref;\n }\n /**\n * @private\n */\n rejoin(timeout = this.timeout) {\n if (this.isLeaving()) {\n return;\n }\n this.socket.leaveOpenTopic(this.topic);\n this.state = CHANNEL_STATES.joining;\n this.joinPush.resend(timeout);\n }\n /**\n * @private\n */\n trigger(event, payload, ref, joinRef) {\n let handledPayload = this.onMessage(event, payload, ref, joinRef);\n if (payload && !handledPayload) {\n throw new Error(\"channel onMessage callbacks must return the payload, modified or unmodified\");\n }\n let eventBindings = this.bindings.filter((bind) => bind.event === event);\n for (let i = 0; i < eventBindings.length; i++) {\n let bind = eventBindings[i];\n bind.callback(handledPayload, ref, joinRef || this.joinRef());\n }\n }\n /**\n * @private\n */\n replyEventName(ref) {\n return `chan_reply_${ref}`;\n }\n /**\n * @private\n */\n isClosed() {\n return this.state === CHANNEL_STATES.closed;\n }\n /**\n * @private\n */\n isErrored() {\n return this.state === CHANNEL_STATES.errored;\n }\n /**\n * @private\n */\n isJoined() {\n return this.state === CHANNEL_STATES.joined;\n }\n /**\n * @private\n */\n isJoining() {\n return this.state === CHANNEL_STATES.joining;\n }\n /**\n * @private\n */\n isLeaving() {\n return this.state === CHANNEL_STATES.leaving;\n }\n};\n\n// js/phoenix/ajax.js\nvar Ajax = class {\n static request(method, endPoint, accept, body, timeout, ontimeout, callback) {\n if (global.XDomainRequest) {\n let req = new global.XDomainRequest();\n return this.xdomainRequest(req, method, endPoint, body, timeout, ontimeout, callback);\n } else {\n let req = new global.XMLHttpRequest();\n return this.xhrRequest(req, method, endPoint, accept, body, timeout, ontimeout, callback);\n }\n }\n static xdomainRequest(req, method, endPoint, body, timeout, ontimeout, callback) {\n req.timeout = timeout;\n req.open(method, endPoint);\n req.onload = () => {\n let response = this.parseJSON(req.responseText);\n callback && callback(response);\n };\n if (ontimeout) {\n req.ontimeout = ontimeout;\n }\n req.onprogress = () => {\n };\n req.send(body);\n return req;\n }\n static xhrRequest(req, method, endPoint, accept, body, timeout, ontimeout, callback) {\n req.open(method, endPoint, true);\n req.timeout = timeout;\n req.setRequestHeader(\"Content-Type\", accept);\n req.onerror = () => callback && callback(null);\n req.onreadystatechange = () => {\n if (req.readyState === XHR_STATES.complete && callback) {\n let response = this.parseJSON(req.responseText);\n callback(response);\n }\n };\n if (ontimeout) {\n req.ontimeout = ontimeout;\n }\n req.send(body);\n return req;\n }\n static parseJSON(resp) {\n if (!resp || resp === \"\") {\n return null;\n }\n try {\n return JSON.parse(resp);\n } catch (e) {\n console && console.log(\"failed to parse JSON response\", resp);\n return null;\n }\n }\n static serialize(obj, parentKey) {\n let queryStr = [];\n for (var key in obj) {\n if (!Object.prototype.hasOwnProperty.call(obj, key)) {\n continue;\n }\n let paramKey = parentKey ? `${parentKey}[${key}]` : key;\n let paramVal = obj[key];\n if (typeof paramVal === \"object\") {\n queryStr.push(this.serialize(paramVal, paramKey));\n } else {\n queryStr.push(encodeURIComponent(paramKey) + \"=\" + encodeURIComponent(paramVal));\n }\n }\n return queryStr.join(\"&\");\n }\n static appendParams(url, params) {\n if (Object.keys(params).length === 0) {\n return url;\n }\n let prefix = url.match(/\\?/) ? \"&\" : \"?\";\n return `${url}${prefix}${this.serialize(params)}`;\n }\n};\n\n// js/phoenix/longpoll.js\nvar arrayBufferToBase64 = (buffer) => {\n let binary = \"\";\n let bytes = new Uint8Array(buffer);\n let len = bytes.byteLength;\n for (let i = 0; i < len; i++) {\n binary += String.fromCharCode(bytes[i]);\n }\n return btoa(binary);\n};\nvar LongPoll = class {\n constructor(endPoint) {\n this.endPoint = null;\n this.token = null;\n this.skipHeartbeat = true;\n this.reqs = /* @__PURE__ */ new Set();\n this.awaitingBatchAck = false;\n this.currentBatch = null;\n this.currentBatchTimer = null;\n this.batchBuffer = [];\n this.onopen = function() {\n };\n this.onerror = function() {\n };\n this.onmessage = function() {\n };\n this.onclose = function() {\n };\n this.pollEndpoint = this.normalizeEndpoint(endPoint);\n this.readyState = SOCKET_STATES.connecting;\n setTimeout(() => this.poll(), 0);\n }\n normalizeEndpoint(endPoint) {\n return endPoint.replace(\"ws://\", \"http://\").replace(\"wss://\", \"https://\").replace(new RegExp(\"(.*)/\" + TRANSPORTS.websocket), \"$1/\" + TRANSPORTS.longpoll);\n }\n endpointURL() {\n return Ajax.appendParams(this.pollEndpoint, { token: this.token });\n }\n closeAndRetry(code, reason, wasClean) {\n this.close(code, reason, wasClean);\n this.readyState = SOCKET_STATES.connecting;\n }\n ontimeout() {\n this.onerror(\"timeout\");\n this.closeAndRetry(1005, \"timeout\", false);\n }\n isActive() {\n return this.readyState === SOCKET_STATES.open || this.readyState === SOCKET_STATES.connecting;\n }\n poll() {\n this.ajax(\"GET\", \"application/json\", null, () => this.ontimeout(), (resp) => {\n if (resp) {\n var { status, token, messages } = resp;\n this.token = token;\n } else {\n status = 0;\n }\n switch (status) {\n case 200:\n messages.forEach((msg) => {\n setTimeout(() => this.onmessage({ data: msg }), 0);\n });\n this.poll();\n break;\n case 204:\n this.poll();\n break;\n case 410:\n this.readyState = SOCKET_STATES.open;\n this.onopen({});\n this.poll();\n break;\n case 403:\n this.onerror(403);\n this.close(1008, \"forbidden\", false);\n break;\n case 0:\n case 500:\n this.onerror(500);\n this.closeAndRetry(1011, \"internal server error\", 500);\n break;\n default:\n throw new Error(`unhandled poll status ${status}`);\n }\n });\n }\n // we collect all pushes within the current event loop by\n // setTimeout 0, which optimizes back-to-back procedural\n // pushes against an empty buffer\n send(body) {\n if (typeof body !== \"string\") {\n body = arrayBufferToBase64(body);\n }\n if (this.currentBatch) {\n this.currentBatch.push(body);\n } else if (this.awaitingBatchAck) {\n this.batchBuffer.push(body);\n } else {\n this.currentBatch = [body];\n this.currentBatchTimer = setTimeout(() => {\n this.batchSend(this.currentBatch);\n this.currentBatch = null;\n }, 0);\n }\n }\n batchSend(messages) {\n this.awaitingBatchAck = true;\n this.ajax(\"POST\", \"application/x-ndjson\", messages.join(\"\\n\"), () => this.onerror(\"timeout\"), (resp) => {\n this.awaitingBatchAck = false;\n if (!resp || resp.status !== 200) {\n this.onerror(resp && resp.status);\n this.closeAndRetry(1011, \"internal server error\", false);\n } else if (this.batchBuffer.length > 0) {\n this.batchSend(this.batchBuffer);\n this.batchBuffer = [];\n }\n });\n }\n close(code, reason, wasClean) {\n for (let req of this.reqs) {\n req.abort();\n }\n this.readyState = SOCKET_STATES.closed;\n let opts = Object.assign({ code: 1e3, reason: void 0, wasClean: true }, { code, reason, wasClean });\n this.batchBuffer = [];\n clearTimeout(this.currentBatchTimer);\n this.currentBatchTimer = null;\n if (typeof CloseEvent !== \"undefined\") {\n this.onclose(new CloseEvent(\"close\", opts));\n } else {\n this.onclose(opts);\n }\n }\n ajax(method, contentType, body, onCallerTimeout, callback) {\n let req;\n let ontimeout = () => {\n this.reqs.delete(req);\n onCallerTimeout();\n };\n req = Ajax.request(method, this.endpointURL(), contentType, body, this.timeout, ontimeout, (resp) => {\n this.reqs.delete(req);\n if (this.isActive()) {\n callback(resp);\n }\n });\n this.reqs.add(req);\n }\n};\n\n// js/phoenix/presence.js\nvar Presence = class {\n constructor(channel, opts = {}) {\n let events = opts.events || { state: \"presence_state\", diff: \"presence_diff\" };\n this.state = {};\n this.pendingDiffs = [];\n this.channel = channel;\n this.joinRef = null;\n this.caller = {\n onJoin: function() {\n },\n onLeave: function() {\n },\n onSync: function() {\n }\n };\n this.channel.on(events.state, (newState) => {\n let { onJoin, onLeave, onSync } = this.caller;\n this.joinRef = this.channel.joinRef();\n this.state = Presence.syncState(this.state, newState, onJoin, onLeave);\n this.pendingDiffs.forEach((diff) => {\n this.state = Presence.syncDiff(this.state, diff, onJoin, onLeave);\n });\n this.pendingDiffs = [];\n onSync();\n });\n this.channel.on(events.diff, (diff) => {\n let { onJoin, onLeave, onSync } = this.caller;\n if (this.inPendingSyncState()) {\n this.pendingDiffs.push(diff);\n } else {\n this.state = Presence.syncDiff(this.state, diff, onJoin, onLeave);\n onSync();\n }\n });\n }\n onJoin(callback) {\n this.caller.onJoin = callback;\n }\n onLeave(callback) {\n this.caller.onLeave = callback;\n }\n onSync(callback) {\n this.caller.onSync = callback;\n }\n list(by) {\n return Presence.list(this.state, by);\n }\n inPendingSyncState() {\n return !this.joinRef || this.joinRef !== this.channel.joinRef();\n }\n // lower-level public static API\n /**\n * Used to sync the list of presences on the server\n * with the client's state. An optional `onJoin` and `onLeave` callback can\n * be provided to react to changes in the client's local presences across\n * disconnects and reconnects with the server.\n *\n * @returns {Presence}\n */\n static syncState(currentState, newState, onJoin, onLeave) {\n let state = this.clone(currentState);\n let joins = {};\n let leaves = {};\n this.map(state, (key, presence) => {\n if (!newState[key]) {\n leaves[key] = presence;\n }\n });\n this.map(newState, (key, newPresence) => {\n let currentPresence = state[key];\n if (currentPresence) {\n let newRefs = newPresence.metas.map((m) => m.phx_ref);\n let curRefs = currentPresence.metas.map((m) => m.phx_ref);\n let joinedMetas = newPresence.metas.filter((m) => curRefs.indexOf(m.phx_ref) < 0);\n let leftMetas = currentPresence.metas.filter((m) => newRefs.indexOf(m.phx_ref) < 0);\n if (joinedMetas.length > 0) {\n joins[key] = newPresence;\n joins[key].metas = joinedMetas;\n }\n if (leftMetas.length > 0) {\n leaves[key] = this.clone(currentPresence);\n leaves[key].metas = leftMetas;\n }\n } else {\n joins[key] = newPresence;\n }\n });\n return this.syncDiff(state, { joins, leaves }, onJoin, onLeave);\n }\n /**\n *\n * Used to sync a diff of presence join and leave\n * events from the server, as they happen. Like `syncState`, `syncDiff`\n * accepts optional `onJoin` and `onLeave` callbacks to react to a user\n * joining or leaving from a device.\n *\n * @returns {Presence}\n */\n static syncDiff(state, diff, onJoin, onLeave) {\n let { joins, leaves } = this.clone(diff);\n if (!onJoin) {\n onJoin = function() {\n };\n }\n if (!onLeave) {\n onLeave = function() {\n };\n }\n this.map(joins, (key, newPresence) => {\n let currentPresence = state[key];\n state[key] = this.clone(newPresence);\n if (currentPresence) {\n let joinedRefs = state[key].metas.map((m) => m.phx_ref);\n let curMetas = currentPresence.metas.filter((m) => joinedRefs.indexOf(m.phx_ref) < 0);\n state[key].metas.unshift(...curMetas);\n }\n onJoin(key, currentPresence, newPresence);\n });\n this.map(leaves, (key, leftPresence) => {\n let currentPresence = state[key];\n if (!currentPresence) {\n return;\n }\n let refsToRemove = leftPresence.metas.map((m) => m.phx_ref);\n currentPresence.metas = currentPresence.metas.filter((p) => {\n return refsToRemove.indexOf(p.phx_ref) < 0;\n });\n onLeave(key, currentPresence, leftPresence);\n if (currentPresence.metas.length === 0) {\n delete state[key];\n }\n });\n return state;\n }\n /**\n * Returns the array of presences, with selected metadata.\n *\n * @param {Object} presences\n * @param {Function} chooser\n *\n * @returns {Presence}\n */\n static list(presences, chooser) {\n if (!chooser) {\n chooser = function(key, pres) {\n return pres;\n };\n }\n return this.map(presences, (key, presence) => {\n return chooser(key, presence);\n });\n }\n // private\n static map(obj, func) {\n return Object.getOwnPropertyNames(obj).map((key) => func(key, obj[key]));\n }\n static clone(obj) {\n return JSON.parse(JSON.stringify(obj));\n }\n};\n\n// js/phoenix/serializer.js\nvar serializer_default = {\n HEADER_LENGTH: 1,\n META_LENGTH: 4,\n KINDS: { push: 0, reply: 1, broadcast: 2 },\n encode(msg, callback) {\n if (msg.payload.constructor === ArrayBuffer) {\n return callback(this.binaryEncode(msg));\n } else {\n let payload = [msg.join_ref, msg.ref, msg.topic, msg.event, msg.payload];\n return callback(JSON.stringify(payload));\n }\n },\n decode(rawPayload, callback) {\n if (rawPayload.constructor === ArrayBuffer) {\n return callback(this.binaryDecode(rawPayload));\n } else {\n let [join_ref, ref, topic, event, payload] = JSON.parse(rawPayload);\n return callback({ join_ref, ref, topic, event, payload });\n }\n },\n // private\n binaryEncode(message) {\n let { join_ref, ref, event, topic, payload } = message;\n let metaLength = this.META_LENGTH + join_ref.length + ref.length + topic.length + event.length;\n let header = new ArrayBuffer(this.HEADER_LENGTH + metaLength);\n let view = new DataView(header);\n let offset = 0;\n view.setUint8(offset++, this.KINDS.push);\n view.setUint8(offset++, join_ref.length);\n view.setUint8(offset++, ref.length);\n view.setUint8(offset++, topic.length);\n view.setUint8(offset++, event.length);\n Array.from(join_ref, (char) => view.setUint8(offset++, char.charCodeAt(0)));\n Array.from(ref, (char) => view.setUint8(offset++, char.charCodeAt(0)));\n Array.from(topic, (char) => view.setUint8(offset++, char.charCodeAt(0)));\n Array.from(event, (char) => view.setUint8(offset++, char.charCodeAt(0)));\n var combined = new Uint8Array(header.byteLength + payload.byteLength);\n combined.set(new Uint8Array(header), 0);\n combined.set(new Uint8Array(payload), header.byteLength);\n return combined.buffer;\n },\n binaryDecode(buffer) {\n let view = new DataView(buffer);\n let kind = view.getUint8(0);\n let decoder = new TextDecoder();\n switch (kind) {\n case this.KINDS.push:\n return this.decodePush(buffer, view, decoder);\n case this.KINDS.reply:\n return this.decodeReply(buffer, view, decoder);\n case this.KINDS.broadcast:\n return this.decodeBroadcast(buffer, view, decoder);\n }\n },\n decodePush(buffer, view, decoder) {\n let joinRefSize = view.getUint8(1);\n let topicSize = view.getUint8(2);\n let eventSize = view.getUint8(3);\n let offset = this.HEADER_LENGTH + this.META_LENGTH - 1;\n let joinRef = decoder.decode(buffer.slice(offset, offset + joinRefSize));\n offset = offset + joinRefSize;\n let topic = decoder.decode(buffer.slice(offset, offset + topicSize));\n offset = offset + topicSize;\n let event = decoder.decode(buffer.slice(offset, offset + eventSize));\n offset = offset + eventSize;\n let data = buffer.slice(offset, buffer.byteLength);\n return { join_ref: joinRef, ref: null, topic, event, payload: data };\n },\n decodeReply(buffer, view, decoder) {\n let joinRefSize = view.getUint8(1);\n let refSize = view.getUint8(2);\n let topicSize = view.getUint8(3);\n let eventSize = view.getUint8(4);\n let offset = this.HEADER_LENGTH + this.META_LENGTH;\n let joinRef = decoder.decode(buffer.slice(offset, offset + joinRefSize));\n offset = offset + joinRefSize;\n let ref = decoder.decode(buffer.slice(offset, offset + refSize));\n offset = offset + refSize;\n let topic = decoder.decode(buffer.slice(offset, offset + topicSize));\n offset = offset + topicSize;\n let event = decoder.decode(buffer.slice(offset, offset + eventSize));\n offset = offset + eventSize;\n let data = buffer.slice(offset, buffer.byteLength);\n let payload = { status: event, response: data };\n return { join_ref: joinRef, ref, topic, event: CHANNEL_EVENTS.reply, payload };\n },\n decodeBroadcast(buffer, view, decoder) {\n let topicSize = view.getUint8(1);\n let eventSize = view.getUint8(2);\n let offset = this.HEADER_LENGTH + 2;\n let topic = decoder.decode(buffer.slice(offset, offset + topicSize));\n offset = offset + topicSize;\n let event = decoder.decode(buffer.slice(offset, offset + eventSize));\n offset = offset + eventSize;\n let data = buffer.slice(offset, buffer.byteLength);\n return { join_ref: null, ref: null, topic, event, payload: data };\n }\n};\n\n// js/phoenix/socket.js\nvar Socket = class {\n constructor(endPoint, opts = {}) {\n this.stateChangeCallbacks = { open: [], close: [], error: [], message: [] };\n this.channels = [];\n this.sendBuffer = [];\n this.ref = 0;\n this.timeout = opts.timeout || DEFAULT_TIMEOUT;\n this.transport = opts.transport || global.WebSocket || LongPoll;\n this.longPollFallbackMs = opts.longPollFallbackMs;\n this.fallbackTimer = null;\n this.sessionStore = opts.sessionStorage || global.sessionStorage;\n this.establishedConnections = 0;\n this.defaultEncoder = serializer_default.encode.bind(serializer_default);\n this.defaultDecoder = serializer_default.decode.bind(serializer_default);\n this.closeWasClean = false;\n this.binaryType = opts.binaryType || \"arraybuffer\";\n this.connectClock = 1;\n if (this.transport !== LongPoll) {\n this.encode = opts.encode || this.defaultEncoder;\n this.decode = opts.decode || this.defaultDecoder;\n } else {\n this.encode = this.defaultEncoder;\n this.decode = this.defaultDecoder;\n }\n let awaitingConnectionOnPageShow = null;\n if (phxWindow && phxWindow.addEventListener) {\n phxWindow.addEventListener(\"pagehide\", (_e) => {\n if (this.conn) {\n this.disconnect();\n awaitingConnectionOnPageShow = this.connectClock;\n }\n });\n phxWindow.addEventListener(\"pageshow\", (_e) => {\n if (awaitingConnectionOnPageShow === this.connectClock) {\n awaitingConnectionOnPageShow = null;\n this.connect();\n }\n });\n }\n this.heartbeatIntervalMs = opts.heartbeatIntervalMs || 3e4;\n this.rejoinAfterMs = (tries) => {\n if (opts.rejoinAfterMs) {\n return opts.rejoinAfterMs(tries);\n } else {\n return [1e3, 2e3, 5e3][tries - 1] || 1e4;\n }\n };\n this.reconnectAfterMs = (tries) => {\n if (opts.reconnectAfterMs) {\n return opts.reconnectAfterMs(tries);\n } else {\n return [10, 50, 100, 150, 200, 250, 500, 1e3, 2e3][tries - 1] || 5e3;\n }\n };\n this.logger = opts.logger || null;\n if (!this.logger && opts.debug) {\n this.logger = (kind, msg, data) => {\n console.log(`${kind}: ${msg}`, data);\n };\n }\n this.longpollerTimeout = opts.longpollerTimeout || 2e4;\n this.params = closure(opts.params || {});\n this.endPoint = `${endPoint}/${TRANSPORTS.websocket}`;\n this.vsn = opts.vsn || DEFAULT_VSN;\n this.heartbeatTimeoutTimer = null;\n this.heartbeatTimer = null;\n this.pendingHeartbeatRef = null;\n this.reconnectTimer = new Timer(() => {\n this.teardown(() => this.connect());\n }, this.reconnectAfterMs);\n }\n /**\n * Returns the LongPoll transport reference\n */\n getLongPollTransport() {\n return LongPoll;\n }\n /**\n * Disconnects and replaces the active transport\n *\n * @param {Function} newTransport - The new transport class to instantiate\n *\n */\n replaceTransport(newTransport) {\n this.connectClock++;\n this.closeWasClean = true;\n clearTimeout(this.fallbackTimer);\n this.reconnectTimer.reset();\n if (this.conn) {\n this.conn.close();\n this.conn = null;\n }\n this.transport = newTransport;\n }\n /**\n * Returns the socket protocol\n *\n * @returns {string}\n */\n protocol() {\n return location.protocol.match(/^https/) ? \"wss\" : \"ws\";\n }\n /**\n * The fully qualified socket url\n *\n * @returns {string}\n */\n endPointURL() {\n let uri = Ajax.appendParams(\n Ajax.appendParams(this.endPoint, this.params()),\n { vsn: this.vsn }\n );\n if (uri.charAt(0) !== \"/\") {\n return uri;\n }\n if (uri.charAt(1) === \"/\") {\n return `${this.protocol()}:${uri}`;\n }\n return `${this.protocol()}://${location.host}${uri}`;\n }\n /**\n * Disconnects the socket\n *\n * See https://developer.mozilla.org/en-US/docs/Web/API/CloseEvent#Status_codes for valid status codes.\n *\n * @param {Function} callback - Optional callback which is called after socket is disconnected.\n * @param {integer} code - A status code for disconnection (Optional).\n * @param {string} reason - A textual description of the reason to disconnect. (Optional)\n */\n disconnect(callback, code, reason) {\n this.connectClock++;\n this.closeWasClean = true;\n clearTimeout(this.fallbackTimer);\n this.reconnectTimer.reset();\n this.teardown(callback, code, reason);\n }\n /**\n *\n * @param {Object} params - The params to send when connecting, for example `{user_id: userToken}`\n *\n * Passing params to connect is deprecated; pass them in the Socket constructor instead:\n * `new Socket(\"/socket\", {params: {user_id: userToken}})`.\n */\n connect(params) {\n if (params) {\n console && console.log(\"passing params to connect is deprecated. Instead pass :params to the Socket constructor\");\n this.params = closure(params);\n }\n if (this.conn) {\n return;\n }\n if (this.longPollFallbackMs && this.transport !== LongPoll) {\n this.connectWithFallback(LongPoll, this.longPollFallbackMs);\n } else {\n this.transportConnect();\n }\n }\n /**\n * Logs the message. Override `this.logger` for specialized logging. noops by default\n * @param {string} kind\n * @param {string} msg\n * @param {Object} data\n */\n log(kind, msg, data) {\n this.logger && this.logger(kind, msg, data);\n }\n /**\n * Returns true if a logger has been set on this socket.\n */\n hasLogger() {\n return this.logger !== null;\n }\n /**\n * Registers callbacks for connection open events\n *\n * @example socket.onOpen(function(){ console.info(\"the socket was opened\") })\n *\n * @param {Function} callback\n */\n onOpen(callback) {\n let ref = this.makeRef();\n this.stateChangeCallbacks.open.push([ref, callback]);\n return ref;\n }\n /**\n * Registers callbacks for connection close events\n * @param {Function} callback\n */\n onClose(callback) {\n let ref = this.makeRef();\n this.stateChangeCallbacks.close.push([ref, callback]);\n return ref;\n }\n /**\n * Registers callbacks for connection error events\n *\n * @example socket.onError(function(error){ alert(\"An error occurred\") })\n *\n * @param {Function} callback\n */\n onError(callback) {\n let ref = this.makeRef();\n this.stateChangeCallbacks.error.push([ref, callback]);\n return ref;\n }\n /**\n * Registers callbacks for connection message events\n * @param {Function} callback\n */\n onMessage(callback) {\n let ref = this.makeRef();\n this.stateChangeCallbacks.message.push([ref, callback]);\n return ref;\n }\n /**\n * Pings the server and invokes the callback with the RTT in milliseconds\n * @param {Function} callback\n *\n * Returns true if the ping was pushed or false if unable to be pushed.\n */\n ping(callback) {\n if (!this.isConnected()) {\n return false;\n }\n let ref = this.makeRef();\n let startTime = Date.now();\n this.push({ topic: \"phoenix\", event: \"heartbeat\", payload: {}, ref });\n let onMsgRef = this.onMessage((msg) => {\n if (msg.ref === ref) {\n this.off([onMsgRef]);\n callback(Date.now() - startTime);\n }\n });\n return true;\n }\n /**\n * @private\n */\n transportConnect() {\n this.connectClock++;\n this.closeWasClean = false;\n this.conn = new this.transport(this.endPointURL());\n this.conn.binaryType = this.binaryType;\n this.conn.timeout = this.longpollerTimeout;\n this.conn.onopen = () => this.onConnOpen();\n this.conn.onerror = (error) => this.onConnError(error);\n this.conn.onmessage = (event) => this.onConnMessage(event);\n this.conn.onclose = (event) => this.onConnClose(event);\n }\n getSession(key) {\n return this.sessionStore && this.sessionStore.getItem(key);\n }\n storeSession(key, val) {\n this.sessionStore && this.sessionStore.setItem(key, val);\n }\n connectWithFallback(fallbackTransport, fallbackThreshold = 2500) {\n clearTimeout(this.fallbackTimer);\n let established = false;\n let primaryTransport = true;\n let openRef, errorRef;\n let fallback = (reason) => {\n this.log(\"transport\", `falling back to ${fallbackTransport.name}...`, reason);\n this.off([openRef, errorRef]);\n primaryTransport = false;\n this.storeSession(\"phx:longpoll\", \"true\");\n this.replaceTransport(fallbackTransport);\n this.transportConnect();\n };\n if (this.getSession(\"phx:longpoll\")) {\n return fallback(\"memorized\");\n }\n this.fallbackTimer = setTimeout(fallback, fallbackThreshold);\n errorRef = this.onError((reason) => {\n this.log(\"transport\", \"error\", reason);\n if (primaryTransport && !established) {\n clearTimeout(this.fallbackTimer);\n fallback(reason);\n }\n });\n this.onOpen(() => {\n established = true;\n if (!primaryTransport) {\n return console.log(\"transport\", `established ${fallbackTransport.name} fallback`);\n }\n clearTimeout(this.fallbackTimer);\n this.fallbackTimer = setTimeout(fallback, fallbackThreshold);\n this.ping((rtt) => {\n this.log(\"transport\", \"connected to primary after\", rtt);\n clearTimeout(this.fallbackTimer);\n });\n });\n this.transportConnect();\n }\n clearHeartbeats() {\n clearTimeout(this.heartbeatTimer);\n clearTimeout(this.heartbeatTimeoutTimer);\n }\n onConnOpen() {\n if (this.hasLogger())\n this.log(\"transport\", `${this.transport.name} connected to ${this.endPointURL()}`);\n this.closeWasClean = false;\n this.establishedConnections++;\n this.flushSendBuffer();\n this.reconnectTimer.reset();\n this.resetHeartbeat();\n this.stateChangeCallbacks.open.forEach(([, callback]) => callback());\n }\n /**\n * @private\n */\n heartbeatTimeout() {\n if (this.pendingHeartbeatRef) {\n this.pendingHeartbeatRef = null;\n if (this.hasLogger()) {\n this.log(\"transport\", \"heartbeat timeout. Attempting to re-establish connection\");\n }\n this.triggerChanError();\n this.closeWasClean = false;\n this.teardown(() => this.reconnectTimer.scheduleTimeout(), WS_CLOSE_NORMAL, \"heartbeat timeout\");\n }\n }\n resetHeartbeat() {\n if (this.conn && this.conn.skipHeartbeat) {\n return;\n }\n this.pendingHeartbeatRef = null;\n this.clearHeartbeats();\n this.heartbeatTimer = setTimeout(() => this.sendHeartbeat(), this.heartbeatIntervalMs);\n }\n teardown(callback, code, reason) {\n if (!this.conn) {\n return callback && callback();\n }\n this.waitForBufferDone(() => {\n if (this.conn) {\n if (code) {\n this.conn.close(code, reason || \"\");\n } else {\n this.conn.close();\n }\n }\n this.waitForSocketClosed(() => {\n if (this.conn) {\n this.conn.onopen = function() {\n };\n this.conn.onerror = function() {\n };\n this.conn.onmessage = function() {\n };\n this.conn.onclose = function() {\n };\n this.conn = null;\n }\n callback && callback();\n });\n });\n }\n waitForBufferDone(callback, tries = 1) {\n if (tries === 5 || !this.conn || !this.conn.bufferedAmount) {\n callback();\n return;\n }\n setTimeout(() => {\n this.waitForBufferDone(callback, tries + 1);\n }, 150 * tries);\n }\n waitForSocketClosed(callback, tries = 1) {\n if (tries === 5 || !this.conn || this.conn.readyState === SOCKET_STATES.closed) {\n callback();\n return;\n }\n setTimeout(() => {\n this.waitForSocketClosed(callback, tries + 1);\n }, 150 * tries);\n }\n onConnClose(event) {\n let closeCode = event && event.code;\n if (this.hasLogger())\n this.log(\"transport\", \"close\", event);\n this.triggerChanError();\n this.clearHeartbeats();\n if (!this.closeWasClean && closeCode !== 1e3) {\n this.reconnectTimer.scheduleTimeout();\n }\n this.stateChangeCallbacks.close.forEach(([, callback]) => callback(event));\n }\n /**\n * @private\n */\n onConnError(error) {\n if (this.hasLogger())\n this.log(\"transport\", error);\n let transportBefore = this.transport;\n let establishedBefore = this.establishedConnections;\n this.stateChangeCallbacks.error.forEach(([, callback]) => {\n callback(error, transportBefore, establishedBefore);\n });\n if (transportBefore === this.transport || establishedBefore > 0) {\n this.triggerChanError();\n }\n }\n /**\n * @private\n */\n triggerChanError() {\n this.channels.forEach((channel) => {\n if (!(channel.isErrored() || channel.isLeaving() || channel.isClosed())) {\n channel.trigger(CHANNEL_EVENTS.error);\n }\n });\n }\n /**\n * @returns {string}\n */\n connectionState() {\n switch (this.conn && this.conn.readyState) {\n case SOCKET_STATES.connecting:\n return \"connecting\";\n case SOCKET_STATES.open:\n return \"open\";\n case SOCKET_STATES.closing:\n return \"closing\";\n default:\n return \"closed\";\n }\n }\n /**\n * @returns {boolean}\n */\n isConnected() {\n return this.connectionState() === \"open\";\n }\n /**\n * @private\n *\n * @param {Channel}\n */\n remove(channel) {\n this.off(channel.stateChangeRefs);\n this.channels = this.channels.filter((c) => c.joinRef() !== channel.joinRef());\n }\n /**\n * Removes `onOpen`, `onClose`, `onError,` and `onMessage` registrations.\n *\n * @param {refs} - list of refs returned by calls to\n * `onOpen`, `onClose`, `onError,` and `onMessage`\n */\n off(refs) {\n for (let key in this.stateChangeCallbacks) {\n this.stateChangeCallbacks[key] = this.stateChangeCallbacks[key].filter(([ref]) => {\n return refs.indexOf(ref) === -1;\n });\n }\n }\n /**\n * Initiates a new channel for the given topic\n *\n * @param {string} topic\n * @param {Object} chanParams - Parameters for the channel\n * @returns {Channel}\n */\n channel(topic, chanParams = {}) {\n let chan = new Channel(topic, chanParams, this);\n this.channels.push(chan);\n return chan;\n }\n /**\n * @param {Object} data\n */\n push(data) {\n if (this.hasLogger()) {\n let { topic, event, payload, ref, join_ref } = data;\n this.log(\"push\", `${topic} ${event} (${join_ref}, ${ref})`, payload);\n }\n if (this.isConnected()) {\n this.encode(data, (result) => this.conn.send(result));\n } else {\n this.sendBuffer.push(() => this.encode(data, (result) => this.conn.send(result)));\n }\n }\n /**\n * Return the next message ref, accounting for overflows\n * @returns {string}\n */\n makeRef() {\n let newRef = this.ref + 1;\n if (newRef === this.ref) {\n this.ref = 0;\n } else {\n this.ref = newRef;\n }\n return this.ref.toString();\n }\n sendHeartbeat() {\n if (this.pendingHeartbeatRef && !this.isConnected()) {\n return;\n }\n this.pendingHeartbeatRef = this.makeRef();\n this.push({ topic: \"phoenix\", event: \"heartbeat\", payload: {}, ref: this.pendingHeartbeatRef });\n this.heartbeatTimeoutTimer = setTimeout(() => this.heartbeatTimeout(), this.heartbeatIntervalMs);\n }\n flushSendBuffer() {\n if (this.isConnected() && this.sendBuffer.length > 0) {\n this.sendBuffer.forEach((callback) => callback());\n this.sendBuffer = [];\n }\n }\n onConnMessage(rawMessage) {\n this.decode(rawMessage.data, (msg) => {\n let { topic, event, payload, ref, join_ref } = msg;\n if (ref && ref === this.pendingHeartbeatRef) {\n this.clearHeartbeats();\n this.pendingHeartbeatRef = null;\n this.heartbeatTimer = setTimeout(() => this.sendHeartbeat(), this.heartbeatIntervalMs);\n }\n if (this.hasLogger())\n this.log(\"receive\", `${payload.status || \"\"} ${topic} ${event} ${ref && \"(\" + ref + \")\" || \"\"}`, payload);\n for (let i = 0; i < this.channels.length; i++) {\n const channel = this.channels[i];\n if (!channel.isMember(topic, event, payload, join_ref)) {\n continue;\n }\n channel.trigger(event, payload, ref, join_ref);\n }\n for (let i = 0; i < this.stateChangeCallbacks.message.length; i++) {\n let [, callback] = this.stateChangeCallbacks.message[i];\n callback(msg);\n }\n });\n }\n leaveOpenTopic(topic) {\n let dupChannel = this.channels.find((c) => c.topic === topic && (c.isJoined() || c.isJoining()));\n if (dupChannel) {\n if (this.hasLogger())\n this.log(\"transport\", `leaving duplicate topic \"${topic}\"`);\n dupChannel.leave();\n }\n }\n};\nexport {\n Channel,\n LongPoll,\n Presence,\n serializer_default as Serializer,\n Socket\n};\n//# sourceMappingURL=phoenix.mjs.map\n","import { Channel, Socket } from 'phoenix'\nimport { apiVersion } from 'config'\nimport debug from 'lib/debug'\nimport splitUrlParams from 'lib/split-url-params'\n\nconst log = debug('seamly')\ntype CurrentConnectionState =\n | 'socket_closed' // Socket is closed.\n | 'channel_closed' // Channel is closed.\n | 'channel_erred' // Errors received from joined channel.\n | 'join_channel_succeeded' // Joined channel succesfully.\n | 'join_channel_erred' // Error on joining channel. This is usefull when you want to restart a chat sessions.\n | 'attach_channel_succeeded' // Attached channel to system.\n | 'attach_channel_erred' // Error attaching channel.\n\ntype ConnectionState = {\n connected: boolean\n ready: boolean\n currentState: CurrentConnectionState\n}\n\n// Subscribers set which are used to subscribe to changes in the conversation.\n// Needs to be outside of the ConversationConnector class so its not recreated for each instance.\nconst subscribers = new Set<Function>()\n\n// Syncs the lifecycle of the conversation with Preact. Each subscriber will fetch the latest value from the conversation if needed.\nconst emitChange = () => {\n // Call the callback function for each subscriber\n subscribers.forEach((callback) => callback())\n}\n\nexport default class ConversationConnector {\n #connectionListeners: ((_payload: ConnectionState) => boolean | void)[] = []\n\n accessToken: string\n\n channelName: string\n\n channelTopic: string\n\n url: string\n\n socket?: Socket\n\n channel: Channel\n\n async connect(\n url: string,\n channelName: string,\n channelTopic: string,\n accessToken: string,\n ) {\n this.url = url\n\n this.accessToken = accessToken\n this.channelName = channelName\n this.channelTopic = channelTopic\n const { url: splittedUrl, params } = splitUrlParams(this.url)\n\n this.socket = new Socket(splittedUrl, {\n params: { ...params, v: apiVersion },\n reconnectAfterMs: (tries) => {\n // Calculate the backoff time based on the number of tries.\n const backoff = 2 ** tries * 250\n\n // Limit the backoff time to 10 seconds.\n return Math.min(backoff, 10000)\n },\n })\n\n this.socket.onError((err) => {\n log('[SOCKET][ERROR]', err)\n })\n\n this.socket.onOpen(() => {\n log('[SOCKET]OPEN')\n })\n\n this.socket.onClose(() => {\n log('[SOCKET]CLOSE')\n this.#emitConnectionState({\n connected: false,\n ready: false,\n currentState: 'socket_closed',\n })\n })\n\n this.socket.connect()\n\n this.channel = this.socket.channel(this.channelTopic, {\n authorization: `Bearer ${this.accessToken}`,\n channelName: this.channelName,\n })\n\n this.start()\n\n this.channel.on('system', (msg) => {\n switch (msg.type) {\n case 'attach_channel_succeeded':\n this.#emitConnectionState({\n connected: true,\n ready: true,\n currentState: 'attach_channel_succeeded',\n })\n break\n }\n })\n\n this.channel.onClose(() => {\n log('[CHANNEL]CLOSE')\n this.#emitConnectionState({\n connected: false,\n ready: false,\n currentState: 'channel_closed',\n })\n })\n\n this.channel.onError((msg) => {\n log('[CHANNEL][ERROR]', msg)\n\n this.#emitConnectionState({\n connected: false,\n ready: false,\n currentState: 'channel_erred',\n })\n })\n\n this.#listenTo(\n 'ack',\n 'ui',\n 'error',\n 'participant',\n 'message',\n 'service_data',\n 'system',\n 'info',\n 'sync',\n )\n }\n\n start() {\n this.channel\n .join()\n .receive('ok', () => {\n log('[CHANNEL][JOIN] OK')\n this.#emitConnectionState({\n connected: true,\n ready: false,\n currentState: 'join_channel_succeeded',\n })\n })\n .receive('error', (err) => {\n log('[CHANNEL][JOIN] ERROR', err)\n this.#emitConnectionState({\n connected: false,\n ready: false,\n currentState: 'join_channel_erred',\n })\n })\n .receive('timeout', () => {\n log('[CHANEL][JOIN] Networking issue. Still waiting...')\n })\n }\n\n disconnect() {\n this.channel?.leave().receive('ok', () => {\n this.socket?.disconnect()\n log('[CHANNEL][LEAVE] OK')\n this.#connectionListeners = []\n })\n }\n\n #listenTo(...types: string[]) {\n types.forEach((type) => {\n this.channel.on(type, (msg) => {\n log('[RECEIVE]', type, msg)\n })\n })\n }\n\n onConnection(cb: (_payload: ConnectionState) => boolean | void) {\n this.#connectionListeners.push(cb)\n }\n\n #emitConnectionState(payload: ConnectionState) {\n this.#connectionListeners = this.#connectionListeners.filter((item) => {\n const complete = item(payload)\n\n // If we only want to execute the callback once, remove it from the listener\n return !complete\n })\n\n emitChange()\n }\n\n pushToChannel(\n command: string,\n payload: { type: string; error: unknown },\n timeout = 10000,\n ) {\n this.channel.push(command, payload, timeout)\n }\n\n // Adds a callback function to the subscribers set and returns a method to unsubscribe from the store.\n // This method is used to sync the state with the lifecycle of Preact.\n static subscribe(callback: Function) {\n subscribers.add(callback)\n\n // Returns a function that removes the callback from the subscribers set.\n return () => subscribers.delete(callback)\n }\n}\n","import type { Config } from 'config.types'\n\nexport const CSS_NAME = 'cvco'\n\nexport const apiVersion = '3'\n\nexport const userParticipantId = 'seamly-client-participant'\n\n// How long to debounce distinct changes in unread messages for before\n// broadcasting to the screen reader. This is done to avoid verbosity.\nexport const unreadScreenReaderWait = 2000\n\nexport const newMessageScreenReaderWait = 1000\n\nexport const screenReaderDebounceDelaySeconds = 10\n\nexport const activitySendDelay = 15000\n\nexport const maxCharacterWarningLimit = 50\n\nexport const maxCharacterSrDebounceDelay = 300\n\nexport const defaultTransitionTimeMs = 300\n\n// How long to wait before we decide the user isn't typing\nexport const typingTimeout = 2000\n\nexport const defaultConfig: Partial<Config> = {\n namespace: 'default',\n layoutMode: 'window', // \"window\", \"inline\" (\"sidebar\")\n messages: {\n agent: {\n showAvatar: false, // true, \"inline\"\n showName: false,\n },\n user: {\n showAvatar: false, // true, \"inline\"\n showName: false,\n },\n timeIndicator: {\n enabled: false,\n threshold: 3600000, // Default threshold is an hour in milliseconds\n },\n },\n}\n","import { createAsyncThunk } from '@reduxjs/toolkit'\nimport SeamlySessionExpiredError from 'api/errors/seamly-session-expired-error'\nimport SeamlyUnavailableError from 'api/errors/seamly-unavailable-error'\nimport { initializeConfig, resetConfig } from 'domains/config/actions'\nimport createDebouncedAsyncThunk from 'domains/redux/create-debounced-async-thunk'\nimport { ThunkAPI } from 'domains/redux/redux.types'\nimport { initializeVisibility } from 'domains/visibility/actions'\nimport { actionTypes } from 'ui/utils/seamly-utils'\nimport type { Config } from 'config.types'\nimport type { RootState } from 'domains/store'\n\nexport const initializeApp = createAsyncThunk<\n {\n initialState: RootState['state']['initialState']\n contentLocale: string\n userLocale: string\n config: Config\n },\n void,\n ThunkAPI\n>('initializeApp', async (_, { extra: { api, config }, rejectWithValue }) => {\n let contentLocale = config?.context?.contentLocale\n let userLocale = config?.context?.userLocale\n\n const environment =\n config.api.sendEnvironment !== false\n ? api.getEnvironment()\n : config.api.sendEnvironment\n\n try {\n if (api.hasConversation()) {\n const initialState = await api.getConversationIntitialState()\n\n contentLocale = initialState.context.contentLocale || contentLocale\n userLocale = initialState.context.userLocale || userLocale\n\n api.sendContext({ ...initialState.context, environment })\n return { initialState, contentLocale, userLocale, config }\n } else {\n if (config?.context?.topic) {\n api.send('action', {\n type: actionTypes.setTopic,\n body: {\n name: config.context.topic,\n // Separate fallback message is not needed here. Only an attached service will use this, but none will\n // be attached before the conversation has started (meaning the fallback message will never be shown).\n fallbackMessage: config.context.topic,\n },\n })\n }\n\n // Send context\n api.sendContext({\n ...config.context,\n environment,\n })\n return { initialState: undefined, contentLocale, userLocale, config }\n }\n } catch (e) {\n if (e instanceof SeamlySessionExpiredError) {\n const err = new SeamlySessionExpiredError()\n\n return rejectWithValue({\n name: err.name,\n message: err.message,\n originalEvent: err.originalEvent,\n originalError: err.originalError,\n action: err.action,\n })\n }\n\n const err = new SeamlyUnavailableError()\n return rejectWithValue({\n name: err.name,\n message: err.message,\n langKey: err.langKey,\n })\n }\n})\n\nexport const resetApp = createDebouncedAsyncThunk<unknown, void, ThunkAPI>(\n 'resetApp',\n async (_, { dispatch, extra: { api } }) => {\n await api.disconnect()\n api.clearStore()\n\n dispatch(resetConfig())\n await dispatch(initializeConfig())\n await dispatch(initializeApp())\n\n dispatch(initializeVisibility())\n },\n {\n wait: 2000,\n leading: true,\n },\n)\n","import {\n AsyncThunkPayloadCreator,\n Dispatch,\n createAsyncThunk,\n} from '@reduxjs/toolkit'\nimport { ThunkAPI } from './redux.types'\n\ntype DebounceOptionsType = {\n /**\n * The number of milliseconds to delay\n * @defaultValue `300`\n */\n wait: number\n\n /**\n * The maximum time `payloadCreator` is allowed to be delayed before\n * it's invoked.\n * @defaultValue `0`\n */\n maxWait?: number\n\n /**\n * Specify invoking on the leading edge of the timeout.\n * @defaultValue `false`\n */\n leading?: boolean\n}\n\ntype AsyncThunkConfig = ThunkAPI & {\n dispatch?: Dispatch\n rejectValue?: unknown\n serializedErrorType?: unknown\n pendingMeta?: unknown\n fulfilledMeta?: unknown\n rejectedMeta?: unknown\n}\n\n/**\n * A debounced analogue of the `createAsyncThunk` from `@reduxjs/toolkit`\n * @param typePrefix - a string action type value\n * @param payloadCreator - a callback function that should return a promise containing the result of some asynchronous logic\n * @param debounceOptions - the debounce options object\n */\nconst createDebouncedAsyncThunk = <\n Returned,\n ThunkArg,\n ThunkApiConfig extends AsyncThunkConfig,\n>(\n typePrefix: string,\n payloadCreator: AsyncThunkPayloadCreator<Returned, ThunkArg, ThunkApiConfig>,\n debounceOptions?: DebounceOptionsType,\n) => {\n const { wait = 300, maxWait = 0, leading = false } = debounceOptions ?? {}\n\n let debounceTimer: ReturnType<typeof setTimeout> = null\n let maxWaitTimer: ReturnType<typeof setTimeout> = null\n let resolve: ((_value: boolean) => void) | undefined\n\n const cancel = (): void => {\n if (resolve) {\n resolve(false)\n resolve = undefined\n }\n }\n\n const invoke = (): void => {\n clearTimeout(maxWaitTimer)\n maxWaitTimer = undefined\n\n if (resolve) {\n resolve(true)\n resolve = undefined\n }\n }\n\n const debounceExecutionCondition = (): Promise<boolean> | boolean => {\n const immediate = leading && !debounceTimer\n\n // Start debounced condition resolution\n clearTimeout(debounceTimer)\n debounceTimer = setTimeout(() => {\n invoke()\n debounceTimer = null\n }, wait)\n\n if (immediate) {\n return true\n }\n\n cancel()\n\n // Start max wait condition resolution\n if (maxWait && !maxWaitTimer) {\n maxWaitTimer = setTimeout(invoke, maxWait)\n }\n\n return new Promise((res) => {\n resolve = res\n })\n }\n\n return createAsyncThunk(typePrefix, payloadCreator, {\n condition: debounceExecutionCondition,\n })\n}\n\nexport default createDebouncedAsyncThunk\n","import { createSelector } from '@reduxjs/toolkit'\n\nexport const selectUserHasResponded = createSelector(\n ({ app }) => app,\n ({ userHasResponded }) => userHasResponded,\n)\n","import { createSlice } from '@reduxjs/toolkit'\nimport { initializeApp, resetApp } from 'domains/app/actions'\nimport { AppState } from 'domains/app/app.types'\n\nconst initialState: AppState = {\n userHasResponded: false,\n}\n\nexport const appSlice = createSlice({\n name: 'app',\n initialState,\n reducers: {\n setHasResponded: (state, { payload }) => {\n state.userHasResponded = payload\n },\n },\n extraReducers: (builder) => {\n builder\n .addCase(resetApp.pending, () => initialState)\n .addCase(initializeApp.fulfilled, (state, { payload }) => {\n if (payload.initialState && 'userResponded' in payload.initialState) {\n state.userHasResponded = payload.initialState?.userResponded\n }\n })\n },\n})\n\nexport const { setHasResponded } = appSlice.actions\n\nexport default appSlice.reducer\n","import { createAsyncThunk } from '@reduxjs/toolkit'\nimport { Config, ConfigResponse } from 'config.types'\nimport { ThunkAPI } from 'domains/redux/redux.types'\n\ntype InitializeConfigReturn = ConfigResponse & {\n defaultUserLocale: ConfigResponse['defaultLocale']\n defaultContentLocale: ConfigResponse['defaultLocale']\n connectWhenInView: Config['connectWhenInView']\n}\n\nexport const initializeConfig = createAsyncThunk<\n InitializeConfigReturn,\n void,\n ThunkAPI\n>(\n 'initializeConfig',\n async (_, { extra: { api, config }, rejectWithValue }) => {\n try {\n const {\n features,\n defaultLocale,\n preChat,\n agentParticipant,\n userParticipant,\n startChatIcon,\n } = await api.getConfig()\n\n const defaultUserLocale = config?.context?.userLocale || defaultLocale\n const defaultContentLocale =\n config?.context?.contentLocale || defaultLocale\n const { connectWhenInView } = config\n\n return {\n features,\n defaultLocale,\n preChat,\n agentParticipant,\n userParticipant,\n startChatIcon,\n defaultUserLocale,\n defaultContentLocale,\n connectWhenInView,\n }\n } catch (error) {\n return rejectWithValue(error)\n }\n },\n)\n\nexport const resetConfig = createAsyncThunk<unknown, void, ThunkAPI>(\n 'resetConfig',\n async (_, { extra: { config } }) => {\n return config\n },\n)\n","import { useSelector } from 'react-redux'\nimport { selectConfig } from 'domains/config/selectors'\n\nexport const useConfig = () => useSelector(selectConfig)\n\nexport function useParticipants() {\n const { agentParticipant, userParticipant } = useConfig()\n\n return {\n agent: agentParticipant,\n user: userParticipant,\n }\n}\n\nexport function useStartChatIcon() {\n const { startChatIcon } = useConfig()\n\n return startChatIcon\n}\n","import { createSelector } from '@reduxjs/toolkit'\nimport { visibilityStates } from 'domains/visibility/constants'\nimport type { VisibilityOptions } from 'config.types'\nimport type { RootState } from 'domains/store'\n\nexport const selectConfig = createSelector(\n ({ config }: RootState) => config,\n (config) => {\n let newConfig = {\n visible: (config?.layoutMode === 'inline'\n ? visibilityStates.open\n : visibilityStates.minimized) as VisibilityOptions,\n appContainerClassNames: config?.appContainerClassNames || [],\n ...config,\n }\n if (typeof newConfig.appContainerClassNames === 'function') {\n newConfig = {\n ...newConfig,\n appContainerClassNames: newConfig.appContainerClassNames(newConfig),\n }\n }\n return newConfig\n },\n)\n","import { PayloadAction, createSlice } from '@reduxjs/toolkit'\nimport { defaultConfig } from 'config'\nimport { Config } from 'config.types'\nimport { initializeConfig, resetConfig } from 'domains/config/actions'\nimport { pick } from 'ui/utils/general-utils'\nimport type { ChannelEvent } from 'domains/store/store.types'\n\nexport const initialConfigState: Config = {\n ...defaultConfig,\n api: {\n domain: '',\n key: '',\n secure: true,\n sendEnvironment: true,\n },\n notificationAudioURL: undefined,\n hideOnNoUserResponse: false,\n connectWhenInView: true,\n showDisclaimer: false,\n showSuggestions: true,\n preChat: {\n enterDelay: 1000,\n exitAfter: 4000,\n },\n continueChat: {\n enterDelay: 0,\n exitAfter: 2000,\n },\n customComponents: {},\n defaults: {\n visible: null,\n },\n preChatEvents: [],\n}\n\nconst configKeys: (keyof Config)[] = [\n 'hideOnNoUserResponse',\n 'connectWhenInView',\n 'showDisclaimer',\n 'showSuggestions',\n 'continueChat',\n 'preChat',\n 'namespace',\n 'customComponents',\n 'defaults',\n 'layoutMode',\n 'api',\n 'zIndex',\n 'context',\n 'appContainerClassNames',\n 'messages',\n 'visible',\n 'visibilityCallback',\n 'errorCallback',\n 'agentParticipant',\n 'userParticipant',\n 'startChatIcon',\n 'notificationAudioURL',\n]\n\nconst updateState = (state, config: Config): Config => {\n const { messages, ...partialConfig } = pick(config, configKeys)\n let newState = state\n if (Object.keys(partialConfig).length > 0) {\n newState = {\n ...newState,\n ...partialConfig,\n }\n }\n if (messages) {\n newState = {\n ...newState,\n messages: {\n ...newState.messages,\n ...messages,\n },\n }\n }\n return newState\n}\n\nexport const configSlice = createSlice({\n name: 'config',\n initialState: initialConfigState,\n reducers: {\n setConfig: (state, { payload }: PayloadAction<Config>) =>\n updateState(state, payload),\n updateConfig: (state, { payload }: PayloadAction<Config>) =>\n updateState(state, payload),\n setPreChatEvents: (state, { payload }: PayloadAction<ChannelEvent[]>) => {\n state.preChatEvents = payload\n },\n },\n extraReducers: (builder) => {\n builder\n .addCase(resetConfig.fulfilled, (config) => config)\n .addCase(\n initializeConfig.fulfilled,\n (\n state,\n {\n payload: {\n preChat,\n agentParticipant,\n userParticipant,\n startChatIcon,\n defaultUserLocale,\n defaultContentLocale,\n },\n },\n ) => {\n // @ts-ignore\n state.preChatEvents = preChat.map((payload) => ({\n type: 'message',\n payload,\n }))\n\n state.context.userLocale = defaultUserLocale\n state.context.contentLocale = defaultContentLocale\n\n state.agentParticipant = agentParticipant\n state.userParticipant = userParticipant\n state.startChatIcon = startChatIcon\n },\n )\n },\n})\n\nexport const { setConfig, updateConfig, setPreChatEvents } = configSlice.actions\n\nexport default configSlice.reducer\n","import { createAction } from '@reduxjs/toolkit'\nimport SeamlyBaseError from 'api/errors/seamly-base-error'\nimport SeamlyConfigurationError from 'api/errors/seamly-configuration-error'\nimport SeamlyGeneralError from 'api/errors/seamly-general-error'\nimport SeamlyOfflineError from 'api/errors/seamly-offline-error'\nimport SeamlySessionExpiredError from 'api/errors/seamly-session-expired-error'\nimport SeamlyUnauthorizedError from 'api/errors/seamly-unauthorized-error'\nimport SeamlyUnavailableError from 'api/errors/seamly-unavailable-error'\nimport { selectConfig } from 'domains/config/selectors'\n\nconst ErrorTypes = {\n SeamlyGeneralError,\n SeamlyConfigurationError,\n SeamlySessionExpiredError,\n SeamlyOfflineError,\n SeamlyUnauthorizedError,\n SeamlyUnavailableError,\n}\n\nexport const catchError = createAction('catch-error', (error) => ({\n payload: error,\n}))\n\nexport function createErrorsMiddleware({ api: seamlyApi }) {\n return ({ getState }) => {\n const handleError = (action) => {\n const { errorCallback, namespace, api, layoutMode } =\n selectConfig(getState())\n\n const { error, type } = action\n\n const errorType = ErrorTypes[error?.name]\n ? new ErrorTypes[error.name](error)\n : new SeamlyBaseError(error)\n\n errorCallback?.(errorType, {\n namespace,\n api,\n layoutMode,\n conversationUrl: seamlyApi.getConversationUrl(),\n action: type ? action : undefined,\n })\n }\n\n return (next) => (action) => {\n try {\n if (action.payload?.originalEvent?.payload) {\n handleError({\n error: action.payload,\n type: action.payload?.originalEvent?.payload?.type,\n })\n } else if (action.payload?.originalError) {\n handleError({\n error: action.payload,\n type: undefined,\n })\n }\n return next(action)\n } catch (error) {\n handleError({ error })\n throw error\n }\n }\n }\n}\n","import { createSlice } from '@reduxjs/toolkit'\nimport { resetApp } from 'domains/app/actions'\nimport { ControlState } from 'domains/forms/forms.types'\n\nconst initialFormState: Record<string, ControlState> = {\n controls: {},\n}\n\nconst initialControlState: ControlState = {\n value: '',\n touched: false,\n}\n\nconst initialState = {\n controls: initialControlState,\n}\n\nexport const formsSlice = createSlice({\n name: 'forms',\n initialState,\n reducers: {\n registerForm: (state, { payload: { persistData, formId } }) => {\n const formState = persistData\n ? state[formId] ?? { ...initialFormState, persistData }\n : { ...initialFormState, persistData }\n\n state[formId] = formState\n },\n deregisterForm: (state, { payload: { formId } }) => {\n if (!state[formId]?.persistData) {\n delete state[formId]\n }\n\n return state\n },\n // Form control handlers\n registerControl: (state, { payload: { name, formId } }) => {\n state[formId].controls = {\n [name]: initialControlState,\n }\n },\n deregisterControl: (state, { payload: { name, formId } }) => {\n const form = state[formId]\n if (!form) {\n return state\n }\n if (form.persistData) {\n return state\n }\n const controls = { ...form.controls }\n delete controls[name]\n return {\n ...state,\n [formId]: {\n ...form,\n controls,\n },\n }\n },\n updateControlValue: (state, { payload: { formId, name, value } }) => {\n // return updateFormControl(state, formId, name, { value })\n if (!state[formId]?.controls) return\n state[formId].controls[name].value = value\n },\n updateControlTouched: (state, { payload: { formId, name, touched } }) => {\n if (!state[formId]?.controls[name]) return\n state[formId].controls[name].touched = touched\n },\n },\n extraReducers: (builder) => {\n builder.addCase(resetApp.pending, () => initialState)\n },\n})\n\nexport const {\n registerForm,\n deregisterForm,\n registerControl,\n deregisterControl,\n updateControlValue,\n updateControlTouched,\n} = formsSlice.actions\n\nexport default formsSlice.reducer\n","import { createAsyncThunk } from '@reduxjs/toolkit'\nimport { ThunkAPI } from 'domains/redux/redux.types'\nimport type { I18nState } from 'domains/i18n/i18n.types'\n\nexport const setLocale = createAsyncThunk<\n {\n translations: I18nState['translations']\n userLocale: I18nState['userLocale']\n },\n string,\n ThunkAPI\n>(\n 'setLocale',\n async (userLocale, { extra: { api }, rejectWithValue }) => {\n try {\n const response = await api.getTranslations(userLocale)\n\n return {\n translations: response,\n userLocale,\n }\n } catch (error) {\n return rejectWithValue(error)\n }\n },\n {\n condition: (locale, { getState }) => {\n const {\n i18n: { isLoading, userLocale },\n } = getState()\n\n if (locale === userLocale || isLoading) {\n // Already fetched or in progress, don't need to re-fetch\n return false\n }\n\n return true\n },\n },\n)\n","export default function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];\n return arr2;\n}","export default function _typeof(o) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n return typeof o;\n } : function (o) {\n return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n }, _typeof(o);\n}","import _typeof from \"./typeof.js\";\nimport toPrimitive from \"./toPrimitive.js\";\nexport default function toPropertyKey(t) {\n var i = toPrimitive(t, \"string\");\n return \"symbol\" == _typeof(i) ? i : String(i);\n}","import _typeof from \"./typeof.js\";\nexport default function toPrimitive(t, r) {\n if (\"object\" != _typeof(t) || !t) return t;\n var e = t[Symbol.toPrimitive];\n if (void 0 !== e) {\n var i = e.call(t, r || \"default\");\n if (\"object\" != _typeof(i)) return i;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (\"string\" === r ? String : Number)(t);\n}","import toPropertyKey from \"./toPropertyKey.js\";\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, toPropertyKey(descriptor.key), descriptor);\n }\n}\nexport default function _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}","import toPropertyKey from \"./toPropertyKey.js\";\nexport default function _defineProperty(obj, key, value) {\n key = toPropertyKey(key);\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}","/* \n * Copyright 2017, Emanuel Rabina (http://www.ultraq.net.nz/)\n * \n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * \n * http://www.apache.org/licenses/LICENSE-2.0\n * \n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * Flattens an array of arrays of infinite depth into a single-dimension array.\n * \n * > This is now natively in JavaScript as the `flat` method on an Array\n * > instance. [Check MDN for which browsers have access to this feature](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/flat).\n * > If you can't use `flat`, then this method will do the job 🙂\n * \n * @param {Array} array\n * @return {Array} Flattened array.\n */\nexport function flatten(array) {\n return array.reduce(function (accumulator, value) {\n return accumulator.concat(Array.isArray(value) ? flatten(value) : value);\n }, []);\n}\n/**\n * Creates an array of numbers from the starting value (inclusive) to the end\n * (exclusive), with an optional step (the gap between values).\n * \n * @param {Number} start\n * The value to start at, the first item in the returned array.\n * @param {Number} end\n * The value to end with, the last item in the returned array.\n * @param {Number} [step=1]\n * The increment/gap between values, defaults to 1.\n * @return {Array} An array encompassing the given range.\n */\n\nexport function range(start, end) {\n var step = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1;\n return Array.apply(0, Array(Math.ceil((end - start) / step))).map(function (empty, index) {\n return index * step + start;\n });\n}\n/**\n * Remove and return the first item from `array` that matches the predicate\n * function.\n * \n * @param {Array} array\n * @param {Function} predicate\n * Invoked with the array item.\n * @return {Object} The matching item, or `null` if no match was found.\n */\n\nexport function remove(array, predicate) {\n return array.find(function (item, index) {\n if (predicate(item)) {\n array.splice(index, 1);\n return item;\n }\n });\n}\n\n//# sourceMappingURL=array-utils.es.js.map","import _slicedToArray from '@babel/runtime/helpers/slicedToArray';\nimport _classCallCheck from '@babel/runtime/helpers/classCallCheck';\nimport _createClass from '@babel/runtime/helpers/createClass';\nimport _defineProperty from '@babel/runtime/helpers/defineProperty';\nimport { flatten } from '@ultraq/array-utils';\nimport { memoize } from '@ultraq/function-utils';\n\n/* \n * Copyright 2019, Emanuel Rabina (http://www.ultraq.net.nz/)\n * \n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * \n * http://www.apache.org/licenses/LICENSE-2.0\n * \n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * Most branch-based type handlers are based around \"cases\".\n * For example, `select` and `plural` compare compare a value\n * to \"case keys\" to choose a subtranslation.\n * \n * This util splits \"matches\" portions provided to the aforementioned\n * handlers into case strings, and extracts any prepended arguments\n * (for example, `plural` supports an `offset:n` argument used for\n * populating the magic `#` variable).\n * \n * @param {String} string\n * @return {Object} The `cases` key points to a map of all cases.\n * The `arguments` key points to a list of prepended arguments.\n */\nfunction parseCases(string) {\n var isWhitespace = function isWhitespace(ch) {\n return /\\s/.test(ch);\n };\n\n var args = [];\n var cases = {};\n var currTermStart = 0;\n var latestTerm = null;\n var inTerm = false;\n var i = 0;\n\n while (i < string.length) {\n // Term ended\n if (inTerm && (isWhitespace(string[i]) || string[i] === '{')) {\n inTerm = false;\n latestTerm = string.slice(currTermStart, i); // We want to process the opening char again so the case will be properly registered.\n\n if (string[i] === '{') {\n i--;\n }\n } // New term\n else if (!inTerm && !isWhitespace(string[i])) {\n var caseBody = string[i] === '{'; // If there's a previous term, we can either handle a whole\n // case, or add that as an argument.\n\n if (latestTerm && caseBody) {\n var branchEndIndex = findClosingBracket(string, i);\n\n if (branchEndIndex === -1) {\n throw new Error(\"Unbalanced curly braces in string: \\\"\".concat(string, \"\\\"\"));\n }\n\n cases[latestTerm] = string.slice(i + 1, branchEndIndex); // Don't include the braces\n\n i = branchEndIndex; // Will be moved up where needed at end of loop.\n\n latestTerm = null;\n } else {\n if (latestTerm) {\n args.push(latestTerm);\n latestTerm = null;\n }\n\n inTerm = true;\n currTermStart = i;\n }\n }\n\n i++;\n }\n\n if (inTerm) {\n latestTerm = string.slice(currTermStart);\n }\n\n if (latestTerm) {\n args.push(latestTerm);\n }\n\n return {\n args: args,\n cases: cases\n };\n}\n/**\n * Finds the index of the matching closing curly bracket, including through\n * strings that could have nested brackets.\n * \n * @param {String} string\n * @param {Number} fromIndex\n * @return {Number} The index of the matching closing bracket, or -1 if no\n * closing bracket could be found.\n */\n\nfunction findClosingBracket(string, fromIndex) {\n var depth = 0;\n\n for (var i = fromIndex + 1; i < string.length; i++) {\n var char = string.charAt(i);\n\n if (char === '}') {\n if (depth === 0) {\n return i;\n }\n\n depth--;\n } else if (char === '{') {\n depth++;\n }\n }\n\n return -1;\n}\n/**\n * Split a `{key, type, format}` block into those 3 parts, taking into account\n * nested message syntax that can exist in the `format` part.\n * \n * @param {String} block\n * @return {Array}\n * An array with `key`, `type`, and `format` items in that order, if present\n * in the formatted argument block.\n */\n\nfunction splitFormattedArgument(block) {\n return split(block.slice(1, -1), ',', 3);\n}\n/**\n * Like `String.prototype.split()` but where the limit parameter causes the\n * remainder of the string to be grouped together in a final entry.\n * \n * @private\n * @param {String} string\n * @param {String} separator\n * @param {Number} limit\n * @param {Array} [accumulator=[]]\n * @return {Array}\n */\n\nfunction split(string, separator, limit) {\n var accumulator = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : [];\n\n if (!string) {\n return accumulator;\n }\n\n if (limit === 1) {\n accumulator.push(string);\n return accumulator;\n }\n\n var indexOfDelimiter = string.indexOf(separator);\n\n if (indexOfDelimiter === -1) {\n accumulator.push(string);\n return accumulator;\n }\n\n var head = string.substring(0, indexOfDelimiter).trim();\n var tail = string.substring(indexOfDelimiter + separator.length + 1).trim();\n accumulator.push(head);\n return split(tail, separator, limit - 1, accumulator);\n}\n\n/**\n * The main class for formatting messages.\n * \n * @author Emanuel Rabina\n */\n\nvar MessageFormatter = /*#__PURE__*/function () {\n /**\n * Creates a new formatter that can work using any of the custom type handlers\n * you register.\n * \n * @param {String} locale\n * @param {Object} [typeHandlers={}]\n * Optional object where the keys are the names of the types to register,\n * their values being the functions that will return a nicely formatted\n * string for the data and locale they are given.\n */\n function MessageFormatter(locale) {\n var _this = this;\n\n var typeHandlers = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n _classCallCheck(this, MessageFormatter);\n\n _defineProperty(this, \"format\", memoize(function (message) {\n var values = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n return flatten(_this.process(message, values)).join('');\n }));\n\n this.locale = locale;\n this.typeHandlers = typeHandlers;\n }\n /**\n * Formats an ICU message syntax string using `values` for placeholder data\n * and any currently-registered type handlers.\n * \n * @param {String} message\n * @param {Object} [values={}]\n * @return {String}\n */\n\n\n _createClass(MessageFormatter, [{\n key: \"process\",\n value:\n /**\n * Process an ICU message syntax string using `values` for placeholder data\n * and any currently-registered type handlers. The result of this method is\n * an array of the component parts after they have been processed in turn by\n * their own type handlers. This raw output is useful for other renderers,\n * eg: React where components can be used instead of being forced to return\n * raw strings.\n * \n * This method is used by {@link MessageFormatter#format} where it acts as a\n * string renderer.\n * \n * @param {String} message\n * @param {Object} [values={}]\n * @return {Array}\n */\n function process(message) {\n var values = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n if (!message) {\n return [];\n }\n\n var blockStartIndex = message.indexOf('{');\n\n if (blockStartIndex !== -1) {\n var blockEndIndex = findClosingBracket(message, blockStartIndex);\n\n if (blockEndIndex !== -1) {\n var block = message.substring(blockStartIndex, blockEndIndex + 1);\n\n if (block) {\n var result = [];\n var head = message.substring(0, blockStartIndex);\n\n if (head) {\n result.push(head);\n }\n\n var _splitFormattedArgume = splitFormattedArgument(block),\n _splitFormattedArgume2 = _slicedToArray(_splitFormattedArgume, 3),\n key = _splitFormattedArgume2[0],\n type = _splitFormattedArgume2[1],\n format = _splitFormattedArgume2[2];\n\n var body = values[key];\n\n if (body === null || body === undefined) {\n body = '';\n }\n\n var typeHandler = type && this.typeHandlers[type];\n result.push(typeHandler ? typeHandler(body, format, this.locale, values, this.process.bind(this)) : body);\n var tail = message.substring(blockEndIndex + 1);\n\n if (tail) {\n result.push(this.process(tail, values));\n }\n\n return result;\n }\n } else {\n throw new Error(\"Unbalanced curly braces in string: \\\"\".concat(message, \"\\\"\"));\n }\n }\n\n return [message];\n }\n }]);\n\n return MessageFormatter;\n}();\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\nvar pluralFormatter;\nvar keyCounter = 0; // All the special keywords that can be used in `plural` blocks for the various branches\n\nvar ONE = 'one';\nvar OTHER$1 = 'other';\n/**\n * @private\n * @param {String} caseBody\n * @param {Number} value\n * @return {Object} {caseBody: string, numberValues: object}\n */\n\nfunction replaceNumberSign(caseBody, value) {\n var i = 0;\n var output = '';\n var numBraces = 0;\n var numberValues = {};\n\n while (i < caseBody.length) {\n if (caseBody[i] === '#' && !numBraces) {\n var keyParam = \"__hashToken\".concat(keyCounter++);\n output += \"{\".concat(keyParam, \", number}\");\n numberValues[keyParam] = value;\n } else {\n output += caseBody[i];\n }\n\n if (caseBody[i] === '{') {\n numBraces++;\n } else if (caseBody[i] === '}') {\n numBraces--;\n }\n\n i++;\n }\n\n return {\n caseBody: output,\n numberValues: numberValues\n };\n}\n/**\n * Handler for `plural` statements within ICU message syntax strings. Returns\n * a formatted string for the branch that closely matches the current value.\n * \n * See https://formatjs.io/docs/core-concepts/icu-syntax#plural-format for more\n * details on how the `plural` statement works.\n * \n * @param {String} value\n * @param {String} matches\n * @param {String} locale\n * @param {String} values\n * @param {Function} format\n * @return {String}\n */\n\n\nfunction pluralTypeHandler(value) {\n var matches = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n var locale = arguments.length > 2 ? arguments[2] : undefined;\n var values = arguments.length > 3 ? arguments[3] : undefined;\n var format = arguments.length > 4 ? arguments[4] : undefined;\n\n var _parseCases = parseCases(matches),\n args = _parseCases.args,\n cases = _parseCases.cases;\n\n var intValue = parseInt(value);\n args.forEach(function (arg) {\n if (arg.startsWith('offset:')) {\n intValue -= parseInt(arg.slice('offset:'.length));\n }\n });\n var keywordPossibilities = [];\n\n if ('PluralRules' in Intl) {\n // Effectively memoize because instantiation of `Int.*` objects is expensive.\n if (pluralFormatter === undefined || pluralFormatter.resolvedOptions().locale !== locale) {\n pluralFormatter = new Intl.PluralRules(locale);\n }\n\n var pluralKeyword = pluralFormatter.select(intValue); // Other is always added last with least priority, so we don't want to add it here.\n\n if (pluralKeyword !== OTHER$1) {\n keywordPossibilities.push(pluralKeyword);\n }\n }\n\n if (intValue === 1) {\n keywordPossibilities.push(ONE);\n }\n\n keywordPossibilities.push(\"=\".concat(intValue), OTHER$1);\n\n for (var i = 0; i < keywordPossibilities.length; i++) {\n var keyword = keywordPossibilities[i];\n\n if (keyword in cases) {\n var _replaceNumberSign = replaceNumberSign(cases[keyword], intValue),\n caseBody = _replaceNumberSign.caseBody,\n numberValues = _replaceNumberSign.numberValues;\n\n return format(caseBody, _objectSpread(_objectSpread({}, values), numberValues));\n }\n }\n\n return value;\n}\n\n/* \n * Copyright 2019, Emanuel Rabina (http://www.ultraq.net.nz/)\n * \n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * \n * http://www.apache.org/licenses/LICENSE-2.0\n * \n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nvar OTHER = 'other';\n/**\n * Handler for `select` statements within ICU message syntax strings. Returns\n * a formatted string for the branch that closely matches the current value.\n * \n * See https://formatjs.io/docs/core-concepts/icu-syntax#select-format for more\n * details on how the `select` statement works.\n * \n * @param {String} value\n * @param {String} matches\n * @param {String} locale\n * @param {String} values\n * @param {Function} format\n * @return {String}\n */\n\nfunction selectTypeHandler(value) {\n var matches = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n var values = arguments.length > 3 ? arguments[3] : undefined;\n var format = arguments.length > 4 ? arguments[4] : undefined;\n\n var _parseCases = parseCases(matches),\n cases = _parseCases.cases;\n\n if (value in cases) {\n return format(cases[value], values);\n } else if (OTHER in cases) {\n return format(cases[OTHER], values);\n }\n\n return value;\n}\n\nexport { MessageFormatter, findClosingBracket, parseCases, pluralTypeHandler, selectTypeHandler, splitFormattedArgument };\n//# sourceMappingURL=icu-message-formatter.es.js.map\n","/**\n * A higher-order function to apply [memoization](https://en.wikipedia.org/wiki/Memoization).\n * \n * If memoizing a recursive function, then memoize and define the function at\n * the same time so you can make a call to the memoized function, eg:\n * \n * ```javascript\n * const myFunction = memoize(() => myFunction());\n * ```\n * \n * @param {Function} func\n * @return {Function} \n */\nexport function memoize(func) {\n var cache = {};\n return function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var key = args.length ? args.map(function (arg) {\n return arg === null ? 'null' : arg === undefined ? 'undefined' : typeof arg === 'function' ? arg.toString() : arg instanceof Date ? arg.toISOString() : JSON.stringify(arg);\n }).join('|') : '_(no-args)_';\n\n if (Object.prototype.hasOwnProperty.call(cache, key)) {\n return cache[key];\n }\n\n var result = func.apply(void 0, args);\n cache[key] = result;\n return result;\n };\n}\n\n//# sourceMappingURL=function-utils.es.js.map","export default function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}","import arrayWithHoles from \"./arrayWithHoles.js\";\nimport iterableToArrayLimit from \"./iterableToArrayLimit.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableRest from \"./nonIterableRest.js\";\nexport default function _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}","export default function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}","export default function _iterableToArrayLimit(r, l) {\n var t = null == r ? null : \"undefined\" != typeof Symbol && r[Symbol.iterator] || r[\"@@iterator\"];\n if (null != t) {\n var e,\n n,\n i,\n u,\n a = [],\n f = !0,\n o = !1;\n try {\n if (i = (t = t.call(r)).next, 0 === l) {\n if (Object(t) !== t) return;\n f = !1;\n } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0);\n } catch (r) {\n o = !0, n = r;\n } finally {\n try {\n if (!f && null != t[\"return\"] && (u = t[\"return\"](), Object(u) !== u)) return;\n } finally {\n if (o) throw n;\n }\n }\n return a;\n }\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}","export default function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","import { createSelector } from '@reduxjs/toolkit'\nimport type { RootState } from 'domains/store'\n\nexport const selectTranslations = createSelector(\n ({ i18n }: RootState) => i18n,\n ({ translations }) => translations,\n)\n\nexport const selectInitialLocale = createSelector(\n ({ i18n }: RootState) => i18n,\n ({ initialLocale }) => initialLocale,\n)\n\nexport const selectLocale = createSelector(\n ({ i18n }: RootState) => i18n,\n ({ userLocale }) => userLocale,\n)\n\nexport const selectIsLoading = createSelector(\n ({ i18n }: RootState) => i18n,\n ({ isLoading }) => isLoading,\n)\n","import {\n MessageFormatter,\n pluralTypeHandler,\n selectTypeHandler,\n} from '@ultraq/icu-message-formatter'\nimport { useCallback } from 'preact/hooks'\nimport { useSelector } from 'react-redux'\nimport {\n selectInitialLocale,\n selectIsLoading,\n selectLocale,\n selectTranslations,\n} from 'domains/i18n/selectors'\n\n// pluralTypeHandler. Since we only use exact plural matches (=0, =1 etc) we can\n// safely use en-GB all the time.\nconst formatter = new MessageFormatter('en-GB', {\n plural: pluralTypeHandler,\n select: selectTypeHandler,\n})\n\nexport function useI18n() {\n const translations = useSelector(selectTranslations)\n const userLocale = useSelector(selectLocale)\n const initialLocale = useSelector(selectInitialLocale)\n const isLoading = useSelector(selectIsLoading)\n\n const t = useCallback(\n (key: string, values = {}) => {\n const translation = translations[key]\n if (!translation) {\n if (isLoading) return null\n\n console.warn(\n `Translation key: ${key} is missing in locale: ${userLocale}`,\n )\n return null\n }\n return formatter.format(translation, values)\n },\n [translations, userLocale, isLoading],\n )\n\n return {\n t,\n userLocale,\n initialLocale,\n }\n}\n","import { useMemo } from 'preact/hooks'\nimport { useSelector } from 'react-redux'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { selectError, selectHasError } from './selectors'\n\nexport function useInterrupt() {\n const { t } = useI18n()\n const error = useSelector(selectError)\n const hasError = useSelector(selectHasError)\n\n const meta = useMemo(() => {\n if (!hasError) {\n return {\n title: undefined,\n message: undefined,\n srText: undefined,\n buttonText: undefined,\n originalError: undefined,\n }\n }\n\n const { langKey, action } = error\n const title = t(`${langKey}.title`)\n const message = t(`${langKey}.message`)\n const srText = t(`${langKey}.srText`)\n const buttonText = action ? t(`${langKey}.buttonText`) : null\n\n return {\n ...(langKey ? { title, message, srText } : {}),\n ...(action ? { action } : {}),\n ...(action && langKey ? { buttonText } : {}),\n originalError: error,\n }\n }, [hasError, error, t])\n\n return { hasError, meta, error }\n}\n","import { createSelector } from '@reduxjs/toolkit'\nimport { RootState } from 'domains/store'\n\nexport const selectError = createSelector(\n ({ interrupt }: RootState) => interrupt,\n ({ error }: RootState['interrupt']) => error,\n)\n\nexport const selectHasError = createSelector(selectError, (error) =>\n Boolean(error),\n)\n","import { createSlice, isAnyOf } from '@reduxjs/toolkit'\nimport { initializeApp } from 'domains/app/actions'\nimport { initializeConfig } from 'domains/config/actions'\nimport { setLocale } from 'domains/i18n/actions'\nimport { getConversation } from 'domains/store/actions'\nimport { initializeVisibility, setVisibility } from 'domains/visibility/actions'\n\nconst initialState = {\n error: undefined,\n}\n\nexport const interruptSlice = createSlice({\n name: 'interrupt',\n initialState,\n reducers: {\n setInterrupt: (state, action) => {\n state.error = action.payload\n },\n clearInterrupt: () => initialState,\n },\n extraReducers: (builder) => {\n builder\n .addCase(initializeConfig.pending, () => initialState)\n .addMatcher(\n isAnyOf(\n initializeApp.rejected,\n initializeConfig.rejected,\n setLocale.rejected,\n setVisibility.rejected,\n initializeVisibility.rejected,\n getConversation.rejected,\n ),\n (state, { payload }) => {\n state.error = payload\n },\n )\n },\n})\n\nexport const { setInterrupt, clearInterrupt } = interruptSlice.actions\n\nexport default interruptSlice.reducer\n","import { createAsyncThunk } from '@reduxjs/toolkit'\nimport { ConversationHistoryResponse } from 'api'\nimport { ThunkAPI } from 'domains/redux/redux.types'\n\nexport const getConversation = createAsyncThunk<\n ConversationHistoryResponse | undefined,\n {\n lastEvent: { id: string; occurredAt: number }\n },\n ThunkAPI\n>(\n 'getConversation',\n async (_, { extra: { api }, rejectWithValue }) => {\n try {\n return api.getConversation()\n } catch (error) {\n return rejectWithValue({\n name: error?.name,\n message: error?.message,\n langKey: error?.langKey,\n action: error?.action,\n originalEvent: error?.originalEvent,\n originalError: error?.originalError,\n })\n }\n },\n {\n condition(payload, { getState }) {\n const {\n state: { events },\n } = getState()\n\n const lastEvent = events[events.length - 1]\n const payloadLastEventId = payload?.lastEvent?.id\n return lastEvent && payloadLastEventId !== lastEvent.payload.id\n },\n },\n)\n","import { createSlice } from '@reduxjs/toolkit'\nimport { resetApp } from 'domains/app/actions'\nimport { initializeConfig } from 'domains/config/actions'\nimport { setLocale } from 'domains/i18n/actions'\nimport { I18nState } from 'domains/i18n/i18n.types'\n\nconst initialState: I18nState = {\n translations: {\n 'errors.configError.message':\n 'We are sorry this happened, please retry at a later time.',\n 'errors.configError.srText':\n 'A chat configuration error occurred. Our apologies, please retry at a later time.',\n 'errors.configError.title': 'Chat configuration error.',\n 'errors.general.buttonText': 'Restart chat',\n 'errors.general.message': 'Do you want to start a new chat session?',\n 'errors.general.srText':\n 'Something went wrong with the chat session. You can restart the chat.',\n 'errors.general.title': 'Something went wrong',\n 'errors.seamlyOffline.message':\n 'There might be a problem with your or our network connection. The chat session should resume as soon the connection is available again.',\n 'errors.seamlyOffline.srText':\n 'The chat has connection issues. There might be a problem with your or our network connection. The chat session should resume as soon as the connection is available again.',\n 'errors.seamlyOffline.title': 'Connection issues',\n 'errors.seamlyUnavailable.buttonText': 'Try again',\n 'errors.seamlyUnavailable.message':\n 'The server could not be reached. Try again in a little while.',\n 'errors.seamlyUnavailable.srText':\n 'The chat server could not be reached. Try again in a little while.',\n 'errors.seamlyUnavailable.title': 'Server unavailable',\n },\n isLoading: false,\n initialLocale: undefined,\n userLocale: undefined,\n}\n\nexport const i18nSlice = createSlice({\n name: 'app',\n initialState,\n reducers: {\n setInitialLocale: (state, action) => {\n state.initialLocale = action.payload\n },\n setTranslations: (state, { payload }) => {\n state.translations = payload\n },\n },\n extraReducers: (builder) => {\n // Add reducers for additional action types here, and handle loading state as needed\n builder\n .addCase(resetApp.pending, () => initialState)\n .addCase(initializeConfig.fulfilled, (state, { payload }) => {\n state.initialLocale = payload.defaultUserLocale\n })\n .addCase(setLocale.pending, (state) => {\n state.isLoading = true\n })\n .addCase(setLocale.rejected, (state) => {\n state.isLoading = false\n })\n .addCase(setLocale.fulfilled, (state, { payload }) => {\n state.isLoading = false\n if (!payload?.translations) {\n return\n }\n\n state.userLocale = payload.userLocale\n state.translations = Object.keys(payload.translations)\n .sort()\n .reduce(\n (accum, key) => ({\n ...accum,\n [key]: payload.translations[key],\n }),\n {},\n )\n })\n },\n})\n\nexport const { setInitialLocale, setTranslations } = i18nSlice.actions\n\nexport default i18nSlice.reducer\n","import { combineReducers, configureStore } from '@reduxjs/toolkit'\nimport { Events } from 'minivents'\nimport { useDispatch } from 'react-redux'\nimport { API } from 'api'\nimport { Config } from 'config.types'\nimport appReducer from 'domains/app/slice'\nimport configReducer from 'domains/config/slice'\nimport { createErrorsMiddleware } from 'domains/errors'\nimport formsReducer from 'domains/forms/slice'\nimport i18nReducer from 'domains/i18n/slice'\nimport createInterruptMiddleware from 'domains/interrupt/middleware'\nimport interruptReducer from 'domains/interrupt/slice'\nimport createOptionsMiddleware from 'domains/options/middleware'\nimport stateReducer from 'domains/store/slice'\nimport createI18nMiddleware from 'domains/translations/middleware'\nimport translationReducer from 'domains/translations/slice'\nimport visibilityReducer from 'domains/visibility/slice'\n\ntype CreateStore = {\n initialState: unknown\n api: API\n eventBus: Events\n config: Config\n}\n\nconst rootReducer = combineReducers({\n state: stateReducer,\n app: appReducer,\n config: configReducer,\n i18n: i18nReducer,\n translations: translationReducer,\n visibility: visibilityReducer,\n forms: formsReducer,\n interrupt: interruptReducer,\n})\n\nexport function createStore({\n initialState,\n api,\n eventBus,\n config,\n}: CreateStore) {\n const store = configureStore({\n reducer: rootReducer,\n preloadedState: initialState,\n middleware: (getDefaultMiddleWare) =>\n getDefaultMiddleWare({\n thunk: {\n extraArgument: {\n api,\n eventBus,\n config,\n },\n },\n serializableCheck: false,\n }).concat(\n createErrorsMiddleware({ api }),\n createInterruptMiddleware({ api }),\n createOptionsMiddleware({ api }),\n createI18nMiddleware,\n ),\n })\n\n return store\n}\nexport type Store = ReturnType<typeof createStore>\nexport type RootState = ReturnType<typeof rootReducer>\nexport type AppDispatch = Store['dispatch']\n\nexport const useAppDispatch: () => AppDispatch = useDispatch\n","import { PayloadAction, createSlice, isAnyOf } from '@reduxjs/toolkit'\nimport { initializeApp, resetApp } from 'domains/app/actions'\nimport { initializeConfig } from 'domains/config/actions'\nimport { randomId } from 'lib/id'\nimport { getTimeFromSeconds } from 'ui/utils/general-utils'\nimport {\n entryTypes,\n eventTypes,\n featureKeys,\n payloadTypes,\n readStates,\n} from 'ui/utils/seamly-utils'\nimport type { ConversationHistoryResponse, InitialConversation } from 'api'\nimport type {\n AckEvent,\n ChannelEvent,\n CurrentUploadPayload,\n EntryMeta,\n MessageParticipant,\n ServiceInfo,\n StoreState,\n} from 'domains/store/store.types'\n\nexport const isUnreadMessage = ({ type, payload }: ChannelEvent) =>\n document.visibilityState === 'hidden' ||\n (type === eventTypes.message && !payload.fromClient) ||\n (type === eventTypes.info && payload.type === payloadTypes.text)\n\nexport const orderHistory = (events: ChannelEvent[]) => {\n return events.sort(\n (\n { payload: { occurredAt: occurredAtA } },\n { payload: { occurredAt: occurredAtB } },\n ) => occurredAtA - occurredAtB,\n )\n}\n\nexport const mergeHistory = (\n stateEvents: ChannelEvent[],\n historyEvents: ConversationHistoryResponse['events'],\n) => {\n const newStateEvents = stateEvents.filter(\n (stateEvent) =>\n stateEvent.type === 'message' &&\n !stateEvent.payload.optimisticallyInjected &&\n // Deduplicate the event streams, giving events in historyEvents\n // precedence so the server is able to push changes to events.\n !historyEvents.some(\n (historyEvent) => historyEvent.payload.id === stateEvent.payload.id,\n ),\n )\n\n const newHistoryEvents = historyEvents\n .filter(\n (historyEvent) =>\n // Remove all non displayable participant messages\n !(\n historyEvent.type === 'participant' &&\n !historyEvent.payload.participant.introduction\n ),\n )\n // Reverse is done here because the server sends the history in the order\n // newest to oldest. In the case of exactly the same occurredAt timestamps\n // these messages will be shown in the wrong order if not reversed. For\n // the normal merging logic there is no added effect.\n .reverse()\n\n return orderHistory([...newHistoryEvents, ...newStateEvents])\n}\n\nconst participantReducer = (participantInfo, action) => {\n // TODO: a) Styleguide only! b) Should be removed after styleguide overhaul.\n if (!participantInfo) {\n return {\n participants: {},\n currentAgent: '',\n }\n }\n\n const { participants } = participantInfo || { participants: {} }\n const { id, avatar, name, introduction } = action.participant\n const oldParticipant = participants[id]\n\n const newParticipants = {\n ...participants,\n [id]: oldParticipant\n ? {\n ...oldParticipant,\n ...(avatar ? { avatar } : {}),\n ...(name ? { name } : {}),\n ...(introduction ? { introduction } : {}),\n }\n : action.participant,\n }\n\n return {\n ...participantInfo,\n participants: newParticipants,\n currentAgent:\n participantInfo.currentAgent !== id && !action.fromClient\n ? id\n : participantInfo.currentAgent,\n }\n}\n\nconst calculateNewEntryMeta = (\n entryMeta: EntryMeta,\n channelEvent?: ChannelEvent,\n) => {\n const entry =\n channelEvent?.type === 'message'\n ? channelEvent?.payload.translatedEntry || channelEvent?.payload.entry\n : {}\n\n const { blockAutoEntrySwitch } = entryMeta\n const actions = channelEvent?.payload?.actions || {}\n const translatedActions = channelEvent?.payload?.translatedActions || {}\n\n if (!entry) {\n return {\n ...entryMeta,\n optionsOverride: {},\n actions,\n translatedActions,\n }\n }\n\n const { type, options } = entry\n\n let newActive = entryMeta.active\n\n if (!blockAutoEntrySwitch && type !== entryMeta.userSelected) {\n newActive = type\n }\n\n return {\n ...entryMeta,\n active: newActive,\n optionsOverride: {\n ...(entryMeta.optionsOverride || {}),\n ...(type ? { [type]: options } : {}),\n },\n actions,\n translatedActions,\n }\n}\n\nexport const initialStoreState: StoreState = {\n events: [],\n isLastEventFromClient: false,\n initialState: {\n userResponded: false,\n },\n unreadEvents: 0,\n userHasResponded: false,\n loadedImageEventIds: [],\n isLoading: false,\n idleDetachCountdown: {\n hasCountdown: false,\n isActive: false,\n remaining: undefined,\n wasStopped: undefined,\n count: undefined,\n timer: undefined,\n },\n resumeConversationPrompt: false,\n serviceInfo: {\n activeServiceSessionId: '',\n proactiveMessages: false,\n },\n participantInfo: {\n participants: {},\n currentAgent: '',\n },\n headerTitles: {\n title: null,\n subTitle: '',\n },\n historyLoaded: false,\n skiplinkTargetId: randomId(),\n optionsButtonId: randomId(),\n headerCollapseButtonId: randomId(),\n serviceData: {},\n options: {\n features: {\n webNotifications: {\n enabled: false,\n },\n },\n panelActive: false,\n optionActive: '',\n userSelectedOptions: {},\n },\n showFileUpload: false,\n currentUploads: [],\n processingFileUploads: [],\n entryMeta: {\n default: entryTypes.text,\n active: entryTypes.text,\n userSelected: null,\n blockAutoEntrySwitch: false,\n options: {},\n optionsOverride: {},\n actions: {},\n translatedActions: {},\n },\n seamlyContainerElement: null,\n}\n\nexport const storeSlice = createSlice({\n name: 'store',\n initialState: initialStoreState,\n reducers: {\n addEvent: (state, action: PayloadAction<ChannelEvent>) => {\n const { type: eventType, payload } = action.payload\n\n const accountHasUploads = state.options.features.hasOwnProperty(\n featureKeys.uploads,\n )\n\n let newOptions = { ...state.options }\n\n // This enabled override of the service enabled value for uploads.\n // If a message is sent with entry of type upload it will temporarily\n // override service value and enable uploads.\n if (\n accountHasUploads &&\n (eventType === eventTypes.message ||\n eventType === eventTypes.participant) &&\n !payload.fromClient\n ) {\n const entryType = eventType === 'message' ? payload.entry?.type : {}\n newOptions = {\n ...newOptions,\n features: {\n ...newOptions.features,\n uploads: {\n ...newOptions.features?.uploads,\n enabledFromEntry: entryType === entryTypes.upload,\n },\n },\n }\n }\n\n const incrementUnread = isUnreadMessage(action.payload)\n\n // We check for duplicated and ignore them as in some error of the websocket\n // a duplicate join can be active for a while until the server connection\n // times out.\n const eventExists = state.events.find((e) => e.payload.id === payload.id)\n if (eventExists) {\n return\n }\n\n const newEntryMeta = calculateNewEntryMeta(\n state.entryMeta,\n action.payload,\n )\n\n state.entryMeta =\n !accountHasUploads && newEntryMeta.active === entryTypes.upload\n ? { ...state.entryMeta }\n : newEntryMeta\n\n state.options = newOptions\n\n if (incrementUnread) {\n state.unreadEvents += 1\n if (eventType !== 'service_data') {\n action.payload.payload.messageStatus = payload.fromClient\n ? readStates.read\n : readStates.received\n }\n }\n\n action.payload.payload.key = randomId()\n state.events.push(action.payload)\n\n state.isLastEventFromClient = payload.fromClient\n },\n ackEvent: (state, { payload: { payload } }: PayloadAction<AckEvent>) => {\n // If any ACKs are sent without transactionID the conversation crashes.\n // Ensure that this edge case is handled gracefully.\n if (!payload.transactionId) {\n console.warn('ACK received without transaction ID.')\n return\n }\n\n const matchedEvent = state.events.find(\n (m) =>\n m.payload.transactionId === payload.transactionId &&\n (!payload.type || m.type === payload.type),\n )\n\n const { id, occurredAt } = payload\n if (matchedEvent) {\n matchedEvent.payload.id = id\n matchedEvent.payload.occurredAt = occurredAt\n\n state.events = orderHistory(state.events)\n }\n },\n clearEvents: (state) => {\n state.unreadEvents = 0\n state.loadedImageEventIds = []\n state.events = []\n },\n setEventsRead: (state, { payload }: PayloadAction<string[]>) => {\n state.unreadEvents = 0\n state.events.forEach((event) => {\n if (payload.indexOf(event.payload.id) !== -1) {\n event.payload = {\n ...event.payload,\n ...(event.type !== 'service_data' &&\n event.payload.messageStatus === readStates.received && {\n messageStatus: readStates.read,\n }),\n }\n }\n return event\n })\n },\n setLoadedImageEventIds: (state, { payload }) => {\n state.loadedImageEventIds.push(payload)\n },\n setHistory: (\n state,\n {\n payload: {\n events: history,\n participants,\n activeServiceSessionId,\n activeServiceSettings = {},\n serviceData,\n resumeConversationPrompt,\n },\n }: PayloadAction<ConversationHistoryResponse>,\n ) => {\n const events = mergeHistory(state.events, history)\n\n const mergedParticipants = {\n ...state.participantInfo.participants,\n ...participants,\n }\n\n const lastParticipantEvent = events\n .slice()\n .reverse()\n .find(\n (m) =>\n (m.type === 'message' || m.type === 'participant') &&\n !m.payload.fromClient,\n )\n\n let lastParticipantId = null\n\n if (lastParticipantEvent) {\n if (lastParticipantEvent.type === 'message') {\n lastParticipantId = lastParticipantEvent.payload.participant\n }\n if (lastParticipantEvent.type === 'participant') {\n lastParticipantId = lastParticipantEvent.payload.participant.id\n }\n }\n\n const { entry } = activeServiceSettings\n const upload = entry?.options?.upload\n\n const historyNewEntryMeta = calculateNewEntryMeta(\n {\n ...state.entryMeta,\n ...entry,\n active: entry?.default || payloadTypes.text,\n options: { ...(entry?.options ? entry.options : {}) },\n },\n events[events.length - 1],\n )\n\n let newFeatures = { ...state.options.features }\n\n const newFeaturesHasUpload = newFeatures.hasOwnProperty(\n featureKeys.uploads,\n )\n\n // Only set uploads if it was initialised by the account config.\n if (newFeaturesHasUpload && lastParticipantEvent?.type === 'message') {\n const { payload: lastParticipantEventPayload } = lastParticipantEvent\n const entryType = lastParticipantEventPayload?.entry?.type || {}\n newFeatures = {\n ...newFeatures,\n uploads: {\n enabled: !!(upload && upload?.enabled),\n enabledFromEntry: entryType === entryTypes.upload,\n },\n }\n }\n\n state.unreadEvents = events.filter(\n (event) =>\n event.type === 'message' &&\n event.payload.messageStatus === readStates.received,\n ).length\n state.events = events.filter(\n (e) => e.type !== 'participant' || !!e.payload.participant.introduction,\n )\n state.participantInfo = {\n ...state.participantInfo,\n ...(lastParticipantId\n ? participantReducer(state.participantInfo, {\n participant: mergedParticipants[lastParticipantId],\n })\n : {}),\n participants: mergedParticipants,\n }\n state.historyLoaded = true\n state.serviceInfo = {\n ...state.serviceInfo,\n activeServiceSessionId,\n proactiveMessages:\n activeServiceSettings?.proactiveMessages?.enabled || false,\n }\n\n state.serviceData = {\n ...state.serviceData,\n ...serviceData,\n }\n\n state.options = {\n ...state.options,\n features: newFeatures,\n }\n state.entryMeta =\n !newFeaturesHasUpload &&\n historyNewEntryMeta.active === entryTypes.upload\n ? { ...state.entryMeta }\n : historyNewEntryMeta\n state.resumeConversationPrompt = resumeConversationPrompt || false\n\n if (lastParticipantId) {\n state.headerTitles.subTitle = mergedParticipants[lastParticipantId].name\n }\n },\n resetHistoryLoadedFlag: (state) => {\n state.historyLoaded = false\n },\n setIsLoading: (state, { payload }) => {\n state.isLoading = payload\n },\n initIdleDetachCountdown: (state, { payload }) => {\n const { delaySeconds, delayTime } = payload\n\n state.idleDetachCountdown = {\n hasCountdown: true,\n isActive: true,\n wasStopped: false,\n count: delaySeconds,\n remaining: delaySeconds,\n timer: delayTime,\n }\n },\n decrementIdleDetachCountdownCounter: (state) => {\n const { idleDetachCountdown } = state\n\n const { remaining: prevRemaining } = idleDetachCountdown\n\n const remaining = prevRemaining - 1\n\n state.idleDetachCountdown.remaining = remaining\n state.idleDetachCountdown.timer = getTimeFromSeconds(remaining)\n },\n stopIdleDetachCountdownCounter: (state) => {\n state.idleDetachCountdown.isActive = false\n state.idleDetachCountdown.wasStopped = true\n },\n clearIdleDetachCountdown: (state) => {\n state.idleDetachCountdown.hasCountdown = false\n state.idleDetachCountdown.isActive = false\n },\n initResumeConversationPrompt: (state) => {\n state.resumeConversationPrompt = true\n },\n clearResumeConversationPrompt: (state) => {\n state.resumeConversationPrompt = false\n },\n setParticipant: (state, { payload }: PayloadAction<MessageParticipant>) => {\n state.participantInfo = participantReducer(state.participantInfo, {\n participant: payload.participant,\n fromClient: payload.fromClient,\n })\n },\n setActiveService: (\n state,\n { payload }: PayloadAction<ServiceInfo['activeServiceSessionId']>,\n ) => {\n if (state.serviceInfo.activeServiceSessionId !== payload) {\n state.serviceInfo.activeServiceSessionId = payload\n }\n },\n setHeaderTitle: (state, { payload }) => {\n state.headerTitles.title = payload\n },\n setHeaderSubTitle: (state, { payload }) => {\n state.headerTitles.subTitle = payload\n },\n setInitialState: (\n state,\n { payload }: PayloadAction<InitialConversation>,\n ) => {\n state.initialState = payload\n state.unreadEvents = initialStoreState.unreadEvents\n },\n setServiceDataItem: (state, { payload }) => {\n state.serviceData[payload.type] = payload\n },\n setFeatures: (state, { payload }) => {\n if (!payload.features) {\n return\n }\n state.options.features = payload.features\n },\n setFeatureEnabledState: (state, { payload }) => {\n if (!state.options.features.hasOwnProperty(payload.key)) {\n return\n }\n state.options.features[payload.key].enabled = payload.enabled\n },\n clearFeatures: (state) => {\n state.options.features = {\n webNotifications: state.options.features.webNotifications,\n }\n },\n showOption: (state, { payload }) => {\n state.options.panelActive = true\n state.options.optionActive = payload\n },\n hideOption: (state) => {\n state.options.panelActive = false\n state.options.optionActive = ''\n },\n setUserSelectedOptions: (state, { payload }) => {\n state.options.userSelectedOptions = payload\n },\n setUserSelectedOption: (state, { payload }) => {\n const { option, value } = payload\n state.options.userSelectedOptions[option] = value\n },\n setBlockAutoEntrySwitch: (state, { payload }) => {\n state.entryMeta.blockAutoEntrySwitch = payload\n },\n setServiceEntryMetadata: (state, { payload }) => {\n state.entryMeta.active = payload.default\n state.entryMeta.options = payload.options || {}\n state.entryMeta.optionsOverride = {}\n state.entryMeta.actions = {}\n state.entryMeta.translatedActions = {}\n },\n setActiveEntryType: (state, { payload }) => {\n state.entryMeta.active = payload\n },\n setUserEntryType: (state, { payload }) => {\n state.entryMeta.userSelected = payload\n },\n clearAbortTransaction: (state) => {\n state.entryMeta.actions = {}\n state.entryMeta.translatedActions = {}\n },\n registerUpload: (\n state,\n { payload }: PayloadAction<Omit<CurrentUploadPayload, 'progress'>>,\n ) => {\n state.currentUploads.push({\n id: payload.fileId,\n name: payload.fileName,\n progress: 1,\n uploading: true,\n complete: false,\n error: '',\n uploadHandle: payload.uploadHandle,\n })\n },\n setUploadProgress: (\n state,\n {\n payload,\n }: PayloadAction<Omit<CurrentUploadPayload, 'uploadHandle' | 'fileName'>>,\n ) => {\n state.currentUploads = state.currentUploads.map((fileUpload) => {\n if (fileUpload.id === payload.fileId) {\n return {\n ...fileUpload,\n progress: payload.progress,\n uploading: payload.progress !== 100,\n uploadHandle:\n payload.progress === 100 ? null : fileUpload.uploadHandle,\n }\n }\n return fileUpload\n })\n },\n startProcessingImage: (state, { payload }: PayloadAction<string>) => {\n state.processingFileUploads.push(payload)\n },\n doneProcessingImage: (state, { payload }: PayloadAction<string>) => {\n state.processingFileUploads = state.processingFileUploads.filter(\n (fileId) => fileId !== payload,\n )\n },\n setUploadError: (state, { payload }) => {\n state.currentUploads = state.currentUploads.map((fileUpload) => {\n if (fileUpload.id === payload.fileId) {\n return {\n ...fileUpload,\n error: payload.errorText,\n progress: 0,\n uploading: false,\n uploadHandle: null,\n }\n }\n return fileUpload\n })\n },\n setUploadComplete: (\n state,\n { payload }: PayloadAction<CurrentUploadPayload['fileId']>,\n ) => {\n state.currentUploads = state.currentUploads.map((fileUpload) => {\n if (fileUpload.id === payload) {\n return {\n ...fileUpload,\n complete: true,\n }\n }\n return fileUpload\n })\n },\n clearAllUploads: (state) => {\n state.currentUploads = []\n },\n setSeamlyContainerElement: (state, { payload }) => {\n state.seamlyContainerElement = payload\n },\n setProactiveMessages: (\n state,\n { payload }: PayloadAction<ServiceInfo['proactiveMessages']>,\n ) => {\n state.serviceInfo.proactiveMessages = payload\n },\n },\n extraReducers: (builder) => {\n builder\n .addCase(resetApp.pending, () => initialStoreState)\n .addCase(initializeApp.pending, (state) => {\n state.isLoading = true\n })\n .addCase(initializeConfig.fulfilled, (state, { payload }) => {\n state.headerTitles.subTitle = payload.agentParticipant?.name\n\n if (!payload.features) return\n\n state.options.features = payload.features\n })\n .addCase(initializeApp.fulfilled, (state, { payload }) => {\n state.isLoading = false\n\n if (!payload.initialState) return\n state.initialState = payload.initialState\n })\n .addMatcher(\n isAnyOf(initIdleDetachCountdown, initResumeConversationPrompt),\n (state) => {\n state.isLastEventFromClient = false\n },\n )\n },\n})\n\nexport const {\n ackEvent,\n addEvent,\n clearAllUploads,\n clearEvents,\n clearFeatures,\n clearIdleDetachCountdown,\n clearResumeConversationPrompt,\n decrementIdleDetachCountdownCounter,\n hideOption,\n initIdleDetachCountdown,\n initResumeConversationPrompt,\n registerUpload,\n resetHistoryLoadedFlag,\n setActiveEntryType,\n setActiveService,\n setBlockAutoEntrySwitch,\n setEventsRead,\n setFeatureEnabledState,\n setFeatures,\n setHeaderSubTitle,\n setHeaderTitle,\n setHistory,\n setInitialState,\n setIsLoading,\n setLoadedImageEventIds,\n setParticipant,\n setSeamlyContainerElement,\n setServiceDataItem,\n setServiceEntryMetadata,\n clearAbortTransaction,\n setUploadComplete,\n setUploadError,\n setUploadProgress,\n startProcessingImage,\n doneProcessingImage,\n setUserEntryType,\n setUserSelectedOption,\n setUserSelectedOptions,\n showOption,\n stopIdleDetachCountdownCounter,\n setProactiveMessages,\n} = storeSlice.actions\n\nexport default storeSlice.reducer\n","import { createSelector } from '@reduxjs/toolkit'\nimport { RootState } from 'domains/store'\nimport { ChannelEvent } from 'domains/store/store.types'\n\nexport const selectIsTranslated = (channelEvent: ChannelEvent) =>\n createSelector(\n (store: RootState) => store.translations.translatedEventGroups,\n (translatedEventGroups: Record<string, string[]>) =>\n Object.values(translatedEventGroups).every(\n (value) => !value.includes(channelEvent?.payload?.id),\n ),\n )\n","import { useCallback, useMemo } from 'preact/hooks'\nimport { useDispatch, useSelector } from 'react-redux'\nimport { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport {\n ChannelEvent,\n InfoEvent,\n MessageEvent,\n ParticipantEvent,\n ServiceDataEvent,\n} from 'domains/store/store.types'\nimport { selectIsTranslated } from 'domains/translations/selectors'\nimport {\n disableTranslation,\n disableTranslationProposalPrompt,\n} from 'domains/translations/slice'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport {\n useElementFocusingById,\n useSeamlyCommands,\n} from 'ui/hooks/seamly-hooks'\nimport { TRANSLATION_PROPOSAL, actionTypes } from 'ui/utils/seamly-utils'\nimport type { RootState } from 'domains/store'\nimport type { Language } from 'domains/translations/translations.types'\n\nexport function useTranslations() {\n const { sendContext } = useSeamlyCommands()\n const dispatch = useDispatch()\n const config = useConfig()\n const enableTranslations = useCallback(\n (userLocale: Language['locale']) => {\n sendContext({\n userLocale,\n })\n },\n [sendContext],\n )\n const disableTranslations = useCallback(() => {\n sendContext({\n userLocale: config.context.contentLocale,\n })\n dispatch(disableTranslation())\n }, [config.context, dispatch, sendContext])\n\n const { languages, isActive, isAvailable, currentLocale } = useSelector(\n ({ translations }: RootState) => translations,\n )\n\n return {\n languages,\n isActive,\n isAvailable,\n currentLocale,\n enableTranslations,\n disableTranslations,\n }\n}\n\ntype EventDataBody =\n | ParticipantEvent['payload']['participant']['introduction']\n | MessageEvent['payload']['body']\n | InfoEvent['payload']['body']\n | ServiceDataEvent['payload']['body']\n\ntype TranslatedEventDataBody =\n | ParticipantEvent['payload']['participant']['translatedIntroduction']\n | MessageEvent['payload']['translatedBody']\n | InfoEvent['payload']['translatedBody']\n | ServiceDataEvent['payload']['translatedBody']\n\nexport function useTranslatedEventData(channelEvent: ChannelEvent): {\n body: EventDataBody\n hasTranslation: boolean\n isTranslated: boolean\n userLocale: string\n} {\n const getTranslations = (): {\n body: EventDataBody\n translatedBody: TranslatedEventDataBody\n translation?: any\n } => {\n if (!channelEvent?.payload)\n return { body: undefined, translatedBody: undefined }\n if (channelEvent.type === 'participant') {\n return {\n body: channelEvent.payload?.participant.introduction,\n translatedBody:\n channelEvent.payload?.participant?.translatedIntroduction,\n translation:\n // @ts-ignore\n channelEvent.payload?.participant?.translation,\n }\n }\n\n return {\n body: channelEvent.payload.body,\n translatedBody: channelEvent.payload.translatedBody,\n // @ts-ignore\n translation: channelEvent?.payload?.translation,\n }\n }\n\n const { translatedBody, translation, body } = getTranslations()\n const hasTranslation = !!translatedBody\n const isTranslated = useSelector(selectIsTranslated(channelEvent))\n\n return {\n // @ts-ignore\n body: hasTranslation && isTranslated ? translatedBody : body,\n hasTranslation,\n isTranslated: isTranslated && hasTranslation,\n locale: translation?.locale,\n }\n}\n\nexport function useTranslationsContainer() {\n const id = useSelector(({ translations }) => translations.containerId)\n const focusContainer = useElementFocusingById(id)\n return { id, focusContainer }\n}\n\nexport function useLocaleNativeName(userLocale: string) {\n const { languages } = useTranslations()\n\n return useMemo(\n () => languages?.find((lang) => lang.locale === userLocale)?.nativeName,\n [userLocale, languages],\n )\n}\n\nexport const useTranslationProposal = () => {\n const { isActive, languages } = useTranslations()\n\n const dispatch = useDispatch()\n const { sendAction } = useSeamlyCommands()\n\n const { translationProposal } = useSelector(\n (state: RootState) => state.translations,\n )\n const { enableTranslations } = useTranslations()\n const { isOpen } = useVisibility()\n const { userLocale } = useI18n()\n const proposedLocale = translationProposal?.proposedLocale\n const proposedLocaleNativeName = useLocaleNativeName(proposedLocale)\n\n const showProposal = useMemo(\n () =>\n translationProposal !== null &&\n !isActive &&\n isOpen &&\n userLocale !== proposedLocale &&\n languages.some((language) => language.locale === proposedLocale),\n [\n translationProposal,\n isActive,\n isOpen,\n userLocale,\n proposedLocale,\n languages,\n ],\n )\n\n const dismissTranslationProposal = () => {\n sendAction({\n type: actionTypes.dismiss,\n body: { type: TRANSLATION_PROPOSAL },\n })\n dispatch(disableTranslationProposalPrompt())\n }\n\n const activateTranslationProposal = () => {\n enableTranslations(translationProposal?.proposedLocale)\n }\n\n return {\n activateTranslationProposal,\n dismissTranslationProposal,\n proposedLocale,\n proposedLocaleNativeName,\n showProposal,\n translationProposal,\n }\n}\n","import { PayloadAction, createSlice, nanoid } from '@reduxjs/toolkit'\nimport { resetApp } from 'domains/app/actions'\nimport { initializeConfig } from 'domains/config/actions'\nimport { setLocale } from 'domains/i18n/actions'\nimport { addEvent, setHistory } from 'domains/store/slice'\nimport type { ChannelEvent, HistoryResponse } from 'domains/store/store.types'\nimport type { TranslationState } from 'domains/translations/translations.types'\n\nexport const translationsInitialState: TranslationState = {\n isActive: false,\n currentLocale: undefined,\n isAvailable: false,\n languages: [],\n containerId: nanoid(),\n translatedEventGroups: {},\n translationProposal: null,\n}\n\nconst getLastGroupId = (events: ChannelEvent[], id: string) => {\n const eventGroup = [...events].reduce<Record<string, string[]>>(\n (acc, { payload }, _index, arr) => {\n if (acc[id]) {\n // Splice to break early (make the reducer think we are done)\n // This is needed to avoid events of other groups from being added to the array.\n // @ts-ignore\n if (payload?.type === 'divider' && payload?.body?.translationEnabled) {\n arr.splice(0)\n return acc\n }\n\n acc[id].push(payload.id)\n }\n\n if (payload.id === id) acc[id] = []\n\n return acc\n },\n {},\n )\n\n const [[groupId, eventIds]] = Object.entries(eventGroup)\n\n const lastGroupId = events\n // @ts-ignore\n .filter((event) => event.payload?.type === 'divider')\n .map((event) => event.payload.id)\n .at(-1)\n\n return { lastGroupId, groupId, eventIds }\n}\n\nexport const translationSlice = createSlice({\n name: 'translation',\n initialState: translationsInitialState,\n reducers: {\n enableTranslation: (state, { payload }) => {\n state.isActive = true\n state.currentLocale = payload\n },\n disableTranslation: (state) => {\n state.isActive = false\n state.currentLocale = undefined\n },\n enableEventsTranslation: (\n state,\n {\n payload: { events, id },\n }: PayloadAction<{ events: ChannelEvent[]; id: string }>,\n ) => {\n delete state.translatedEventGroups[id]\n\n const { lastGroupId } = getLastGroupId(events, id)\n state.lastGroupId = lastGroupId\n },\n disableEventsTranslation: (\n state,\n {\n payload: { events, id },\n }: PayloadAction<{ events: ChannelEvent[]; id: string }>,\n ) => {\n const { lastGroupId, groupId, eventIds } = getLastGroupId(events, id)\n\n state.lastGroupId = lastGroupId\n state.translatedEventGroups[groupId] = eventIds\n },\n disableTranslationProposalPrompt: (state) => {\n state.translationProposal = null\n },\n setTranslationProposalPrompt: (\n state,\n { payload }: PayloadAction<HistoryResponse['translationProposal']>,\n ) => {\n state.translationProposal = payload\n },\n },\n extraReducers: (builder) => {\n builder\n .addCase(resetApp.pending, () => translationsInitialState)\n .addCase(initializeConfig.fulfilled, (state, { payload }) => {\n const feature = payload?.features?.translation\n if (!feature) return\n\n state.isAvailable = feature.enabled === true\n state.languages = [...feature.languages].sort((a, b) => {\n if (a.locale === payload.defaultUserLocale) return -1\n if (b.locale === payload.defaultUserLocale) return 1\n\n return a.nativeName.localeCompare(b.nativeName, undefined, {\n sensitivity: 'base',\n })\n })\n })\n .addCase(setHistory, (state, { payload }) => {\n state.translationProposal = payload.translationProposal\n })\n .addCase(setLocale.fulfilled, (state, { payload }) => {\n state.currentLocale = payload.userLocale\n })\n .addCase(addEvent, (state, { payload }) => {\n if (state.translatedEventGroups[state.lastGroupId]) {\n state.translatedEventGroups[state.lastGroupId].push(\n payload.payload.id,\n )\n }\n })\n },\n})\n\nexport const {\n enableTranslation,\n disableTranslation,\n enableEventsTranslation,\n disableEventsTranslation,\n setTranslationProposalPrompt,\n disableTranslationProposalPrompt,\n} = translationSlice.actions\n\nexport default translationSlice.reducer\n","import { createAsyncThunk } from '@reduxjs/toolkit'\nimport { selectUserHasResponded } from 'domains/app/selectors'\nimport * as ConfigSelectors from 'domains/config/selectors'\nimport { calculateVisibility } from 'domains/visibility/utils'\nimport { selectState } from 'ui/hooks/seamly-state-hooks'\nimport { StoreKey, visibilityStates } from './constants'\nimport * as Selectors from './selectors'\nimport type { VisibilityOptions } from 'config.types'\nimport type { ThunkAPI } from 'domains/redux/redux.types'\n\nconst validVisibilityStates = [\n visibilityStates.open,\n visibilityStates.minimized,\n visibilityStates.hidden,\n]\nexport const setVisibility = createAsyncThunk<\n VisibilityOptions,\n VisibilityOptions,\n ThunkAPI\n>(\n 'setVisibility',\n (requestedVisibility, { getState, extra: { api, eventBus } }) => {\n const state = getState()\n const previousVisibility = Selectors.selectVisibility(state)\n const userHasResponded = selectUserHasResponded(state)\n const hasConversation = api.hasConversation()\n const config = ConfigSelectors.selectConfig(state)\n\n const { visibilityCallback = calculateVisibility, layoutMode } = config\n const { unreadEvents: unreadMessageCount } = selectState(state)\n\n const calculatedVisibility = visibilityCallback({\n hasResponded: userHasResponded,\n previousVisibility,\n requestedVisibility,\n config,\n })\n if (!validVisibilityStates.includes(calculatedVisibility)) {\n console.error(\n 'The visibilityCallback function should return \"open\", \"minimized\" or \"hidden\".',\n )\n return undefined\n }\n if (previousVisibility === calculatedVisibility) {\n return undefined\n }\n\n const visibility = api.store.get(StoreKey) as object | undefined\n\n // Store the user-requested visibility in order to reinitialize after refresh\n api.store.set(StoreKey, {\n ...(visibility || {}),\n [layoutMode]: requestedVisibility,\n })\n if (requestedVisibility) {\n eventBus.emit('ui.visible', requestedVisibility, {\n visibility: requestedVisibility,\n hasConversation,\n hasResponded: userHasResponded,\n unreadMessageCount,\n })\n }\n\n return calculatedVisibility\n },\n)\n\nexport const initializeVisibility = createAsyncThunk<unknown, void, ThunkAPI>(\n 'initialize',\n async (_, { dispatch, getState, extra: { api } }) => {\n // initialize stored visibility\n const { layoutMode } = ConfigSelectors.selectConfig(getState())\n\n const storedVisibility =\n api.store.get(StoreKey)?.[layoutMode] || visibilityStates.initialize\n\n dispatch(setVisibility(storedVisibility))\n return storedVisibility\n },\n)\n","export const StoreKey = 'visibility'\n\nexport const visibilityStates = {\n hidden: 'hidden',\n minimized: 'minimized',\n open: 'open',\n initialize: null,\n} as const\n","import { RefObject, createRef } from 'preact'\nimport { useCallback, useEffect, useState } from 'preact/hooks'\nimport { useDispatch, useSelector } from 'react-redux'\nimport { useConfig } from 'domains/config/hooks'\nimport { useAppDispatch } from 'domains/store'\nimport { setVisibility } from 'domains/visibility/actions'\nimport { setShowInlineView } from 'domains/visibility/slice'\nimport { visibilityStates } from './constants'\nimport { selectShowInlineView, selectVisibility } from './selectors'\nimport type { VisibilityOptions } from 'config.types'\n\nexport const useVisibility = () => {\n const dispatch = useAppDispatch()\n const visible = useSelector(selectVisibility)\n const isVisible = visible ? visible !== visibilityStates.hidden : false\n const isOpen = visible === visibilityStates.open\n const isMinimized = visible === visibilityStates.minimized\n\n const dispatchVisibility = useCallback(\n (visibility: VisibilityOptions) => dispatch(setVisibility(visibility)),\n [dispatch],\n )\n\n const openChat = () => {\n dispatchVisibility(visibilityStates.open as VisibilityOptions)\n }\n\n const closeChat = () => {\n dispatchVisibility(visibilityStates.minimized as VisibilityOptions)\n }\n\n return {\n isVisible,\n isOpen,\n isMinimized,\n visible,\n setVisibility: dispatchVisibility,\n openChat,\n closeChat,\n }\n}\n\ntype UseIntersectOptions = {\n /** Stops observing when the root element is visible. */\n freezeOnceVisible?: boolean\n /** Determines if useIntersect is enabled. */\n enabled?: boolean\n /** The node ref to apply the intersection to */\n containerRef?: RefObject<any>\n}\n\n/**\n * Custom hook which enables initializing of IntersectionObserver on any node ref.\n */\nexport const useIntersect = ({\n freezeOnceVisible = false,\n enabled = true,\n containerRef = createRef(),\n}: UseIntersectOptions) => {\n const [entry, setEntry] = useState(null)\n const isVisible = !!entry?.isIntersecting || !enabled\n const frozen = isVisible && freezeOnceVisible\n\n const observerCallback = ([updatedEntry]) => setEntry(updatedEntry)\n\n useEffect(() => {\n const node = containerRef?.current\n const hasIOSupport = !!window.IntersectionObserver\n\n if (!node && process.env.NODE_ENV === 'development') {\n console.error(\n 'containerRef must be set on a DOM element. check the component where useIntersect is being used.',\n )\n }\n\n // Return an arrow function to have a consistent return value\n if (!hasIOSupport || frozen || !node || !enabled) return () => undefined\n\n const observerOptions = { threshold: 0, root: null, rootMargin: '0%' }\n const observer = new IntersectionObserver(observerCallback, observerOptions)\n\n observer.observe(node)\n\n return () => observer.disconnect()\n }, [containerRef, enabled, frozen])\n\n return { isVisible, containerRef }\n}\n\nexport const useShowInlineView = () => {\n const dispatch = useDispatch()\n const { connectWhenInView } = useConfig()\n const showInlineView = useSelector(selectShowInlineView)\n\n const { containerRef, isVisible } = useIntersect({\n enabled: connectWhenInView,\n freezeOnceVisible: true,\n })\n\n useEffect(() => {\n if (!isVisible) return\n\n dispatch(setShowInlineView())\n }, [dispatch, isVisible])\n\n return { containerRef, showInlineView }\n}\n","import { createSelector } from '@reduxjs/toolkit'\nimport type { RootState } from 'domains/store'\n\nexport const selectVisibility = createSelector(\n ({ visibility }: RootState) => visibility,\n (state) => state.visibility,\n)\n\nexport const selectShowInlineView = createSelector(\n ({ visibility }: RootState) => visibility,\n (state) => state.showInlineView,\n)\n","import { PayloadAction, createSlice } from '@reduxjs/toolkit'\nimport { initializeConfig } from 'domains/config/actions'\nimport { setVisibility } from 'domains/visibility/actions'\nimport { visibilityStates } from 'domains/visibility/constants'\nimport type { VisibilityOptions } from 'config.types'\nimport type { VisibilityState } from 'domains/visibility/visibility.types'\n\nconst initialState: VisibilityState = {\n visibility: visibilityStates.initialize,\n showInlineView: false,\n}\n\nexport const visibilitySlice = createSlice({\n name: 'visibility',\n initialState,\n reducers: {\n setShowInlineView: (state) => {\n state.showInlineView = true\n },\n },\n extraReducers: (builder) => {\n builder\n .addCase(\n setVisibility.fulfilled,\n (state, { payload: visibility }: PayloadAction<VisibilityOptions>) => {\n if (visibility) {\n state.visibility = visibility\n }\n },\n )\n .addCase(initializeConfig.fulfilled, (state, { payload }) => {\n // We only want to (always) show the inlineView when connectWhenInView is disabled\n if (!payload.connectWhenInView) {\n state.showInlineView = !payload.connectWhenInView\n }\n })\n },\n})\n\nexport const { setShowInlineView } = visibilitySlice.actions\n\nexport default visibilitySlice.reducer\n","import { Events } from 'minivents'\nimport { createContext } from 'preact'\nimport { API } from 'api'\n\nexport const SeamlyApiContext = createContext<API>(null)\n\nexport const SeamlyEventBusContext = createContext<Events>(null)\n","import { useCallback, useContext } from 'preact/hooks'\nimport { SeamlyApiContext } from 'ui/components/core/seamly-api-context'\n\nexport const useSeamlyApiContext = () => useContext(SeamlyApiContext)\n\nexport const useSeamlyObjectStore = () => {\n const api = useSeamlyApiContext()\n\n return api.store\n}\n\nexport const useSeamlyConversationUrl = () => {\n const { get } = useSeamlyObjectStore()\n\n if (get) {\n return get('conversationUrl')\n }\n return null\n}\n\nexport const useSeamlyHasConversation = () => {\n const api = useSeamlyApiContext()\n\n const hasConversation = useCallback(() => {\n return api.hasConversation()\n }, [api])\n\n return hasConversation\n}\n","import { createSelector } from '@reduxjs/toolkit'\nimport { useSelector } from 'react-redux'\nimport { selectUserHasResponded } from 'domains/app/selectors'\nimport { useConfig } from 'domains/config/hooks'\nimport * as ConfigSelectors from 'domains/config/selectors'\nimport { microsecondsToMilliseconds } from 'ui/utils/general-utils'\nimport type { RootState } from 'domains/store'\nimport type { ChannelEvent, ServiceDataEvent } from 'domains/store/store.types'\n\nexport const selectState = ({ state }: RootState) => state\nexport const useSeamlyStateContext = () => useSelector(selectState)\n\nexport const selectEventsWithSuggestion = createSelector(\n selectState,\n ConfigSelectors.selectConfig,\n selectUserHasResponded,\n ({ events, serviceData }, config, hasUserResponded) => {\n if (\n hasUserResponded ||\n config.layoutMode === 'inline' ||\n !serviceData?.suggestion ||\n !serviceData?.suggestion?.body.length\n ) {\n return events\n }\n\n const suggestionsEvent: ServiceDataEvent = {\n type: 'service_data',\n payload: serviceData.suggestion,\n }\n\n return [...events, suggestionsEvent]\n },\n)\n\nexport const selectEvents = createSelector(\n selectEventsWithSuggestion,\n ConfigSelectors.selectConfig,\n (events, config): ChannelEvent[] => {\n const { enabled, threshold } = config?.messages?.timeIndicator ?? {}\n if (!enabled) {\n return events\n }\n\n const mappedEvents = []\n let previousEvent = null\n events.forEach((event, idx) => {\n // always add timeIndicator to first message\n if (idx === 0) {\n mappedEvents.push({ ...event, timeIndicator: event.payload.occurredAt })\n // else check if diff is greater than threshold\n } else {\n const timeIndicator =\n previousEvent &&\n microsecondsToMilliseconds(\n event.payload.occurredAt - previousEvent.payload.occurredAt,\n ) >= threshold\n ? event.payload.occurredAt\n : undefined\n mappedEvents.push({ ...event, timeIndicator })\n }\n previousEvent = event\n })\n\n return mappedEvents\n },\n)\nexport const useEvents = () => useSelector(selectEvents)\n\nexport const selectEventIds = createSelector(selectEvents, (events) => {\n return events.map((event) => event.payload.id)\n})\n\nexport const useEventsIds = () => useSelector(selectEventIds)\n\nexport const useSeamlyIsLoading = () => useSeamlyStateContext().isLoading\n\nexport const useSeamlyHeaderData = () => useSeamlyStateContext().headerTitles\n\nexport const useSeamlyUnreadCount = () => useSeamlyStateContext().unreadEvents\n\nexport const useLoadedImageEventIds = () =>\n useSeamlyStateContext().loadedImageEventIds\n\nexport const useSkiplink = () => useSeamlyStateContext().skiplinkTargetId\n\nexport const useSeamlyParticipant = (participantId) =>\n useSeamlyStateContext().participantInfo.participants[participantId]\n\nexport const useSeamlyServiceInfo = () => useSeamlyStateContext().serviceInfo\n\nconst selectLastMessageEventId = createSelector(selectEvents, (events) => {\n const filteredEvents = events.filter((event) => event.type === 'message')\n return filteredEvents[filteredEvents.length - 1]?.payload.id\n})\nexport const useLastMessageEventId = () => useSelector(selectLastMessageEventId)\n\nexport const useSeamlyIsHistoryLoaded = () =>\n useSeamlyStateContext().historyLoaded\n\nexport const useSeamlyCurrentAgent = () => {\n const { participants, currentAgent } = useSeamlyStateContext().participantInfo\n\n return currentAgent ? participants[currentAgent] : null\n}\n\nexport const useSeamlyServiceData = (key) => {\n return useSeamlyStateContext().serviceData[key]\n}\n\nexport const useEntryTextLimit = () => {\n const {\n entryMeta: {\n options: { text },\n optionsOverride: { text: overrideText },\n },\n } = useSeamlyStateContext()\n\n const { limit } = overrideText || text || { limit: null }\n\n return {\n hasLimit: limit !== null,\n limit: limit !== null ? limit : null,\n }\n}\n\nexport const useSeamlyLayoutMode = () => {\n const { layoutMode } = useConfig()\n\n return {\n isInline: layoutMode === 'inline',\n isWindow: layoutMode === 'window',\n isApp: layoutMode === 'app',\n isResolving: !layoutMode,\n }\n}\n","export const eventTypes = {\n info: 'info',\n message: 'message',\n participant: 'participant',\n system: 'system',\n} as const\n\nexport const payloadTypes = {\n choicePrompt: 'choice_prompt',\n text: 'text',\n image: 'image',\n video: 'video',\n participant: 'participant',\n divider: 'divider',\n translation: 'translation',\n message: 'message',\n countdown: 'countdown',\n upload: 'upload',\n cta: 'cta',\n splash: 'splash',\n}\n\nexport const entryTypes = {\n text: 'text',\n upload: 'upload',\n}\n\nexport const readStates = {\n received: 'received',\n read: 'read',\n}\n\nexport const actionTypes = {\n pickChoice: 'pick_choice',\n navigate: 'navigate',\n custom: 'custom',\n typing: 'typing',\n read: 'read',\n detachService: 'detach_service',\n interactivityUpdate: 'interactivity_update',\n dismiss: 'dismiss',\n sendTranscript: 'send_transcript',\n setTopic: 'set_topic',\n setTranslation: 'set_translation',\n setContext: 'set_context',\n clickCta: 'click_cta',\n clickCard: 'click_card',\n}\n\nexport const TRANSLATION_PROPOSAL = 'translation_proposal'\n\nexport const dismissTypes = {\n resumeConversationPrompt: 'resume_conversation_prompt',\n translationProposal: TRANSLATION_PROPOSAL,\n} as const\n\nexport const sourceTypes = {\n translationProposal: TRANSLATION_PROPOSAL,\n translationChoice: 'translation_choice',\n windowApi: 'window_api',\n} as const\n\nexport const ariaLiveLevels = {\n assertive: 'assertive',\n polite: 'polite',\n}\n\nexport const dividerKeys = {\n new_topic: 'newTopic',\n new_translation: 'newTranslation',\n}\n\nexport const featureKeys = {\n sendTranscript: 'sendTranscript',\n typingPeekahead: 'typingPeekahead',\n uploads: 'uploads',\n}\n\nexport const cardTypes = {\n ask: 'ask',\n navigate: 'navigate',\n topic: 'topic',\n}\n","function parseOriginalErrMsg(str) {\n try {\n const json = JSON.parse(str)\n return json.error\n } catch (e) {\n return str\n }\n}\n\nexport default class SeamlyBaseError extends Error {\n action = ''\n\n langKey = ''\n\n constructor(originalError, ...params) {\n super(...params)\n\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, Object.getPrototypeOf(this))\n }\n this.originalError = originalError\n\n if (originalError?.payload) {\n this.originalEvent = originalError\n this.originalError = originalError.payload.error\n this.message = `Event of type ${originalError.payload.type} encountered`\n }\n if (!this.message && originalError?.message) {\n const parsedOriginalMessage = parseOriginalErrMsg(originalError.message)\n this.message = parsedOriginalMessage\n }\n\n if (originalError?.error) {\n this.originalError = originalError.error\n }\n }\n}\n","import SeamlyBaseError from './seamly-base-error'\n\nexport default class SeamlyConfigurationError extends SeamlyBaseError {\n constructor(originalError, ...params) {\n super(originalError, ...params)\n\n this.name = 'SeamlyConfigurationError'\n this.langKey = 'errors.configError'\n }\n}\n","import SeamlyBaseError from './seamly-base-error'\n\nexport default class SeamlyGeneralError extends SeamlyBaseError {\n constructor(originalError, ...params) {\n super(originalError, ...params)\n\n this.name = 'SeamlyGeneralError'\n this.langKey = 'errors.general'\n this.action = 'reset'\n }\n}\n","import SeamlyBaseError from './seamly-base-error'\n\nexport default class SeamlyOfflineError extends SeamlyBaseError {\n constructor(originalError, ...params) {\n super(originalError, ...params)\n\n this.name = 'SeamlyOfflineError'\n this.langKey = 'errors.seamlyOffline'\n }\n}\n","import SeamlyBaseError from './seamly-base-error'\n\nexport default class SeamlySessionExpiredError extends SeamlyBaseError {\n constructor(originalError, ...params) {\n super(originalError, ...params)\n\n this.name = 'SeamlySessionExpiredError'\n this.action = 'reset'\n }\n}\n","import SeamlyBaseError from './seamly-base-error'\n\nexport default class SeamlyUnauthorizedError extends SeamlyBaseError {\n constructor(originalError, ...params) {\n super(originalError, ...params)\n\n this.name = 'SeamlyUnauthorizedError'\n this.langKey = 'errors.general'\n this.action = 'reset'\n }\n}\n","import SeamlyBaseError from './seamly-base-error'\n\n/**\n * This error is used to alert the user that there's a problem with the connection\n * when initialising the application because of a connection issue on either the server\n * or the client side.\n */\nexport default class SeamlyUnavailableError extends SeamlyBaseError {\n constructor(originalError, ...params) {\n super(originalError, ...params)\n\n this.name = 'SeamlyUnavailableError'\n this.langKey = 'errors.seamlyUnavailable'\n }\n}\n","import { useSelector } from 'react-redux'\nimport { selectUserHasResponded } from 'domains/app/selectors'\n\nexport const useUserHasResponded = () => useSelector(selectUserHasResponded)\n","import { visibilityStates } from './constants'\n\nexport const calculateVisibility = ({\n hasResponded,\n previousVisibility,\n requestedVisibility,\n config,\n}) => {\n const { defaults, layoutMode, hideOnNoUserResponse } = config\n const { visible: defaultVisibility } = defaults || {}\n\n // The app layout should always be open by default.\n if (layoutMode === 'app' && !previousVisibility) {\n return visibilityStates.open\n }\n\n // Requesting open should override the responded check.\n if (\n layoutMode === 'window' &&\n hideOnNoUserResponse &&\n requestedVisibility !== visibilityStates.open\n ) {\n return hasResponded\n ? requestedVisibility || previousVisibility || visibilityStates.open\n : visibilityStates.hidden\n }\n\n // Allow users to continue a conversation (if they have responded and no visibility is requested)\n // when switching from the window layout to the inline layout\n if (layoutMode === 'inline' && hasResponded && !requestedVisibility) {\n return previousVisibility || visibilityStates.open\n }\n\n const baseVisibility = visibilityStates.minimized\n\n return (\n requestedVisibility ||\n previousVisibility ||\n defaultVisibility ||\n baseVisibility\n )\n}\n","import { CSS_NAME } from 'config'\n\n/**\n * Generate a className with all classes prefixed with the CSS_NAME\n *\n * @export\n * @param {*} names\n */\n\nexport const className = (...classes) =>\n classes\n .flat()\n .map((c) => {\n if (typeof c === 'object') {\n return Object.entries(c)\n .map(([key, value]) => (value ? key : ''))\n .join(' ')\n }\n return c\n })\n .filter((c) => typeof c === 'string')\n .map((c) => c.split(' '))\n .flat()\n .filter((c) => c.length)\n .map((c) => {\n // This rule makes sure the CSS_NAME is not added yet\n if (c.indexOf(CSS_NAME) > -1) {\n return c\n }\n return [CSS_NAME, c].join('-')\n })\n .join(' ')\n","if (process.env.NODE_ENV === 'development') {\n module.exports = require('debug')\n} else {\n // eslint-disable-next-line react/display-name\n module.exports = () => () => null\n}\n","export function randomId() {\n return `_${(\n Number(String(Math.random()).slice(2)) +\n Date.now() +\n Math.round(performance.now())\n ).toString(36)}`\n}\n","import { toChildArray } from 'preact'\nimport { useEffect, useMemo, useState } from 'preact/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { useTranslatedEventData } from 'domains/translations/hooks'\nimport { className } from 'lib/css'\nimport { randomId } from 'lib/id'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport Icon from 'ui/components/layout/icon'\nimport {\n useGeneratedId,\n useLastMessageEventId,\n useSeamlyCommands,\n useSeamlyServiceInfo,\n} from 'ui/hooks/seamly-hooks'\nimport { actionTypes } from 'ui/utils/seamly-utils'\n\nexport const useChoicePrompt = (event) => {\n const { payload } = event\n const [showOptions, setShowOptions] = useState(false)\n const { sendAction, addMessageBubble, addDivider } = useSeamlyCommands()\n const { activeServiceSessionId } = useSeamlyServiceInfo()\n const lastEventId = useLastMessageEventId()\n const { body } = useTranslatedEventData(event)\n const { service } = payload\n\n const subEvent = useMemo(() => {\n return {\n ...event,\n payload: {\n ...event.payload,\n body: event.payload.body?.prompt,\n translatedBody: event.payload.translatedBody && {\n ...event.payload.translatedBody,\n data: event.payload.translatedBody.prompt,\n },\n },\n }\n }, [event])\n\n const chooseAgain =\n body.chooseAgain &&\n activeServiceSessionId === service.serviceSessionId &&\n payload.id !== lastEventId\n\n useEffect(() => {\n setShowOptions(payload.id === lastEventId)\n }, [payload, lastEventId])\n\n const onChoiceClickHandler = (choice) => {\n const transactionId = randomId()\n\n if (chooseAgain) {\n addDivider('new_topic', transactionId)\n }\n addMessageBubble(choice.text, transactionId)\n sendAction({\n type: actionTypes.pickChoice,\n originMessage: payload.id,\n choice: {\n id: choice.id,\n text: choice.text,\n chooseAgain,\n },\n transactionId,\n })\n setShowOptions(false)\n }\n\n const onChooseAgainClickHandler = () => {\n setShowOptions((s) => !s)\n }\n\n return {\n body,\n subEvent,\n showOptions,\n chooseAgain,\n onChoiceClickHandler,\n onChooseAgainClickHandler,\n }\n}\n\nconst ChoicePrompt = ({ event, children, ...props }) => {\n const { t } = useI18n()\n const descriptorId = useGeneratedId()\n\n const {\n body,\n subEvent,\n showOptions,\n chooseAgain,\n onChoiceClickHandler,\n onChooseAgainClickHandler,\n } = useChoicePrompt(event)\n\n return (\n <>\n {toChildArray(children).map((child) => {\n child.props = {\n ...child.props,\n event: subEvent,\n descriptorId,\n showTranslationToggle: false,\n }\n return child\n })}\n {chooseAgain && (\n <button\n type=\"button\"\n className={className(\n 'button',\n 'button--secondary',\n 'button--choose-again',\n )}\n aria-expanded={showOptions ? 'true' : 'false'}\n onClick={onChooseAgainClickHandler}\n aria-describedby={descriptorId}\n >\n {showOptions\n ? t('message.choicePrompts.cancelChooseAgain')\n : t('message.choicePrompts.chooseAgain')}\n <Icon name=\"chevronDown\" size=\"8\" alt=\"\" />\n </button>\n )}\n {showOptions && (\n <MessageContainer\n type=\"choice-prompt\"\n showParticipant={false}\n event={event}\n {...props}\n >\n <ul className={className('choice-prompt', 'choice-prompt--many')}>\n {body.choices.map((choice) => (\n <li\n key={choice.id}\n className={className('choice-prompt__item', {\n [`choice-prompt__item--${choice.category}`]: choice.category,\n })}\n >\n <button\n type=\"button\"\n className={className('button', 'button--primary')}\n onClick={() => {\n onChoiceClickHandler(choice)\n }}\n >\n {choice.text}\n </button>\n </li>\n ))}\n </ul>\n </MessageContainer>\n )}\n </>\n )\n}\n\nexport default ChoicePrompt\n","import { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport { useSeamlyParticipant } from 'ui/hooks/seamly-hooks'\n\nconst EventParticipant = ({ eventPayload }) => {\n const { t } = useI18n()\n const { fromClient, participant: participantId } = eventPayload\n const participant = useSeamlyParticipant(participantId) || {}\n const { messages } = useConfig()\n\n const participantName = fromClient\n ? t('participants.user.name')\n : participant && participant.name\n const { showAvatar, showName } = messages[fromClient ? 'user' : 'agent'] || {}\n\n if (!showAvatar && !showName) {\n return null\n }\n\n const authorInfo = []\n\n if (showAvatar && participantName && participant.avatar) {\n authorInfo.push(\n <span className={className('message__avatar')}>\n <img src={participant.avatar} className={className('avatar')} alt=\"\" />\n </span>,\n )\n }\n\n if (showName && participantName) {\n authorInfo.push(\n <span className={className('message__author-name')}>\n {participantName}\n </span>,\n )\n }\n\n return (\n authorInfo.length > 0 && (\n <div className={className('message__author')}>{authorInfo}</div>\n )\n )\n}\n\nexport default EventParticipant\n","import { useTranslatedEventData } from 'domains/translations/hooks'\nimport { className } from 'lib/css'\nimport { useSeamlyMessageContainerClassNames } from 'ui/hooks/component-helper-hooks'\nimport EventParticipant from './event/event-participant'\n\nfunction MessageContainer({\n showParticipant = true,\n event,\n type,\n modifiers,\n children,\n bodyProps = {},\n info,\n ...props\n}) {\n const classNames = useSeamlyMessageContainerClassNames(event)\n\n const { hasTranslation, isTranslated, locale } = useTranslatedEventData(event)\n\n if (type) {\n classNames.push(`message--type-${type}`)\n }\n if (modifiers) {\n if (typeof modifiers === 'string') {\n // eslint-disable-next-line no-param-reassign\n modifiers = modifiers.split(' ').filter((v) => v.length)\n }\n modifiers.forEach((modifier) => {\n classNames.push(`message--${modifier}`)\n })\n }\n if (isTranslated) {\n classNames.push('message--is-translated')\n }\n if (hasTranslation) {\n classNames.push('message--has-translation')\n }\n\n if (isTranslated) {\n // eslint-disable-next-line no-param-reassign\n bodyProps = {\n ...bodyProps,\n lang: locale,\n }\n }\n\n return (\n <>\n <div className={className(classNames)} {...props}>\n {showParticipant && <EventParticipant eventPayload={event.payload} />}\n <div className={className('message__body')} {...bodyProps}>\n {children}\n </div>\n {info && (\n <div aria-hidden=\"true\" className={className('message__info')}>\n {info}\n </div>\n )}\n </div>\n </>\n )\n}\n\nexport default MessageContainer\n","import { createContext } from 'preact'\n\nconst SeamlyActivityEventContext = createContext(null)\n\nexport default SeamlyActivityEventContext\n","import { createContext } from 'preact'\n\nconst SeamlyFileUploadContext = createContext({})\n\nexport default SeamlyFileUploadContext\n","import { createContext } from 'preact'\n\nexport const SeamlyLiveRegionContext = createContext(null)\n","import { useConfig } from 'domains/config/hooks'\n\nexport const useSeamlyAppContainerClassNames = () => {\n return useConfig().appContainerClassNames\n}\n\nexport const useSeamlyMessageContainerClassNames = (event) => {\n const { fromClient } = event.payload\n const classNames = ['message']\n\n if (event.type === 'info') {\n classNames.push('message--source-info')\n } else if (!fromClient) {\n classNames.push('message--source-agent')\n } else {\n classNames.push('message--source-user')\n }\n\n return classNames\n}\n","import { useCallback, useRef } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { setSeamlyContainerElement } from 'domains/store/slice'\nimport {\n focusElement,\n runIfElementContainsOrHasFocus,\n} from 'ui/utils/general-utils'\nimport { useSeamlyStateContext, useSkiplink } from './seamly-state-hooks'\n\nexport const timeout = (ms = 0) =>\n new Promise((resolve) => {\n setTimeout(resolve, ms)\n })\n\nconst focusWithRaf = (el) => {\n requestAnimationFrame(async () => {\n await timeout(180) // wait for next 3 ticks\n const focusEl = typeof el === 'string' ? document.getElementById(el) : el\n focusElement(focusEl)\n })\n}\n\nexport const useSeamlyContainerElement = () => {\n const { seamlyContainerElement } = useSeamlyStateContext()\n\n const dispatch = useDispatch()\n\n const dispatchSeamlyContainerElement = useCallback(\n (element) => {\n dispatch(setSeamlyContainerElement(element))\n },\n [dispatch],\n )\n\n return [seamlyContainerElement, dispatchSeamlyContainerElement]\n}\n\nexport const useElementFocusingById = (elementId) =>\n useCallback(() => {\n focusWithRaf(elementId)\n }, [elementId])\n\nexport const useSkiplinkTargetFocusing = () => {\n const skiplinkTargetId = useSkiplink()\n return useElementFocusingById(skiplinkTargetId)\n}\n\nexport const useFocusIfSeamlyContainedFocus = () => {\n const containerElementRef = useRef(null)\n const [seamlyContainerElement] = useSeamlyContainerElement()\n\n containerElementRef.current = seamlyContainerElement\n\n return useCallback((elementToFocus) => {\n const focusFn = () => {\n focusWithRaf(elementToFocus)\n }\n\n runIfElementContainsOrHasFocus(containerElementRef.current, focusFn)\n }, [])\n}\n","import { useCallback, useContext } from 'preact/hooks'\nimport { SeamlyLiveRegionContext } from 'ui/components/core/seamly-live-region-context'\nimport { ariaLiveLevels } from 'ui/utils/seamly-utils'\n\nexport const useSeamlyLiveRegionContext = () =>\n useContext(SeamlyLiveRegionContext)\n\nexport const useLiveRegion = () => {\n const sendMessage = useSeamlyLiveRegionContext()\n const sendPolite = useCallback(\n (messageText) => {\n if (!messageText) return\n sendMessage({\n ariaLive: ariaLiveLevels.polite,\n messageText,\n })\n },\n [sendMessage],\n )\n const sendAssertive = useCallback(\n (messageText) => {\n if (!messageText) return\n sendMessage({\n ariaLive: ariaLiveLevels.assertive,\n messageText,\n })\n },\n [sendMessage],\n )\n\n return { sendPolite, sendAssertive }\n}\n","import { useCallback, useContext } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { clearAllUploads } from 'domains/store/slice'\nimport SeamlyFileUploadContext from 'ui/components/core/seamly-file-upload-context'\nimport { useSeamlyStateContext } from './seamly-state-hooks'\n\nconst useSeamlyFileUploadContext = () => useContext(SeamlyFileUploadContext)\n\nexport const useFileUploadMeta = () => {\n const {\n showFileUpload,\n entryMeta: { options, optionsOverride },\n options: {\n features: { uploads: uploadsFeature },\n },\n } = useSeamlyStateContext()\n\n const {\n allowedMimeTypes: allowedMimeTypesOverride,\n maxSize: maxSizeOverride,\n } = optionsOverride.upload || {}\n\n const { enabled: uploadsEnabled, enabledFromEntry: uploadsEnabledFromEntry } =\n uploadsFeature || {}\n\n const { allowedMimeTypes, maxSize } = {\n ...(options.upload || {\n allowedMimeTypes: [],\n maxSize: 0,\n }),\n ...(allowedMimeTypesOverride\n ? { allowedMimeTypes: allowedMimeTypesOverride }\n : {}),\n ...(maxSizeOverride ? { maxSize: maxSizeOverride } : {}),\n }\n\n return {\n showFileUpload,\n accountAllowsUploads: !!uploadsFeature,\n serviceAllowsUploads: uploadsEnabledFromEntry || uploadsEnabled,\n allowedMimeTypes,\n maxSize,\n }\n}\n\nexport const useFileUploads = () => {\n const { currentUploads } = useSeamlyStateContext()\n const dispatch = useDispatch()\n const upload = useSeamlyFileUploadContext()\n\n const uploadFile = useCallback(\n (file) => {\n upload(file)\n },\n [upload],\n )\n\n const clearUploads = useCallback(() => {\n dispatch(clearAllUploads())\n }, [dispatch])\n\n return {\n uploadFile,\n clearUploads,\n currentUploads,\n isUploading: currentUploads.some((file) => file.uploading),\n isComplete: currentUploads.every((file) => file.complete),\n }\n}\n","import { useCallback } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { useI18n } from 'domains/i18n/hooks'\nimport {\n hideOption as dispatchHideOption,\n showOption as dispatchShowOption,\n setUserSelectedOption as dispatchUserSelectedOption,\n setUserSelectedOptions as dispatchUserSelectedOptions,\n} from 'domains/store/slice'\nimport { useElementFocusingById } from 'ui/hooks/focus-helper-hooks'\nimport { useSeamlyObjectStore } from 'ui/hooks/seamly-api-hooks'\nimport { useSeamlyStateContext } from 'ui/hooks/seamly-state-hooks'\n\nexport const useSeamlyOptions = () => {\n const { t } = useI18n()\n const { options } = useSeamlyStateContext()\n\n const { panelActive, optionActive, userSelectedOptions, features } = options\n\n const { extraMenuItem, sendTranscript } = features\n\n const optionsObj = { extraMenuItem, sendTranscript }\n\n const menuTitle = (option) => {\n return option === 'extraMenuItem'\n ? 'Extra menu item'\n : t(`options.${option}.menuTitle`)\n }\n\n const menuOptions = Object.keys(optionsObj)\n .filter((key) => {\n return optionsObj[key]\n })\n .map((option) => ({\n name: option,\n title: menuTitle(option),\n available: optionsObj[option].enabled,\n }))\n\n const allowOptionSelection = extraMenuItem || sendTranscript\n\n const dispatch = useDispatch()\n const { get, set } = useSeamlyObjectStore()\n\n const initUserSelectedOptions = useCallback(() => {\n const storedOptions = get('options') || {}\n dispatch(dispatchUserSelectedOptions(storedOptions))\n }, [get, dispatch])\n\n const setUserSelectedOptions = useCallback(\n (optionValues) => {\n dispatch(dispatchUserSelectedOptions(optionValues))\n set('options', optionValues)\n },\n [set, dispatch],\n )\n\n const setUserSelectedOption = useCallback(\n (option, value) => {\n const storedOptions = get('options') || {}\n set('options', {\n ...storedOptions,\n [option]: value,\n })\n dispatch(dispatchUserSelectedOption({ option, value }))\n },\n [dispatch, get, set],\n )\n\n const showOption = (optionName) => {\n dispatch(dispatchShowOption(optionName))\n }\n\n const hideOption = () => {\n dispatch(dispatchHideOption())\n }\n\n return {\n allowOptionSelection,\n userSelectedOptions,\n features,\n menuOptions,\n initUserSelectedOptions,\n setUserSelectedOptions,\n setUserSelectedOption,\n showOption,\n hideOption,\n panelActive,\n optionActive,\n }\n}\n\nexport const useOptionButton = () => {\n const { optionsButtonId: id } = useSeamlyStateContext()\n const focusButton = useElementFocusingById(id)\n\n return { id, focusButton }\n}\n","import { useContext } from 'preact/hooks'\nimport SeamlyActivityEventContext from 'ui/components/core/seamly-activity-event-context'\n\nconst useSeamlyActivityEventHandler = () =>\n useContext(SeamlyActivityEventContext)\n\nexport default useSeamlyActivityEventHandler\n","import { useCallback, useContext } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { userParticipantId } from 'config'\nimport * as AppActions from 'domains/app/actions'\nimport { useUserHasResponded } from 'domains/app/hooks'\nimport { setHasResponded } from 'domains/app/slice'\nimport { setInterrupt } from 'domains/interrupt/slice'\nimport { addEvent, setInitialState } from 'domains/store/slice'\nimport { visibilityStates } from 'domains/visibility/constants'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { randomId } from 'lib/id'\nimport { SeamlyEventBusContext } from 'ui/components/core/seamly-api-context'\nimport { actionTypes } from 'ui/utils/seamly-utils'\nimport {\n useSeamlyApiContext,\n useSeamlyHasConversation,\n} from './seamly-api-hooks'\nimport { useSeamlyUnreadCount } from './seamly-state-hooks'\n\nconst useSeamlyCommands = () => {\n const api = useSeamlyApiContext()\n const dispatch = useDispatch()\n const eventBus = useContext(SeamlyEventBusContext)\n const userHasResponded = useUserHasResponded()\n const hasConversation = useSeamlyHasConversation()\n const { visible: visibility, setVisibility } = useVisibility()\n const unreadMessageCount = useSeamlyUnreadCount()\n\n const emitEvent = useCallback(\n (...args) => {\n eventBus.emit(...args)\n },\n [eventBus],\n )\n\n const start = useCallback(() => {\n emitEvent('ui.beforeStart', {\n visibility,\n hasConversation: hasConversation(),\n hasResponded: userHasResponded,\n unreadMessageCount,\n })\n\n api.send('start')\n emitEvent('ui.start', {\n visibility,\n hasConversation: hasConversation(),\n hasResponded: userHasResponded,\n unreadMessageCount,\n })\n }, [\n api,\n emitEvent,\n hasConversation,\n userHasResponded,\n unreadMessageCount,\n visibility,\n ])\n\n const reset = useCallback(async () => {\n dispatch(AppActions.resetApp())\n }, [dispatch])\n\n const getMessageBase = useCallback(\n (type) => ({\n type,\n id: randomId(),\n transactionId: randomId(),\n participant: userParticipantId,\n fromClient: true,\n occurredAt: Date.now() * 1000,\n meta: {},\n }),\n [],\n )\n\n const getTextMessageBase = useCallback(\n (bodyText) => {\n const base = getMessageBase('text')\n\n return {\n ...base,\n body: {\n text: bodyText,\n },\n }\n },\n [getMessageBase],\n )\n\n const sendMessage = useCallback(\n ({ body, config = {} }) => {\n if (body.trim() === '') {\n return\n }\n\n const message = {\n ...getTextMessageBase(body),\n ...config,\n }\n\n api.send('message', message)\n emitEvent('message', message)\n dispatch(\n addEvent({\n type: 'message',\n payload: {\n ...message,\n optimisticallyInjected: true,\n },\n }),\n )\n },\n [api, dispatch, emitEvent, getTextMessageBase],\n )\n\n const addMessageBubble = useCallback(\n (text, transactionId = randomId()) => {\n dispatch(\n addEvent({\n type: 'message',\n payload: { ...getTextMessageBase(text), transactionId },\n }),\n )\n },\n [dispatch, getTextMessageBase],\n )\n\n const addUploadBubble = useCallback(\n (id, transactionId, occurredAt, contentType, filename, filesize, url) => {\n dispatch(\n addEvent({\n type: 'message',\n payload: {\n type: 'upload',\n id,\n transactionId,\n participant: userParticipantId,\n fromClient: true,\n occurredAt,\n meta: {},\n body: { contentType, filename, filesize, url },\n },\n }),\n )\n },\n [dispatch],\n )\n\n const addDivider = useCallback(\n (subtype, transactionId = randomId()) => {\n const payload = {\n body: { subtype, type: 'divider' },\n fromClient: false,\n fromHistory: true,\n id: randomId(),\n transactionId,\n type: 'divider',\n }\n\n dispatch(addEvent({ type: 'info', payload }))\n },\n [dispatch],\n )\n\n const sendAction = useCallback(\n (body) => {\n if (!body) {\n return\n }\n\n api.send('action', body)\n\n const { type } = body\n if (type !== actionTypes.typing && type !== actionTypes.read) {\n emitEvent(`action.${type}`, body)\n }\n },\n [api, emitEvent],\n )\n\n const sendContext = useCallback(\n (context) => {\n api.sendContext(context)\n },\n [api],\n )\n\n const connect = useCallback(() => {\n if (api.connected) {\n return Promise.reject(new Error('The API is already connected'))\n }\n\n return api\n .connect()\n .then((initialState) => {\n if (initialState) {\n dispatch(setInitialState(initialState))\n if (initialState.userResponded) {\n dispatch(setHasResponded(initialState.userResponded))\n setVisibility(visibilityStates.open)\n }\n }\n })\n .catch((error) => {\n dispatch(\n setInterrupt({\n name: error?.name,\n message: error?.message,\n langKey: error?.langKey,\n action: error?.action,\n originalEvent: error?.originalEvent,\n originalError: error?.originalError,\n }),\n )\n })\n }, [api, dispatch, setVisibility])\n\n return {\n connect,\n start,\n sendMessage,\n sendAction,\n sendContext,\n reset,\n emitEvent,\n addMessageBubble,\n addUploadBubble,\n addDivider,\n apiConnected: api.connected,\n apiConfigReady: api.configReady,\n }\n}\n\nexport default useSeamlyCommands\n","import { useCallback, useRef } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { screenReaderDebounceDelaySeconds } from 'config'\nimport { useI18n } from 'domains/i18n/hooks'\nimport {\n clearIdleDetachCountdown,\n decrementIdleDetachCountdownCounter,\n initIdleDetachCountdown,\n stopIdleDetachCountdownCounter,\n} from 'domains/store/slice'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport {\n getTimeFromSeconds,\n millisecondsToSeconds,\n} from 'ui/utils/general-utils'\nimport { actionTypes } from 'ui/utils/seamly-utils'\nimport { useLiveRegion } from './live-region-hooks'\nimport { useSeamlyStateContext } from './seamly-state-hooks'\nimport useSeamlyCommands from './use-seamly-commands'\n\nconst useSeamlyIdleDetachCountdown = () => {\n const dispatch = useDispatch()\n\n const { idleDetachCountdown } = useSeamlyStateContext()\n\n const { isOpen: isSeamlyOpen } = useVisibility()\n\n const stableState = useRef({})\n\n stableState.current = {\n hasCountdown: idleDetachCountdown.hasCountdown,\n isActive: idleDetachCountdown.isActive,\n remaining: idleDetachCountdown.remaining,\n wasStopped: idleDetachCountdown.wasStopped,\n isOpen: isSeamlyOpen,\n }\n\n const { emitEvent, sendAction } = useSeamlyCommands()\n const { t } = useI18n()\n const { sendAssertive, sendPolite } = useLiveRegion()\n\n const sendAssertiveIfOpen = useCallback(\n (text) => {\n const { isOpen } = stableState.current\n if (isOpen) {\n sendAssertive(text)\n }\n },\n [sendAssertive],\n )\n\n const sendPoliteIfOpen = useCallback(\n (text) => {\n const { isOpen } = stableState.current\n if (isOpen) {\n sendPolite(text)\n }\n },\n [sendPolite],\n )\n\n const initCountdown = useCallback(\n (milliseconds) => {\n const delaySeconds = millisecondsToSeconds(milliseconds)\n const delayTime = getTimeFromSeconds(delaySeconds)\n\n dispatch(\n initIdleDetachCountdown({\n delaySeconds,\n delayTime,\n }),\n )\n emitEvent('idleTimer.start')\n sendAssertiveIfOpen(\n `${t('idleDetachWarning.countdownTitle')} ${t(\n 'idleDetachWarning.countdownText',\n )} ${t('idleDetachWarning.countdownTimer', delayTime)}`,\n )\n },\n [dispatch, emitEvent, sendAssertiveIfOpen, t],\n )\n\n const endCountdown = useCallback(\n (continueChat, isServerAction) => {\n const { hasCountdown, wasStopped } = stableState.current\n if (!hasCountdown) {\n return\n }\n\n if (!continueChat) {\n if (!isServerAction) {\n sendAction({ type: actionTypes.detachService })\n }\n sendAssertiveIfOpen(t('idleDetachWarning.notifyTransferText'))\n }\n\n if (!wasStopped) {\n emitEvent('idleTimer.stop')\n }\n\n dispatch(clearIdleDetachCountdown())\n },\n [dispatch, sendAction, emitEvent, sendAssertiveIfOpen, t],\n )\n\n const decrementCountdown = useCallback(() => {\n const { remaining } = stableState.current\n if (remaining <= 0) {\n return\n }\n\n const newRemaining = remaining - 1\n\n if (newRemaining % screenReaderDebounceDelaySeconds === 0) {\n sendAssertiveIfOpen(\n `${t('idleDetachWarning.countdownText')} ${t(\n 'idleDetachWarning.countdownTimer',\n getTimeFromSeconds(newRemaining),\n )}`,\n )\n }\n\n dispatch(decrementIdleDetachCountdownCounter())\n }, [dispatch, sendAssertiveIfOpen, t])\n\n const stopCountdown = useCallback(() => {\n const { isActive, remaining } = stableState.current\n if (!isActive) {\n return\n }\n\n dispatch(stopIdleDetachCountdownCounter())\n\n if (remaining) {\n emitEvent('idleTimer.stop')\n sendPoliteIfOpen(t('idleDetachWarning.srCountDownStoppedText'))\n }\n }, [dispatch, emitEvent, sendPoliteIfOpen, t])\n\n return {\n ...idleDetachCountdown,\n initCountdown,\n endCountdown,\n decrementCountdown,\n stopCountdown,\n }\n}\n\nexport default useSeamlyIdleDetachCountdown\n","import { useDispatch } from 'react-redux'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { clearResumeConversationPrompt } from 'domains/store/slice'\nimport { actionTypes, dismissTypes } from 'ui/utils/seamly-utils'\nimport { useLiveRegion } from './live-region-hooks'\nimport { useSeamlyStateContext } from './seamly-state-hooks'\nimport useSeamlyCommands from './use-seamly-commands'\n\nconst useSeamlyResumeConversationPrompt = () => {\n const dispatch = useDispatch()\n const hasPrompt = useSeamlyStateContext().resumeConversationPrompt\n const { sendAction } = useSeamlyCommands()\n const { t } = useI18n()\n const { sendAssertive } = useLiveRegion()\n\n const continueChat = () => {\n sendAction({\n type: actionTypes.dismiss,\n body: { type: dismissTypes.resumeConversationPrompt },\n })\n dispatch(clearResumeConversationPrompt())\n }\n\n const restartChat = () => {\n sendAssertive(t('resumeConversationPrompt.srNotifyRestartText'))\n sendAction({ type: actionTypes.detachService })\n dispatch(clearResumeConversationPrompt())\n }\n\n return { continueChat, hasPrompt, restartChat }\n}\n\nexport default useSeamlyResumeConversationPrompt\n","import {\n useCallback,\n useMemo,\n useReducer,\n useRef,\n useState,\n} from 'preact/hooks'\nimport { randomId } from 'lib/id'\n\nexport const useForceUpdate = () => {\n // This is an escape hatch mentioned in the React docs:\n // https://reactjs.org/docs/hooks-faq.html#is-there-something-like-forceupdate\n /* eslint-disable-next-line no-unused-vars */\n const [_, forceUpdate] = useReducer((x) => x + 1, 0)\n\n return useCallback(() => {\n setTimeout(() => {\n forceUpdate()\n })\n }, [])\n}\n\nexport const useGeneratedId = () => {\n const [id] = useState(() => randomId())\n return id\n}\n\nexport const useStableCallback = (callback) => {\n const callbackRef = useRef(null)\n callbackRef.current = callback\n const isFunction = typeof callback === 'function'\n return useMemo(() => {\n return isFunction ? (...args) => callbackRef.current(...args) : undefined\n }, [isFunction])\n}\n","export const debounce = (func, wait) => {\n let timeout\n return function (...args) {\n let isCancelled = false\n clearTimeout(timeout)\n timeout = setTimeout(() => {\n timeout = null\n if (!isCancelled) {\n func.apply(this, args)\n }\n isCancelled = false\n }, wait)\n\n return (runInstant) => {\n isCancelled = true\n if (runInstant) {\n func.apply(this, args)\n }\n }\n }\n}\n\nexport const elementMatch = (el, match) => {\n if (el.matches) {\n el.matches(match)\n } else if (el.msMatchesSelector) {\n return el.msMatchesSelector(match)\n } else if (el.webkitMatchesSelector) {\n return el.webkitMatchesSelector(match)\n }\n return false\n}\n\nexport const closestElement = (el, match) => {\n if (el.closest) {\n return el.closest(match)\n }\n\n let foundElement = el\n\n do {\n if (elementMatch(foundElement, match)) {\n break\n }\n foundElement = foundElement.parentElement || foundElement.parentNode\n } while (foundElement !== null && foundElement.nodeType === 1)\n\n return foundElement !== null && foundElement.nodeType === 1\n ? foundElement\n : null\n}\n\nexport const createAriaHider = () => {\n const originalValues = []\n const rootNodes = []\n document.querySelectorAll('body > *:not([role=\"dialog\"])').forEach((node) => {\n const attr = node.getAttribute('aria-hidden')\n const alreadyHidden = attr !== null && attr !== 'false'\n if (alreadyHidden) {\n return\n }\n originalValues.push(attr)\n rootNodes.push(node)\n node.setAttribute('aria-hidden', 'true')\n })\n\n return () => {\n rootNodes.forEach((node, index) => {\n const originalValue = originalValues[index]\n if (originalValue === null) {\n node.removeAttribute('aria-hidden')\n } else {\n node.setAttribute('aria-hidden', originalValue)\n }\n })\n }\n}\n\nexport const propIsTrue = (prop) => prop === 'true' || prop === true\n\nexport const millisecondsToSeconds = (milliseconds) => {\n return Math.ceil(milliseconds / 1000)\n}\n\nexport const microsecondsToMilliseconds = (microseconds) => {\n return Math.ceil(microseconds / 1000)\n}\n\nexport const getTimeFromSeconds = (seconds) => {\n const minutes = Math.floor(seconds / 60)\n const secondsPartial = seconds - minutes * 60\n\n return { minutes, seconds: secondsPartial }\n}\n\nexport const formatBytes = (bytes, decimals = 2) => {\n if (bytes === 0) return '0 Bytes'\n\n const k = 1024\n const dm = decimals < 0 ? 0 : decimals\n const sizes = ['Bytes', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB']\n\n const i = Math.floor(Math.log(bytes) / Math.log(k))\n\n return `${parseFloat((bytes / k ** i).toFixed(dm))} ${sizes[i]}`\n}\n\nexport const keyCodes = {\n 27: 'Escape',\n 35: 'End',\n 36: 'Home',\n 37: 'ArrowLeft',\n 38: 'ArrowUp',\n 39: 'ArrowRight',\n 40: 'ArrowDown',\n}\n\nexport const keyNames = {\n Escape: 'Escape',\n End: 'End',\n Home: 'Home',\n ArrowLeft: 'ArrowLeft',\n ArrowUp: 'ArrowUp',\n ArrowRight: 'ArrowRight',\n ArrowDown: 'ArrowDown',\n}\n\nexport const getKey = (e) => (e.code ? keyNames[e.code] : keyCodes[e.keyCode])\n\nexport const focusElement = (el) => {\n if (el) {\n el.focus()\n }\n}\n\nexport const runIfElementContainsOrHasFocus = (el, callback) => {\n if (\n el &&\n (el.contains(document.activeElement) || el === document.activeElement)\n ) {\n callback()\n }\n}\n\n// Compare two dates to decide which relative date to return\nexport const getRelativeDate = (date, currentDate) => {\n const msMidnightToday = new Date(currentDate).setHours(0, 0, 0, 0)\n const msDate = date.getTime()\n const dayInMs = 86400000\n if (msDate >= msMidnightToday + dayInMs) {\n // Future date\n return date\n } else if (msDate > msMidnightToday) {\n // Today\n return 'today'\n } else if (msDate > msMidnightToday - dayInMs) {\n // Yesterday\n return 'yesterday'\n } else {\n // Older date\n return date\n }\n}\n\nexport const pick = (obj, keys) =>\n keys.reduce((accum, key) => {\n if (key in obj) accum[key] = obj[key]\n return accum\n }, {})\n\nexport const omit = (obj, keys) =>\n Object.keys(obj).reduce((accum, key) => {\n if (!keys.includes(key)) accum[key] = obj[key]\n return accum\n }, {})\n","import{Component as n,createElement as t,options as e,toChildArray as r,Fragment as u,render as o,hydrate as i,createContext as l,createRef as c,cloneElement as f}from\"preact\";export{Component,Fragment,createContext,createElement,createRef}from\"preact\";import{useState as a,useId as s,useReducer as h,useEffect as v,useLayoutEffect as d,useRef as p,useImperativeHandle as m,useMemo as y,useCallback as _,useContext as b,useDebugValue as S}from\"preact/hooks\";export*from\"preact/hooks\";function g(n,t){for(var e in t)n[e]=t[e];return n}function C(n,t){for(var e in n)if(\"__source\"!==e&&!(e in t))return!0;for(var r in t)if(\"__source\"!==r&&n[r]!==t[r])return!0;return!1}function E(n){this.props=n}function w(n,e){function r(n){var t=this.props.ref,r=t==n.ref;return!r&&t&&(t.call?t(null):t.current=null),e?!e(this.props,n)||!r:C(this.props,n)}function u(e){return this.shouldComponentUpdate=r,t(n,e)}return u.displayName=\"Memo(\"+(n.displayName||n.name)+\")\",u.prototype.isReactComponent=!0,u.__f=!0,u}(E.prototype=new n).isPureReactComponent=!0,E.prototype.shouldComponentUpdate=function(n,t){return C(this.props,n)||C(this.state,t)};var x=e.__b;e.__b=function(n){n.type&&n.type.__f&&n.ref&&(n.props.ref=n.ref,n.ref=null),x&&x(n)};var R=\"undefined\"!=typeof Symbol&&Symbol.for&&Symbol.for(\"react.forward_ref\")||3911;function N(n){function t(t){var e=g({},t);return delete e.ref,n(e,t.ref||null)}return t.$$typeof=R,t.render=t,t.prototype.isReactComponent=t.__f=!0,t.displayName=\"ForwardRef(\"+(n.displayName||n.name)+\")\",t}var k=function(n,t){return null==n?null:r(r(n).map(t))},A={map:k,forEach:k,count:function(n){return n?r(n).length:0},only:function(n){var t=r(n);if(1!==t.length)throw\"Children.only\";return t[0]},toArray:r},O=e.__e;e.__e=function(n,t,e,r){if(n.then)for(var u,o=t;o=o.__;)if((u=o.__c)&&u.__c)return null==t.__e&&(t.__e=e.__e,t.__k=e.__k),u.__c(n,t);O(n,t,e,r)};var T=e.unmount;function F(n,t,e){return n&&(n.__c&&n.__c.__H&&(n.__c.__H.__.forEach(function(n){\"function\"==typeof n.__c&&n.__c()}),n.__c.__H=null),null!=(n=g({},n)).__c&&(n.__c.__P===e&&(n.__c.__P=t),n.__c=null),n.__k=n.__k&&n.__k.map(function(n){return F(n,t,e)})),n}function I(n,t,e){return n&&e&&(n.__v=null,n.__k=n.__k&&n.__k.map(function(n){return I(n,t,e)}),n.__c&&n.__c.__P===t&&(n.__e&&e.appendChild(n.__e),n.__c.__e=!0,n.__c.__P=e)),n}function L(){this.__u=0,this.t=null,this.__b=null}function U(n){var t=n.__.__c;return t&&t.__a&&t.__a(n)}function D(n){var e,r,u;function o(o){if(e||(e=n()).then(function(n){r=n.default||n},function(n){u=n}),u)throw u;if(!r)throw e;return t(r,o)}return o.displayName=\"Lazy\",o.__f=!0,o}function M(){this.u=null,this.o=null}e.unmount=function(n){var t=n.__c;t&&t.__R&&t.__R(),t&&32&n.__u&&(n.type=null),T&&T(n)},(L.prototype=new n).__c=function(n,t){var e=t.__c,r=this;null==r.t&&(r.t=[]),r.t.push(e);var u=U(r.__v),o=!1,i=function(){o||(o=!0,e.__R=null,u?u(l):l())};e.__R=i;var l=function(){if(!--r.__u){if(r.state.__a){var n=r.state.__a;r.__v.__k[0]=I(n,n.__c.__P,n.__c.__O)}var t;for(r.setState({__a:r.__b=null});t=r.t.pop();)t.forceUpdate()}};r.__u++||32&t.__u||r.setState({__a:r.__b=r.__v.__k[0]}),n.then(i,i)},L.prototype.componentWillUnmount=function(){this.t=[]},L.prototype.render=function(n,e){if(this.__b){if(this.__v.__k){var r=document.createElement(\"div\"),o=this.__v.__k[0].__c;this.__v.__k[0]=F(this.__b,r,o.__O=o.__P)}this.__b=null}var i=e.__a&&t(u,null,n.fallback);return i&&(i.__u&=-33),[t(u,null,e.__a?null:n.children),i]};var V=function(n,t,e){if(++e[1]===e[0]&&n.o.delete(t),n.props.revealOrder&&(\"t\"!==n.props.revealOrder[0]||!n.o.size))for(e=n.u;e;){for(;e.length>3;)e.pop()();if(e[1]<e[0])break;n.u=e=e[2]}};function W(n){return this.getChildContext=function(){return n.context},n.children}function P(n){var e=this,r=n.i;e.componentWillUnmount=function(){o(null,e.l),e.l=null,e.i=null},e.i&&e.i!==r&&e.componentWillUnmount(),e.l||(e.i=r,e.l={nodeType:1,parentNode:r,childNodes:[],appendChild:function(n){this.childNodes.push(n),e.i.appendChild(n)},insertBefore:function(n,t){this.childNodes.push(n),e.i.appendChild(n)},removeChild:function(n){this.childNodes.splice(this.childNodes.indexOf(n)>>>1,1),e.i.removeChild(n)}}),o(t(W,{context:e.context},n.__v),e.l)}function j(n,e){var r=t(P,{__v:n,i:e});return r.containerInfo=e,r}(M.prototype=new n).__a=function(n){var t=this,e=U(t.__v),r=t.o.get(n);return r[0]++,function(u){var o=function(){t.props.revealOrder?(r.push(u),V(t,n,r)):u()};e?e(o):o()}},M.prototype.render=function(n){this.u=null,this.o=new Map;var t=r(n.children);n.revealOrder&&\"b\"===n.revealOrder[0]&&t.reverse();for(var e=t.length;e--;)this.o.set(t[e],this.u=[1,0,this.u]);return n.children},M.prototype.componentDidUpdate=M.prototype.componentDidMount=function(){var n=this;this.o.forEach(function(t,e){V(n,e,t)})};var z=\"undefined\"!=typeof Symbol&&Symbol.for&&Symbol.for(\"react.element\")||60103,B=/^(?:accent|alignment|arabic|baseline|cap|clip(?!PathU)|color|dominant|fill|flood|font|glyph(?!R)|horiz|image(!S)|letter|lighting|marker(?!H|W|U)|overline|paint|pointer|shape|stop|strikethrough|stroke|text(?!L)|transform|underline|unicode|units|v|vector|vert|word|writing|x(?!C))[A-Z]/,H=/^on(Ani|Tra|Tou|BeforeInp|Compo)/,Z=/[A-Z0-9]/g,Y=\"undefined\"!=typeof document,$=function(n){return(\"undefined\"!=typeof Symbol&&\"symbol\"==typeof Symbol()?/fil|che|rad/:/fil|che|ra/).test(n)};function q(n,t,e){return null==t.__k&&(t.textContent=\"\"),o(n,t),\"function\"==typeof e&&e(),n?n.__c:null}function G(n,t,e){return i(n,t),\"function\"==typeof e&&e(),n?n.__c:null}n.prototype.isReactComponent={},[\"componentWillMount\",\"componentWillReceiveProps\",\"componentWillUpdate\"].forEach(function(t){Object.defineProperty(n.prototype,t,{configurable:!0,get:function(){return this[\"UNSAFE_\"+t]},set:function(n){Object.defineProperty(this,t,{configurable:!0,writable:!0,value:n})}})});var J=e.event;function K(){}function Q(){return this.cancelBubble}function X(){return this.defaultPrevented}e.event=function(n){return J&&(n=J(n)),n.persist=K,n.isPropagationStopped=Q,n.isDefaultPrevented=X,n.nativeEvent=n};var nn,tn={enumerable:!1,configurable:!0,get:function(){return this.class}},en=e.vnode;e.vnode=function(n){\"string\"==typeof n.type&&function(n){var t=n.props,e=n.type,u={};for(var o in t){var i=t[o];if(!(\"value\"===o&&\"defaultValue\"in t&&null==i||Y&&\"children\"===o&&\"noscript\"===e||\"class\"===o||\"className\"===o)){var l=o.toLowerCase();\"defaultValue\"===o&&\"value\"in t&&null==t.value?o=\"value\":\"download\"===o&&!0===i?i=\"\":\"ondoubleclick\"===l?o=\"ondblclick\":\"onchange\"!==l||\"input\"!==e&&\"textarea\"!==e||$(t.type)?\"onfocus\"===l?o=\"onfocusin\":\"onblur\"===l?o=\"onfocusout\":H.test(o)?o=l:-1===e.indexOf(\"-\")&&B.test(o)?o=o.replace(Z,\"-$&\").toLowerCase():null===i&&(i=void 0):l=o=\"oninput\",\"oninput\"===l&&u[o=l]&&(o=\"oninputCapture\"),u[o]=i}}\"select\"==e&&u.multiple&&Array.isArray(u.value)&&(u.value=r(t.children).forEach(function(n){n.props.selected=-1!=u.value.indexOf(n.props.value)})),\"select\"==e&&null!=u.defaultValue&&(u.value=r(t.children).forEach(function(n){n.props.selected=u.multiple?-1!=u.defaultValue.indexOf(n.props.value):u.defaultValue==n.props.value})),t.class&&!t.className?(u.class=t.class,Object.defineProperty(u,\"className\",tn)):(t.className&&!t.class||t.class&&t.className)&&(u.class=u.className=t.className),n.props=u}(n),n.$$typeof=z,en&&en(n)};var rn=e.__r;e.__r=function(n){rn&&rn(n),nn=n.__c};var un=e.diffed;e.diffed=function(n){un&&un(n);var t=n.props,e=n.__e;null!=e&&\"textarea\"===n.type&&\"value\"in t&&t.value!==e.value&&(e.value=null==t.value?\"\":t.value),nn=null};var on={ReactCurrentDispatcher:{current:{readContext:function(n){return nn.__n[n.__c].props.value}}}},ln=\"17.0.2\";function cn(n){return t.bind(null,n)}function fn(n){return!!n&&n.$$typeof===z}function an(n){return fn(n)&&n.type===u}function sn(n){return fn(n)?f.apply(null,arguments):n}function hn(n){return!!n.__k&&(o(null,n),!0)}function vn(n){return n&&(n.base||1===n.nodeType&&n)||null}var dn=function(n,t){return n(t)},pn=function(n,t){return n(t)},mn=u;function yn(n){n()}function _n(n){return n}function bn(){return[!1,yn]}var Sn=d,gn=fn;function Cn(n,t){var e=t(),r=a({h:{__:e,v:t}}),u=r[0].h,o=r[1];return d(function(){u.__=e,u.v=t,En(u)&&o({h:u})},[n,e,t]),v(function(){return En(u)&&o({h:u}),n(function(){En(u)&&o({h:u})})},[n]),e}function En(n){var t,e,r=n.v,u=n.__;try{var o=r();return!((t=u)===(e=o)&&(0!==t||1/t==1/e)||t!=t&&e!=e)}catch(n){return!0}}var wn={useState:a,useId:s,useReducer:h,useEffect:v,useLayoutEffect:d,useInsertionEffect:Sn,useTransition:bn,useDeferredValue:_n,useSyncExternalStore:Cn,startTransition:yn,useRef:p,useImperativeHandle:m,useMemo:y,useCallback:_,useContext:b,useDebugValue:S,version:\"17.0.2\",Children:A,render:q,hydrate:G,unmountComponentAtNode:hn,createPortal:j,createElement:t,createContext:l,createFactory:cn,cloneElement:sn,createRef:c,Fragment:u,isValidElement:fn,isElement:gn,isFragment:an,findDOMNode:vn,Component:n,PureComponent:E,memo:w,forwardRef:N,flushSync:pn,unstable_batchedUpdates:dn,StrictMode:mn,Suspense:L,SuspenseList:M,lazy:D,__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED:on};export{A as Children,E as PureComponent,mn as StrictMode,L as Suspense,M as SuspenseList,on as __SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED,sn as cloneElement,cn as createFactory,j as createPortal,wn as default,vn as findDOMNode,pn as flushSync,N as forwardRef,G as hydrate,gn as isElement,an as isFragment,fn as isValidElement,D as lazy,w as memo,q as render,yn as startTransition,hn as unmountComponentAtNode,dn as unstable_batchedUpdates,_n as useDeferredValue,Sn as useInsertionEffect,Cn as useSyncExternalStore,bn as useTransition,ln as version};\n//# sourceMappingURL=compat.module.js.map\n","/* eslint-disable import/no-webpack-loader-syntax */\n// The eslint rules are disabled for this as otherwsise we'd need to include the loader rule in all implementations\n// this can again be changed when we can import pre-built packages in implementations\nimport iconAvatar32 from '!!raw-loader!../../../../icons/avatar_bot-32.svg'\nimport iconArrowLeft16 from '!!raw-loader!../../../../icons/icon_arrow_left-16.svg'\nimport iconArrowRight16 from '!!raw-loader!../../../../icons/icon_arrow_right-16.svg'\nimport iconBalloon32 from '!!raw-loader!../../../../icons/icon_balloon-32.svg'\nimport iconCheck16 from '!!raw-loader!../../../../icons/icon_check-16.svg'\nimport iconCheck32 from '!!raw-loader!../../../../icons/icon_check-32.svg'\nimport iconChevronDown32 from '!!raw-loader!../../../../icons/icon_chevron_down-32.svg'\nimport iconChevronDown8 from '!!raw-loader!../../../../icons/icon_chevron_down-8.svg'\nimport iconChevronRight16 from '!!raw-loader!../../../../icons/icon_chevron_right-16.svg'\nimport iconChevronRight8 from '!!raw-loader!../../../../icons/icon_chevron_right-8.svg'\nimport iconClose16 from '!!raw-loader!../../../../icons/icon_close-16.svg'\nimport iconClose8 from '!!raw-loader!../../../../icons/icon_close-8.svg'\nimport iconDownload16 from '!!raw-loader!../../../../icons/icon_download-16.svg'\nimport iconEnlarge32 from '!!raw-loader!../../../../icons/icon_enlarge-32.svg'\nimport iconError16 from '!!raw-loader!../../../../icons/icon_error-16.svg'\nimport iconFile32 from '!!raw-loader!../../../../icons/icon_file-32.svg'\nimport iconNewTopic32 from '!!raw-loader!../../../../icons/icon_newtopic-32.svg'\nimport iconNewTranslation16 from '!!raw-loader!../../../../icons/icon_newtranslation-16.svg'\nimport iconNewTranslation32 from '!!raw-loader!../../../../icons/icon_newtranslation-32.svg'\nimport iconOptions32 from '!!raw-loader!../../../../icons/icon_options-32.svg'\nimport iconSend32 from '!!raw-loader!../../../../icons/icon_send-32.svg'\nimport iconUpload32 from '!!raw-loader!../../../../icons/icon_upload-32.svg'\nimport { className as classNameFn } from 'lib/css'\n\n/* eslint-enable import/no-webpack-loader-syntax */\n\nexport const ICONS = {\n send: {\n 32: iconSend32,\n },\n balloon: {\n 32: iconBalloon32,\n },\n newTopic: {\n 32: iconNewTopic32,\n },\n newTranslation: {\n 16: iconNewTranslation16,\n 32: iconNewTranslation32,\n },\n avatar: {\n 32: iconAvatar32,\n },\n chevronDown: {\n 8: iconChevronDown8,\n 32: iconChevronDown32,\n },\n chevronRight: {\n 8: iconChevronRight8,\n 16: iconChevronRight16,\n },\n close: {\n 8: iconClose8,\n 16: iconClose16,\n },\n enlarge: {\n 32: iconEnlarge32,\n },\n options: {\n 32: iconOptions32,\n },\n file: {\n 32: iconFile32,\n },\n upload: {\n 32: iconUpload32,\n },\n download: {\n 16: iconDownload16,\n },\n error: {\n 16: iconError16,\n },\n arrowLeft: {\n 16: iconArrowLeft16,\n },\n arrowRight: {\n 16: iconArrowRight16,\n },\n check: {\n 16: iconCheck16,\n 32: iconCheck32,\n },\n} as const\n\nexport type IconProps = {\n name: keyof typeof ICONS\n size?: '8' | '16' | '32'\n className?: string\n alt: string\n}\n\nconst Icon = ({ name, size = '32', className, alt }: IconProps) => (\n <>\n <div\n aria-hidden=\"true\"\n className={className || classNameFn('icon')}\n dangerouslySetInnerHTML={{ __html: ICONS[name][size] }}\n />\n {alt && <span className={classNameFn('visually-hidden')}>{alt}</span>}\n </>\n)\n\nexport default Icon\n","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"32px\\\" height=\\\"32px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 32 32\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M6.714,14.985l17.837-7.906c0.681-0.302,1.414,0.301,1.25,1.027L22.273,23.59\\tc-0.13,0.566-0.751,0.865-1.275,0.613l-3.623-1.752l-2.334,2.287c-0.572,0.562-1.538,0.156-1.538-0.645V21.01\\tc0-0.217,0.078-0.43,0.222-0.594l7.676-8.841l-10.414,7.472l-4.351-2.445C5.987,16.236,6.033,15.287,6.714,14.985L6.714,14.985z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"32px\\\" height=\\\"32px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 32 32\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M24,10.824v10.375c0,1.104-0.896,2-2,2h-4.694l-4.931,3.625v-3.625H10c-1.104,0-2-0.896-2-2V10.824\\tc0-1.104,0.896-2,2-2h12C23.104,8.824,24,9.719,24,10.824z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"32px\\\" height=\\\"32px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 32 32\\\"><path fill=\\\"#4A48C1\\\" d=\\\"M16,8.593l2.407,4.573l5.093,0.876l-3.604,3.702l0.74,5.115L16,20.574l-4.634,2.285l0.739-5.115L8.5,14.042\\tl5.094-0.876L16,8.593z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 16 16\\\"><path fill=\\\"#4A48C1\\\" d=\\\"M8,0C3.6,0,0,3.6,0,8s3.6,8,8,8s8-3.6,8-8S12.4,0,8,0z M14.1,7.1h-1.4c-0.1-1.5-0.4-2.9-1-4\\tC13,4,13.9,5.4,14.1,7.1z M7.1,2.1v5H5C5.2,4.7,6.1,2.9,7.1,2.1z M7.1,8.9v5c-1-0.7-1.9-2.5-2.1-5H7.1z M8.9,13.9v-5H11\\tC10.8,11.3,9.9,13.2,8.9,13.9z M8.9,7.1v-5c1,0.7,1.9,2.5,2.1,5H8.9z M4.2,3.1c-0.5,1.1-0.9,2.5-1,4H1.9C2.1,5.4,3,4,4.2,3.1z M1.9,8.9h1.4c0.1,1.5,0.4,2.9,1,4C3,12,2.1,10.5,1.9,8.9z M11.8,12.9c0.5-1.1,0.9-2.5,1-4h1.4C13.9,10.5,13,12,11.8,12.9z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 32 32\\\"><path fill=\\\"#4A48C1\\\" d=\\\"M16,7c-4.9,0-9,4.1-9,9s4.1,9,9,9s9-4.1,9-9S20.9,7,16,7z M22.9,15h-1.6c-0.1-1.7-0.5-3.3-1.1-4.5\\tC21.6,11.5,22.6,13.1,22.9,15z M15,9.4V15h-2.3C12.9,12.3,13.9,10.2,15,9.4z M15,17v5.6c-1.1-0.8-2.1-2.9-2.3-5.6H15z M17,22.6V17\\th2.3C19.1,19.8,18.1,21.8,17,22.6z M17,15V9.4c1.1,0.8,2.1,2.9,2.3,5.6H17z M11.8,10.4c-0.6,1.3-1,2.8-1.1,4.5H9.1\\tC9.4,13.1,10.4,11.5,11.8,10.4z M9.1,17h1.6c0.1,1.7,0.5,3.3,1.1,4.5C10.4,20.5,9.4,18.9,9.1,17z M20.2,21.5c0.6-1.3,1-2.8,1.1-4.5\\th1.6C22.6,18.8,21.6,20.5,20.2,21.5z\\\"/></svg>\";","export default \"<svg version=\\\"1.1\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" xmlns:xlink=\\\"http://www.w3.org/1999/xlink\\\" x=\\\"0px\\\" y=\\\"0px\\\"\\n\\t viewBox=\\\"0 0 32 32\\\" enable-background=\\\"new 0 0 32 32\\\" xml:space=\\\"preserve\\\">\\n<path fill=\\\"#4A48C1\\\" d=\\\"M10,14.8c-1.1,0-2-0.9-2-2s0.9-2,2-2s2,0.9,2,2S11.1,14.8,10,14.8z M15.9,14.8c1.1,0,2-0.9,2-2s-0.9-2-2-2\\n\\ts-2,0.9-2,2S14.8,14.8,15.9,14.8z M21.8,10.8c-1.1,0-2,0.9-2,2s0.9,2,2,2s2-0.9,2-2S22.9,10.8,21.8,10.8z M21.3,18.1H10.7\\n\\tC11.7,23.9,20.2,23.9,21.3,18.1z\\\"/>\\n</svg>\\n\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"8px\\\" height=\\\"8px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 8 8\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M-0.001,2.876c0-0.247,0.091-0.494,0.273-0.688c0.38-0.401,1.013-0.418,1.414-0.039l1.938,1.834\\tc0.199,0.188,0.547,0.188,0.746,0L6.31,2.15c0.401-0.379,1.034-0.362,1.414,0.04c0.379,0.401,0.361,1.034-0.04,1.414L5.745,5.437\\tC4.782,6.35,3.213,6.35,2.249,5.436L0.311,3.603C0.103,3.406-0.001,3.142-0.001,2.876z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"32px\\\" height=\\\"32px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 32 32\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M16,20.425c-0.782,0-1.563-0.291-2.159-0.874l-6.541-6.408c-0.395-0.387-0.401-1.02-0.015-1.414\\tc0.387-0.394,1.021-0.4,1.414-0.015l6.541,6.408c0.42,0.409,1.102,0.409,1.52-0.001l6.541-6.407c0.396-0.386,1.028-0.38,1.414,0.015\\tc0.387,0.395,0.381,1.027-0.014,1.414l-6.541,6.407C17.563,20.133,16.782,20.425,16,20.425z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"8px\\\" height=\\\"8px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 8 8\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M2.875,7.998c-0.247,0-0.494-0.091-0.688-0.273c-0.401-0.38-0.418-1.013-0.039-1.414l1.834-1.938\\tc0.188-0.199,0.188-0.547,0-0.746l-1.835-1.94c-0.379-0.401-0.362-1.034,0.04-1.414s1.034-0.361,1.414,0.04l1.834,1.939\\tc0.913,0.963,0.913,2.532-0.001,3.496L3.601,7.686C3.405,7.894,3.14,7.998,2.875,7.998z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"16px\\\" height=\\\"16px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 16 16\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M6.5,13c-0.247,0-0.494-0.091-0.687-0.273c-0.401-0.38-0.419-1.013-0.04-1.414L8.22,8.727\\tc0.373-0.394,0.373-1.06,0-1.454L5.773,4.687c-0.379-0.401-0.362-1.034,0.04-1.414c0.4-0.378,1.034-0.362,1.414,0.04l2.446,2.586\\tc1.096,1.159,1.096,3.043,0,4.203l-2.446,2.586C7.03,12.896,6.765,13,6.5,13z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"8px\\\" height=\\\"8px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 8 8\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M7.705,7.729C7.511,7.923,7.255,8.02,7,8.02c-0.257,0-0.514-0.099-0.709-0.295L4,5.423L1.709,7.725\\tC1.513,7.921,1.257,8.02,1,8.02c-0.255,0-0.51-0.097-0.706-0.291c-0.391-0.39-0.393-1.022-0.003-1.414l2.298-2.309l-2.27-2.28\\tC-0.07,1.334-0.068,0.701,0.323,0.311c0.392-0.389,1.024-0.387,1.415,0.003L4,2.587l2.263-2.274C6.653-0.077,7.287-0.079,7.677,0.31\\tC8.068,0.7,8.07,1.333,7.681,1.725l-2.27,2.281l2.298,2.309C8.099,6.705,8.097,7.339,7.705,7.729z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"16px\\\" height=\\\"16px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 16 16\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M12.709,11.295L9.411,7.982l3.262-3.276c0.39-0.392,0.388-1.024-0.004-1.414\\tc-0.39-0.39-1.023-0.388-1.414,0.003L8,6.564L4.746,3.295C4.357,2.904,3.724,2.903,3.332,3.292C2.94,3.682,2.939,4.315,3.329,4.707\\tl3.261,3.275l-3.298,3.313c-0.39,0.391-0.388,1.024,0.003,1.414C3.49,12.903,3.745,13,4,13c0.257,0,0.513-0.099,0.708-0.295L8,9.399\\tl3.291,3.306C11.486,12.901,11.743,13,12,13c0.255,0,0.511-0.097,0.705-0.291C13.097,12.319,13.099,11.686,12.709,11.295z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"32px\\\" height=\\\"32px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 32 32\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M24,9v6.5c0,0.552-0.447,1-1,1s-1-0.448-1-1v-4.086L11.414,22H15.5c0.552,0,1,0.447,1,1s-0.448,1-1,1H9\\tc-0.13,0-0.26-0.026-0.382-0.077c-0.245-0.102-0.439-0.296-0.541-0.541C8.026,23.26,8,23.13,8,23v-6.5c0-0.552,0.448-1,1-1\\ts1,0.448,1,1v4.085L20.586,10H16.5c-0.552,0-1-0.448-1-1s0.448-1,1-1H23c0.13,0,0.26,0.026,0.382,0.077\\tc0.245,0.102,0.439,0.296,0.541,0.541C23.974,8.74,24,8.87,24,9z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"32px\\\" height=\\\"32px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 32 32\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M26.1,21.383c0.334-0.625,0.602-1.279,0.812-1.949L32,18.609V13.51l-5.058-0.846\\tc-0.208-0.67-0.468-1.325-0.795-1.956l3.009-4.145l-3.604-3.634L21.38,5.903c-0.626-0.333-1.276-0.602-1.948-0.81L18.609,0\\tl-5.098,0.001l-0.847,5.061c-0.669,0.203-1.326,0.465-1.957,0.794L6.562,2.847L2.929,6.449l2.973,4.171\\tC5.569,11.247,5.3,11.9,5.091,12.569L0,13.373v5.099l5.06,0.866c0.204,0.669,0.467,1.324,0.796,1.955l-3.009,4.146l3.601,3.635\\tl4.171-2.975c0.627,0.335,1.282,0.603,1.951,0.811L13.372,32h5.118l0.849-5.057c0.668-0.207,1.323-0.469,1.953-0.795l4.144,3.01\\tl3.639-3.604L26.1,21.383z M19.01,19.035c-1.675,1.663-4.381,1.652-6.041-0.025c-1.662-1.675-1.649-4.381,0.024-6.042\\tc1.676-1.661,4.382-1.648,6.043,0.025C20.699,14.67,20.686,17.377,19.01,19.035z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" xml:space=\\\"preserve\\\" x=\\\"0px\\\" y=\\\"0px\\\" version=\\\"1.1\\\" viewBox=\\\"0 0 32 32\\\"><path fill=\\\"#4A48C1\\\" d=\\\"M16,28.5c-3.6,0-6.5-3-6.5-6.6V9.6c0-0.6,0.4-1,1-1s1,0.4,1,1v12.3c0,2.5,2,4.6,4.5,4.6\\tc2.5,0,4.5-2.1,4.5-4.6V8.3c0-1.5-1.2-2.8-2.7-2.8c-1.5,0-2.7,1.3-2.7,2.8v13.5c0,0.6,0.5,1.1,1,1.1c0.6,0,1-0.5,1-1.1v-10\\tc0-0.6,0.4-1,1-1s1,0.4,1,1v10c0,1.7-1.4,3.1-3,3.1s-3-1.4-3-3.1V8.3c0-2.6,2.1-4.8,4.7-4.8c2.6,0,4.7,2.2,4.7,4.8v13.6\\tC22.5,25.5,19.6,28.5,16,28.5z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"32px\\\" height=\\\"32px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 32 32\\\"><defs/><path fill=\\\"#4A48C1\\\" d=\\\"M9.488,13.481c-0.391-0.391-0.391-1.023,0-1.414l5.805-5.805c0.026-0.026,0.06-0.036,0.088-0.058\\tc0.073-0.06,0.146-0.119,0.235-0.156c0.246-0.103,0.522-0.103,0.769,0c0.093,0.039,0.171,0.101,0.249,0.165\\tc0.023,0.02,0.053,0.027,0.074,0.049l5.805,5.805c0.391,0.391,0.391,1.023,0,1.414c-0.195,0.195-0.451,0.293-0.707,0.293\\ts-0.512-0.098-0.707-0.293L17,9.383V20.33c0,0.553-0.447,1-1,1c-0.552,0-1-0.447-1-1V9.383l-4.098,4.098\\tC10.512,13.872,9.879,13.872,9.488,13.481z M22.819,24.031H9.181c-0.552,0-1,0.447-1,1s0.448,1,1,1h13.639c0.553,0,1-0.447,1-1\\tS23.372,24.031,22.819,24.031z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"16px\\\" height=\\\"16px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 16 16\\\"><defs/><path fill=\\\"#FFF\\\" d=\\\"M3.175,7.726c-0.413-0.367-0.45-0.999-0.083-1.412c0.367-0.413,0.999-0.45,1.412-0.083L7,8.45V1.5\\tc0-0.552,0.448-1,1-1c0.553,0,1,0.448,1,1v6.95l2.496-2.219c0.412-0.367,1.044-0.331,1.411,0.083\\tc0.367,0.413,0.33,1.045-0.083,1.412l-4.16,3.698c-0.047,0.041-0.103,0.062-0.154,0.094c-0.047,0.028-0.089,0.064-0.141,0.085\\tC8.25,11.649,8.125,11.677,8,11.677c-0.126,0-0.25-0.027-0.369-0.074c-0.05-0.021-0.09-0.055-0.136-0.083\\tc-0.053-0.031-0.111-0.053-0.159-0.096L3.175,7.726z M12.018,13.5H3.983c-0.552,0-1,0.447-1,1s0.448,1,1,1h8.035\\tc0.553,0,1-0.447,1-1S12.57,13.5,12.018,13.5z\\\"/></svg>\";","export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" width=\\\"16px\\\" height=\\\"16px\\\" x=\\\"0px\\\" y=\\\"0px\\\" viewBox=\\\"0 0 16 16\\\"><defs/><path fill=\\\"#ad001f\\\" d=\\\"M15.744,13.104L9.097,1.47c-0.604-1.055-1.59-1.055-2.193,0L0.256,13.104\\tc-0.604,1.056-0.102,1.919,1.113,1.919H14.63C15.847,15.022,16.348,14.159,15.744,13.104z M7,5.045c0-0.552,0.448-1,1-1s1,0.448,1,1\\tv3.656c0,0.552-0.448,1-1,1s-1-0.448-1-1V5.045z M8,13.212c-0.748,0-1.354-0.607-1.354-1.354c0-0.748,0.606-1.354,1.354-1.354\\ts1.354,0.606,1.354,1.354C9.354,12.604,8.748,13.212,8,13.212z\\\"/></svg>\";","export default \"<?xml version=\\\"1.0\\\" encoding=\\\"utf-8\\\"?>\\n<!-- Generator: Adobe Illustrator 25.2.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->\\n<svg version=\\\"1.1\\\" id=\\\"Layer_1\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" xmlns:xlink=\\\"http://www.w3.org/1999/xlink\\\" x=\\\"0px\\\" y=\\\"0px\\\"\\n\\t viewBox=\\\"0 0 16 16\\\" enable-background=\\\"new 0 0 16 16\\\" xml:space=\\\"preserve\\\">\\n<path fill=\\\"#5053A4\\\" d=\\\"M13.6,8c0,0.6-0.4,1-1,1h-7l2.2,2.5c0.4,0.4,0.3,1-0.1,1.4c-0.2,0.2-0.4,0.2-0.7,0.2c-0.3,0-0.6-0.1-0.8-0.3\\n\\tL2.6,8.6c0,0-0.1-0.1-0.1-0.2c0,0-0.1-0.1-0.1-0.1c0-0.1-0.1-0.2-0.1-0.3c0,0,0,0,0,0c0,0,0,0,0,0c0-0.1,0-0.3,0.1-0.4\\n\\tc0,0,0.1-0.1,0.1-0.1c0-0.1,0.1-0.1,0.1-0.2l3.7-4.1c0.4-0.4,1-0.4,1.4-0.1c0.4,0.4,0.4,1,0.1,1.4L5.6,7h7C13.2,7,13.6,7.4,13.6,8z\\\"\\n\\t/>\\n</svg>\\n\";","export default \"<?xml version=\\\"1.0\\\" encoding=\\\"utf-8\\\"?>\\n<!-- Generator: Adobe Illustrator 25.2.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->\\n<svg version=\\\"1.1\\\" id=\\\"Layer_1\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\" xmlns:xlink=\\\"http://www.w3.org/1999/xlink\\\" x=\\\"0px\\\" y=\\\"0px\\\"\\n\\t viewBox=\\\"0 0 16 16\\\" enable-background=\\\"new 0 0 16 16\\\" xml:space=\\\"preserve\\\">\\n<path fill=\\\"#5053A4\\\" d=\\\"M2.4,8.1c0-0.6,0.4-1,1-1h7L8.1,4.5c-0.4-0.4-0.3-1,0.1-1.4c0.2-0.2,0.4-0.2,0.7-0.2c0.3,0,0.6,0.1,0.8,0.3\\n\\tl3.7,4.2c0,0,0.1,0.1,0.1,0.2c0,0,0.1,0.1,0.1,0.1c0,0.1,0.1,0.2,0.1,0.3c0,0,0,0,0,0c0,0,0,0,0,0c0,0.1,0,0.3-0.1,0.4\\n\\tc0,0-0.1,0.1-0.1,0.1c0,0.1-0.1,0.1-0.1,0.2l-3.7,4.1c-0.4,0.4-1,0.4-1.4,0.1c-0.4-0.4-0.4-1-0.1-1.4l2.2-2.4h-7\\n\\tC2.8,9.1,2.4,8.6,2.4,8.1z\\\"/>\\n</svg>\\n\";","export default \"<svg\\n xmlns=\\\"http://www.w3.org/2000/svg\\\"\\n width=\\\"16px\\\"\\n height=\\\"16px\\\"\\n x=\\\"0px\\\"\\n y=\\\"0px\\\"\\n viewBox=\\\"0 0 16 16\\\"\\n>\\n <path\\n fill=\\\"currentColor\\\"\\n d=\\\"M11.6,4.3l-5,5L4.9,7.5C4.4,7,3.7,7,3.2,7.5l0,0C2.8,8,2.8,8.7,3.2,9.2l1.7,1.7l0,0l0.8,0.8\\n\\tc0.5,0.5,1.2,0.5,1.7,0l0.8-0.8l5-5c0.5-0.5,0.5-1.2,0-1.7l0,0C12.8,3.8,12.1,3.8,11.6,4.3z\\\"\\n />\\n</svg>\\n\";","export default \"<svg\\n xmlns=\\\"http://www.w3.org/2000/svg\\\"\\n width=\\\"32px\\\"\\n height=\\\"32px\\\"\\n x=\\\"0px\\\"\\n y=\\\"0px\\\"\\n viewBox=\\\"0 0 32 32\\\"\\n>\\n <path\\n fill=\\\"currentColor\\\"\\n d=\\\"M22.9,9.3l-9.3,9.3l-3.2-3.2c-0.9-0.9-2.3-0.9-3.2,0l0,0c-0.9,0.9-0.9,2.3,0,3.2l3.2,3.2l0,0l1.6,1.6\\n\\tc0.9,0.9,2.3,0.9,3.2,0l1.6-1.6l9.3-9.3c0.9-0.9,0.9-2.3,0-3.2l0,0C25.2,8.4,23.7,8.4,22.9,9.3z\\\"\\n />\\n</svg>\\n\";","/**\n * @license React\n * use-sync-external-store-with-selector.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var g=require(\"react\");function n(a,b){return a===b&&(0!==a||1/a===1/b)||a!==a&&b!==b}var p=\"function\"===typeof Object.is?Object.is:n,q=g.useSyncExternalStore,r=g.useRef,t=g.useEffect,u=g.useMemo,v=g.useDebugValue;\nexports.useSyncExternalStoreWithSelector=function(a,b,e,l,h){var c=r(null);if(null===c.current){var f={hasValue:!1,value:null};c.current=f}else f=c.current;c=u(function(){function a(a){if(!c){c=!0;d=a;a=l(a);if(void 0!==h&&f.hasValue){var b=f.value;if(h(b,a))return k=b}return k=a}b=k;if(p(d,a))return b;var e=l(a);if(void 0!==h&&h(b,e))return b;d=a;return k=e}var c=!1,d,k,m=void 0===e?null:e;return[function(){return a(b())},null===m?void 0:function(){return a(m())}]},[b,e,l,h]);var d=q(a,c[0],c[1]);\nt(function(){f.hasValue=!0;f.value=d},[d]);v(d);return d};\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/use-sync-external-store-with-selector.production.min.js');\n} else {\n module.exports = require('./cjs/use-sync-external-store-with-selector.development.js');\n}\n","module.exports = require(\"preact\");","module.exports = require(\"preact/compat\");","module.exports = require(\"preact/hooks\");","module.exports = require(\"preact/jsx-runtime\");","// src/utils/env.ts\nvar NOTHING = Symbol.for(\"immer-nothing\");\nvar DRAFTABLE = Symbol.for(\"immer-draftable\");\nvar DRAFT_STATE = Symbol.for(\"immer-state\");\n\n// src/utils/errors.ts\nvar errors = process.env.NODE_ENV !== \"production\" ? [\n // All error codes, starting by 0:\n function(plugin) {\n return `The plugin for '${plugin}' has not been loaded into Immer. To enable the plugin, import and call \\`enable${plugin}()\\` when initializing your application.`;\n },\n function(thing) {\n return `produce can only be called on things that are draftable: plain objects, arrays, Map, Set or classes that are marked with '[immerable]: true'. Got '${thing}'`;\n },\n \"This object has been frozen and should not be mutated\",\n function(data) {\n return \"Cannot use a proxy that has been revoked. Did you pass an object from inside an immer function to an async process? \" + data;\n },\n \"An immer producer returned a new value *and* modified its draft. Either return a new value *or* modify the draft.\",\n \"Immer forbids circular references\",\n \"The first or second argument to `produce` must be a function\",\n \"The third argument to `produce` must be a function or undefined\",\n \"First argument to `createDraft` must be a plain object, an array, or an immerable object\",\n \"First argument to `finishDraft` must be a draft returned by `createDraft`\",\n function(thing) {\n return `'current' expects a draft, got: ${thing}`;\n },\n \"Object.defineProperty() cannot be used on an Immer draft\",\n \"Object.setPrototypeOf() cannot be used on an Immer draft\",\n \"Immer only supports deleting array indices\",\n \"Immer only supports setting array indices and the 'length' property\",\n function(thing) {\n return `'original' expects a draft, got: ${thing}`;\n }\n // Note: if more errors are added, the errorOffset in Patches.ts should be increased\n // See Patches.ts for additional errors\n] : [];\nfunction die(error, ...args) {\n if (process.env.NODE_ENV !== \"production\") {\n const e = errors[error];\n const msg = typeof e === \"function\" ? e.apply(null, args) : e;\n throw new Error(`[Immer] ${msg}`);\n }\n throw new Error(\n `[Immer] minified error nr: ${error}. Full error at: https://bit.ly/3cXEKWf`\n );\n}\n\n// src/utils/common.ts\nvar getPrototypeOf = Object.getPrototypeOf;\nfunction isDraft(value) {\n return !!value && !!value[DRAFT_STATE];\n}\nfunction isDraftable(value) {\n if (!value)\n return false;\n return isPlainObject(value) || Array.isArray(value) || !!value[DRAFTABLE] || !!value.constructor?.[DRAFTABLE] || isMap(value) || isSet(value);\n}\nvar objectCtorString = Object.prototype.constructor.toString();\nfunction isPlainObject(value) {\n if (!value || typeof value !== \"object\")\n return false;\n const proto = getPrototypeOf(value);\n if (proto === null) {\n return true;\n }\n const Ctor = Object.hasOwnProperty.call(proto, \"constructor\") && proto.constructor;\n if (Ctor === Object)\n return true;\n return typeof Ctor == \"function\" && Function.toString.call(Ctor) === objectCtorString;\n}\nfunction original(value) {\n if (!isDraft(value))\n die(15, value);\n return value[DRAFT_STATE].base_;\n}\nfunction each(obj, iter) {\n if (getArchtype(obj) === 0 /* Object */) {\n Object.entries(obj).forEach(([key, value]) => {\n iter(key, value, obj);\n });\n } else {\n obj.forEach((entry, index) => iter(index, entry, obj));\n }\n}\nfunction getArchtype(thing) {\n const state = thing[DRAFT_STATE];\n return state ? state.type_ : Array.isArray(thing) ? 1 /* Array */ : isMap(thing) ? 2 /* Map */ : isSet(thing) ? 3 /* Set */ : 0 /* Object */;\n}\nfunction has(thing, prop) {\n return getArchtype(thing) === 2 /* Map */ ? thing.has(prop) : Object.prototype.hasOwnProperty.call(thing, prop);\n}\nfunction get(thing, prop) {\n return getArchtype(thing) === 2 /* Map */ ? thing.get(prop) : thing[prop];\n}\nfunction set(thing, propOrOldValue, value) {\n const t = getArchtype(thing);\n if (t === 2 /* Map */)\n thing.set(propOrOldValue, value);\n else if (t === 3 /* Set */) {\n thing.add(value);\n } else\n thing[propOrOldValue] = value;\n}\nfunction is(x, y) {\n if (x === y) {\n return x !== 0 || 1 / x === 1 / y;\n } else {\n return x !== x && y !== y;\n }\n}\nfunction isMap(target) {\n return target instanceof Map;\n}\nfunction isSet(target) {\n return target instanceof Set;\n}\nfunction latest(state) {\n return state.copy_ || state.base_;\n}\nfunction shallowCopy(base, strict) {\n if (isMap(base)) {\n return new Map(base);\n }\n if (isSet(base)) {\n return new Set(base);\n }\n if (Array.isArray(base))\n return Array.prototype.slice.call(base);\n if (!strict && isPlainObject(base)) {\n if (!getPrototypeOf(base)) {\n const obj = /* @__PURE__ */ Object.create(null);\n return Object.assign(obj, base);\n }\n return { ...base };\n }\n const descriptors = Object.getOwnPropertyDescriptors(base);\n delete descriptors[DRAFT_STATE];\n let keys = Reflect.ownKeys(descriptors);\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i];\n const desc = descriptors[key];\n if (desc.writable === false) {\n desc.writable = true;\n desc.configurable = true;\n }\n if (desc.get || desc.set)\n descriptors[key] = {\n configurable: true,\n writable: true,\n // could live with !!desc.set as well here...\n enumerable: desc.enumerable,\n value: base[key]\n };\n }\n return Object.create(getPrototypeOf(base), descriptors);\n}\nfunction freeze(obj, deep = false) {\n if (isFrozen(obj) || isDraft(obj) || !isDraftable(obj))\n return obj;\n if (getArchtype(obj) > 1) {\n obj.set = obj.add = obj.clear = obj.delete = dontMutateFrozenCollections;\n }\n Object.freeze(obj);\n if (deep)\n each(obj, (_key, value) => freeze(value, true), true);\n return obj;\n}\nfunction dontMutateFrozenCollections() {\n die(2);\n}\nfunction isFrozen(obj) {\n return Object.isFrozen(obj);\n}\n\n// src/utils/plugins.ts\nvar plugins = {};\nfunction getPlugin(pluginKey) {\n const plugin = plugins[pluginKey];\n if (!plugin) {\n die(0, pluginKey);\n }\n return plugin;\n}\nfunction loadPlugin(pluginKey, implementation) {\n if (!plugins[pluginKey])\n plugins[pluginKey] = implementation;\n}\n\n// src/core/scope.ts\nvar currentScope;\nfunction getCurrentScope() {\n return currentScope;\n}\nfunction createScope(parent_, immer_) {\n return {\n drafts_: [],\n parent_,\n immer_,\n // Whenever the modified draft contains a draft from another scope, we\n // need to prevent auto-freezing so the unowned draft can be finalized.\n canAutoFreeze_: true,\n unfinalizedDrafts_: 0\n };\n}\nfunction usePatchesInScope(scope, patchListener) {\n if (patchListener) {\n getPlugin(\"Patches\");\n scope.patches_ = [];\n scope.inversePatches_ = [];\n scope.patchListener_ = patchListener;\n }\n}\nfunction revokeScope(scope) {\n leaveScope(scope);\n scope.drafts_.forEach(revokeDraft);\n scope.drafts_ = null;\n}\nfunction leaveScope(scope) {\n if (scope === currentScope) {\n currentScope = scope.parent_;\n }\n}\nfunction enterScope(immer2) {\n return currentScope = createScope(currentScope, immer2);\n}\nfunction revokeDraft(draft) {\n const state = draft[DRAFT_STATE];\n if (state.type_ === 0 /* Object */ || state.type_ === 1 /* Array */)\n state.revoke_();\n else\n state.revoked_ = true;\n}\n\n// src/core/finalize.ts\nfunction processResult(result, scope) {\n scope.unfinalizedDrafts_ = scope.drafts_.length;\n const baseDraft = scope.drafts_[0];\n const isReplaced = result !== void 0 && result !== baseDraft;\n if (isReplaced) {\n if (baseDraft[DRAFT_STATE].modified_) {\n revokeScope(scope);\n die(4);\n }\n if (isDraftable(result)) {\n result = finalize(scope, result);\n if (!scope.parent_)\n maybeFreeze(scope, result);\n }\n if (scope.patches_) {\n getPlugin(\"Patches\").generateReplacementPatches_(\n baseDraft[DRAFT_STATE].base_,\n result,\n scope.patches_,\n scope.inversePatches_\n );\n }\n } else {\n result = finalize(scope, baseDraft, []);\n }\n revokeScope(scope);\n if (scope.patches_) {\n scope.patchListener_(scope.patches_, scope.inversePatches_);\n }\n return result !== NOTHING ? result : void 0;\n}\nfunction finalize(rootScope, value, path) {\n if (isFrozen(value))\n return value;\n const state = value[DRAFT_STATE];\n if (!state) {\n each(\n value,\n (key, childValue) => finalizeProperty(rootScope, state, value, key, childValue, path),\n true\n // See #590, don't recurse into non-enumerable of non drafted objects\n );\n return value;\n }\n if (state.scope_ !== rootScope)\n return value;\n if (!state.modified_) {\n maybeFreeze(rootScope, state.base_, true);\n return state.base_;\n }\n if (!state.finalized_) {\n state.finalized_ = true;\n state.scope_.unfinalizedDrafts_--;\n const result = state.copy_;\n let resultEach = result;\n let isSet2 = false;\n if (state.type_ === 3 /* Set */) {\n resultEach = new Set(result);\n result.clear();\n isSet2 = true;\n }\n each(\n resultEach,\n (key, childValue) => finalizeProperty(rootScope, state, result, key, childValue, path, isSet2)\n );\n maybeFreeze(rootScope, result, false);\n if (path && rootScope.patches_) {\n getPlugin(\"Patches\").generatePatches_(\n state,\n path,\n rootScope.patches_,\n rootScope.inversePatches_\n );\n }\n }\n return state.copy_;\n}\nfunction finalizeProperty(rootScope, parentState, targetObject, prop, childValue, rootPath, targetIsSet) {\n if (process.env.NODE_ENV !== \"production\" && childValue === targetObject)\n die(5);\n if (isDraft(childValue)) {\n const path = rootPath && parentState && parentState.type_ !== 3 /* Set */ && // Set objects are atomic since they have no keys.\n !has(parentState.assigned_, prop) ? rootPath.concat(prop) : void 0;\n const res = finalize(rootScope, childValue, path);\n set(targetObject, prop, res);\n if (isDraft(res)) {\n rootScope.canAutoFreeze_ = false;\n } else\n return;\n } else if (targetIsSet) {\n targetObject.add(childValue);\n }\n if (isDraftable(childValue) && !isFrozen(childValue)) {\n if (!rootScope.immer_.autoFreeze_ && rootScope.unfinalizedDrafts_ < 1) {\n return;\n }\n finalize(rootScope, childValue);\n if (!parentState || !parentState.scope_.parent_)\n maybeFreeze(rootScope, childValue);\n }\n}\nfunction maybeFreeze(scope, value, deep = false) {\n if (!scope.parent_ && scope.immer_.autoFreeze_ && scope.canAutoFreeze_) {\n freeze(value, deep);\n }\n}\n\n// src/core/proxy.ts\nfunction createProxyProxy(base, parent) {\n const isArray = Array.isArray(base);\n const state = {\n type_: isArray ? 1 /* Array */ : 0 /* Object */,\n // Track which produce call this is associated with.\n scope_: parent ? parent.scope_ : getCurrentScope(),\n // True for both shallow and deep changes.\n modified_: false,\n // Used during finalization.\n finalized_: false,\n // Track which properties have been assigned (true) or deleted (false).\n assigned_: {},\n // The parent draft state.\n parent_: parent,\n // The base state.\n base_: base,\n // The base proxy.\n draft_: null,\n // set below\n // The base copy with any updated values.\n copy_: null,\n // Called by the `produce` function.\n revoke_: null,\n isManual_: false\n };\n let target = state;\n let traps = objectTraps;\n if (isArray) {\n target = [state];\n traps = arrayTraps;\n }\n const { revoke, proxy } = Proxy.revocable(target, traps);\n state.draft_ = proxy;\n state.revoke_ = revoke;\n return proxy;\n}\nvar objectTraps = {\n get(state, prop) {\n if (prop === DRAFT_STATE)\n return state;\n const source = latest(state);\n if (!has(source, prop)) {\n return readPropFromProto(state, source, prop);\n }\n const value = source[prop];\n if (state.finalized_ || !isDraftable(value)) {\n return value;\n }\n if (value === peek(state.base_, prop)) {\n prepareCopy(state);\n return state.copy_[prop] = createProxy(value, state);\n }\n return value;\n },\n has(state, prop) {\n return prop in latest(state);\n },\n ownKeys(state) {\n return Reflect.ownKeys(latest(state));\n },\n set(state, prop, value) {\n const desc = getDescriptorFromProto(latest(state), prop);\n if (desc?.set) {\n desc.set.call(state.draft_, value);\n return true;\n }\n if (!state.modified_) {\n const current2 = peek(latest(state), prop);\n const currentState = current2?.[DRAFT_STATE];\n if (currentState && currentState.base_ === value) {\n state.copy_[prop] = value;\n state.assigned_[prop] = false;\n return true;\n }\n if (is(value, current2) && (value !== void 0 || has(state.base_, prop)))\n return true;\n prepareCopy(state);\n markChanged(state);\n }\n if (state.copy_[prop] === value && // special case: handle new props with value 'undefined'\n (value !== void 0 || prop in state.copy_) || // special case: NaN\n Number.isNaN(value) && Number.isNaN(state.copy_[prop]))\n return true;\n state.copy_[prop] = value;\n state.assigned_[prop] = true;\n return true;\n },\n deleteProperty(state, prop) {\n if (peek(state.base_, prop) !== void 0 || prop in state.base_) {\n state.assigned_[prop] = false;\n prepareCopy(state);\n markChanged(state);\n } else {\n delete state.assigned_[prop];\n }\n if (state.copy_) {\n delete state.copy_[prop];\n }\n return true;\n },\n // Note: We never coerce `desc.value` into an Immer draft, because we can't make\n // the same guarantee in ES5 mode.\n getOwnPropertyDescriptor(state, prop) {\n const owner = latest(state);\n const desc = Reflect.getOwnPropertyDescriptor(owner, prop);\n if (!desc)\n return desc;\n return {\n writable: true,\n configurable: state.type_ !== 1 /* Array */ || prop !== \"length\",\n enumerable: desc.enumerable,\n value: owner[prop]\n };\n },\n defineProperty() {\n die(11);\n },\n getPrototypeOf(state) {\n return getPrototypeOf(state.base_);\n },\n setPrototypeOf() {\n die(12);\n }\n};\nvar arrayTraps = {};\neach(objectTraps, (key, fn) => {\n arrayTraps[key] = function() {\n arguments[0] = arguments[0][0];\n return fn.apply(this, arguments);\n };\n});\narrayTraps.deleteProperty = function(state, prop) {\n if (process.env.NODE_ENV !== \"production\" && isNaN(parseInt(prop)))\n die(13);\n return arrayTraps.set.call(this, state, prop, void 0);\n};\narrayTraps.set = function(state, prop, value) {\n if (process.env.NODE_ENV !== \"production\" && prop !== \"length\" && isNaN(parseInt(prop)))\n die(14);\n return objectTraps.set.call(this, state[0], prop, value, state[0]);\n};\nfunction peek(draft, prop) {\n const state = draft[DRAFT_STATE];\n const source = state ? latest(state) : draft;\n return source[prop];\n}\nfunction readPropFromProto(state, source, prop) {\n const desc = getDescriptorFromProto(source, prop);\n return desc ? `value` in desc ? desc.value : (\n // This is a very special case, if the prop is a getter defined by the\n // prototype, we should invoke it with the draft as context!\n desc.get?.call(state.draft_)\n ) : void 0;\n}\nfunction getDescriptorFromProto(source, prop) {\n if (!(prop in source))\n return void 0;\n let proto = getPrototypeOf(source);\n while (proto) {\n const desc = Object.getOwnPropertyDescriptor(proto, prop);\n if (desc)\n return desc;\n proto = getPrototypeOf(proto);\n }\n return void 0;\n}\nfunction markChanged(state) {\n if (!state.modified_) {\n state.modified_ = true;\n if (state.parent_) {\n markChanged(state.parent_);\n }\n }\n}\nfunction prepareCopy(state) {\n if (!state.copy_) {\n state.copy_ = shallowCopy(\n state.base_,\n state.scope_.immer_.useStrictShallowCopy_\n );\n }\n}\n\n// src/core/immerClass.ts\nvar Immer2 = class {\n constructor(config) {\n this.autoFreeze_ = true;\n this.useStrictShallowCopy_ = false;\n /**\n * The `produce` function takes a value and a \"recipe function\" (whose\n * return value often depends on the base state). The recipe function is\n * free to mutate its first argument however it wants. All mutations are\n * only ever applied to a __copy__ of the base state.\n *\n * Pass only a function to create a \"curried producer\" which relieves you\n * from passing the recipe function every time.\n *\n * Only plain objects and arrays are made mutable. All other objects are\n * considered uncopyable.\n *\n * Note: This function is __bound__ to its `Immer` instance.\n *\n * @param {any} base - the initial state\n * @param {Function} recipe - function that receives a proxy of the base state as first argument and which can be freely modified\n * @param {Function} patchListener - optional function that will be called with all the patches produced here\n * @returns {any} a new state, or the initial state if nothing was modified\n */\n this.produce = (base, recipe, patchListener) => {\n if (typeof base === \"function\" && typeof recipe !== \"function\") {\n const defaultBase = recipe;\n recipe = base;\n const self = this;\n return function curriedProduce(base2 = defaultBase, ...args) {\n return self.produce(base2, (draft) => recipe.call(this, draft, ...args));\n };\n }\n if (typeof recipe !== \"function\")\n die(6);\n if (patchListener !== void 0 && typeof patchListener !== \"function\")\n die(7);\n let result;\n if (isDraftable(base)) {\n const scope = enterScope(this);\n const proxy = createProxy(base, void 0);\n let hasError = true;\n try {\n result = recipe(proxy);\n hasError = false;\n } finally {\n if (hasError)\n revokeScope(scope);\n else\n leaveScope(scope);\n }\n usePatchesInScope(scope, patchListener);\n return processResult(result, scope);\n } else if (!base || typeof base !== \"object\") {\n result = recipe(base);\n if (result === void 0)\n result = base;\n if (result === NOTHING)\n result = void 0;\n if (this.autoFreeze_)\n freeze(result, true);\n if (patchListener) {\n const p = [];\n const ip = [];\n getPlugin(\"Patches\").generateReplacementPatches_(base, result, p, ip);\n patchListener(p, ip);\n }\n return result;\n } else\n die(1, base);\n };\n this.produceWithPatches = (base, recipe) => {\n if (typeof base === \"function\") {\n return (state, ...args) => this.produceWithPatches(state, (draft) => base(draft, ...args));\n }\n let patches, inversePatches;\n const result = this.produce(base, recipe, (p, ip) => {\n patches = p;\n inversePatches = ip;\n });\n return [result, patches, inversePatches];\n };\n if (typeof config?.autoFreeze === \"boolean\")\n this.setAutoFreeze(config.autoFreeze);\n if (typeof config?.useStrictShallowCopy === \"boolean\")\n this.setUseStrictShallowCopy(config.useStrictShallowCopy);\n }\n createDraft(base) {\n if (!isDraftable(base))\n die(8);\n if (isDraft(base))\n base = current(base);\n const scope = enterScope(this);\n const proxy = createProxy(base, void 0);\n proxy[DRAFT_STATE].isManual_ = true;\n leaveScope(scope);\n return proxy;\n }\n finishDraft(draft, patchListener) {\n const state = draft && draft[DRAFT_STATE];\n if (!state || !state.isManual_)\n die(9);\n const { scope_: scope } = state;\n usePatchesInScope(scope, patchListener);\n return processResult(void 0, scope);\n }\n /**\n * Pass true to automatically freeze all copies created by Immer.\n *\n * By default, auto-freezing is enabled.\n */\n setAutoFreeze(value) {\n this.autoFreeze_ = value;\n }\n /**\n * Pass true to enable strict shallow copy.\n *\n * By default, immer does not copy the object descriptors such as getter, setter and non-enumrable properties.\n */\n setUseStrictShallowCopy(value) {\n this.useStrictShallowCopy_ = value;\n }\n applyPatches(base, patches) {\n let i;\n for (i = patches.length - 1; i >= 0; i--) {\n const patch = patches[i];\n if (patch.path.length === 0 && patch.op === \"replace\") {\n base = patch.value;\n break;\n }\n }\n if (i > -1) {\n patches = patches.slice(i + 1);\n }\n const applyPatchesImpl = getPlugin(\"Patches\").applyPatches_;\n if (isDraft(base)) {\n return applyPatchesImpl(base, patches);\n }\n return this.produce(\n base,\n (draft) => applyPatchesImpl(draft, patches)\n );\n }\n};\nfunction createProxy(value, parent) {\n const draft = isMap(value) ? getPlugin(\"MapSet\").proxyMap_(value, parent) : isSet(value) ? getPlugin(\"MapSet\").proxySet_(value, parent) : createProxyProxy(value, parent);\n const scope = parent ? parent.scope_ : getCurrentScope();\n scope.drafts_.push(draft);\n return draft;\n}\n\n// src/core/current.ts\nfunction current(value) {\n if (!isDraft(value))\n die(10, value);\n return currentImpl(value);\n}\nfunction currentImpl(value) {\n if (!isDraftable(value) || isFrozen(value))\n return value;\n const state = value[DRAFT_STATE];\n let copy;\n if (state) {\n if (!state.modified_)\n return state.base_;\n state.finalized_ = true;\n copy = shallowCopy(value, state.scope_.immer_.useStrictShallowCopy_);\n } else {\n copy = shallowCopy(value, true);\n }\n each(copy, (key, childValue) => {\n set(copy, key, currentImpl(childValue));\n });\n if (state) {\n state.finalized_ = false;\n }\n return copy;\n}\n\n// src/plugins/patches.ts\nfunction enablePatches() {\n const errorOffset = 16;\n if (process.env.NODE_ENV !== \"production\") {\n errors.push(\n 'Sets cannot have \"replace\" patches.',\n function(op) {\n return \"Unsupported patch operation: \" + op;\n },\n function(path) {\n return \"Cannot apply patch, path doesn't resolve: \" + path;\n },\n \"Patching reserved attributes like __proto__, prototype and constructor is not allowed\"\n );\n }\n const REPLACE = \"replace\";\n const ADD = \"add\";\n const REMOVE = \"remove\";\n function generatePatches_(state, basePath, patches, inversePatches) {\n switch (state.type_) {\n case 0 /* Object */:\n case 2 /* Map */:\n return generatePatchesFromAssigned(\n state,\n basePath,\n patches,\n inversePatches\n );\n case 1 /* Array */:\n return generateArrayPatches(state, basePath, patches, inversePatches);\n case 3 /* Set */:\n return generateSetPatches(\n state,\n basePath,\n patches,\n inversePatches\n );\n }\n }\n function generateArrayPatches(state, basePath, patches, inversePatches) {\n let { base_, assigned_ } = state;\n let copy_ = state.copy_;\n if (copy_.length < base_.length) {\n ;\n [base_, copy_] = [copy_, base_];\n [patches, inversePatches] = [inversePatches, patches];\n }\n for (let i = 0; i < base_.length; i++) {\n if (assigned_[i] && copy_[i] !== base_[i]) {\n const path = basePath.concat([i]);\n patches.push({\n op: REPLACE,\n path,\n // Need to maybe clone it, as it can in fact be the original value\n // due to the base/copy inversion at the start of this function\n value: clonePatchValueIfNeeded(copy_[i])\n });\n inversePatches.push({\n op: REPLACE,\n path,\n value: clonePatchValueIfNeeded(base_[i])\n });\n }\n }\n for (let i = base_.length; i < copy_.length; i++) {\n const path = basePath.concat([i]);\n patches.push({\n op: ADD,\n path,\n // Need to maybe clone it, as it can in fact be the original value\n // due to the base/copy inversion at the start of this function\n value: clonePatchValueIfNeeded(copy_[i])\n });\n }\n for (let i = copy_.length - 1; base_.length <= i; --i) {\n const path = basePath.concat([i]);\n inversePatches.push({\n op: REMOVE,\n path\n });\n }\n }\n function generatePatchesFromAssigned(state, basePath, patches, inversePatches) {\n const { base_, copy_ } = state;\n each(state.assigned_, (key, assignedValue) => {\n const origValue = get(base_, key);\n const value = get(copy_, key);\n const op = !assignedValue ? REMOVE : has(base_, key) ? REPLACE : ADD;\n if (origValue === value && op === REPLACE)\n return;\n const path = basePath.concat(key);\n patches.push(op === REMOVE ? { op, path } : { op, path, value });\n inversePatches.push(\n op === ADD ? { op: REMOVE, path } : op === REMOVE ? { op: ADD, path, value: clonePatchValueIfNeeded(origValue) } : { op: REPLACE, path, value: clonePatchValueIfNeeded(origValue) }\n );\n });\n }\n function generateSetPatches(state, basePath, patches, inversePatches) {\n let { base_, copy_ } = state;\n let i = 0;\n base_.forEach((value) => {\n if (!copy_.has(value)) {\n const path = basePath.concat([i]);\n patches.push({\n op: REMOVE,\n path,\n value\n });\n inversePatches.unshift({\n op: ADD,\n path,\n value\n });\n }\n i++;\n });\n i = 0;\n copy_.forEach((value) => {\n if (!base_.has(value)) {\n const path = basePath.concat([i]);\n patches.push({\n op: ADD,\n path,\n value\n });\n inversePatches.unshift({\n op: REMOVE,\n path,\n value\n });\n }\n i++;\n });\n }\n function generateReplacementPatches_(baseValue, replacement, patches, inversePatches) {\n patches.push({\n op: REPLACE,\n path: [],\n value: replacement === NOTHING ? void 0 : replacement\n });\n inversePatches.push({\n op: REPLACE,\n path: [],\n value: baseValue\n });\n }\n function applyPatches_(draft, patches) {\n patches.forEach((patch) => {\n const { path, op } = patch;\n let base = draft;\n for (let i = 0; i < path.length - 1; i++) {\n const parentType = getArchtype(base);\n let p = path[i];\n if (typeof p !== \"string\" && typeof p !== \"number\") {\n p = \"\" + p;\n }\n if ((parentType === 0 /* Object */ || parentType === 1 /* Array */) && (p === \"__proto__\" || p === \"constructor\"))\n die(errorOffset + 3);\n if (typeof base === \"function\" && p === \"prototype\")\n die(errorOffset + 3);\n base = get(base, p);\n if (typeof base !== \"object\")\n die(errorOffset + 2, path.join(\"/\"));\n }\n const type = getArchtype(base);\n const value = deepClonePatchValue(patch.value);\n const key = path[path.length - 1];\n switch (op) {\n case REPLACE:\n switch (type) {\n case 2 /* Map */:\n return base.set(key, value);\n case 3 /* Set */:\n die(errorOffset);\n default:\n return base[key] = value;\n }\n case ADD:\n switch (type) {\n case 1 /* Array */:\n return key === \"-\" ? base.push(value) : base.splice(key, 0, value);\n case 2 /* Map */:\n return base.set(key, value);\n case 3 /* Set */:\n return base.add(value);\n default:\n return base[key] = value;\n }\n case REMOVE:\n switch (type) {\n case 1 /* Array */:\n return base.splice(key, 1);\n case 2 /* Map */:\n return base.delete(key);\n case 3 /* Set */:\n return base.delete(patch.value);\n default:\n return delete base[key];\n }\n default:\n die(errorOffset + 1, op);\n }\n });\n return draft;\n }\n function deepClonePatchValue(obj) {\n if (!isDraftable(obj))\n return obj;\n if (Array.isArray(obj))\n return obj.map(deepClonePatchValue);\n if (isMap(obj))\n return new Map(\n Array.from(obj.entries()).map(([k, v]) => [k, deepClonePatchValue(v)])\n );\n if (isSet(obj))\n return new Set(Array.from(obj).map(deepClonePatchValue));\n const cloned = Object.create(getPrototypeOf(obj));\n for (const key in obj)\n cloned[key] = deepClonePatchValue(obj[key]);\n if (has(obj, DRAFTABLE))\n cloned[DRAFTABLE] = obj[DRAFTABLE];\n return cloned;\n }\n function clonePatchValueIfNeeded(obj) {\n if (isDraft(obj)) {\n return deepClonePatchValue(obj);\n } else\n return obj;\n }\n loadPlugin(\"Patches\", {\n applyPatches_,\n generatePatches_,\n generateReplacementPatches_\n });\n}\n\n// src/plugins/mapset.ts\nfunction enableMapSet() {\n class DraftMap extends Map {\n constructor(target, parent) {\n super();\n this[DRAFT_STATE] = {\n type_: 2 /* Map */,\n parent_: parent,\n scope_: parent ? parent.scope_ : getCurrentScope(),\n modified_: false,\n finalized_: false,\n copy_: void 0,\n assigned_: void 0,\n base_: target,\n draft_: this,\n isManual_: false,\n revoked_: false\n };\n }\n get size() {\n return latest(this[DRAFT_STATE]).size;\n }\n has(key) {\n return latest(this[DRAFT_STATE]).has(key);\n }\n set(key, value) {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (!latest(state).has(key) || latest(state).get(key) !== value) {\n prepareMapCopy(state);\n markChanged(state);\n state.assigned_.set(key, true);\n state.copy_.set(key, value);\n state.assigned_.set(key, true);\n }\n return this;\n }\n delete(key) {\n if (!this.has(key)) {\n return false;\n }\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n prepareMapCopy(state);\n markChanged(state);\n if (state.base_.has(key)) {\n state.assigned_.set(key, false);\n } else {\n state.assigned_.delete(key);\n }\n state.copy_.delete(key);\n return true;\n }\n clear() {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (latest(state).size) {\n prepareMapCopy(state);\n markChanged(state);\n state.assigned_ = /* @__PURE__ */ new Map();\n each(state.base_, (key) => {\n state.assigned_.set(key, false);\n });\n state.copy_.clear();\n }\n }\n forEach(cb, thisArg) {\n const state = this[DRAFT_STATE];\n latest(state).forEach((_value, key, _map) => {\n cb.call(thisArg, this.get(key), key, this);\n });\n }\n get(key) {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n const value = latest(state).get(key);\n if (state.finalized_ || !isDraftable(value)) {\n return value;\n }\n if (value !== state.base_.get(key)) {\n return value;\n }\n const draft = createProxy(value, state);\n prepareMapCopy(state);\n state.copy_.set(key, draft);\n return draft;\n }\n keys() {\n return latest(this[DRAFT_STATE]).keys();\n }\n values() {\n const iterator = this.keys();\n return {\n [Symbol.iterator]: () => this.values(),\n next: () => {\n const r = iterator.next();\n if (r.done)\n return r;\n const value = this.get(r.value);\n return {\n done: false,\n value\n };\n }\n };\n }\n entries() {\n const iterator = this.keys();\n return {\n [Symbol.iterator]: () => this.entries(),\n next: () => {\n const r = iterator.next();\n if (r.done)\n return r;\n const value = this.get(r.value);\n return {\n done: false,\n value: [r.value, value]\n };\n }\n };\n }\n [(DRAFT_STATE, Symbol.iterator)]() {\n return this.entries();\n }\n }\n function proxyMap_(target, parent) {\n return new DraftMap(target, parent);\n }\n function prepareMapCopy(state) {\n if (!state.copy_) {\n state.assigned_ = /* @__PURE__ */ new Map();\n state.copy_ = new Map(state.base_);\n }\n }\n class DraftSet extends Set {\n constructor(target, parent) {\n super();\n this[DRAFT_STATE] = {\n type_: 3 /* Set */,\n parent_: parent,\n scope_: parent ? parent.scope_ : getCurrentScope(),\n modified_: false,\n finalized_: false,\n copy_: void 0,\n base_: target,\n draft_: this,\n drafts_: /* @__PURE__ */ new Map(),\n revoked_: false,\n isManual_: false\n };\n }\n get size() {\n return latest(this[DRAFT_STATE]).size;\n }\n has(value) {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (!state.copy_) {\n return state.base_.has(value);\n }\n if (state.copy_.has(value))\n return true;\n if (state.drafts_.has(value) && state.copy_.has(state.drafts_.get(value)))\n return true;\n return false;\n }\n add(value) {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (!this.has(value)) {\n prepareSetCopy(state);\n markChanged(state);\n state.copy_.add(value);\n }\n return this;\n }\n delete(value) {\n if (!this.has(value)) {\n return false;\n }\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n prepareSetCopy(state);\n markChanged(state);\n return state.copy_.delete(value) || (state.drafts_.has(value) ? state.copy_.delete(state.drafts_.get(value)) : (\n /* istanbul ignore next */\n false\n ));\n }\n clear() {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n if (latest(state).size) {\n prepareSetCopy(state);\n markChanged(state);\n state.copy_.clear();\n }\n }\n values() {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n prepareSetCopy(state);\n return state.copy_.values();\n }\n entries() {\n const state = this[DRAFT_STATE];\n assertUnrevoked(state);\n prepareSetCopy(state);\n return state.copy_.entries();\n }\n keys() {\n return this.values();\n }\n [(DRAFT_STATE, Symbol.iterator)]() {\n return this.values();\n }\n forEach(cb, thisArg) {\n const iterator = this.values();\n let result = iterator.next();\n while (!result.done) {\n cb.call(thisArg, result.value, result.value, this);\n result = iterator.next();\n }\n }\n }\n function proxySet_(target, parent) {\n return new DraftSet(target, parent);\n }\n function prepareSetCopy(state) {\n if (!state.copy_) {\n state.copy_ = /* @__PURE__ */ new Set();\n state.base_.forEach((value) => {\n if (isDraftable(value)) {\n const draft = createProxy(value, state);\n state.drafts_.set(value, draft);\n state.copy_.add(draft);\n } else {\n state.copy_.add(value);\n }\n });\n }\n }\n function assertUnrevoked(state) {\n if (state.revoked_)\n die(3, JSON.stringify(latest(state)));\n }\n loadPlugin(\"MapSet\", { proxyMap_, proxySet_ });\n}\n\n// src/immer.ts\nvar immer = new Immer2();\nvar produce = immer.produce;\nvar produceWithPatches = immer.produceWithPatches.bind(\n immer\n);\nvar setAutoFreeze = immer.setAutoFreeze.bind(immer);\nvar setUseStrictShallowCopy = immer.setUseStrictShallowCopy.bind(immer);\nvar applyPatches = immer.applyPatches.bind(immer);\nvar createDraft = immer.createDraft.bind(immer);\nvar finishDraft = immer.finishDraft.bind(immer);\nfunction castDraft(value) {\n return value;\n}\nfunction castImmutable(value) {\n return value;\n}\nexport {\n Immer2 as Immer,\n applyPatches,\n castDraft,\n castImmutable,\n createDraft,\n current,\n enableMapSet,\n enablePatches,\n finishDraft,\n freeze,\n DRAFTABLE as immerable,\n isDraft,\n isDraftable,\n NOTHING as nothing,\n original,\n produce,\n produceWithPatches,\n setAutoFreeze,\n setUseStrictShallowCopy\n};\n//# sourceMappingURL=immer.mjs.map","// src/index.ts\nexport * from \"redux\";\nimport { produce, current as current2, freeze, original as original2, isDraft as isDraft4 } from \"immer\";\nimport { createSelector, createSelectorCreator as createSelectorCreator2, lruMemoize, weakMapMemoize as weakMapMemoize2 } from \"reselect\";\n\n// src/createDraftSafeSelector.ts\nimport { current, isDraft } from \"immer\";\nimport { createSelectorCreator, weakMapMemoize } from \"reselect\";\nvar createDraftSafeSelectorCreator = (...args) => {\n const createSelector2 = createSelectorCreator(...args);\n const createDraftSafeSelector2 = Object.assign((...args2) => {\n const selector = createSelector2(...args2);\n const wrappedSelector = (value, ...rest) => selector(isDraft(value) ? current(value) : value, ...rest);\n Object.assign(wrappedSelector, selector);\n return wrappedSelector;\n }, {\n withTypes: () => createDraftSafeSelector2\n });\n return createDraftSafeSelector2;\n};\nvar createDraftSafeSelector = createDraftSafeSelectorCreator(weakMapMemoize);\n\n// src/configureStore.ts\nimport { applyMiddleware, createStore, compose as compose2, combineReducers, isPlainObject as isPlainObject2 } from \"redux\";\n\n// src/devtoolsExtension.ts\nimport { compose } from \"redux\";\nvar composeWithDevTools = typeof window !== \"undefined\" && window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ ? window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ : function() {\n if (arguments.length === 0)\n return void 0;\n if (typeof arguments[0] === \"object\")\n return compose;\n return compose.apply(null, arguments);\n};\nvar devToolsEnhancer = typeof window !== \"undefined\" && window.__REDUX_DEVTOOLS_EXTENSION__ ? window.__REDUX_DEVTOOLS_EXTENSION__ : function() {\n return function(noop3) {\n return noop3;\n };\n};\n\n// src/getDefaultMiddleware.ts\nimport { thunk as thunkMiddleware, withExtraArgument } from \"redux-thunk\";\n\n// src/createAction.ts\nimport { isAction } from \"redux\";\n\n// src/tsHelpers.ts\nvar hasMatchFunction = (v) => {\n return v && typeof v.match === \"function\";\n};\n\n// src/createAction.ts\nfunction createAction(type, prepareAction) {\n function actionCreator(...args) {\n if (prepareAction) {\n let prepared = prepareAction(...args);\n if (!prepared) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(0) : \"prepareAction did not return an object\");\n }\n return {\n type,\n payload: prepared.payload,\n ...\"meta\" in prepared && {\n meta: prepared.meta\n },\n ...\"error\" in prepared && {\n error: prepared.error\n }\n };\n }\n return {\n type,\n payload: args[0]\n };\n }\n actionCreator.toString = () => `${type}`;\n actionCreator.type = type;\n actionCreator.match = (action) => isAction(action) && action.type === type;\n return actionCreator;\n}\nfunction isActionCreator(action) {\n return typeof action === \"function\" && \"type\" in action && // hasMatchFunction only wants Matchers but I don't see the point in rewriting it\n hasMatchFunction(action);\n}\nfunction isFSA(action) {\n return isAction(action) && Object.keys(action).every(isValidKey);\n}\nfunction isValidKey(key) {\n return [\"type\", \"payload\", \"error\", \"meta\"].indexOf(key) > -1;\n}\n\n// src/actionCreatorInvariantMiddleware.ts\nfunction getMessage(type) {\n const splitType = type ? `${type}`.split(\"/\") : [];\n const actionName = splitType[splitType.length - 1] || \"actionCreator\";\n return `Detected an action creator with type \"${type || \"unknown\"}\" being dispatched. \nMake sure you're calling the action creator before dispatching, i.e. \\`dispatch(${actionName}())\\` instead of \\`dispatch(${actionName})\\`. This is necessary even if the action has no payload.`;\n}\nfunction createActionCreatorInvariantMiddleware(options = {}) {\n if (process.env.NODE_ENV === \"production\") {\n return () => (next) => (action) => next(action);\n }\n const {\n isActionCreator: isActionCreator2 = isActionCreator\n } = options;\n return () => (next) => (action) => {\n if (isActionCreator2(action)) {\n console.warn(getMessage(action.type));\n }\n return next(action);\n };\n}\n\n// src/utils.ts\nimport { produce as createNextState, isDraftable } from \"immer\";\nfunction getTimeMeasureUtils(maxDelay, fnName) {\n let elapsed = 0;\n return {\n measureTime(fn) {\n const started = Date.now();\n try {\n return fn();\n } finally {\n const finished = Date.now();\n elapsed += finished - started;\n }\n },\n warnIfExceeded() {\n if (elapsed > maxDelay) {\n console.warn(`${fnName} took ${elapsed}ms, which is more than the warning threshold of ${maxDelay}ms. \nIf your state or actions are very large, you may want to disable the middleware as it might cause too much of a slowdown in development mode. See https://redux-toolkit.js.org/api/getDefaultMiddleware for instructions.\nIt is disabled in production builds, so you don't need to worry about that.`);\n }\n }\n };\n}\nfunction find(iterable, comparator) {\n for (const entry of iterable) {\n if (comparator(entry)) {\n return entry;\n }\n }\n return void 0;\n}\nvar Tuple = class _Tuple extends Array {\n constructor(...items) {\n super(...items);\n Object.setPrototypeOf(this, _Tuple.prototype);\n }\n static get [Symbol.species]() {\n return _Tuple;\n }\n concat(...arr) {\n return super.concat.apply(this, arr);\n }\n prepend(...arr) {\n if (arr.length === 1 && Array.isArray(arr[0])) {\n return new _Tuple(...arr[0].concat(this));\n }\n return new _Tuple(...arr.concat(this));\n }\n};\nfunction freezeDraftable(val) {\n return isDraftable(val) ? createNextState(val, () => {\n }) : val;\n}\nfunction emplace(map, key, handler) {\n if (map.has(key)) {\n let value = map.get(key);\n if (handler.update) {\n value = handler.update(value, key, map);\n map.set(key, value);\n }\n return value;\n }\n if (!handler.insert)\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(10) : \"No insert provided for key not already in map\");\n const inserted = handler.insert(key, map);\n map.set(key, inserted);\n return inserted;\n}\n\n// src/immutableStateInvariantMiddleware.ts\nfunction isImmutableDefault(value) {\n return typeof value !== \"object\" || value == null || Object.isFrozen(value);\n}\nfunction trackForMutations(isImmutable, ignorePaths, obj) {\n const trackedProperties = trackProperties(isImmutable, ignorePaths, obj);\n return {\n detectMutations() {\n return detectMutations(isImmutable, ignorePaths, trackedProperties, obj);\n }\n };\n}\nfunction trackProperties(isImmutable, ignorePaths = [], obj, path = \"\", checkedObjects = /* @__PURE__ */ new Set()) {\n const tracked = {\n value: obj\n };\n if (!isImmutable(obj) && !checkedObjects.has(obj)) {\n checkedObjects.add(obj);\n tracked.children = {};\n for (const key in obj) {\n const childPath = path ? path + \".\" + key : key;\n if (ignorePaths.length && ignorePaths.indexOf(childPath) !== -1) {\n continue;\n }\n tracked.children[key] = trackProperties(isImmutable, ignorePaths, obj[key], childPath);\n }\n }\n return tracked;\n}\nfunction detectMutations(isImmutable, ignoredPaths = [], trackedProperty, obj, sameParentRef = false, path = \"\") {\n const prevObj = trackedProperty ? trackedProperty.value : void 0;\n const sameRef = prevObj === obj;\n if (sameParentRef && !sameRef && !Number.isNaN(obj)) {\n return {\n wasMutated: true,\n path\n };\n }\n if (isImmutable(prevObj) || isImmutable(obj)) {\n return {\n wasMutated: false\n };\n }\n const keysToDetect = {};\n for (let key in trackedProperty.children) {\n keysToDetect[key] = true;\n }\n for (let key in obj) {\n keysToDetect[key] = true;\n }\n const hasIgnoredPaths = ignoredPaths.length > 0;\n for (let key in keysToDetect) {\n const nestedPath = path ? path + \".\" + key : key;\n if (hasIgnoredPaths) {\n const hasMatches = ignoredPaths.some((ignored) => {\n if (ignored instanceof RegExp) {\n return ignored.test(nestedPath);\n }\n return nestedPath === ignored;\n });\n if (hasMatches) {\n continue;\n }\n }\n const result = detectMutations(isImmutable, ignoredPaths, trackedProperty.children[key], obj[key], sameRef, nestedPath);\n if (result.wasMutated) {\n return result;\n }\n }\n return {\n wasMutated: false\n };\n}\nfunction createImmutableStateInvariantMiddleware(options = {}) {\n if (process.env.NODE_ENV === \"production\") {\n return () => (next) => (action) => next(action);\n } else {\n let stringify2 = function(obj, serializer, indent, decycler) {\n return JSON.stringify(obj, getSerialize2(serializer, decycler), indent);\n }, getSerialize2 = function(serializer, decycler) {\n let stack = [], keys = [];\n if (!decycler)\n decycler = function(_, value) {\n if (stack[0] === value)\n return \"[Circular ~]\";\n return \"[Circular ~.\" + keys.slice(0, stack.indexOf(value)).join(\".\") + \"]\";\n };\n return function(key, value) {\n if (stack.length > 0) {\n var thisPos = stack.indexOf(this);\n ~thisPos ? stack.splice(thisPos + 1) : stack.push(this);\n ~thisPos ? keys.splice(thisPos, Infinity, key) : keys.push(key);\n if (~stack.indexOf(value))\n value = decycler.call(this, key, value);\n } else\n stack.push(value);\n return serializer == null ? value : serializer.call(this, key, value);\n };\n };\n var stringify = stringify2, getSerialize = getSerialize2;\n let {\n isImmutable = isImmutableDefault,\n ignoredPaths,\n warnAfter = 32\n } = options;\n const track = trackForMutations.bind(null, isImmutable, ignoredPaths);\n return ({\n getState\n }) => {\n let state = getState();\n let tracker = track(state);\n let result;\n return (next) => (action) => {\n const measureUtils = getTimeMeasureUtils(warnAfter, \"ImmutableStateInvariantMiddleware\");\n measureUtils.measureTime(() => {\n state = getState();\n result = tracker.detectMutations();\n tracker = track(state);\n if (result.wasMutated) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(19) : `A state mutation was detected between dispatches, in the path '${result.path || \"\"}'. This may cause incorrect behavior. (https://redux.js.org/style-guide/style-guide#do-not-mutate-state)`);\n }\n });\n const dispatchedAction = next(action);\n measureUtils.measureTime(() => {\n state = getState();\n result = tracker.detectMutations();\n tracker = track(state);\n if (result.wasMutated) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(20) : `A state mutation was detected inside a dispatch, in the path: ${result.path || \"\"}. Take a look at the reducer(s) handling the action ${stringify2(action)}. (https://redux.js.org/style-guide/style-guide#do-not-mutate-state)`);\n }\n });\n measureUtils.warnIfExceeded();\n return dispatchedAction;\n };\n };\n }\n}\n\n// src/serializableStateInvariantMiddleware.ts\nimport { isAction as isAction2, isPlainObject } from \"redux\";\nfunction isPlain(val) {\n const type = typeof val;\n return val == null || type === \"string\" || type === \"boolean\" || type === \"number\" || Array.isArray(val) || isPlainObject(val);\n}\nfunction findNonSerializableValue(value, path = \"\", isSerializable = isPlain, getEntries, ignoredPaths = [], cache) {\n let foundNestedSerializable;\n if (!isSerializable(value)) {\n return {\n keyPath: path || \"<root>\",\n value\n };\n }\n if (typeof value !== \"object\" || value === null) {\n return false;\n }\n if (cache?.has(value))\n return false;\n const entries = getEntries != null ? getEntries(value) : Object.entries(value);\n const hasIgnoredPaths = ignoredPaths.length > 0;\n for (const [key, nestedValue] of entries) {\n const nestedPath = path ? path + \".\" + key : key;\n if (hasIgnoredPaths) {\n const hasMatches = ignoredPaths.some((ignored) => {\n if (ignored instanceof RegExp) {\n return ignored.test(nestedPath);\n }\n return nestedPath === ignored;\n });\n if (hasMatches) {\n continue;\n }\n }\n if (!isSerializable(nestedValue)) {\n return {\n keyPath: nestedPath,\n value: nestedValue\n };\n }\n if (typeof nestedValue === \"object\") {\n foundNestedSerializable = findNonSerializableValue(nestedValue, nestedPath, isSerializable, getEntries, ignoredPaths, cache);\n if (foundNestedSerializable) {\n return foundNestedSerializable;\n }\n }\n }\n if (cache && isNestedFrozen(value))\n cache.add(value);\n return false;\n}\nfunction isNestedFrozen(value) {\n if (!Object.isFrozen(value))\n return false;\n for (const nestedValue of Object.values(value)) {\n if (typeof nestedValue !== \"object\" || nestedValue === null)\n continue;\n if (!isNestedFrozen(nestedValue))\n return false;\n }\n return true;\n}\nfunction createSerializableStateInvariantMiddleware(options = {}) {\n if (process.env.NODE_ENV === \"production\") {\n return () => (next) => (action) => next(action);\n } else {\n const {\n isSerializable = isPlain,\n getEntries,\n ignoredActions = [],\n ignoredActionPaths = [\"meta.arg\", \"meta.baseQueryMeta\"],\n ignoredPaths = [],\n warnAfter = 32,\n ignoreState = false,\n ignoreActions = false,\n disableCache = false\n } = options;\n const cache = !disableCache && WeakSet ? /* @__PURE__ */ new WeakSet() : void 0;\n return (storeAPI) => (next) => (action) => {\n if (!isAction2(action)) {\n return next(action);\n }\n const result = next(action);\n const measureUtils = getTimeMeasureUtils(warnAfter, \"SerializableStateInvariantMiddleware\");\n if (!ignoreActions && !(ignoredActions.length && ignoredActions.indexOf(action.type) !== -1)) {\n measureUtils.measureTime(() => {\n const foundActionNonSerializableValue = findNonSerializableValue(action, \"\", isSerializable, getEntries, ignoredActionPaths, cache);\n if (foundActionNonSerializableValue) {\n const {\n keyPath,\n value\n } = foundActionNonSerializableValue;\n console.error(`A non-serializable value was detected in an action, in the path: \\`${keyPath}\\`. Value:`, value, \"\\nTake a look at the logic that dispatched this action: \", action, \"\\n(See https://redux.js.org/faq/actions#why-should-type-be-a-string-or-at-least-serializable-why-should-my-action-types-be-constants)\", \"\\n(To allow non-serializable values see: https://redux-toolkit.js.org/usage/usage-guide#working-with-non-serializable-data)\");\n }\n });\n }\n if (!ignoreState) {\n measureUtils.measureTime(() => {\n const state = storeAPI.getState();\n const foundStateNonSerializableValue = findNonSerializableValue(state, \"\", isSerializable, getEntries, ignoredPaths, cache);\n if (foundStateNonSerializableValue) {\n const {\n keyPath,\n value\n } = foundStateNonSerializableValue;\n console.error(`A non-serializable value was detected in the state, in the path: \\`${keyPath}\\`. Value:`, value, `\nTake a look at the reducer(s) handling this action type: ${action.type}.\n(See https://redux.js.org/faq/organizing-state#can-i-put-functions-promises-or-other-non-serializable-items-in-my-store-state)`);\n }\n });\n measureUtils.warnIfExceeded();\n }\n return result;\n };\n }\n}\n\n// src/getDefaultMiddleware.ts\nfunction isBoolean(x) {\n return typeof x === \"boolean\";\n}\nvar buildGetDefaultMiddleware = () => function getDefaultMiddleware(options) {\n const {\n thunk = true,\n immutableCheck = true,\n serializableCheck = true,\n actionCreatorCheck = true\n } = options ?? {};\n let middlewareArray = new Tuple();\n if (thunk) {\n if (isBoolean(thunk)) {\n middlewareArray.push(thunkMiddleware);\n } else {\n middlewareArray.push(withExtraArgument(thunk.extraArgument));\n }\n }\n if (process.env.NODE_ENV !== \"production\") {\n if (immutableCheck) {\n let immutableOptions = {};\n if (!isBoolean(immutableCheck)) {\n immutableOptions = immutableCheck;\n }\n middlewareArray.unshift(createImmutableStateInvariantMiddleware(immutableOptions));\n }\n if (serializableCheck) {\n let serializableOptions = {};\n if (!isBoolean(serializableCheck)) {\n serializableOptions = serializableCheck;\n }\n middlewareArray.push(createSerializableStateInvariantMiddleware(serializableOptions));\n }\n if (actionCreatorCheck) {\n let actionCreatorOptions = {};\n if (!isBoolean(actionCreatorCheck)) {\n actionCreatorOptions = actionCreatorCheck;\n }\n middlewareArray.unshift(createActionCreatorInvariantMiddleware(actionCreatorOptions));\n }\n }\n return middlewareArray;\n};\n\n// src/autoBatchEnhancer.ts\nvar SHOULD_AUTOBATCH = \"RTK_autoBatch\";\nvar prepareAutoBatched = () => (payload) => ({\n payload,\n meta: {\n [SHOULD_AUTOBATCH]: true\n }\n});\nvar createQueueWithTimer = (timeout) => {\n return (notify) => {\n setTimeout(notify, timeout);\n };\n};\nvar rAF = typeof window !== \"undefined\" && window.requestAnimationFrame ? window.requestAnimationFrame : createQueueWithTimer(10);\nvar autoBatchEnhancer = (options = {\n type: \"raf\"\n}) => (next) => (...args) => {\n const store = next(...args);\n let notifying = true;\n let shouldNotifyAtEndOfTick = false;\n let notificationQueued = false;\n const listeners = /* @__PURE__ */ new Set();\n const queueCallback = options.type === \"tick\" ? queueMicrotask : options.type === \"raf\" ? rAF : options.type === \"callback\" ? options.queueNotification : createQueueWithTimer(options.timeout);\n const notifyListeners = () => {\n notificationQueued = false;\n if (shouldNotifyAtEndOfTick) {\n shouldNotifyAtEndOfTick = false;\n listeners.forEach((l) => l());\n }\n };\n return Object.assign({}, store, {\n // Override the base `store.subscribe` method to keep original listeners\n // from running if we're delaying notifications\n subscribe(listener2) {\n const wrappedListener = () => notifying && listener2();\n const unsubscribe = store.subscribe(wrappedListener);\n listeners.add(listener2);\n return () => {\n unsubscribe();\n listeners.delete(listener2);\n };\n },\n // Override the base `store.dispatch` method so that we can check actions\n // for the `shouldAutoBatch` flag and determine if batching is active\n dispatch(action) {\n try {\n notifying = !action?.meta?.[SHOULD_AUTOBATCH];\n shouldNotifyAtEndOfTick = !notifying;\n if (shouldNotifyAtEndOfTick) {\n if (!notificationQueued) {\n notificationQueued = true;\n queueCallback(notifyListeners);\n }\n }\n return store.dispatch(action);\n } finally {\n notifying = true;\n }\n }\n });\n};\n\n// src/getDefaultEnhancers.ts\nvar buildGetDefaultEnhancers = (middlewareEnhancer) => function getDefaultEnhancers(options) {\n const {\n autoBatch = true\n } = options ?? {};\n let enhancerArray = new Tuple(middlewareEnhancer);\n if (autoBatch) {\n enhancerArray.push(autoBatchEnhancer(typeof autoBatch === \"object\" ? autoBatch : void 0));\n }\n return enhancerArray;\n};\n\n// src/configureStore.ts\nvar IS_PRODUCTION = process.env.NODE_ENV === \"production\";\nfunction configureStore(options) {\n const getDefaultMiddleware = buildGetDefaultMiddleware();\n const {\n reducer = void 0,\n middleware,\n devTools = true,\n preloadedState = void 0,\n enhancers = void 0\n } = options || {};\n let rootReducer;\n if (typeof reducer === \"function\") {\n rootReducer = reducer;\n } else if (isPlainObject2(reducer)) {\n rootReducer = combineReducers(reducer);\n } else {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(1) : \"`reducer` is a required argument, and must be a function or an object of functions that can be passed to combineReducers\");\n }\n if (!IS_PRODUCTION && middleware && typeof middleware !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(2) : \"`middleware` field must be a callback\");\n }\n let finalMiddleware;\n if (typeof middleware === \"function\") {\n finalMiddleware = middleware(getDefaultMiddleware);\n if (!IS_PRODUCTION && !Array.isArray(finalMiddleware)) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(3) : \"when using a middleware builder function, an array of middleware must be returned\");\n }\n } else {\n finalMiddleware = getDefaultMiddleware();\n }\n if (!IS_PRODUCTION && finalMiddleware.some((item) => typeof item !== \"function\")) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(4) : \"each middleware provided to configureStore must be a function\");\n }\n let finalCompose = compose2;\n if (devTools) {\n finalCompose = composeWithDevTools({\n // Enable capture of stack traces for dispatched Redux actions\n trace: !IS_PRODUCTION,\n ...typeof devTools === \"object\" && devTools\n });\n }\n const middlewareEnhancer = applyMiddleware(...finalMiddleware);\n const getDefaultEnhancers = buildGetDefaultEnhancers(middlewareEnhancer);\n if (!IS_PRODUCTION && enhancers && typeof enhancers !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(5) : \"`enhancers` field must be a callback\");\n }\n let storeEnhancers = typeof enhancers === \"function\" ? enhancers(getDefaultEnhancers) : getDefaultEnhancers();\n if (!IS_PRODUCTION && !Array.isArray(storeEnhancers)) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(6) : \"`enhancers` callback must return an array\");\n }\n if (!IS_PRODUCTION && storeEnhancers.some((item) => typeof item !== \"function\")) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(7) : \"each enhancer provided to configureStore must be a function\");\n }\n if (!IS_PRODUCTION && finalMiddleware.length && !storeEnhancers.includes(middlewareEnhancer)) {\n console.error(\"middlewares were provided, but middleware enhancer was not included in final enhancers - make sure to call `getDefaultEnhancers`\");\n }\n const composedEnhancer = finalCompose(...storeEnhancers);\n return createStore(rootReducer, preloadedState, composedEnhancer);\n}\n\n// src/createReducer.ts\nimport { produce as createNextState2, isDraft as isDraft2, isDraftable as isDraftable2 } from \"immer\";\n\n// src/mapBuilders.ts\nfunction executeReducerBuilderCallback(builderCallback) {\n const actionsMap = {};\n const actionMatchers = [];\n let defaultCaseReducer;\n const builder = {\n addCase(typeOrActionCreator, reducer) {\n if (process.env.NODE_ENV !== \"production\") {\n if (actionMatchers.length > 0) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(26) : \"`builder.addCase` should only be called before calling `builder.addMatcher`\");\n }\n if (defaultCaseReducer) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(27) : \"`builder.addCase` should only be called before calling `builder.addDefaultCase`\");\n }\n }\n const type = typeof typeOrActionCreator === \"string\" ? typeOrActionCreator : typeOrActionCreator.type;\n if (!type) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(28) : \"`builder.addCase` cannot be called with an empty action type\");\n }\n if (type in actionsMap) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(29) : `\\`builder.addCase\\` cannot be called with two reducers for the same action type '${type}'`);\n }\n actionsMap[type] = reducer;\n return builder;\n },\n addMatcher(matcher, reducer) {\n if (process.env.NODE_ENV !== \"production\") {\n if (defaultCaseReducer) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(30) : \"`builder.addMatcher` should only be called before calling `builder.addDefaultCase`\");\n }\n }\n actionMatchers.push({\n matcher,\n reducer\n });\n return builder;\n },\n addDefaultCase(reducer) {\n if (process.env.NODE_ENV !== \"production\") {\n if (defaultCaseReducer) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(31) : \"`builder.addDefaultCase` can only be called once\");\n }\n }\n defaultCaseReducer = reducer;\n return builder;\n }\n };\n builderCallback(builder);\n return [actionsMap, actionMatchers, defaultCaseReducer];\n}\n\n// src/createReducer.ts\nfunction isStateFunction(x) {\n return typeof x === \"function\";\n}\nfunction createReducer(initialState, mapOrBuilderCallback) {\n if (process.env.NODE_ENV !== \"production\") {\n if (typeof mapOrBuilderCallback === \"object\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(8) : \"The object notation for `createReducer` has been removed. Please use the 'builder callback' notation instead: https://redux-toolkit.js.org/api/createReducer\");\n }\n }\n let [actionsMap, finalActionMatchers, finalDefaultCaseReducer] = executeReducerBuilderCallback(mapOrBuilderCallback);\n let getInitialState;\n if (isStateFunction(initialState)) {\n getInitialState = () => freezeDraftable(initialState());\n } else {\n const frozenInitialState = freezeDraftable(initialState);\n getInitialState = () => frozenInitialState;\n }\n function reducer(state = getInitialState(), action) {\n let caseReducers = [actionsMap[action.type], ...finalActionMatchers.filter(({\n matcher\n }) => matcher(action)).map(({\n reducer: reducer2\n }) => reducer2)];\n if (caseReducers.filter((cr) => !!cr).length === 0) {\n caseReducers = [finalDefaultCaseReducer];\n }\n return caseReducers.reduce((previousState, caseReducer) => {\n if (caseReducer) {\n if (isDraft2(previousState)) {\n const draft = previousState;\n const result = caseReducer(draft, action);\n if (result === void 0) {\n return previousState;\n }\n return result;\n } else if (!isDraftable2(previousState)) {\n const result = caseReducer(previousState, action);\n if (result === void 0) {\n if (previousState === null) {\n return previousState;\n }\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(9) : \"A case reducer on a non-draftable value must not return undefined\");\n }\n return result;\n } else {\n return createNextState2(previousState, (draft) => {\n return caseReducer(draft, action);\n });\n }\n }\n return previousState;\n }, state);\n }\n reducer.getInitialState = getInitialState;\n return reducer;\n}\n\n// src/nanoid.ts\nvar urlAlphabet = \"ModuleSymbhasOwnPr-0123456789ABCDEFGHNRVfgctiUvz_KqYTJkLxpZXIjQW\";\nvar nanoid = (size = 21) => {\n let id = \"\";\n let i = size;\n while (i--) {\n id += urlAlphabet[Math.random() * 64 | 0];\n }\n return id;\n};\n\n// src/matchers.ts\nvar matches = (matcher, action) => {\n if (hasMatchFunction(matcher)) {\n return matcher.match(action);\n } else {\n return matcher(action);\n }\n};\nfunction isAnyOf(...matchers) {\n return (action) => {\n return matchers.some((matcher) => matches(matcher, action));\n };\n}\nfunction isAllOf(...matchers) {\n return (action) => {\n return matchers.every((matcher) => matches(matcher, action));\n };\n}\nfunction hasExpectedRequestMetadata(action, validStatus) {\n if (!action || !action.meta)\n return false;\n const hasValidRequestId = typeof action.meta.requestId === \"string\";\n const hasValidRequestStatus = validStatus.indexOf(action.meta.requestStatus) > -1;\n return hasValidRequestId && hasValidRequestStatus;\n}\nfunction isAsyncThunkArray(a) {\n return typeof a[0] === \"function\" && \"pending\" in a[0] && \"fulfilled\" in a[0] && \"rejected\" in a[0];\n}\nfunction isPending(...asyncThunks) {\n if (asyncThunks.length === 0) {\n return (action) => hasExpectedRequestMetadata(action, [\"pending\"]);\n }\n if (!isAsyncThunkArray(asyncThunks)) {\n return isPending()(asyncThunks[0]);\n }\n return (action) => {\n const matchers = asyncThunks.map((asyncThunk) => asyncThunk.pending);\n const combinedMatcher = isAnyOf(...matchers);\n return combinedMatcher(action);\n };\n}\nfunction isRejected(...asyncThunks) {\n if (asyncThunks.length === 0) {\n return (action) => hasExpectedRequestMetadata(action, [\"rejected\"]);\n }\n if (!isAsyncThunkArray(asyncThunks)) {\n return isRejected()(asyncThunks[0]);\n }\n return (action) => {\n const matchers = asyncThunks.map((asyncThunk) => asyncThunk.rejected);\n const combinedMatcher = isAnyOf(...matchers);\n return combinedMatcher(action);\n };\n}\nfunction isRejectedWithValue(...asyncThunks) {\n const hasFlag = (action) => {\n return action && action.meta && action.meta.rejectedWithValue;\n };\n if (asyncThunks.length === 0) {\n return (action) => {\n const combinedMatcher = isAllOf(isRejected(...asyncThunks), hasFlag);\n return combinedMatcher(action);\n };\n }\n if (!isAsyncThunkArray(asyncThunks)) {\n return isRejectedWithValue()(asyncThunks[0]);\n }\n return (action) => {\n const combinedMatcher = isAllOf(isRejected(...asyncThunks), hasFlag);\n return combinedMatcher(action);\n };\n}\nfunction isFulfilled(...asyncThunks) {\n if (asyncThunks.length === 0) {\n return (action) => hasExpectedRequestMetadata(action, [\"fulfilled\"]);\n }\n if (!isAsyncThunkArray(asyncThunks)) {\n return isFulfilled()(asyncThunks[0]);\n }\n return (action) => {\n const matchers = asyncThunks.map((asyncThunk) => asyncThunk.fulfilled);\n const combinedMatcher = isAnyOf(...matchers);\n return combinedMatcher(action);\n };\n}\nfunction isAsyncThunkAction(...asyncThunks) {\n if (asyncThunks.length === 0) {\n return (action) => hasExpectedRequestMetadata(action, [\"pending\", \"fulfilled\", \"rejected\"]);\n }\n if (!isAsyncThunkArray(asyncThunks)) {\n return isAsyncThunkAction()(asyncThunks[0]);\n }\n return (action) => {\n const matchers = [];\n for (const asyncThunk of asyncThunks) {\n matchers.push(asyncThunk.pending, asyncThunk.rejected, asyncThunk.fulfilled);\n }\n const combinedMatcher = isAnyOf(...matchers);\n return combinedMatcher(action);\n };\n}\n\n// src/createAsyncThunk.ts\nvar commonProperties = [\"name\", \"message\", \"stack\", \"code\"];\nvar RejectWithValue = class {\n constructor(payload, meta) {\n this.payload = payload;\n this.meta = meta;\n }\n /*\n type-only property to distinguish between RejectWithValue and FulfillWithMeta\n does not exist at runtime\n */\n _type;\n};\nvar FulfillWithMeta = class {\n constructor(payload, meta) {\n this.payload = payload;\n this.meta = meta;\n }\n /*\n type-only property to distinguish between RejectWithValue and FulfillWithMeta\n does not exist at runtime\n */\n _type;\n};\nvar miniSerializeError = (value) => {\n if (typeof value === \"object\" && value !== null) {\n const simpleError = {};\n for (const property of commonProperties) {\n if (typeof value[property] === \"string\") {\n simpleError[property] = value[property];\n }\n }\n return simpleError;\n }\n return {\n message: String(value)\n };\n};\nvar createAsyncThunk = /* @__PURE__ */ (() => {\n function createAsyncThunk2(typePrefix, payloadCreator, options) {\n const fulfilled = createAction(typePrefix + \"/fulfilled\", (payload, requestId, arg, meta) => ({\n payload,\n meta: {\n ...meta || {},\n arg,\n requestId,\n requestStatus: \"fulfilled\"\n }\n }));\n const pending = createAction(typePrefix + \"/pending\", (requestId, arg, meta) => ({\n payload: void 0,\n meta: {\n ...meta || {},\n arg,\n requestId,\n requestStatus: \"pending\"\n }\n }));\n const rejected = createAction(typePrefix + \"/rejected\", (error, requestId, arg, payload, meta) => ({\n payload,\n error: (options && options.serializeError || miniSerializeError)(error || \"Rejected\"),\n meta: {\n ...meta || {},\n arg,\n requestId,\n rejectedWithValue: !!payload,\n requestStatus: \"rejected\",\n aborted: error?.name === \"AbortError\",\n condition: error?.name === \"ConditionError\"\n }\n }));\n function actionCreator(arg) {\n return (dispatch, getState, extra) => {\n const requestId = options?.idGenerator ? options.idGenerator(arg) : nanoid();\n const abortController = new AbortController();\n let abortHandler;\n let abortReason;\n function abort(reason) {\n abortReason = reason;\n abortController.abort();\n }\n const promise = async function() {\n let finalAction;\n try {\n let conditionResult = options?.condition?.(arg, {\n getState,\n extra\n });\n if (isThenable(conditionResult)) {\n conditionResult = await conditionResult;\n }\n if (conditionResult === false || abortController.signal.aborted) {\n throw {\n name: \"ConditionError\",\n message: \"Aborted due to condition callback returning false.\"\n };\n }\n const abortedPromise = new Promise((_, reject) => {\n abortHandler = () => {\n reject({\n name: \"AbortError\",\n message: abortReason || \"Aborted\"\n });\n };\n abortController.signal.addEventListener(\"abort\", abortHandler);\n });\n dispatch(pending(requestId, arg, options?.getPendingMeta?.({\n requestId,\n arg\n }, {\n getState,\n extra\n })));\n finalAction = await Promise.race([abortedPromise, Promise.resolve(payloadCreator(arg, {\n dispatch,\n getState,\n extra,\n requestId,\n signal: abortController.signal,\n abort,\n rejectWithValue: (value, meta) => {\n return new RejectWithValue(value, meta);\n },\n fulfillWithValue: (value, meta) => {\n return new FulfillWithMeta(value, meta);\n }\n })).then((result) => {\n if (result instanceof RejectWithValue) {\n throw result;\n }\n if (result instanceof FulfillWithMeta) {\n return fulfilled(result.payload, requestId, arg, result.meta);\n }\n return fulfilled(result, requestId, arg);\n })]);\n } catch (err) {\n finalAction = err instanceof RejectWithValue ? rejected(null, requestId, arg, err.payload, err.meta) : rejected(err, requestId, arg);\n } finally {\n if (abortHandler) {\n abortController.signal.removeEventListener(\"abort\", abortHandler);\n }\n }\n const skipDispatch = options && !options.dispatchConditionRejection && rejected.match(finalAction) && finalAction.meta.condition;\n if (!skipDispatch) {\n dispatch(finalAction);\n }\n return finalAction;\n }();\n return Object.assign(promise, {\n abort,\n requestId,\n arg,\n unwrap() {\n return promise.then(unwrapResult);\n }\n });\n };\n }\n return Object.assign(actionCreator, {\n pending,\n rejected,\n fulfilled,\n settled: isAnyOf(rejected, fulfilled),\n typePrefix\n });\n }\n createAsyncThunk2.withTypes = () => createAsyncThunk2;\n return createAsyncThunk2;\n})();\nfunction unwrapResult(action) {\n if (action.meta && action.meta.rejectedWithValue) {\n throw action.payload;\n }\n if (action.error) {\n throw action.error;\n }\n return action.payload;\n}\nfunction isThenable(value) {\n return value !== null && typeof value === \"object\" && typeof value.then === \"function\";\n}\n\n// src/createSlice.ts\nvar asyncThunkSymbol = Symbol.for(\"rtk-slice-createasyncthunk\");\nvar asyncThunkCreator = {\n [asyncThunkSymbol]: createAsyncThunk\n};\nvar ReducerType = /* @__PURE__ */ ((ReducerType2) => {\n ReducerType2[\"reducer\"] = \"reducer\";\n ReducerType2[\"reducerWithPrepare\"] = \"reducerWithPrepare\";\n ReducerType2[\"asyncThunk\"] = \"asyncThunk\";\n return ReducerType2;\n})(ReducerType || {});\nfunction getType(slice, actionKey) {\n return `${slice}/${actionKey}`;\n}\nfunction buildCreateSlice({\n creators\n} = {}) {\n const cAT = creators?.asyncThunk?.[asyncThunkSymbol];\n return function createSlice2(options) {\n const {\n name,\n reducerPath = name\n } = options;\n if (!name) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(11) : \"`name` is a required option for createSlice\");\n }\n if (typeof process !== \"undefined\" && process.env.NODE_ENV === \"development\") {\n if (options.initialState === void 0) {\n console.error(\"You must provide an `initialState` value that is not `undefined`. You may have misspelled `initialState`\");\n }\n }\n const reducers = (typeof options.reducers === \"function\" ? options.reducers(buildReducerCreators()) : options.reducers) || {};\n const reducerNames = Object.keys(reducers);\n const context = {\n sliceCaseReducersByName: {},\n sliceCaseReducersByType: {},\n actionCreators: {},\n sliceMatchers: []\n };\n const contextMethods = {\n addCase(typeOrActionCreator, reducer2) {\n const type = typeof typeOrActionCreator === \"string\" ? typeOrActionCreator : typeOrActionCreator.type;\n if (!type) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(12) : \"`context.addCase` cannot be called with an empty action type\");\n }\n if (type in context.sliceCaseReducersByType) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(13) : \"`context.addCase` cannot be called with two reducers for the same action type: \" + type);\n }\n context.sliceCaseReducersByType[type] = reducer2;\n return contextMethods;\n },\n addMatcher(matcher, reducer2) {\n context.sliceMatchers.push({\n matcher,\n reducer: reducer2\n });\n return contextMethods;\n },\n exposeAction(name2, actionCreator) {\n context.actionCreators[name2] = actionCreator;\n return contextMethods;\n },\n exposeCaseReducer(name2, reducer2) {\n context.sliceCaseReducersByName[name2] = reducer2;\n return contextMethods;\n }\n };\n reducerNames.forEach((reducerName) => {\n const reducerDefinition = reducers[reducerName];\n const reducerDetails = {\n reducerName,\n type: getType(name, reducerName),\n createNotation: typeof options.reducers === \"function\"\n };\n if (isAsyncThunkSliceReducerDefinition(reducerDefinition)) {\n handleThunkCaseReducerDefinition(reducerDetails, reducerDefinition, contextMethods, cAT);\n } else {\n handleNormalReducerDefinition(reducerDetails, reducerDefinition, contextMethods);\n }\n });\n function buildReducer() {\n if (process.env.NODE_ENV !== \"production\") {\n if (typeof options.extraReducers === \"object\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(14) : \"The object notation for `createSlice.extraReducers` has been removed. Please use the 'builder callback' notation instead: https://redux-toolkit.js.org/api/createSlice\");\n }\n }\n const [extraReducers = {}, actionMatchers = [], defaultCaseReducer = void 0] = typeof options.extraReducers === \"function\" ? executeReducerBuilderCallback(options.extraReducers) : [options.extraReducers];\n const finalCaseReducers = {\n ...extraReducers,\n ...context.sliceCaseReducersByType\n };\n return createReducer(options.initialState, (builder) => {\n for (let key in finalCaseReducers) {\n builder.addCase(key, finalCaseReducers[key]);\n }\n for (let sM of context.sliceMatchers) {\n builder.addMatcher(sM.matcher, sM.reducer);\n }\n for (let m of actionMatchers) {\n builder.addMatcher(m.matcher, m.reducer);\n }\n if (defaultCaseReducer) {\n builder.addDefaultCase(defaultCaseReducer);\n }\n });\n }\n const selectSelf = (state) => state;\n const injectedSelectorCache = /* @__PURE__ */ new Map();\n let _reducer;\n function reducer(state, action) {\n if (!_reducer)\n _reducer = buildReducer();\n return _reducer(state, action);\n }\n function getInitialState() {\n if (!_reducer)\n _reducer = buildReducer();\n return _reducer.getInitialState();\n }\n function makeSelectorProps(reducerPath2, injected = false) {\n function selectSlice(state) {\n let sliceState = state[reducerPath2];\n if (typeof sliceState === \"undefined\") {\n if (injected) {\n sliceState = getInitialState();\n } else if (process.env.NODE_ENV !== \"production\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(15) : \"selectSlice returned undefined for an uninjected slice reducer\");\n }\n }\n return sliceState;\n }\n function getSelectors(selectState = selectSelf) {\n const selectorCache = emplace(injectedSelectorCache, injected, {\n insert: () => /* @__PURE__ */ new WeakMap()\n });\n return emplace(selectorCache, selectState, {\n insert: () => {\n const map = {};\n for (const [name2, selector] of Object.entries(options.selectors ?? {})) {\n map[name2] = wrapSelector(selector, selectState, getInitialState, injected);\n }\n return map;\n }\n });\n }\n return {\n reducerPath: reducerPath2,\n getSelectors,\n get selectors() {\n return getSelectors(selectSlice);\n },\n selectSlice\n };\n }\n const slice = {\n name,\n reducer,\n actions: context.actionCreators,\n caseReducers: context.sliceCaseReducersByName,\n getInitialState,\n ...makeSelectorProps(reducerPath),\n injectInto(injectable, {\n reducerPath: pathOpt,\n ...config\n } = {}) {\n const newReducerPath = pathOpt ?? reducerPath;\n injectable.inject({\n reducerPath: newReducerPath,\n reducer\n }, config);\n return {\n ...slice,\n ...makeSelectorProps(newReducerPath, true)\n };\n }\n };\n return slice;\n };\n}\nfunction wrapSelector(selector, selectState, getInitialState, injected) {\n function wrapper(rootState, ...args) {\n let sliceState = selectState(rootState);\n if (typeof sliceState === \"undefined\") {\n if (injected) {\n sliceState = getInitialState();\n } else if (process.env.NODE_ENV !== \"production\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(16) : \"selectState returned undefined for an uninjected slice reducer\");\n }\n }\n return selector(sliceState, ...args);\n }\n wrapper.unwrapped = selector;\n return wrapper;\n}\nvar createSlice = buildCreateSlice();\nfunction buildReducerCreators() {\n function asyncThunk(payloadCreator, config) {\n return {\n _reducerDefinitionType: \"asyncThunk\" /* asyncThunk */,\n payloadCreator,\n ...config\n };\n }\n asyncThunk.withTypes = () => asyncThunk;\n return {\n reducer(caseReducer) {\n return Object.assign({\n // hack so the wrapping function has the same name as the original\n // we need to create a wrapper so the `reducerDefinitionType` is not assigned to the original\n [caseReducer.name](...args) {\n return caseReducer(...args);\n }\n }[caseReducer.name], {\n _reducerDefinitionType: \"reducer\" /* reducer */\n });\n },\n preparedReducer(prepare, reducer) {\n return {\n _reducerDefinitionType: \"reducerWithPrepare\" /* reducerWithPrepare */,\n prepare,\n reducer\n };\n },\n asyncThunk\n };\n}\nfunction handleNormalReducerDefinition({\n type,\n reducerName,\n createNotation\n}, maybeReducerWithPrepare, context) {\n let caseReducer;\n let prepareCallback;\n if (\"reducer\" in maybeReducerWithPrepare) {\n if (createNotation && !isCaseReducerWithPrepareDefinition(maybeReducerWithPrepare)) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(17) : \"Please use the `create.preparedReducer` notation for prepared action creators with the `create` notation.\");\n }\n caseReducer = maybeReducerWithPrepare.reducer;\n prepareCallback = maybeReducerWithPrepare.prepare;\n } else {\n caseReducer = maybeReducerWithPrepare;\n }\n context.addCase(type, caseReducer).exposeCaseReducer(reducerName, caseReducer).exposeAction(reducerName, prepareCallback ? createAction(type, prepareCallback) : createAction(type));\n}\nfunction isAsyncThunkSliceReducerDefinition(reducerDefinition) {\n return reducerDefinition._reducerDefinitionType === \"asyncThunk\" /* asyncThunk */;\n}\nfunction isCaseReducerWithPrepareDefinition(reducerDefinition) {\n return reducerDefinition._reducerDefinitionType === \"reducerWithPrepare\" /* reducerWithPrepare */;\n}\nfunction handleThunkCaseReducerDefinition({\n type,\n reducerName\n}, reducerDefinition, context, cAT) {\n if (!cAT) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(18) : \"Cannot use `create.asyncThunk` in the built-in `createSlice`. Use `buildCreateSlice({ creators: { asyncThunk: asyncThunkCreator } })` to create a customised version of `createSlice`.\");\n }\n const {\n payloadCreator,\n fulfilled,\n pending,\n rejected,\n settled,\n options\n } = reducerDefinition;\n const thunk = cAT(type, payloadCreator, options);\n context.exposeAction(reducerName, thunk);\n if (fulfilled) {\n context.addCase(thunk.fulfilled, fulfilled);\n }\n if (pending) {\n context.addCase(thunk.pending, pending);\n }\n if (rejected) {\n context.addCase(thunk.rejected, rejected);\n }\n if (settled) {\n context.addMatcher(thunk.settled, settled);\n }\n context.exposeCaseReducer(reducerName, {\n fulfilled: fulfilled || noop,\n pending: pending || noop,\n rejected: rejected || noop,\n settled: settled || noop\n });\n}\nfunction noop() {\n}\n\n// src/entities/entity_state.ts\nfunction getInitialEntityState() {\n return {\n ids: [],\n entities: {}\n };\n}\nfunction createInitialStateFactory() {\n function getInitialState(additionalState = {}) {\n return Object.assign(getInitialEntityState(), additionalState);\n }\n return {\n getInitialState\n };\n}\n\n// src/entities/state_selectors.ts\nfunction createSelectorsFactory() {\n function getSelectors(selectState, options = {}) {\n const {\n createSelector: createSelector2 = createDraftSafeSelector\n } = options;\n const selectIds = (state) => state.ids;\n const selectEntities = (state) => state.entities;\n const selectAll = createSelector2(selectIds, selectEntities, (ids, entities) => ids.map((id) => entities[id]));\n const selectId = (_, id) => id;\n const selectById = (entities, id) => entities[id];\n const selectTotal = createSelector2(selectIds, (ids) => ids.length);\n if (!selectState) {\n return {\n selectIds,\n selectEntities,\n selectAll,\n selectTotal,\n selectById: createSelector2(selectEntities, selectId, selectById)\n };\n }\n const selectGlobalizedEntities = createSelector2(selectState, selectEntities);\n return {\n selectIds: createSelector2(selectState, selectIds),\n selectEntities: selectGlobalizedEntities,\n selectAll: createSelector2(selectState, selectAll),\n selectTotal: createSelector2(selectState, selectTotal),\n selectById: createSelector2(selectGlobalizedEntities, selectId, selectById)\n };\n }\n return {\n getSelectors\n };\n}\n\n// src/entities/state_adapter.ts\nimport { produce as createNextState3, isDraft as isDraft3 } from \"immer\";\nvar isDraftTyped = isDraft3;\nfunction createSingleArgumentStateOperator(mutator) {\n const operator = createStateOperator((_, state) => mutator(state));\n return function operation(state) {\n return operator(state, void 0);\n };\n}\nfunction createStateOperator(mutator) {\n return function operation(state, arg) {\n function isPayloadActionArgument(arg2) {\n return isFSA(arg2);\n }\n const runMutator = (draft) => {\n if (isPayloadActionArgument(arg)) {\n mutator(arg.payload, draft);\n } else {\n mutator(arg, draft);\n }\n };\n if (isDraftTyped(state)) {\n runMutator(state);\n return state;\n }\n return createNextState3(state, runMutator);\n };\n}\n\n// src/entities/utils.ts\nfunction selectIdValue(entity, selectId) {\n const key = selectId(entity);\n if (process.env.NODE_ENV !== \"production\" && key === void 0) {\n console.warn(\"The entity passed to the `selectId` implementation returned undefined.\", \"You should probably provide your own `selectId` implementation.\", \"The entity that was passed:\", entity, \"The `selectId` implementation:\", selectId.toString());\n }\n return key;\n}\nfunction ensureEntitiesArray(entities) {\n if (!Array.isArray(entities)) {\n entities = Object.values(entities);\n }\n return entities;\n}\nfunction splitAddedUpdatedEntities(newEntities, selectId, state) {\n newEntities = ensureEntitiesArray(newEntities);\n const added = [];\n const updated = [];\n for (const entity of newEntities) {\n const id = selectIdValue(entity, selectId);\n if (id in state.entities) {\n updated.push({\n id,\n changes: entity\n });\n } else {\n added.push(entity);\n }\n }\n return [added, updated];\n}\n\n// src/entities/unsorted_state_adapter.ts\nfunction createUnsortedStateAdapter(selectId) {\n function addOneMutably(entity, state) {\n const key = selectIdValue(entity, selectId);\n if (key in state.entities) {\n return;\n }\n state.ids.push(key);\n state.entities[key] = entity;\n }\n function addManyMutably(newEntities, state) {\n newEntities = ensureEntitiesArray(newEntities);\n for (const entity of newEntities) {\n addOneMutably(entity, state);\n }\n }\n function setOneMutably(entity, state) {\n const key = selectIdValue(entity, selectId);\n if (!(key in state.entities)) {\n state.ids.push(key);\n }\n state.entities[key] = entity;\n }\n function setManyMutably(newEntities, state) {\n newEntities = ensureEntitiesArray(newEntities);\n for (const entity of newEntities) {\n setOneMutably(entity, state);\n }\n }\n function setAllMutably(newEntities, state) {\n newEntities = ensureEntitiesArray(newEntities);\n state.ids = [];\n state.entities = {};\n addManyMutably(newEntities, state);\n }\n function removeOneMutably(key, state) {\n return removeManyMutably([key], state);\n }\n function removeManyMutably(keys, state) {\n let didMutate = false;\n keys.forEach((key) => {\n if (key in state.entities) {\n delete state.entities[key];\n didMutate = true;\n }\n });\n if (didMutate) {\n state.ids = state.ids.filter((id) => id in state.entities);\n }\n }\n function removeAllMutably(state) {\n Object.assign(state, {\n ids: [],\n entities: {}\n });\n }\n function takeNewKey(keys, update, state) {\n const original3 = state.entities[update.id];\n if (original3 === void 0) {\n return false;\n }\n const updated = Object.assign({}, original3, update.changes);\n const newKey = selectIdValue(updated, selectId);\n const hasNewKey = newKey !== update.id;\n if (hasNewKey) {\n keys[update.id] = newKey;\n delete state.entities[update.id];\n }\n state.entities[newKey] = updated;\n return hasNewKey;\n }\n function updateOneMutably(update, state) {\n return updateManyMutably([update], state);\n }\n function updateManyMutably(updates, state) {\n const newKeys = {};\n const updatesPerEntity = {};\n updates.forEach((update) => {\n if (update.id in state.entities) {\n updatesPerEntity[update.id] = {\n id: update.id,\n // Spreads ignore falsy values, so this works even if there isn't\n // an existing update already at this key\n changes: {\n ...updatesPerEntity[update.id] ? updatesPerEntity[update.id].changes : null,\n ...update.changes\n }\n };\n }\n });\n updates = Object.values(updatesPerEntity);\n const didMutateEntities = updates.length > 0;\n if (didMutateEntities) {\n const didMutateIds = updates.filter((update) => takeNewKey(newKeys, update, state)).length > 0;\n if (didMutateIds) {\n state.ids = Object.values(state.entities).map((e) => selectIdValue(e, selectId));\n }\n }\n }\n function upsertOneMutably(entity, state) {\n return upsertManyMutably([entity], state);\n }\n function upsertManyMutably(newEntities, state) {\n const [added, updated] = splitAddedUpdatedEntities(newEntities, selectId, state);\n updateManyMutably(updated, state);\n addManyMutably(added, state);\n }\n return {\n removeAll: createSingleArgumentStateOperator(removeAllMutably),\n addOne: createStateOperator(addOneMutably),\n addMany: createStateOperator(addManyMutably),\n setOne: createStateOperator(setOneMutably),\n setMany: createStateOperator(setManyMutably),\n setAll: createStateOperator(setAllMutably),\n updateOne: createStateOperator(updateOneMutably),\n updateMany: createStateOperator(updateManyMutably),\n upsertOne: createStateOperator(upsertOneMutably),\n upsertMany: createStateOperator(upsertManyMutably),\n removeOne: createStateOperator(removeOneMutably),\n removeMany: createStateOperator(removeManyMutably)\n };\n}\n\n// src/entities/sorted_state_adapter.ts\nfunction createSortedStateAdapter(selectId, sort) {\n const {\n removeOne,\n removeMany,\n removeAll\n } = createUnsortedStateAdapter(selectId);\n function addOneMutably(entity, state) {\n return addManyMutably([entity], state);\n }\n function addManyMutably(newEntities, state) {\n newEntities = ensureEntitiesArray(newEntities);\n const models = newEntities.filter((model) => !(selectIdValue(model, selectId) in state.entities));\n if (models.length !== 0) {\n merge(models, state);\n }\n }\n function setOneMutably(entity, state) {\n return setManyMutably([entity], state);\n }\n function setManyMutably(newEntities, state) {\n newEntities = ensureEntitiesArray(newEntities);\n if (newEntities.length !== 0) {\n merge(newEntities, state);\n }\n }\n function setAllMutably(newEntities, state) {\n newEntities = ensureEntitiesArray(newEntities);\n state.entities = {};\n state.ids = [];\n addManyMutably(newEntities, state);\n }\n function updateOneMutably(update, state) {\n return updateManyMutably([update], state);\n }\n function updateManyMutably(updates, state) {\n let appliedUpdates = false;\n for (let update of updates) {\n const entity = state.entities[update.id];\n if (!entity) {\n continue;\n }\n appliedUpdates = true;\n Object.assign(entity, update.changes);\n const newId = selectId(entity);\n if (update.id !== newId) {\n delete state.entities[update.id];\n state.entities[newId] = entity;\n }\n }\n if (appliedUpdates) {\n resortEntities(state);\n }\n }\n function upsertOneMutably(entity, state) {\n return upsertManyMutably([entity], state);\n }\n function upsertManyMutably(newEntities, state) {\n const [added, updated] = splitAddedUpdatedEntities(newEntities, selectId, state);\n updateManyMutably(updated, state);\n addManyMutably(added, state);\n }\n function areArraysEqual(a, b) {\n if (a.length !== b.length) {\n return false;\n }\n for (let i = 0; i < a.length && i < b.length; i++) {\n if (a[i] === b[i]) {\n continue;\n }\n return false;\n }\n return true;\n }\n function merge(models, state) {\n models.forEach((model) => {\n state.entities[selectId(model)] = model;\n });\n resortEntities(state);\n }\n function resortEntities(state) {\n const allEntities = Object.values(state.entities);\n allEntities.sort(sort);\n const newSortedIds = allEntities.map(selectId);\n const {\n ids\n } = state;\n if (!areArraysEqual(ids, newSortedIds)) {\n state.ids = newSortedIds;\n }\n }\n return {\n removeOne,\n removeMany,\n removeAll,\n addOne: createStateOperator(addOneMutably),\n updateOne: createStateOperator(updateOneMutably),\n upsertOne: createStateOperator(upsertOneMutably),\n setOne: createStateOperator(setOneMutably),\n setMany: createStateOperator(setManyMutably),\n setAll: createStateOperator(setAllMutably),\n addMany: createStateOperator(addManyMutably),\n updateMany: createStateOperator(updateManyMutably),\n upsertMany: createStateOperator(upsertManyMutably)\n };\n}\n\n// src/entities/create_adapter.ts\nfunction createEntityAdapter(options = {}) {\n const {\n selectId,\n sortComparer\n } = {\n sortComparer: false,\n selectId: (instance) => instance.id,\n ...options\n };\n const stateFactory = createInitialStateFactory();\n const selectorsFactory = createSelectorsFactory();\n const stateAdapter = sortComparer ? createSortedStateAdapter(selectId, sortComparer) : createUnsortedStateAdapter(selectId);\n return {\n selectId,\n sortComparer,\n ...stateFactory,\n ...selectorsFactory,\n ...stateAdapter\n };\n}\n\n// src/listenerMiddleware/index.ts\nimport { isAction as isAction3 } from \"redux\";\n\n// src/listenerMiddleware/exceptions.ts\nvar task = \"task\";\nvar listener = \"listener\";\nvar completed = \"completed\";\nvar cancelled = \"cancelled\";\nvar taskCancelled = `task-${cancelled}`;\nvar taskCompleted = `task-${completed}`;\nvar listenerCancelled = `${listener}-${cancelled}`;\nvar listenerCompleted = `${listener}-${completed}`;\nvar TaskAbortError = class {\n constructor(code) {\n this.code = code;\n this.message = `${task} ${cancelled} (reason: ${code})`;\n }\n name = \"TaskAbortError\";\n message;\n};\n\n// src/listenerMiddleware/utils.ts\nvar assertFunction = (func, expected) => {\n if (typeof func !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(32) : `${expected} is not a function`);\n }\n};\nvar noop2 = () => {\n};\nvar catchRejection = (promise, onError = noop2) => {\n promise.catch(onError);\n return promise;\n};\nvar addAbortSignalListener = (abortSignal, callback) => {\n abortSignal.addEventListener(\"abort\", callback, {\n once: true\n });\n return () => abortSignal.removeEventListener(\"abort\", callback);\n};\nvar abortControllerWithReason = (abortController, reason) => {\n const signal = abortController.signal;\n if (signal.aborted) {\n return;\n }\n if (!(\"reason\" in signal)) {\n Object.defineProperty(signal, \"reason\", {\n enumerable: true,\n value: reason,\n configurable: true,\n writable: true\n });\n }\n ;\n abortController.abort(reason);\n};\n\n// src/listenerMiddleware/task.ts\nvar validateActive = (signal) => {\n if (signal.aborted) {\n const {\n reason\n } = signal;\n throw new TaskAbortError(reason);\n }\n};\nfunction raceWithSignal(signal, promise) {\n let cleanup = noop2;\n return new Promise((resolve, reject) => {\n const notifyRejection = () => reject(new TaskAbortError(signal.reason));\n if (signal.aborted) {\n notifyRejection();\n return;\n }\n cleanup = addAbortSignalListener(signal, notifyRejection);\n promise.finally(() => cleanup()).then(resolve, reject);\n }).finally(() => {\n cleanup = noop2;\n });\n}\nvar runTask = async (task2, cleanUp) => {\n try {\n await Promise.resolve();\n const value = await task2();\n return {\n status: \"ok\",\n value\n };\n } catch (error) {\n return {\n status: error instanceof TaskAbortError ? \"cancelled\" : \"rejected\",\n error\n };\n } finally {\n cleanUp?.();\n }\n};\nvar createPause = (signal) => {\n return (promise) => {\n return catchRejection(raceWithSignal(signal, promise).then((output) => {\n validateActive(signal);\n return output;\n }));\n };\n};\nvar createDelay = (signal) => {\n const pause = createPause(signal);\n return (timeoutMs) => {\n return pause(new Promise((resolve) => setTimeout(resolve, timeoutMs)));\n };\n};\n\n// src/listenerMiddleware/index.ts\nvar {\n assign\n} = Object;\nvar INTERNAL_NIL_TOKEN = {};\nvar alm = \"listenerMiddleware\";\nvar createFork = (parentAbortSignal, parentBlockingPromises) => {\n const linkControllers = (controller) => addAbortSignalListener(parentAbortSignal, () => abortControllerWithReason(controller, parentAbortSignal.reason));\n return (taskExecutor, opts) => {\n assertFunction(taskExecutor, \"taskExecutor\");\n const childAbortController = new AbortController();\n linkControllers(childAbortController);\n const result = runTask(async () => {\n validateActive(parentAbortSignal);\n validateActive(childAbortController.signal);\n const result2 = await taskExecutor({\n pause: createPause(childAbortController.signal),\n delay: createDelay(childAbortController.signal),\n signal: childAbortController.signal\n });\n validateActive(childAbortController.signal);\n return result2;\n }, () => abortControllerWithReason(childAbortController, taskCompleted));\n if (opts?.autoJoin) {\n parentBlockingPromises.push(result.catch(noop2));\n }\n return {\n result: createPause(parentAbortSignal)(result),\n cancel() {\n abortControllerWithReason(childAbortController, taskCancelled);\n }\n };\n };\n};\nvar createTakePattern = (startListening, signal) => {\n const take = async (predicate, timeout) => {\n validateActive(signal);\n let unsubscribe = () => {\n };\n const tuplePromise = new Promise((resolve, reject) => {\n let stopListening = startListening({\n predicate,\n effect: (action, listenerApi) => {\n listenerApi.unsubscribe();\n resolve([action, listenerApi.getState(), listenerApi.getOriginalState()]);\n }\n });\n unsubscribe = () => {\n stopListening();\n reject();\n };\n });\n const promises = [tuplePromise];\n if (timeout != null) {\n promises.push(new Promise((resolve) => setTimeout(resolve, timeout, null)));\n }\n try {\n const output = await raceWithSignal(signal, Promise.race(promises));\n validateActive(signal);\n return output;\n } finally {\n unsubscribe();\n }\n };\n return (predicate, timeout) => catchRejection(take(predicate, timeout));\n};\nvar getListenerEntryPropsFrom = (options) => {\n let {\n type,\n actionCreator,\n matcher,\n predicate,\n effect\n } = options;\n if (type) {\n predicate = createAction(type).match;\n } else if (actionCreator) {\n type = actionCreator.type;\n predicate = actionCreator.match;\n } else if (matcher) {\n predicate = matcher;\n } else if (predicate) {\n } else {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(21) : \"Creating or removing a listener requires one of the known fields for matching an action\");\n }\n assertFunction(effect, \"options.listener\");\n return {\n predicate,\n type,\n effect\n };\n};\nvar createListenerEntry = Object.assign((options) => {\n const {\n type,\n predicate,\n effect\n } = getListenerEntryPropsFrom(options);\n const id = nanoid();\n const entry = {\n id,\n effect,\n type,\n predicate,\n pending: /* @__PURE__ */ new Set(),\n unsubscribe: () => {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(22) : \"Unsubscribe not initialized\");\n }\n };\n return entry;\n}, {\n withTypes: () => createListenerEntry\n});\nvar cancelActiveListeners = (entry) => {\n entry.pending.forEach((controller) => {\n abortControllerWithReason(controller, listenerCancelled);\n });\n};\nvar createClearListenerMiddleware = (listenerMap) => {\n return () => {\n listenerMap.forEach(cancelActiveListeners);\n listenerMap.clear();\n };\n};\nvar safelyNotifyError = (errorHandler, errorToNotify, errorInfo) => {\n try {\n errorHandler(errorToNotify, errorInfo);\n } catch (errorHandlerError) {\n setTimeout(() => {\n throw errorHandlerError;\n }, 0);\n }\n};\nvar addListener = Object.assign(createAction(`${alm}/add`), {\n withTypes: () => addListener\n});\nvar clearAllListeners = createAction(`${alm}/removeAll`);\nvar removeListener = Object.assign(createAction(`${alm}/remove`), {\n withTypes: () => removeListener\n});\nvar defaultErrorHandler = (...args) => {\n console.error(`${alm}/error`, ...args);\n};\nvar createListenerMiddleware = (middlewareOptions = {}) => {\n const listenerMap = /* @__PURE__ */ new Map();\n const {\n extra,\n onError = defaultErrorHandler\n } = middlewareOptions;\n assertFunction(onError, \"onError\");\n const insertEntry = (entry) => {\n entry.unsubscribe = () => listenerMap.delete(entry.id);\n listenerMap.set(entry.id, entry);\n return (cancelOptions) => {\n entry.unsubscribe();\n if (cancelOptions?.cancelActive) {\n cancelActiveListeners(entry);\n }\n };\n };\n const startListening = (options) => {\n let entry = find(Array.from(listenerMap.values()), (existingEntry) => existingEntry.effect === options.effect);\n if (!entry) {\n entry = createListenerEntry(options);\n }\n return insertEntry(entry);\n };\n Object.assign(startListening, {\n withTypes: () => startListening\n });\n const stopListening = (options) => {\n const {\n type,\n effect,\n predicate\n } = getListenerEntryPropsFrom(options);\n const entry = find(Array.from(listenerMap.values()), (entry2) => {\n const matchPredicateOrType = typeof type === \"string\" ? entry2.type === type : entry2.predicate === predicate;\n return matchPredicateOrType && entry2.effect === effect;\n });\n if (entry) {\n entry.unsubscribe();\n if (options.cancelActive) {\n cancelActiveListeners(entry);\n }\n }\n return !!entry;\n };\n Object.assign(stopListening, {\n withTypes: () => stopListening\n });\n const notifyListener = async (entry, action, api, getOriginalState) => {\n const internalTaskController = new AbortController();\n const take = createTakePattern(startListening, internalTaskController.signal);\n const autoJoinPromises = [];\n try {\n entry.pending.add(internalTaskController);\n await Promise.resolve(entry.effect(\n action,\n // Use assign() rather than ... to avoid extra helper functions added to bundle\n assign({}, api, {\n getOriginalState,\n condition: (predicate, timeout) => take(predicate, timeout).then(Boolean),\n take,\n delay: createDelay(internalTaskController.signal),\n pause: createPause(internalTaskController.signal),\n extra,\n signal: internalTaskController.signal,\n fork: createFork(internalTaskController.signal, autoJoinPromises),\n unsubscribe: entry.unsubscribe,\n subscribe: () => {\n listenerMap.set(entry.id, entry);\n },\n cancelActiveListeners: () => {\n entry.pending.forEach((controller, _, set) => {\n if (controller !== internalTaskController) {\n abortControllerWithReason(controller, listenerCancelled);\n set.delete(controller);\n }\n });\n },\n cancel: () => {\n abortControllerWithReason(internalTaskController, listenerCancelled);\n entry.pending.delete(internalTaskController);\n },\n throwIfCancelled: () => {\n validateActive(internalTaskController.signal);\n }\n })\n ));\n } catch (listenerError) {\n if (!(listenerError instanceof TaskAbortError)) {\n safelyNotifyError(onError, listenerError, {\n raisedBy: \"effect\"\n });\n }\n } finally {\n await Promise.all(autoJoinPromises);\n abortControllerWithReason(internalTaskController, listenerCompleted);\n entry.pending.delete(internalTaskController);\n }\n };\n const clearListenerMiddleware = createClearListenerMiddleware(listenerMap);\n const middleware = (api) => (next) => (action) => {\n if (!isAction3(action)) {\n return next(action);\n }\n if (addListener.match(action)) {\n return startListening(action.payload);\n }\n if (clearAllListeners.match(action)) {\n clearListenerMiddleware();\n return;\n }\n if (removeListener.match(action)) {\n return stopListening(action.payload);\n }\n let originalState = api.getState();\n const getOriginalState = () => {\n if (originalState === INTERNAL_NIL_TOKEN) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(23) : `${alm}: getOriginalState can only be called synchronously`);\n }\n return originalState;\n };\n let result;\n try {\n result = next(action);\n if (listenerMap.size > 0) {\n const currentState = api.getState();\n const listenerEntries = Array.from(listenerMap.values());\n for (const entry of listenerEntries) {\n let runListener = false;\n try {\n runListener = entry.predicate(action, currentState, originalState);\n } catch (predicateError) {\n runListener = false;\n safelyNotifyError(onError, predicateError, {\n raisedBy: \"predicate\"\n });\n }\n if (!runListener) {\n continue;\n }\n notifyListener(entry, action, api, getOriginalState);\n }\n }\n } finally {\n originalState = INTERNAL_NIL_TOKEN;\n }\n return result;\n };\n return {\n middleware,\n startListening,\n stopListening,\n clearListeners: clearListenerMiddleware\n };\n};\n\n// src/dynamicMiddleware/index.ts\nimport { compose as compose3 } from \"redux\";\nvar createMiddlewareEntry = (middleware) => ({\n id: nanoid(),\n middleware,\n applied: /* @__PURE__ */ new Map()\n});\nvar matchInstance = (instanceId) => (action) => action?.meta?.instanceId === instanceId;\nvar createDynamicMiddleware = () => {\n const instanceId = nanoid();\n const middlewareMap = /* @__PURE__ */ new Map();\n const withMiddleware = Object.assign(createAction(\"dynamicMiddleware/add\", (...middlewares) => ({\n payload: middlewares,\n meta: {\n instanceId\n }\n })), {\n withTypes: () => withMiddleware\n });\n const addMiddleware = Object.assign(function addMiddleware2(...middlewares) {\n middlewares.forEach((middleware2) => {\n let entry = find(Array.from(middlewareMap.values()), (entry2) => entry2.middleware === middleware2);\n if (!entry) {\n entry = createMiddlewareEntry(middleware2);\n }\n middlewareMap.set(entry.id, entry);\n });\n }, {\n withTypes: () => addMiddleware\n });\n const getFinalMiddleware = (api) => {\n const appliedMiddleware = Array.from(middlewareMap.values()).map((entry) => emplace(entry.applied, api, {\n insert: () => entry.middleware(api)\n }));\n return compose3(...appliedMiddleware);\n };\n const isWithMiddleware = isAllOf(withMiddleware, matchInstance(instanceId));\n const middleware = (api) => (next) => (action) => {\n if (isWithMiddleware(action)) {\n addMiddleware(...action.payload);\n return api.dispatch;\n }\n return getFinalMiddleware(api)(next)(action);\n };\n return {\n middleware,\n addMiddleware,\n withMiddleware,\n instanceId\n };\n};\n\n// src/combineSlices.ts\nimport { combineReducers as combineReducers2 } from \"redux\";\nvar isSliceLike = (maybeSliceLike) => \"reducerPath\" in maybeSliceLike && typeof maybeSliceLike.reducerPath === \"string\";\nvar getReducers = (slices) => slices.flatMap((sliceOrMap) => isSliceLike(sliceOrMap) ? [[sliceOrMap.reducerPath, sliceOrMap.reducer]] : Object.entries(sliceOrMap));\nvar ORIGINAL_STATE = Symbol.for(\"rtk-state-proxy-original\");\nvar isStateProxy = (value) => !!value && !!value[ORIGINAL_STATE];\nvar stateProxyMap = /* @__PURE__ */ new WeakMap();\nvar createStateProxy = (state, reducerMap) => emplace(stateProxyMap, state, {\n insert: () => new Proxy(state, {\n get: (target, prop, receiver) => {\n if (prop === ORIGINAL_STATE)\n return target;\n const result = Reflect.get(target, prop, receiver);\n if (typeof result === \"undefined\") {\n const reducer = reducerMap[prop.toString()];\n if (reducer) {\n const reducerResult = reducer(void 0, {\n type: nanoid()\n });\n if (typeof reducerResult === \"undefined\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(24) : `The slice reducer for key \"${prop.toString()}\" returned undefined when called for selector(). If the state passed to the reducer is undefined, you must explicitly return the initial state. The initial state may not be undefined. If you don't want to set a value for this reducer, you can use null instead of undefined.`);\n }\n return reducerResult;\n }\n }\n return result;\n }\n })\n});\nvar original = (state) => {\n if (!isStateProxy(state)) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(25) : \"original must be used on state Proxy\");\n }\n return state[ORIGINAL_STATE];\n};\nfunction combineSlices(...slices) {\n const reducerMap = Object.fromEntries(getReducers(slices));\n const getReducer = () => combineReducers2(reducerMap);\n let reducer = getReducer();\n function combinedReducer(state, action) {\n return reducer(state, action);\n }\n combinedReducer.withLazyLoadedSlices = () => combinedReducer;\n const inject = (slice, config = {}) => {\n const {\n reducerPath,\n reducer: reducerToInject\n } = slice;\n const currentReducer = reducerMap[reducerPath];\n if (!config.overrideExisting && currentReducer && currentReducer !== reducerToInject) {\n if (typeof process !== \"undefined\" && process.env.NODE_ENV === \"development\") {\n console.error(`called \\`inject\\` to override already-existing reducer ${reducerPath} without specifying \\`overrideExisting: true\\``);\n }\n return combinedReducer;\n }\n reducerMap[reducerPath] = reducerToInject;\n reducer = getReducer();\n return combinedReducer;\n };\n const selector = Object.assign(function makeSelector(selectorFn, selectState) {\n return function selector2(state, ...args) {\n return selectorFn(createStateProxy(selectState ? selectState(state, ...args) : state, reducerMap), ...args);\n };\n }, {\n original\n });\n return Object.assign(combinedReducer, {\n inject,\n selector\n });\n}\n\n// src/formatProdErrorMessage.ts\nfunction formatProdErrorMessage(code) {\n return `Minified Redux Toolkit error #${code}; visit https://redux-toolkit.js.org/Errors?code=${code} for the full message or use the non-minified dev environment for full errors. `;\n}\nexport {\n ReducerType,\n SHOULD_AUTOBATCH,\n TaskAbortError,\n Tuple,\n addListener,\n asyncThunkCreator,\n autoBatchEnhancer,\n buildCreateSlice,\n clearAllListeners,\n combineSlices,\n configureStore,\n createAction,\n createActionCreatorInvariantMiddleware,\n createAsyncThunk,\n createDraftSafeSelector,\n createDraftSafeSelectorCreator,\n createDynamicMiddleware,\n createEntityAdapter,\n createImmutableStateInvariantMiddleware,\n createListenerMiddleware,\n produce as createNextState,\n createReducer,\n createSelector,\n createSelectorCreator2 as createSelectorCreator,\n createSerializableStateInvariantMiddleware,\n createSlice,\n current2 as current,\n findNonSerializableValue,\n formatProdErrorMessage,\n freeze,\n isActionCreator,\n isAllOf,\n isAnyOf,\n isAsyncThunkAction,\n isDraft4 as isDraft,\n isFSA as isFluxStandardAction,\n isFulfilled,\n isImmutableDefault,\n isPending,\n isPlain,\n isRejected,\n isRejectedWithValue,\n lruMemoize,\n miniSerializeError,\n nanoid,\n original2 as original,\n prepareAutoBatched,\n removeListener,\n unwrapResult,\n weakMapMemoize2 as weakMapMemoize\n};\n//# sourceMappingURL=redux-toolkit.modern.mjs.map","// src/index.ts\nimport * as React2 from \"react\";\nimport { useSyncExternalStoreWithSelector as useSyncExternalStoreWithSelector2 } from \"use-sync-external-store/with-selector.js\";\n\n// src/utils/react.ts\nimport * as ReactOriginal from \"react\";\nvar React = (\n // prettier-ignore\n // @ts-ignore\n \"default\" in ReactOriginal ? ReactOriginal[\"default\"] : ReactOriginal\n);\n\n// src/components/Context.ts\nvar ContextKey = Symbol.for(`react-redux-context`);\nvar gT = typeof globalThis !== \"undefined\" ? globalThis : (\n /* fall back to a per-module scope (pre-8.1 behaviour) if `globalThis` is not available */\n {}\n);\nfunction getContext() {\n if (!React.createContext)\n return {};\n const contextMap = gT[ContextKey] ?? (gT[ContextKey] = /* @__PURE__ */ new Map());\n let realContext = contextMap.get(React.createContext);\n if (!realContext) {\n realContext = React.createContext(\n null\n );\n if (process.env.NODE_ENV !== \"production\") {\n realContext.displayName = \"ReactRedux\";\n }\n contextMap.set(React.createContext, realContext);\n }\n return realContext;\n}\nvar ReactReduxContext = /* @__PURE__ */ getContext();\n\n// src/utils/useSyncExternalStore.ts\nvar notInitialized = () => {\n throw new Error(\"uSES not initialized!\");\n};\n\n// src/hooks/useReduxContext.ts\nfunction createReduxContextHook(context = ReactReduxContext) {\n return function useReduxContext2() {\n const contextValue = React.useContext(context);\n if (process.env.NODE_ENV !== \"production\" && !contextValue) {\n throw new Error(\n \"could not find react-redux context value; please ensure the component is wrapped in a <Provider>\"\n );\n }\n return contextValue;\n };\n}\nvar useReduxContext = /* @__PURE__ */ createReduxContextHook();\n\n// src/hooks/useSelector.ts\nvar useSyncExternalStoreWithSelector = notInitialized;\nvar initializeUseSelector = (fn) => {\n useSyncExternalStoreWithSelector = fn;\n};\nvar refEquality = (a, b) => a === b;\nfunction createSelectorHook(context = ReactReduxContext) {\n const useReduxContext2 = context === ReactReduxContext ? useReduxContext : createReduxContextHook(context);\n const useSelector2 = (selector, equalityFnOrOptions = {}) => {\n const { equalityFn = refEquality, devModeChecks = {} } = typeof equalityFnOrOptions === \"function\" ? { equalityFn: equalityFnOrOptions } : equalityFnOrOptions;\n if (process.env.NODE_ENV !== \"production\") {\n if (!selector) {\n throw new Error(`You must pass a selector to useSelector`);\n }\n if (typeof selector !== \"function\") {\n throw new Error(`You must pass a function as a selector to useSelector`);\n }\n if (typeof equalityFn !== \"function\") {\n throw new Error(\n `You must pass a function as an equality function to useSelector`\n );\n }\n }\n const {\n store,\n subscription,\n getServerState,\n stabilityCheck,\n identityFunctionCheck\n } = useReduxContext2();\n const firstRun = React.useRef(true);\n const wrappedSelector = React.useCallback(\n {\n [selector.name](state) {\n const selected = selector(state);\n if (process.env.NODE_ENV !== \"production\") {\n const {\n identityFunctionCheck: finalIdentityFunctionCheck,\n stabilityCheck: finalStabilityCheck\n } = {\n stabilityCheck,\n identityFunctionCheck,\n ...devModeChecks\n };\n if (finalStabilityCheck === \"always\" || finalStabilityCheck === \"once\" && firstRun.current) {\n const toCompare = selector(state);\n if (!equalityFn(selected, toCompare)) {\n let stack = void 0;\n try {\n throw new Error();\n } catch (e) {\n ;\n ({ stack } = e);\n }\n console.warn(\n \"Selector \" + (selector.name || \"unknown\") + \" returned a different result when called with the same parameters. This can lead to unnecessary rerenders.\\nSelectors that return a new reference (such as an object or an array) should be memoized: https://redux.js.org/usage/deriving-data-selectors#optimizing-selectors-with-memoization\",\n {\n state,\n selected,\n selected2: toCompare,\n stack\n }\n );\n }\n }\n if (finalIdentityFunctionCheck === \"always\" || finalIdentityFunctionCheck === \"once\" && firstRun.current) {\n if (selected === state) {\n let stack = void 0;\n try {\n throw new Error();\n } catch (e) {\n ;\n ({ stack } = e);\n }\n console.warn(\n \"Selector \" + (selector.name || \"unknown\") + \" returned the root state when called. This can lead to unnecessary rerenders.\\nSelectors that return the entire state are almost certainly a mistake, as they will cause a rerender whenever *anything* in state changes.\",\n { stack }\n );\n }\n }\n if (firstRun.current)\n firstRun.current = false;\n }\n return selected;\n }\n }[selector.name],\n [selector, stabilityCheck, devModeChecks.stabilityCheck]\n );\n const selectedState = useSyncExternalStoreWithSelector(\n subscription.addNestedSub,\n store.getState,\n getServerState || store.getState,\n wrappedSelector,\n equalityFn\n );\n React.useDebugValue(selectedState);\n return selectedState;\n };\n Object.assign(useSelector2, {\n withTypes: () => useSelector2\n });\n return useSelector2;\n}\nvar useSelector = /* @__PURE__ */ createSelectorHook();\n\n// src/utils/react-is.ts\nvar REACT_ELEMENT_TYPE = Symbol.for(\"react.element\");\nvar REACT_PORTAL_TYPE = Symbol.for(\"react.portal\");\nvar REACT_FRAGMENT_TYPE = Symbol.for(\"react.fragment\");\nvar REACT_STRICT_MODE_TYPE = Symbol.for(\"react.strict_mode\");\nvar REACT_PROFILER_TYPE = Symbol.for(\"react.profiler\");\nvar REACT_PROVIDER_TYPE = Symbol.for(\"react.provider\");\nvar REACT_CONTEXT_TYPE = Symbol.for(\"react.context\");\nvar REACT_SERVER_CONTEXT_TYPE = Symbol.for(\"react.server_context\");\nvar REACT_FORWARD_REF_TYPE = Symbol.for(\"react.forward_ref\");\nvar REACT_SUSPENSE_TYPE = Symbol.for(\"react.suspense\");\nvar REACT_SUSPENSE_LIST_TYPE = Symbol.for(\"react.suspense_list\");\nvar REACT_MEMO_TYPE = Symbol.for(\"react.memo\");\nvar REACT_LAZY_TYPE = Symbol.for(\"react.lazy\");\nvar REACT_OFFSCREEN_TYPE = Symbol.for(\"react.offscreen\");\nvar REACT_CLIENT_REFERENCE = Symbol.for(\"react.client.reference\");\nvar ForwardRef = REACT_FORWARD_REF_TYPE;\nvar Memo = REACT_MEMO_TYPE;\nfunction isValidElementType(type) {\n if (typeof type === \"string\" || typeof type === \"function\") {\n return true;\n }\n if (type === REACT_FRAGMENT_TYPE || type === REACT_PROFILER_TYPE || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || type === REACT_OFFSCREEN_TYPE) {\n return true;\n }\n if (typeof type === \"object\" && type !== null) {\n if (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || // This needs to include all possible module reference object\n // types supported by any Flight configuration anywhere since\n // we don't know which Flight build this will end up being used\n // with.\n type.$$typeof === REACT_CLIENT_REFERENCE || type.getModuleId !== void 0) {\n return true;\n }\n }\n return false;\n}\nfunction typeOf(object) {\n if (typeof object === \"object\" && object !== null) {\n const $$typeof = object.$$typeof;\n switch ($$typeof) {\n case REACT_ELEMENT_TYPE: {\n const type = object.type;\n switch (type) {\n case REACT_FRAGMENT_TYPE:\n case REACT_PROFILER_TYPE:\n case REACT_STRICT_MODE_TYPE:\n case REACT_SUSPENSE_TYPE:\n case REACT_SUSPENSE_LIST_TYPE:\n return type;\n default: {\n const $$typeofType = type && type.$$typeof;\n switch ($$typeofType) {\n case REACT_SERVER_CONTEXT_TYPE:\n case REACT_CONTEXT_TYPE:\n case REACT_FORWARD_REF_TYPE:\n case REACT_LAZY_TYPE:\n case REACT_MEMO_TYPE:\n case REACT_PROVIDER_TYPE:\n return $$typeofType;\n default:\n return $$typeof;\n }\n }\n }\n }\n case REACT_PORTAL_TYPE: {\n return $$typeof;\n }\n }\n }\n return void 0;\n}\nfunction isContextConsumer(object) {\n return typeOf(object) === REACT_CONTEXT_TYPE;\n}\nfunction isMemo(object) {\n return typeOf(object) === REACT_MEMO_TYPE;\n}\n\n// src/utils/warning.ts\nfunction warning(message) {\n if (typeof console !== \"undefined\" && typeof console.error === \"function\") {\n console.error(message);\n }\n try {\n throw new Error(message);\n } catch (e) {\n }\n}\n\n// src/connect/verifySubselectors.ts\nfunction verify(selector, methodName) {\n if (!selector) {\n throw new Error(`Unexpected value for ${methodName} in connect.`);\n } else if (methodName === \"mapStateToProps\" || methodName === \"mapDispatchToProps\") {\n if (!Object.prototype.hasOwnProperty.call(selector, \"dependsOnOwnProps\")) {\n warning(\n `The selector for ${methodName} of connect did not specify a value for dependsOnOwnProps.`\n );\n }\n }\n}\nfunction verifySubselectors(mapStateToProps, mapDispatchToProps, mergeProps) {\n verify(mapStateToProps, \"mapStateToProps\");\n verify(mapDispatchToProps, \"mapDispatchToProps\");\n verify(mergeProps, \"mergeProps\");\n}\n\n// src/connect/selectorFactory.ts\nfunction pureFinalPropsSelectorFactory(mapStateToProps, mapDispatchToProps, mergeProps, dispatch, {\n areStatesEqual,\n areOwnPropsEqual,\n areStatePropsEqual\n}) {\n let hasRunAtLeastOnce = false;\n let state;\n let ownProps;\n let stateProps;\n let dispatchProps;\n let mergedProps;\n function handleFirstCall(firstState, firstOwnProps) {\n state = firstState;\n ownProps = firstOwnProps;\n stateProps = mapStateToProps(state, ownProps);\n dispatchProps = mapDispatchToProps(dispatch, ownProps);\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n hasRunAtLeastOnce = true;\n return mergedProps;\n }\n function handleNewPropsAndNewState() {\n stateProps = mapStateToProps(state, ownProps);\n if (mapDispatchToProps.dependsOnOwnProps)\n dispatchProps = mapDispatchToProps(dispatch, ownProps);\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n return mergedProps;\n }\n function handleNewProps() {\n if (mapStateToProps.dependsOnOwnProps)\n stateProps = mapStateToProps(state, ownProps);\n if (mapDispatchToProps.dependsOnOwnProps)\n dispatchProps = mapDispatchToProps(dispatch, ownProps);\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n return mergedProps;\n }\n function handleNewState() {\n const nextStateProps = mapStateToProps(state, ownProps);\n const statePropsChanged = !areStatePropsEqual(nextStateProps, stateProps);\n stateProps = nextStateProps;\n if (statePropsChanged)\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n return mergedProps;\n }\n function handleSubsequentCalls(nextState, nextOwnProps) {\n const propsChanged = !areOwnPropsEqual(nextOwnProps, ownProps);\n const stateChanged = !areStatesEqual(\n nextState,\n state,\n nextOwnProps,\n ownProps\n );\n state = nextState;\n ownProps = nextOwnProps;\n if (propsChanged && stateChanged)\n return handleNewPropsAndNewState();\n if (propsChanged)\n return handleNewProps();\n if (stateChanged)\n return handleNewState();\n return mergedProps;\n }\n return function pureFinalPropsSelector(nextState, nextOwnProps) {\n return hasRunAtLeastOnce ? handleSubsequentCalls(nextState, nextOwnProps) : handleFirstCall(nextState, nextOwnProps);\n };\n}\nfunction finalPropsSelectorFactory(dispatch, {\n initMapStateToProps,\n initMapDispatchToProps,\n initMergeProps,\n ...options\n}) {\n const mapStateToProps = initMapStateToProps(dispatch, options);\n const mapDispatchToProps = initMapDispatchToProps(dispatch, options);\n const mergeProps = initMergeProps(dispatch, options);\n if (process.env.NODE_ENV !== \"production\") {\n verifySubselectors(mapStateToProps, mapDispatchToProps, mergeProps);\n }\n return pureFinalPropsSelectorFactory(mapStateToProps, mapDispatchToProps, mergeProps, dispatch, options);\n}\n\n// src/utils/bindActionCreators.ts\nfunction bindActionCreators(actionCreators, dispatch) {\n const boundActionCreators = {};\n for (const key in actionCreators) {\n const actionCreator = actionCreators[key];\n if (typeof actionCreator === \"function\") {\n boundActionCreators[key] = (...args) => dispatch(actionCreator(...args));\n }\n }\n return boundActionCreators;\n}\n\n// src/utils/isPlainObject.ts\nfunction isPlainObject(obj) {\n if (typeof obj !== \"object\" || obj === null)\n return false;\n const proto = Object.getPrototypeOf(obj);\n if (proto === null)\n return true;\n let baseProto = proto;\n while (Object.getPrototypeOf(baseProto) !== null) {\n baseProto = Object.getPrototypeOf(baseProto);\n }\n return proto === baseProto;\n}\n\n// src/utils/verifyPlainObject.ts\nfunction verifyPlainObject(value, displayName, methodName) {\n if (!isPlainObject(value)) {\n warning(\n `${methodName}() in ${displayName} must return a plain object. Instead received ${value}.`\n );\n }\n}\n\n// src/connect/wrapMapToProps.ts\nfunction wrapMapToPropsConstant(getConstant) {\n return function initConstantSelector(dispatch) {\n const constant = getConstant(dispatch);\n function constantSelector() {\n return constant;\n }\n constantSelector.dependsOnOwnProps = false;\n return constantSelector;\n };\n}\nfunction getDependsOnOwnProps(mapToProps) {\n return mapToProps.dependsOnOwnProps ? Boolean(mapToProps.dependsOnOwnProps) : mapToProps.length !== 1;\n}\nfunction wrapMapToPropsFunc(mapToProps, methodName) {\n return function initProxySelector(dispatch, { displayName }) {\n const proxy = function mapToPropsProxy(stateOrDispatch, ownProps) {\n return proxy.dependsOnOwnProps ? proxy.mapToProps(stateOrDispatch, ownProps) : proxy.mapToProps(stateOrDispatch, void 0);\n };\n proxy.dependsOnOwnProps = true;\n proxy.mapToProps = function detectFactoryAndVerify(stateOrDispatch, ownProps) {\n proxy.mapToProps = mapToProps;\n proxy.dependsOnOwnProps = getDependsOnOwnProps(mapToProps);\n let props = proxy(stateOrDispatch, ownProps);\n if (typeof props === \"function\") {\n proxy.mapToProps = props;\n proxy.dependsOnOwnProps = getDependsOnOwnProps(props);\n props = proxy(stateOrDispatch, ownProps);\n }\n if (process.env.NODE_ENV !== \"production\")\n verifyPlainObject(props, displayName, methodName);\n return props;\n };\n return proxy;\n };\n}\n\n// src/connect/invalidArgFactory.ts\nfunction createInvalidArgFactory(arg, name) {\n return (dispatch, options) => {\n throw new Error(\n `Invalid value of type ${typeof arg} for ${name} argument when connecting component ${options.wrappedComponentName}.`\n );\n };\n}\n\n// src/connect/mapDispatchToProps.ts\nfunction mapDispatchToPropsFactory(mapDispatchToProps) {\n return mapDispatchToProps && typeof mapDispatchToProps === \"object\" ? wrapMapToPropsConstant(\n (dispatch) => (\n // @ts-ignore\n bindActionCreators(mapDispatchToProps, dispatch)\n )\n ) : !mapDispatchToProps ? wrapMapToPropsConstant((dispatch) => ({\n dispatch\n })) : typeof mapDispatchToProps === \"function\" ? (\n // @ts-ignore\n wrapMapToPropsFunc(mapDispatchToProps, \"mapDispatchToProps\")\n ) : createInvalidArgFactory(mapDispatchToProps, \"mapDispatchToProps\");\n}\n\n// src/connect/mapStateToProps.ts\nfunction mapStateToPropsFactory(mapStateToProps) {\n return !mapStateToProps ? wrapMapToPropsConstant(() => ({})) : typeof mapStateToProps === \"function\" ? (\n // @ts-ignore\n wrapMapToPropsFunc(mapStateToProps, \"mapStateToProps\")\n ) : createInvalidArgFactory(mapStateToProps, \"mapStateToProps\");\n}\n\n// src/connect/mergeProps.ts\nfunction defaultMergeProps(stateProps, dispatchProps, ownProps) {\n return { ...ownProps, ...stateProps, ...dispatchProps };\n}\nfunction wrapMergePropsFunc(mergeProps) {\n return function initMergePropsProxy(dispatch, { displayName, areMergedPropsEqual }) {\n let hasRunOnce = false;\n let mergedProps;\n return function mergePropsProxy(stateProps, dispatchProps, ownProps) {\n const nextMergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n if (hasRunOnce) {\n if (!areMergedPropsEqual(nextMergedProps, mergedProps))\n mergedProps = nextMergedProps;\n } else {\n hasRunOnce = true;\n mergedProps = nextMergedProps;\n if (process.env.NODE_ENV !== \"production\")\n verifyPlainObject(mergedProps, displayName, \"mergeProps\");\n }\n return mergedProps;\n };\n };\n}\nfunction mergePropsFactory(mergeProps) {\n return !mergeProps ? () => defaultMergeProps : typeof mergeProps === \"function\" ? wrapMergePropsFunc(mergeProps) : createInvalidArgFactory(mergeProps, \"mergeProps\");\n}\n\n// src/utils/batch.ts\nfunction defaultNoopBatch(callback) {\n callback();\n}\n\n// src/utils/Subscription.ts\nfunction createListenerCollection() {\n let first = null;\n let last = null;\n return {\n clear() {\n first = null;\n last = null;\n },\n notify() {\n defaultNoopBatch(() => {\n let listener = first;\n while (listener) {\n listener.callback();\n listener = listener.next;\n }\n });\n },\n get() {\n const listeners = [];\n let listener = first;\n while (listener) {\n listeners.push(listener);\n listener = listener.next;\n }\n return listeners;\n },\n subscribe(callback) {\n let isSubscribed = true;\n const listener = last = {\n callback,\n next: null,\n prev: last\n };\n if (listener.prev) {\n listener.prev.next = listener;\n } else {\n first = listener;\n }\n return function unsubscribe() {\n if (!isSubscribed || first === null)\n return;\n isSubscribed = false;\n if (listener.next) {\n listener.next.prev = listener.prev;\n } else {\n last = listener.prev;\n }\n if (listener.prev) {\n listener.prev.next = listener.next;\n } else {\n first = listener.next;\n }\n };\n }\n };\n}\nvar nullListeners = {\n notify() {\n },\n get: () => []\n};\nfunction createSubscription(store, parentSub) {\n let unsubscribe;\n let listeners = nullListeners;\n let subscriptionsAmount = 0;\n let selfSubscribed = false;\n function addNestedSub(listener) {\n trySubscribe();\n const cleanupListener = listeners.subscribe(listener);\n let removed = false;\n return () => {\n if (!removed) {\n removed = true;\n cleanupListener();\n tryUnsubscribe();\n }\n };\n }\n function notifyNestedSubs() {\n listeners.notify();\n }\n function handleChangeWrapper() {\n if (subscription.onStateChange) {\n subscription.onStateChange();\n }\n }\n function isSubscribed() {\n return selfSubscribed;\n }\n function trySubscribe() {\n subscriptionsAmount++;\n if (!unsubscribe) {\n unsubscribe = parentSub ? parentSub.addNestedSub(handleChangeWrapper) : store.subscribe(handleChangeWrapper);\n listeners = createListenerCollection();\n }\n }\n function tryUnsubscribe() {\n subscriptionsAmount--;\n if (unsubscribe && subscriptionsAmount === 0) {\n unsubscribe();\n unsubscribe = void 0;\n listeners.clear();\n listeners = nullListeners;\n }\n }\n function trySubscribeSelf() {\n if (!selfSubscribed) {\n selfSubscribed = true;\n trySubscribe();\n }\n }\n function tryUnsubscribeSelf() {\n if (selfSubscribed) {\n selfSubscribed = false;\n tryUnsubscribe();\n }\n }\n const subscription = {\n addNestedSub,\n notifyNestedSubs,\n handleChangeWrapper,\n isSubscribed,\n trySubscribe: trySubscribeSelf,\n tryUnsubscribe: tryUnsubscribeSelf,\n getListeners: () => listeners\n };\n return subscription;\n}\n\n// src/utils/useIsomorphicLayoutEffect.ts\nvar canUseDOM = !!(typeof window !== \"undefined\" && typeof window.document !== \"undefined\" && typeof window.document.createElement !== \"undefined\");\nvar useIsomorphicLayoutEffect = canUseDOM ? React.useLayoutEffect : React.useEffect;\n\n// src/utils/shallowEqual.ts\nfunction is(x, y) {\n if (x === y) {\n return x !== 0 || y !== 0 || 1 / x === 1 / y;\n } else {\n return x !== x && y !== y;\n }\n}\nfunction shallowEqual(objA, objB) {\n if (is(objA, objB))\n return true;\n if (typeof objA !== \"object\" || objA === null || typeof objB !== \"object\" || objB === null) {\n return false;\n }\n const keysA = Object.keys(objA);\n const keysB = Object.keys(objB);\n if (keysA.length !== keysB.length)\n return false;\n for (let i = 0; i < keysA.length; i++) {\n if (!Object.prototype.hasOwnProperty.call(objB, keysA[i]) || !is(objA[keysA[i]], objB[keysA[i]])) {\n return false;\n }\n }\n return true;\n}\n\n// src/utils/hoistStatics.ts\nvar REACT_STATICS = {\n childContextTypes: true,\n contextType: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n getDerivedStateFromError: true,\n getDerivedStateFromProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\nvar FORWARD_REF_STATICS = {\n $$typeof: true,\n render: true,\n defaultProps: true,\n displayName: true,\n propTypes: true\n};\nvar MEMO_STATICS = {\n $$typeof: true,\n compare: true,\n defaultProps: true,\n displayName: true,\n propTypes: true,\n type: true\n};\nvar TYPE_STATICS = {\n [ForwardRef]: FORWARD_REF_STATICS,\n [Memo]: MEMO_STATICS\n};\nfunction getStatics(component) {\n if (isMemo(component)) {\n return MEMO_STATICS;\n }\n return TYPE_STATICS[component[\"$$typeof\"]] || REACT_STATICS;\n}\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = Object.prototype;\nfunction hoistNonReactStatics(targetComponent, sourceComponent) {\n if (typeof sourceComponent !== \"string\") {\n if (objectPrototype) {\n const inheritedComponent = getPrototypeOf(sourceComponent);\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent);\n }\n }\n let keys = getOwnPropertyNames(sourceComponent);\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n const targetStatics = getStatics(targetComponent);\n const sourceStatics = getStatics(sourceComponent);\n for (let i = 0; i < keys.length; ++i) {\n const key = keys[i];\n if (!KNOWN_STATICS[key] && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) {\n const descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n try {\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {\n }\n }\n }\n }\n return targetComponent;\n}\n\n// src/components/connect.tsx\nvar useSyncExternalStore = notInitialized;\nvar initializeConnect = (fn) => {\n useSyncExternalStore = fn;\n};\nvar NO_SUBSCRIPTION_ARRAY = [null, null];\nvar stringifyComponent = (Comp) => {\n try {\n return JSON.stringify(Comp);\n } catch (err) {\n return String(Comp);\n }\n};\nfunction useIsomorphicLayoutEffectWithArgs(effectFunc, effectArgs, dependencies) {\n useIsomorphicLayoutEffect(() => effectFunc(...effectArgs), dependencies);\n}\nfunction captureWrapperProps(lastWrapperProps, lastChildProps, renderIsScheduled, wrapperProps, childPropsFromStoreUpdate, notifyNestedSubs) {\n lastWrapperProps.current = wrapperProps;\n renderIsScheduled.current = false;\n if (childPropsFromStoreUpdate.current) {\n childPropsFromStoreUpdate.current = null;\n notifyNestedSubs();\n }\n}\nfunction subscribeUpdates(shouldHandleStateChanges, store, subscription, childPropsSelector, lastWrapperProps, lastChildProps, renderIsScheduled, isMounted, childPropsFromStoreUpdate, notifyNestedSubs, additionalSubscribeListener) {\n if (!shouldHandleStateChanges)\n return () => {\n };\n let didUnsubscribe = false;\n let lastThrownError = null;\n const checkForUpdates = () => {\n if (didUnsubscribe || !isMounted.current) {\n return;\n }\n const latestStoreState = store.getState();\n let newChildProps, error;\n try {\n newChildProps = childPropsSelector(\n latestStoreState,\n lastWrapperProps.current\n );\n } catch (e) {\n error = e;\n lastThrownError = e;\n }\n if (!error) {\n lastThrownError = null;\n }\n if (newChildProps === lastChildProps.current) {\n if (!renderIsScheduled.current) {\n notifyNestedSubs();\n }\n } else {\n lastChildProps.current = newChildProps;\n childPropsFromStoreUpdate.current = newChildProps;\n renderIsScheduled.current = true;\n additionalSubscribeListener();\n }\n };\n subscription.onStateChange = checkForUpdates;\n subscription.trySubscribe();\n checkForUpdates();\n const unsubscribeWrapper = () => {\n didUnsubscribe = true;\n subscription.tryUnsubscribe();\n subscription.onStateChange = null;\n if (lastThrownError) {\n throw lastThrownError;\n }\n };\n return unsubscribeWrapper;\n}\nfunction strictEqual(a, b) {\n return a === b;\n}\nvar hasWarnedAboutDeprecatedPureOption = false;\nfunction connect(mapStateToProps, mapDispatchToProps, mergeProps, {\n // The `pure` option has been removed, so TS doesn't like us destructuring this to check its existence.\n // @ts-ignore\n pure,\n areStatesEqual = strictEqual,\n areOwnPropsEqual = shallowEqual,\n areStatePropsEqual = shallowEqual,\n areMergedPropsEqual = shallowEqual,\n // use React's forwardRef to expose a ref of the wrapped component\n forwardRef = false,\n // the context consumer to use\n context = ReactReduxContext\n} = {}) {\n if (process.env.NODE_ENV !== \"production\") {\n if (pure !== void 0 && !hasWarnedAboutDeprecatedPureOption) {\n hasWarnedAboutDeprecatedPureOption = true;\n warning(\n 'The `pure` option has been removed. `connect` is now always a \"pure/memoized\" component'\n );\n }\n }\n const Context = context;\n const initMapStateToProps = mapStateToPropsFactory(mapStateToProps);\n const initMapDispatchToProps = mapDispatchToPropsFactory(mapDispatchToProps);\n const initMergeProps = mergePropsFactory(mergeProps);\n const shouldHandleStateChanges = Boolean(mapStateToProps);\n const wrapWithConnect = (WrappedComponent) => {\n if (process.env.NODE_ENV !== \"production\") {\n const isValid = /* @__PURE__ */ isValidElementType(WrappedComponent);\n if (!isValid)\n throw new Error(\n `You must pass a component to the function returned by connect. Instead received ${stringifyComponent(\n WrappedComponent\n )}`\n );\n }\n const wrappedComponentName = WrappedComponent.displayName || WrappedComponent.name || \"Component\";\n const displayName = `Connect(${wrappedComponentName})`;\n const selectorFactoryOptions = {\n shouldHandleStateChanges,\n displayName,\n wrappedComponentName,\n WrappedComponent,\n // @ts-ignore\n initMapStateToProps,\n // @ts-ignore\n initMapDispatchToProps,\n initMergeProps,\n areStatesEqual,\n areStatePropsEqual,\n areOwnPropsEqual,\n areMergedPropsEqual\n };\n function ConnectFunction(props) {\n const [propsContext, reactReduxForwardedRef, wrapperProps] = React.useMemo(() => {\n const { reactReduxForwardedRef: reactReduxForwardedRef2, ...wrapperProps2 } = props;\n return [props.context, reactReduxForwardedRef2, wrapperProps2];\n }, [props]);\n const ContextToUse = React.useMemo(() => {\n let ResultContext = Context;\n if (propsContext?.Consumer) {\n if (process.env.NODE_ENV !== \"production\") {\n const isValid = /* @__PURE__ */ isContextConsumer(\n // @ts-ignore\n /* @__PURE__ */ React.createElement(propsContext.Consumer, null)\n );\n if (!isValid) {\n throw new Error(\n \"You must pass a valid React context consumer as `props.context`\"\n );\n }\n ResultContext = propsContext;\n }\n }\n return ResultContext;\n }, [propsContext, Context]);\n const contextValue = React.useContext(ContextToUse);\n const didStoreComeFromProps = Boolean(props.store) && Boolean(props.store.getState) && Boolean(props.store.dispatch);\n const didStoreComeFromContext = Boolean(contextValue) && Boolean(contextValue.store);\n if (process.env.NODE_ENV !== \"production\" && !didStoreComeFromProps && !didStoreComeFromContext) {\n throw new Error(\n `Could not find \"store\" in the context of \"${displayName}\". Either wrap the root component in a <Provider>, or pass a custom React context provider to <Provider> and the corresponding React context consumer to ${displayName} in connect options.`\n );\n }\n const store = didStoreComeFromProps ? props.store : contextValue.store;\n const getServerState = didStoreComeFromContext ? contextValue.getServerState : store.getState;\n const childPropsSelector = React.useMemo(() => {\n return finalPropsSelectorFactory(store.dispatch, selectorFactoryOptions);\n }, [store]);\n const [subscription, notifyNestedSubs] = React.useMemo(() => {\n if (!shouldHandleStateChanges)\n return NO_SUBSCRIPTION_ARRAY;\n const subscription2 = createSubscription(\n store,\n didStoreComeFromProps ? void 0 : contextValue.subscription\n );\n const notifyNestedSubs2 = subscription2.notifyNestedSubs.bind(subscription2);\n return [subscription2, notifyNestedSubs2];\n }, [store, didStoreComeFromProps, contextValue]);\n const overriddenContextValue = React.useMemo(() => {\n if (didStoreComeFromProps) {\n return contextValue;\n }\n return {\n ...contextValue,\n subscription\n };\n }, [didStoreComeFromProps, contextValue, subscription]);\n const lastChildProps = React.useRef();\n const lastWrapperProps = React.useRef(wrapperProps);\n const childPropsFromStoreUpdate = React.useRef();\n const renderIsScheduled = React.useRef(false);\n const isProcessingDispatch = React.useRef(false);\n const isMounted = React.useRef(false);\n const latestSubscriptionCallbackError = React.useRef();\n useIsomorphicLayoutEffect(() => {\n isMounted.current = true;\n return () => {\n isMounted.current = false;\n };\n }, []);\n const actualChildPropsSelector = React.useMemo(() => {\n const selector = () => {\n if (childPropsFromStoreUpdate.current && wrapperProps === lastWrapperProps.current) {\n return childPropsFromStoreUpdate.current;\n }\n return childPropsSelector(store.getState(), wrapperProps);\n };\n return selector;\n }, [store, wrapperProps]);\n const subscribeForReact = React.useMemo(() => {\n const subscribe = (reactListener) => {\n if (!subscription) {\n return () => {\n };\n }\n return subscribeUpdates(\n shouldHandleStateChanges,\n store,\n subscription,\n // @ts-ignore\n childPropsSelector,\n lastWrapperProps,\n lastChildProps,\n renderIsScheduled,\n isMounted,\n childPropsFromStoreUpdate,\n notifyNestedSubs,\n reactListener\n );\n };\n return subscribe;\n }, [subscription]);\n useIsomorphicLayoutEffectWithArgs(captureWrapperProps, [\n lastWrapperProps,\n lastChildProps,\n renderIsScheduled,\n wrapperProps,\n childPropsFromStoreUpdate,\n notifyNestedSubs\n ]);\n let actualChildProps;\n try {\n actualChildProps = useSyncExternalStore(\n // TODO We're passing through a big wrapper that does a bunch of extra side effects besides subscribing\n subscribeForReact,\n // TODO This is incredibly hacky. We've already processed the store update and calculated new child props,\n // TODO and we're just passing that through so it triggers a re-render for us rather than relying on `uSES`.\n actualChildPropsSelector,\n getServerState ? () => childPropsSelector(getServerState(), wrapperProps) : actualChildPropsSelector\n );\n } catch (err) {\n if (latestSubscriptionCallbackError.current) {\n ;\n err.message += `\nThe error may be correlated with this previous error:\n${latestSubscriptionCallbackError.current.stack}\n\n`;\n }\n throw err;\n }\n useIsomorphicLayoutEffect(() => {\n latestSubscriptionCallbackError.current = void 0;\n childPropsFromStoreUpdate.current = void 0;\n lastChildProps.current = actualChildProps;\n });\n const renderedWrappedComponent = React.useMemo(() => {\n return (\n // @ts-ignore\n /* @__PURE__ */ React.createElement(\n WrappedComponent,\n {\n ...actualChildProps,\n ref: reactReduxForwardedRef\n }\n )\n );\n }, [reactReduxForwardedRef, WrappedComponent, actualChildProps]);\n const renderedChild = React.useMemo(() => {\n if (shouldHandleStateChanges) {\n return /* @__PURE__ */ React.createElement(ContextToUse.Provider, { value: overriddenContextValue }, renderedWrappedComponent);\n }\n return renderedWrappedComponent;\n }, [ContextToUse, renderedWrappedComponent, overriddenContextValue]);\n return renderedChild;\n }\n const _Connect = React.memo(ConnectFunction);\n const Connect = _Connect;\n Connect.WrappedComponent = WrappedComponent;\n Connect.displayName = ConnectFunction.displayName = displayName;\n if (forwardRef) {\n const _forwarded = React.forwardRef(function forwardConnectRef(props, ref) {\n return /* @__PURE__ */ React.createElement(Connect, { ...props, reactReduxForwardedRef: ref });\n });\n const forwarded = _forwarded;\n forwarded.displayName = displayName;\n forwarded.WrappedComponent = WrappedComponent;\n return /* @__PURE__ */ hoistNonReactStatics(forwarded, WrappedComponent);\n }\n return /* @__PURE__ */ hoistNonReactStatics(Connect, WrappedComponent);\n };\n return wrapWithConnect;\n}\nvar connect_default = connect;\n\n// src/components/Provider.tsx\nfunction Provider({\n store,\n context,\n children,\n serverState,\n stabilityCheck = \"once\",\n identityFunctionCheck = \"once\"\n}) {\n const contextValue = React.useMemo(() => {\n const subscription = createSubscription(store);\n return {\n store,\n subscription,\n getServerState: serverState ? () => serverState : void 0,\n stabilityCheck,\n identityFunctionCheck\n };\n }, [store, serverState, stabilityCheck, identityFunctionCheck]);\n const previousState = React.useMemo(() => store.getState(), [store]);\n useIsomorphicLayoutEffect(() => {\n const { subscription } = contextValue;\n subscription.onStateChange = subscription.notifyNestedSubs;\n subscription.trySubscribe();\n if (previousState !== store.getState()) {\n subscription.notifyNestedSubs();\n }\n return () => {\n subscription.tryUnsubscribe();\n subscription.onStateChange = void 0;\n };\n }, [contextValue, previousState]);\n const Context = context || ReactReduxContext;\n return /* @__PURE__ */ React.createElement(Context.Provider, { value: contextValue }, children);\n}\nvar Provider_default = Provider;\n\n// src/hooks/useStore.ts\nfunction createStoreHook(context = ReactReduxContext) {\n const useReduxContext2 = context === ReactReduxContext ? useReduxContext : (\n // @ts-ignore\n createReduxContextHook(context)\n );\n const useStore2 = () => {\n const { store } = useReduxContext2();\n return store;\n };\n Object.assign(useStore2, {\n withTypes: () => useStore2\n });\n return useStore2;\n}\nvar useStore = /* @__PURE__ */ createStoreHook();\n\n// src/hooks/useDispatch.ts\nfunction createDispatchHook(context = ReactReduxContext) {\n const useStore2 = context === ReactReduxContext ? useStore : createStoreHook(context);\n const useDispatch2 = () => {\n const store = useStore2();\n return store.dispatch;\n };\n Object.assign(useDispatch2, {\n withTypes: () => useDispatch2\n });\n return useDispatch2;\n}\nvar useDispatch = /* @__PURE__ */ createDispatchHook();\n\n// src/exports.ts\nvar batch = defaultNoopBatch;\n\n// src/index.ts\ninitializeUseSelector(useSyncExternalStoreWithSelector2);\ninitializeConnect(React2.useSyncExternalStore);\nexport {\n Provider_default as Provider,\n ReactReduxContext,\n batch,\n connect_default as connect,\n createDispatchHook,\n createSelectorHook,\n createStoreHook,\n shallowEqual,\n useDispatch,\n useSelector,\n useStore\n};\n//# sourceMappingURL=react-redux.mjs.map","// src/utils/formatProdErrorMessage.ts\nfunction formatProdErrorMessage(code) {\n return `Minified Redux error #${code}; visit https://redux.js.org/Errors?code=${code} for the full message or use the non-minified dev environment for full errors. `;\n}\n\n// src/utils/symbol-observable.ts\nvar $$observable = /* @__PURE__ */ (() => typeof Symbol === \"function\" && Symbol.observable || \"@@observable\")();\nvar symbol_observable_default = $$observable;\n\n// src/utils/actionTypes.ts\nvar randomString = () => Math.random().toString(36).substring(7).split(\"\").join(\".\");\nvar ActionTypes = {\n INIT: `@@redux/INIT${/* @__PURE__ */ randomString()}`,\n REPLACE: `@@redux/REPLACE${/* @__PURE__ */ randomString()}`,\n PROBE_UNKNOWN_ACTION: () => `@@redux/PROBE_UNKNOWN_ACTION${randomString()}`\n};\nvar actionTypes_default = ActionTypes;\n\n// src/utils/isPlainObject.ts\nfunction isPlainObject(obj) {\n if (typeof obj !== \"object\" || obj === null)\n return false;\n let proto = obj;\n while (Object.getPrototypeOf(proto) !== null) {\n proto = Object.getPrototypeOf(proto);\n }\n return Object.getPrototypeOf(obj) === proto || Object.getPrototypeOf(obj) === null;\n}\n\n// src/utils/kindOf.ts\nfunction miniKindOf(val) {\n if (val === void 0)\n return \"undefined\";\n if (val === null)\n return \"null\";\n const type = typeof val;\n switch (type) {\n case \"boolean\":\n case \"string\":\n case \"number\":\n case \"symbol\":\n case \"function\": {\n return type;\n }\n }\n if (Array.isArray(val))\n return \"array\";\n if (isDate(val))\n return \"date\";\n if (isError(val))\n return \"error\";\n const constructorName = ctorName(val);\n switch (constructorName) {\n case \"Symbol\":\n case \"Promise\":\n case \"WeakMap\":\n case \"WeakSet\":\n case \"Map\":\n case \"Set\":\n return constructorName;\n }\n return Object.prototype.toString.call(val).slice(8, -1).toLowerCase().replace(/\\s/g, \"\");\n}\nfunction ctorName(val) {\n return typeof val.constructor === \"function\" ? val.constructor.name : null;\n}\nfunction isError(val) {\n return val instanceof Error || typeof val.message === \"string\" && val.constructor && typeof val.constructor.stackTraceLimit === \"number\";\n}\nfunction isDate(val) {\n if (val instanceof Date)\n return true;\n return typeof val.toDateString === \"function\" && typeof val.getDate === \"function\" && typeof val.setDate === \"function\";\n}\nfunction kindOf(val) {\n let typeOfVal = typeof val;\n if (process.env.NODE_ENV !== \"production\") {\n typeOfVal = miniKindOf(val);\n }\n return typeOfVal;\n}\n\n// src/createStore.ts\nfunction createStore(reducer, preloadedState, enhancer) {\n if (typeof reducer !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(2) : `Expected the root reducer to be a function. Instead, received: '${kindOf(reducer)}'`);\n }\n if (typeof preloadedState === \"function\" && typeof enhancer === \"function\" || typeof enhancer === \"function\" && typeof arguments[3] === \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(0) : \"It looks like you are passing several store enhancers to createStore(). This is not supported. Instead, compose them together to a single function. See https://redux.js.org/tutorials/fundamentals/part-4-store#creating-a-store-with-enhancers for an example.\");\n }\n if (typeof preloadedState === \"function\" && typeof enhancer === \"undefined\") {\n enhancer = preloadedState;\n preloadedState = void 0;\n }\n if (typeof enhancer !== \"undefined\") {\n if (typeof enhancer !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(1) : `Expected the enhancer to be a function. Instead, received: '${kindOf(enhancer)}'`);\n }\n return enhancer(createStore)(reducer, preloadedState);\n }\n let currentReducer = reducer;\n let currentState = preloadedState;\n let currentListeners = /* @__PURE__ */ new Map();\n let nextListeners = currentListeners;\n let listenerIdCounter = 0;\n let isDispatching = false;\n function ensureCanMutateNextListeners() {\n if (nextListeners === currentListeners) {\n nextListeners = /* @__PURE__ */ new Map();\n currentListeners.forEach((listener, key) => {\n nextListeners.set(key, listener);\n });\n }\n }\n function getState() {\n if (isDispatching) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(3) : \"You may not call store.getState() while the reducer is executing. The reducer has already received the state as an argument. Pass it down from the top reducer instead of reading it from the store.\");\n }\n return currentState;\n }\n function subscribe(listener) {\n if (typeof listener !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(4) : `Expected the listener to be a function. Instead, received: '${kindOf(listener)}'`);\n }\n if (isDispatching) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(5) : \"You may not call store.subscribe() while the reducer is executing. If you would like to be notified after the store has been updated, subscribe from a component and invoke store.getState() in the callback to access the latest state. See https://redux.js.org/api/store#subscribelistener for more details.\");\n }\n let isSubscribed = true;\n ensureCanMutateNextListeners();\n const listenerId = listenerIdCounter++;\n nextListeners.set(listenerId, listener);\n return function unsubscribe() {\n if (!isSubscribed) {\n return;\n }\n if (isDispatching) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(6) : \"You may not unsubscribe from a store listener while the reducer is executing. See https://redux.js.org/api/store#subscribelistener for more details.\");\n }\n isSubscribed = false;\n ensureCanMutateNextListeners();\n nextListeners.delete(listenerId);\n currentListeners = null;\n };\n }\n function dispatch(action) {\n if (!isPlainObject(action)) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(7) : `Actions must be plain objects. Instead, the actual type was: '${kindOf(action)}'. You may need to add middleware to your store setup to handle dispatching other values, such as 'redux-thunk' to handle dispatching functions. See https://redux.js.org/tutorials/fundamentals/part-4-store#middleware and https://redux.js.org/tutorials/fundamentals/part-6-async-logic#using-the-redux-thunk-middleware for examples.`);\n }\n if (typeof action.type === \"undefined\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(8) : 'Actions may not have an undefined \"type\" property. You may have misspelled an action type string constant.');\n }\n if (typeof action.type !== \"string\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(17) : `Action \"type\" property must be a string. Instead, the actual type was: '${kindOf(action.type)}'. Value was: '${action.type}' (stringified)`);\n }\n if (isDispatching) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(9) : \"Reducers may not dispatch actions.\");\n }\n try {\n isDispatching = true;\n currentState = currentReducer(currentState, action);\n } finally {\n isDispatching = false;\n }\n const listeners = currentListeners = nextListeners;\n listeners.forEach((listener) => {\n listener();\n });\n return action;\n }\n function replaceReducer(nextReducer) {\n if (typeof nextReducer !== \"function\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(10) : `Expected the nextReducer to be a function. Instead, received: '${kindOf(nextReducer)}`);\n }\n currentReducer = nextReducer;\n dispatch({\n type: actionTypes_default.REPLACE\n });\n }\n function observable() {\n const outerSubscribe = subscribe;\n return {\n /**\n * The minimal observable subscription method.\n * @param observer Any object that can be used as an observer.\n * The observer object should have a `next` method.\n * @returns An object with an `unsubscribe` method that can\n * be used to unsubscribe the observable from the store, and prevent further\n * emission of values from the observable.\n */\n subscribe(observer) {\n if (typeof observer !== \"object\" || observer === null) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(11) : `Expected the observer to be an object. Instead, received: '${kindOf(observer)}'`);\n }\n function observeState() {\n const observerAsObserver = observer;\n if (observerAsObserver.next) {\n observerAsObserver.next(getState());\n }\n }\n observeState();\n const unsubscribe = outerSubscribe(observeState);\n return {\n unsubscribe\n };\n },\n [symbol_observable_default]() {\n return this;\n }\n };\n }\n dispatch({\n type: actionTypes_default.INIT\n });\n const store = {\n dispatch,\n subscribe,\n getState,\n replaceReducer,\n [symbol_observable_default]: observable\n };\n return store;\n}\nfunction legacy_createStore(reducer, preloadedState, enhancer) {\n return createStore(reducer, preloadedState, enhancer);\n}\n\n// src/utils/warning.ts\nfunction warning(message) {\n if (typeof console !== \"undefined\" && typeof console.error === \"function\") {\n console.error(message);\n }\n try {\n throw new Error(message);\n } catch (e) {\n }\n}\n\n// src/combineReducers.ts\nfunction getUnexpectedStateShapeWarningMessage(inputState, reducers, action, unexpectedKeyCache) {\n const reducerKeys = Object.keys(reducers);\n const argumentName = action && action.type === actionTypes_default.INIT ? \"preloadedState argument passed to createStore\" : \"previous state received by the reducer\";\n if (reducerKeys.length === 0) {\n return \"Store does not have a valid reducer. Make sure the argument passed to combineReducers is an object whose values are reducers.\";\n }\n if (!isPlainObject(inputState)) {\n return `The ${argumentName} has unexpected type of \"${kindOf(inputState)}\". Expected argument to be an object with the following keys: \"${reducerKeys.join('\", \"')}\"`;\n }\n const unexpectedKeys = Object.keys(inputState).filter((key) => !reducers.hasOwnProperty(key) && !unexpectedKeyCache[key]);\n unexpectedKeys.forEach((key) => {\n unexpectedKeyCache[key] = true;\n });\n if (action && action.type === actionTypes_default.REPLACE)\n return;\n if (unexpectedKeys.length > 0) {\n return `Unexpected ${unexpectedKeys.length > 1 ? \"keys\" : \"key\"} \"${unexpectedKeys.join('\", \"')}\" found in ${argumentName}. Expected to find one of the known reducer keys instead: \"${reducerKeys.join('\", \"')}\". Unexpected keys will be ignored.`;\n }\n}\nfunction assertReducerShape(reducers) {\n Object.keys(reducers).forEach((key) => {\n const reducer = reducers[key];\n const initialState = reducer(void 0, {\n type: actionTypes_default.INIT\n });\n if (typeof initialState === \"undefined\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(12) : `The slice reducer for key \"${key}\" returned undefined during initialization. If the state passed to the reducer is undefined, you must explicitly return the initial state. The initial state may not be undefined. If you don't want to set a value for this reducer, you can use null instead of undefined.`);\n }\n if (typeof reducer(void 0, {\n type: actionTypes_default.PROBE_UNKNOWN_ACTION()\n }) === \"undefined\") {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(13) : `The slice reducer for key \"${key}\" returned undefined when probed with a random type. Don't try to handle '${actionTypes_default.INIT}' or other actions in \"redux/*\" namespace. They are considered private. Instead, you must return the current state for any unknown actions, unless it is undefined, in which case you must return the initial state, regardless of the action type. The initial state may not be undefined, but can be null.`);\n }\n });\n}\nfunction combineReducers(reducers) {\n const reducerKeys = Object.keys(reducers);\n const finalReducers = {};\n for (let i = 0; i < reducerKeys.length; i++) {\n const key = reducerKeys[i];\n if (process.env.NODE_ENV !== \"production\") {\n if (typeof reducers[key] === \"undefined\") {\n warning(`No reducer provided for key \"${key}\"`);\n }\n }\n if (typeof reducers[key] === \"function\") {\n finalReducers[key] = reducers[key];\n }\n }\n const finalReducerKeys = Object.keys(finalReducers);\n let unexpectedKeyCache;\n if (process.env.NODE_ENV !== \"production\") {\n unexpectedKeyCache = {};\n }\n let shapeAssertionError;\n try {\n assertReducerShape(finalReducers);\n } catch (e) {\n shapeAssertionError = e;\n }\n return function combination(state = {}, action) {\n if (shapeAssertionError) {\n throw shapeAssertionError;\n }\n if (process.env.NODE_ENV !== \"production\") {\n const warningMessage = getUnexpectedStateShapeWarningMessage(state, finalReducers, action, unexpectedKeyCache);\n if (warningMessage) {\n warning(warningMessage);\n }\n }\n let hasChanged = false;\n const nextState = {};\n for (let i = 0; i < finalReducerKeys.length; i++) {\n const key = finalReducerKeys[i];\n const reducer = finalReducers[key];\n const previousStateForKey = state[key];\n const nextStateForKey = reducer(previousStateForKey, action);\n if (typeof nextStateForKey === \"undefined\") {\n const actionType = action && action.type;\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(14) : `When called with an action of type ${actionType ? `\"${String(actionType)}\"` : \"(unknown type)\"}, the slice reducer for key \"${key}\" returned undefined. To ignore an action, you must explicitly return the previous state. If you want this reducer to hold no value, you can return null instead of undefined.`);\n }\n nextState[key] = nextStateForKey;\n hasChanged = hasChanged || nextStateForKey !== previousStateForKey;\n }\n hasChanged = hasChanged || finalReducerKeys.length !== Object.keys(state).length;\n return hasChanged ? nextState : state;\n };\n}\n\n// src/bindActionCreators.ts\nfunction bindActionCreator(actionCreator, dispatch) {\n return function(...args) {\n return dispatch(actionCreator.apply(this, args));\n };\n}\nfunction bindActionCreators(actionCreators, dispatch) {\n if (typeof actionCreators === \"function\") {\n return bindActionCreator(actionCreators, dispatch);\n }\n if (typeof actionCreators !== \"object\" || actionCreators === null) {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(16) : `bindActionCreators expected an object or a function, but instead received: '${kindOf(actionCreators)}'. Did you write \"import ActionCreators from\" instead of \"import * as ActionCreators from\"?`);\n }\n const boundActionCreators = {};\n for (const key in actionCreators) {\n const actionCreator = actionCreators[key];\n if (typeof actionCreator === \"function\") {\n boundActionCreators[key] = bindActionCreator(actionCreator, dispatch);\n }\n }\n return boundActionCreators;\n}\n\n// src/compose.ts\nfunction compose(...funcs) {\n if (funcs.length === 0) {\n return (arg) => arg;\n }\n if (funcs.length === 1) {\n return funcs[0];\n }\n return funcs.reduce((a, b) => (...args) => a(b(...args)));\n}\n\n// src/applyMiddleware.ts\nfunction applyMiddleware(...middlewares) {\n return (createStore2) => (reducer, preloadedState) => {\n const store = createStore2(reducer, preloadedState);\n let dispatch = () => {\n throw new Error(process.env.NODE_ENV === \"production\" ? formatProdErrorMessage(15) : \"Dispatching while constructing your middleware is not allowed. Other middleware would not be applied to this dispatch.\");\n };\n const middlewareAPI = {\n getState: store.getState,\n dispatch: (action, ...args) => dispatch(action, ...args)\n };\n const chain = middlewares.map((middleware) => middleware(middlewareAPI));\n dispatch = compose(...chain)(store.dispatch);\n return {\n ...store,\n dispatch\n };\n };\n}\n\n// src/utils/isAction.ts\nfunction isAction(action) {\n return isPlainObject(action) && \"type\" in action && typeof action.type === \"string\";\n}\nexport {\n actionTypes_default as __DO_NOT_USE__ActionTypes,\n applyMiddleware,\n bindActionCreators,\n combineReducers,\n compose,\n createStore,\n isAction,\n isPlainObject,\n legacy_createStore\n};\n//# sourceMappingURL=redux.mjs.map","// src/devModeChecks/identityFunctionCheck.ts\nvar runIdentityFunctionCheck = (resultFunc, inputSelectorsResults, outputSelectorResult) => {\n if (inputSelectorsResults.length === 1 && inputSelectorsResults[0] === outputSelectorResult) {\n let isInputSameAsOutput = false;\n try {\n const emptyObject = {};\n if (resultFunc(emptyObject) === emptyObject)\n isInputSameAsOutput = true;\n } catch {\n }\n if (isInputSameAsOutput) {\n let stack = void 0;\n try {\n throw new Error();\n } catch (e) {\n ;\n ({ stack } = e);\n }\n console.warn(\n \"The result function returned its own inputs without modification. e.g\\n`createSelector([state => state.todos], todos => todos)`\\nThis could lead to inefficient memoization and unnecessary re-renders.\\nEnsure transformation logic is in the result function, and extraction logic is in the input selectors.\",\n { stack }\n );\n }\n }\n};\n\n// src/devModeChecks/inputStabilityCheck.ts\nvar runInputStabilityCheck = (inputSelectorResultsObject, options, inputSelectorArgs) => {\n const { memoize, memoizeOptions } = options;\n const { inputSelectorResults, inputSelectorResultsCopy } = inputSelectorResultsObject;\n const createAnEmptyObject = memoize(() => ({}), ...memoizeOptions);\n const areInputSelectorResultsEqual = createAnEmptyObject.apply(null, inputSelectorResults) === createAnEmptyObject.apply(null, inputSelectorResultsCopy);\n if (!areInputSelectorResultsEqual) {\n let stack = void 0;\n try {\n throw new Error();\n } catch (e) {\n ;\n ({ stack } = e);\n }\n console.warn(\n \"An input selector returned a different result when passed same arguments.\\nThis means your output selector will likely run more frequently than intended.\\nAvoid returning a new reference inside your input selector, e.g.\\n`createSelector([state => state.todos.map(todo => todo.id)], todoIds => todoIds.length)`\",\n {\n arguments: inputSelectorArgs,\n firstInputs: inputSelectorResults,\n secondInputs: inputSelectorResultsCopy,\n stack\n }\n );\n }\n};\n\n// src/devModeChecks/setGlobalDevModeChecks.ts\nvar globalDevModeChecks = {\n inputStabilityCheck: \"once\",\n identityFunctionCheck: \"once\"\n};\nvar setGlobalDevModeChecks = (devModeChecks) => {\n Object.assign(globalDevModeChecks, devModeChecks);\n};\n\n// src/utils.ts\nvar NOT_FOUND = \"NOT_FOUND\";\nfunction assertIsFunction(func, errorMessage = `expected a function, instead received ${typeof func}`) {\n if (typeof func !== \"function\") {\n throw new TypeError(errorMessage);\n }\n}\nfunction assertIsObject(object, errorMessage = `expected an object, instead received ${typeof object}`) {\n if (typeof object !== \"object\") {\n throw new TypeError(errorMessage);\n }\n}\nfunction assertIsArrayOfFunctions(array, errorMessage = `expected all items to be functions, instead received the following types: `) {\n if (!array.every((item) => typeof item === \"function\")) {\n const itemTypes = array.map(\n (item) => typeof item === \"function\" ? `function ${item.name || \"unnamed\"}()` : typeof item\n ).join(\", \");\n throw new TypeError(`${errorMessage}[${itemTypes}]`);\n }\n}\nvar ensureIsArray = (item) => {\n return Array.isArray(item) ? item : [item];\n};\nfunction getDependencies(createSelectorArgs) {\n const dependencies = Array.isArray(createSelectorArgs[0]) ? createSelectorArgs[0] : createSelectorArgs;\n assertIsArrayOfFunctions(\n dependencies,\n `createSelector expects all input-selectors to be functions, but received the following types: `\n );\n return dependencies;\n}\nfunction collectInputSelectorResults(dependencies, inputSelectorArgs) {\n const inputSelectorResults = [];\n const { length } = dependencies;\n for (let i = 0; i < length; i++) {\n inputSelectorResults.push(dependencies[i].apply(null, inputSelectorArgs));\n }\n return inputSelectorResults;\n}\nvar getDevModeChecksExecutionInfo = (firstRun, devModeChecks) => {\n const { identityFunctionCheck, inputStabilityCheck } = {\n ...globalDevModeChecks,\n ...devModeChecks\n };\n return {\n identityFunctionCheck: {\n shouldRun: identityFunctionCheck === \"always\" || identityFunctionCheck === \"once\" && firstRun,\n run: runIdentityFunctionCheck\n },\n inputStabilityCheck: {\n shouldRun: inputStabilityCheck === \"always\" || inputStabilityCheck === \"once\" && firstRun,\n run: runInputStabilityCheck\n }\n };\n};\n\n// src/autotrackMemoize/autotracking.ts\nvar $REVISION = 0;\nvar CURRENT_TRACKER = null;\nvar Cell = class {\n revision = $REVISION;\n _value;\n _lastValue;\n _isEqual = tripleEq;\n constructor(initialValue, isEqual = tripleEq) {\n this._value = this._lastValue = initialValue;\n this._isEqual = isEqual;\n }\n // Whenever a storage value is read, it'll add itself to the current tracker if\n // one exists, entangling its state with that cache.\n get value() {\n CURRENT_TRACKER?.add(this);\n return this._value;\n }\n // Whenever a storage value is updated, we bump the global revision clock,\n // assign the revision for this storage to the new value, _and_ we schedule a\n // rerender. This is important, and it's what makes autotracking _pull_\n // based. We don't actively tell the caches which depend on the storage that\n // anything has happened. Instead, we recompute the caches when needed.\n set value(newValue) {\n if (this.value === newValue)\n return;\n this._value = newValue;\n this.revision = ++$REVISION;\n }\n};\nfunction tripleEq(a, b) {\n return a === b;\n}\nvar TrackingCache = class {\n _cachedValue;\n _cachedRevision = -1;\n _deps = [];\n hits = 0;\n fn;\n constructor(fn) {\n this.fn = fn;\n }\n clear() {\n this._cachedValue = void 0;\n this._cachedRevision = -1;\n this._deps = [];\n this.hits = 0;\n }\n get value() {\n if (this.revision > this._cachedRevision) {\n const { fn } = this;\n const currentTracker = /* @__PURE__ */ new Set();\n const prevTracker = CURRENT_TRACKER;\n CURRENT_TRACKER = currentTracker;\n this._cachedValue = fn();\n CURRENT_TRACKER = prevTracker;\n this.hits++;\n this._deps = Array.from(currentTracker);\n this._cachedRevision = this.revision;\n }\n CURRENT_TRACKER?.add(this);\n return this._cachedValue;\n }\n get revision() {\n return Math.max(...this._deps.map((d) => d.revision), 0);\n }\n};\nfunction getValue(cell) {\n if (!(cell instanceof Cell)) {\n console.warn(\"Not a valid cell! \", cell);\n }\n return cell.value;\n}\nfunction setValue(storage, value) {\n if (!(storage instanceof Cell)) {\n throw new TypeError(\n \"setValue must be passed a tracked store created with `createStorage`.\"\n );\n }\n storage.value = storage._lastValue = value;\n}\nfunction createCell(initialValue, isEqual = tripleEq) {\n return new Cell(initialValue, isEqual);\n}\nfunction createCache(fn) {\n assertIsFunction(\n fn,\n \"the first parameter to `createCache` must be a function\"\n );\n return new TrackingCache(fn);\n}\n\n// src/autotrackMemoize/tracking.ts\nvar neverEq = (a, b) => false;\nfunction createTag() {\n return createCell(null, neverEq);\n}\nfunction dirtyTag(tag, value) {\n setValue(tag, value);\n}\nvar consumeCollection = (node) => {\n let tag = node.collectionTag;\n if (tag === null) {\n tag = node.collectionTag = createTag();\n }\n getValue(tag);\n};\nvar dirtyCollection = (node) => {\n const tag = node.collectionTag;\n if (tag !== null) {\n dirtyTag(tag, null);\n }\n};\n\n// src/autotrackMemoize/proxy.ts\nvar REDUX_PROXY_LABEL = Symbol();\nvar nextId = 0;\nvar proto = Object.getPrototypeOf({});\nvar ObjectTreeNode = class {\n constructor(value) {\n this.value = value;\n this.value = value;\n this.tag.value = value;\n }\n proxy = new Proxy(this, objectProxyHandler);\n tag = createTag();\n tags = {};\n children = {};\n collectionTag = null;\n id = nextId++;\n};\nvar objectProxyHandler = {\n get(node, key) {\n function calculateResult() {\n const { value } = node;\n const childValue = Reflect.get(value, key);\n if (typeof key === \"symbol\") {\n return childValue;\n }\n if (key in proto) {\n return childValue;\n }\n if (typeof childValue === \"object\" && childValue !== null) {\n let childNode = node.children[key];\n if (childNode === void 0) {\n childNode = node.children[key] = createNode(childValue);\n }\n if (childNode.tag) {\n getValue(childNode.tag);\n }\n return childNode.proxy;\n } else {\n let tag = node.tags[key];\n if (tag === void 0) {\n tag = node.tags[key] = createTag();\n tag.value = childValue;\n }\n getValue(tag);\n return childValue;\n }\n }\n const res = calculateResult();\n return res;\n },\n ownKeys(node) {\n consumeCollection(node);\n return Reflect.ownKeys(node.value);\n },\n getOwnPropertyDescriptor(node, prop) {\n return Reflect.getOwnPropertyDescriptor(node.value, prop);\n },\n has(node, prop) {\n return Reflect.has(node.value, prop);\n }\n};\nvar ArrayTreeNode = class {\n constructor(value) {\n this.value = value;\n this.value = value;\n this.tag.value = value;\n }\n proxy = new Proxy([this], arrayProxyHandler);\n tag = createTag();\n tags = {};\n children = {};\n collectionTag = null;\n id = nextId++;\n};\nvar arrayProxyHandler = {\n get([node], key) {\n if (key === \"length\") {\n consumeCollection(node);\n }\n return objectProxyHandler.get(node, key);\n },\n ownKeys([node]) {\n return objectProxyHandler.ownKeys(node);\n },\n getOwnPropertyDescriptor([node], prop) {\n return objectProxyHandler.getOwnPropertyDescriptor(node, prop);\n },\n has([node], prop) {\n return objectProxyHandler.has(node, prop);\n }\n};\nfunction createNode(value) {\n if (Array.isArray(value)) {\n return new ArrayTreeNode(value);\n }\n return new ObjectTreeNode(value);\n}\nfunction updateNode(node, newValue) {\n const { value, tags, children } = node;\n node.value = newValue;\n if (Array.isArray(value) && Array.isArray(newValue) && value.length !== newValue.length) {\n dirtyCollection(node);\n } else {\n if (value !== newValue) {\n let oldKeysSize = 0;\n let newKeysSize = 0;\n let anyKeysAdded = false;\n for (const _key in value) {\n oldKeysSize++;\n }\n for (const key in newValue) {\n newKeysSize++;\n if (!(key in value)) {\n anyKeysAdded = true;\n break;\n }\n }\n const isDifferent = anyKeysAdded || oldKeysSize !== newKeysSize;\n if (isDifferent) {\n dirtyCollection(node);\n }\n }\n }\n for (const key in tags) {\n const childValue = value[key];\n const newChildValue = newValue[key];\n if (childValue !== newChildValue) {\n dirtyCollection(node);\n dirtyTag(tags[key], newChildValue);\n }\n if (typeof newChildValue === \"object\" && newChildValue !== null) {\n delete tags[key];\n }\n }\n for (const key in children) {\n const childNode = children[key];\n const newChildValue = newValue[key];\n const childValue = childNode.value;\n if (childValue === newChildValue) {\n continue;\n } else if (typeof newChildValue === \"object\" && newChildValue !== null) {\n updateNode(childNode, newChildValue);\n } else {\n deleteNode(childNode);\n delete children[key];\n }\n }\n}\nfunction deleteNode(node) {\n if (node.tag) {\n dirtyTag(node.tag, null);\n }\n dirtyCollection(node);\n for (const key in node.tags) {\n dirtyTag(node.tags[key], null);\n }\n for (const key in node.children) {\n deleteNode(node.children[key]);\n }\n}\n\n// src/lruMemoize.ts\nfunction createSingletonCache(equals) {\n let entry;\n return {\n get(key) {\n if (entry && equals(entry.key, key)) {\n return entry.value;\n }\n return NOT_FOUND;\n },\n put(key, value) {\n entry = { key, value };\n },\n getEntries() {\n return entry ? [entry] : [];\n },\n clear() {\n entry = void 0;\n }\n };\n}\nfunction createLruCache(maxSize, equals) {\n let entries = [];\n function get(key) {\n const cacheIndex = entries.findIndex((entry) => equals(key, entry.key));\n if (cacheIndex > -1) {\n const entry = entries[cacheIndex];\n if (cacheIndex > 0) {\n entries.splice(cacheIndex, 1);\n entries.unshift(entry);\n }\n return entry.value;\n }\n return NOT_FOUND;\n }\n function put(key, value) {\n if (get(key) === NOT_FOUND) {\n entries.unshift({ key, value });\n if (entries.length > maxSize) {\n entries.pop();\n }\n }\n }\n function getEntries() {\n return entries;\n }\n function clear() {\n entries = [];\n }\n return { get, put, getEntries, clear };\n}\nvar referenceEqualityCheck = (a, b) => a === b;\nfunction createCacheKeyComparator(equalityCheck) {\n return function areArgumentsShallowlyEqual(prev, next) {\n if (prev === null || next === null || prev.length !== next.length) {\n return false;\n }\n const { length } = prev;\n for (let i = 0; i < length; i++) {\n if (!equalityCheck(prev[i], next[i])) {\n return false;\n }\n }\n return true;\n };\n}\nfunction lruMemoize(func, equalityCheckOrOptions) {\n const providedOptions = typeof equalityCheckOrOptions === \"object\" ? equalityCheckOrOptions : { equalityCheck: equalityCheckOrOptions };\n const {\n equalityCheck = referenceEqualityCheck,\n maxSize = 1,\n resultEqualityCheck\n } = providedOptions;\n const comparator = createCacheKeyComparator(equalityCheck);\n let resultsCount = 0;\n const cache = maxSize === 1 ? createSingletonCache(comparator) : createLruCache(maxSize, comparator);\n function memoized() {\n let value = cache.get(arguments);\n if (value === NOT_FOUND) {\n value = func.apply(null, arguments);\n resultsCount++;\n if (resultEqualityCheck) {\n const entries = cache.getEntries();\n const matchingEntry = entries.find(\n (entry) => resultEqualityCheck(entry.value, value)\n );\n if (matchingEntry) {\n value = matchingEntry.value;\n resultsCount !== 0 && resultsCount--;\n }\n }\n cache.put(arguments, value);\n }\n return value;\n }\n memoized.clearCache = () => {\n cache.clear();\n memoized.resetResultsCount();\n };\n memoized.resultsCount = () => resultsCount;\n memoized.resetResultsCount = () => {\n resultsCount = 0;\n };\n return memoized;\n}\n\n// src/autotrackMemoize/autotrackMemoize.ts\nfunction autotrackMemoize(func) {\n const node = createNode(\n []\n );\n let lastArgs = null;\n const shallowEqual = createCacheKeyComparator(referenceEqualityCheck);\n const cache = createCache(() => {\n const res = func.apply(null, node.proxy);\n return res;\n });\n function memoized() {\n if (!shallowEqual(lastArgs, arguments)) {\n updateNode(node, arguments);\n lastArgs = arguments;\n }\n return cache.value;\n }\n memoized.clearCache = () => {\n return cache.clear();\n };\n return memoized;\n}\n\n// src/weakMapMemoize.ts\nvar StrongRef = class {\n constructor(value) {\n this.value = value;\n }\n deref() {\n return this.value;\n }\n};\nvar Ref = typeof WeakRef !== \"undefined\" ? WeakRef : StrongRef;\nvar UNTERMINATED = 0;\nvar TERMINATED = 1;\nfunction createCacheNode() {\n return {\n s: UNTERMINATED,\n v: void 0,\n o: null,\n p: null\n };\n}\nfunction weakMapMemoize(func, options = {}) {\n let fnNode = createCacheNode();\n const { resultEqualityCheck } = options;\n let lastResult;\n let resultsCount = 0;\n function memoized() {\n let cacheNode = fnNode;\n const { length } = arguments;\n for (let i = 0, l = length; i < l; i++) {\n const arg = arguments[i];\n if (typeof arg === \"function\" || typeof arg === \"object\" && arg !== null) {\n let objectCache = cacheNode.o;\n if (objectCache === null) {\n cacheNode.o = objectCache = /* @__PURE__ */ new WeakMap();\n }\n const objectNode = objectCache.get(arg);\n if (objectNode === void 0) {\n cacheNode = createCacheNode();\n objectCache.set(arg, cacheNode);\n } else {\n cacheNode = objectNode;\n }\n } else {\n let primitiveCache = cacheNode.p;\n if (primitiveCache === null) {\n cacheNode.p = primitiveCache = /* @__PURE__ */ new Map();\n }\n const primitiveNode = primitiveCache.get(arg);\n if (primitiveNode === void 0) {\n cacheNode = createCacheNode();\n primitiveCache.set(arg, cacheNode);\n } else {\n cacheNode = primitiveNode;\n }\n }\n }\n const terminatedNode = cacheNode;\n let result;\n if (cacheNode.s === TERMINATED) {\n result = cacheNode.v;\n } else {\n result = func.apply(null, arguments);\n resultsCount++;\n }\n terminatedNode.s = TERMINATED;\n if (resultEqualityCheck) {\n const lastResultValue = lastResult?.deref?.() ?? lastResult;\n if (lastResultValue != null && resultEqualityCheck(lastResultValue, result)) {\n result = lastResultValue;\n resultsCount !== 0 && resultsCount--;\n }\n const needsWeakRef = typeof result === \"object\" && result !== null || typeof result === \"function\";\n lastResult = needsWeakRef ? new Ref(result) : result;\n }\n terminatedNode.v = result;\n return result;\n }\n memoized.clearCache = () => {\n fnNode = createCacheNode();\n memoized.resetResultsCount();\n };\n memoized.resultsCount = () => resultsCount;\n memoized.resetResultsCount = () => {\n resultsCount = 0;\n };\n return memoized;\n}\n\n// src/createSelectorCreator.ts\nfunction createSelectorCreator(memoizeOrOptions, ...memoizeOptionsFromArgs) {\n const createSelectorCreatorOptions = typeof memoizeOrOptions === \"function\" ? {\n memoize: memoizeOrOptions,\n memoizeOptions: memoizeOptionsFromArgs\n } : memoizeOrOptions;\n const createSelector2 = (...createSelectorArgs) => {\n let recomputations = 0;\n let dependencyRecomputations = 0;\n let lastResult;\n let directlyPassedOptions = {};\n let resultFunc = createSelectorArgs.pop();\n if (typeof resultFunc === \"object\") {\n directlyPassedOptions = resultFunc;\n resultFunc = createSelectorArgs.pop();\n }\n assertIsFunction(\n resultFunc,\n `createSelector expects an output function after the inputs, but received: [${typeof resultFunc}]`\n );\n const combinedOptions = {\n ...createSelectorCreatorOptions,\n ...directlyPassedOptions\n };\n const {\n memoize,\n memoizeOptions = [],\n argsMemoize = weakMapMemoize,\n argsMemoizeOptions = [],\n devModeChecks = {}\n } = combinedOptions;\n const finalMemoizeOptions = ensureIsArray(memoizeOptions);\n const finalArgsMemoizeOptions = ensureIsArray(argsMemoizeOptions);\n const dependencies = getDependencies(createSelectorArgs);\n const memoizedResultFunc = memoize(function recomputationWrapper() {\n recomputations++;\n return resultFunc.apply(\n null,\n arguments\n );\n }, ...finalMemoizeOptions);\n let firstRun = true;\n const selector = argsMemoize(function dependenciesChecker() {\n dependencyRecomputations++;\n const inputSelectorResults = collectInputSelectorResults(\n dependencies,\n arguments\n );\n lastResult = memoizedResultFunc.apply(null, inputSelectorResults);\n if (process.env.NODE_ENV !== \"production\") {\n const { identityFunctionCheck, inputStabilityCheck } = getDevModeChecksExecutionInfo(firstRun, devModeChecks);\n if (identityFunctionCheck.shouldRun) {\n identityFunctionCheck.run(\n resultFunc,\n inputSelectorResults,\n lastResult\n );\n }\n if (inputStabilityCheck.shouldRun) {\n const inputSelectorResultsCopy = collectInputSelectorResults(\n dependencies,\n arguments\n );\n inputStabilityCheck.run(\n { inputSelectorResults, inputSelectorResultsCopy },\n { memoize, memoizeOptions: finalMemoizeOptions },\n arguments\n );\n }\n if (firstRun)\n firstRun = false;\n }\n return lastResult;\n }, ...finalArgsMemoizeOptions);\n return Object.assign(selector, {\n resultFunc,\n memoizedResultFunc,\n dependencies,\n dependencyRecomputations: () => dependencyRecomputations,\n resetDependencyRecomputations: () => {\n dependencyRecomputations = 0;\n },\n lastResult: () => lastResult,\n recomputations: () => recomputations,\n resetRecomputations: () => {\n recomputations = 0;\n },\n memoize,\n argsMemoize\n });\n };\n Object.assign(createSelector2, {\n withTypes: () => createSelector2\n });\n return createSelector2;\n}\nvar createSelector = /* @__PURE__ */ createSelectorCreator(weakMapMemoize);\n\n// src/createStructuredSelector.ts\nvar createStructuredSelector = Object.assign(\n (inputSelectorsObject, selectorCreator = createSelector) => {\n assertIsObject(\n inputSelectorsObject,\n `createStructuredSelector expects first argument to be an object where each property is a selector, instead received a ${typeof inputSelectorsObject}`\n );\n const inputSelectorKeys = Object.keys(inputSelectorsObject);\n const dependencies = inputSelectorKeys.map(\n (key) => inputSelectorsObject[key]\n );\n const structuredSelector = selectorCreator(\n dependencies,\n (...inputSelectorResults) => {\n return inputSelectorResults.reduce((composition, value, index) => {\n composition[inputSelectorKeys[index]] = value;\n return composition;\n }, {});\n }\n );\n return structuredSelector;\n },\n { withTypes: () => createStructuredSelector }\n);\nexport {\n createSelector,\n createSelectorCreator,\n createStructuredSelector,\n lruMemoize,\n referenceEqualityCheck,\n setGlobalDevModeChecks,\n autotrackMemoize as unstable_autotrackMemoize,\n weakMapMemoize\n};\n//# sourceMappingURL=reselect.mjs.map","// 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","// 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__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","var scriptUrl;\nif (__webpack_require__.g.importScripts) scriptUrl = __webpack_require__.g.location + \"\";\nvar document = __webpack_require__.g.document;\nif (!scriptUrl && document) {\n\tif (document.currentScript)\n\t\tscriptUrl = document.currentScript.src;\n\tif (!scriptUrl) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tif(scripts.length) {\n\t\t\tvar i = scripts.length - 1;\n\t\t\twhile (i > -1 && !scriptUrl) scriptUrl = scripts[i--].src;\n\t\t}\n\t}\n}\n// When supporting browsers where an automatic publicPath is not supported you must specify an output.publicPath manually via configuration\n// or pass an empty string (\"\") and set the __webpack_public_path__ variable from your code to use your own logic.\nif (!scriptUrl) throw new Error(\"Automatic publicPath is not supported in this browser\");\nscriptUrl = scriptUrl.replace(/#.*$/, \"\").replace(/\\?.*$/, \"\").replace(/\\/[^\\/]+$/, \"/\");\n__webpack_require__.p = scriptUrl;","import { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\n\nconst PrivacyDisclaimer = () => {\n const { t } = useI18n()\n const { showDisclaimer } = useConfig()\n\n return (\n showDisclaimer && (\n <div className={className('disclaimer')} tabIndex=\"0\">\n <h2 className={className('disclaimer__title')}>\n {t('disclaimer.title')}\n </h2>\n <div\n className={className('disclaimer__message')}\n dangerouslySetInnerHTML={{ __html: t('disclaimer.content') }}\n />\n </div>\n )\n )\n}\n\nexport default PrivacyDisclaimer\n","import { createSelector } from '@reduxjs/toolkit'\nimport type { RootState } from 'domains/store'\n\nconst getState = ({ forms }: RootState) => forms\n\nexport const getFormById = createSelector(\n [getState, (_, { formId }): string => formId],\n (forms, formId) => forms[formId],\n)\n\nconst getFormControlsByFormId = createSelector(\n getFormById,\n (form) => form?.controls || {},\n)\n\nexport const getFormValuesByFormId = createSelector(\n getFormControlsByFormId,\n (controls: { [key: string]: { value: string } }) => {\n const valuesObj = {}\n Object.entries(controls).forEach(([key, { value }]) => {\n valuesObj[key] = value\n })\n\n return valuesObj\n },\n)\n\nexport const getControlValueByName = createSelector(\n [getFormControlsByFormId, (_, { name }): string => name],\n (controls, name) => controls[name]?.value,\n)\n\nexport const getControlTouchedByName = createSelector(\n [getFormControlsByFormId, (_, { name }): string => name],\n (controls, name) => controls[name]?.touched,\n)\n","import { createContext } from 'preact'\nimport type { FormContextType } from 'domains/forms/forms.types'\n\nconst FormContext = createContext<FormContextType>({\n handleSubmit: () => undefined,\n isSubmitted: false,\n isValid: false,\n updateControlValue: () => undefined,\n updateControlTouched: () => undefined,\n errors: undefined,\n})\n\nexport default FormContext\nexport const { Provider, Consumer } = FormContext\n","import {\n useCallback,\n useContext,\n useEffect,\n useLayoutEffect,\n useMemo,\n} from 'preact/hooks'\nimport { useDispatch, useSelector } from 'react-redux'\nimport {\n getControlTouchedByName,\n getControlValueByName,\n getFormById,\n} from 'domains/forms/selectors'\nimport { deregisterControl, registerControl } from 'domains/forms/slice'\nimport FormContext from './context'\nimport { validate } from './utils'\nimport type { ControlState, FormContextType } from 'domains/forms/forms.types'\nimport type { RootState } from 'domains/store'\n\nexport function useFormContext(): FormContextType {\n return useContext(FormContext)\n}\n\nexport function useForm() {\n const { handleSubmit, isSubmitted, isValid } = useFormContext()\n\n return {\n handleSubmit,\n isSubmitted,\n isValid,\n }\n}\n\nexport function useValidations(values, validationSchema) {\n const errors = useMemo(\n () => validate(values, validationSchema),\n [values, validationSchema],\n )\n return {\n isValid: Object.keys(errors).length === 0,\n errors,\n }\n}\n\nexport function useFormControl(name): [\n {\n name: string\n onInput: (_e: any) => void\n onBlur: () => void\n value: string\n },\n ControlState,\n] {\n const dispatch = useDispatch()\n const { formId, updateControlValue, updateControlTouched, errors } =\n useFormContext()\n const form = useSelector((state: RootState) => getFormById(state, { formId }))\n const isRegistered = !!form\n const value = useSelector((state: RootState) => {\n return getControlValueByName(state, { formId, name })\n })\n\n const touched = useSelector((state: RootState) =>\n getControlTouchedByName(state, { formId, name }),\n )\n const error = errors?.[name]\n const isValid = !error\n\n useEffect(() => {\n // Make sure the form is registered\n // Since child useEffect runs before FormProvider useEffect\n if (isRegistered) {\n dispatch(registerControl({ formId, name }))\n }\n }, [isRegistered, formId, name, dispatch])\n useLayoutEffect(() => {\n return () => {\n dispatch(deregisterControl({ formId, name }))\n }\n }, [isRegistered, formId, name, dispatch])\n\n // preact uses onInput instead of onChange\n const onInput = useCallback(\n (e) => updateControlValue(name, e.target.value),\n [name, updateControlValue],\n )\n\n const onBlur = useCallback(() => {\n updateControlTouched(name, true)\n }, [updateControlTouched, name])\n\n const field = useMemo(\n () => ({\n name,\n onInput,\n onBlur,\n value,\n }),\n [name, onInput, onBlur, value],\n )\n\n const meta = useMemo(\n () => ({\n isValid,\n error,\n touched,\n }),\n [isValid, error, touched],\n )\n\n return [field, meta]\n}\n","import { useEffect, useMemo } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { maxCharacterSrDebounceDelay, maxCharacterWarningLimit } from 'config'\nimport { ControlState } from 'domains/forms/forms.types'\nimport { useFormControl } from 'domains/forms/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { clearAbortTransaction } from 'domains/store/slice'\nimport { useLiveRegion } from 'ui/hooks/live-region-hooks'\nimport {\n useEntryTextLimit,\n useSeamlyStateContext,\n} from 'ui/hooks/seamly-state-hooks'\nimport { debounce } from 'ui/utils/general-utils'\n\nexport function useCharacterLimit(controlName) {\n const { t } = useI18n()\n const { sendAssertive } = useLiveRegion()\n const { hasLimit, limit } = useEntryTextLimit()\n\n const debouncedSendAssertive = useMemo(\n () => debounce(sendAssertive, maxCharacterSrDebounceDelay),\n [sendAssertive],\n )\n const validateLimit = useMemo(() => {\n return debounce((_reachedCharacterWarning, _remainingChars) => {\n if (_reachedCharacterWarning) {\n debouncedSendAssertive(\n t('input.srCharacterLimitText', { limit: _remainingChars }),\n )\n }\n }, maxCharacterSrDebounceDelay)\n }, [debouncedSendAssertive, t])\n\n const [{ value }] = useFormControl(controlName)\n const remainingChars = hasLimit && value ? limit - value.length : limit\n const reachedCharacterWarning = hasLimit\n ? remainingChars <= maxCharacterWarningLimit\n : false\n const reachedCharacterLimit = hasLimit ? remainingChars < 0 : false\n\n useEffect(() => {\n validateLimit(reachedCharacterWarning, remainingChars)\n }, [reachedCharacterWarning, remainingChars, validateLimit])\n\n return {\n hasCharacterLimit: hasLimit,\n characterLimit: limit,\n reachedCharacterWarning,\n reachedCharacterLimit,\n remainingChars,\n }\n}\n\nexport const useEntryTextTranslation = (controlName: ControlState['name']) => {\n const { hasCharacterLimit, characterLimit } = useCharacterLimit(controlName)\n\n const {\n entryMeta: {\n optionsOverride: { text },\n },\n } = useSeamlyStateContext()\n\n const { t } = useI18n()\n\n const placeholder: string = useMemo(\n () =>\n t('input.inputPlaceholder', {\n hasLimit: hasCharacterLimit,\n text: text?.placeholder || t('input.inputPlaceholderText'),\n limit: hasCharacterLimit ? characterLimit : null,\n }),\n [t, hasCharacterLimit, characterLimit, text?.placeholder],\n )\n\n const label: string = useMemo(\n () =>\n t('input.inputLabel', {\n hasLimit: !text?.label ? hasCharacterLimit : false,\n text: text?.label || t('input.inputLabelText'),\n limit: !text?.label && hasCharacterLimit ? characterLimit : null,\n }),\n [t, hasCharacterLimit, characterLimit, text?.label],\n )\n\n const labelClass = useMemo(\n () => (text?.label ? 'label' : 'visually-hidden'),\n [text?.label],\n )\n\n return { placeholder, label, labelClass }\n}\n\nexport const useEntryAbortTransaction = () => {\n const dispatch = useDispatch()\n\n const {\n entryMeta: { actions, translatedActions },\n } = useSeamlyStateContext()\n\n const clearEntryAbortTransaction = () => {\n dispatch(clearAbortTransaction())\n }\n\n const abortTransaction =\n translatedActions?.abortTransaction || actions?.abortTransaction\n\n return {\n abortTransaction,\n clearEntryAbortTransaction,\n }\n}\n","import { className } from 'lib/css'\nimport { useSeamlyApiContext } from 'ui/hooks/seamly-api-hooks'\nimport { actionTypes } from 'ui/utils/seamly-utils'\nimport { useEntryAbortTransaction } from '../text-entry/hooks'\n\nexport default function AbortTransactionButton() {\n const { abortTransaction, clearEntryAbortTransaction } =\n useEntryAbortTransaction()\n const api = useSeamlyApiContext()\n\n if (!abortTransaction) return null\n\n const handleAbortTransaction = () => {\n api.send('action', {\n type: actionTypes.setTopic,\n body: {\n name: abortTransaction.topicName,\n fallbackMessage: abortTransaction.topicFallbackMessage,\n },\n })\n\n clearEntryAbortTransaction()\n }\n\n return (\n <li\n className={className([\n 'cvco-conversation__item',\n 'cvco-conversation__item--abort-transaction',\n ])}\n >\n <button\n className={className([\n 'button',\n 'button--secondary',\n 'abort-transaction__button',\n ])}\n type=\"button\"\n onClick={handleAbortTransaction}\n >\n {abortTransaction.label}\n </button>\n </li>\n )\n}\n","import { createContext } from 'preact'\n\nconst ComponentContext = createContext({})\n\nexport default ComponentContext\n","import { useCallback, useEffect, useMemo, useRef } from 'preact/hooks'\nimport { className } from 'lib/css'\nimport { useGeneratedId, useSeamlyCommands } from 'ui/hooks/seamly-hooks'\nimport { actionTypes, cardTypes } from 'ui/utils/seamly-utils'\n\nconst CardComponent = ({\n id,\n action,\n buttonText,\n description,\n hasFocus,\n image,\n title,\n isCarouselItem,\n}) => {\n const cardRef = useRef(null)\n const { sendMessage, sendAction, emitEvent } = useSeamlyCommands()\n const descriptionId = useGeneratedId()\n const isMounted = useRef(false)\n\n const CardActionComponent =\n action.type === cardTypes.navigate ? 'a' : 'button'\n\n const emitCardEvent = useCallback(\n () =>\n emitEvent(`action.${actionTypes.clickCard}`, {\n type: actionTypes.clickCta,\n originMessage: id,\n action,\n }),\n [emitEvent, id, action],\n )\n\n const handleClick = useCallback(() => {\n emitCardEvent()\n if (action.type === cardTypes.ask) {\n sendMessage({ body: action.ask })\n } else if (action.type === cardTypes.topic) {\n const { topic: name, fallbackMessage } = action\n sendAction({\n type: actionTypes.setTopic,\n body: { name, fallbackMessage },\n })\n }\n }, [sendMessage, action, sendAction, emitCardEvent])\n\n const actionProps = useMemo(\n () =>\n action.type === cardTypes.navigate\n ? {\n href: action.link,\n rel: 'noopener noreferrer',\n target: action.newTab ? '_blank' : '_self',\n onClick: emitCardEvent,\n }\n : {\n onClick: handleClick,\n },\n [action, handleClick, emitCardEvent],\n )\n\n useEffect(() => {\n if (isCarouselItem) {\n if (hasFocus && isMounted.current) {\n window.requestAnimationFrame(() => cardRef.current.focus())\n } else {\n cardRef.current.blur()\n }\n }\n isMounted.current = true\n }, [hasFocus, isCarouselItem])\n\n return (\n <div\n className={className('card__wrapper')}\n id={id}\n tabIndex={-1} // set tabIndex of -1 so card can be focussed\n ref={cardRef}\n >\n {image ? (\n <img className={className('card__image')} src={image} alt=\"\" />\n ) : null}\n <div className={className('card__content')} id={id}>\n {title && <h2 className={className('card__title')}>{title}</h2>}\n {description && (\n <div\n className={className('card__description')}\n dangerouslySetInnerHTML={{ __html: description }}\n />\n )}\n <CardActionComponent\n tabIndex={isCarouselItem && !hasFocus ? -1 : undefined} // disable to prevent tabbing through cards\n className={className('button', 'button--primary')}\n aria-describedby={descriptionId}\n {...actionProps}\n >\n {buttonText}\n </CardActionComponent>\n </div>\n </div>\n )\n}\n\nexport default CardComponent\n","import { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport CardComponent from 'ui/components/conversation/event/card-component'\n\nexport default function CarouselMessageSlide({\n item: slide,\n items,\n index,\n isActive,\n}) {\n const { t } = useI18n()\n return (\n <div\n className={className('carousel-item', `carousel-item--${slide.type}`)}\n role=\"group\"\n aria-roledescription=\"slide\"\n aria-label={t('carousel.slide.label', {\n index: index + 1,\n total: items.length,\n })}\n >\n <CardComponent {...slide} isCarouselItem={true} hasFocus={isActive} />\n </div>\n )\n}\n","import { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\n\nexport default function CarouselControls({\n items,\n currentIndex,\n onChange,\n children,\n}) {\n const { t } = useI18n()\n const itemCount = items.length\n const handlePrevious = () => {\n onChange((currentIndex - 1 + itemCount) % itemCount)\n }\n const handleNext = () => {\n onChange((currentIndex + 1) % itemCount)\n }\n\n return (\n <div className={className('carousel-controls')}>\n <button\n className={className('button', 'button--previous')}\n aria-label={t('carousel.controls.previous')}\n onClick={handlePrevious}\n >\n <Icon name=\"arrowLeft\" size=\"16\" alt=\"\" />\n </button>\n {children}\n <button\n className={className('button', 'button--next')}\n aria-label={t('carousel.controls.next')}\n onClick={handleNext}\n >\n <Icon name=\"arrowRight\" size=\"16\" alt=\"\" />\n </button>\n </div>\n )\n}\n","import { useCallback } from 'preact/hooks'\nimport { className } from 'lib/css'\n\nexport default function CarouselPagination({\n items,\n currentIndex,\n onChange,\n getItemKey,\n getItemLabel,\n}) {\n const itemCount = items.length\n const handlePaginate = useCallback(\n (event) => {\n const slideIndex = Number(event.target.dataset.item || '0')\n const nextIndex = Math.min(itemCount - 1, Math.max(0, slideIndex))\n if (nextIndex !== currentIndex) {\n onChange(nextIndex)\n }\n },\n [itemCount, currentIndex, onChange],\n )\n\n return (\n <div className={className('carousel-pagination__wrapper')} role=\"group\">\n <ul className={className('carousel-pagination')}>\n {items.map((item, idx) => {\n const isActive = currentIndex === idx\n return (\n <li\n key={getItemKey(item, idx, 'pagination-item-')}\n className={className(\n 'carousel-pagination__item',\n isActive ? 'is-active' : undefined,\n )}\n >\n <button\n className={className('carousel-pagination__button')}\n type=\"button\"\n onClick={handlePaginate}\n data-item={idx}\n aria-disabled={isActive ? 'true' : undefined}\n aria-label={getItemLabel(item, idx)}\n />\n </li>\n )\n })}\n </ul>\n </div>\n )\n}\n","import { createRef } from 'preact'\nimport { useEffect, useMemo, useRef, useState } from 'preact/hooks'\nimport { className } from 'lib/css'\nimport CarouselMessageSlide from 'ui/components/conversation/event/carousel-message/components/slide'\nimport { useGeneratedId } from 'ui/hooks/utility-hooks'\nimport CarouselControls from './components/controls'\nimport CarouselPagination from './components/pagination'\n\nconst defaultGetItemKey = (item, idx, prefix) => `${prefix}${idx}`\nconst defaultGetItemLabel = (item) => item.label\nconst preventScroll = ({ target }) => {\n target.scrollLeft = 0\n}\n\nexport default function CarouselComponent({\n currentIndex: originalIndex,\n onChange,\n getItemKey = defaultGetItemKey,\n getItemLabel = defaultGetItemLabel,\n items,\n}) {\n const carouselItemsId = useGeneratedId()\n const itemCount = items.length\n const [currentIndex, setCurrentIndex] = useState(Number(originalIndex || '0'))\n\n useEffect(() => {\n setCurrentIndex(Number(originalIndex || '0'))\n }, [setCurrentIndex, originalIndex])\n\n const slideRefs = useRef([])\n slideRefs.current = useMemo(() => {\n return Array(itemCount)\n .fill(1)\n .map(() => createRef())\n }, [itemCount])\n\n const isMountRef = useRef(true)\n const onChangeRef = useRef()\n onChangeRef.current = onChange\n useEffect(() => {\n if (isMountRef.current) {\n isMountRef.current = false\n return\n }\n\n if (onChangeRef.current) {\n onChangeRef.current(currentIndex)\n }\n }, [currentIndex])\n\n return (\n <div\n className={className('carousel')}\n role=\"group\"\n aria-roledescription=\"carousel\"\n >\n <div\n className={className('carousel__slides-wrapper')}\n onScroll={preventScroll}\n >\n <div\n id={carouselItemsId}\n className={className('carousel__slides')}\n style={{\n width: `${itemCount * 100}%`,\n left: `${currentIndex * -100}%`,\n }}\n aria-live=\"polite\"\n aria-atomic=\"false\"\n >\n {items.map((item, idx) => {\n const isActive = currentIndex === idx\n return (\n <div\n key={getItemKey(item, idx, 'item-')}\n ref={slideRefs.current[idx]}\n className={className(\n 'carousel__slide',\n isActive ? 'is-active' : undefined,\n )}\n aria-hidden={!isActive ? 'true' : undefined}\n >\n <CarouselMessageSlide\n item={item}\n items={items}\n currentIndex={currentIndex}\n index={idx}\n isActive={isActive}\n />\n </div>\n )\n })}\n </div>\n </div>\n <div className={className('carousel__controls')}>\n <CarouselControls\n currentIndex={currentIndex}\n items={items}\n onChange={setCurrentIndex}\n controlId={carouselItemsId}\n >\n <div className={className('carousel__pagination')}>\n <CarouselPagination\n currentIndex={currentIndex}\n items={items}\n onChange={setCurrentIndex}\n getItemKey={getItemKey}\n getItemLabel={getItemLabel}\n />\n </div>\n </CarouselControls>\n </div>\n </div>\n )\n}\n","import { useTranslatedEventData } from 'domains/translations/hooks'\nimport CarouselComponent from 'ui/components/conversation/event/carousel-component'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport CarouselMessageSlide from './components/slide'\n\nconst getItemKey = (item, idx, prefix = '') => `${prefix}${item.title}:${idx}`\nconst getItemLabel = (item) => item.title\nconst CarouselMessage = ({ event }) => {\n const { body } = useTranslatedEventData(event)\n const slides = body.cards\n\n return (\n <MessageContainer event={event} modifiers={'type-carousel'}>\n <CarouselComponent\n items={slides}\n ItemComponent={CarouselMessageSlide}\n getItemKey={getItemKey}\n getItemLabel={getItemLabel}\n />\n </MessageContainer>\n )\n}\n\nexport default CarouselMessage\n","import { useCallback, useMemo } from 'preact/hooks'\nimport { className } from '../../../lib/css'\nimport Icon from '../layout/icon'\n\nexport const mapCategoryToClass = (category) =>\n `suggestions__item--${String(category)\n .toLowerCase()\n .replace(/[^a-z0-9_\\\\-]/, '')}`\n\nconst SuggestionsItem = ({\n id,\n categories = [],\n question,\n onClick,\n hasIcon,\n}) => {\n const mappedClassNames = useMemo(() => {\n return ['suggestions__item', ...categories.map(mapCategoryToClass)]\n }, [categories])\n\n const handleClick = useCallback(() => {\n if (onClick) {\n onClick({ id, question })\n }\n }, [id, question, onClick])\n return (\n <li className={className(mappedClassNames)}>\n <button\n type=\"button\"\n onClick={handleClick}\n className={className('button', 'button--primary')}\n >\n {hasIcon && <Icon name=\"chevronRight\" size=\"8\" alt=\"\" />}\n {question}\n </button>\n </li>\n )\n}\n\nexport default SuggestionsItem\n","import { className } from '../../../lib/css'\nimport SuggestionsItem from './suggestions-item'\n\nconst SuggestionsList = ({\n className: givenClassName,\n suggestions = [],\n onClickSuggestion,\n hasIcon = true,\n}) => (\n <ul className={className('suggestions__list', givenClassName)}>\n {suggestions.map((suggestion) => (\n <SuggestionsItem\n hasIcon={hasIcon}\n key={suggestion.id}\n onClick={onClickSuggestion}\n {...suggestion}\n />\n ))}\n </ul>\n)\n\nexport default SuggestionsList\n","import { useSeamlyCommands } from 'ui/hooks/seamly-hooks'\nimport { actionTypes } from 'ui/utils/seamly-utils'\n\nconst useEventLinkClickHandler = (eventId) => {\n const { sendAction } = useSeamlyCommands()\n\n const eventClick = (e) => {\n if (e.target && e.target.dataset.linkId) {\n sendAction({\n type: actionTypes.navigate,\n originMessage: eventId,\n link: {\n id: e.target.dataset.linkId,\n url: e.target.getAttribute('href'),\n },\n })\n }\n }\n\n return eventClick\n}\n\nexport default useEventLinkClickHandler\n","import { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\n\nexport default function EventDivider({\n children,\n childrenHTML,\n className: providedClassName,\n\n graphicSrc,\n graphicType = 'icon',\n iconName,\n iconSize,\n iconClassName,\n\n dividerType,\n}) {\n const hasGraphic = Boolean(iconName || graphicSrc)\n\n const bodyProps = childrenHTML\n ? { dangerouslySetInnerHTML: { __html: childrenHTML } }\n : { children }\n\n return (\n <div\n className={className(\n 'divider',\n dividerType && `divider--type-${dividerType}`,\n providedClassName,\n )}\n >\n {hasGraphic && (\n <span className={className('divider__graphic')}>\n {iconName ? (\n <Icon\n name={iconName}\n size={iconSize}\n className={iconClassName}\n alt=\"\"\n />\n ) : (\n <img\n src={graphicSrc}\n className={className(\n {\n icon: graphicType === 'icon',\n avatar: graphicType === 'avatar',\n },\n iconClassName,\n )}\n />\n )}\n </span>\n )}\n\n <div className={className('divider__body')} {...bodyProps} />\n </div>\n )\n}\n","import { useI18n } from 'domains/i18n/hooks'\nimport EventDivider from 'ui/components/conversation/event-divider'\nimport { dividerKeys } from 'ui/utils/seamly-utils'\n\nconst dividerTypes = {\n [dividerKeys.new_topic]: 'newtopic',\n}\n\nconst Divider = ({ event }) => {\n const { t } = useI18n()\n\n const { subtype } = event.payload.body\n const dividerType = dividerTypes[dividerKeys[subtype]]\n\n return (\n <EventDivider dividerType={dividerType} iconName={dividerKeys[subtype]}>\n <p>{t(`dividerKeys.${dividerKeys[subtype]}`)}</p>\n </EventDivider>\n )\n}\n\nexport default Divider\n","import { useCallback } from 'preact/hooks'\nimport { useDispatch, useSelector } from 'react-redux'\nimport { useI18n } from 'domains/i18n/hooks'\nimport {\n disableEventsTranslation,\n enableEventsTranslation,\n} from 'domains/translations/slice'\nimport { className } from 'lib/css'\nimport EventDivider from 'ui/components/conversation/event-divider'\nimport { useEvents } from 'ui/hooks/seamly-state-hooks'\n\nconst NewTranslationDivider = ({ event }) => {\n const { t } = useI18n()\n const events = useEvents()\n const {\n body: { translationEnabled, text, title },\n id,\n } = event.payload\n const translatedEventGroups = useSelector(\n (state) => state.translations.translatedEventGroups,\n )\n\n const dispatch = useDispatch()\n const toggleTranslations = useCallback(() => {\n if (!translatedEventGroups[id]) {\n dispatch(disableEventsTranslation({ events, id }))\n return\n }\n\n dispatch(enableEventsTranslation({ events, id }))\n }, [dispatch, events, id, translatedEventGroups])\n\n return (\n <EventDivider iconName=\"newTranslation\" dividerType=\"newtranslation\">\n <p className={className('divider__title')}>{title}</p>\n {text && <p>{text}</p>}\n {translationEnabled ? (\n <>\n <button\n className={className('button', 'button--secondary')}\n onClick={toggleTranslations}\n >\n {t(\n !translatedEventGroups[id]\n ? 'translations.toggle.hideTranslationsButtonText'\n : 'translations.toggle.showTranslationsButtonText',\n )}\n </button>\n </>\n ) : null}\n </EventDivider>\n )\n}\n\nexport default NewTranslationDivider\n","import { dividerKeys } from 'ui/utils/seamly-utils'\nimport DefaultDivider from './variants/default'\nimport NewTranslationDivider from './variants/new-translation'\n\nconst Variants = {\n default: DefaultDivider,\n [dividerKeys.new_translation]: NewTranslationDivider,\n}\n\nconst Divider = ({ event, ...props }) => {\n const Component =\n Variants[dividerKeys[event.payload.body.subtype]] || Variants.default\n return <Component event={event} {...props} />\n}\n\nexport default Divider\n","import { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { getRelativeDate } from 'ui/utils/general-utils'\n\nconst dateFormatOptions = { month: 'long', day: 'numeric', year: 'numeric' }\nconst timeFormatOptions = { hour: 'numeric', minute: 'numeric' }\n\nexport const useFormattedDate = (date) => {\n const { t } = useI18n()\n const config = useConfig()\n const locale = config?.context?.locale ?? []\n const eventDate = new Date(date)\n const currentDate = new Date()\n const midnight = new Date(currentDate)\n midnight.setHours(24, 0, 0, 0)\n const timeUntilMidnight = midnight - currentDate\n const fullDateTime = eventDate.toString()\n const time = new Intl.DateTimeFormat(locale, timeFormatOptions).format(\n eventDate,\n )\n\n let relativeDate = getRelativeDate(eventDate, currentDate)\n switch (relativeDate) {\n case 'today':\n relativeDate = t('dateTime.today')\n break\n case 'yesterday':\n relativeDate = t('dateTime.yesterday')\n break\n default:\n relativeDate = new Intl.DateTimeFormat(locale, dateFormatOptions).format(\n eventDate,\n )\n }\n\n const srText = t('dateTime.srText', { date: relativeDate, time })\n\n return {\n date: relativeDate,\n srText,\n time,\n fullDateTime,\n timeUntilMidnight,\n }\n}\n","import { useEffect } from 'preact/hooks'\nimport { className } from 'lib/css'\nimport { useFormattedDate } from 'ui/components/conversation/event/hooks/use-formatted-date'\nimport EventDivider from 'ui/components/conversation/event-divider'\nimport { useForceUpdate } from 'ui/hooks/utility-hooks'\nimport { microsecondsToMilliseconds } from 'ui/utils/general-utils'\n\nconst TimeIndicator = ({ event }) => {\n const forceUpdate = useForceUpdate()\n const { date, time, timeUntilMidnight, srText } = useFormattedDate(\n microsecondsToMilliseconds(event.timeIndicator),\n )\n\n // At midnight, force a re-render so \"Today\" can become \"Yesterday\"\n useEffect(() => {\n const timeout = setTimeout(() => {\n forceUpdate()\n }, timeUntilMidnight)\n\n return () => {\n clearTimeout(timeout)\n }\n }, [forceUpdate, timeUntilMidnight])\n\n return (\n <EventDivider dividerType=\"time-indicator\">\n <p className={className('divider__time')} aria-hidden=\"true\">\n <span>{date}</span>\n <span>{time}</span>\n </p>\n <p className={className('visually-hidden')}>{srText}</p>\n </EventDivider>\n )\n}\n\nexport default TimeIndicator\n","/*!\n* tabbable 6.2.0\n* @license MIT, https://github.com/focus-trap/tabbable/blob/master/LICENSE\n*/\n// NOTE: separate `:not()` selectors has broader browser support than the newer\n// `:not([inert], [inert] *)` (Feb 2023)\n// CAREFUL: JSDom does not support `:not([inert] *)` as a selector; using it causes\n// the entire query to fail, resulting in no nodes found, which will break a lot\n// of things... so we have to rely on JS to identify nodes inside an inert container\nvar candidateSelectors = ['input:not([inert])', 'select:not([inert])', 'textarea:not([inert])', 'a[href]:not([inert])', 'button:not([inert])', '[tabindex]:not(slot):not([inert])', 'audio[controls]:not([inert])', 'video[controls]:not([inert])', '[contenteditable]:not([contenteditable=\"false\"]):not([inert])', 'details>summary:first-of-type:not([inert])', 'details:not([inert])'];\nvar candidateSelector = /* #__PURE__ */candidateSelectors.join(',');\nvar NoElement = typeof Element === 'undefined';\nvar matches = NoElement ? function () {} : Element.prototype.matches || Element.prototype.msMatchesSelector || Element.prototype.webkitMatchesSelector;\nvar getRootNode = !NoElement && Element.prototype.getRootNode ? function (element) {\n var _element$getRootNode;\n return element === null || element === void 0 ? void 0 : (_element$getRootNode = element.getRootNode) === null || _element$getRootNode === void 0 ? void 0 : _element$getRootNode.call(element);\n} : function (element) {\n return element === null || element === void 0 ? void 0 : element.ownerDocument;\n};\n\n/**\n * Determines if a node is inert or in an inert ancestor.\n * @param {Element} [node]\n * @param {boolean} [lookUp] If true and `node` is not inert, looks up at ancestors to\n * see if any of them are inert. If false, only `node` itself is considered.\n * @returns {boolean} True if inert itself or by way of being in an inert ancestor.\n * False if `node` is falsy.\n */\nvar isInert = function isInert(node, lookUp) {\n var _node$getAttribute;\n if (lookUp === void 0) {\n lookUp = true;\n }\n // CAREFUL: JSDom does not support inert at all, so we can't use the `HTMLElement.inert`\n // JS API property; we have to check the attribute, which can either be empty or 'true';\n // if it's `null` (not specified) or 'false', it's an active element\n var inertAtt = node === null || node === void 0 ? void 0 : (_node$getAttribute = node.getAttribute) === null || _node$getAttribute === void 0 ? void 0 : _node$getAttribute.call(node, 'inert');\n var inert = inertAtt === '' || inertAtt === 'true';\n\n // NOTE: this could also be handled with `node.matches('[inert], :is([inert] *)')`\n // if it weren't for `matches()` not being a function on shadow roots; the following\n // code works for any kind of node\n // CAREFUL: JSDom does not appear to support certain selectors like `:not([inert] *)`\n // so it likely would not support `:is([inert] *)` either...\n var result = inert || lookUp && node && isInert(node.parentNode); // recursive\n\n return result;\n};\n\n/**\n * Determines if a node's content is editable.\n * @param {Element} [node]\n * @returns True if it's content-editable; false if it's not or `node` is falsy.\n */\nvar isContentEditable = function isContentEditable(node) {\n var _node$getAttribute2;\n // CAREFUL: JSDom does not support the `HTMLElement.isContentEditable` API so we have\n // to use the attribute directly to check for this, which can either be empty or 'true';\n // if it's `null` (not specified) or 'false', it's a non-editable element\n var attValue = node === null || node === void 0 ? void 0 : (_node$getAttribute2 = node.getAttribute) === null || _node$getAttribute2 === void 0 ? void 0 : _node$getAttribute2.call(node, 'contenteditable');\n return attValue === '' || attValue === 'true';\n};\n\n/**\n * @param {Element} el container to check in\n * @param {boolean} includeContainer add container to check\n * @param {(node: Element) => boolean} filter filter candidates\n * @returns {Element[]}\n */\nvar getCandidates = function getCandidates(el, includeContainer, filter) {\n // even if `includeContainer=false`, we still have to check it for inertness because\n // if it's inert, all its children are inert\n if (isInert(el)) {\n return [];\n }\n var candidates = Array.prototype.slice.apply(el.querySelectorAll(candidateSelector));\n if (includeContainer && matches.call(el, candidateSelector)) {\n candidates.unshift(el);\n }\n candidates = candidates.filter(filter);\n return candidates;\n};\n\n/**\n * @callback GetShadowRoot\n * @param {Element} element to check for shadow root\n * @returns {ShadowRoot|boolean} ShadowRoot if available or boolean indicating if a shadowRoot is attached but not available.\n */\n\n/**\n * @callback ShadowRootFilter\n * @param {Element} shadowHostNode the element which contains shadow content\n * @returns {boolean} true if a shadow root could potentially contain valid candidates.\n */\n\n/**\n * @typedef {Object} CandidateScope\n * @property {Element} scopeParent contains inner candidates\n * @property {Element[]} candidates list of candidates found in the scope parent\n */\n\n/**\n * @typedef {Object} IterativeOptions\n * @property {GetShadowRoot|boolean} getShadowRoot true if shadow support is enabled; falsy if not;\n * if a function, implies shadow support is enabled and either returns the shadow root of an element\n * or a boolean stating if it has an undisclosed shadow root\n * @property {(node: Element) => boolean} filter filter candidates\n * @property {boolean} flatten if true then result will flatten any CandidateScope into the returned list\n * @property {ShadowRootFilter} shadowRootFilter filter shadow roots;\n */\n\n/**\n * @param {Element[]} elements list of element containers to match candidates from\n * @param {boolean} includeContainer add container list to check\n * @param {IterativeOptions} options\n * @returns {Array.<Element|CandidateScope>}\n */\nvar getCandidatesIteratively = function getCandidatesIteratively(elements, includeContainer, options) {\n var candidates = [];\n var elementsToCheck = Array.from(elements);\n while (elementsToCheck.length) {\n var element = elementsToCheck.shift();\n if (isInert(element, false)) {\n // no need to look up since we're drilling down\n // anything inside this container will also be inert\n continue;\n }\n if (element.tagName === 'SLOT') {\n // add shadow dom slot scope (slot itself cannot be focusable)\n var assigned = element.assignedElements();\n var content = assigned.length ? assigned : element.children;\n var nestedCandidates = getCandidatesIteratively(content, true, options);\n if (options.flatten) {\n candidates.push.apply(candidates, nestedCandidates);\n } else {\n candidates.push({\n scopeParent: element,\n candidates: nestedCandidates\n });\n }\n } else {\n // check candidate element\n var validCandidate = matches.call(element, candidateSelector);\n if (validCandidate && options.filter(element) && (includeContainer || !elements.includes(element))) {\n candidates.push(element);\n }\n\n // iterate over shadow content if possible\n var shadowRoot = element.shadowRoot ||\n // check for an undisclosed shadow\n typeof options.getShadowRoot === 'function' && options.getShadowRoot(element);\n\n // no inert look up because we're already drilling down and checking for inertness\n // on the way down, so all containers to this root node should have already been\n // vetted as non-inert\n var validShadowRoot = !isInert(shadowRoot, false) && (!options.shadowRootFilter || options.shadowRootFilter(element));\n if (shadowRoot && validShadowRoot) {\n // add shadow dom scope IIF a shadow root node was given; otherwise, an undisclosed\n // shadow exists, so look at light dom children as fallback BUT create a scope for any\n // child candidates found because they're likely slotted elements (elements that are\n // children of the web component element (which has the shadow), in the light dom, but\n // slotted somewhere _inside_ the undisclosed shadow) -- the scope is created below,\n // _after_ we return from this recursive call\n var _nestedCandidates = getCandidatesIteratively(shadowRoot === true ? element.children : shadowRoot.children, true, options);\n if (options.flatten) {\n candidates.push.apply(candidates, _nestedCandidates);\n } else {\n candidates.push({\n scopeParent: element,\n candidates: _nestedCandidates\n });\n }\n } else {\n // there's not shadow so just dig into the element's (light dom) children\n // __without__ giving the element special scope treatment\n elementsToCheck.unshift.apply(elementsToCheck, element.children);\n }\n }\n }\n return candidates;\n};\n\n/**\n * @private\n * Determines if the node has an explicitly specified `tabindex` attribute.\n * @param {HTMLElement} node\n * @returns {boolean} True if so; false if not.\n */\nvar hasTabIndex = function hasTabIndex(node) {\n return !isNaN(parseInt(node.getAttribute('tabindex'), 10));\n};\n\n/**\n * Determine the tab index of a given node.\n * @param {HTMLElement} node\n * @returns {number} Tab order (negative, 0, or positive number).\n * @throws {Error} If `node` is falsy.\n */\nvar getTabIndex = function getTabIndex(node) {\n if (!node) {\n throw new Error('No node provided');\n }\n if (node.tabIndex < 0) {\n // in Chrome, <details/>, <audio controls/> and <video controls/> elements get a default\n // `tabIndex` of -1 when the 'tabindex' attribute isn't specified in the DOM,\n // yet they are still part of the regular tab order; in FF, they get a default\n // `tabIndex` of 0; since Chrome still puts those elements in the regular tab\n // order, consider their tab index to be 0.\n // Also browsers do not return `tabIndex` correctly for contentEditable nodes;\n // so if they don't have a tabindex attribute specifically set, assume it's 0.\n if ((/^(AUDIO|VIDEO|DETAILS)$/.test(node.tagName) || isContentEditable(node)) && !hasTabIndex(node)) {\n return 0;\n }\n }\n return node.tabIndex;\n};\n\n/**\n * Determine the tab index of a given node __for sort order purposes__.\n * @param {HTMLElement} node\n * @param {boolean} [isScope] True for a custom element with shadow root or slot that, by default,\n * has tabIndex -1, but needs to be sorted by document order in order for its content to be\n * inserted into the correct sort position.\n * @returns {number} Tab order (negative, 0, or positive number).\n */\nvar getSortOrderTabIndex = function getSortOrderTabIndex(node, isScope) {\n var tabIndex = getTabIndex(node);\n if (tabIndex < 0 && isScope && !hasTabIndex(node)) {\n return 0;\n }\n return tabIndex;\n};\nvar sortOrderedTabbables = function sortOrderedTabbables(a, b) {\n return a.tabIndex === b.tabIndex ? a.documentOrder - b.documentOrder : a.tabIndex - b.tabIndex;\n};\nvar isInput = function isInput(node) {\n return node.tagName === 'INPUT';\n};\nvar isHiddenInput = function isHiddenInput(node) {\n return isInput(node) && node.type === 'hidden';\n};\nvar isDetailsWithSummary = function isDetailsWithSummary(node) {\n var r = node.tagName === 'DETAILS' && Array.prototype.slice.apply(node.children).some(function (child) {\n return child.tagName === 'SUMMARY';\n });\n return r;\n};\nvar getCheckedRadio = function getCheckedRadio(nodes, form) {\n for (var i = 0; i < nodes.length; i++) {\n if (nodes[i].checked && nodes[i].form === form) {\n return nodes[i];\n }\n }\n};\nvar isTabbableRadio = function isTabbableRadio(node) {\n if (!node.name) {\n return true;\n }\n var radioScope = node.form || getRootNode(node);\n var queryRadios = function queryRadios(name) {\n return radioScope.querySelectorAll('input[type=\"radio\"][name=\"' + name + '\"]');\n };\n var radioSet;\n if (typeof window !== 'undefined' && typeof window.CSS !== 'undefined' && typeof window.CSS.escape === 'function') {\n radioSet = queryRadios(window.CSS.escape(node.name));\n } else {\n try {\n radioSet = queryRadios(node.name);\n } catch (err) {\n // eslint-disable-next-line no-console\n console.error('Looks like you have a radio button with a name attribute containing invalid CSS selector characters and need the CSS.escape polyfill: %s', err.message);\n return false;\n }\n }\n var checked = getCheckedRadio(radioSet, node.form);\n return !checked || checked === node;\n};\nvar isRadio = function isRadio(node) {\n return isInput(node) && node.type === 'radio';\n};\nvar isNonTabbableRadio = function isNonTabbableRadio(node) {\n return isRadio(node) && !isTabbableRadio(node);\n};\n\n// determines if a node is ultimately attached to the window's document\nvar isNodeAttached = function isNodeAttached(node) {\n var _nodeRoot;\n // The root node is the shadow root if the node is in a shadow DOM; some document otherwise\n // (but NOT _the_ document; see second 'If' comment below for more).\n // If rootNode is shadow root, it'll have a host, which is the element to which the shadow\n // is attached, and the one we need to check if it's in the document or not (because the\n // shadow, and all nodes it contains, is never considered in the document since shadows\n // behave like self-contained DOMs; but if the shadow's HOST, which is part of the document,\n // is hidden, or is not in the document itself but is detached, it will affect the shadow's\n // visibility, including all the nodes it contains). The host could be any normal node,\n // or a custom element (i.e. web component). Either way, that's the one that is considered\n // part of the document, not the shadow root, nor any of its children (i.e. the node being\n // tested).\n // To further complicate things, we have to look all the way up until we find a shadow HOST\n // that is attached (or find none) because the node might be in nested shadows...\n // If rootNode is not a shadow root, it won't have a host, and so rootNode should be the\n // document (per the docs) and while it's a Document-type object, that document does not\n // appear to be the same as the node's `ownerDocument` for some reason, so it's safer\n // to ignore the rootNode at this point, and use `node.ownerDocument`. Otherwise,\n // using `rootNode.contains(node)` will _always_ be true we'll get false-positives when\n // node is actually detached.\n // NOTE: If `nodeRootHost` or `node` happens to be the `document` itself (which is possible\n // if a tabbable/focusable node was quickly added to the DOM, focused, and then removed\n // from the DOM as in https://github.com/focus-trap/focus-trap-react/issues/905), then\n // `ownerDocument` will be `null`, hence the optional chaining on it.\n var nodeRoot = node && getRootNode(node);\n var nodeRootHost = (_nodeRoot = nodeRoot) === null || _nodeRoot === void 0 ? void 0 : _nodeRoot.host;\n\n // in some cases, a detached node will return itself as the root instead of a document or\n // shadow root object, in which case, we shouldn't try to look further up the host chain\n var attached = false;\n if (nodeRoot && nodeRoot !== node) {\n var _nodeRootHost, _nodeRootHost$ownerDo, _node$ownerDocument;\n attached = !!((_nodeRootHost = nodeRootHost) !== null && _nodeRootHost !== void 0 && (_nodeRootHost$ownerDo = _nodeRootHost.ownerDocument) !== null && _nodeRootHost$ownerDo !== void 0 && _nodeRootHost$ownerDo.contains(nodeRootHost) || node !== null && node !== void 0 && (_node$ownerDocument = node.ownerDocument) !== null && _node$ownerDocument !== void 0 && _node$ownerDocument.contains(node));\n while (!attached && nodeRootHost) {\n var _nodeRoot2, _nodeRootHost2, _nodeRootHost2$ownerD;\n // since it's not attached and we have a root host, the node MUST be in a nested shadow DOM,\n // which means we need to get the host's host and check if that parent host is contained\n // in (i.e. attached to) the document\n nodeRoot = getRootNode(nodeRootHost);\n nodeRootHost = (_nodeRoot2 = nodeRoot) === null || _nodeRoot2 === void 0 ? void 0 : _nodeRoot2.host;\n attached = !!((_nodeRootHost2 = nodeRootHost) !== null && _nodeRootHost2 !== void 0 && (_nodeRootHost2$ownerD = _nodeRootHost2.ownerDocument) !== null && _nodeRootHost2$ownerD !== void 0 && _nodeRootHost2$ownerD.contains(nodeRootHost));\n }\n }\n return attached;\n};\nvar isZeroArea = function isZeroArea(node) {\n var _node$getBoundingClie = node.getBoundingClientRect(),\n width = _node$getBoundingClie.width,\n height = _node$getBoundingClie.height;\n return width === 0 && height === 0;\n};\nvar isHidden = function isHidden(node, _ref) {\n var displayCheck = _ref.displayCheck,\n getShadowRoot = _ref.getShadowRoot;\n // NOTE: visibility will be `undefined` if node is detached from the document\n // (see notes about this further down), which means we will consider it visible\n // (this is legacy behavior from a very long way back)\n // NOTE: we check this regardless of `displayCheck=\"none\"` because this is a\n // _visibility_ check, not a _display_ check\n if (getComputedStyle(node).visibility === 'hidden') {\n return true;\n }\n var isDirectSummary = matches.call(node, 'details>summary:first-of-type');\n var nodeUnderDetails = isDirectSummary ? node.parentElement : node;\n if (matches.call(nodeUnderDetails, 'details:not([open]) *')) {\n return true;\n }\n if (!displayCheck || displayCheck === 'full' || displayCheck === 'legacy-full') {\n if (typeof getShadowRoot === 'function') {\n // figure out if we should consider the node to be in an undisclosed shadow and use the\n // 'non-zero-area' fallback\n var originalNode = node;\n while (node) {\n var parentElement = node.parentElement;\n var rootNode = getRootNode(node);\n if (parentElement && !parentElement.shadowRoot && getShadowRoot(parentElement) === true // check if there's an undisclosed shadow\n ) {\n // node has an undisclosed shadow which means we can only treat it as a black box, so we\n // fall back to a non-zero-area test\n return isZeroArea(node);\n } else if (node.assignedSlot) {\n // iterate up slot\n node = node.assignedSlot;\n } else if (!parentElement && rootNode !== node.ownerDocument) {\n // cross shadow boundary\n node = rootNode.host;\n } else {\n // iterate up normal dom\n node = parentElement;\n }\n }\n node = originalNode;\n }\n // else, `getShadowRoot` might be true, but all that does is enable shadow DOM support\n // (i.e. it does not also presume that all nodes might have undisclosed shadows); or\n // it might be a falsy value, which means shadow DOM support is disabled\n\n // Since we didn't find it sitting in an undisclosed shadow (or shadows are disabled)\n // now we can just test to see if it would normally be visible or not, provided it's\n // attached to the main document.\n // NOTE: We must consider case where node is inside a shadow DOM and given directly to\n // `isTabbable()` or `isFocusable()` -- regardless of `getShadowRoot` option setting.\n\n if (isNodeAttached(node)) {\n // this works wherever the node is: if there's at least one client rect, it's\n // somehow displayed; it also covers the CSS 'display: contents' case where the\n // node itself is hidden in place of its contents; and there's no need to search\n // up the hierarchy either\n return !node.getClientRects().length;\n }\n\n // Else, the node isn't attached to the document, which means the `getClientRects()`\n // API will __always__ return zero rects (this can happen, for example, if React\n // is used to render nodes onto a detached tree, as confirmed in this thread:\n // https://github.com/facebook/react/issues/9117#issuecomment-284228870)\n //\n // It also means that even window.getComputedStyle(node).display will return `undefined`\n // because styles are only computed for nodes that are in the document.\n //\n // NOTE: THIS HAS BEEN THE CASE FOR YEARS. It is not new, nor is it caused by tabbable\n // somehow. Though it was never stated officially, anyone who has ever used tabbable\n // APIs on nodes in detached containers has actually implicitly used tabbable in what\n // was later (as of v5.2.0 on Apr 9, 2021) called `displayCheck=\"none\"` mode -- essentially\n // considering __everything__ to be visible because of the innability to determine styles.\n //\n // v6.0.0: As of this major release, the default 'full' option __no longer treats detached\n // nodes as visible with the 'none' fallback.__\n if (displayCheck !== 'legacy-full') {\n return true; // hidden\n }\n // else, fallback to 'none' mode and consider the node visible\n } else if (displayCheck === 'non-zero-area') {\n // NOTE: Even though this tests that the node's client rect is non-zero to determine\n // whether it's displayed, and that a detached node will __always__ have a zero-area\n // client rect, we don't special-case for whether the node is attached or not. In\n // this mode, we do want to consider nodes that have a zero area to be hidden at all\n // times, and that includes attached or not.\n return isZeroArea(node);\n }\n\n // visible, as far as we can tell, or per current `displayCheck=none` mode, we assume\n // it's visible\n return false;\n};\n\n// form fields (nested) inside a disabled fieldset are not focusable/tabbable\n// unless they are in the _first_ <legend> element of the top-most disabled\n// fieldset\nvar isDisabledFromFieldset = function isDisabledFromFieldset(node) {\n if (/^(INPUT|BUTTON|SELECT|TEXTAREA)$/.test(node.tagName)) {\n var parentNode = node.parentElement;\n // check if `node` is contained in a disabled <fieldset>\n while (parentNode) {\n if (parentNode.tagName === 'FIELDSET' && parentNode.disabled) {\n // look for the first <legend> among the children of the disabled <fieldset>\n for (var i = 0; i < parentNode.children.length; i++) {\n var child = parentNode.children.item(i);\n // when the first <legend> (in document order) is found\n if (child.tagName === 'LEGEND') {\n // if its parent <fieldset> is not nested in another disabled <fieldset>,\n // return whether `node` is a descendant of its first <legend>\n return matches.call(parentNode, 'fieldset[disabled] *') ? true : !child.contains(node);\n }\n }\n // the disabled <fieldset> containing `node` has no <legend>\n return true;\n }\n parentNode = parentNode.parentElement;\n }\n }\n\n // else, node's tabbable/focusable state should not be affected by a fieldset's\n // enabled/disabled state\n return false;\n};\nvar isNodeMatchingSelectorFocusable = function isNodeMatchingSelectorFocusable(options, node) {\n if (node.disabled ||\n // we must do an inert look up to filter out any elements inside an inert ancestor\n // because we're limited in the type of selectors we can use in JSDom (see related\n // note related to `candidateSelectors`)\n isInert(node) || isHiddenInput(node) || isHidden(node, options) ||\n // For a details element with a summary, the summary element gets the focus\n isDetailsWithSummary(node) || isDisabledFromFieldset(node)) {\n return false;\n }\n return true;\n};\nvar isNodeMatchingSelectorTabbable = function isNodeMatchingSelectorTabbable(options, node) {\n if (isNonTabbableRadio(node) || getTabIndex(node) < 0 || !isNodeMatchingSelectorFocusable(options, node)) {\n return false;\n }\n return true;\n};\nvar isValidShadowRootTabbable = function isValidShadowRootTabbable(shadowHostNode) {\n var tabIndex = parseInt(shadowHostNode.getAttribute('tabindex'), 10);\n if (isNaN(tabIndex) || tabIndex >= 0) {\n return true;\n }\n // If a custom element has an explicit negative tabindex,\n // browsers will not allow tab targeting said element's children.\n return false;\n};\n\n/**\n * @param {Array.<Element|CandidateScope>} candidates\n * @returns Element[]\n */\nvar sortByOrder = function sortByOrder(candidates) {\n var regularTabbables = [];\n var orderedTabbables = [];\n candidates.forEach(function (item, i) {\n var isScope = !!item.scopeParent;\n var element = isScope ? item.scopeParent : item;\n var candidateTabindex = getSortOrderTabIndex(element, isScope);\n var elements = isScope ? sortByOrder(item.candidates) : element;\n if (candidateTabindex === 0) {\n isScope ? regularTabbables.push.apply(regularTabbables, elements) : regularTabbables.push(element);\n } else {\n orderedTabbables.push({\n documentOrder: i,\n tabIndex: candidateTabindex,\n item: item,\n isScope: isScope,\n content: elements\n });\n }\n });\n return orderedTabbables.sort(sortOrderedTabbables).reduce(function (acc, sortable) {\n sortable.isScope ? acc.push.apply(acc, sortable.content) : acc.push(sortable.content);\n return acc;\n }, []).concat(regularTabbables);\n};\nvar tabbable = function tabbable(container, options) {\n options = options || {};\n var candidates;\n if (options.getShadowRoot) {\n candidates = getCandidatesIteratively([container], options.includeContainer, {\n filter: isNodeMatchingSelectorTabbable.bind(null, options),\n flatten: false,\n getShadowRoot: options.getShadowRoot,\n shadowRootFilter: isValidShadowRootTabbable\n });\n } else {\n candidates = getCandidates(container, options.includeContainer, isNodeMatchingSelectorTabbable.bind(null, options));\n }\n return sortByOrder(candidates);\n};\nvar focusable = function focusable(container, options) {\n options = options || {};\n var candidates;\n if (options.getShadowRoot) {\n candidates = getCandidatesIteratively([container], options.includeContainer, {\n filter: isNodeMatchingSelectorFocusable.bind(null, options),\n flatten: true,\n getShadowRoot: options.getShadowRoot\n });\n } else {\n candidates = getCandidates(container, options.includeContainer, isNodeMatchingSelectorFocusable.bind(null, options));\n }\n return candidates;\n};\nvar isTabbable = function isTabbable(node, options) {\n options = options || {};\n if (!node) {\n throw new Error('No node provided');\n }\n if (matches.call(node, candidateSelector) === false) {\n return false;\n }\n return isNodeMatchingSelectorTabbable(options, node);\n};\nvar focusableCandidateSelector = /* #__PURE__ */candidateSelectors.concat('iframe').join(',');\nvar isFocusable = function isFocusable(node, options) {\n options = options || {};\n if (!node) {\n throw new Error('No node provided');\n }\n if (matches.call(node, focusableCandidateSelector) === false) {\n return false;\n }\n return isNodeMatchingSelectorFocusable(options, node);\n};\n\nexport { focusable, getTabIndex, isFocusable, isTabbable, tabbable };\n//# sourceMappingURL=index.esm.js.map\n","/*!\n* focus-trap 7.5.4\n* @license MIT, https://github.com/focus-trap/focus-trap/blob/master/LICENSE\n*/\nimport { isFocusable, tabbable, focusable, isTabbable, getTabIndex } from 'tabbable';\n\nfunction ownKeys(e, r) {\n var t = Object.keys(e);\n if (Object.getOwnPropertySymbols) {\n var o = Object.getOwnPropertySymbols(e);\n r && (o = o.filter(function (r) {\n return Object.getOwnPropertyDescriptor(e, r).enumerable;\n })), t.push.apply(t, o);\n }\n return t;\n}\nfunction _objectSpread2(e) {\n for (var r = 1; r < arguments.length; r++) {\n var t = null != arguments[r] ? arguments[r] : {};\n r % 2 ? ownKeys(Object(t), !0).forEach(function (r) {\n _defineProperty(e, r, t[r]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) {\n Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r));\n });\n }\n return e;\n}\nfunction _defineProperty(obj, key, value) {\n key = _toPropertyKey(key);\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nfunction _toPrimitive(input, hint) {\n if (typeof input !== \"object\" || input === null) return input;\n var prim = input[Symbol.toPrimitive];\n if (prim !== undefined) {\n var res = prim.call(input, hint || \"default\");\n if (typeof res !== \"object\") return res;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (hint === \"string\" ? String : Number)(input);\n}\nfunction _toPropertyKey(arg) {\n var key = _toPrimitive(arg, \"string\");\n return typeof key === \"symbol\" ? key : String(key);\n}\n\nvar activeFocusTraps = {\n activateTrap: function activateTrap(trapStack, trap) {\n if (trapStack.length > 0) {\n var activeTrap = trapStack[trapStack.length - 1];\n if (activeTrap !== trap) {\n activeTrap.pause();\n }\n }\n var trapIndex = trapStack.indexOf(trap);\n if (trapIndex === -1) {\n trapStack.push(trap);\n } else {\n // move this existing trap to the front of the queue\n trapStack.splice(trapIndex, 1);\n trapStack.push(trap);\n }\n },\n deactivateTrap: function deactivateTrap(trapStack, trap) {\n var trapIndex = trapStack.indexOf(trap);\n if (trapIndex !== -1) {\n trapStack.splice(trapIndex, 1);\n }\n if (trapStack.length > 0) {\n trapStack[trapStack.length - 1].unpause();\n }\n }\n};\nvar isSelectableInput = function isSelectableInput(node) {\n return node.tagName && node.tagName.toLowerCase() === 'input' && typeof node.select === 'function';\n};\nvar isEscapeEvent = function isEscapeEvent(e) {\n return (e === null || e === void 0 ? void 0 : e.key) === 'Escape' || (e === null || e === void 0 ? void 0 : e.key) === 'Esc' || (e === null || e === void 0 ? void 0 : e.keyCode) === 27;\n};\nvar isTabEvent = function isTabEvent(e) {\n return (e === null || e === void 0 ? void 0 : e.key) === 'Tab' || (e === null || e === void 0 ? void 0 : e.keyCode) === 9;\n};\n\n// checks for TAB by default\nvar isKeyForward = function isKeyForward(e) {\n return isTabEvent(e) && !e.shiftKey;\n};\n\n// checks for SHIFT+TAB by default\nvar isKeyBackward = function isKeyBackward(e) {\n return isTabEvent(e) && e.shiftKey;\n};\nvar delay = function delay(fn) {\n return setTimeout(fn, 0);\n};\n\n// Array.find/findIndex() are not supported on IE; this replicates enough\n// of Array.findIndex() for our needs\nvar findIndex = function findIndex(arr, fn) {\n var idx = -1;\n arr.every(function (value, i) {\n if (fn(value)) {\n idx = i;\n return false; // break\n }\n\n return true; // next\n });\n\n return idx;\n};\n\n/**\n * Get an option's value when it could be a plain value, or a handler that provides\n * the value.\n * @param {*} value Option's value to check.\n * @param {...*} [params] Any parameters to pass to the handler, if `value` is a function.\n * @returns {*} The `value`, or the handler's returned value.\n */\nvar valueOrHandler = function valueOrHandler(value) {\n for (var _len = arguments.length, params = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n params[_key - 1] = arguments[_key];\n }\n return typeof value === 'function' ? value.apply(void 0, params) : value;\n};\nvar getActualTarget = function getActualTarget(event) {\n // NOTE: If the trap is _inside_ a shadow DOM, event.target will always be the\n // shadow host. However, event.target.composedPath() will be an array of\n // nodes \"clicked\" from inner-most (the actual element inside the shadow) to\n // outer-most (the host HTML document). If we have access to composedPath(),\n // then use its first element; otherwise, fall back to event.target (and\n // this only works for an _open_ shadow DOM; otherwise,\n // composedPath()[0] === event.target always).\n return event.target.shadowRoot && typeof event.composedPath === 'function' ? event.composedPath()[0] : event.target;\n};\n\n// NOTE: this must be _outside_ `createFocusTrap()` to make sure all traps in this\n// current instance use the same stack if `userOptions.trapStack` isn't specified\nvar internalTrapStack = [];\nvar createFocusTrap = function createFocusTrap(elements, userOptions) {\n // SSR: a live trap shouldn't be created in this type of environment so this\n // should be safe code to execute if the `document` option isn't specified\n var doc = (userOptions === null || userOptions === void 0 ? void 0 : userOptions.document) || document;\n var trapStack = (userOptions === null || userOptions === void 0 ? void 0 : userOptions.trapStack) || internalTrapStack;\n var config = _objectSpread2({\n returnFocusOnDeactivate: true,\n escapeDeactivates: true,\n delayInitialFocus: true,\n isKeyForward: isKeyForward,\n isKeyBackward: isKeyBackward\n }, userOptions);\n var state = {\n // containers given to createFocusTrap()\n // @type {Array<HTMLElement>}\n containers: [],\n // list of objects identifying tabbable nodes in `containers` in the trap\n // NOTE: it's possible that a group has no tabbable nodes if nodes get removed while the trap\n // is active, but the trap should never get to a state where there isn't at least one group\n // with at least one tabbable node in it (that would lead to an error condition that would\n // result in an error being thrown)\n // @type {Array<{\n // container: HTMLElement,\n // tabbableNodes: Array<HTMLElement>, // empty if none\n // focusableNodes: Array<HTMLElement>, // empty if none\n // posTabIndexesFound: boolean,\n // firstTabbableNode: HTMLElement|undefined,\n // lastTabbableNode: HTMLElement|undefined,\n // firstDomTabbableNode: HTMLElement|undefined,\n // lastDomTabbableNode: HTMLElement|undefined,\n // nextTabbableNode: (node: HTMLElement, forward: boolean) => HTMLElement|undefined\n // }>}\n containerGroups: [],\n // same order/length as `containers` list\n\n // references to objects in `containerGroups`, but only those that actually have\n // tabbable nodes in them\n // NOTE: same order as `containers` and `containerGroups`, but __not necessarily__\n // the same length\n tabbableGroups: [],\n nodeFocusedBeforeActivation: null,\n mostRecentlyFocusedNode: null,\n active: false,\n paused: false,\n // timer ID for when delayInitialFocus is true and initial focus in this trap\n // has been delayed during activation\n delayInitialFocusTimer: undefined,\n // the most recent KeyboardEvent for the configured nav key (typically [SHIFT+]TAB), if any\n recentNavEvent: undefined\n };\n var trap; // eslint-disable-line prefer-const -- some private functions reference it, and its methods reference private functions, so we must declare here and define later\n\n /**\n * Gets a configuration option value.\n * @param {Object|undefined} configOverrideOptions If true, and option is defined in this set,\n * value will be taken from this object. Otherwise, value will be taken from base configuration.\n * @param {string} optionName Name of the option whose value is sought.\n * @param {string|undefined} [configOptionName] Name of option to use __instead of__ `optionName`\n * IIF `configOverrideOptions` is not defined. Otherwise, `optionName` is used.\n */\n var getOption = function getOption(configOverrideOptions, optionName, configOptionName) {\n return configOverrideOptions && configOverrideOptions[optionName] !== undefined ? configOverrideOptions[optionName] : config[configOptionName || optionName];\n };\n\n /**\n * Finds the index of the container that contains the element.\n * @param {HTMLElement} element\n * @param {Event} [event] If available, and `element` isn't directly found in any container,\n * the event's composed path is used to see if includes any known trap containers in the\n * case where the element is inside a Shadow DOM.\n * @returns {number} Index of the container in either `state.containers` or\n * `state.containerGroups` (the order/length of these lists are the same); -1\n * if the element isn't found.\n */\n var findContainerIndex = function findContainerIndex(element, event) {\n var composedPath = typeof (event === null || event === void 0 ? void 0 : event.composedPath) === 'function' ? event.composedPath() : undefined;\n // NOTE: search `containerGroups` because it's possible a group contains no tabbable\n // nodes, but still contains focusable nodes (e.g. if they all have `tabindex=-1`)\n // and we still need to find the element in there\n return state.containerGroups.findIndex(function (_ref) {\n var container = _ref.container,\n tabbableNodes = _ref.tabbableNodes;\n return container.contains(element) || ( // fall back to explicit tabbable search which will take into consideration any\n // web components if the `tabbableOptions.getShadowRoot` option was used for\n // the trap, enabling shadow DOM support in tabbable (`Node.contains()` doesn't\n // look inside web components even if open)\n composedPath === null || composedPath === void 0 ? void 0 : composedPath.includes(container)) || tabbableNodes.find(function (node) {\n return node === element;\n });\n });\n };\n\n /**\n * Gets the node for the given option, which is expected to be an option that\n * can be either a DOM node, a string that is a selector to get a node, `false`\n * (if a node is explicitly NOT given), or a function that returns any of these\n * values.\n * @param {string} optionName\n * @returns {undefined | false | HTMLElement | SVGElement} Returns\n * `undefined` if the option is not specified; `false` if the option\n * resolved to `false` (node explicitly not given); otherwise, the resolved\n * DOM node.\n * @throws {Error} If the option is set, not `false`, and is not, or does not\n * resolve to a node.\n */\n var getNodeForOption = function getNodeForOption(optionName) {\n var optionValue = config[optionName];\n if (typeof optionValue === 'function') {\n for (var _len2 = arguments.length, params = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n params[_key2 - 1] = arguments[_key2];\n }\n optionValue = optionValue.apply(void 0, params);\n }\n if (optionValue === true) {\n optionValue = undefined; // use default value\n }\n\n if (!optionValue) {\n if (optionValue === undefined || optionValue === false) {\n return optionValue;\n }\n // else, empty string (invalid), null (invalid), 0 (invalid)\n\n throw new Error(\"`\".concat(optionName, \"` was specified but was not a node, or did not return a node\"));\n }\n var node = optionValue; // could be HTMLElement, SVGElement, or non-empty string at this point\n\n if (typeof optionValue === 'string') {\n node = doc.querySelector(optionValue); // resolve to node, or null if fails\n if (!node) {\n throw new Error(\"`\".concat(optionName, \"` as selector refers to no known node\"));\n }\n }\n return node;\n };\n var getInitialFocusNode = function getInitialFocusNode() {\n var node = getNodeForOption('initialFocus');\n\n // false explicitly indicates we want no initialFocus at all\n if (node === false) {\n return false;\n }\n if (node === undefined || !isFocusable(node, config.tabbableOptions)) {\n // option not specified nor focusable: use fallback options\n if (findContainerIndex(doc.activeElement) >= 0) {\n node = doc.activeElement;\n } else {\n var firstTabbableGroup = state.tabbableGroups[0];\n var firstTabbableNode = firstTabbableGroup && firstTabbableGroup.firstTabbableNode;\n\n // NOTE: `fallbackFocus` option function cannot return `false` (not supported)\n node = firstTabbableNode || getNodeForOption('fallbackFocus');\n }\n }\n if (!node) {\n throw new Error('Your focus-trap needs to have at least one focusable element');\n }\n return node;\n };\n var updateTabbableNodes = function updateTabbableNodes() {\n state.containerGroups = state.containers.map(function (container) {\n var tabbableNodes = tabbable(container, config.tabbableOptions);\n\n // NOTE: if we have tabbable nodes, we must have focusable nodes; focusable nodes\n // are a superset of tabbable nodes since nodes with negative `tabindex` attributes\n // are focusable but not tabbable\n var focusableNodes = focusable(container, config.tabbableOptions);\n var firstTabbableNode = tabbableNodes.length > 0 ? tabbableNodes[0] : undefined;\n var lastTabbableNode = tabbableNodes.length > 0 ? tabbableNodes[tabbableNodes.length - 1] : undefined;\n var firstDomTabbableNode = focusableNodes.find(function (node) {\n return isTabbable(node);\n });\n var lastDomTabbableNode = focusableNodes.slice().reverse().find(function (node) {\n return isTabbable(node);\n });\n var posTabIndexesFound = !!tabbableNodes.find(function (node) {\n return getTabIndex(node) > 0;\n });\n return {\n container: container,\n tabbableNodes: tabbableNodes,\n focusableNodes: focusableNodes,\n /** True if at least one node with positive `tabindex` was found in this container. */\n posTabIndexesFound: posTabIndexesFound,\n /** First tabbable node in container, __tabindex__ order; `undefined` if none. */\n firstTabbableNode: firstTabbableNode,\n /** Last tabbable node in container, __tabindex__ order; `undefined` if none. */\n lastTabbableNode: lastTabbableNode,\n // NOTE: DOM order is NOT NECESSARILY \"document position\" order, but figuring that out\n // would require more than just https://developer.mozilla.org/en-US/docs/Web/API/Node/compareDocumentPosition\n // because that API doesn't work with Shadow DOM as well as it should (@see\n // https://github.com/whatwg/dom/issues/320) and since this first/last is only needed, so far,\n // to address an edge case related to positive tabindex support, this seems like a much easier,\n // \"close enough most of the time\" alternative for positive tabindexes which should generally\n // be avoided anyway...\n /** First tabbable node in container, __DOM__ order; `undefined` if none. */\n firstDomTabbableNode: firstDomTabbableNode,\n /** Last tabbable node in container, __DOM__ order; `undefined` if none. */\n lastDomTabbableNode: lastDomTabbableNode,\n /**\n * Finds the __tabbable__ node that follows the given node in the specified direction,\n * in this container, if any.\n * @param {HTMLElement} node\n * @param {boolean} [forward] True if going in forward tab order; false if going\n * in reverse.\n * @returns {HTMLElement|undefined} The next tabbable node, if any.\n */\n nextTabbableNode: function nextTabbableNode(node) {\n var forward = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n var nodeIdx = tabbableNodes.indexOf(node);\n if (nodeIdx < 0) {\n // either not tabbable nor focusable, or was focused but not tabbable (negative tabindex):\n // since `node` should at least have been focusable, we assume that's the case and mimic\n // what browsers do, which is set focus to the next node in __document position order__,\n // regardless of positive tabindexes, if any -- and for reasons explained in the NOTE\n // above related to `firstDomTabbable` and `lastDomTabbable` properties, we fall back to\n // basic DOM order\n if (forward) {\n return focusableNodes.slice(focusableNodes.indexOf(node) + 1).find(function (el) {\n return isTabbable(el);\n });\n }\n return focusableNodes.slice(0, focusableNodes.indexOf(node)).reverse().find(function (el) {\n return isTabbable(el);\n });\n }\n return tabbableNodes[nodeIdx + (forward ? 1 : -1)];\n }\n };\n });\n state.tabbableGroups = state.containerGroups.filter(function (group) {\n return group.tabbableNodes.length > 0;\n });\n\n // throw if no groups have tabbable nodes and we don't have a fallback focus node either\n if (state.tabbableGroups.length <= 0 && !getNodeForOption('fallbackFocus') // returning false not supported for this option\n ) {\n throw new Error('Your focus-trap must have at least one container with at least one tabbable node in it at all times');\n }\n\n // NOTE: Positive tabindexes are only properly supported in single-container traps because\n // doing it across multiple containers where tabindexes could be all over the place\n // would require Tabbable to support multiple containers, would require additional\n // specialized Shadow DOM support, and would require Tabbable's multi-container support\n // to look at those containers in document position order rather than user-provided\n // order (as they are treated in Focus-trap, for legacy reasons). See discussion on\n // https://github.com/focus-trap/focus-trap/issues/375 for more details.\n if (state.containerGroups.find(function (g) {\n return g.posTabIndexesFound;\n }) && state.containerGroups.length > 1) {\n throw new Error(\"At least one node with a positive tabindex was found in one of your focus-trap's multiple containers. Positive tabindexes are only supported in single-container focus-traps.\");\n }\n };\n\n /**\n * Gets the current activeElement. If it's a web-component and has open shadow-root\n * it will recursively search inside shadow roots for the \"true\" activeElement.\n *\n * @param {Document | ShadowRoot} el\n *\n * @returns {HTMLElement} The element that currently has the focus\n **/\n var getActiveElement = function getActiveElement(el) {\n var activeElement = el.activeElement;\n if (!activeElement) {\n return;\n }\n if (activeElement.shadowRoot && activeElement.shadowRoot.activeElement !== null) {\n return getActiveElement(activeElement.shadowRoot);\n }\n return activeElement;\n };\n var tryFocus = function tryFocus(node) {\n if (node === false) {\n return;\n }\n if (node === getActiveElement(document)) {\n return;\n }\n if (!node || !node.focus) {\n tryFocus(getInitialFocusNode());\n return;\n }\n node.focus({\n preventScroll: !!config.preventScroll\n });\n // NOTE: focus() API does not trigger focusIn event so set MRU node manually\n state.mostRecentlyFocusedNode = node;\n if (isSelectableInput(node)) {\n node.select();\n }\n };\n var getReturnFocusNode = function getReturnFocusNode(previousActiveElement) {\n var node = getNodeForOption('setReturnFocus', previousActiveElement);\n return node ? node : node === false ? false : previousActiveElement;\n };\n\n /**\n * Finds the next node (in either direction) where focus should move according to a\n * keyboard focus-in event.\n * @param {Object} params\n * @param {Node} [params.target] Known target __from which__ to navigate, if any.\n * @param {KeyboardEvent|FocusEvent} [params.event] Event to use if `target` isn't known (event\n * will be used to determine the `target`). Ignored if `target` is specified.\n * @param {boolean} [params.isBackward] True if focus should move backward.\n * @returns {Node|undefined} The next node, or `undefined` if a next node couldn't be\n * determined given the current state of the trap.\n */\n var findNextNavNode = function findNextNavNode(_ref2) {\n var target = _ref2.target,\n event = _ref2.event,\n _ref2$isBackward = _ref2.isBackward,\n isBackward = _ref2$isBackward === void 0 ? false : _ref2$isBackward;\n target = target || getActualTarget(event);\n updateTabbableNodes();\n var destinationNode = null;\n if (state.tabbableGroups.length > 0) {\n // make sure the target is actually contained in a group\n // NOTE: the target may also be the container itself if it's focusable\n // with tabIndex='-1' and was given initial focus\n var containerIndex = findContainerIndex(target, event);\n var containerGroup = containerIndex >= 0 ? state.containerGroups[containerIndex] : undefined;\n if (containerIndex < 0) {\n // target not found in any group: quite possible focus has escaped the trap,\n // so bring it back into...\n if (isBackward) {\n // ...the last node in the last group\n destinationNode = state.tabbableGroups[state.tabbableGroups.length - 1].lastTabbableNode;\n } else {\n // ...the first node in the first group\n destinationNode = state.tabbableGroups[0].firstTabbableNode;\n }\n } else if (isBackward) {\n // REVERSE\n\n // is the target the first tabbable node in a group?\n var startOfGroupIndex = findIndex(state.tabbableGroups, function (_ref3) {\n var firstTabbableNode = _ref3.firstTabbableNode;\n return target === firstTabbableNode;\n });\n if (startOfGroupIndex < 0 && (containerGroup.container === target || isFocusable(target, config.tabbableOptions) && !isTabbable(target, config.tabbableOptions) && !containerGroup.nextTabbableNode(target, false))) {\n // an exception case where the target is either the container itself, or\n // a non-tabbable node that was given focus (i.e. tabindex is negative\n // and user clicked on it or node was programmatically given focus)\n // and is not followed by any other tabbable node, in which\n // case, we should handle shift+tab as if focus were on the container's\n // first tabbable node, and go to the last tabbable node of the LAST group\n startOfGroupIndex = containerIndex;\n }\n if (startOfGroupIndex >= 0) {\n // YES: then shift+tab should go to the last tabbable node in the\n // previous group (and wrap around to the last tabbable node of\n // the LAST group if it's the first tabbable node of the FIRST group)\n var destinationGroupIndex = startOfGroupIndex === 0 ? state.tabbableGroups.length - 1 : startOfGroupIndex - 1;\n var destinationGroup = state.tabbableGroups[destinationGroupIndex];\n destinationNode = getTabIndex(target) >= 0 ? destinationGroup.lastTabbableNode : destinationGroup.lastDomTabbableNode;\n } else if (!isTabEvent(event)) {\n // user must have customized the nav keys so we have to move focus manually _within_\n // the active group: do this based on the order determined by tabbable()\n destinationNode = containerGroup.nextTabbableNode(target, false);\n }\n } else {\n // FORWARD\n\n // is the target the last tabbable node in a group?\n var lastOfGroupIndex = findIndex(state.tabbableGroups, function (_ref4) {\n var lastTabbableNode = _ref4.lastTabbableNode;\n return target === lastTabbableNode;\n });\n if (lastOfGroupIndex < 0 && (containerGroup.container === target || isFocusable(target, config.tabbableOptions) && !isTabbable(target, config.tabbableOptions) && !containerGroup.nextTabbableNode(target))) {\n // an exception case where the target is the container itself, or\n // a non-tabbable node that was given focus (i.e. tabindex is negative\n // and user clicked on it or node was programmatically given focus)\n // and is not followed by any other tabbable node, in which\n // case, we should handle tab as if focus were on the container's\n // last tabbable node, and go to the first tabbable node of the FIRST group\n lastOfGroupIndex = containerIndex;\n }\n if (lastOfGroupIndex >= 0) {\n // YES: then tab should go to the first tabbable node in the next\n // group (and wrap around to the first tabbable node of the FIRST\n // group if it's the last tabbable node of the LAST group)\n var _destinationGroupIndex = lastOfGroupIndex === state.tabbableGroups.length - 1 ? 0 : lastOfGroupIndex + 1;\n var _destinationGroup = state.tabbableGroups[_destinationGroupIndex];\n destinationNode = getTabIndex(target) >= 0 ? _destinationGroup.firstTabbableNode : _destinationGroup.firstDomTabbableNode;\n } else if (!isTabEvent(event)) {\n // user must have customized the nav keys so we have to move focus manually _within_\n // the active group: do this based on the order determined by tabbable()\n destinationNode = containerGroup.nextTabbableNode(target);\n }\n }\n } else {\n // no groups available\n // NOTE: the fallbackFocus option does not support returning false to opt-out\n destinationNode = getNodeForOption('fallbackFocus');\n }\n return destinationNode;\n };\n\n // This needs to be done on mousedown and touchstart instead of click\n // so that it precedes the focus event.\n var checkPointerDown = function checkPointerDown(e) {\n var target = getActualTarget(e);\n if (findContainerIndex(target, e) >= 0) {\n // allow the click since it ocurred inside the trap\n return;\n }\n if (valueOrHandler(config.clickOutsideDeactivates, e)) {\n // immediately deactivate the trap\n trap.deactivate({\n // NOTE: by setting `returnFocus: false`, deactivate() will do nothing,\n // which will result in the outside click setting focus to the node\n // that was clicked (and if not focusable, to \"nothing\"); by setting\n // `returnFocus: true`, we'll attempt to re-focus the node originally-focused\n // on activation (or the configured `setReturnFocus` node), whether the\n // outside click was on a focusable node or not\n returnFocus: config.returnFocusOnDeactivate\n });\n return;\n }\n\n // This is needed for mobile devices.\n // (If we'll only let `click` events through,\n // then on mobile they will be blocked anyways if `touchstart` is blocked.)\n if (valueOrHandler(config.allowOutsideClick, e)) {\n // allow the click outside the trap to take place\n return;\n }\n\n // otherwise, prevent the click\n e.preventDefault();\n };\n\n // In case focus escapes the trap for some strange reason, pull it back in.\n // NOTE: the focusIn event is NOT cancelable, so if focus escapes, it may cause unexpected\n // scrolling if the node that got focused was out of view; there's nothing we can do to\n // prevent that from happening by the time we discover that focus escaped\n var checkFocusIn = function checkFocusIn(event) {\n var target = getActualTarget(event);\n var targetContained = findContainerIndex(target, event) >= 0;\n\n // In Firefox when you Tab out of an iframe the Document is briefly focused.\n if (targetContained || target instanceof Document) {\n if (targetContained) {\n state.mostRecentlyFocusedNode = target;\n }\n } else {\n // escaped! pull it back in to where it just left\n event.stopImmediatePropagation();\n\n // focus will escape if the MRU node had a positive tab index and user tried to nav forward;\n // it will also escape if the MRU node had a 0 tab index and user tried to nav backward\n // toward a node with a positive tab index\n var nextNode; // next node to focus, if we find one\n var navAcrossContainers = true;\n if (state.mostRecentlyFocusedNode) {\n if (getTabIndex(state.mostRecentlyFocusedNode) > 0) {\n // MRU container index must be >=0 otherwise we wouldn't have it as an MRU node...\n var mruContainerIdx = findContainerIndex(state.mostRecentlyFocusedNode);\n // there MAY not be any tabbable nodes in the container if there are at least 2 containers\n // and the MRU node is focusable but not tabbable (focus-trap requires at least 1 container\n // with at least one tabbable node in order to function, so this could be the other container\n // with nothing tabbable in it)\n var tabbableNodes = state.containerGroups[mruContainerIdx].tabbableNodes;\n if (tabbableNodes.length > 0) {\n // MRU tab index MAY not be found if the MRU node is focusable but not tabbable\n var mruTabIdx = tabbableNodes.findIndex(function (node) {\n return node === state.mostRecentlyFocusedNode;\n });\n if (mruTabIdx >= 0) {\n if (config.isKeyForward(state.recentNavEvent)) {\n if (mruTabIdx + 1 < tabbableNodes.length) {\n nextNode = tabbableNodes[mruTabIdx + 1];\n navAcrossContainers = false;\n }\n // else, don't wrap within the container as focus should move to next/previous\n // container\n } else {\n if (mruTabIdx - 1 >= 0) {\n nextNode = tabbableNodes[mruTabIdx - 1];\n navAcrossContainers = false;\n }\n // else, don't wrap within the container as focus should move to next/previous\n // container\n }\n // else, don't find in container order without considering direction too\n }\n }\n // else, no tabbable nodes in that container (which means we must have at least one other\n // container with at least one tabbable node in it, otherwise focus-trap would've thrown\n // an error the last time updateTabbableNodes() was run): find next node among all known\n // containers\n } else {\n // check to see if there's at least one tabbable node with a positive tab index inside\n // the trap because focus seems to escape when navigating backward from a tabbable node\n // with tabindex=0 when this is the case (instead of wrapping to the tabbable node with\n // the greatest positive tab index like it should)\n if (!state.containerGroups.some(function (g) {\n return g.tabbableNodes.some(function (n) {\n return getTabIndex(n) > 0;\n });\n })) {\n // no containers with tabbable nodes with positive tab indexes which means the focus\n // escaped for some other reason and we should just execute the fallback to the\n // MRU node or initial focus node, if any\n navAcrossContainers = false;\n }\n }\n } else {\n // no MRU node means we're likely in some initial condition when the trap has just\n // been activated and initial focus hasn't been given yet, in which case we should\n // fall through to trying to focus the initial focus node, which is what should\n // happen below at this point in the logic\n navAcrossContainers = false;\n }\n if (navAcrossContainers) {\n nextNode = findNextNavNode({\n // move FROM the MRU node, not event-related node (which will be the node that is\n // outside the trap causing the focus escape we're trying to fix)\n target: state.mostRecentlyFocusedNode,\n isBackward: config.isKeyBackward(state.recentNavEvent)\n });\n }\n if (nextNode) {\n tryFocus(nextNode);\n } else {\n tryFocus(state.mostRecentlyFocusedNode || getInitialFocusNode());\n }\n }\n state.recentNavEvent = undefined; // clear\n };\n\n // Hijack key nav events on the first and last focusable nodes of the trap,\n // in order to prevent focus from escaping. If it escapes for even a\n // moment it can end up scrolling the page and causing confusion so we\n // kind of need to capture the action at the keydown phase.\n var checkKeyNav = function checkKeyNav(event) {\n var isBackward = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n state.recentNavEvent = event;\n var destinationNode = findNextNavNode({\n event: event,\n isBackward: isBackward\n });\n if (destinationNode) {\n if (isTabEvent(event)) {\n // since tab natively moves focus, we wouldn't have a destination node unless we\n // were on the edge of a container and had to move to the next/previous edge, in\n // which case we want to prevent default to keep the browser from moving focus\n // to where it normally would\n event.preventDefault();\n }\n tryFocus(destinationNode);\n }\n // else, let the browser take care of [shift+]tab and move the focus\n };\n\n var checkKey = function checkKey(event) {\n if (isEscapeEvent(event) && valueOrHandler(config.escapeDeactivates, event) !== false) {\n event.preventDefault();\n trap.deactivate();\n return;\n }\n if (config.isKeyForward(event) || config.isKeyBackward(event)) {\n checkKeyNav(event, config.isKeyBackward(event));\n }\n };\n var checkClick = function checkClick(e) {\n var target = getActualTarget(e);\n if (findContainerIndex(target, e) >= 0) {\n return;\n }\n if (valueOrHandler(config.clickOutsideDeactivates, e)) {\n return;\n }\n if (valueOrHandler(config.allowOutsideClick, e)) {\n return;\n }\n e.preventDefault();\n e.stopImmediatePropagation();\n };\n\n //\n // EVENT LISTENERS\n //\n\n var addListeners = function addListeners() {\n if (!state.active) {\n return;\n }\n\n // There can be only one listening focus trap at a time\n activeFocusTraps.activateTrap(trapStack, trap);\n\n // Delay ensures that the focused element doesn't capture the event\n // that caused the focus trap activation.\n state.delayInitialFocusTimer = config.delayInitialFocus ? delay(function () {\n tryFocus(getInitialFocusNode());\n }) : tryFocus(getInitialFocusNode());\n doc.addEventListener('focusin', checkFocusIn, true);\n doc.addEventListener('mousedown', checkPointerDown, {\n capture: true,\n passive: false\n });\n doc.addEventListener('touchstart', checkPointerDown, {\n capture: true,\n passive: false\n });\n doc.addEventListener('click', checkClick, {\n capture: true,\n passive: false\n });\n doc.addEventListener('keydown', checkKey, {\n capture: true,\n passive: false\n });\n return trap;\n };\n var removeListeners = function removeListeners() {\n if (!state.active) {\n return;\n }\n doc.removeEventListener('focusin', checkFocusIn, true);\n doc.removeEventListener('mousedown', checkPointerDown, true);\n doc.removeEventListener('touchstart', checkPointerDown, true);\n doc.removeEventListener('click', checkClick, true);\n doc.removeEventListener('keydown', checkKey, true);\n return trap;\n };\n\n //\n // MUTATION OBSERVER\n //\n\n var checkDomRemoval = function checkDomRemoval(mutations) {\n var isFocusedNodeRemoved = mutations.some(function (mutation) {\n var removedNodes = Array.from(mutation.removedNodes);\n return removedNodes.some(function (node) {\n return node === state.mostRecentlyFocusedNode;\n });\n });\n\n // If the currently focused is removed then browsers will move focus to the\n // <body> element. If this happens, try to move focus back into the trap.\n if (isFocusedNodeRemoved) {\n tryFocus(getInitialFocusNode());\n }\n };\n\n // Use MutationObserver - if supported - to detect if focused node is removed\n // from the DOM.\n var mutationObserver = typeof window !== 'undefined' && 'MutationObserver' in window ? new MutationObserver(checkDomRemoval) : undefined;\n var updateObservedNodes = function updateObservedNodes() {\n if (!mutationObserver) {\n return;\n }\n mutationObserver.disconnect();\n if (state.active && !state.paused) {\n state.containers.map(function (container) {\n mutationObserver.observe(container, {\n subtree: true,\n childList: true\n });\n });\n }\n };\n\n //\n // TRAP DEFINITION\n //\n\n trap = {\n get active() {\n return state.active;\n },\n get paused() {\n return state.paused;\n },\n activate: function activate(activateOptions) {\n if (state.active) {\n return this;\n }\n var onActivate = getOption(activateOptions, 'onActivate');\n var onPostActivate = getOption(activateOptions, 'onPostActivate');\n var checkCanFocusTrap = getOption(activateOptions, 'checkCanFocusTrap');\n if (!checkCanFocusTrap) {\n updateTabbableNodes();\n }\n state.active = true;\n state.paused = false;\n state.nodeFocusedBeforeActivation = doc.activeElement;\n onActivate === null || onActivate === void 0 || onActivate();\n var finishActivation = function finishActivation() {\n if (checkCanFocusTrap) {\n updateTabbableNodes();\n }\n addListeners();\n updateObservedNodes();\n onPostActivate === null || onPostActivate === void 0 || onPostActivate();\n };\n if (checkCanFocusTrap) {\n checkCanFocusTrap(state.containers.concat()).then(finishActivation, finishActivation);\n return this;\n }\n finishActivation();\n return this;\n },\n deactivate: function deactivate(deactivateOptions) {\n if (!state.active) {\n return this;\n }\n var options = _objectSpread2({\n onDeactivate: config.onDeactivate,\n onPostDeactivate: config.onPostDeactivate,\n checkCanReturnFocus: config.checkCanReturnFocus\n }, deactivateOptions);\n clearTimeout(state.delayInitialFocusTimer); // noop if undefined\n state.delayInitialFocusTimer = undefined;\n removeListeners();\n state.active = false;\n state.paused = false;\n updateObservedNodes();\n activeFocusTraps.deactivateTrap(trapStack, trap);\n var onDeactivate = getOption(options, 'onDeactivate');\n var onPostDeactivate = getOption(options, 'onPostDeactivate');\n var checkCanReturnFocus = getOption(options, 'checkCanReturnFocus');\n var returnFocus = getOption(options, 'returnFocus', 'returnFocusOnDeactivate');\n onDeactivate === null || onDeactivate === void 0 || onDeactivate();\n var finishDeactivation = function finishDeactivation() {\n delay(function () {\n if (returnFocus) {\n tryFocus(getReturnFocusNode(state.nodeFocusedBeforeActivation));\n }\n onPostDeactivate === null || onPostDeactivate === void 0 || onPostDeactivate();\n });\n };\n if (returnFocus && checkCanReturnFocus) {\n checkCanReturnFocus(getReturnFocusNode(state.nodeFocusedBeforeActivation)).then(finishDeactivation, finishDeactivation);\n return this;\n }\n finishDeactivation();\n return this;\n },\n pause: function pause(pauseOptions) {\n if (state.paused || !state.active) {\n return this;\n }\n var onPause = getOption(pauseOptions, 'onPause');\n var onPostPause = getOption(pauseOptions, 'onPostPause');\n state.paused = true;\n onPause === null || onPause === void 0 || onPause();\n removeListeners();\n updateObservedNodes();\n onPostPause === null || onPostPause === void 0 || onPostPause();\n return this;\n },\n unpause: function unpause(unpauseOptions) {\n if (!state.paused || !state.active) {\n return this;\n }\n var onUnpause = getOption(unpauseOptions, 'onUnpause');\n var onPostUnpause = getOption(unpauseOptions, 'onPostUnpause');\n state.paused = false;\n onUnpause === null || onUnpause === void 0 || onUnpause();\n updateTabbableNodes();\n addListeners();\n updateObservedNodes();\n onPostUnpause === null || onPostUnpause === void 0 || onPostUnpause();\n return this;\n },\n updateContainerElements: function updateContainerElements(containerElements) {\n var elementsAsArray = [].concat(containerElements).filter(Boolean);\n state.containers = elementsAsArray.map(function (element) {\n return typeof element === 'string' ? doc.querySelector(element) : element;\n });\n if (state.active) {\n updateTabbableNodes();\n }\n updateObservedNodes();\n return this;\n }\n };\n\n // initialize container elements\n trap.updateContainerElements(elements);\n return trap;\n};\n\nexport { createFocusTrap };\n//# sourceMappingURL=focus-trap.esm.js.map\n","import { createFocusTrap } from 'focus-trap'\nimport { render, toChildArray } from 'preact'\nimport { useEffect, useLayoutEffect, useRef, useState } from 'preact/hooks'\nimport { useGeneratedId } from 'ui/hooks/seamly-hooks'\nimport { createAriaHider } from 'ui/utils/general-utils'\n\nconst Modal = ({\n children,\n onClose,\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n fallBackFocusRef,\n}) => {\n const modalId = useGeneratedId()\n const modalContainer = useRef(null)\n const focusTrap = useRef(null)\n const [containerIsSet, setContainerIsSet] = useState(false)\n\n useEffect(() => {\n if (containerIsSet) {\n focusTrap.current = createFocusTrap(modalContainer.current, {\n initialFocus:\n fallBackFocusRef && fallBackFocusRef.current\n ? fallBackFocusRef.current\n : null,\n })\n focusTrap.current.activate()\n }\n return () => {\n if (focusTrap.current) {\n focusTrap.current.deactivate()\n }\n }\n }, [containerIsSet, fallBackFocusRef])\n\n useEffect(() => {\n const disposeAriaHider = createAriaHider()\n return () => {\n disposeAriaHider()\n }\n }, [containerIsSet])\n\n useEffect(() => {\n if (containerIsSet) {\n modalContainer.current.addEventListener('keydown', (event) => {\n if ((event.code && event.code === 'Escape') || event.keyCode === 27) {\n onClose()\n }\n })\n }\n }, [containerIsSet, onClose])\n\n useLayoutEffect(() => {\n const bodyElement = document.getElementsByTagName('body')[0]\n const container = document.createElement('div')\n container.setAttribute('id', modalId)\n container.setAttribute('role', 'dialog')\n container.setAttribute('data-nosnippet', 'true')\n container.setAttribute('aria-modal', 'true')\n if (ariaLabel) {\n container.setAttribute('aria-label', ariaLabel)\n }\n if (ariaLabelledBy) {\n container.setAttribute('aria-labelledby', ariaLabelledBy)\n }\n bodyElement.appendChild(container)\n modalContainer.current = container\n setContainerIsSet(true)\n return () => {\n if (modalContainer.current) {\n bodyElement.removeChild(modalContainer.current)\n modalContainer.current = null\n }\n }\n }, [ariaLabel, ariaLabelledBy, modalId])\n\n // This component can either be provided with a children render\n // function or another component.\n // If a render function the function will be called with the onClose\n // handler function as well as a modalRenderFn that should be used to\n // render your content.\n // <Modal onClose={onCloseHandler} aria-label=\"label test\">\n // {({ onClose, modalRenderFn }) =>\n // modalRenderFn(<MyContent onClose={onClose} />)\n // }\n // </Modal>\n // If called with a single component, no render function is required\n // and the onClose function will be automatically added to the\n // single child component.\n // <Modal onClose={onCloseHandler} aria-label=\"label test\" >\n // <MyContent />\n // </Modal>\n return typeof children === 'function'\n ? children({\n onClose,\n modalRenderFn: (els) =>\n modalContainer.current && render(els, modalContainer.current),\n })\n : modalContainer.current &&\n render(\n toChildArray(children).map((child) => {\n child.props = { ...child.props, onClose }\n return child\n }),\n modalContainer.current,\n )\n}\n\nexport default Modal\n","import { useRef } from 'preact/hooks'\nimport { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport {\n useSeamlyActivityEventHandler,\n useSeamlyAppContainerClassNames,\n} from 'ui/hooks/seamly-hooks'\nimport Modal from './modal'\n\nconst Lightbox = ({ url, description, onClose: onCloseHandler }) => {\n const { zIndex, layoutMode, namespace } = useConfig()\n const onActivityHandler = useSeamlyActivityEventHandler()\n const appContainerClassNames = useSeamlyAppContainerClassNames()\n const focusContainer = useRef(null)\n const { t } = useI18n()\n\n // TODO: Change incorrect usage of css modifiers\n const defaultClassNames = [\n `app--layout-${layoutMode}`,\n `namespace--${namespace}`,\n ]\n const classNames = ['modal', ...defaultClassNames, ...appContainerClassNames]\n\n const onFrameClickHandler = (e) => {\n e.stopPropagation()\n }\n\n const onFloatClickHandler = () => {\n onCloseHandler()\n }\n\n const style = zIndex ? { zIndex: zIndex + 1 } : undefined\n\n const getModalContent = (onClose) => (\n <div\n className={className(classNames)}\n onClick={onFloatClickHandler}\n style={style}\n >\n <div\n className={className('modal__float')}\n tabIndex=\"-1\"\n onMouseDown={onActivityHandler}\n onKeyDown={onActivityHandler}\n onTouchStart={onActivityHandler}\n onMouseMove={onActivityHandler}\n onWheel={onActivityHandler}\n onPointerDown={onActivityHandler}\n onPointerMove={onActivityHandler}\n ref={focusContainer}\n >\n <div\n className={className('modal__inner')}\n onClick={onFrameClickHandler}\n >\n <img\n className={className('modal__image')}\n src={url}\n alt={description}\n />\n </div>\n <button\n type=\"button\"\n className={className('modal__close')}\n onClick={onClose}\n >\n <Icon name=\"close\" size=\"16\" alt=\"\" />\n {t('lightbox.closeLabel')}\n </button>\n </div>\n </div>\n )\n\n return (\n <Modal\n onClose={onCloseHandler}\n aria-label={t('lightbox.heading')}\n fallBackFocusRef={focusContainer}\n >\n {({ onClose, modalRenderFn }) => modalRenderFn(getModalContent(onClose))}\n </Modal>\n )\n}\n\nexport default Lightbox\n","import { useState } from 'preact/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport Lightbox from 'ui/components/widgets/lightbox'\n\nconst ImageLightbox = ({ description, url }) => {\n const { t } = useI18n()\n const [showLightBox, setShowLightBox] = useState(false)\n\n const onOpenLightboxHandler = () => {\n setShowLightBox(true)\n }\n\n const onCloseLightboxHandler = () => {\n setShowLightBox(false)\n }\n\n return (\n <>\n <button\n type=\"button\"\n className={className('modal__enlarge')}\n onClick={onOpenLightboxHandler}\n >\n {t('message.image.srTextEnlargeButtonLabel', { description })}\n <Icon name=\"enlarge\" size=\"32\" alt=\"\" />\n </button>\n {showLightBox && (\n <Lightbox\n url={url}\n description={description}\n onClose={onCloseLightboxHandler}\n />\n )}\n </>\n )\n}\n\nexport default ImageLightbox\n","import { useMemo } from 'preact/hooks'\nimport { useTranslatedEventData } from 'domains/translations/hooks'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport useEventLinkClickHandler from './hooks/use-event-link-click-handler'\n\nconst Text = ({ event, ...props }) => {\n const { body } = useTranslatedEventData(event)\n const eventClick = useEventLinkClickHandler(event.payload.id)\n\n const containerProps = useMemo(() => {\n if (event.payload.optimisticallyInjected) {\n return {\n children: <p>{body.text}</p>,\n }\n }\n\n return {\n bodyProps: {\n dangerouslySetInnerHTML: {\n __html: body?.data?.text || body.text,\n },\n },\n }\n }, [body, event])\n\n return (\n <MessageContainer\n type=\"text\"\n event={event}\n onClick={eventClick}\n {...props}\n {...containerProps}\n />\n )\n}\n\nexport default Text\n","import { useMemo } from 'preact/hooks'\nimport { useSelector } from 'react-redux'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { useTranslatedEventData } from 'domains/translations/hooks'\nimport { className } from 'lib/css'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport Icon from 'ui/components/layout/icon'\n\nconst PROCESSING_IMAGE = 'PROCESSING_IMAGE'\n\nconst useImageFromStorage = (currentFileId) => {\n const { processingFileUploads } = useSelector(({ state }) => state)\n\n return useMemo(() => {\n const isProcessingImg = processingFileUploads.some(\n (fileId) => fileId === currentFileId,\n )\n\n if (isProcessingImg) return PROCESSING_IMAGE\n\n try {\n return sessionStorage.getItem(`image-${currentFileId}`)\n } catch (error) {\n return undefined\n }\n }, [currentFileId, processingFileUploads])\n}\n\nconst UploadedImage = ({ img, filename }) => {\n const { t } = useI18n()\n const srText = t('fileUpload.srFileUploadedText', { fileName: filename })\n\n return (\n <>\n <span className={className(['download', 'download--preview'])}>\n <img src={img} alt={srText} />\n <span aria-hidden=\"true\" className={className('file-download')}>\n {filename}\n </span>\n </span>\n </>\n )\n}\n\nconst UploadContent = ({ children, url, target }) =>\n url ? (\n <a\n href={url}\n download\n target={target}\n className={className(['download', 'download-link'])}\n >\n {children}\n </a>\n ) : (\n <span className={className('download')}>{children}</span>\n )\n\nconst Upload = ({ event, ...props }) => {\n const { t } = useI18n()\n const { body } = useTranslatedEventData(event)\n const { fromClient, id } = event.payload\n const { filename, url } = body\n const img = useImageFromStorage(id)\n\n const srText = useMemo(\n () =>\n url\n ? t('fileUpload.srFileDownloadText', { fileName: filename })\n : t('fileUpload.srFileUploadedText', { fileName: filename }),\n [url, filename, t],\n )\n\n return (\n <MessageContainer event={event} type=\"upload\" {...props}>\n {img && img !== PROCESSING_IMAGE ? (\n <UploadedImage img={img} filename={filename} />\n ) : (\n <UploadContent url={url} target={!fromClient ? '_blank' : undefined}>\n <Icon name=\"download\" size=\"16\" alt={srText} />\n <span aria-hidden=\"true\" className={className('file-download')}>\n {filename}\n </span>\n </UploadContent>\n )}\n </MessageContainer>\n )\n}\n\nexport default Upload\n","import { useMemo } from 'preact/hooks'\nimport { useConfig } from 'domains/config/hooks'\nimport ComponentContext from './component-context'\nimport CardMessage from './event/card-message'\nimport CarouselMessage from './event/carousel-message'\nimport ChoicePrompt from './event/choice-prompt'\nimport ConversationSuggestions from './event/conversation-suggestions'\nimport Cta from './event/cta'\nimport Divider from './event/divider'\nimport TimeIndicator from './event/divider/variants/time-indicator'\nimport Image from './event/image'\nimport Participant from './event/participant'\nimport Splash from './event/splash'\nimport Text from './event/text'\nimport Translation from './event/translation'\nimport Upload from './event/upload'\nimport Video from './event/video'\n\nconst eventTypeMapping = {\n message: {\n choice_prompt: ChoicePrompt,\n text: Text,\n image: Image,\n splash: Splash,\n video: Video,\n upload: Upload,\n cta: Cta,\n carousel: CarouselMessage,\n card: CardMessage,\n },\n info: {\n text: Text,\n divider: Divider,\n translation: Translation,\n timeIndicator: TimeIndicator,\n },\n participant: {\n participant: Participant,\n },\n service_data: {\n suggestion: ConversationSuggestions,\n },\n}\n\nconst ComponentFilter = ({ children }) => {\n const { customComponents } = useConfig()\n\n const resolvedComponents = useMemo(() => {\n // Calculates a combined component mapping object based on the defaults with\n // user implementation component overrides where required.\n return Object.keys(eventTypeMapping).reduce(\n (acc, key) => {\n return {\n ...acc,\n [key]: {\n ...eventTypeMapping[key],\n ...(customComponents ? customComponents[key] : {}),\n },\n }\n },\n { fallback: Text },\n )\n }, [customComponents])\n\n return (\n <ComponentContext.Provider value={resolvedComponents}>\n {children}\n </ComponentContext.Provider>\n )\n}\n\nexport default ComponentFilter\n","import { useState } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { setLoadedImageEventIds } from 'domains/store/slice'\nimport { useTranslatedEventData } from 'domains/translations/hooks'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport ImageLightbox from './image-lightbox'\n\nconst Image = ({ event, descriptorId, ...props }) => {\n const { body } = useTranslatedEventData(event)\n const { description, url, isZoomable } = body\n const [showLighbox, setShowLightbox] = useState(false)\n const dispatch = useDispatch()\n\n const handleOnLoad = () => {\n dispatch(setLoadedImageEventIds(event.payload.id))\n setShowLightbox(true)\n }\n\n return (\n <MessageContainer event={event} type=\"image\" {...props}>\n <img\n src={url}\n id={descriptorId}\n alt={description}\n onLoad={handleOnLoad}\n />\n {isZoomable && showLighbox && (\n <ImageLightbox description={description} url={url} />\n )}\n </MessageContainer>\n )\n}\n\nexport default Image\n","import { useTranslatedEventData } from 'domains/translations/hooks'\nimport useEventLinkClickHandler from 'ui/components/conversation/event/hooks/use-event-link-click-handler'\nimport MessageContainer from 'ui/components/conversation/message-container'\n\nconst Splash = ({ event, ...props }) => {\n const { payload } = event\n const { body } = useTranslatedEventData(event)\n const eventClick = useEventLinkClickHandler(payload.id)\n\n return (\n <MessageContainer\n type=\"splash\"\n event={event}\n onClick={eventClick}\n {...props}\n bodyProps={{\n dangerouslySetInnerHTML: {\n __html: body.text,\n },\n }}\n />\n )\n}\n\nexport default Splash\n","import { useTranslatedEventData } from 'domains/translations/hooks'\nimport { className } from 'lib/css'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport { useSeamlyMessageContainerClassNames } from 'ui/hooks/seamly-hooks'\n\nconst Video = ({ event, descriptorId, ...props }) => {\n const { body } = useTranslatedEventData(event)\n const { description, url } = body\n const classNames = useSeamlyMessageContainerClassNames(event)\n\n classNames.push('message--type-video')\n\n return (\n <MessageContainer event={event} type=\"video\" {...props}>\n <div id={descriptorId} className={className('visually-hidden')}>\n {description}\n </div>\n <iframe\n title={description}\n src={url}\n allow=\"autoplay; encrypted-media\"\n allowFullScreen\n />\n </MessageContainer>\n )\n}\n\nexport default Video\n","import { useCallback } from 'preact/hooks'\nimport { useTranslatedEventData } from 'domains/translations/hooks'\nimport { className } from 'lib/css'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport { useGeneratedId, useSeamlyCommands } from 'ui/hooks/seamly-hooks'\nimport { actionTypes } from 'ui/utils/seamly-utils'\nimport useEventLinkClickHandler from './hooks/use-event-link-click-handler'\n\nconst Cta = ({ event }) => {\n const { body } = useTranslatedEventData(event)\n const eventClick = useEventLinkClickHandler(event.payload.id)\n const { emitEvent } = useSeamlyCommands()\n\n const descriptionId = useGeneratedId()\n\n const onClickHandler = useCallback(\n () =>\n emitEvent(`action.${actionTypes.clickCta}`, {\n type: actionTypes.clickCta,\n originMessage: event.payload.id,\n link: {\n url: body.buttonLink,\n },\n }),\n [emitEvent, body, event],\n )\n\n return (\n <MessageContainer type=\"cta\" event={event}>\n <div\n className={className('cta__content')}\n id={descriptionId}\n dangerouslySetInnerHTML={{ __html: body.description }}\n onClick={eventClick}\n />\n <a\n className={className('button', 'button--primary')}\n aria-describedby={descriptionId}\n href={body.buttonLink}\n rel=\"noreferrer\"\n target={body.buttonNewTab ? '_blank' : '_self'}\n onClick={onClickHandler}\n >\n {body.buttonText}\n </a>\n </MessageContainer>\n )\n}\n\nexport default Cta\n","import { useTranslatedEventData } from 'domains/translations/hooks'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport { useGeneratedId } from 'ui/hooks/seamly-hooks'\nimport CardComponent from './card-component'\n\nconst CardMessage = ({ event }) => {\n const { body } = useTranslatedEventData(event)\n const descriptionId = useGeneratedId()\n\n return (\n <MessageContainer type=\"card\" event={event}>\n <CardComponent id={descriptionId} {...body} />\n </MessageContainer>\n )\n}\n\nexport default CardMessage\n","import { useI18n } from 'domains/i18n/hooks'\nimport { useTranslatedEventData } from 'domains/translations/hooks'\nimport MessageContainer from 'ui/components/conversation/message-container'\n\nconst Translation = ({ event, ...props }) => {\n const { t } = useI18n()\n const { body } = useTranslatedEventData(event)\n return (\n <MessageContainer type=\"text\" event={event} {...props}>\n {t(body.key.join('.'), body.variables)}\n </MessageContainer>\n )\n}\n\nexport default Translation\n","import { useTranslatedEventData } from 'domains/translations/hooks'\nimport EventDivider from 'ui/components/conversation/event-divider'\n\nconst Participant = ({ event }) => {\n const { participant } = event.payload\n const { body: introduction } = useTranslatedEventData(event)\n\n if (!introduction) {\n return null\n }\n\n return (\n <EventDivider\n graphicSrc={participant.avatar}\n graphicType={participant.avatar ? 'avatar' : undefined}\n iconName={!participant.avatar ? 'balloon' : undefined}\n childrenHTML={introduction}\n dividerType=\"participant\"\n />\n )\n}\n\nexport default Participant\n","import { useCallback, useMemo, useState } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { useUserHasResponded } from 'domains/app/hooks'\nimport { setHasResponded } from 'domains/app/slice'\nimport { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { useTranslatedEventData } from 'domains/translations/hooks'\nimport { className } from 'lib/css'\nimport MessageContainer from 'ui/components/conversation/message-container'\nimport SuggestionsList from 'ui/components/suggestions/suggestions-list'\nimport { useEvents, useSeamlyCommands } from 'ui/hooks/seamly-hooks'\nimport { actionTypes } from 'ui/utils/seamly-utils'\n\nexport const useSuggestions = (event) => {\n const { payload } = event\n const { body: suggestions } = useTranslatedEventData(event)\n\n return {\n suggestions,\n payload,\n }\n}\n\nconst ConversationSuggestions = ({ event, ...props }) => {\n const [isExpanded, setIsExpanded] = useState(true)\n const dispatch = useDispatch()\n const userHasResponded = useUserHasResponded()\n const { sendAction, addMessageBubble } = useSeamlyCommands()\n const { suggestions, payload } = useSuggestions(event)\n const { showSuggestions } = useConfig()\n const events = useEvents()\n\n const { t } = useI18n()\n const headingText = t('suggestions.headingText')\n const footerText = t('suggestions.footerText')\n\n // We check if there is at least one last transaction\n // to avoid rendering the suggestions before prior events are rendered.\n const hasLastTransactionEvent = useMemo(\n () =>\n events.some(({ payload: eventPayload }) => eventPayload?.transactionLast),\n [events],\n )\n\n const handleClick = useCallback(\n ({ id, question }) => {\n setIsExpanded(false)\n dispatch(setHasResponded(true))\n\n // @todo Refactor to 'suggestionclick'\n sendAction({\n type: actionTypes.custom,\n originMessage: payload.id,\n body: {\n type: 'faqclick',\n body: {\n faqId: id,\n faqQuestion: question,\n },\n },\n })\n\n addMessageBubble(question)\n },\n [dispatch, sendAction, payload.id, addMessageBubble],\n )\n\n if (\n !isExpanded ||\n userHasResponded ||\n !hasLastTransactionEvent ||\n !showSuggestions\n ) {\n return null\n }\n\n return (\n <div className={className('suggestions', 'suggestions--conversation')}>\n {headingText && (\n <p className={className('suggestions__heading')}>{headingText}</p>\n )}\n <MessageContainer\n type=\"suggestions\"\n showParticipant={false}\n event={event}\n {...props}\n >\n <SuggestionsList\n className=\"suggestions__list--conversation\"\n onClickSuggestion={handleClick}\n suggestions={suggestions}\n />\n {footerText && (\n <p className={className('suggestions__footer')}>{footerText}</p>\n )}\n </MessageContainer>\n </div>\n )\n}\n\nexport default ConversationSuggestions\n","import { RefObject, createContext } from 'preact'\nimport { MutableRef } from 'preact/hooks'\n\nconst ChatScrollContext = createContext<{\n eventRefs: Record<string, RefObject<HTMLElement>>\n unreadIds: string[]\n scrollToRef: () => void\n scrollToBottom: () => void\n containerRef: MutableRef<HTMLDivElement>\n}>(null)\n\nexport default ChatScrollContext\n","import { useContext } from 'preact/hooks'\nimport ComponentContext from 'ui/components/conversation/component-context'\nimport { payloadTypes } from 'ui/utils/seamly-utils'\n\nconst useEventComponentMapping = (event) => {\n const components = useContext(ComponentContext)\n const componentType = components[event.type]\n let Component = componentType[event.payload.type]\n let SubComponent = null\n\n if (event.payload.type === payloadTypes.choicePrompt) {\n SubComponent = componentType[event.payload.body.prompt.type]\n }\n\n if (event.type === 'participant') {\n Component = componentType[event.type]\n }\n\n if (Component && typeof Component !== 'function') {\n Component = Component[event.payload.body.type]\n }\n\n return [Component || components?.fallback, SubComponent]\n}\n\nexport default useEventComponentMapping\n","import { FunctionComponent, useContext, useEffect } from 'preact/compat'\nimport { useDispatch } from 'react-redux'\nimport { setEventsRead } from 'domains/store/slice'\nimport { useIntersect } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport ChatScrollContext from 'ui/components/conversation/event/chat-scroll/chat-scroll-context'\nimport TimeIndicator from 'ui/components/conversation/event/divider/variants/time-indicator'\nimport { useSeamlyCommands } from 'ui/hooks/seamly-hooks'\nimport useEventComponentMapping from 'ui/hooks/use-event-component-mapping'\nimport { actionTypes } from 'ui/utils/seamly-utils'\n\nconst Event: FunctionComponent<{\n event\n newParticipant: boolean\n}> = ({ event, newParticipant }) => {\n const { eventRefs, unreadIds } = useContext(ChatScrollContext)\n const { sendAction } = useSeamlyCommands()\n const ref = eventRefs[event.payload.id]\n const { containerRef, isVisible } = useIntersect({\n containerRef: ref,\n freezeOnceVisible: true,\n })\n const dispatch = useDispatch()\n const [Component, SubComponent] = useEventComponentMapping(event)\n\n useEffect(() => {\n if (isVisible && unreadIds?.includes(event.payload.id)) {\n const readIds = unreadIds.reduce<string[]>(\n (arr, id) => (!arr.includes(event.payload.id) ? arr.concat(id) : arr),\n [],\n )\n\n dispatch(setEventsRead(readIds))\n sendAction({ type: actionTypes.read, events: readIds })\n }\n }, [dispatch, event.payload.id, isVisible, sendAction, unreadIds])\n\n if (!Component) {\n return null\n }\n\n const classNames = ['conversation__item']\n\n if (event.type === 'info') {\n classNames.push('conversation__item--source-info')\n } else if (event.payload.fromClient) {\n classNames.push('conversation__item--source-user')\n } else {\n classNames.push('conversation__item--source-agent')\n }\n\n if (newParticipant) {\n classNames.push('conversation__item--new-participant')\n }\n\n return (\n <li className={className(classNames)} ref={containerRef}>\n {event.timeIndicator && <TimeIndicator event={event} />}\n <Component event={event}>\n <SubComponent event={event} />\n </Component>\n </li>\n )\n}\n\nexport default Event\n","import { className } from 'lib/css'\nimport { useSeamlyCurrentAgent } from 'ui/hooks/seamly-hooks'\nimport EventParticipant from './event/event-participant'\n\nconst Loader = () => {\n const { id } = useSeamlyCurrentAgent() || {}\n\n return (\n <li\n className={className(\n 'conversation__item',\n 'conversation__item--source-agent',\n )}\n >\n <div\n className={className(\n 'message',\n 'message--source-agent',\n 'message--type-loading',\n )}\n >\n <EventParticipant\n eventPayload={{\n fromClient: false,\n participant: id,\n }}\n />\n <div className={className('message__body')}>\n <span className={className('loader')}>\n <span className={className('loader__part', 'one')} />\n <span className={className('loader__part', 'two')} />\n <span className={className('loader__part', 'three')} />\n <span className={className('loader__part', 'four')} />\n </span>\n </div>\n </div>\n </li>\n )\n}\n\nexport default Loader\n","import { useI18n } from 'domains/i18n/hooks'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport PrivacyDisclaimer from 'ui/components/layout/privacy-disclaimer'\nimport {\n useSeamlyIsLoading,\n useSkiplink,\n useSkiplinkTargetFocusing,\n} from 'ui/hooks/seamly-hooks'\nimport { useEvents } from 'ui/hooks/seamly-state-hooks'\nimport useDebounce from 'ui/hooks/use-debounce'\nimport AbortTransactionButton from '../entry/abort-transaction-button/abort-transaction-button'\nimport ComponentFilter from './component-filter'\nimport Event from './event/event'\nimport Loader from './loader'\n\nconst Events = () => {\n const events = useEvents()\n\n let prevParticipant = null\n return (\n <>\n {events.map((event) => {\n const { type, payload } = event\n\n let participantChanged = false\n if (type !== 'participant' && type !== 'service_data') {\n const { participant, fromClient } = payload\n const currentParticipant = fromClient\n ? 'seamly-client-participant'\n : participant\n if (event.type !== 'info' && prevParticipant !== currentParticipant) {\n participantChanged = true\n }\n prevParticipant = currentParticipant\n }\n\n return (\n <Event\n key={event.payload.key || event.payload.id}\n event={event}\n newParticipant={participantChanged}\n />\n )\n })}\n </>\n )\n}\n\nconst Conversation = () => {\n const { t } = useI18n()\n const isLoading = useSeamlyIsLoading()\n const debouncedIsLoading = useDebounce(isLoading, isLoading ? 0 : 20)\n const { isOpen } = useVisibility()\n const skiplinkTargetId = useSkiplink()\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n\n const onClickHandler = (e) => {\n e.preventDefault()\n focusSkiplinkTarget()\n }\n\n return (\n <>\n {isOpen && (\n <a\n className={className('skip-link')}\n href={`#${skiplinkTargetId}`}\n onClick={onClickHandler}\n >\n {t('skiplinkText')}\n </a>\n )}\n\n <div className={className('chat__body')}>\n <div className={className('conversation__container')}>\n <PrivacyDisclaimer />\n <ol className={className('conversation')}>\n <ComponentFilter>\n <Events />\n </ComponentFilter>\n {debouncedIsLoading ? <Loader /> : null}\n <AbortTransactionButton />\n </ol>\n </div>\n </div>\n </>\n )\n}\n\nexport default Conversation\n","import { useEffect, useRef, useState } from 'preact/hooks'\n\nconst useDebounce = <T extends unknown>(value: T, delay = 20): T => {\n const [debouncedValue, setDebouncedValue] = useState<T>(value)\n const timeoutRef = useRef<ReturnType<typeof setTimeout>>(null)\n\n useEffect(() => {\n timeoutRef.current = setTimeout(() => setDebouncedValue(value), delay)\n\n return () => {\n clearTimeout(timeoutRef.current)\n }\n }, [value, delay])\n\n return debouncedValue\n}\n\nexport default useDebounce\n","import { className } from 'lib/css'\nimport { useGeneratedId, useSkiplink } from 'ui/hooks/seamly-hooks'\n\nconst Prompt = ({ baseClassName, children, title }) => {\n const skiplinkTargetId = useSkiplink()\n const containerHeadingId = useGeneratedId()\n\n return (\n <section\n id={skiplinkTargetId}\n className={className(baseClassName)}\n aria-describedby={containerHeadingId}\n tabIndex=\"-1\"\n >\n <h2\n className={className(`${baseClassName}__title`)}\n id={containerHeadingId}\n >\n {title}\n </h2>\n {children}\n </section>\n )\n}\n\nexport default Prompt\n","import { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport { useSkiplinkTargetFocusing } from 'ui/hooks/focus-helper-hooks'\nimport useSeamlyActivityEventHandler from 'ui/hooks/use-seamly-activity-event-handler'\nimport useSeamlyCommands from 'ui/hooks/use-seamly-commands'\nimport useSeamlyIdleDetachCountdown from 'ui/hooks/use-seamly-idle-detach-countdown'\nimport Prompt from './prompt'\n\nconst IdleDetachWarning = () => {\n const { t } = useI18n()\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n const sendActivity = useSeamlyActivityEventHandler()\n const { emitEvent } = useSeamlyCommands()\n\n const { isActive, remaining, timer, endCountdown } =\n useSeamlyIdleDetachCountdown()\n\n const continueChat = () => {\n sendActivity()\n endCountdown(true)\n focusSkiplinkTarget()\n emitEvent('idleTimer.selectContinue')\n }\n\n const transferChat = () => {\n endCountdown()\n focusSkiplinkTarget()\n emitEvent('idleTimer.selectEnd')\n }\n\n const countDownComplete = remaining > 0\n const title = countDownComplete\n ? t('idleDetachWarning.countdownTitle')\n : t('idleDetachWarning.notifyTransferText')\n\n return (\n <Prompt baseClassName=\"idle\" title={title}>\n {countDownComplete && (\n <>\n <div className={className('idle__count-container')}>\n {isActive && (\n <>\n <span className={className('idle__count-text')}>\n {t('idleDetachWarning.countdownText')}\n </span>\n <span className={className('idle__count-timer')}>\n {t('idleDetachWarning.countdownTimer', timer)}\n </span>\n </>\n )}\n </div>\n <div className={className('idle__options')}>\n <button\n type=\"button\"\n className={className('button', 'button--primary')}\n onClick={continueChat}\n >\n {t('idleDetachWarning.continueButton')}\n </button>\n <button\n type=\"button\"\n className={className('button', 'button--primary')}\n onClick={transferChat}\n >\n {t('idleDetachWarning.detachButton')}\n </button>\n </div>\n </>\n )}\n </Prompt>\n )\n}\n\nexport default IdleDetachWarning\n","import { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport { useSeamlyCurrentAgent } from 'ui/hooks/seamly-state-hooks'\nimport useSeamlyActivityEventHandler from 'ui/hooks/use-seamly-activity-event-handler'\nimport useSeamlyResumeConversationPrompt from 'ui/hooks/use-seamly-resume-conversation-prompt'\nimport Prompt from './prompt'\n\nconst ResumeConversationPrompt = () => {\n const { t } = useI18n()\n const sendActivity = useSeamlyActivityEventHandler()\n const { name: currentAgentName } = useSeamlyCurrentAgent() || {}\n\n const { continueChat, restartChat } = useSeamlyResumeConversationPrompt()\n\n const continueChatHandler = () => {\n sendActivity()\n continueChat()\n }\n\n return (\n <Prompt\n baseClassName=\"prompt\"\n title={t('resumeConversationPrompt.title', { name: currentAgentName })}\n >\n <div className={className('prompt__options')}>\n <button\n type=\"button\"\n className={className('button', 'button--primary')}\n onClick={continueChatHandler}\n >\n {t('resumeConversationPrompt.continueButton')}\n </button>\n <button\n type=\"button\"\n className={className('button', 'button--primary')}\n onClick={restartChat}\n >\n {t('resumeConversationPrompt.detachButton')}\n </button>\n </div>\n </Prompt>\n )\n}\n\nexport default ResumeConversationPrompt\n","import { useCallback, useEffect, useRef } from 'preact/hooks'\nimport { useDispatch } from 'react-redux'\nimport { typingTimeout } from 'config'\nimport {\n setActiveEntryType,\n setBlockAutoEntrySwitch,\n setUserEntryType,\n} from 'domains/store/slice'\nimport { useSeamlyCommands, useSeamlyOptions } from 'ui/hooks/seamly-hooks'\nimport { useSeamlyStateContext } from 'ui/hooks/seamly-state-hooks'\nimport { actionTypes } from 'ui/utils/seamly-utils'\n\nexport const useSeamlyTyping = () => {\n const { sendAction } = useSeamlyCommands()\n const { features } = useSeamlyOptions()\n const { typingPeekahead } = features || {}\n const typingTimerId = useRef(null)\n const sendEndTypingTimerId = useRef(null)\n const isTyping = useRef(false)\n const typingIntervalId = useRef(null)\n\n useEffect(() => {\n return () => {\n clearInterval(typingIntervalId.current)\n clearTimeout(typingTimerId.current)\n clearTimeout(sendEndTypingTimerId.current)\n }\n }, [])\n\n const sendTypingState = (state, currentMessage) => {\n sendAction({\n type: actionTypes.typing,\n state,\n ...(typingPeekahead && typingPeekahead.enabled\n ? {\n body: {\n currentMessage,\n },\n }\n : {}),\n })\n }\n\n return (e) => {\n if ((e.code && e.code === 'Enter') || e.keyCode === 13) {\n return\n }\n\n isTyping.current = true\n if (!typingIntervalId.current) {\n sendTypingState(true, e.target.value)\n typingIntervalId.current = setInterval(() => {\n if (!isTyping.current) {\n clearInterval(typingIntervalId.current)\n typingIntervalId.current = null\n } else if (typingPeekahead && typingPeekahead.enabled) {\n sendTypingState(true, e.target.value)\n }\n }, typingTimeout)\n }\n\n clearTimeout(typingTimerId.current)\n clearTimeout(sendEndTypingTimerId.current)\n\n typingTimerId.current = setTimeout(() => {\n isTyping.current = false\n }, 300)\n\n sendEndTypingTimerId.current = setTimeout(() => {\n sendTypingState(false, e.target.value)\n }, typingTimeout)\n }\n}\n\nexport const useSeamlyEntry = () => {\n const {\n default: defaultEntry,\n active,\n userSelected,\n options: entryOptions,\n optionsOverride: entryOptionsOverride,\n } = useSeamlyStateContext().entryMeta\n const dispatch = useDispatch()\n\n const activeEntry = userSelected || active || defaultEntry\n const activeEntryOptions =\n entryOptionsOverride[activeEntry] || entryOptions[activeEntry] || {}\n\n const dispatchBlockAutoEntrySwitch = useCallback(\n (value) => {\n dispatch(setBlockAutoEntrySwitch(value))\n },\n [dispatch],\n )\n\n const dispatchActiveEntryType = useCallback(\n (entryType) => {\n dispatch(setActiveEntryType(entryType))\n },\n [dispatch],\n )\n\n const dispatchUserEntryType = useCallback(\n (entryType) => {\n dispatch(setUserEntryType(entryType))\n },\n [dispatch],\n )\n\n const cancelEntrySelection = useCallback(() => {\n if (userSelected) {\n dispatchUserEntryType(null)\n } else {\n dispatchActiveEntryType(defaultEntry)\n }\n }, [\n userSelected,\n defaultEntry,\n dispatchUserEntryType,\n dispatchActiveEntryType,\n ])\n\n return {\n activeEntry,\n activeEntryOptions,\n setActiveEntryType: dispatchActiveEntryType,\n setUserEntryType: dispatchUserEntryType,\n cancelEntrySelection,\n setBlockAutoEntrySwitch: dispatchBlockAutoEntrySwitch,\n }\n}\n","import {\n useCallback,\n useEffect,\n useLayoutEffect,\n useMemo,\n useState,\n} from 'preact/hooks'\nimport { useDispatch, useSelector } from 'react-redux'\nimport { setHasResponded } from 'domains/app/slice'\nimport { Provider } from 'domains/forms/context'\nimport { useValidations } from 'domains/forms/hooks'\nimport { getFormValuesByFormId } from 'domains/forms/selectors'\nimport {\n deregisterForm,\n updateControlTouched as dispatchControlTouched,\n updateControlValue as dispatchControlValue,\n registerForm,\n} from 'domains/forms/slice'\nimport type { RootState } from 'domains/store'\n\nexport default function FormProvider({\n children,\n formId,\n persistData,\n onError,\n onSubmit,\n validationSchema,\n ...props\n}) {\n const dispatch = useDispatch()\n const values = useSelector((store: RootState) =>\n getFormValuesByFormId(store, { formId }),\n )\n const [isSubmitted, setIsSubmitted] = useState(false)\n const [externalErrors, setExternalErrors] = useState({})\n const { isValid: validationIsValid, errors: validationErrors } =\n useValidations(values, validationSchema)\n const errors = useMemo(\n () => ({\n ...validationErrors,\n ...externalErrors,\n }),\n [validationErrors, externalErrors],\n )\n\n // register\n useLayoutEffect(() => {\n // register form in redux store\n dispatch(registerForm({ formId, persistData }))\n }, [formId, persistData, dispatch])\n\n // deregister\n useEffect(() => {\n return () => {\n // deregister form from redux store\n dispatch(deregisterForm({ formId }))\n }\n }, [formId, persistData, dispatch])\n\n const updateControlValue = useCallback(\n (name, value) => {\n dispatch(dispatchControlValue({ formId, name, value }))\n },\n [formId, dispatch],\n )\n\n const updateControlTouched = useCallback(\n (name, touched) => {\n dispatch(dispatchControlTouched({ formId, name, touched }))\n },\n [dispatch, formId],\n )\n\n // Function to manually set an error\n const setError = useCallback(\n (name, error) => {\n setExternalErrors((val) => {\n return {\n ...val,\n [name]: error,\n }\n })\n },\n [setExternalErrors],\n )\n\n const handleSubmit = useCallback(\n (e) => {\n e.preventDefault()\n // If the submitter is set to being aria-disabled, block the submit action\n const ariaDisabled = e.submitter.getAttribute('aria-disabled') === 'true'\n setIsSubmitted(!ariaDisabled)\n if (!ariaDisabled && validationIsValid) {\n dispatch(setHasResponded(true))\n onSubmit(values, { updateControlValue, setError })\n }\n },\n [\n validationIsValid,\n dispatch,\n onSubmit,\n values,\n updateControlValue,\n setError,\n ],\n )\n\n useEffect(() => {\n if (onError) {\n onError({\n errors,\n isSubmitted,\n isValid: Object.keys(errors).length === 0,\n })\n }\n }, [isSubmitted, errors, onError])\n\n const contextValue = useMemo(\n () => ({\n formId,\n values,\n errors,\n isValid: Object.keys(errors).length === 0,\n isSubmitted,\n handleSubmit,\n validationSchema,\n updateControlValue,\n updateControlTouched,\n }),\n [\n formId,\n values,\n errors,\n isSubmitted,\n handleSubmit,\n validationSchema,\n updateControlValue,\n updateControlTouched,\n ],\n )\n\n if (!formId) {\n console.error('\"formId\" is required.')\n return null\n }\n if (!onSubmit) {\n console.error('\"onSubmit\" is required.')\n return null\n }\n\n return (\n <Provider {...props} value={contextValue}>\n {children}\n </Provider>\n )\n}\n","export function validate(values, schema: Record<string, unknown> = {}) {\n return Object.entries(schema).reduce((errors, [key, validations]) => {\n const validationsArr = !Array.isArray(validations)\n ? [validations]\n : validations\n\n for (let i = 0; i < validationsArr?.length ?? 0; i++) {\n if (!validationsArr[i].fn(values[key], validationsArr[i].compareValue)) {\n errors[key] = validationsArr[i].errorText\n break\n }\n }\n return errors\n }, {})\n}\n","import { useForm } from 'domains/forms/hooks'\nimport { className } from 'lib/css'\n\nfunction Form({\n className: givenClassName,\n disableValidationClasses,\n ...props\n}) {\n const { handleSubmit, isValid, isSubmitted } = useForm()\n\n const formClasses = ['form']\n\n if (!disableValidationClasses && isSubmitted) {\n formClasses.push('form--submitted')\n\n if (isValid) {\n formClasses.push('form--valid')\n } else {\n formClasses.push('form--invalid')\n }\n }\n\n return (\n <form\n onSubmit={handleSubmit}\n className={className([...formClasses, givenClassName])}\n {...props}\n />\n )\n}\n\nexport default Form\n","import { useEffect, useState } from 'preact/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\n\nexport default function Error({ id, error }) {\n const [isAvailable, setIsAvailable] = useState(false)\n useEffect(() => {\n const timerId = setTimeout(() => setIsAvailable(true), 300) // 300 = magic number, could be less or more\n return () => clearTimeout(timerId) // clear timer if error is mounted+unmounted within 300\n }, [])\n\n return (\n <div\n className={className('error')}\n aria-live=\"assertive\"\n aria-atomic=\"true\"\n >\n {isAvailable && error && (\n <span id={id} className={className('error__message')}>\n <Icon name=\"error\" size=\"16\" alt=\"\" />\n {error}\n </span>\n )}\n </div>\n )\n}\n","import { FC } from 'preact/compat'\nimport { className } from 'lib/css'\nimport Error from './error'\n\ntype FormControlWrapperProps = {\n contentHint: string\n id: string\n labelText: string\n labelClass: string\n validity: boolean\n errorText: unknown\n}\n\nconst FormControlWrapper: FC<FormControlWrapperProps> = ({\n contentHint,\n id,\n labelText,\n labelClass,\n validity,\n errorText,\n children,\n}) => {\n return (\n <>\n {contentHint && (\n <span\n id={`${id}-content-hint`}\n className={className('input__content-hint')}\n >\n {contentHint}\n </span>\n )}\n\n <Error id={`${id}-error`} error={!validity && errorText} />\n\n <div className={className('form-control__wrapper')}>\n <label htmlFor={id} className={className(labelClass)}>\n {labelText}\n </label>\n {children}\n </div>\n </>\n )\n}\n\nexport default FormControlWrapper\n","import { HTMLAttributes } from 'preact/compat'\nimport { useFormContext, useFormControl } from 'domains/forms/hooks'\nimport FormControlWrapper from './wrapper'\n\ntype InputProps = HTMLAttributes<HTMLInputElement> & {\n id: string\n name: string\n type: string\n labelText: string\n labelClass: string\n contentHint?: string\n 'aria-describedby'?: string\n}\n\nfunction Input({\n id,\n name,\n type,\n labelText,\n labelClass,\n contentHint = null,\n 'aria-describedby': ariaDescribedBy,\n ...props\n}: InputProps) {\n const { isSubmitted } = useFormContext()\n const [field, { error }] = useFormControl(name)\n const hasError = isSubmitted && error\n\n const describedByIds = []\n if (ariaDescribedBy) {\n describedByIds.push(ariaDescribedBy)\n }\n if (contentHint) {\n describedByIds.push(`${id}-content-hint`)\n }\n if (hasError) {\n describedByIds.push(`${id}-error`)\n }\n\n // todo: destructure Field\n return (\n <FormControlWrapper\n id={id}\n contentHint={contentHint}\n validity={!hasError}\n errorText={error}\n labelText={labelText}\n labelClass={labelClass}\n >\n <input\n id={id}\n name={name}\n type={type}\n aria-invalid={hasError ? 'true' : 'false'}\n aria-describedby={describedByIds.join(' ') || null}\n {...field}\n {...props}\n />\n </FormControlWrapper>\n )\n}\n\nexport default Input\n","import { useCallback, useLayoutEffect } from 'preact/hooks'\nimport { useFormControl } from 'domains/forms/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport Form from 'ui/components/form-controls/form'\nimport Input from 'ui/components/form-controls/input'\nimport Icon from 'ui/components/layout/icon'\nimport { useSeamlyEntry, useSeamlyTyping } from 'ui/hooks/seamly-entry-hooks'\nimport { useLiveRegion, useSeamlyCommands } from 'ui/hooks/seamly-hooks'\nimport { useCharacterLimit, useEntryTextTranslation } from './hooks'\n\nexport default function TextEntryForm({ controlName, skipLinkId }) {\n const { t } = useI18n()\n const { sendAssertive } = useLiveRegion()\n const { emitEvent } = useSeamlyCommands()\n const handleKeyUp = useSeamlyTyping()\n const { setBlockAutoEntrySwitch } = useSeamlyEntry()\n const { placeholder, label, labelClass } =\n useEntryTextTranslation(controlName)\n // TODO: Standardize the validation on form fields\n const {\n hasCharacterLimit,\n reachedCharacterWarning,\n reachedCharacterLimit,\n remainingChars,\n } = useCharacterLimit(controlName)\n const [{ value }] = useFormControl(controlName)\n\n const hasValue = !!value\n\n const handleFocus = useCallback(() => {\n if (reachedCharacterWarning) {\n sendAssertive(t('input.srCharacterLimitText', { limit: remainingChars }))\n }\n\n emitEvent('ui.inputFocus')\n }, [t, sendAssertive, reachedCharacterWarning, remainingChars, emitEvent])\n\n // When the input holds a value, the component should be blocked from switching\n // to file upload form.\n useLayoutEffect(() => {\n setBlockAutoEntrySwitch(hasValue)\n\n return () => {\n setBlockAutoEntrySwitch(false)\n }\n }, [setBlockAutoEntrySwitch, hasValue])\n\n const handlePointerDown = (event) => {\n // When a message is submitted, the keyboard should be prevented from closing on mobile devices\n event.preventDefault()\n }\n\n return (\n <Form\n className={className('entry-form')}\n disableValidationClasses\n noValidate=\"true\"\n >\n <div\n className={className([\n 'input--text__container',\n ...(reachedCharacterWarning && !reachedCharacterLimit\n ? ['character-warning']\n : []),\n ...(reachedCharacterLimit ? ['character-exceeded'] : []),\n ])}\n >\n <Input\n id={skipLinkId}\n type=\"text\"\n name={controlName}\n className={className('input__text')}\n autocomplete=\"off\"\n placeholder={placeholder}\n labelText={label}\n labelClass={className(labelClass)}\n aria-invalid={hasCharacterLimit ? reachedCharacterLimit : null}\n onKeyUp={handleKeyUp}\n onFocus={handleFocus}\n />\n <div className={className('character-count')}>\n {reachedCharacterWarning && <span>{remainingChars}</span>}\n </div>\n </div>\n <button\n className={className('button', 'input__submit')}\n type=\"submit\"\n onPointerDown={handlePointerDown}\n aria-disabled={!hasValue || reachedCharacterLimit ? 'true' : null}\n >\n <Icon name=\"send\" size=\"32\" alt={t('input.sendMessage')} />\n </button>\n </Form>\n )\n}\n","import { useCallback } from 'preact/hooks'\nimport FormProvider from 'domains/forms/provider'\nimport { visibilityStates } from 'domains/visibility/constants'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport {\n useSeamlyCommands,\n useSkiplink,\n useSkiplinkTargetFocusing,\n} from 'ui/hooks/seamly-hooks'\nimport TextEntryForm from './text-entry-form'\n\nexport const textEntryControlName = 'textMessageEntry'\n\nexport default function TextEntry({ ...props }) {\n const { isOpen, setVisibility } = useVisibility()\n const skipLinkId = useSkiplink()\n const focusSkipLinkTarget = useSkiplinkTargetFocusing()\n const { sendMessage } = useSeamlyCommands()\n const handleSubmit = useCallback(\n (values, { updateControlValue }) => {\n sendMessage({ body: values[textEntryControlName] })\n updateControlValue(textEntryControlName, '')\n focusSkipLinkTarget()\n\n if (!isOpen) {\n setVisibility(visibilityStates.open)\n }\n },\n [sendMessage, focusSkipLinkTarget, isOpen, setVisibility],\n )\n\n return (\n <FormProvider\n {...props}\n formId=\"textEntry\"\n persistData={true}\n onSubmit={handleSubmit}\n >\n <TextEntryForm\n controlName={textEntryControlName}\n skipLinkId={skipLinkId}\n />\n </FormProvider>\n )\n}\n","import { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport Error from 'ui/components/form-controls/error'\nimport { useFileUploads } from 'ui/hooks/seamly-hooks'\n\nconst UploadProgress = () => {\n const { t } = useI18n()\n const { currentUploads } = useFileUploads()\n\n return (\n <div className={className('progress')}>\n {currentUploads.map(({ id, name, progress, uploading, error }) => (\n <div key={id} className={className('progress_container')}>\n <div className={className('progress__text')}>\n <span className={className('progress__text--file-name')}>\n {name}\n </span>\n <span\n className={className('progress__text--percentage')}\n >{`${progress}%`}</span>\n </div>\n <Error error={error} />\n <progress\n className={className('progress__bar')}\n role=\"progressbar\"\n aria-valuemin=\"0\"\n aria-valuemax=\"100\"\n aria-label={t('fileUpload.srProgressLabel', { fileName: name })}\n max=\"100\"\n aria-valuenow={progress}\n value={progress}\n aria-busy={uploading}\n >\n {`${progress}%`}\n </progress>\n </div>\n ))}\n </div>\n )\n}\n\nexport default UploadProgress\n","export const getValidator = (fn, errorText, compareValue = null) => ({\n fn,\n errorText,\n compareValue,\n})\n","export const validateFileSize = (fileList, maxSize) => {\n let isValid = true\n for (let i = 0; i < fileList.length; i++) {\n if (fileList[i].size > maxSize) {\n isValid = false\n }\n }\n\n return isValid\n}\n\nexport const fileListObjectIsNotEmpty = (fileListObj) =>\n !!fileListObj?.length > 0\n\n/* eslint-disable no-control-regex */\nexport const isEmailString = (val) => {\n const regex =\n /^(?:[a-z0-9!#$%&'*+/=?^_`{|}~-]+(?:\\.[a-z0-9!#$%&'*+/=?^_`{|}~-]+)*|\"(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21\\x23-\\x5b\\x5d-\\x7f]|\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])*\")@(?:(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?|\\[(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?|[a-z0-9-]*[a-z0-9]:(?:[\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x21-\\x5a\\x53-\\x7f]|\\\\[\\x01-\\x09\\x0b\\x0c\\x0e-\\x7f])+)\\])$/i\n const trimmedVal = val && val.trim()\n return !!(trimmedVal && trimmedVal.match(regex))\n}\n/* eslint-enable no-control-regex */\n\nexport const isNotEmptyString = (val) => !!val\n","import { useCallback, useState } from 'preact/hooks'\nimport { useFormContext, useFormControl } from 'domains/forms/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport { useGeneratedId } from 'ui/hooks/seamly-hooks'\nimport Error from './error'\n\nexport default function FileInput({\n id,\n name,\n labelText,\n contentHint,\n outputText,\n accept,\n}) {\n const { isSubmitted } = useFormContext()\n const [focusWithin, setFocusWithin] = useState(false)\n const [{ onInput, onBlur }, { error }] = useFormControl(name)\n const errorId = useGeneratedId()\n const contentHintId = useGeneratedId()\n const outputId = useGeneratedId()\n const hasError = isSubmitted && error\n\n const describedByIds = [outputId]\n if (contentHint) {\n describedByIds.push(contentHintId)\n }\n if (hasError) {\n describedByIds.push(errorId)\n }\n\n const handleFocus = useCallback(() => {\n setFocusWithin(true)\n }, [setFocusWithin])\n\n const handleBlur = useCallback(() => {\n setFocusWithin(false)\n onBlur()\n }, [setFocusWithin, onBlur])\n\n const handleChange = useCallback(\n (e) => {\n const customEvent = {\n target: {\n value: e.target.files,\n },\n }\n\n onInput(customEvent)\n },\n [onInput],\n )\n\n return (\n <div className={className('upload__container')}>\n {contentHint && (\n <span className={className('upload__content-hint')} id={contentHintId}>\n {contentHint}\n </span>\n )}\n <Error id={errorId} error={hasError && error} />\n <div\n className={className([\n 'file-upload',\n ...(focusWithin ? ['focus-within'] : []),\n ])}\n >\n <label htmlFor={id} className={className('upload__label')}>\n <Icon name=\"upload\" size=\"32\" alt=\"\" />\n <div>\n <span className={className(['upload__label--text'])}>\n {labelText}\n </span>\n <input\n id={id}\n className={className('upload__input')}\n type=\"file\"\n name={name}\n onChange={handleChange}\n aria-invalid={hasError ? 'true' : 'false'}\n aria-describedby={describedByIds.join(' ')}\n accept={accept || null}\n onFocus={handleFocus}\n onBlur={handleBlur}\n />\n <span\n className={className('upload__output')}\n aria-hidden=\"true\"\n id={outputId}\n >\n {outputText}\n </span>\n </div>\n </label>\n </div>\n </div>\n )\n}\n","import { useFormControl } from 'domains/forms/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport FileInput from 'ui/components/form-controls/file-input'\nimport Form from 'ui/components/form-controls/form'\n\nexport default function FileInputForm({\n skiplinkId,\n controlName,\n accept,\n contentHint,\n isUploading,\n isComplete,\n onClickCancel,\n}) {\n const { t } = useI18n()\n const [{ value: fileList }] = useFormControl(controlName)\n const hasFile = fileList && fileList.length > 0\n const selectedFileName = hasFile ? fileList[0].name : ''\n\n return (\n <Form className={className('upload-form')}>\n <FileInput\n name={controlName}\n id={skiplinkId}\n accept={accept}\n labelText={t('fileUpload.labelText')}\n outputText={t('fileUpload.selectedText', {\n hasFile,\n filename: selectedFileName,\n })}\n contentHint={contentHint}\n />\n <div className={className('upload__button-container')}>\n <button\n id={isUploading || !isComplete ? skiplinkId : undefined}\n type=\"button\"\n onClick={onClickCancel}\n className={className('button', 'button--secondary', 'upload__cancel')}\n >\n {t('fileUpload.cancelButtonText')}\n </button>\n <button\n className={className('button', 'button--primary')}\n type=\"submit\"\n >\n {t('fileUpload.uploadButtonText')}\n </button>\n </div>\n </Form>\n )\n}\n","import { useCallback, useEffect, useMemo, useRef } from 'preact/hooks'\nimport FormProvider from 'domains/forms/provider'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport UploadProgress from 'ui/components/widgets/upload-progress'\nimport { useSeamlyEntry } from 'ui/hooks/seamly-entry-hooks'\nimport {\n useFileUploadMeta,\n useFileUploads,\n useGeneratedId,\n useLiveRegion,\n useSkiplink,\n useSkiplinkTargetFocusing,\n} from 'ui/hooks/seamly-hooks'\nimport useSingleFileUpload from 'ui/hooks/use-single-file-upload'\nimport { getValidator } from 'ui/utils/form-utils'\nimport { formatBytes } from 'ui/utils/general-utils'\nimport {\n fileListObjectIsNotEmpty,\n validateFileSize,\n} from 'ui/utils/validations'\nimport FileInputForm from './file-upload-form'\n\nconst formName = 'fileListForm'\nconst fileInputName = 'fileList'\n\nconst Upload = () => {\n const { t } = useI18n()\n const { sendPolite, sendAssertive } = useLiveRegion()\n const skiplinkTargetId = useSkiplink()\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n // This hook should be refactored at some point\n const { serviceAllowsUploads, allowedMimeTypes, maxSize } =\n useFileUploadMeta()\n const cancelButtonRef = useRef(null)\n const canUpload = useRef(serviceAllowsUploads)\n\n const { cancelEntrySelection } = useSeamlyEntry()\n const { uploadFile, clearUploads, isUploading, isComplete } = useFileUploads()\n\n const hasError = false\n\n const { hasFile, selectedFileName, uploadHandle, hasServerError, progress } =\n useSingleFileUpload(formName, fileInputName)\n const notificationId = useGeneratedId()\n const prevIsComplete = useRef(true)\n\n const contentHintText = t('fileUpload.contentHint', {\n size: formatBytes(maxSize),\n })\n const prevContentHintText = useRef('')\n const containerRef = useRef(null)\n\n useEffect(() => {\n if (\n prevContentHintText.current &&\n containerRef.current?.contains(document.activeElement) &&\n document.activeElement.tagName === 'INPUT'\n ) {\n sendAssertive(contentHintText)\n }\n prevContentHintText.current = contentHintText\n }, [contentHintText, sendAssertive])\n\n // a11y\n useEffect(() => {\n if (progress > 0) {\n switch (progress) {\n case 1:\n sendPolite(t('fileUpload.srStartedText'))\n break\n default:\n sendPolite(`${progress}%`)\n }\n }\n }, [progress, sendPolite, t])\n\n // reset form when uploads are complete\n useEffect(() => {\n if (!prevIsComplete.current && !isUploading && isComplete) {\n clearUploads()\n cancelEntrySelection()\n focusSkiplinkTarget()\n // This timeout is set as testing in VoiceOver revealed that 300 ms is needed for\n // the live region to resolve in this case.\n setTimeout(() => {\n sendPolite(t('fileUpload.srCompleteText'))\n }, 300)\n }\n prevIsComplete.current = isComplete\n }, [\n isUploading,\n isComplete,\n clearUploads,\n cancelEntrySelection,\n focusSkiplinkTarget,\n sendPolite,\n t,\n ])\n\n const handleSubmit = useCallback(\n ({ fileList }) => {\n uploadFile(fileList[0])\n\n if (!hasError) {\n focusSkiplinkTarget()\n }\n },\n [uploadFile, hasError, focusSkiplinkTarget],\n )\n\n const handleOnClickCancel = useCallback(() => {\n if (uploadHandle) {\n uploadHandle.abort()\n }\n clearUploads()\n cancelEntrySelection()\n focusSkiplinkTarget()\n }, [uploadHandle, clearUploads, cancelEntrySelection, focusSkiplinkTarget])\n\n const validationSchema = useMemo(\n () => ({\n [fileInputName]: [\n // For now this is fine, but this shouldn't be a validation on the field itself\n getValidator(\n () => serviceAllowsUploads,\n t('fileUpload.errors.unavailable'),\n ),\n getValidator(fileListObjectIsNotEmpty, t('fileUpload.errors.noFile')),\n getValidator(\n validateFileSize,\n t('fileUpload.errors.tooLarge'),\n maxSize,\n ),\n ],\n }),\n [maxSize, serviceAllowsUploads, t],\n )\n\n return (\n <div\n className={className([\n 'upload',\n ...(hasError || hasServerError ? ['upload--error'] : []),\n ])}\n ref={containerRef}\n >\n <FormProvider\n formId={formName}\n persistData={true}\n onSubmit={handleSubmit}\n validationSchema={validationSchema}\n >\n {(isUploading || !isComplete) && (\n <>\n <UploadProgress />\n <div className={className('upload__button-container')}>\n <button\n id={isUploading || !isComplete ? skiplinkTargetId : undefined}\n type=\"button\"\n onClick={handleOnClickCancel}\n ref={cancelButtonRef}\n className={className(\n 'button',\n 'button--secondary',\n 'upload__cancel',\n )}\n >\n {t('fileUpload.cancelButtonText')}\n </button>\n </div>\n </>\n )}\n {!isUploading && isComplete && (\n <FileInputForm\n controlName={fileInputName}\n skiplinkId={skiplinkTargetId}\n accept={allowedMimeTypes.join(', ')}\n contentHint={contentHintText}\n isComplete={isComplete}\n isUploading={isUploading}\n outputText={t('fileUpload.selectedText', {\n hasFile,\n filename: selectedFileName,\n })}\n onClickCancel={handleOnClickCancel}\n />\n )}\n\n {!canUpload.current && (\n <>\n <span className={className('notification')} id={notificationId}>\n {t('fileUpload.unavailableText')}\n </span>\n <div className={className('upload__button-container')}>\n <button\n id={isUploading || !isComplete ? skiplinkTargetId : undefined}\n type=\"button\"\n onClick={handleOnClickCancel}\n className={className(\n 'button',\n 'button--secondary',\n 'upload__cancel',\n )}\n >\n {t('fileUpload.cancelButtonText')}\n </button>\n </div>\n </>\n )}\n </FormProvider>\n </div>\n )\n}\n\nexport default Upload\n","import { useSelector } from 'react-redux'\nimport { getControlValueByName } from 'domains/forms/selectors'\nimport { useFileUploads } from './seamly-hooks'\n\nconst useSingleFileUpload = (formId, name) => {\n const fileList = useSelector((store) =>\n getControlValueByName(store, { formId, name }),\n )\n // This hook acts as a helper as the data model is built to handle multiple\n // file uploads but currently Seamly only supports single file uploads.\n // This hook HAS to be used inside the FormBoundary of the file upload.\n const { currentUploads } = useFileUploads()\n\n const hasFile = fileList && fileList.length > 0\n\n let uploadHandle = null\n let hasServerError = false\n let progress = 0\n if (currentUploads && currentUploads.length > 0) {\n const currentUpload = currentUploads[0]\n uploadHandle = currentUpload.uploadHandle\n hasServerError = !!currentUpload.error\n progress = currentUpload.progress\n }\n\n return {\n hasFile,\n selectedFileName: hasFile ? fileList[0].name : '',\n uploadHandle,\n hasServerError,\n progress,\n }\n}\n\nexport default useSingleFileUpload\n","import { useEffect, useRef } from 'preact/hooks'\n\nexport default function useTimeout(callback: Function, delay?: number) {\n const timeoutRef = useRef<number | null>(null)\n const savedCallback = useRef(callback)\n\n useEffect(() => {\n savedCallback.current = callback\n }, [callback])\n\n useEffect(() => {\n if (typeof delay !== 'number') return () => undefined\n\n timeoutRef.current = setTimeout(savedCallback.current, delay)\n\n return () => clearTimeout(timeoutRef.current)\n }, [delay])\n\n return timeoutRef\n}\n","import { VNode, cloneElement, toChildArray } from 'preact'\nimport { FC } from 'preact/compat'\nimport { useEffect, useMemo, useRef, useState } from 'preact/hooks'\nimport { defaultTransitionTimeMs } from 'config'\nimport { className } from 'lib/css'\nimport { useStableCallback } from 'ui/hooks/seamly-hooks'\nimport useTimeout from 'ui/hooks/use-timeout'\n\ntype VDOMChild = string | number | VNode\ntype ValueOf<T> = T[keyof T]\nfunction childIsVNode(\n child: VDOMChild,\n): child is VNode<{ className?: string }> {\n return typeof child === 'object'\n}\n\nconst transitionClasses = {\n visible: className('transition--visible'),\n in: className('transition--in'),\n visuallyHidden: className('visually-hidden'),\n}\n\nconst transitionClassesArray = Object.values(transitionClasses)\n\nexport const transitionStartStates = {\n notRendered: 'notRendered',\n rendered: 'rendered',\n visuallyHidden: 'visuallyHidden',\n} as const\n\ntype InOutTransitionProps = {\n isActive: boolean\n timeout?: number\n transitionStartState?: keyof typeof transitionStartStates\n onInTransitionComplete?: Function\n onOutTransitionComplete?: Function\n exitAfter?: number\n enterDelay?: number\n}\n\nconst InOutTransition: FC<InOutTransitionProps> = ({\n children,\n isActive,\n timeout = defaultTransitionTimeMs,\n transitionStartState = transitionStartStates.notRendered,\n onInTransitionComplete = () => {},\n onOutTransitionComplete = () => {},\n exitAfter,\n enterDelay = 0,\n}) => {\n const prevIsActive = useRef(false)\n\n const isVisuallyHidden =\n transitionStartState === transitionStartStates.visuallyHidden\n\n const [activeTransitionClasses, setActiveTransitionClasses] = useState<\n ValueOf<typeof transitionClasses>[]\n >(() => (isVisuallyHidden ? [transitionClasses.visuallyHidden] : []))\n\n const [inState, setInState] = useState(() => enterDelay === 0)\n\n const transitionOutAfter = useMemo(\n () => (exitAfter ? exitAfter + enterDelay : exitAfter),\n [enterDelay, exitAfter],\n )\n\n useTimeout(() => setInState(false), isActive ? transitionOutAfter : undefined)\n useTimeout(() => setInState(true), isActive ? enterDelay : undefined)\n\n const transitionIn = useMemo(() => inState && isActive, [isActive, inState])\n\n const onInTransitionCompleteHandler = useStableCallback(\n onInTransitionComplete,\n )\n\n const onOutTransitionCompleteHandler = useStableCallback(\n onOutTransitionComplete,\n )\n\n const renderChildren =\n transitionStartState !== 'notRendered' || activeTransitionClasses.length > 0\n\n useEffect(() => {\n let activeTimeout = null\n let activeRaf = null\n\n if (prevIsActive.current && !transitionIn) {\n setActiveTransitionClasses([transitionClasses.visible])\n activeTimeout = setTimeout(() => {\n setActiveTransitionClasses([\n ...(isVisuallyHidden ? [transitionClasses.visuallyHidden] : []),\n ])\n\n if (onOutTransitionCompleteHandler) {\n activeRaf = requestAnimationFrame(() => {\n onOutTransitionCompleteHandler()\n })\n }\n }, timeout)\n }\n\n if (!prevIsActive.current && transitionIn) {\n setActiveTransitionClasses([transitionClasses.visible])\n // Doubling up on rAF as a single rAF can be too slow for the\n // animation transition to be resolved.\n activeRaf = requestAnimationFrame(() => {\n activeRaf = requestAnimationFrame(() => {\n setActiveTransitionClasses([\n transitionClasses.visible,\n transitionClasses.in,\n ])\n if (onInTransitionCompleteHandler) {\n activeTimeout = setTimeout(() => {\n onInTransitionCompleteHandler()\n }, timeout)\n }\n })\n })\n }\n\n prevIsActive.current = transitionIn\n\n return () => {\n clearTimeout(activeTimeout)\n cancelAnimationFrame(activeRaf)\n }\n }, [\n isVisuallyHidden,\n onInTransitionCompleteHandler,\n onOutTransitionCompleteHandler,\n timeout,\n transitionIn,\n ])\n\n return (\n <>\n {renderChildren &&\n toChildArray(children)\n .filter(childIsVNode)\n .map((child) => {\n const { className: childClassName = '' } = child.props\n const cleanClasses = childClassName\n .split(' ')\n .filter((cl) => !transitionClassesArray.includes(cl))\n\n return cloneElement(child, {\n className: [...cleanClasses, ...activeTransitionClasses].join(\n ' ',\n ),\n })\n })}\n </>\n )\n}\n\nexport default InOutTransition\n","import { useEffect, useRef, useState } from 'preact/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport InOutTransition, {\n transitionStartStates,\n} from 'ui/components/widgets/in-out-transition'\nimport { useSeamlyEntry } from 'ui/hooks/seamly-entry-hooks'\nimport {\n useFileUploadMeta,\n useLiveRegion,\n useSeamlyCurrentAgent,\n useSkiplinkTargetFocusing,\n} from 'ui/hooks/seamly-hooks'\nimport { runIfElementContainsOrHasFocus } from 'ui/utils/general-utils'\nimport { entryTypes } from 'ui/utils/seamly-utils'\n\nconst UploadToggle = () => {\n const { t } = useI18n()\n const { showFileUpload, serviceAllowsUploads } = useFileUploadMeta()\n const [showUploadButton, setShowUploadButton] = useState(serviceAllowsUploads)\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n const prevServiceAllowsUploads = useRef(null)\n const { setUserEntryType, activeEntry } = useSeamlyEntry()\n const uploadButton = useRef(null)\n const { sendPolite } = useLiveRegion()\n const hasAgent = !!useSeamlyCurrentAgent()\n\n useEffect(() => {\n const focusFn = () => {\n if (!serviceAllowsUploads) {\n focusSkiplinkTarget()\n }\n }\n runIfElementContainsOrHasFocus(uploadButton.current, focusFn)\n setShowUploadButton(serviceAllowsUploads)\n }, [serviceAllowsUploads, focusSkiplinkTarget])\n\n useEffect(() => {\n if (prevServiceAllowsUploads.current && !serviceAllowsUploads) {\n sendPolite(t('fileUpload.srUnavailableText'))\n }\n\n if (prevServiceAllowsUploads.current === false && serviceAllowsUploads) {\n sendPolite(t('fileUpload.srAvailableText'))\n }\n\n // We wait for the first agent to join before activating this check.\n // This is to avoid messages being sent to the screen reader on app\n // startup or app refresh.\n if (hasAgent) {\n prevServiceAllowsUploads.current = serviceAllowsUploads\n }\n }, [serviceAllowsUploads, hasAgent, sendPolite, t])\n\n const onClickHandler = () => {\n setUserEntryType(entryTypes.upload)\n focusSkiplinkTarget()\n }\n\n return (\n !showFileUpload &&\n activeEntry !== entryTypes.upload && (\n <InOutTransition\n isActive={showUploadButton}\n transitionStartState={transitionStartStates.rendered}\n >\n <div className={className('upload-toggle-wrapper')}>\n <InOutTransition\n isActive={showUploadButton}\n transitionStartState={transitionStartStates.visuallyHidden}\n >\n <button\n className={className([\n 'button',\n 'button--secondary',\n 'upload-toggle',\n ])}\n ref={uploadButton}\n aria-disabled={!showUploadButton ? 'true' : null}\n type=\"button\"\n onClick={showUploadButton ? onClickHandler : null}\n >\n <Icon\n name=\"file\"\n size=\"32\"\n alt={t('fileUpload.toggleButtonText')}\n />\n </button>\n </InOutTransition>\n </div>\n </InOutTransition>\n )\n )\n}\n\nexport default UploadToggle\n","import { useCallback, useEffect, useRef, useState } from 'preact/hooks'\nimport { useConfig } from 'domains/config/hooks'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport IdleDetachWarning from 'ui/components/warnings/idle-detach-warning'\nimport ResumeConversationPrompt from 'ui/components/warnings/resume-conversation-prompt'\nimport { useSeamlyEntry } from 'ui/hooks/seamly-entry-hooks'\nimport {\n useFileUploadMeta,\n useSeamlyIdleDetachCountdown,\n useSeamlyResumeConversationPrompt,\n useSkiplinkTargetFocusing,\n} from 'ui/hooks/seamly-hooks'\nimport { runIfElementContainsOrHasFocus } from 'ui/utils/general-utils'\nimport { entryTypes } from 'ui/utils/seamly-utils'\nimport TextEntry from './text-entry'\nimport Upload from './upload'\nimport UploadToggle from './upload-toggle'\n\nconst EntryContainer = () => {\n const { isOpen } = useVisibility()\n const entryContainer = useRef(null)\n const { hasCountdown } = useSeamlyIdleDetachCountdown()\n const [showCountdown, setShowCountDown] = useState(hasCountdown)\n const { hasPrompt: hasResumeConversationPrompt } =\n useSeamlyResumeConversationPrompt()\n const [showResumeConversationPrompt, setShowResumeConversationPrompt] =\n useState(hasResumeConversationPrompt)\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n const containedFocus = useRef(false)\n const { activeEntry } = useSeamlyEntry()\n const [entryComponents, setEntryComponents] = useState({\n text: TextEntry,\n upload: Upload,\n })\n const [renderEntry, setRenderEntry] = useState(() => activeEntry)\n const config = useConfig()\n const { accountAllowsUploads } = useFileUploadMeta()\n\n const focusFn = useCallback(() => {\n runIfElementContainsOrHasFocus(entryContainer.current, focusSkiplinkTarget)\n }, [focusSkiplinkTarget])\n\n useEffect(() => {\n const { customComponents } = config\n const { entry } = customComponents || {}\n\n if (entry) {\n setEntryComponents((c) => ({\n ...c,\n ...entry,\n }))\n }\n }, [config])\n\n useEffect(() => {\n // Focus the current target of the skip link if focus was inside the\n // container before this effect change.\n focusFn()\n setShowCountDown(hasCountdown)\n setShowResumeConversationPrompt(hasResumeConversationPrompt)\n }, [hasCountdown, hasResumeConversationPrompt, focusFn])\n\n useEffect(() => {\n setRenderEntry(activeEntry)\n // This focus action is required for auto entry changes. User driven\n // changes should be handled in the originating components.\n focusFn()\n }, [activeEntry, focusFn, entryContainer])\n\n // Check if the active element is inside this container and save it.\n containedFocus.current = !!(\n entryContainer.current &&\n entryContainer.current.contains(document.activeElement)\n )\n\n const EntryComponent = entryComponents[renderEntry]\n\n return (\n <div className={className('chat__entry')} ref={entryContainer}>\n {showCountdown && <IdleDetachWarning />}\n {showResumeConversationPrompt && <ResumeConversationPrompt />}\n <div\n className={className([\n 'entry__body',\n ...(hasCountdown || hasResumeConversationPrompt\n ? ['entry__body--hidden']\n : []),\n ])}\n >\n {renderEntry !== entryTypes.upload &&\n accountAllowsUploads &&\n isOpen && <UploadToggle />}\n <EntryComponent />\n </div>\n </div>\n )\n}\n\nexport default EntryContainer\n","import { useSelector } from 'react-redux'\nimport { useStartChatIcon } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { selectHasError } from 'domains/interrupt/selectors'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport {\n useSeamlyCurrentAgent,\n useSeamlyHeaderData,\n useSeamlyUnreadCount,\n} from 'ui/hooks/seamly-hooks'\nimport Icon from './icon'\n\nconst AgentInfo = () => {\n const { t } = useI18n()\n const { title, subTitle } = useSeamlyHeaderData()\n const unreadMessageCount = useSeamlyUnreadCount()\n const { isOpen } = useVisibility()\n const currentAgent = useSeamlyCurrentAgent()\n const hasError = useSelector(selectHasError)\n const startChatIcon = useStartChatIcon()\n const src = currentAgent?.avatar ?? startChatIcon\n const displaySubtitle = hasError ? '' : subTitle\n\n const classNames = ['message-count']\n\n if (isOpen) {\n classNames.push('message-count__hide')\n }\n\n if (unreadMessageCount === 0) {\n classNames.push('message-count__empty')\n }\n\n return (\n (displaySubtitle || !isOpen) && (\n <div className={className('agent-info')}>\n <div className={className('agent-info__graphic')}>\n {src ? (\n <img\n className={className(currentAgent?.avatar ? 'avatar' : 'icon')}\n src={src}\n alt=\"\"\n />\n ) : (\n <Icon name=\"avatar\" size=\"32\" alt=\"\" />\n )}\n <span className={className(classNames)} aria-hidden=\"true\">\n {unreadMessageCount}\n </span>\n </div>\n\n <div className={className('agent-info__body')}>\n <p className={className('agent-info__heading')}>\n {title ?? t('header.title')}\n </p>\n <p className={className('agent-info__text')}>{displaySubtitle}</p>\n </div>\n </div>\n )\n )\n}\n\nexport default AgentInfo\n","import { useCallback, useEffect, useMemo, useRef } from 'preact/hooks'\nimport { useSelector } from 'react-redux'\nimport { useUserHasResponded } from 'domains/app/hooks'\nimport { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { selectHasError } from 'domains/interrupt/selectors'\nimport { useTranslatedEventData } from 'domains/translations/hooks'\nimport { visibilityStates } from 'domains/visibility/constants'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport SuggestionsList from 'ui/components/suggestions/suggestions-list'\nimport InOutTransition, {\n transitionStartStates,\n} from 'ui/components/widgets/in-out-transition'\nimport { useSkiplinkTargetFocusing } from 'ui/hooks/focus-helper-hooks'\nimport { useLiveRegion } from 'ui/hooks/live-region-hooks'\nimport {\n useSeamlyLayoutMode,\n useSeamlyServiceData,\n} from 'ui/hooks/seamly-state-hooks'\nimport useSeamlyCommands from 'ui/hooks/use-seamly-commands'\nimport useSeamlyIdleDetachCountdown from 'ui/hooks/use-seamly-idle-detach-countdown'\nimport useSeamlyResumeConversationPrompt from 'ui/hooks/use-seamly-resume-conversation-prompt'\nimport { useGeneratedId } from 'ui/hooks/utility-hooks'\nimport { runIfElementContainsOrHasFocus } from 'ui/utils/general-utils'\nimport { actionTypes } from 'ui/utils/seamly-utils'\n\nconst Suggestions = ({ isAside = false }) => {\n // generic hooks\n const { isInline } = useSeamlyLayoutMode()\n const { t } = useI18n()\n const { sendAction, addMessageBubble } = useSeamlyCommands()\n const { isOpen, setVisibility } = useVisibility()\n const { showSuggestions } = useConfig()\n // a11y hooks\n const sectionId = useGeneratedId()\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n const containerRef = useRef(null)\n const { sendPolite } = useLiveRegion()\n // interrupt & countdown hooks\n const hasError = useSelector(selectHasError)\n const { hasCountdown, endCountdown } = useSeamlyIdleDetachCountdown()\n const { hasPrompt, continueChat } = useSeamlyResumeConversationPrompt()\n // data hooks\n const userHasResponded = useUserHasResponded()\n const payload = useSeamlyServiceData('suggestion')\n const { body: eventBody } = useTranslatedEventData({ payload })\n const suggestions = useMemo(\n () => (payload && !hasError ? eventBody : []),\n [payload, hasError, eventBody],\n )\n\n const prevSuggestions = useRef(null)\n const prevHasSuggestions = useRef(false)\n\n const previousRenderedSuggestions = useRef([])\n const hasSuggestions = !!suggestions.length\n const hideSuggestions = isInline\n ? (userHasResponded || isOpen) && !isAside\n : userHasResponded\n const prevHideSuggestions = useRef(hideSuggestions)\n const showSuggestionsContainer =\n hasSuggestions && !hideSuggestions && showSuggestions\n const renderedSuggestions = hasSuggestions\n ? suggestions\n : previousRenderedSuggestions.current\n previousRenderedSuggestions.current = renderedSuggestions\n\n const suggestionsClassNames = useMemo(() => {\n const classNames = ['suggestions']\n\n if (isAside) {\n classNames.push('suggestions--aside')\n }\n\n return className(classNames)\n }, [isAside])\n\n // click handler\n const handleClick = useCallback(\n ({ id, question }) => {\n if (hasCountdown) {\n endCountdown(true)\n }\n\n if (hasPrompt) {\n continueChat()\n }\n\n // @todo Refactor to 'suggestionclick'\n sendAction({\n type: actionTypes.custom,\n originMessage: payload.id,\n body: {\n type: 'faqclick',\n body: {\n faqId: id,\n faqQuestion: question,\n },\n },\n })\n\n addMessageBubble(question)\n if (!isOpen) {\n setVisibility(visibilityStates.open)\n }\n focusSkiplinkTarget()\n },\n [\n addMessageBubble,\n continueChat,\n endCountdown,\n focusSkiplinkTarget,\n hasCountdown,\n hasPrompt,\n payload,\n sendAction,\n setVisibility,\n isOpen,\n ],\n )\n\n useEffect(() => {\n if (prevSuggestions.current !== suggestions && !hideSuggestions) {\n if (hasSuggestions) {\n const politeText = prevHasSuggestions.current\n ? t('suggestions.srUpdatedText')\n : t('suggestions.srAvailableText')\n setTimeout(() => {\n sendPolite(politeText)\n }, 30)\n } else if (prevHasSuggestions.current) {\n sendPolite(t('suggestions.srUnavailableText'))\n }\n\n prevSuggestions.current = suggestions\n }\n\n if (!prevHideSuggestions.current && hideSuggestions) {\n runIfElementContainsOrHasFocus(containerRef.current, focusSkiplinkTarget)\n sendPolite(t('suggestions.srUnavailableText'))\n } else if (!hasSuggestions && prevHasSuggestions.current) {\n runIfElementContainsOrHasFocus(containerRef.current, focusSkiplinkTarget)\n }\n prevHasSuggestions.current = hasSuggestions\n prevHideSuggestions.current = hideSuggestions\n }, [\n suggestions,\n hasSuggestions,\n hideSuggestions,\n focusSkiplinkTarget,\n sendPolite,\n t,\n ])\n\n const headingText = t('suggestions.headingText')\n const footerText = t('suggestions.footerText')\n const ContainerElement = headingText ? 'section' : 'div'\n\n return (\n <InOutTransition\n isActive={showSuggestionsContainer}\n transitionStartState={transitionStartStates.notRendered}\n >\n <ContainerElement\n className={suggestionsClassNames}\n aria-labelledby={headingText ? sectionId : null}\n ref={containerRef}\n >\n {headingText && (\n <p id={sectionId} className={className('suggestions__heading')}>\n {headingText}\n </p>\n )}\n {!!renderedSuggestions.length && (\n <SuggestionsList\n suggestions={renderedSuggestions}\n onClickSuggestion={handleClick}\n />\n )}\n {footerText && !isOpen && (\n <p className={className('suggestions__footer')}>{footerText}</p>\n )}\n </ContainerElement>\n </InOutTransition>\n )\n}\n\nexport default Suggestions\n","import { forwardRef } from 'preact/compat'\nimport { useUserHasResponded } from 'domains/app/hooks'\nimport { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { visibilityStates } from 'domains/visibility/constants'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport Suggestions from 'ui/components/suggestions'\nimport { useSeamlyAppContainerClassNames } from 'ui/hooks/component-helper-hooks'\nimport { useSeamlyLayoutMode } from 'ui/hooks/seamly-state-hooks'\n\nconst Chat = forwardRef(\n ({ children, className: givenClassName = '' }, forwardedRef) => {\n const { isOpen, isVisible, setVisibility } = useVisibility()\n const { namespace, layoutMode } = useConfig()\n const { isInline } = useSeamlyLayoutMode()\n const appContainerClassNames = useSeamlyAppContainerClassNames()\n const userHasResponded = useUserHasResponded()\n const { t } = useI18n()\n\n const defaultClassNames = [\n 'chat',\n `chat--layout-${layoutMode}`,\n `namespace--${namespace}`,\n ]\n\n const classNames = [\n ...defaultClassNames,\n ...appContainerClassNames,\n givenClassName,\n ]\n\n if (!isOpen && layoutMode !== 'app') {\n classNames.push('chat--collapsed')\n }\n\n if (userHasResponded) {\n classNames.push('chat--user-responded')\n }\n\n const onKeyDownHandler = (e) => {\n if ((e.code && e.code === 'Escape') || e.keyCode === 27)\n if (!isInline && isOpen) {\n setVisibility(visibilityStates.minimized)\n }\n }\n\n return (\n isVisible && (\n <section\n className={className(classNames)}\n onKeyDown={onKeyDownHandler}\n tabIndex=\"-1\"\n ref={forwardedRef}\n aria-label={t('chat.srLabel')}\n >\n <div className={className('chat-wrapper')}>{children}</div>\n {layoutMode === 'inline' && isOpen && <Suggestions isAside={true} />}\n </section>\n )\n )\n },\n)\n\nexport default Chat\n","import { FC } from 'preact/compat'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport { useGeneratedId } from 'ui/hooks/utility-hooks'\n\ntype ChatStatusProps = {\n handleClose: () => void\n title: string\n closeButtonText?: string\n srCloseButtonText?: string\n id: string\n}\n\nconst ChatStatus: FC<ChatStatusProps> = ({\n children,\n handleClose,\n title,\n closeButtonText,\n srCloseButtonText,\n id,\n}) => {\n const headingId = useGeneratedId()\n\n return (\n <section\n tabIndex={-1}\n id={id}\n aria-labelledby={title ? headingId : undefined}\n className={className('chat-status', !title && 'chat-status--condensed')}\n >\n <div className={className('chat-status__body')}>\n {title ? (\n <h2 className={className('chat-status__title')} id={headingId}>\n {title}\n </h2>\n ) : null}\n {children}\n </div>\n {typeof handleClose === 'function' && (\n <button\n type=\"button\"\n onClick={handleClose}\n className={className(\n 'button',\n 'button--tertiary',\n 'chat-status__close',\n )}\n >\n {closeButtonText || <Icon name=\"close\" size=\"16\" alt=\"\" />}\n {srCloseButtonText && (\n <span className={className('visually-hidden')}>\n {srCloseButtonText}\n </span>\n )}\n </button>\n )}\n </section>\n )\n}\n\nexport default ChatStatus\n","import { className } from 'lib/css'\nimport Icon, { IconProps } from 'ui/components/layout/icon'\n\ntype ChatStatusActionProps = {\n handleClick: () => void\n icon: IconProps['name']\n title: string\n srButtonText?: string\n}\n\nconst ChatStatusAction = ({\n handleClick,\n icon,\n title,\n srButtonText,\n}: ChatStatusActionProps) => (\n <button\n type=\"button\"\n onClick={handleClick}\n className={className('button', 'button--primary', 'chat-status__button')}\n >\n <Icon name={icon} size=\"16\" alt=\"\" />\n {title}\n {srButtonText && (\n <span className={className('visually-hidden')}>{srButtonText}</span>\n )}\n </button>\n)\n\nexport default ChatStatusAction\n","import {\n useTranslationProposal,\n useTranslationsContainer,\n} from 'domains/translations/hooks'\nimport ChatStatus from 'ui/components/chat-status'\nimport ChatStatusAction from 'ui/components/chat-status/chat-status-action'\n\nexport default function TranslationProposal() {\n const {\n showProposal,\n translationProposal,\n dismissTranslationProposal,\n activateTranslationProposal,\n } = useTranslationProposal()\n\n const { id } = useTranslationsContainer()\n\n if (!showProposal) {\n return null\n }\n\n return (\n <ChatStatus\n handleClose={dismissTranslationProposal}\n srCloseButtonText={translationProposal.srDismissButtonText}\n id={id}\n title={translationProposal.titleLabel}\n >\n <ChatStatusAction\n handleClick={activateTranslationProposal}\n icon=\"newTranslation\"\n title={translationProposal.buttonLabel}\n />\n </ChatStatus>\n )\n}\n","import { useSelector } from 'react-redux'\nimport { selectHasError } from 'domains/interrupt/selectors'\nimport { useTranslations } from 'domains/translations/hooks'\nimport TranslationProposal from 'ui/components/translation-proposal'\n\nexport default function TranslationStatus() {\n const hasError = useSelector(selectHasError)\n\n const { isActive } = useTranslations()\n if (hasError) {\n return null\n }\n\n return !isActive ? <TranslationProposal /> : null\n}\n","import { FC } from 'preact/compat'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\n\ntype TranslationOptionProps = {\n label: string\n checked: boolean\n description?: string\n onChange: () => void\n id: string\n itemClassName?: string\n}\n\nconst TranslationOption: FC<TranslationOptionProps> = ({\n label,\n checked,\n description,\n onChange,\n id,\n itemClassName,\n}) => {\n const onKeyDown = (e: KeyboardEvent) => {\n if (e.code === 'Space' || e.code === 'Enter') {\n e.preventDefault()\n onChange()\n }\n }\n\n return (\n <li\n className={className([itemClassName, 'translation-options__item'])}\n aria-selected={checked}\n role=\"option\"\n tabIndex={0}\n onClick={onChange}\n onKeyDown={onKeyDown}\n id={id}\n >\n <Icon name=\"check\" size=\"16\" alt=\"\" />\n {label} {description && <span>({description})</span>}\n </li>\n )\n}\n\nexport default TranslationOption\n","import { FC, useMemo } from 'preact/compat'\nimport { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport TranslationOption from 'domains/translations/components/options-dialog/translation-option'\nimport { useTranslations } from 'domains/translations/hooks'\nimport { className } from 'lib/css'\nimport { useSkiplinkTargetFocusing } from 'ui/hooks/focus-helper-hooks'\nimport type { Language } from 'domains/translations/translations.types'\n\ntype TranslationOptionsProps = {\n onChange: () => void\n describedById?: string\n}\n\nconst isChecked = (language, currentLocale, isOriginal): boolean =>\n currentLocale === language.locale || (!currentLocale && isOriginal)\n\nconst TranslationOptions: FC<TranslationOptionsProps> = ({\n onChange,\n describedById,\n}) => {\n const {\n context: { userLocale, contentLocale },\n } = useConfig()\n\n const { t } = useI18n()\n const { languages, currentLocale, enableTranslations, disableTranslations } =\n useTranslations()\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n\n const handleChange = (locale: Language['locale']) => () => {\n if (locale === currentLocale || contentLocale === locale) {\n disableTranslations()\n } else {\n enableTranslations(locale)\n }\n\n onChange()\n focusSkiplinkTarget()\n }\n\n const { primaryLanguages, remainingLanguages } = useMemo(\n () =>\n languages.reduce(\n (acc, language) => {\n const isOriginal = language.locale === contentLocale\n const checked = isChecked(language, currentLocale, isOriginal)\n\n if (language.locale !== contentLocale) {\n acc.remainingLanguages.push({ ...language, checked, isOriginal })\n }\n\n const selectedIdx = acc.remainingLanguages.findIndex(\n (l) => l.locale === currentLocale,\n )\n\n if (isOriginal || (checked && selectedIdx > 4)) {\n acc.primaryLanguages.push({ ...language, checked, isOriginal })\n }\n\n return acc\n },\n {\n primaryLanguages: [],\n remainingLanguages: [],\n },\n ),\n [currentLocale, contentLocale, languages],\n )\n\n return (\n <ul\n aria-describedby={describedById}\n role=\"listbox\"\n tabIndex={-1}\n className={className('translation-options')}\n >\n {primaryLanguages.map(\n ({ locale, nativeName, checked, isOriginal }, idx) => (\n <TranslationOption\n key={locale}\n id={locale}\n label={nativeName}\n checked={checked}\n description={isOriginal && t('translations.settings.original')}\n onChange={handleChange(locale)}\n itemClassName={className({\n 'translation-options__item--original': isOriginal,\n 'translation-options__item--selected': checked && idx !== 0,\n })}\n />\n ),\n )}\n {remainingLanguages.map(({ locale, nativeName, checked, isOriginal }) => (\n <TranslationOption\n key={locale}\n id={locale}\n label={nativeName}\n checked={checked}\n description={isOriginal && t('translations.settings.original')}\n onChange={handleChange(locale)}\n />\n ))}\n </ul>\n )\n}\n\nexport default TranslationOptions\n","import { FC } from 'preact/compat'\nimport { MutableRef, useCallback, useEffect } from 'preact/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport {\n useGeneratedId,\n useOptionButton,\n useSeamlyOptions,\n} from 'ui/hooks/seamly-hooks'\nimport useClickOutside from 'ui/hooks/use-click-outside'\nimport { focusElement } from 'ui/utils/general-utils'\n\nexport type FramePosition = {\n vertical: 'top' | 'bottom'\n horizontal: 'left' | 'right'\n}\n\ntype OptionsFrameProps = {\n className?: string\n onCancel?: () => void\n headingText: string\n description?: string\n descriptionId?: string\n cancelButtonText?: string\n cancelButtonRef?: MutableRef<HTMLElement>\n disableButtonFocusing?: boolean\n position: FramePosition\n}\n\nconst OptionsFrame: FC<OptionsFrameProps> = ({\n className: givenClassName,\n children,\n onCancel,\n headingText,\n description,\n descriptionId,\n cancelButtonText,\n cancelButtonRef,\n disableButtonFocusing,\n position = {\n horizontal: 'left',\n vertical: 'top',\n },\n}) => {\n const mainHeadingId = useGeneratedId()\n // @todo Lift this from the \"options frame\" into something reusable\n // when you're not using options\n const { hideOption } = useSeamlyOptions()\n const { focusButton } = useOptionButton()\n\n const closePanel = useCallback(() => {\n hideOption()\n if (!disableButtonFocusing) {\n focusButton()\n }\n }, [disableButtonFocusing, focusButton, hideOption])\n\n const onCancelHandler = useCallback(() => {\n if (onCancel) {\n onCancel()\n }\n closePanel()\n }, [closePanel, onCancel])\n\n const container = useClickOutside(onCancelHandler)\n\n useEffect(() => {\n focusElement(container.current)\n }, [container])\n\n return (\n <section\n className={className(\n 'options',\n {\n 'options--right': position.horizontal === 'right',\n 'options--left': position.horizontal === 'left',\n 'options--top': position.vertical === 'top',\n 'options--bottom': position.vertical === 'bottom',\n },\n givenClassName,\n )}\n aria-labelledby={mainHeadingId}\n tabIndex={-1}\n ref={container}\n >\n <div className={className('options__body')}>\n <h2 id={mainHeadingId} className={className('options__title')}>\n {headingText}\n </h2>\n <button\n type=\"button\"\n onClick={onCancelHandler}\n aria-describedby={mainHeadingId}\n className={className('button', 'options__close')}\n ref={(btn) => {\n if (cancelButtonRef) {\n cancelButtonRef.current = btn\n }\n }}\n >\n <Icon name=\"close\" size=\"16\" alt=\"\" />\n <span>{cancelButtonText}</span>\n </button>\n\n {description ? (\n <p className={className('options__description')} id={descriptionId}>\n {description}\n </p>\n ) : null}\n <div className={className('options__wrapper')}>{children}</div>\n </div>\n </section>\n )\n}\n\nexport default OptionsFrame\n","import { useEffect, useRef } from 'preact/hooks'\n\nconst useClickOutside = (callback: Function) => {\n const ref = useRef<HTMLElement>(null)\n\n useEffect(() => {\n const handler = (el: TouchEvent | MouseEvent): void => {\n if (\n ref.current &&\n el.target instanceof HTMLElement &&\n !ref.current.contains(el.target)\n ) {\n el.preventDefault()\n el.stopPropagation()\n callback()\n }\n }\n\n document.addEventListener('click', handler, true)\n document.addEventListener('touchstart', handler, true)\n\n return () => {\n document.removeEventListener('click', handler, true)\n document.removeEventListener('touchstart', handler, true)\n }\n }, [callback, ref])\n\n return ref\n}\n\nexport default useClickOutside\n","import { useI18n } from 'domains/i18n/hooks'\nimport TranslationOptions from 'domains/translations/components/options-dialog/translation-options'\nimport OptionsFrame from 'ui/components/options/options-frame'\nimport { useGeneratedId } from 'ui/hooks/seamly-hooks'\nimport type { FramePosition } from 'ui/components/options/options-frame'\n\ntype TranslationsOptionsDialogProps = {\n onClose: () => void\n position: FramePosition\n}\n\nfunction TranslationsOptionsDialog({\n onClose,\n position,\n}: TranslationsOptionsDialogProps) {\n const { t } = useI18n()\n const descriptionId = useGeneratedId()\n return (\n <OptionsFrame\n onCancel={onClose}\n headingText={t('translations.menu.title')}\n cancelButtonText={t('translations.settings.cancelButtonText')}\n description={t('translations.menu.description')}\n descriptionId={descriptionId}\n position={position}\n disableButtonFocusing\n >\n <TranslationOptions describedById={descriptionId} onChange={onClose} />\n </OptionsFrame>\n )\n}\n\nexport default TranslationsOptionsDialog\n","import { ComponentChildren } from 'preact'\nimport { useRef, useState } from 'preact/hooks'\nimport { className } from 'lib/css'\nimport InOutTransition, {\n transitionStartStates,\n} from 'ui/components/widgets/in-out-transition'\nimport { useGeneratedId } from 'ui/hooks/seamly-hooks'\nimport { focusElement, getKey, keyNames } from 'ui/utils/general-utils'\nimport TranslationsOptionsDialog from './options-dialog'\nimport type { FramePosition } from 'ui/components/options/options-frame'\n\ntype TranslationsOptionsButtonProps = {\n children: ComponentChildren\n position: FramePosition\n classNames?: string[]\n}\n\nexport default function TranslationsOptionsButton({\n children,\n position = {\n horizontal: 'left',\n vertical: 'top',\n },\n classNames,\n}: TranslationsOptionsButtonProps) {\n const [menuIsOpen, setMenuIsOpen] = useState(false)\n const toggleButton = useRef(null)\n const toggleButtonId = useGeneratedId()\n\n const onMainKeyDownHandler = (e: KeyboardEvent) => {\n if (!menuIsOpen) {\n return\n }\n\n if (getKey(e) === keyNames.Escape) {\n setMenuIsOpen(false)\n focusElement(toggleButton.current)\n }\n }\n\n const handleDialogClose = () => {\n setMenuIsOpen(false)\n }\n\n const handleToggleClick = () => {\n setMenuIsOpen(!menuIsOpen)\n }\n\n const handleToggleKeyDown = (e: KeyboardEvent) => {\n if (getKey(e) === keyNames.ArrowDown) {\n setMenuIsOpen(true)\n e.preventDefault()\n }\n }\n return (\n <div\n className={className('translations__container')}\n onKeyDown={onMainKeyDownHandler}\n >\n <InOutTransition\n transitionStartState={transitionStartStates.notRendered}\n isActive={menuIsOpen}\n >\n <div className={className('options__dialog')} role=\"dialog\">\n <TranslationsOptionsDialog\n onClose={handleDialogClose}\n position={position}\n />\n </div>\n </InOutTransition>\n <button\n type=\"button\"\n className={className([\n 'button',\n 'chat__options__button',\n ...classNames,\n ])}\n id={toggleButtonId}\n onClick={handleToggleClick}\n onKeyDown={handleToggleKeyDown}\n ref={toggleButton}\n aria-haspopup=\"dialog\"\n aria-expanded={menuIsOpen}\n >\n {children}\n </button>\n </div>\n )\n}\n","import { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport Form from 'ui/components/form-controls/form'\nimport Input from 'ui/components/form-controls/input'\n\nexport default function TranscriptForm({ controlName, describedById }) {\n const { t } = useI18n()\n return (\n <Form noValidate=\"true\" className={className('options__form')}>\n <Input\n name={controlName}\n type=\"email\"\n className={className('transcript__input')}\n aria-describedby={describedById}\n labelClass={className('label')}\n labelText={t('options.sendTranscript.label')}\n />\n <div className={className('options__actions')}>\n <button\n type=\"submit\"\n className={className('button', 'button--primary', 'options__submit')}\n >\n {t('options.sendTranscript.sendButtonText')}\n </button>\n </div>\n </Form>\n )\n}\n","import { useCallback, useMemo, useState } from 'preact/hooks'\nimport FormProvider from 'domains/forms/provider'\nimport { useI18n } from 'domains/i18n/hooks'\nimport OptionsFrame from 'ui/components/options/options-frame'\nimport {\n useGeneratedId,\n useOptionButton,\n useSeamlyCommands,\n useSeamlyOptions,\n} from 'ui/hooks/seamly-hooks'\nimport { getValidator } from 'ui/utils/form-utils'\nimport { actionTypes } from 'ui/utils/seamly-utils'\nimport { isEmailString, isNotEmptyString } from 'ui/utils/validations'\nimport TranscriptForm from './transcript-form'\n\nconst formId = 'sendTranscript'\nconst controlName = 'email'\n\nconst Transcript = () => {\n const [errorClass, setErrorClass] = useState(undefined)\n const { hideOption } = useSeamlyOptions()\n const { focusButton } = useOptionButton()\n const { t } = useI18n()\n const transcriptDescriptionId = useGeneratedId()\n const { sendAction } = useSeamlyCommands()\n\n const validationSchema = useMemo(\n () => ({\n [controlName]: [\n getValidator(isNotEmptyString, t('options.sendTranscript.noEmailText')),\n getValidator(\n isEmailString,\n t('options.sendTranscript.invalidEmailText'),\n ),\n ],\n }),\n [t],\n )\n\n const handleSubmit = useCallback(\n (values) => {\n const emailAddress = values[controlName].trim()\n sendAction({\n type: actionTypes.sendTranscript,\n body: { emailAddress },\n })\n hideOption()\n focusButton()\n },\n [sendAction, hideOption, focusButton],\n )\n\n const handleError = useCallback(\n ({ isValid, isSubmitted }) => {\n if (isSubmitted && !isValid) {\n setErrorClass('options--error')\n } else {\n setErrorClass(undefined)\n }\n },\n [setErrorClass],\n )\n\n return (\n <OptionsFrame\n className={errorClass}\n headingText={t('options.sendTranscript.title')}\n cancelButtonText={t('options.cancelButtonText')}\n description={t('options.sendTranscript.description')}\n descriptionId={transcriptDescriptionId}\n position={{\n vertical: 'top',\n horizontal: 'right',\n }}\n >\n <FormProvider\n formId={formId}\n onSubmit={handleSubmit}\n validationSchema={validationSchema}\n onError={handleError}\n >\n <TranscriptForm\n controlName={controlName}\n describedById={transcriptDescriptionId}\n />\n </FormProvider>\n </OptionsFrame>\n )\n}\n\nexport default Transcript\n","import { useRef } from 'preact/hooks'\nimport { useSeamlyOptions } from 'ui/hooks/seamly-hooks'\nimport Transcript from './transcript'\n\nconst mapper = {\n sendTranscript: Transcript,\n}\n\nconst Options = () => {\n const { optionActive } = useSeamlyOptions()\n const prevRenderOption = useRef(null)\n\n // We keep the previously selected option active so that we can animate the options panel.\n const RenderOption = mapper[optionActive || prevRenderOption.current]\n\n if (optionActive) {\n prevRenderOption.current = optionActive\n }\n return RenderOption ? <RenderOption /> : null\n}\n\nexport default Options\n","import { createRef } from 'preact'\nimport { useEffect, useMemo, useRef, useState } from 'preact/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport InOutTransition, {\n transitionStartStates,\n} from 'ui/components/widgets/in-out-transition'\nimport { timeout } from 'ui/hooks/focus-helper-hooks'\nimport { useOptionButton, useSeamlyOptions } from 'ui/hooks/seamly-hooks'\nimport { focusElement, getKey, keyNames } from 'ui/utils/general-utils'\nimport Options from './options'\n\nconst OptionsButton = () => {\n const { t } = useI18n()\n const { menuOptions, showOption, panelActive, hideOption } =\n useSeamlyOptions()\n const { id } = useOptionButton()\n const focusOutDelayTimeoutID = useRef(null)\n\n const [menuIsOpen, setMenuIsOpen] = useState(false)\n\n const toggleButton = useRef(null)\n const optionsLength = menuOptions.length\n const menuItemButtons = useRef(\n Array.from({ length: optionsLength }, () => createRef()),\n )\n const prevMenuIsOpen = useRef(false)\n\n const multiMenu = optionsLength > 1\n const firstOption = menuOptions[0]\n const firstOptionName = useMemo(\n () => firstOption?.name?.trim().replace(/\\s+/g, ''),\n [firstOption],\n )\n\n useEffect(() => {\n return () => {\n clearTimeout(focusOutDelayTimeoutID.current)\n }\n }, [])\n\n useEffect(() => {\n if (menuIsOpen && !prevMenuIsOpen.current) {\n requestAnimationFrame(async () => {\n await timeout(60) // Wait for next frame tick\n const firstActiveOptionIndex = menuOptions.findIndex(\n (option) => option.available,\n )\n\n const focusIndex =\n firstActiveOptionIndex === -1 ? 0 : firstActiveOptionIndex\n focusElement(menuItemButtons.current[focusIndex])\n })\n }\n prevMenuIsOpen.current = menuIsOpen\n }, [menuIsOpen, menuOptions])\n\n const onClickHandler = () => {\n if (panelActive) {\n hideOption()\n }\n if (multiMenu) {\n setMenuIsOpen((o) => !o)\n } else if (firstOption.available && !panelActive) {\n showOption(firstOption.name)\n }\n }\n\n const onMainKeyDownHandler = (e) => {\n if (!menuIsOpen) {\n return\n }\n\n if (getKey(e) === keyNames.Escape) {\n setMenuIsOpen(false)\n focusElement(toggleButton.current)\n }\n if (getKey(e) === keyNames.Home) {\n focusElement(menuItemButtons.current[0])\n e.preventDefault()\n }\n if (getKey(e) === keyNames.End) {\n focusElement(menuItemButtons.current[optionsLength - 1])\n e.preventDefault()\n }\n }\n\n const onButtonKeyDownHandler = (e) => {\n if (getKey(e) === keyNames.ArrowDown) {\n setMenuIsOpen(true)\n e.preventDefault()\n }\n }\n\n const onMenuItemKeyDownHandler = (e, index) => {\n if (getKey(e) === keyNames.ArrowDown) {\n const newIndex = Math.min(optionsLength - 1, index + 1)\n focusElement(menuItemButtons.current[index === newIndex ? 0 : newIndex])\n e.preventDefault()\n }\n if (getKey(e) === keyNames.ArrowUp) {\n const newIndex = Math.max(0, index - 1)\n focusElement(\n menuItemButtons.current[\n index === newIndex ? optionsLength - 1 : newIndex\n ],\n )\n e.preventDefault()\n }\n }\n\n const onFocusOutHandler = () => {\n if (multiMenu) {\n focusOutDelayTimeoutID.current = setTimeout(() => {\n setMenuIsOpen(false)\n }, 200)\n }\n }\n\n const onFocusInHandler = () => {\n clearTimeout(focusOutDelayTimeoutID.current)\n }\n\n const onKeyPressHandler = (e, index) => {\n const char = String.fromCharCode(e.charCode)\n const isPrintableChar = !!(char.length === 1 && char.match(/\\S/))\n\n if (!isPrintableChar) {\n return\n }\n\n let foundIndex = -1\n\n menuOptions.forEach((option, i) => {\n if (\n i > index &&\n option.title.charAt(0).toLowerCase() === char.toLowerCase() &&\n foundIndex === -1\n ) {\n foundIndex = i\n }\n })\n\n if (foundIndex !== -1) {\n focusElement(menuItemButtons.current[foundIndex])\n }\n }\n\n const onMenuItemClickHandler = (name, available) => {\n if (available) {\n setMenuIsOpen(false)\n showOption(name)\n }\n }\n if (!optionsLength) {\n return null\n }\n\n return (\n <div\n className={className('options__container')}\n onKeyDown={onMainKeyDownHandler}\n // eslint-disable-next-line react/no-unknown-property\n onfocusout={onFocusOutHandler}\n // eslint-disable-next-line react/no-unknown-property\n onfocusin={onFocusInHandler}\n >\n <InOutTransition\n transitionStartState={transitionStartStates.notRendered}\n isActive={panelActive}\n >\n <div className={className('options__dialog')}>\n <Options />\n </div>\n </InOutTransition>\n {multiMenu && (\n <InOutTransition\n isActive={menuIsOpen}\n transitionStartState={transitionStartStates.notRendered}\n >\n <ul\n className={className(['options__menu'])}\n role=\"menu\"\n tabIndex=\"-1\"\n aria-labelledby={id}\n >\n {menuOptions.map(({ name, title, available }, i) => (\n <li\n className={className('options__menu__item')}\n key={name}\n role=\"menuitem\"\n data-testid={name}\n >\n <button\n type=\"button\"\n ref={(item) => {\n menuItemButtons.current[i] = item\n }}\n className={className(['button', 'button--secondary'])}\n onKeyDown={(e) => onMenuItemKeyDownHandler(e, i)}\n onKeyPress={(e) => onKeyPressHandler(e, i)}\n onClick={() => onMenuItemClickHandler(name, available)}\n aria-disabled={!available ? 'true' : null}\n >\n <span className={className('button__text')}>\n {title}\n {!available && ' '}\n </span>\n {!available && (\n <span className={className('button__state')}>\n {t('options.unavailableText')}\n </span>\n )}\n </button>\n </li>\n ))}\n </ul>\n </InOutTransition>\n )}\n <button\n type=\"button\"\n className={className([\n 'button',\n 'button--secondary',\n 'chat__options__button',\n ...(!multiMenu && firstOptionName\n ? [`chat__options__button--${firstOptionName}`]\n : []),\n ])}\n id={id}\n onClick={onClickHandler}\n onKeyDown={multiMenu ? onButtonKeyDownHandler : null}\n ref={toggleButton}\n aria-haspopup={multiMenu ? 'menu' : null}\n aria-expanded={multiMenu ? menuIsOpen.toString() : null}\n aria-disabled={!multiMenu && !firstOption.available ? 'true' : null}\n >\n {multiMenu && <Icon name=\"options\" size=\"32\" alt=\"\" />}\n <span className={className('button__text')}>\n {multiMenu\n ? t('options.openButtonText')\n : `${firstOption.title}${!firstOption.available ? ' ' : ''}`}\n </span>\n {!multiMenu && !firstOption.available && (\n <span className={className('button__state')}>\n {t('options.unavailableText')}\n </span>\n )}\n </button>\n </div>\n )\n}\n\nexport default OptionsButton\n","import { useSelector } from 'react-redux'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { selectHasError } from 'domains/interrupt/selectors'\nimport TranslationsOptionsButton from 'domains/translations/components/options-button'\nimport {\n useLocaleNativeName,\n useTranslations,\n} from 'domains/translations/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport OptionsButton from 'ui/components/options/options-button'\nimport { useSeamlyOptions } from 'ui/hooks/seamly-hooks'\n\nexport default function AppOptions() {\n const { menuOptions, allowOptionSelection } = useSeamlyOptions()\n const { isAvailable: isTranslationsAvailable } = useTranslations()\n const hasError = useSelector(selectHasError)\n const { t, locale } = useI18n()\n const localeNativeName = useLocaleNativeName(locale)\n\n if (\n (!isTranslationsAvailable &&\n (!allowOptionSelection || !menuOptions.length)) ||\n hasError\n ) {\n return null\n }\n\n const openButtonText = t('translations.settings.openButtonText', {\n hasLanguage: !!localeNativeName,\n language: localeNativeName,\n })\n\n return (\n <div className={className('chat__options')}>\n {isTranslationsAvailable && (\n <div\n className={className(\n 'chat__options-item',\n 'chat__options-item--left',\n )}\n >\n <TranslationsOptionsButton classNames={['button--secondary']}>\n <Icon alt={openButtonText} name=\"newTranslation\" size=\"16\" />\n <span className={className('button__text')}>{openButtonText}</span>\n </TranslationsOptionsButton>\n </div>\n )}\n {allowOptionSelection && (\n <div\n className={className(\n 'chat__options-item',\n 'chat__options-item--right',\n )}\n >\n <OptionsButton />\n </div>\n )}\n </div>\n )\n}\n","import { useContext } from 'preact/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport ChatScrollContext from 'ui/components/conversation/event/chat-scroll/chat-scroll-context'\nimport Icon from 'ui/components/layout/icon'\nimport InOutTransition from 'ui/components/widgets/in-out-transition'\n\nconst UnreadMessagesButton = () => {\n const { scrollToRef, unreadIds } = useContext(ChatScrollContext)\n const { isMinimized } = useVisibility()\n const { t } = useI18n()\n\n return (\n <InOutTransition isActive={!!unreadIds.length && !isMinimized}>\n <div className={className('unread-messages')}>\n <button\n type=\"button\"\n className={className('button', 'button--primary')}\n onClick={scrollToRef}\n >\n {t('message.unreadMessagesCount', { unreadCount: unreadIds.length })}\n <Icon name=\"chevronDown\" size=\"32\" alt=\"\" />\n </button>\n </div>\n </InOutTransition>\n )\n}\n\nexport default UnreadMessagesButton\n","import { createSelector } from '@reduxjs/toolkit'\nimport { isUnreadMessage } from 'domains/store/slice'\nimport { selectEvents } from 'ui/hooks/seamly-state-hooks'\nimport { readStates } from 'ui/utils/seamly-utils'\nimport { RootState } from '.'\n\nexport const selectUnreadEvents = createSelector(selectEvents, (events) => {\n return events.filter((event) => {\n return (\n isUnreadMessage(event) &&\n event.type !== 'service_data' &&\n event.payload?.messageStatus === readStates.received\n )\n })\n})\nexport const selectLastUnreadEvent = createSelector(\n selectUnreadEvents,\n (events) => events.at(-1),\n)\n\nexport const selectUnreadEventIds = createSelector(\n selectUnreadEvents,\n (events) => events.map((event) => event.payload.id),\n)\n\nexport const selectShowNotifications = createSelector(\n ({ state }: RootState) => state.options.features?.webNotifications,\n (webNotifications) => webNotifications?.enabled,\n)\n","import { RefObject } from 'preact'\nimport {\n MutableRef,\n useCallback,\n useEffect,\n useRef,\n useState,\n} from 'preact/hooks'\nimport { useSelector } from 'react-redux'\nimport { RootState } from 'domains/store'\nimport { selectUnreadEventIds } from 'domains/store/selectors'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { timeout } from 'ui/hooks/focus-helper-hooks'\nimport {\n useEvents,\n useLoadedImageEventIds,\n useSeamlyIsLoading,\n} from 'ui/hooks/seamly-state-hooks'\n\n/**\n * Threshold defines how close to the bottom user needs to scroll for it to be treated as the bottom of the conversation.\n */\nconst THRESHOLD = 10\n\nconst useChatScroll = (\n eventRefs: Record<string, RefObject<HTMLElement>>,\n): {\n containerRef: MutableRef<HTMLDivElement>\n unreadIds: string[]\n scrollToRef: () => void\n scrollToBottom: () => void\n} => {\n const containerRef = useRef<HTMLDivElement>()\n const [hasScrolledToBottom, setHasScrolledToBottom] = useState(true)\n const unreadIds = useSelector(selectUnreadEventIds)\n const events = useEvents()\n const isLoading = useSeamlyIsLoading()\n const { isOpen } = useVisibility()\n const loadedImageEventIds = useLoadedImageEventIds()\n const { processingFileUploads, isLastEventFromClient } = useSelector(\n ({ state }: RootState) => state,\n )\n\n useEffect(() => {\n const element = containerRef.current\n const onScroll = () => {\n const { scrollHeight, scrollTop, clientHeight } = element\n const hasScrolledUp =\n Math.abs(scrollHeight - scrollTop - clientHeight) > THRESHOLD\n\n setHasScrolledToBottom(!hasScrolledUp)\n }\n\n element.addEventListener('scroll', onScroll)\n\n return () => element.removeEventListener('scroll', onScroll)\n }, [])\n\n const scrollToBottom = useCallback(() => {\n requestAnimationFrame(async () => {\n await timeout(30)\n containerRef.current?.scrollTo({\n top: containerRef.current?.scrollHeight,\n left: 0,\n behavior: 'auto',\n })\n })\n }, [])\n\n useEffect(() => {\n if (isLastEventFromClient) {\n scrollToBottom()\n }\n }, [isLastEventFromClient, scrollToBottom])\n\n useEffect(() => {\n if (hasScrolledToBottom) {\n scrollToBottom()\n }\n }, [\n hasScrolledToBottom,\n unreadIds,\n events,\n isLoading,\n isOpen,\n loadedImageEventIds,\n processingFileUploads,\n scrollToBottom,\n ])\n\n const scrollToRef = () => {\n const ref = eventRefs[unreadIds?.at(0)]?.current\n // We scroll to the oldest unread event\n containerRef.current?.scrollTo({\n top: ref?.offsetTop,\n behavior: 'auto',\n left: 0,\n })\n }\n\n return {\n containerRef,\n unreadIds,\n scrollToRef,\n scrollToBottom,\n }\n}\n\nexport default useChatScroll\n","import { RefObject, createRef } from 'preact'\nimport { useMemo } from 'preact/hooks'\nimport { className } from 'lib/css'\nimport ChatScrollContext from 'ui/components/conversation/event/chat-scroll/chat-scroll-context'\nimport UnreadMessagesButton from 'ui/components/conversation/event/chat-scroll/unread-messages-button'\nimport useChatScroll from 'ui/components/conversation/use-chat-scroll'\nimport { useEvents } from 'ui/hooks/seamly-hooks'\n\nconst ChatScrollProvider = ({ children }) => {\n const events = useEvents()\n const eventRefs = useMemo(\n () =>\n events.reduce<Record<string, RefObject<HTMLElement>>>((acc, value) => {\n if (!value.payload.id) return acc\n\n acc[value.payload.id] = createRef()\n return acc\n }, {}),\n [events],\n )\n\n const { scrollToRef, scrollToBottom, containerRef, unreadIds } =\n useChatScroll(eventRefs)\n\n return (\n <ChatScrollContext.Provider\n value={{\n eventRefs,\n unreadIds,\n scrollToRef,\n scrollToBottom,\n containerRef,\n }}\n >\n <div className={className('chat__container')}>\n <div\n className={className('chat__container__scroll-area')}\n ref={containerRef}\n >\n {children}\n </div>\n <UnreadMessagesButton />\n </div>\n </ChatScrollContext.Provider>\n )\n}\n\nexport default ChatScrollProvider\n","import { useI18n } from 'domains/i18n/hooks'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport { useSeamlyLayoutMode } from 'ui/hooks/seamly-state-hooks'\n\nconst CollapseButton = () => {\n const { t } = useI18n()\n const { isOpen, closeChat } = useVisibility()\n const { isWindow } = useSeamlyLayoutMode()\n return isOpen && isWindow ? (\n <button\n type=\"button\"\n className={className('button', 'collapse-button')}\n onClick={closeChat}\n >\n <Icon name=\"chevronDown\" size=\"32\" alt={t('window.srCollapseButton')} />\n </button>\n ) : null\n}\n\nexport default CollapseButton\n","import { useEffect } from 'preact/hooks'\nimport { useInterrupt } from 'domains/interrupt/hooks'\nimport { className } from 'lib/css'\nimport CollapseButton from 'ui/components/view/window-view/collapse-button'\nimport {\n useGeneratedId,\n useLiveRegion,\n useSeamlyCommands,\n useSkiplinkTargetFocusing,\n} from 'ui/hooks/seamly-hooks'\n\nconst Interrupt = () => {\n const {\n meta: { originalError, title, message, buttonText, action, srText },\n } = useInterrupt()\n const seamlyCommands = useSeamlyCommands()\n const headingId = useGeneratedId()\n const { sendPolite } = useLiveRegion()\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n const isExpiredError = originalError?.name === 'SeamlySessionExpiredError'\n\n useEffect(() => {\n if (!isExpiredError && srText) {\n // Wait for live regions to stabilise in case this occurs\n // at an initial render\n setTimeout(() => {\n sendPolite(srText)\n }, 200)\n }\n }, [sendPolite, srText, isExpiredError])\n\n const onClickHandler = () => {\n if (seamlyCommands[action]) {\n seamlyCommands[action]()\n }\n focusSkiplinkTarget()\n }\n\n return !isExpiredError ? (\n <section className={className('interrupt')} aria-labelledby={headingId}>\n <CollapseButton />\n <div className={className('interrupt__body')}>\n <h2 id={headingId} className={className('interrupt__title')}>\n {title}\n </h2>\n <p className={className('interrupt__message')}>{message}</p>\n {buttonText && action && (\n <div className={className('interrupt__actions')}>\n <button\n type=\"button\"\n className={className('button', 'button--primary')}\n onClick={onClickHandler}\n >\n {buttonText}\n </button>\n </div>\n )}\n </div>\n </section>\n ) : (\n <></>\n )\n}\n\nexport default Interrupt\n","import { useSelector } from 'react-redux'\nimport { selectHasError } from 'domains/interrupt/selectors'\nimport TranslationStatus from 'domains/translations/components/translation-status'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport AppOptions from 'ui/components/app-options'\nimport ChatScrollProvider from 'ui/components/conversation/event/chat-scroll/chat-scroll-provider'\nimport EntryContainer from 'ui/components/entry/entry-container'\nimport CollapseButton from 'ui/components/view/window-view/collapse-button'\nimport Interrupt from './interrupt'\n\nfunction ChatFrame({ children }) {\n const hasError = useSelector(selectHasError)\n const { isOpen } = useVisibility()\n\n if (hasError) {\n return <Interrupt />\n }\n\n return (\n <>\n <ChatScrollProvider>\n <div className={className('chat__container__header')}>\n <TranslationStatus />\n <CollapseButton />\n </div>\n {children}\n </ChatScrollProvider>\n <EntryContainer />\n {isOpen && <AppOptions />}\n </>\n )\n}\n\nexport default ChatFrame\n","import { useRef } from 'preact/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { className } from 'lib/css'\nimport { useSeamlyStateContext } from 'ui/hooks/seamly-hooks'\nimport Icon from './icon'\n\nconst Header = ({ children, onCloseChat }) => {\n const { headerCollapseButtonId } = useSeamlyStateContext()\n const closeButton = useRef(null)\n\n const { t } = useI18n()\n return (\n <header className={className('chat__header')}>\n {children}\n <div className={className('header-controls')}>\n <button\n type=\"button\"\n className={className('button', 'header-controls__collapse')}\n onClick={onCloseChat}\n ref={closeButton}\n id={headerCollapseButtonId}\n >\n <Icon name=\"chevronDown\" size=\"32\" alt={t('header.collapseApp')} />\n </button>\n </div>\n </header>\n )\n}\n\nexport default Header\n","import { ChannelEvent } from 'domains/store/store.types'\nimport { className } from 'lib/css'\nimport useEventComponentMapping from 'ui/hooks/use-event-component-mapping'\n\nfunction CollapsedChatMessage({ event }: { event: ChannelEvent }) {\n const [Component] = useEventComponentMapping(event)\n\n return (\n <li>\n <Component event={event} />\n </li>\n )\n}\n\nexport function CollapsedChatMessages({ events }: { events: ChannelEvent[] }) {\n return (\n <ul className={className('collapsed-chat-messages')}>\n {events.map((event) => (\n <CollapsedChatMessage key={event.payload.id} event={event} />\n ))}\n </ul>\n )\n}\n","import { useSelector } from 'react-redux'\nimport { useConfig } from 'domains/config/hooks'\nimport { selectHasError } from 'domains/interrupt/selectors'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { CollapsedChatMessages } from './collapsed-chat-messages'\n\nexport default function PreChatMessages() {\n const { preChatEvents } = useConfig()\n const hasError = useSelector(selectHasError)\n const { isOpen } = useVisibility()\n\n const isVisible = !(hasError || !preChatEvents?.length || isOpen)\n\n return isVisible && <CollapsedChatMessages events={preChatEvents} />\n}\n","import { useMemo } from 'preact/hooks'\nimport { ChannelEvent } from 'domains/store/store.types'\nimport { useI18n } from 'package/hooks'\nimport { CollapsedChatMessages } from './collapsed-chat-messages'\n\nexport default function ContinueChatMessages() {\n const { t } = useI18n()\n const continueChatText = t('window.chat.continue')\n const continueChatEvent = useMemo(\n (): ChannelEvent => ({\n type: 'message',\n payload: {\n body: {\n text: continueChatText,\n },\n },\n }),\n [continueChatText],\n )\n\n return <CollapsedChatMessages events={[continueChatEvent]} />\n}\n","import { useCallback } from 'preact/hooks'\nimport { useSelector } from 'react-redux'\nimport { useStartChatIcon } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { selectHasError } from 'domains/interrupt/selectors'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport Icon from 'ui/components/layout/icon'\nimport InOutTransition, {\n transitionStartStates,\n} from 'ui/components/widgets/in-out-transition'\nimport { useSkiplinkTargetFocusing } from 'ui/hooks/focus-helper-hooks'\nimport { useSeamlyHasConversation } from 'ui/hooks/seamly-api-hooks'\nimport {\n useSeamlyCurrentAgent,\n useSeamlyUnreadCount,\n} from 'ui/hooks/seamly-state-hooks'\n\nconst ButtonIcon = () => {\n const startChatIcon = useStartChatIcon()\n const currentAgent = useSeamlyCurrentAgent()\n const hasError = useSelector(selectHasError)\n const isActiveConversation = currentAgent && !hasError\n const src = isActiveConversation ? currentAgent.avatar : startChatIcon\n return src ? (\n <img\n className={className(isActiveConversation ? 'avatar' : 'icon')}\n src={src}\n alt=\"\"\n />\n ) : (\n <Icon name=\"avatar\" size=\"32\" alt=\"\" />\n )\n}\n\nconst WindowOpenButton = ({ onClick }) => {\n const hasConversation = useSeamlyHasConversation()\n const { t } = useI18n()\n const ariaLabel = hasConversation()\n ? t('window.openButton.srContinue')\n : t('window.openButton.srStart')\n const focusSkiplinkTarget = useSkiplinkTargetFocusing()\n const { isOpen } = useVisibility()\n const count = useSeamlyUnreadCount()\n const handleClick = useCallback(() => {\n onClick()\n focusSkiplinkTarget()\n }, [focusSkiplinkTarget, onClick])\n return (\n <InOutTransition\n isActive={!isOpen}\n transitionStartState={transitionStartStates.rendered}\n >\n <button\n className={className('window-open-button')}\n aria-label={ariaLabel}\n aria-hidden={isOpen}\n onClick={handleClick}\n >\n <InOutTransition\n isActive={!!count}\n transitionStartState={transitionStartStates.notRendered}\n >\n <span className={className('message-count')} aria-hidden=\"true\">\n {count}\n </span>\n </InOutTransition>\n <ButtonIcon />\n </button>\n </InOutTransition>\n )\n}\n\nexport default WindowOpenButton\n","import { useUserHasResponded } from 'domains/app/hooks'\nimport { useConfig } from 'domains/config/hooks'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport Conversation from 'ui/components/conversation/conversation'\nimport Chat from 'ui/components/layout/chat'\nimport ChatFrame from 'ui/components/layout/chat-frame'\nimport ContinueChatMessages from 'ui/components/layout/continue-chat-messages'\nimport PreChatMessages from 'ui/components/layout/pre-chat-messages'\nimport InOutTransition, {\n transitionStartStates,\n} from 'ui/components/widgets/in-out-transition'\nimport WindowOpenButton from './window-open-button'\n\nconst getDelay = <T extends string>(\n prop: Record<T, number> | boolean,\n val: T,\n init?: number,\n) => (typeof prop === 'object' ? prop[val] : init)\n\nconst WindowView = () => {\n const { isOpen, openChat } = useVisibility()\n const userHasResponded = useUserHasResponded()\n const { continueChat, preChat } = useConfig()\n\n return (\n <>\n <WindowOpenButton onClick={openChat} />\n <InOutTransition\n isActive={preChat && !isOpen && !userHasResponded}\n exitAfter={getDelay(preChat, 'exitAfter')}\n enterDelay={getDelay(preChat, 'enterDelay')}\n transitionStartState={transitionStartStates.notRendered}\n >\n <div\n className={className(\n 'unstarted-wrapper',\n 'unstarted-wrapper--window',\n )}\n >\n <PreChatMessages />\n </div>\n </InOutTransition>\n <InOutTransition\n isActive={continueChat && !isOpen && userHasResponded}\n exitAfter={getDelay(continueChat, 'exitAfter')}\n enterDelay={getDelay(continueChat, 'enterDelay')}\n transitionStartState={transitionStartStates.notRendered}\n >\n <div\n className={className(\n 'unstarted-wrapper',\n 'unstarted-wrapper--window',\n 'unstarted-wrapper--continue',\n )}\n >\n <ContinueChatMessages />\n </div>\n </InOutTransition>\n <InOutTransition\n isActive={isOpen}\n transitionStartState={transitionStartStates.notRendered}\n >\n <Chat>\n <ChatFrame>\n <Conversation />\n </ChatFrame>\n </Chat>\n </InOutTransition>\n </>\n )\n}\n\nexport default WindowView\n","export default __webpack_public_path__ + \"sounds/beep.mp3\";","import { useCallback, useEffect, useMemo, useState } from 'preact/hooks'\nimport { useSelector } from 'react-redux'\nimport { useConfig } from 'domains/config/hooks'\nimport { selectShowNotifications } from 'domains/store/selectors'\nimport { textEntryControlName } from 'ui/components/entry/text-entry'\nimport { useSeamlyServiceInfo } from './seamly-state-hooks'\nimport beep from './sounds/beep.mp3'\n\nconst hasNotificationSupport = !!window.Notification\n\nconst useNotification = () => {\n const { proactiveMessages } = useSeamlyServiceInfo()\n\n const { notificationAudioURL } = useConfig()\n const [permission, setPermission] = useState(\n hasNotificationSupport ? Notification.permission : 'default',\n )\n const [visibilityState, setVisibilityState] = useState(\n document.visibilityState,\n )\n\n const showNotifications = useSelector(selectShowNotifications)\n\n const requestPermission = useCallback(async () => {\n if (hasNotificationSupport && permission !== 'granted') {\n const notificationPermission = await Notification.requestPermission()\n setPermission(notificationPermission)\n }\n }, [permission])\n\n const permissionGranted = useMemo(\n () => permission === 'granted',\n [permission],\n )\n\n const visibilityStateHidden = useMemo(\n () => visibilityState === 'hidden',\n [visibilityState],\n )\n\n useEffect(() => {\n if (permission === 'default' && proactiveMessages) {\n requestPermission()\n }\n }, [permission, proactiveMessages, requestPermission])\n\n const sendNotification = useCallback(\n // eslint-disable-next-line no-undef\n async (title: string, options?: NotificationOptions) => {\n if (!showNotifications || !hasNotificationSupport) return\n\n if (permission === 'default') {\n requestPermission()\n }\n\n if (\n notificationAudioURL !== false &&\n !permissionGranted &&\n (visibilityStateHidden || !document.hasFocus())\n ) {\n try {\n const AudioPlay = new Audio(notificationAudioURL || beep)\n await AudioPlay.play()\n } catch (error) {\n // Autoplay was prevented. See link for more details\n // https://developer.chrome.com/blog/autoplay/#audiovideo-elements\n console.warn(error)\n }\n }\n\n if (\n permissionGranted &&\n (visibilityStateHidden || !document.hasFocus())\n ) {\n const notification = new Notification(title, options)\n\n notification.onclick = function () {\n window.parent.focus()\n window.focus()\n notification.close()\n\n const entry = document.querySelector<HTMLInputElement>(\n `input[name=${textEntryControlName}]`,\n )\n if (entry) entry.focus()\n }\n }\n },\n [\n notificationAudioURL,\n permission,\n permissionGranted,\n requestPermission,\n showNotifications,\n visibilityStateHidden,\n ],\n )\n\n useEffect(() => {\n if (!showNotifications) return () => {}\n\n function handleVisibilityChange() {\n setVisibilityState(document.visibilityState)\n }\n\n document.addEventListener('visibilitychange', handleVisibilityChange, false)\n\n return () => {\n document.removeEventListener('visibilitychange', handleVisibilityChange)\n }\n }, [showNotifications])\n\n return {\n permission,\n requestPermission,\n sendNotification,\n }\n}\n\nexport default useNotification\n","import { useCallback, useEffect, useMemo, useRef } from 'preact/hooks'\nimport { useSelector } from 'react-redux'\nimport { useUserHasResponded } from 'domains/app/hooks'\nimport { useConfig } from 'domains/config/hooks'\nimport { useI18n } from 'domains/i18n/hooks'\nimport { selectLastUnreadEvent } from 'domains/store/selectors'\nimport { useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport { useTranslatedEventData } from 'package/hooks'\nimport AppView from 'ui/components/view/app-view'\nimport InlineView from 'ui/components/view/inline-view'\nimport WindowView from 'ui/components/view/window-view'\nimport { useSeamlyAppContainerClassNames } from 'ui/hooks/component-helper-hooks'\nimport { useSeamlyContainerElement } from 'ui/hooks/focus-helper-hooks'\nimport {\n useSeamlyCurrentAgent,\n useSeamlyServiceInfo,\n} from 'ui/hooks/seamly-state-hooks'\nimport useNotification from 'ui/hooks/use-notifications'\n\nconst ViewComponentsMap = {\n app: AppView,\n inline: InlineView,\n window: WindowView,\n}\n\nfunction stripHtml(html?: string | undefined) {\n const tmp = document.createElement('div')\n tmp.innerHTML = html\n return tmp.textContent || tmp.innerText || ''\n}\n\nconst View = ({ children }) => {\n const { sendNotification } = useNotification()\n const [, setSeamlyContainerElement] = useSeamlyContainerElement()\n const { namespace, layoutMode, zIndex } = useConfig()\n const currentAgent = useSeamlyCurrentAgent()\n const { proactiveMessages } = useSeamlyServiceInfo()\n const { isOpen, isVisible } = useVisibility()\n const appContainerClassNames = useSeamlyAppContainerClassNames()\n const userHasResponded = useUserHasResponded()\n const lastUnreadEvent = useSelector(selectLastUnreadEvent)\n const { body } = useTranslatedEventData(lastUnreadEvent)\n const { userLocale } = useI18n()\n const prevLastUnreadEventId = useRef<string | undefined>(undefined)\n\n const notificationBody = useMemo(() => {\n return body\n ? // @ts-ignore\n stripHtml(body?.text || body?.prompt?.text || body)\n : undefined\n }, [body])\n\n useEffect(() => {\n if (\n !currentAgent?.name ||\n !notificationBody ||\n !proactiveMessages ||\n !lastUnreadEvent ||\n prevLastUnreadEventId.current === lastUnreadEvent.payload?.id\n ) {\n return\n }\n\n sendNotification(currentAgent.name, {\n body: notificationBody,\n icon: currentAgent?.avatar,\n })\n\n prevLastUnreadEventId.current = lastUnreadEvent.payload.id\n }, [\n currentAgent?.avatar,\n currentAgent?.name,\n lastUnreadEvent,\n notificationBody,\n proactiveMessages,\n sendNotification,\n ])\n const ViewComponent = ViewComponentsMap[layoutMode]\n\n const containerElementRef = useCallback(\n (container: HTMLElement) => {\n if (typeof setSeamlyContainerElement !== 'function') return\n setSeamlyContainerElement(container)\n },\n [setSeamlyContainerElement],\n )\n\n const blockLang = useMemo(() => {\n if (userLocale) {\n const htmlElementLang = document\n .querySelector('html')\n .getAttribute('lang')\n if (htmlElementLang !== userLocale) {\n return userLocale\n }\n }\n return undefined\n }, [userLocale])\n\n if (!ViewComponent) {\n console.warn('\"layoutMode\" should be one of \"app\", \"inline\" or \"window\"')\n return null\n }\n\n const defaultClassNames = [\n `app--layout-${layoutMode}`,\n `namespace--${namespace}`,\n ]\n\n const classNames = ['app', ...defaultClassNames]\n\n if (typeof appContainerClassNames !== 'function') {\n classNames.push(...appContainerClassNames)\n }\n\n if (!isOpen && layoutMode !== 'app') {\n classNames.push('app--collapsed')\n }\n\n if (userHasResponded) {\n classNames.push('app--user-responded')\n }\n\n return (\n isVisible && (\n <div\n className={className(classNames)}\n lang={blockLang}\n tabIndex={-1}\n data-nosnippet\n style={{ zIndex }}\n ref={containerElementRef}\n >\n {children || <ViewComponent />}\n </div>\n )\n )\n}\n\nexport default View\n","import Conversation from '../conversation/conversation'\nimport Chat from '../layout/chat'\nimport ChatFrame from '../layout/chat-frame'\n\nconst AppView = () => {\n return (\n <Chat>\n <ChatFrame>\n <Conversation />\n </ChatFrame>\n </Chat>\n )\n}\n\nexport default AppView\n","import { useShowInlineView, useVisibility } from 'domains/visibility/hooks'\nimport { className } from 'lib/css'\nimport Conversation from '../conversation/conversation'\nimport Chat from '../layout/chat'\nimport ChatFrame from '../layout/chat-frame'\nimport PreChatMessages from '../layout/pre-chat-messages'\nimport Suggestions from '../suggestions'\nimport InOutTransition, {\n transitionStartStates,\n} from '../widgets/in-out-transition'\n\nconst InlineView = () => {\n const { showInlineView, containerRef } = useShowInlineView()\n\n const { isOpen } = useVisibility()\n return (\n <>\n <InOutTransition\n isActive={!isOpen}\n transitionStartState={transitionStartStates.rendered}\n >\n <div\n ref={containerRef}\n className={className(\n 'unstarted-wrapper',\n 'unstarted-wrapper--inline',\n )}\n >\n <PreChatMessages />\n <Suggestions />\n </div>\n </InOutTransition>\n <InOutTransition\n isActive={isOpen}\n transitionStartState={transitionStartStates.rendered}\n >\n <Chat ref={containerRef}>\n {showInlineView && (\n <ChatFrame>{isOpen && <Conversation />}</ChatFrame>\n )}\n </Chat>\n </InOutTransition>\n </>\n )\n}\n\nexport default InlineView\n"],"names":["self","window","debug","Set","CSS_NAME","userParticipantId","screenReaderDebounceDelaySeconds","maxCharacterWarningLimit","maxCharacterSrDebounceDelay","defaultTransitionTimeMs","typingTimeout","defaultConfig","namespace","layoutMode","messages","agent","showAvatar","showName","user","timeIndicator","enabled","threshold","initializeApp","createAsyncThunk","_","extra","api","config","rejectWithValue","__awaiter","contentLocale","_a","context","userLocale","_b","environment","sendEnvironment","getEnvironment","hasConversation","initialState","getConversationIntitialState","sendContext","Object","assign","_c","topic","send","type","actionTypes","setTopic","body","name","fallbackMessage","undefined","e","SeamlySessionExpiredError","err","message","originalEvent","originalError","action","SeamlyUnavailableError","langKey","resetApp","createDebouncedAsyncThunk","typePrefix","payloadCreator","debounceOptions","wait","maxWait","leading","resolve","debounceTimer","maxWaitTimer","invoke","clearTimeout","condition","debounceExecutionCondition","immediate","setTimeout","Promise","res","dispatch","disconnect","clearStore","resetConfig","initializeConfig","initializeVisibility","selectUserHasResponded","createSelector","app","userHasResponded","appSlice","createSlice","reducers","setHasResponded","state","payload","extraReducers","builder","addCase","pending","fulfilled","userResponded","actions","features","defaultLocale","preChat","agentParticipant","userParticipant","startChatIcon","getConfig","defaultUserLocale","defaultContentLocale","connectWhenInView","error","useConfig","useSelector","selectConfig","useStartChatIcon","newConfig","visible","visibilityStates","open","minimized","appContainerClassNames","initialConfigState","domain","key","secure","notificationAudioURL","hideOnNoUserResponse","showDisclaimer","showSuggestions","enterDelay","exitAfter","continueChat","customComponents","defaults","preChatEvents","configKeys","updateState","pick","partialConfig","__rest","newState","keys","length","configSlice","setConfig","updateConfig","setPreChatEvents","map","createAction","initialFormState","controls","initialControlState","value","touched","formsSlice","registerForm","persistData","formId","formState","deregisterForm","registerControl","deregisterControl","form","updateControlValue","updateControlTouched","setLocale","translations","getTranslations","locale","getState","i18n","isLoading","_arrayLikeToArray","arr","len","i","arr2","Array","_typeof","o","Symbol","iterator","constructor","prototype","toPropertyKey","t","r","toPrimitive","call","TypeError","String","_defineProperties","target","props","descriptor","enumerable","configurable","writable","defineProperty","_defineProperty","obj","flatten","array","reduce","accumulator","concat","isArray","parseCases","string","isWhitespace","ch","test","args","cases","currTermStart","latestTerm","inTerm","slice","caseBody","branchEndIndex","findClosingBracket","Error","push","fromIndex","depth","char","charAt","splitFormattedArgument","block","split","separator","limit","arguments","indexOfDelimiter","indexOf","head","substring","trim","tail","pluralFormatter","MessageFormatter","func","cache","_this","this","typeHandlers","instance","Constructor","_classCallCheck","values","process","join","_len","_key","arg","toString","Date","toISOString","JSON","stringify","hasOwnProperty","result","apply","protoProps","blockStartIndex","blockEndIndex","_splitFormattedArgume2","l","n","u","a","f","next","done","minLen","from","format","typeHandler","bind","ownKeys","object","enumerableOnly","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","_objectSpread","source","forEach","getOwnPropertyDescriptors","defineProperties","keyCounter","OTHER$1","replaceNumberSign","output","numBraces","numberValues","keyParam","OTHER","selectTranslations","selectInitialLocale","initialLocale","selectLocale","selectIsLoading","formatter","plural","_parseCases","intValue","parseInt","startsWith","keywordPossibilities","Intl","resolvedOptions","PluralRules","pluralKeyword","select","keyword","_replaceNumberSign","useI18n","useCallback","translation","console","warn","useInterrupt","selectError","hasError","selectHasError","meta","useMemo","title","srText","buttonText","interrupt","Boolean","interruptSlice","setInterrupt","clearInterrupt","addMatcher","isAnyOf","rejected","setVisibility","getConversation","events","lastEvent","payloadLastEventId","id","i18nSlice","setInitialLocale","setTranslations","sort","accum","combineReducers","stateReducer","appReducer","configReducer","i18nReducer","translationReducer","visibility","visibilityReducer","forms","formsReducer","interruptReducer","useAppDispatch","useDispatch","isUnreadMessage","document","visibilityState","eventTypes","fromClient","info","payloadTypes","text","orderHistory","occurredAt","occurredAtA","occurredAtB","participantReducer","participantInfo","participants","currentAgent","avatar","introduction","participant","oldParticipant","newParticipants","calculateNewEntryMeta","entryMeta","channelEvent","entry","translatedEntry","blockAutoEntrySwitch","translatedActions","optionsOverride","options","newActive","active","userSelected","initialStoreState","isLastEventFromClient","unreadEvents","loadedImageEventIds","idleDetachCountdown","hasCountdown","isActive","remaining","wasStopped","count","timer","resumeConversationPrompt","serviceInfo","activeServiceSessionId","proactiveMessages","headerTitles","subTitle","historyLoaded","skiplinkTargetId","randomId","optionsButtonId","headerCollapseButtonId","serviceData","webNotifications","panelActive","optionActive","userSelectedOptions","showFileUpload","currentUploads","processingFileUploads","default","entryTypes","seamlyContainerElement","storeSlice","addEvent","eventType","accountHasUploads","featureKeys","uploads","newOptions","entryType","enabledFromEntry","upload","incrementUnread","find","newEntryMeta","messageStatus","readStates","read","received","ackEvent","transactionId","matchedEvent","m","clearEvents","setEventsRead","event","setLoadedImageEventIds","setHistory","history","activeServiceSettings","mergeHistory","stateEvents","historyEvents","newStateEvents","stateEvent","optimisticallyInjected","some","historyEvent","newHistoryEvents","reverse","mergedParticipants","lastParticipantEvent","lastParticipantId","historyNewEntryMeta","newFeatures","newFeaturesHasUpload","lastParticipantEventPayload","resetHistoryLoadedFlag","setIsLoading","initIdleDetachCountdown","delaySeconds","delayTime","decrementIdleDetachCountdownCounter","prevRemaining","getTimeFromSeconds","stopIdleDetachCountdownCounter","clearIdleDetachCountdown","initResumeConversationPrompt","clearResumeConversationPrompt","setParticipant","setActiveService","setHeaderTitle","setHeaderSubTitle","setInitialState","setServiceDataItem","setFeatures","setFeatureEnabledState","clearFeatures","showOption","hideOption","setUserSelectedOptions","setUserSelectedOption","option","setBlockAutoEntrySwitch","setServiceEntryMetadata","setActiveEntryType","setUserEntryType","clearAbortTransaction","registerUpload","fileId","fileName","progress","uploading","complete","uploadHandle","setUploadProgress","fileUpload","startProcessingImage","doneProcessingImage","setUploadError","errorText","setUploadComplete","clearAllUploads","setSeamlyContainerElement","setProactiveMessages","selectIsTranslated","store","translatedEventGroups","every","includes","useTranslations","useSeamlyCommands","enableTranslations","disableTranslations","disableTranslation","languages","isAvailable","currentLocale","useTranslatedEventData","translatedBody","translatedIntroduction","_e","_d","_f","hasTranslation","isTranslated","useTranslationsContainer","containerId","focusContainer","useElementFocusingById","useLocaleNativeName","lang","nativeName","useTranslationProposal","sendAction","translationProposal","isOpen","useVisibility","proposedLocale","proposedLocaleNativeName","showProposal","language","activateTranslationProposal","dismissTranslationProposal","dismiss","TRANSLATION_PROPOSAL","disableTranslationProposalPrompt","translationsInitialState","nanoid","getLastGroupId","eventGroup","acc","_index","translationEnabled","splice","groupId","eventIds","entries","lastGroupId","at","translationSlice","enableTranslation","enableEventsTranslation","disableEventsTranslation","setTranslationProposalPrompt","feature","b","localeCompare","sensitivity","validVisibilityStates","hidden","requestedVisibility","eventBus","previousVisibility","Selectors","ConfigSelectors","visibilityCallback","calculateVisibility","unreadMessageCount","selectState","calculatedVisibility","hasResponded","get","StoreKey","set","emit","storedVisibility","initialize","selectVisibility","isVisible","isMinimized","dispatchVisibility","openChat","closeChat","useIntersect","freezeOnceVisible","containerRef","createRef","setEntry","useState","isIntersecting","frozen","observerCallback","updatedEntry","useEffect","node","current","IntersectionObserver","observer","root","rootMargin","observe","useShowInlineView","showInlineView","selectShowInlineView","setShowInlineView","visibilitySlice","SeamlyApiContext","createContext","SeamlyEventBusContext","useSeamlyApiContext","useContext","useSeamlyObjectStore","useSeamlyHasConversation","useSeamlyStateContext","selectEventsWithSuggestion","hasUserResponded","suggestion","suggestionsEvent","selectEvents","mappedEvents","previousEvent","idx","microsecondsToMilliseconds","useEvents","useSeamlyIsLoading","useSeamlyHeaderData","useSeamlyUnreadCount","useLoadedImageEventIds","useSkiplink","useSeamlyParticipant","participantId","useSeamlyServiceInfo","selectLastMessageEventId","filteredEvents","useLastMessageEventId","useSeamlyCurrentAgent","useSeamlyServiceData","useEntryTextLimit","overrideText","hasLimit","useSeamlyLayoutMode","isInline","isWindow","isApp","isResolving","system","choicePrompt","image","video","divider","countdown","cta","splash","pickChoice","navigate","custom","typing","detachService","interactivityUpdate","sendTranscript","setTranslation","setContext","clickCta","clickCard","dismissTypes","ariaLiveLevels","assertive","polite","dividerKeys","new_topic","new_translation","typingPeekahead","cardTypes","ask","SeamlyBaseError","params","super","captureStackTrace","getPrototypeOf","parsedOriginalMessage","str","parse","parseOriginalErrMsg","SeamlyConfigurationError","SeamlyGeneralError","SeamlyOfflineError","SeamlyUnauthorizedError","useUserHasResponded","defaultVisibility","baseVisibility","className","classes","flat","c","module","exports","Number","Math","random","now","round","performance","ChoicePrompt","children","descriptorId","useGeneratedId","subEvent","showOptions","chooseAgain","onChoiceClickHandler","onChooseAgainClickHandler","setShowOptions","addMessageBubble","addDivider","lastEventId","service","prompt","data","serviceSessionId","choice","originMessage","s","useChoicePrompt","_jsxs","_Fragment","toChildArray","child","showTranslationToggle","onClick","_jsx","Icon","size","alt","MessageContainer","showParticipant","choices","category","EventParticipant","eventPayload","participantName","authorInfo","src","modifiers","bodyProps","classNames","useSeamlyMessageContainerClassNames","v","modifier","SeamlyLiveRegionContext","useSeamlyAppContainerClassNames","timeout","ms","useSeamlyContainerElement","element","elementId","el","requestAnimationFrame","async","focusEl","getElementById","focusElement","useSkiplinkTargetFocusing","useLiveRegion","sendMessage","sendPolite","messageText","ariaLive","sendAssertive","useFileUploadMeta","uploadsFeature","allowedMimeTypes","allowedMimeTypesOverride","maxSize","maxSizeOverride","uploadsEnabled","uploadsEnabledFromEntry","accountAllowsUploads","serviceAllowsUploads","useFileUploads","SeamlyFileUploadContext","uploadFile","file","clearUploads","isUploading","isComplete","useSeamlyOptions","extraMenuItem","optionsObj","menuTitle","menuOptions","available","allowOptionSelection","initUserSelectedOptions","storedOptions","dispatchUserSelectedOptions","optionValues","dispatchUserSelectedOption","optionName","dispatchShowOption","dispatchHideOption","useOptionButton","focusButton","useSeamlyActivityEventHandler","SeamlyActivityEventContext","emitEvent","start","reset","AppActions","getMessageBase","getTextMessageBase","bodyText","addUploadBubble","contentType","filename","filesize","url","subtype","fromHistory","connect","connected","reject","then","catch","apiConnected","apiConfigReady","configReady","useSeamlyIdleDetachCountdown","isSeamlyOpen","stableState","useRef","sendAssertiveIfOpen","sendPoliteIfOpen","initCountdown","milliseconds","millisecondsToSeconds","endCountdown","isServerAction","decrementCountdown","newRemaining","stopCountdown","useSeamlyResumeConversationPrompt","hasPrompt","restartChat","useForceUpdate","forceUpdate","useReducer","x","useStableCallback","callback","callbackRef","isFunction","debounce","isCancelled","runInstant","createAriaHider","originalValues","rootNodes","querySelectorAll","attr","getAttribute","setAttribute","index","originalValue","removeAttribute","ceil","microseconds","seconds","minutes","floor","formatBytes","bytes","decimals","dm","log","parseFloat","toFixed","keyCodes","keyNames","Escape","End","Home","ArrowLeft","ArrowUp","ArrowRight","ArrowDown","getKey","code","keyCode","focus","runIfElementContainsOrHasFocus","contains","activeElement","getRelativeDate","date","currentDate","msMidnightToday","setHours","msDate","getTime","dayInMs","g","C","E","w","ref","shouldComponentUpdate","displayName","isReactComponent","__f","isPureReactComponent","__b","R","for","N","$$typeof","render","k","A","only","toArray","O","__e","__","__c","__k","T","unmount","F","__H","__P","I","__v","appendChild","L","__u","U","__a","D","M","__R","__O","setState","pop","componentWillUnmount","createElement","fallback","V","delete","revealOrder","W","getChildContext","P","nodeType","parentNode","childNodes","insertBefore","removeChild","j","containerInfo","Map","componentDidUpdate","componentDidMount","z","B","H","Z","Y","$","q","textContent","G","J","K","Q","cancelBubble","X","defaultPrevented","persist","isPropagationStopped","isDefaultPrevented","nativeEvent","nn","tn","class","en","vnode","toLowerCase","replace","multiple","selected","defaultValue","rn","__r","un","diffed","on","ReactCurrentDispatcher","readContext","__n","ln","cn","fn","an","sn","hn","vn","base","dn","pn","mn","yn","_n","bn","Sn","gn","Cn","h","En","wn","useId","useLayoutEffect","useInsertionEffect","useTransition","useDeferredValue","useSyncExternalStore","startTransition","useImperativeHandle","useDebugValue","version","Children","hydrate","unmountComponentAtNode","createPortal","createFactory","cloneElement","Fragment","isValidElement","isElement","isFragment","findDOMNode","Component","PureComponent","memo","forwardRef","flushSync","unstable_batchedUpdates","StrictMode","Suspense","SuspenseList","lazy","__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED","ICONS","balloon","newTopic","newTranslation","chevronDown","chevronRight","close","enlarge","download","arrowLeft","arrowRight","check","dangerouslySetInnerHTML","__html","p","is","useSyncExternalStoreWithSelector","hasValue","d","require","NOTHING","DRAFTABLE","DRAFT_STATE","die","isDraft","isDraftable","isMap","isSet","objectCtorString","proto","Ctor","Function","each","iter","getArchtype","thing","type_","has","prop","propOrOldValue","add","latest","copy_","base_","shallowCopy","strict","create","descriptors","Reflect","desc","freeze","deep","isFrozen","clear","dontMutateFrozenCollections","currentScope","plugins","getPlugin","pluginKey","plugin","getCurrentScope","usePatchesInScope","scope","patchListener","patches_","inversePatches_","patchListener_","revokeScope","leaveScope","drafts_","revokeDraft","parent_","enterScope","immer2","immer_","canAutoFreeze_","unfinalizedDrafts_","draft","revoke_","revoked_","processResult","baseDraft","modified_","finalize","maybeFreeze","generateReplacementPatches_","rootScope","path","childValue","finalizeProperty","scope_","finalized_","resultEach","isSet2","generatePatches_","parentState","targetObject","rootPath","targetIsSet","assigned_","autoFreeze_","objectTraps","getDescriptorFromProto","draft_","readPropFromProto","peek","prepareCopy","createProxy","current2","currentState","y","markChanged","isNaN","deleteProperty","owner","setPrototypeOf","arrayTraps","useStrictShallowCopy_","parent","proxyMap_","proxySet_","isManual_","traps","revoke","proxy","Proxy","revocable","createProxyProxy","currentImpl","copy","immer","produce","recipe","defaultBase","base2","ip","produceWithPatches","patches","inversePatches","autoFreeze","setAutoFreeze","useStrictShallowCopy","setUseStrictShallowCopy","createDraft","finishDraft","applyPatches","patch","op","applyPatchesImpl","applyPatches_","hasMatchFunction","createSelector2","createDraftSafeSelector2","args2","selector","wrappedSelector","rest","withTypes","createDraftSafeSelectorCreator","__REDUX_DEVTOOLS_EXTENSION_COMPOSE__","__REDUX_DEVTOOLS_EXTENSION__","match","prepareAction","actionCreator","prepared","formatProdErrorMessage","freezeDraftable","val","emplace","handler","update","insert","inserted","species","executeReducerBuilderCallback","builderCallback","actionsMap","actionMatchers","defaultCaseReducer","typeOrActionCreator","reducer","matcher","addDefaultCase","matches","matchers","commonProperties","RejectWithValue","_type","FulfillWithMeta","miniSerializeError","simpleError","property","createAsyncThunk2","requestId","requestStatus","serializeError","rejectedWithValue","aborted","idGenerator","abortController","AbortController","abortHandler","abortReason","abort","reason","promise","finalAction","conditionResult","signal","abortedPromise","addEventListener","getPendingMeta","race","fulfillWithValue","removeEventListener","dispatchConditionRejection","unwrap","unwrapResult","settled","asyncThunkSymbol","getType","actionKey","wrapSelector","getInitialState","injected","wrapper","rootState","sliceState","unwrapped","creators","cAT","asyncThunk","reducerPath","_reducerDefinitionType","caseReducer","preparedReducer","prepare","buildReducerCreators","reducerNames","sliceCaseReducersByName","sliceCaseReducersByType","actionCreators","sliceMatchers","contextMethods","reducer2","exposeAction","name2","exposeCaseReducer","buildReducer","finalCaseReducers","mapOrBuilderCallback","finalActionMatchers","finalDefaultCaseReducer","sM","frozenInitialState","caseReducers","cr","previousState","createReducer","reducerName","reducerDefinition","reducerDetails","createNotation","isAsyncThunkSliceReducerDefinition","maybeReducerWithPrepare","prepareCallback","isCaseReducerWithPrepareDefinition","handleNormalReducerDefinition","thunk","noop","handleThunkCaseReducerDefinition","selectSelf","injectedSelectorCache","_reducer","makeSelectorProps","reducerPath2","selectSlice","getSelectors","selectorCache","WeakMap","selectors","injectInto","injectable","pathOpt","newReducerPath","inject","buildCreateSlice","alm","getListenerEntryPropsFrom","predicate","effect","expected","assertFunction","createListenerEntry","unsubscribe","addListener","removeListener","React","ContextKey","gT","globalThis","getContext","contextMap","realContext","ReactReduxContext","createReduxContextHook","useReduxContext","refEquality","createSelectorHook","useReduxContext2","useSelector2","equalityFnOrOptions","equalityFn","devModeChecks","subscription","getServerState","stabilityCheck","identityFunctionCheck","selectedState","addNestedSub","createStoreHook","useStore2","getOwnPropertyNames","useStore","createDispatchHook","useDispatch2","randomString","actionTypes_default","INIT","REPLACE","PROBE_UNKNOWN_ACTION","reducerKeys","finalReducers","finalReducerKeys","shapeAssertionError","assertReducerShape","hasChanged","nextState","previousStateForKey","nextStateForKey","compose","funcs","isAction","isPlainObject","ensureIsArray","item","Ref","WeakRef","deref","UNTERMINATED","TERMINATED","createCacheNode","weakMapMemoize","fnNode","resultEqualityCheck","lastResult","resultsCount","memoized","cacheNode","objectCache","objectNode","primitiveCache","primitiveNode","terminatedNode","lastResultValue","clearCache","resetResultsCount","createSelectorCreator","memoizeOrOptions","memoizeOptionsFromArgs","createSelectorCreatorOptions","memoize","memoizeOptions","createSelectorArgs","recomputations","dependencyRecomputations","directlyPassedOptions","resultFunc","errorMessage","assertIsFunction","combinedOptions","argsMemoize","argsMemoizeOptions","finalMemoizeOptions","finalArgsMemoizeOptions","dependencies","itemTypes","assertIsArrayOfFunctions","getDependencies","memoizedResultFunc","inputSelectorResults","inputSelectorArgs","collectInputSelectorResults","resetDependencyRecomputations","resetRecomputations","createStructuredSelector","inputSelectorsObject","selectorCreator","assertIsObject","inputSelectorKeys","composition","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","getter","__esModule","definition","toStringTag","scriptUrl","importScripts","location","currentScript","scripts","getElementsByTagName","PrivacyDisclaimer","tabIndex","getFormById","getFormControlsByFormId","getFormValuesByFormId","valuesObj","getControlValueByName","getControlTouchedByName","FormContext","handleSubmit","isSubmitted","isValid","errors","Provider","Consumer","useFormContext","useFormControl","isRegistered","onInput","onBlur","useCharacterLimit","controlName","debouncedSendAssertive","validateLimit","_reachedCharacterWarning","_remainingChars","remainingChars","reachedCharacterWarning","reachedCharacterLimit","hasCharacterLimit","characterLimit","useEntryTextTranslation","placeholder","label","labelClass","AbortTransactionButton","abortTransaction","clearEntryAbortTransaction","useEntryAbortTransaction","topicName","topicFallbackMessage","description","hasFocus","isCarouselItem","cardRef","descriptionId","isMounted","CardActionComponent","emitCardEvent","handleClick","actionProps","href","link","rel","newTab","blur","CarouselMessageSlide","slide","items","role","total","CardComponent","CarouselControls","currentIndex","onChange","itemCount","handlePrevious","handleNext","CarouselPagination","getItemKey","getItemLabel","handlePaginate","slideIndex","dataset","nextIndex","min","max","defaultGetItemKey","prefix","defaultGetItemLabel","preventScroll","scrollLeft","CarouselComponent","originalIndex","carouselItemsId","setCurrentIndex","slideRefs","fill","isMountRef","onChangeRef","onScroll","style","width","left","controlId","mapCategoryToClass","SuggestionsItem","categories","question","hasIcon","mappedClassNames","SuggestionsList","givenClassName","suggestions","onClickSuggestion","eventId","linkId","EventDivider","childrenHTML","providedClassName","graphicSrc","graphicType","iconName","iconSize","iconClassName","dividerType","hasGraphic","icon","dividerTypes","Variants","Divider","NewTranslationDivider","toggleTranslations","dateFormatOptions","month","day","year","timeFormatOptions","hour","minute","TimeIndicator","time","timeUntilMidnight","eventDate","midnight","fullDateTime","DateTimeFormat","relativeDate","useFormattedDate","candidateSelectors","candidateSelector","NoElement","Element","msMatchesSelector","webkitMatchesSelector","getRootNode","_element$getRootNode","ownerDocument","isInert","lookUp","_node$getAttribute","inertAtt","getCandidates","includeContainer","candidates","unshift","getCandidatesIteratively","elements","elementsToCheck","shift","tagName","assigned","assignedElements","nestedCandidates","scopeParent","shadowRoot","getShadowRoot","validShadowRoot","shadowRootFilter","_nestedCandidates","hasTabIndex","getTabIndex","_node$getAttribute2","attValue","isContentEditable","sortOrderedTabbables","documentOrder","isInput","isZeroArea","_node$getBoundingClie","getBoundingClientRect","height","isNodeMatchingSelectorFocusable","disabled","isHiddenInput","_ref","displayCheck","getComputedStyle","nodeUnderDetails","parentElement","originalNode","rootNode","assignedSlot","host","_nodeRoot","_nodeRootHost","_nodeRootHost$ownerDo","_node$ownerDocument","nodeRoot","nodeRootHost","attached","_nodeRoot2","_nodeRootHost2","_nodeRootHost2$ownerD","isNodeAttached","getClientRects","isHidden","isDetailsWithSummary","isDisabledFromFieldset","isNodeMatchingSelectorTabbable","isRadio","radioSet","radioScope","queryRadios","CSS","escape","checked","nodes","getCheckedRadio","isTabbableRadio","isNonTabbableRadio","isValidShadowRootTabbable","shadowHostNode","sortByOrder","regularTabbables","orderedTabbables","isScope","candidateTabindex","getSortOrderTabIndex","content","sortable","isTabbable","focusableCandidateSelector","isFocusable","_objectSpread2","input","hint","prim","_toPrimitive","_toPropertyKey","isTabEvent","isKeyForward","shiftKey","isKeyBackward","delay","findIndex","valueOrHandler","getActualTarget","composedPath","internalTrapStack","createFocusTrap","userOptions","trap","doc","trapStack","returnFocusOnDeactivate","escapeDeactivates","delayInitialFocus","containers","containerGroups","tabbableGroups","nodeFocusedBeforeActivation","mostRecentlyFocusedNode","paused","delayInitialFocusTimer","recentNavEvent","getOption","configOverrideOptions","configOptionName","findContainerIndex","container","tabbableNodes","getNodeForOption","optionValue","_len2","_key2","querySelector","getInitialFocusNode","tabbableOptions","firstTabbableGroup","firstTabbableNode","updateTabbableNodes","tabbable","focusableNodes","focusable","lastTabbableNode","firstDomTabbableNode","lastDomTabbableNode","posTabIndexesFound","nextTabbableNode","forward","nodeIdx","group","getActiveElement","tryFocus","isSelectableInput","getReturnFocusNode","previousActiveElement","findNextNavNode","_ref2","_ref2$isBackward","isBackward","destinationNode","containerIndex","containerGroup","startOfGroupIndex","_ref3","destinationGroupIndex","destinationGroup","lastOfGroupIndex","_ref4","_destinationGroupIndex","_destinationGroup","checkPointerDown","clickOutsideDeactivates","deactivate","returnFocus","allowOutsideClick","preventDefault","checkFocusIn","targetContained","Document","nextNode","stopImmediatePropagation","navAcrossContainers","mruContainerIdx","mruTabIdx","checkKey","checkKeyNav","checkClick","addListeners","activeTrap","pause","trapIndex","activeFocusTraps","capture","passive","removeListeners","mutationObserver","MutationObserver","mutations","mutation","removedNodes","updateObservedNodes","subtree","childList","activate","activateOptions","onActivate","onPostActivate","checkCanFocusTrap","finishActivation","deactivateOptions","onDeactivate","onPostDeactivate","checkCanReturnFocus","unpause","finishDeactivation","pauseOptions","onPause","onPostPause","unpauseOptions","onUnpause","onPostUnpause","updateContainerElements","containerElements","elementsAsArray","Modal","onClose","ariaLabel","ariaLabelledBy","fallBackFocusRef","modalId","modalContainer","focusTrap","containerIsSet","setContainerIsSet","initialFocus","disposeAriaHider","bodyElement","modalRenderFn","els","Lightbox","onCloseHandler","zIndex","onActivityHandler","onFrameClickHandler","stopPropagation","onFloatClickHandler","onMouseDown","onKeyDown","onTouchStart","onMouseMove","onWheel","onPointerDown","onPointerMove","getModalContent","ImageLightbox","showLightBox","setShowLightBox","onOpenLightboxHandler","onCloseLightboxHandler","Text","eventClick","useEventLinkClickHandler","containerProps","PROCESSING_IMAGE","UploadedImage","img","UploadContent","eventTypeMapping","choice_prompt","Image","isZoomable","showLighbox","setShowLightbox","onLoad","handleOnLoad","Splash","Video","allow","allowFullScreen","Upload","currentFileId","sessionStorage","getItem","useImageFromStorage","Cta","onClickHandler","buttonLink","buttonNewTab","carousel","CarouselMessage","slides","cards","ItemComponent","card","CardMessage","Translation","variables","Participant","service_data","ConversationSuggestions","isExpanded","setIsExpanded","useSuggestions","headingText","footerText","hasLastTransactionEvent","transactionLast","faqId","faqQuestion","ComponentFilter","resolvedComponents","ComponentContext","components","componentType","SubComponent","newParticipant","eventRefs","unreadIds","readIds","Loader","Events","prevParticipant","participantChanged","currentParticipant","debouncedIsLoading","useDebounce","debouncedValue","setDebouncedValue","timeoutRef","focusSkiplinkTarget","Prompt","baseClassName","containerHeadingId","IdleDetachWarning","sendActivity","countDownComplete","transferChat","ResumeConversationPrompt","currentAgentName","continueChatHandler","useSeamlyTyping","typingTimerId","sendEndTypingTimerId","isTyping","typingIntervalId","clearInterval","sendTypingState","currentMessage","setInterval","useSeamlyEntry","defaultEntry","entryOptions","entryOptionsOverride","activeEntry","activeEntryOptions","dispatchBlockAutoEntrySwitch","dispatchActiveEntryType","dispatchUserEntryType","cancelEntrySelection","FormProvider","onError","onSubmit","validationSchema","setIsSubmitted","externalErrors","setExternalErrors","validationIsValid","validationErrors","schema","validations","validationsArr","compareValue","validate","useValidations","setError","ariaDisabled","submitter","contextValue","disableValidationClasses","useForm","formClasses","setIsAvailable","timerId","contentHint","labelText","validity","htmlFor","ariaDescribedBy","field","describedByIds","TextEntryForm","skipLinkId","handleKeyUp","handleFocus","noValidate","autocomplete","onKeyUp","onFocus","textEntryControlName","TextEntry","focusSkipLinkTarget","UploadProgress","getValidator","validateFileSize","fileList","fileListObjectIsNotEmpty","fileListObj","isEmailString","trimmedVal","isNotEmptyString","FileInput","outputText","accept","focusWithin","setFocusWithin","errorId","contentHintId","outputId","handleBlur","handleChange","customEvent","files","FileInputForm","skiplinkId","onClickCancel","hasFile","selectedFileName","Form","formName","fileInputName","cancelButtonRef","canUpload","hasServerError","useSingleFileUpload","currentUpload","notificationId","prevIsComplete","contentHintText","prevContentHintText","handleOnClickCancel","useTimeout","savedCallback","childIsVNode","transitionClasses","in","visuallyHidden","transitionClassesArray","transitionStartStates","notRendered","rendered","transitionStartState","onInTransitionComplete","onOutTransitionComplete","prevIsActive","isVisuallyHidden","activeTransitionClasses","setActiveTransitionClasses","inState","setInState","transitionOutAfter","transitionIn","onInTransitionCompleteHandler","onOutTransitionCompleteHandler","renderChildren","activeTimeout","activeRaf","cancelAnimationFrame","childClassName","cleanClasses","cl","UploadToggle","showUploadButton","setShowUploadButton","prevServiceAllowsUploads","uploadButton","hasAgent","focusFn","InOutTransition","EntryContainer","entryContainer","showCountdown","setShowCountDown","hasResumeConversationPrompt","showResumeConversationPrompt","setShowResumeConversationPrompt","containedFocus","entryComponents","setEntryComponents","renderEntry","setRenderEntry","EntryComponent","AgentInfo","displaySubtitle","Suggestions","isAside","sectionId","eventBody","prevSuggestions","prevHasSuggestions","previousRenderedSuggestions","hasSuggestions","hideSuggestions","prevHideSuggestions","showSuggestionsContainer","renderedSuggestions","suggestionsClassNames","politeText","ContainerElement","forwardedRef","handleClose","closeButtonText","srCloseButtonText","headingId","srButtonText","TranslationProposal","srDismissButtonText","titleLabel","buttonLabel","TranslationStatus","itemClassName","describedById","primaryLanguages","remainingLanguages","isOriginal","isChecked","selectedIdx","onCancel","cancelButtonText","disableButtonFocusing","position","horizontal","vertical","mainHeadingId","closePanel","onCancelHandler","HTMLElement","btn","TranslationsOptionsButton","menuIsOpen","setMenuIsOpen","toggleButton","toggleButtonId","TranscriptForm","Input","mapper","Transcript","errorClass","setErrorClass","transcriptDescriptionId","emailAddress","handleError","OptionsFrame","Options","prevRenderOption","RenderOption","OptionsButton","focusOutDelayTimeoutID","optionsLength","menuItemButtons","prevMenuIsOpen","multiMenu","firstOption","firstOptionName","firstActiveOptionIndex","focusIndex","onfocusout","onFocusOutHandler","onfocusin","onFocusInHandler","onMenuItemKeyDownHandler","newIndex","onKeyPress","onKeyPressHandler","fromCharCode","charCode","foundIndex","onMenuItemClickHandler","AppOptions","isTranslationsAvailable","localeNativeName","openButtonText","hasLanguage","scrollToRef","unreadCount","selectUnreadEvents","selectLastUnreadEvent","selectUnreadEventIds","selectShowNotifications","hasScrolledToBottom","setHasScrolledToBottom","scrollHeight","scrollTop","clientHeight","hasScrolledUp","abs","scrollToBottom","scrollTo","top","behavior","offsetTop","CollapseButton","Interrupt","seamlyCommands","isExpiredError","ChatScrollProvider","Header","onCloseChat","closeButton","CollapsedChatMessage","CollapsedChatMessages","PreChatMessages","ContinueChatMessages","continueChatText","continueChatEvent","ButtonIcon","isActiveConversation","WindowOpenButton","getDelay","init","hasNotificationSupport","Notification","ViewComponentsMap","AppView","Chat","ChatFrame","Conversation","inline","InlineView","sendNotification","useNotification","permission","setPermission","setVisibilityState","showNotifications","requestPermission","notificationPermission","permissionGranted","visibilityStateHidden","AudioPlay","Audio","beep","play","notification","onclick","handleVisibilityChange","lastUnreadEvent","prevLastUnreadEventId","notificationBody","html","tmp","innerHTML","innerText","stripHtml","ViewComponent","containerElementRef","blockLang"],"sourceRoot":""}
|