@opencx/widget-react-headless 4.0.13 → 4.0.15
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/dist/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +62 -70
- package/dist/index.js.map +1 -1
- package/dist/src/WidgetProvider.d.ts.map +1 -1
- package/dist/src/index.d.ts +0 -1
- package/dist/src/index.d.ts.map +1 -1
- package/package.json +4 -4
- package/dist/src/hooks/usePreludeData.d.ts +0 -86
- package/dist/src/hooks/usePreludeData.d.ts.map +0 -1
package/dist/index.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=require("react"),
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=require("react"),v=require("@opencx/widget-core"),M=require("uuid"),F="4.0.15";class R{constructor(t){this.components=[];const{components:n}=t;if(n&&n.forEach(o=>this.register(o)),this.components.length===0)throw new Error("No components registered");if(!this.get("fallback"))throw new Error("No fallback component registered")}register(t){const n=this.components.findIndex(o=>o.key===t.key);return n!==-1?this.components[n]=t:this.components.push(t),this}get(t){const n=this.components.find(o=>o.key.toUpperCase()===t.toUpperCase());return n||null}getComponent(t){var n;return(n=this.get(t))==null?void 0:n.component}}const y=i.createContext(null);function U({options:e,children:t,components:n,storage:o,loadingComponent:u}){const a=i.useRef(null),l=i.useRef(!1),[g,f]=i.useState(null),c=i.useMemo(()=>new R({components:n}),[n]);return i.useEffect(()=>{l.current||(l.current=!0,v.WidgetCtx.initialize({config:e,storage:o}).then(f).catch(console.error))},[]),g?i.createElement(y.Provider,{value:{widgetCtx:g,config:e,components:n,componentStore:c,version:F,contentIframeRef:a}},t):u||null}function p(){const e=i.useContext(y);if(!e)throw new Error("useWidget must be used within a WidgetProvider");return e}function w(){const{config:e}=p();return e}function m(e){return i.useSyncExternalStore(e.subscribe,e.get,e.get)}function W(){const{widgetCtx:e}=p();return{contactState:m(e.contactCtx.state),createUnverifiedContact:e.contactCtx.createUnverifiedContact}}function A(){const[e,t]=i.useState("ltr");return i.useEffect(()=>{const n=()=>{typeof document>"u"||t(window.getComputedStyle((window.top||window).document.body).direction)};n();const o=new MutationObserver(n);return o.observe(document.documentElement,{attributes:!0,attributeFilter:["dir"]}),o.observe(document.body,{attributes:!0,attributeFilter:["dir"]}),window.addEventListener("languagechange",n),()=>{o.disconnect(),window.removeEventListener("languagechange",n)}},[]),{dir:e}}function h(){const{widgetCtx:e}=p();return{messagesState:m(e.messageCtx.state),sendMessage:e.messageCtx.sendMessage}}function x(){const{widgetCtx:e}=p(),{oneOpenSessionAllowed:t}=w(),n=m(e.sessionCtx.sessionState),o=m(e.sessionCtx.sessionsState),{openSessions:u,closedSessions:a}=i.useMemo(()=>({openSessions:o.data.filter(g=>g.isOpened===!0),closedSessions:o.data.filter(g=>g.isOpened===!1)}),[o.data]),l=i.useMemo(()=>t?u.length===0:!0,[t,u.length]);return{sessionState:n,sessionsState:o,loadMoreSessions:e.sessionCtx.loadMoreSessions,resolveSession:e.sessionCtx.resolveSession,createStateCheckpoint:e.sessionCtx.createStateCheckpoint,openSessions:u,closedSessions:a,canCreateNewSession:l}}function P(){var l;const{sessionState:e}=x(),{messagesState:t}=h(),n=((l=e.session)==null?void 0:l.assignee.kind)==="ai",o=t.messages.length>0?t.messages[t.messages.length-1]:null,u=(o==null?void 0:o.type)==="USER";return{isAwaitingBotReply:(n||e.isCreatingSession)&&(t.isSendingMessage||u)}}function T(){const{widgetCtx:e}=p();return{routerState:m(e.routerCtx.state),toSessionsScreen:e.routerCtx.toSessionsScreen,toChatScreen:e.routerCtx.toChatScreen}}const S=new Map;function k(){const[e,t]=i.useState([]),{widgetCtx:{api:n}}=p();function o(s){const r=s.map(d=>({file:d,id:M.v4(),status:"pending",progress:0}));t(d=>[...d,...r]),r.forEach(l)}function u(s,r){t(d=>d.map(C=>C.id===s?{...C,...r}:C))}function a(s){t(r=>r.filter(d=>d.id!==s))}const l=async s=>{const r=new AbortController;S.set(s.id,r);try{t(C=>C.map(b=>b.id===s.id?{...b,status:"uploading",progress:0}:b));const d=await n.uploadFile({file:s.file,abortSignal:r.signal,onProgress:C=>{u(s.id,{progress:C})}});u(s.id,{status:"success",fileUrl:d.fileUrl,progress:100})}catch(d){r.signal.aborted||u(s.id,{status:"error",error:d instanceof Error?d.message:"Upload failed",progress:0})}finally{S.delete(s.id)}},g=s=>{const r=S.get(s);r&&(r.abort(),S.delete(s)),a(s)},f=i.useMemo(()=>e.filter(s=>s.status==="success"&&s.fileUrl),[e]);function c(){S.forEach(s=>s.abort()),S.clear(),t([])}return i.useEffect(()=>()=>{S.forEach(s=>s.abort()),S.clear()},[]),{allFiles:e,appendFiles:o,handleCancelUpload:g,successFiles:f,emptyTheFiles:c,getFileById:s=>e.find(r=>r.id===s),getUploadProgress:s=>{var r;return((r=e.find(d=>d.id===s))==null?void 0:r.progress)??0},getUploadStatus:s=>{var r;return(r=e.find(d=>d.id===s))==null?void 0:r.status},hasErrors:e.some(s=>s.status==="error"),isUploading:e.some(s=>s.status==="uploading")}}const E=i.createContext(null);function O({children:e}){const t=w(),[n,o]=i.useState(()=>t.inline?!0:t.isOpen??!1);return i.useEffect(()=>{o(u=>t.isOpen??u)},[t.isOpen]),i.useEffect(()=>{const u=t.openAfterNSeconds;if(typeof u!="number"||isNaN(u))return;const a=setTimeout(()=>o(!0),u*1e3);return()=>clearTimeout(a)},[t.openAfterNSeconds]),i.createElement(E.Provider,{value:{isOpen:n,setIsOpen:o}},e)}function q(){const e=i.useContext(E);if(!e)throw new Error("useWidgetTrigger must be used within a WidgetTriggerProvider");return e}function N(){var g,f;const{widgetCtx:e}=p(),{modesComponents:t}=w(),{sessionState:n}=x(),o=e.modes,u=(g=n.session)==null?void 0:g.modeId,a=o.find(c=>c.id===u),l=(f=t==null?void 0:t.find(c=>{var s,r;return[(a==null?void 0:a.id)||"",((s=a==null?void 0:a.name)==null?void 0:s.toLowerCase())||"",((r=a==null?void 0:a.slug)==null?void 0:r.toLowerCase())||""].includes(c.key.toLowerCase())}))==null?void 0:f.component;return{modes:o,modesComponents:t,activeModeId:u,activeMode:a,Component:l}}function B(){const{widgetCtx:e}=p(),{messagesState:{messages:t}}=h(),{csatRequestedMessage:n,isCsatRequested:o,csatSubmittedMessage:u,isCsatSubmitted:a,submittedScore:l,submittedFeedback:g}=i.useMemo(()=>{const f=t.find(s=>s.type==="SYSTEM"&&s.subtype==="csat_requested"),c=t.findLast(s=>s.type==="SYSTEM"&&s.subtype==="csat_submitted");return{csatRequestedMessage:f,isCsatRequested:!!f&&!c,csatSubmittedMessage:c,isCsatSubmitted:!!c,submittedScore:c==null?void 0:c.data.payload.score,submittedFeedback:c==null?void 0:c.data.payload.feedback}},[t]);return{submitCsat:e.csatCtx.submitCsat,csatRequestedMessage:n,isCsatRequested:o,csatSubmittedMessage:u,isCsatSubmitted:a,submittedScore:l,submittedFeedback:g}}exports.WidgetProvider=U;exports.WidgetTriggerProvider=O;exports.useConfig=w;exports.useContact=W;exports.useCsat=B;exports.useDocumentDir=A;exports.useIsAwaitingBotReply=P;exports.useMessages=h;exports.useModes=N;exports.usePrimitiveState=m;exports.useSessions=x;exports.useUploadFiles=k;exports.useWidget=p;exports.useWidgetRouter=T;exports.useWidgetTrigger=q;
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
package/dist/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs","sources":["../src/ComponentRegistry.ts","../src/WidgetProvider.tsx","../src/hooks/useConfig.ts","../src/hooks/usePrimitiveState.ts","../src/hooks/useContact.ts","../src/hooks/useDocumentDir.ts","../src/hooks/useMessages.ts","../src/hooks/useSessions.ts","../src/hooks/useIsAwaitingBotReply.ts","../src/hooks/usePreludeData.ts","../src/hooks/useWidgetRouter.ts","../src/hooks/useUploadFiles.ts","../src/hooks/useWidgetTrigger.tsx","../src/hooks/useModes.ts","../src/hooks/useCsat.ts"],"sourcesContent":["import type { WidgetComponentKey } from '@opencx/widget-core';\nimport type { WidgetComponentType } from './types/components';\n\nexport class ComponentRegistry {\n components: WidgetComponentType[] = [];\n\n constructor(opts: { components?: WidgetComponentType[] }) {\n const { components } = opts;\n\n if (components) {\n components.forEach((c) => this.register(c));\n }\n\n if (this.components.length === 0) {\n throw new Error('No components registered');\n }\n if (!this.get('fallback')) {\n throw new Error('No fallback component registered');\n }\n }\n\n // TODO test that this registers or replaces the component\n register(component: WidgetComponentType) {\n // Replace the key if it already exists\n const index = this.components.findIndex((c) => c.key === component.key);\n if (index !== -1) {\n this.components[index] = component;\n } else {\n this.components.push(component);\n }\n return this;\n }\n\n private get(key: WidgetComponentKey) {\n const c = this.components.find(\n (c) => c.key.toUpperCase() === key.toUpperCase(),\n );\n if (c) return c;\n return null;\n }\n\n public getComponent(key: string) {\n return this.get(key)?.component;\n }\n}\n","import React, {\n createContext,\n useContext,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { version } from '../package.json';\nimport { type ExternalStorage, type WidgetConfig, WidgetCtx } from '@opencx/widget-core';\nimport { ComponentRegistry } from './ComponentRegistry';\nimport type { WidgetComponentType } from './types/components';\n\ninterface WidgetProviderValue {\n widgetCtx: WidgetCtx;\n config: WidgetConfig;\n components?: WidgetComponentType[];\n componentStore: ComponentRegistry;\n version: string;\n contentIframeRef?: React.MutableRefObject<HTMLIFrameElement | null>;\n}\n\nconst context = createContext<WidgetProviderValue | null>(null);\n\nexport function WidgetProvider({\n options: config,\n children,\n components,\n storage,\n loadingComponent,\n}: {\n options: WidgetConfig;\n children: React.ReactNode;\n components?: WidgetComponentType[];\n storage?: ExternalStorage;\n /**\n * Custom loading component while the widget is initializing\n * Not to be confused with the `loading` custom component which renders when the bot's reply is pending\n */\n loadingComponent?: React.ReactNode;\n}) {\n const contentIframeRef = useRef<HTMLIFrameElement | null>(null);\n\n const didInitialize = useRef(false);\n const [widgetCtx, setWidgetCtx] = useState<WidgetCtx | null>(null);\n\n const componentStore = useMemo(\n () =>\n new ComponentRegistry({\n components: components,\n }),\n [components],\n );\n\n useEffect(() => {\n if (didInitialize.current) return;\n didInitialize.current = true;\n\n WidgetCtx.initialize({ config, storage }).then(setWidgetCtx);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n if (!widgetCtx) {\n return loadingComponent || null;\n }\n\n return (\n <context.Provider\n value={{\n widgetCtx,\n config,\n components,\n componentStore,\n version,\n contentIframeRef,\n }}\n >\n {children}\n </context.Provider>\n );\n}\n\nexport function useWidget() {\n const ctx = useContext(context);\n if (!ctx) {\n throw new Error('useWidget must be used within a WidgetProvider');\n }\n return ctx;\n}\n","import { useWidget } from '../WidgetProvider';\n\nexport function useConfig() {\n const { config } = useWidget();\n\n return config;\n}\n","import { useSyncExternalStore } from 'react';\nimport type { PrimitiveState } from '@opencx/widget-core';\n\nexport function usePrimitiveState<T>(p: PrimitiveState<T>) {\n return useSyncExternalStore(p.subscribe, p.get, p.get);\n}\n","import { useWidget } from '../WidgetProvider';\nimport { usePrimitiveState } from './usePrimitiveState';\n\nexport function useContact() {\n const { widgetCtx } = useWidget();\n const contactState = usePrimitiveState(widgetCtx.contactCtx.state);\n\n return {\n contactState,\n createUnverifiedContact: widgetCtx.contactCtx.createUnverifiedContact,\n };\n}\n","import { useEffect, useState } from 'react';\nimport type { StringOrLiteral } from '@opencx/widget-core';\n\nexport function useDocumentDir() {\n const [dir, setDir] = useState<StringOrLiteral<'ltr' | 'rtl'>>('ltr');\n\n useEffect(() => {\n const updateDir = () => {\n if (typeof document === 'undefined') return;\n setDir(\n window.getComputedStyle((window.top || window).document.body).direction,\n );\n };\n\n // Set initial direction\n updateDir();\n\n // Watch for direction changes on both document and documentElement\n const observer = new MutationObserver(updateDir);\n\n // Observe both document and documentElement\n observer.observe(document.documentElement, {\n attributes: true,\n attributeFilter: ['dir'],\n });\n\n observer.observe(document.body, {\n attributes: true,\n attributeFilter: ['dir'],\n });\n\n // Add event listener for dynamic changes\n window.addEventListener('languagechange', updateDir);\n\n return () => {\n observer.disconnect();\n window.removeEventListener('languagechange', updateDir);\n };\n }, []);\n\n return { dir };\n}\n","import { usePrimitiveState } from './usePrimitiveState';\nimport { useWidget } from '../WidgetProvider';\n\nexport function useMessages() {\n const { widgetCtx } = useWidget();\n const messagesState = usePrimitiveState(widgetCtx.messageCtx.state);\n\n return { messagesState, sendMessage: widgetCtx.messageCtx.sendMessage };\n}\n","import { useMemo } from 'react';\nimport { useWidget } from '../WidgetProvider';\nimport { usePrimitiveState } from './usePrimitiveState';\nimport { useConfig } from './useConfig';\n\nexport function useSessions() {\n const { widgetCtx } = useWidget();\n const { oneOpenSessionAllowed } = useConfig();\n const sessionState = usePrimitiveState(widgetCtx.sessionCtx.sessionState);\n const sessionsState = usePrimitiveState(widgetCtx.sessionCtx.sessionsState);\n\n const { openSessions, closedSessions } = useMemo(() => {\n return {\n openSessions: sessionsState.data.filter((s) => s.isOpened === true),\n closedSessions: sessionsState.data.filter((s) => s.isOpened === false),\n };\n }, [sessionsState.data]);\n\n const canCreateNewSession = useMemo(() => {\n if (oneOpenSessionAllowed) {\n return openSessions.length === 0;\n }\n return true;\n }, [oneOpenSessionAllowed, openSessions.length]);\n\n return {\n sessionState,\n sessionsState,\n loadMoreSessions: widgetCtx.sessionCtx.loadMoreSessions,\n resolveSession: widgetCtx.sessionCtx.resolveSession,\n createStateCheckpoint: widgetCtx.sessionCtx.createStateCheckpoint,\n openSessions,\n closedSessions,\n canCreateNewSession,\n };\n}\n","import { useMessages } from './useMessages';\nimport { useSessions } from './useSessions';\n\nexport function useIsAwaitingBotReply() {\n const { sessionState } = useSessions();\n const { messagesState } = useMessages();\n\n const isSessionAssignedToAI = sessionState.session?.assignee.kind === 'ai';\n // This check is useful in cases where the user might navigate in and out of a chat, and `isSendingMessage` is reset back to its default value\n const lastMessage =\n messagesState.messages.length > 0\n ? messagesState.messages[messagesState.messages.length - 1]\n : null;\n const isLastMessageAUserMessage = lastMessage?.type === 'USER';\n\n const isAwaitingBotReply =\n (isSessionAssignedToAI || sessionState.isCreatingSession) &&\n (messagesState.isSendingMessage || isLastMessageAUserMessage);\n\n return { isAwaitingBotReply };\n}\n","import useSWR from 'swr';\nimport { useWidget } from '../WidgetProvider';\n\nfunction usePreludeData() {\n const { widgetCtx } = useWidget();\n\n // TODO remove swr dependency\n return useSWR([widgetCtx.config.token], widgetCtx.api.widgetPrelude, {\n revalidateOnFocus: false,\n });\n}\n\nexport { usePreludeData };\n","import { useWidget } from '../WidgetProvider';\nimport { usePrimitiveState } from './usePrimitiveState';\n\nexport function useWidgetRouter() {\n const { widgetCtx } = useWidget();\n\n const routerState = usePrimitiveState(widgetCtx.routerCtx.state);\n\n return {\n routerState,\n toSessionsScreen: widgetCtx.routerCtx.toSessionsScreen,\n toChatScreen: widgetCtx.routerCtx.toChatScreen,\n };\n}\n","import { useEffect, useMemo, useState } from 'react';\nimport { useWidget } from '../WidgetProvider';\nimport { v4 } from 'uuid';\n\nconst uploadAbortControllers: Map<string, AbortController> = new Map();\n\ninterface FileWithProgress {\n status: 'pending' | 'uploading' | 'success' | 'error';\n id: string;\n file: File;\n fileUrl?: string;\n progress: number;\n error?: string;\n}\n\nfunction useUploadFiles() {\n const [files, setFiles] = useState<FileWithProgress[]>([]);\n const {\n widgetCtx: { api },\n } = useWidget();\n function appendFiles(files: File[]) {\n const newFiles = files.map((file) => ({\n file,\n id: v4(),\n status: 'pending' as const,\n progress: 0,\n }));\n\n setFiles((prev) => [...prev, ...newFiles]);\n newFiles.forEach(uploadFile);\n }\n\n function updateFileById(id: string, update: Partial<FileWithProgress>) {\n setFiles((prev) =>\n prev.map((f) => (f.id === id ? { ...f, ...update } : f)),\n );\n }\n\n function removeFileById(id: string) {\n setFiles((prev) => prev.filter((f) => f.id !== id));\n }\n\n const uploadFile = async (fileItem: FileWithProgress) => {\n const controller = new AbortController();\n uploadAbortControllers.set(fileItem.id, controller);\n\n try {\n setFiles((prev) =>\n prev.map((f) =>\n f.id === fileItem.id ? { ...f, status: 'uploading', progress: 0 } : f,\n ),\n );\n\n const response = await api.uploadFile({\n file: fileItem.file,\n abortSignal: controller.signal,\n onProgress: (percentage) => {\n updateFileById(fileItem.id, { progress: percentage });\n },\n });\n\n updateFileById(fileItem.id, {\n status: 'success',\n fileUrl: response.fileUrl,\n progress: 100,\n });\n } catch (error) {\n if (!controller.signal.aborted) {\n updateFileById(fileItem.id, {\n status: 'error',\n error: error instanceof Error ? error.message : 'Upload failed',\n progress: 0,\n });\n }\n } finally {\n uploadAbortControllers.delete(fileItem.id);\n }\n };\n\n const handleCancelUpload = (fileId: string) => {\n const controller = uploadAbortControllers.get(fileId);\n if (controller) {\n controller.abort();\n uploadAbortControllers.delete(fileId);\n }\n removeFileById(fileId);\n };\n\n const successFiles = useMemo(() => {\n return files.filter((f) => f.status === 'success' && f.fileUrl);\n }, [files]);\n\n function emptyTheFiles() {\n uploadAbortControllers.forEach((controller) => controller.abort());\n uploadAbortControllers.clear();\n setFiles([]);\n }\n\n useEffect(() => {\n return () => {\n uploadAbortControllers.forEach((controller) => controller.abort());\n uploadAbortControllers.clear();\n };\n }, []);\n\n return {\n allFiles: files,\n appendFiles,\n handleCancelUpload,\n successFiles,\n emptyTheFiles,\n getFileById: (id: string) => files.find((f) => f.id === id),\n getUploadProgress: (id: string) =>\n files.find((f) => f.id === id)?.progress ?? 0,\n getUploadStatus: (id: string) => files.find((f) => f.id === id)?.status,\n hasErrors: files.some((f) => f.status === 'error'),\n isUploading: files.some((f) => f.status === 'uploading'),\n };\n}\n\nexport { useUploadFiles, type FileWithProgress };\n","import React, {\n createContext,\n useContext,\n useEffect,\n useState,\n type Dispatch,\n type ReactNode,\n type SetStateAction,\n} from 'react';\nimport { useConfig } from './useConfig';\n\ntype WidgetTriggerCtx = {\n isOpen: boolean;\n setIsOpen: Dispatch<SetStateAction<boolean>>;\n};\n\nconst context = createContext<WidgetTriggerCtx | null>(null);\n\nexport function WidgetTriggerProvider({ children }: { children: ReactNode }) {\n const config = useConfig();\n const [isOpen, setIsOpen] = useState(() => {\n if (config.inline) return true;\n return config.isOpen ?? false;\n });\n\n useEffect(() => {\n setIsOpen((prev) => config.isOpen ?? prev);\n }, [config.isOpen]);\n\n useEffect(() => {\n const openAfterNSeconds = config.openAfterNSeconds;\n if (typeof openAfterNSeconds !== 'number' || isNaN(openAfterNSeconds))\n return;\n\n const timeout = setTimeout(() => setIsOpen(true), openAfterNSeconds * 1000);\n\n return () => clearTimeout(timeout);\n }, [config.openAfterNSeconds]);\n\n return (\n <context.Provider value={{ isOpen, setIsOpen }}>\n {children}\n </context.Provider>\n );\n}\n\nexport function useWidgetTrigger() {\n const ctx = useContext(context);\n if (!ctx) {\n throw new Error(\n 'useWidgetTrigger must be used within a WidgetTriggerProvider',\n );\n }\n return ctx;\n}\n","import { useWidget } from '../WidgetProvider';\nimport { useConfig } from './useConfig';\nimport { useSessions } from './useSessions';\n\nexport function useModes() {\n const { widgetCtx } = useWidget();\n const { modesComponents } = useConfig();\n const { sessionState } = useSessions();\n\n const modes = widgetCtx.modes;\n const activeModeId = sessionState.session?.modeId;\n const activeMode = modes.find((mode) => mode.id === activeModeId);\n\n const Component = modesComponents?.find((modeComponent) =>\n [\n activeMode?.id || '',\n activeMode?.name?.toLowerCase() || '',\n activeMode?.slug?.toLowerCase() || '',\n ].includes(modeComponent.key.toLowerCase()),\n )?.component;\n\n return {\n modes,\n modesComponents,\n activeModeId,\n activeMode,\n Component,\n };\n}\n","import type {\n WidgetSystemMessage__CsatRequested,\n WidgetSystemMessage__CsatSubmitted,\n} from '@opencx/widget-core';\nimport { useMemo } from 'react';\nimport { useMessages } from './useMessages';\nimport { useWidget } from '../WidgetProvider';\n\nexport function useCsat() {\n const { widgetCtx } = useWidget();\n const {\n messagesState: { messages },\n } = useMessages();\n\n const {\n csatRequestedMessage,\n isCsatRequested,\n csatSubmittedMessage,\n isCsatSubmitted,\n submittedScore,\n submittedFeedback,\n } = useMemo(() => {\n const csatRequestedMessage = messages.find(\n (message): message is WidgetSystemMessage__CsatRequested =>\n message.type === 'SYSTEM' && message.subtype === 'csat_requested',\n );\n const csatSubmittedMessage = messages.findLast(\n (message): message is WidgetSystemMessage__CsatSubmitted =>\n message.type === 'SYSTEM' && message.subtype === 'csat_submitted',\n );\n\n return {\n csatRequestedMessage,\n isCsatRequested: !!csatRequestedMessage && !csatSubmittedMessage,\n csatSubmittedMessage,\n isCsatSubmitted: !!csatSubmittedMessage,\n submittedScore: csatSubmittedMessage?.data.payload.score,\n submittedFeedback: csatSubmittedMessage?.data.payload.feedback,\n };\n }, [messages]);\n\n return {\n submitCsat: widgetCtx.csatCtx.submitCsat,\n csatRequestedMessage,\n isCsatRequested,\n csatSubmittedMessage,\n isCsatSubmitted,\n submittedScore,\n submittedFeedback,\n };\n}\n"],"names":["ComponentRegistry","opts","components","c","component","index","key","_a","context","createContext","WidgetProvider","config","children","storage","loadingComponent","contentIframeRef","useRef","didInitialize","widgetCtx","setWidgetCtx","useState","componentStore","useMemo","useEffect","WidgetCtx","React","version","useWidget","ctx","useContext","useConfig","usePrimitiveState","p","useSyncExternalStore","useContact","useDocumentDir","dir","setDir","updateDir","observer","useMessages","useSessions","oneOpenSessionAllowed","sessionState","sessionsState","openSessions","closedSessions","s","canCreateNewSession","useIsAwaitingBotReply","messagesState","isSessionAssignedToAI","lastMessage","isLastMessageAUserMessage","usePreludeData","useSWR","useWidgetRouter","uploadAbortControllers","useUploadFiles","files","setFiles","api","appendFiles","newFiles","file","v4","prev","uploadFile","updateFileById","id","update","f","removeFileById","fileItem","controller","response","percentage","error","handleCancelUpload","fileId","successFiles","emptyTheFiles","WidgetTriggerProvider","isOpen","setIsOpen","openAfterNSeconds","timeout","useWidgetTrigger","useModes","modesComponents","modes","activeModeId","activeMode","mode","Component","_b","modeComponent","useCsat","messages","csatRequestedMessage","isCsatRequested","csatSubmittedMessage","isCsatSubmitted","submittedScore","submittedFeedback","message"],"mappings":"wLAGO,MAAMA,CAAkB,CAG7B,YAAYC,EAA8C,CAF1D,KAAA,WAAoC,CAAA,EAGlC,KAAM,CAAE,WAAAC,GAAeD,EAMvB,GAJIC,GACFA,EAAW,QAASC,GAAM,KAAK,SAASA,CAAC,CAAC,EAGxC,KAAK,WAAW,SAAW,EAC7B,MAAM,IAAI,MAAM,0BAA0B,EAE5C,GAAI,CAAC,KAAK,IAAI,UAAU,EACtB,MAAM,IAAI,MAAM,kCAAkC,CAEtD,CAGA,SAASC,EAAgC,CAEvC,MAAMC,EAAQ,KAAK,WAAW,UAAWF,GAAMA,EAAE,MAAQC,EAAU,GAAG,EACtE,OAAIC,IAAU,GACZ,KAAK,WAAWA,CAAK,EAAID,EAEzB,KAAK,WAAW,KAAKA,CAAS,EAEzB,IACT,CAEQ,IAAIE,EAAyB,CACnC,MAAMH,EAAI,KAAK,WAAW,KACvBA,GAAMA,EAAE,IAAI,YAAA,IAAkBG,EAAI,YAAA,CAAY,EAEjD,OAAIH,GACG,IACT,CAEO,aAAaG,EAAa,OAC/B,OAAOC,EAAA,KAAK,IAAID,CAAG,IAAZ,YAAAC,EAAe,SACxB,CACF,CCtBA,MAAMC,EAAUC,EAAAA,cAA0C,IAAI,EAEvD,SAASC,EAAe,CAC7B,QAASC,EACT,SAAAC,EACA,WAAAV,EACA,QAAAW,EACA,iBAAAC,CACF,EAUG,CACD,MAAMC,EAAmBC,EAAAA,OAAiC,IAAI,EAExDC,EAAgBD,EAAAA,OAAO,EAAK,EAC5B,CAACE,EAAWC,CAAY,EAAIC,EAAAA,SAA2B,IAAI,EAE3DC,EAAiBC,EAAAA,QACrB,IACE,IAAItB,EAAkB,CACpB,WAAAE,CAAA,CACD,EACH,CAACA,CAAU,CAAA,EAWb,OARAqB,EAAAA,UAAU,IAAM,CACVN,EAAc,UAClBA,EAAc,QAAU,GAExBO,EAAAA,UAAU,WAAW,CAAE,OAAAb,EAAQ,QAAAE,EAAS,EAAE,KAAKM,CAAY,EAE7D,EAAG,CAAA,CAAE,EAEAD,EAKHO,EAAA,cAACjB,EAAQ,SAAR,CACC,MAAO,CACL,UAAAU,EACA,OAAAP,EACA,WAAAT,EACA,eAAAmB,EACA,QAAAK,EACA,iBAAAX,CAAA,CACF,EAECH,CAAA,EAdIE,GAAoB,IAiB/B,CAEO,SAASa,GAAY,CAC1B,MAAMC,EAAMC,EAAAA,WAAWrB,CAAO,EAC9B,GAAI,CAACoB,EACH,MAAM,IAAI,MAAM,gDAAgD,EAElE,OAAOA,CACT,CCtFO,SAASE,GAAY,CAC1B,KAAM,CAAE,OAAAnB,CAAA,EAAWgB,EAAA,EAEnB,OAAOhB,CACT,CCHO,SAASoB,EAAqBC,EAAsB,CACzD,OAAOC,EAAAA,qBAAqBD,EAAE,UAAWA,EAAE,IAAKA,EAAE,GAAG,CACvD,CCFO,SAASE,GAAa,CAC3B,KAAM,CAAE,UAAAhB,CAAA,EAAcS,EAAA,EAGtB,MAAO,CACL,aAHmBI,EAAkBb,EAAU,WAAW,KAAK,EAI/D,wBAAyBA,EAAU,WAAW,uBAAA,CAElD,CCRO,SAASiB,GAAiB,CAC/B,KAAM,CAACC,EAAKC,CAAM,EAAIjB,EAAAA,SAAyC,KAAK,EAEpEG,OAAAA,EAAAA,UAAU,IAAM,CACd,MAAMe,EAAY,IAAM,CAClB,OAAO,SAAa,KACxBD,EACE,OAAO,kBAAkB,OAAO,KAAO,QAAQ,SAAS,IAAI,EAAE,SAAA,CAElE,EAGAC,EAAA,EAGA,MAAMC,EAAW,IAAI,iBAAiBD,CAAS,EAG/C,OAAAC,EAAS,QAAQ,SAAS,gBAAiB,CACzC,WAAY,GACZ,gBAAiB,CAAC,KAAK,CAAA,CACxB,EAEDA,EAAS,QAAQ,SAAS,KAAM,CAC9B,WAAY,GACZ,gBAAiB,CAAC,KAAK,CAAA,CACxB,EAGD,OAAO,iBAAiB,iBAAkBD,CAAS,EAE5C,IAAM,CACXC,EAAS,WAAA,EACT,OAAO,oBAAoB,iBAAkBD,CAAS,CACxD,CACF,EAAG,CAAA,CAAE,EAEE,CAAE,IAAAF,CAAA,CACX,CCtCO,SAASI,GAAc,CAC5B,KAAM,CAAE,UAAAtB,CAAA,EAAcS,EAAA,EAGtB,MAAO,CAAE,cAFaI,EAAkBb,EAAU,WAAW,KAAK,EAE1C,YAAaA,EAAU,WAAW,WAAA,CAC5D,CCHO,SAASuB,GAAc,CAC5B,KAAM,CAAE,UAAAvB,CAAA,EAAcS,EAAA,EAChB,CAAE,sBAAAe,CAAA,EAA0BZ,EAAA,EAC5Ba,EAAeZ,EAAkBb,EAAU,WAAW,YAAY,EAClE0B,EAAgBb,EAAkBb,EAAU,WAAW,aAAa,EAEpE,CAAE,aAAA2B,EAAc,eAAAC,CAAA,EAAmBxB,EAAAA,QAAQ,KACxC,CACL,aAAcsB,EAAc,KAAK,OAAQG,GAAMA,EAAE,WAAa,EAAI,EAClE,eAAgBH,EAAc,KAAK,OAAQG,GAAMA,EAAE,WAAa,EAAK,CAAA,GAEtE,CAACH,EAAc,IAAI,CAAC,EAEjBI,EAAsB1B,EAAAA,QAAQ,IAC9BoB,EACKG,EAAa,SAAW,EAE1B,GACN,CAACH,EAAuBG,EAAa,MAAM,CAAC,EAE/C,MAAO,CACL,aAAAF,EACA,cAAAC,EACA,iBAAkB1B,EAAU,WAAW,iBACvC,eAAgBA,EAAU,WAAW,eACrC,sBAAuBA,EAAU,WAAW,sBAC5C,aAAA2B,EACA,eAAAC,EACA,oBAAAE,CAAA,CAEJ,CChCO,SAASC,GAAwB,OACtC,KAAM,CAAE,aAAAN,CAAA,EAAiBF,EAAA,EACnB,CAAE,cAAAS,CAAA,EAAkBV,EAAA,EAEpBW,IAAwB5C,EAAAoC,EAAa,UAAb,YAAApC,EAAsB,SAAS,QAAS,KAEhE6C,EACJF,EAAc,SAAS,OAAS,EAC5BA,EAAc,SAASA,EAAc,SAAS,OAAS,CAAC,EACxD,KACAG,GAA4BD,GAAA,YAAAA,EAAa,QAAS,OAMxD,MAAO,CAAE,oBAHND,GAAyBR,EAAa,qBACtCO,EAAc,kBAAoBG,EAE5B,CACX,CCjBA,SAASC,GAAiB,CACxB,KAAM,CAAE,UAAApC,CAAA,EAAcS,EAAA,EAGtB,OAAO4B,EAAO,CAACrC,EAAU,OAAO,KAAK,EAAGA,EAAU,IAAI,cAAe,CACnE,kBAAmB,EAAA,CACpB,CACH,CCPO,SAASsC,GAAkB,CAChC,KAAM,CAAE,UAAAtC,CAAA,EAAcS,EAAA,EAItB,MAAO,CACL,YAHkBI,EAAkBb,EAAU,UAAU,KAAK,EAI7D,iBAAkBA,EAAU,UAAU,iBACtC,aAAcA,EAAU,UAAU,YAAA,CAEtC,CCTA,MAAMuC,MAA2D,IAWjE,SAASC,GAAiB,CACxB,KAAM,CAACC,EAAOC,CAAQ,EAAIxC,EAAAA,SAA6B,CAAA,CAAE,EACnD,CACJ,UAAW,CAAE,IAAAyC,CAAA,CAAI,EACflC,EAAA,EACJ,SAASmC,EAAYH,EAAe,CAClC,MAAMI,EAAWJ,EAAM,IAAKK,IAAU,CACpC,KAAAA,EACA,GAAIC,EAAAA,GAAA,EACJ,OAAQ,UACR,SAAU,CAAA,EACV,EAEFL,EAAUM,GAAS,CAAC,GAAGA,EAAM,GAAGH,CAAQ,CAAC,EACzCA,EAAS,QAAQI,CAAU,CAC7B,CAEA,SAASC,EAAeC,EAAYC,EAAmC,CACrEV,EAAUM,GACRA,EAAK,IAAKK,GAAOA,EAAE,KAAOF,EAAK,CAAE,GAAGE,EAAG,GAAGD,CAAA,EAAWC,CAAE,CAAA,CAE3D,CAEA,SAASC,EAAeH,EAAY,CAClCT,EAAUM,GAASA,EAAK,OAAQK,GAAMA,EAAE,KAAOF,CAAE,CAAC,CACpD,CAEA,MAAMF,EAAa,MAAOM,GAA+B,CACvD,MAAMC,EAAa,IAAI,gBACvBjB,EAAuB,IAAIgB,EAAS,GAAIC,CAAU,EAElD,GAAI,CACFd,EAAUM,GACRA,EAAK,IAAKK,GACRA,EAAE,KAAOE,EAAS,GAAK,CAAE,GAAGF,EAAG,OAAQ,YAAa,SAAU,GAAMA,CAAA,CACtE,EAGF,MAAMI,EAAW,MAAMd,EAAI,WAAW,CACpC,KAAMY,EAAS,KACf,YAAaC,EAAW,OACxB,WAAaE,GAAe,CAC1BR,EAAeK,EAAS,GAAI,CAAE,SAAUG,EAAY,CACtD,CAAA,CACD,EAEDR,EAAeK,EAAS,GAAI,CAC1B,OAAQ,UACR,QAASE,EAAS,QAClB,SAAU,GAAA,CACX,CACH,OAASE,EAAO,CACTH,EAAW,OAAO,SACrBN,EAAeK,EAAS,GAAI,CAC1B,OAAQ,QACR,MAAOI,aAAiB,MAAQA,EAAM,QAAU,gBAChD,SAAU,CAAA,CACX,CAEL,QAAA,CACEpB,EAAuB,OAAOgB,EAAS,EAAE,CAC3C,CACF,EAEMK,EAAsBC,GAAmB,CAC7C,MAAML,EAAajB,EAAuB,IAAIsB,CAAM,EAChDL,IACFA,EAAW,MAAA,EACXjB,EAAuB,OAAOsB,CAAM,GAEtCP,EAAeO,CAAM,CACvB,EAEMC,EAAe1D,EAAAA,QAAQ,IACpBqC,EAAM,OAAQY,GAAMA,EAAE,SAAW,WAAaA,EAAE,OAAO,EAC7D,CAACZ,CAAK,CAAC,EAEV,SAASsB,GAAgB,CACvBxB,EAAuB,QAASiB,GAAeA,EAAW,OAAO,EACjEjB,EAAuB,MAAA,EACvBG,EAAS,CAAA,CAAE,CACb,CAEArC,OAAAA,EAAAA,UAAU,IACD,IAAM,CACXkC,EAAuB,QAASiB,GAAeA,EAAW,OAAO,EACjEjB,EAAuB,MAAA,CACzB,EACC,CAAA,CAAE,EAEE,CACL,SAAUE,EACV,YAAAG,EACA,mBAAAgB,EACA,aAAAE,EACA,cAAAC,EACA,YAAcZ,GAAeV,EAAM,KAAMY,GAAMA,EAAE,KAAOF,CAAE,EAC1D,kBAAoBA,UAClB,QAAA9D,EAAAoD,EAAM,KAAMY,GAAMA,EAAE,KAAOF,CAAE,IAA7B,YAAA9D,EAAgC,WAAY,GAC9C,gBAAkB8D,GAAA,OAAe,OAAA9D,EAAAoD,EAAM,KAAMY,GAAMA,EAAE,KAAOF,CAAE,IAA7B,YAAA9D,EAAgC,QACjE,UAAWoD,EAAM,KAAMY,GAAMA,EAAE,SAAW,OAAO,EACjD,YAAaZ,EAAM,KAAMY,GAAMA,EAAE,SAAW,WAAW,CAAA,CAE3D,CCtGA,MAAM/D,EAAUC,EAAAA,cAAuC,IAAI,EAEpD,SAASyE,EAAsB,CAAE,SAAAtE,GAAqC,CAC3E,MAAMD,EAASmB,EAAA,EACT,CAACqD,EAAQC,CAAS,EAAIhE,EAAAA,SAAS,IAC/BT,EAAO,OAAe,GACnBA,EAAO,QAAU,EACzB,EAEDY,OAAAA,EAAAA,UAAU,IAAM,CACd6D,EAAWlB,GAASvD,EAAO,QAAUuD,CAAI,CAC3C,EAAG,CAACvD,EAAO,MAAM,CAAC,EAElBY,EAAAA,UAAU,IAAM,CACd,MAAM8D,EAAoB1E,EAAO,kBACjC,GAAI,OAAO0E,GAAsB,UAAY,MAAMA,CAAiB,EAClE,OAEF,MAAMC,EAAU,WAAW,IAAMF,EAAU,EAAI,EAAGC,EAAoB,GAAI,EAE1E,MAAO,IAAM,aAAaC,CAAO,CACnC,EAAG,CAAC3E,EAAO,iBAAiB,CAAC,EAG3Bc,EAAA,cAACjB,EAAQ,SAAR,CAAiB,MAAO,CAAE,OAAA2E,EAAQ,UAAAC,EAAU,EAC1CxE,CACH,CAEJ,CAEO,SAAS2E,GAAmB,CACjC,MAAM3D,EAAMC,EAAAA,WAAWrB,CAAO,EAC9B,GAAI,CAACoB,EACH,MAAM,IAAI,MACR,8DAAA,EAGJ,OAAOA,CACT,CClDO,SAAS4D,GAAW,SACzB,KAAM,CAAE,UAAAtE,CAAA,EAAcS,EAAA,EAChB,CAAE,gBAAA8D,CAAA,EAAoB3D,EAAA,EACtB,CAAE,aAAAa,CAAA,EAAiBF,EAAA,EAEnBiD,EAAQxE,EAAU,MAClByE,GAAepF,EAAAoC,EAAa,UAAb,YAAApC,EAAsB,OACrCqF,EAAaF,EAAM,KAAMG,GAASA,EAAK,KAAOF,CAAY,EAE1DG,GAAYC,EAAAN,GAAA,YAAAA,EAAiB,KAAMO,GAAA,SACvC,QACEJ,GAAA,YAAAA,EAAY,KAAM,KAClBrF,EAAAqF,GAAA,YAAAA,EAAY,OAAZ,YAAArF,EAAkB,gBAAiB,KACnCwF,EAAAH,GAAA,YAAAA,EAAY,OAAZ,YAAAG,EAAkB,gBAAiB,EAAA,EACnC,SAASC,EAAc,IAAI,aAAa,MAL1B,YAAAD,EAMf,UAEH,MAAO,CACL,MAAAL,EACA,gBAAAD,EACA,aAAAE,EACA,WAAAC,EACA,UAAAE,CAAA,CAEJ,CCpBO,SAASG,GAAU,CACxB,KAAM,CAAE,UAAA/E,CAAA,EAAcS,EAAA,EAChB,CACJ,cAAe,CAAE,SAAAuE,CAAA,CAAS,EACxB1D,EAAA,EAEE,CACJ,qBAAA2D,EACA,gBAAAC,EACA,qBAAAC,EACA,gBAAAC,EACA,eAAAC,EACA,kBAAAC,CAAA,EACElF,EAAAA,QAAQ,IAAM,CAChB,MAAM6E,EAAuBD,EAAS,KACnCO,GACCA,EAAQ,OAAS,UAAYA,EAAQ,UAAY,gBAAA,EAE/CJ,EAAuBH,EAAS,SACnCO,GACCA,EAAQ,OAAS,UAAYA,EAAQ,UAAY,gBAAA,EAGrD,MAAO,CACL,qBAAAN,EACA,gBAAiB,CAAC,CAACA,GAAwB,CAACE,EAC5C,qBAAAA,EACA,gBAAiB,CAAC,CAACA,EACnB,eAAgBA,GAAAA,YAAAA,EAAsB,KAAK,QAAQ,MACnD,kBAAmBA,GAAAA,YAAAA,EAAsB,KAAK,QAAQ,QAAA,CAE1D,EAAG,CAACH,CAAQ,CAAC,EAEb,MAAO,CACL,WAAYhF,EAAU,QAAQ,WAC9B,qBAAAiF,EACA,gBAAAC,EACA,qBAAAC,EACA,gBAAAC,EACA,eAAAC,EACA,kBAAAC,CAAA,CAEJ"}
|
|
1
|
+
{"version":3,"file":"index.cjs","sources":["../src/ComponentRegistry.ts","../src/WidgetProvider.tsx","../src/hooks/useConfig.ts","../src/hooks/usePrimitiveState.ts","../src/hooks/useContact.ts","../src/hooks/useDocumentDir.ts","../src/hooks/useMessages.ts","../src/hooks/useSessions.ts","../src/hooks/useIsAwaitingBotReply.ts","../src/hooks/useWidgetRouter.ts","../src/hooks/useUploadFiles.ts","../src/hooks/useWidgetTrigger.tsx","../src/hooks/useModes.ts","../src/hooks/useCsat.ts"],"sourcesContent":["import type { WidgetComponentKey } from '@opencx/widget-core';\nimport type { WidgetComponentType } from './types/components';\n\nexport class ComponentRegistry {\n components: WidgetComponentType[] = [];\n\n constructor(opts: { components?: WidgetComponentType[] }) {\n const { components } = opts;\n\n if (components) {\n components.forEach((c) => this.register(c));\n }\n\n if (this.components.length === 0) {\n throw new Error('No components registered');\n }\n if (!this.get('fallback')) {\n throw new Error('No fallback component registered');\n }\n }\n\n // TODO test that this registers or replaces the component\n register(component: WidgetComponentType) {\n // Replace the key if it already exists\n const index = this.components.findIndex((c) => c.key === component.key);\n if (index !== -1) {\n this.components[index] = component;\n } else {\n this.components.push(component);\n }\n return this;\n }\n\n private get(key: WidgetComponentKey) {\n const c = this.components.find(\n (c) => c.key.toUpperCase() === key.toUpperCase(),\n );\n if (c) return c;\n return null;\n }\n\n public getComponent(key: string) {\n return this.get(key)?.component;\n }\n}\n","import React, {\n createContext,\n useContext,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { version } from '../package.json';\nimport {\n type ExternalStorage,\n type WidgetConfig,\n WidgetCtx,\n} from '@opencx/widget-core';\nimport { ComponentRegistry } from './ComponentRegistry';\nimport type { WidgetComponentType } from './types/components';\n\ninterface WidgetProviderValue {\n widgetCtx: WidgetCtx;\n config: WidgetConfig;\n components?: WidgetComponentType[];\n componentStore: ComponentRegistry;\n version: string;\n contentIframeRef?: React.MutableRefObject<HTMLIFrameElement | null>;\n}\n\nconst context = createContext<WidgetProviderValue | null>(null);\n\nexport function WidgetProvider({\n options: config,\n children,\n components,\n storage,\n loadingComponent,\n}: {\n options: WidgetConfig;\n children: React.ReactNode;\n components?: WidgetComponentType[];\n storage?: ExternalStorage;\n /**\n * Custom loading component while the widget is initializing\n * Not to be confused with the `loading` custom component which renders when the bot's reply is pending\n */\n loadingComponent?: React.ReactNode;\n}) {\n const contentIframeRef = useRef<HTMLIFrameElement | null>(null);\n\n const didInitialize = useRef(false);\n const [widgetCtx, setWidgetCtx] = useState<WidgetCtx | null>(null);\n\n const componentStore = useMemo(\n () =>\n new ComponentRegistry({\n components: components,\n }),\n [components],\n );\n\n useEffect(() => {\n if (didInitialize.current) return;\n didInitialize.current = true;\n\n WidgetCtx.initialize({ config, storage })\n .then(setWidgetCtx)\n .catch(console.error);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n if (!widgetCtx) {\n return loadingComponent || null;\n }\n\n return (\n <context.Provider\n value={{\n widgetCtx,\n config,\n components,\n componentStore,\n version,\n contentIframeRef,\n }}\n >\n {children}\n </context.Provider>\n );\n}\n\nexport function useWidget() {\n const ctx = useContext(context);\n if (!ctx) {\n throw new Error('useWidget must be used within a WidgetProvider');\n }\n return ctx;\n}\n","import { useWidget } from '../WidgetProvider';\n\nexport function useConfig() {\n const { config } = useWidget();\n\n return config;\n}\n","import { useSyncExternalStore } from 'react';\nimport type { PrimitiveState } from '@opencx/widget-core';\n\nexport function usePrimitiveState<T>(p: PrimitiveState<T>) {\n return useSyncExternalStore(p.subscribe, p.get, p.get);\n}\n","import { useWidget } from '../WidgetProvider';\nimport { usePrimitiveState } from './usePrimitiveState';\n\nexport function useContact() {\n const { widgetCtx } = useWidget();\n const contactState = usePrimitiveState(widgetCtx.contactCtx.state);\n\n return {\n contactState,\n createUnverifiedContact: widgetCtx.contactCtx.createUnverifiedContact,\n };\n}\n","import { useEffect, useState } from 'react';\nimport type { StringOrLiteral } from '@opencx/widget-core';\n\nexport function useDocumentDir() {\n const [dir, setDir] = useState<StringOrLiteral<'ltr' | 'rtl'>>('ltr');\n\n useEffect(() => {\n const updateDir = () => {\n if (typeof document === 'undefined') return;\n setDir(\n window.getComputedStyle((window.top || window).document.body).direction,\n );\n };\n\n // Set initial direction\n updateDir();\n\n // Watch for direction changes on both document and documentElement\n const observer = new MutationObserver(updateDir);\n\n // Observe both document and documentElement\n observer.observe(document.documentElement, {\n attributes: true,\n attributeFilter: ['dir'],\n });\n\n observer.observe(document.body, {\n attributes: true,\n attributeFilter: ['dir'],\n });\n\n // Add event listener for dynamic changes\n window.addEventListener('languagechange', updateDir);\n\n return () => {\n observer.disconnect();\n window.removeEventListener('languagechange', updateDir);\n };\n }, []);\n\n return { dir };\n}\n","import { usePrimitiveState } from './usePrimitiveState';\nimport { useWidget } from '../WidgetProvider';\n\nexport function useMessages() {\n const { widgetCtx } = useWidget();\n const messagesState = usePrimitiveState(widgetCtx.messageCtx.state);\n\n return { messagesState, sendMessage: widgetCtx.messageCtx.sendMessage };\n}\n","import { useMemo } from 'react';\nimport { useWidget } from '../WidgetProvider';\nimport { usePrimitiveState } from './usePrimitiveState';\nimport { useConfig } from './useConfig';\n\nexport function useSessions() {\n const { widgetCtx } = useWidget();\n const { oneOpenSessionAllowed } = useConfig();\n const sessionState = usePrimitiveState(widgetCtx.sessionCtx.sessionState);\n const sessionsState = usePrimitiveState(widgetCtx.sessionCtx.sessionsState);\n\n const { openSessions, closedSessions } = useMemo(() => {\n return {\n openSessions: sessionsState.data.filter((s) => s.isOpened === true),\n closedSessions: sessionsState.data.filter((s) => s.isOpened === false),\n };\n }, [sessionsState.data]);\n\n const canCreateNewSession = useMemo(() => {\n if (oneOpenSessionAllowed) {\n return openSessions.length === 0;\n }\n return true;\n }, [oneOpenSessionAllowed, openSessions.length]);\n\n return {\n sessionState,\n sessionsState,\n loadMoreSessions: widgetCtx.sessionCtx.loadMoreSessions,\n resolveSession: widgetCtx.sessionCtx.resolveSession,\n createStateCheckpoint: widgetCtx.sessionCtx.createStateCheckpoint,\n openSessions,\n closedSessions,\n canCreateNewSession,\n };\n}\n","import { useMessages } from './useMessages';\nimport { useSessions } from './useSessions';\n\nexport function useIsAwaitingBotReply() {\n const { sessionState } = useSessions();\n const { messagesState } = useMessages();\n\n const isSessionAssignedToAI = sessionState.session?.assignee.kind === 'ai';\n // This check is useful in cases where the user might navigate in and out of a chat, and `isSendingMessage` is reset back to its default value\n const lastMessage =\n messagesState.messages.length > 0\n ? messagesState.messages[messagesState.messages.length - 1]\n : null;\n const isLastMessageAUserMessage = lastMessage?.type === 'USER';\n\n const isAwaitingBotReply =\n (isSessionAssignedToAI || sessionState.isCreatingSession) &&\n (messagesState.isSendingMessage || isLastMessageAUserMessage);\n\n return { isAwaitingBotReply };\n}\n","import { useWidget } from '../WidgetProvider';\nimport { usePrimitiveState } from './usePrimitiveState';\n\nexport function useWidgetRouter() {\n const { widgetCtx } = useWidget();\n\n const routerState = usePrimitiveState(widgetCtx.routerCtx.state);\n\n return {\n routerState,\n toSessionsScreen: widgetCtx.routerCtx.toSessionsScreen,\n toChatScreen: widgetCtx.routerCtx.toChatScreen,\n };\n}\n","import { useEffect, useMemo, useState } from 'react';\nimport { useWidget } from '../WidgetProvider';\nimport { v4 } from 'uuid';\n\nconst uploadAbortControllers: Map<string, AbortController> = new Map();\n\ninterface FileWithProgress {\n status: 'pending' | 'uploading' | 'success' | 'error';\n id: string;\n file: File;\n fileUrl?: string;\n progress: number;\n error?: string;\n}\n\nfunction useUploadFiles() {\n const [files, setFiles] = useState<FileWithProgress[]>([]);\n const {\n widgetCtx: { api },\n } = useWidget();\n function appendFiles(files: File[]) {\n const newFiles = files.map((file) => ({\n file,\n id: v4(),\n status: 'pending' as const,\n progress: 0,\n }));\n\n setFiles((prev) => [...prev, ...newFiles]);\n newFiles.forEach(uploadFile);\n }\n\n function updateFileById(id: string, update: Partial<FileWithProgress>) {\n setFiles((prev) =>\n prev.map((f) => (f.id === id ? { ...f, ...update } : f)),\n );\n }\n\n function removeFileById(id: string) {\n setFiles((prev) => prev.filter((f) => f.id !== id));\n }\n\n const uploadFile = async (fileItem: FileWithProgress) => {\n const controller = new AbortController();\n uploadAbortControllers.set(fileItem.id, controller);\n\n try {\n setFiles((prev) =>\n prev.map((f) =>\n f.id === fileItem.id ? { ...f, status: 'uploading', progress: 0 } : f,\n ),\n );\n\n const response = await api.uploadFile({\n file: fileItem.file,\n abortSignal: controller.signal,\n onProgress: (percentage) => {\n updateFileById(fileItem.id, { progress: percentage });\n },\n });\n\n updateFileById(fileItem.id, {\n status: 'success',\n fileUrl: response.fileUrl,\n progress: 100,\n });\n } catch (error) {\n if (!controller.signal.aborted) {\n updateFileById(fileItem.id, {\n status: 'error',\n error: error instanceof Error ? error.message : 'Upload failed',\n progress: 0,\n });\n }\n } finally {\n uploadAbortControllers.delete(fileItem.id);\n }\n };\n\n const handleCancelUpload = (fileId: string) => {\n const controller = uploadAbortControllers.get(fileId);\n if (controller) {\n controller.abort();\n uploadAbortControllers.delete(fileId);\n }\n removeFileById(fileId);\n };\n\n const successFiles = useMemo(() => {\n return files.filter((f) => f.status === 'success' && f.fileUrl);\n }, [files]);\n\n function emptyTheFiles() {\n uploadAbortControllers.forEach((controller) => controller.abort());\n uploadAbortControllers.clear();\n setFiles([]);\n }\n\n useEffect(() => {\n return () => {\n uploadAbortControllers.forEach((controller) => controller.abort());\n uploadAbortControllers.clear();\n };\n }, []);\n\n return {\n allFiles: files,\n appendFiles,\n handleCancelUpload,\n successFiles,\n emptyTheFiles,\n getFileById: (id: string) => files.find((f) => f.id === id),\n getUploadProgress: (id: string) =>\n files.find((f) => f.id === id)?.progress ?? 0,\n getUploadStatus: (id: string) => files.find((f) => f.id === id)?.status,\n hasErrors: files.some((f) => f.status === 'error'),\n isUploading: files.some((f) => f.status === 'uploading'),\n };\n}\n\nexport { useUploadFiles, type FileWithProgress };\n","import React, {\n createContext,\n useContext,\n useEffect,\n useState,\n type Dispatch,\n type ReactNode,\n type SetStateAction,\n} from 'react';\nimport { useConfig } from './useConfig';\n\ntype WidgetTriggerCtx = {\n isOpen: boolean;\n setIsOpen: Dispatch<SetStateAction<boolean>>;\n};\n\nconst context = createContext<WidgetTriggerCtx | null>(null);\n\nexport function WidgetTriggerProvider({ children }: { children: ReactNode }) {\n const config = useConfig();\n const [isOpen, setIsOpen] = useState(() => {\n if (config.inline) return true;\n return config.isOpen ?? false;\n });\n\n useEffect(() => {\n setIsOpen((prev) => config.isOpen ?? prev);\n }, [config.isOpen]);\n\n useEffect(() => {\n const openAfterNSeconds = config.openAfterNSeconds;\n if (typeof openAfterNSeconds !== 'number' || isNaN(openAfterNSeconds))\n return;\n\n const timeout = setTimeout(() => setIsOpen(true), openAfterNSeconds * 1000);\n\n return () => clearTimeout(timeout);\n }, [config.openAfterNSeconds]);\n\n return (\n <context.Provider value={{ isOpen, setIsOpen }}>\n {children}\n </context.Provider>\n );\n}\n\nexport function useWidgetTrigger() {\n const ctx = useContext(context);\n if (!ctx) {\n throw new Error(\n 'useWidgetTrigger must be used within a WidgetTriggerProvider',\n );\n }\n return ctx;\n}\n","import { useWidget } from '../WidgetProvider';\nimport { useConfig } from './useConfig';\nimport { useSessions } from './useSessions';\n\nexport function useModes() {\n const { widgetCtx } = useWidget();\n const { modesComponents } = useConfig();\n const { sessionState } = useSessions();\n\n const modes = widgetCtx.modes;\n const activeModeId = sessionState.session?.modeId;\n const activeMode = modes.find((mode) => mode.id === activeModeId);\n\n const Component = modesComponents?.find((modeComponent) =>\n [\n activeMode?.id || '',\n activeMode?.name?.toLowerCase() || '',\n activeMode?.slug?.toLowerCase() || '',\n ].includes(modeComponent.key.toLowerCase()),\n )?.component;\n\n return {\n modes,\n modesComponents,\n activeModeId,\n activeMode,\n Component,\n };\n}\n","import type {\n WidgetSystemMessage__CsatRequested,\n WidgetSystemMessage__CsatSubmitted,\n} from '@opencx/widget-core';\nimport { useMemo } from 'react';\nimport { useMessages } from './useMessages';\nimport { useWidget } from '../WidgetProvider';\n\nexport function useCsat() {\n const { widgetCtx } = useWidget();\n const {\n messagesState: { messages },\n } = useMessages();\n\n const {\n csatRequestedMessage,\n isCsatRequested,\n csatSubmittedMessage,\n isCsatSubmitted,\n submittedScore,\n submittedFeedback,\n } = useMemo(() => {\n const csatRequestedMessage = messages.find(\n (message): message is WidgetSystemMessage__CsatRequested =>\n message.type === 'SYSTEM' && message.subtype === 'csat_requested',\n );\n const csatSubmittedMessage = messages.findLast(\n (message): message is WidgetSystemMessage__CsatSubmitted =>\n message.type === 'SYSTEM' && message.subtype === 'csat_submitted',\n );\n\n return {\n csatRequestedMessage,\n isCsatRequested: !!csatRequestedMessage && !csatSubmittedMessage,\n csatSubmittedMessage,\n isCsatSubmitted: !!csatSubmittedMessage,\n submittedScore: csatSubmittedMessage?.data.payload.score,\n submittedFeedback: csatSubmittedMessage?.data.payload.feedback,\n };\n }, [messages]);\n\n return {\n submitCsat: widgetCtx.csatCtx.submitCsat,\n csatRequestedMessage,\n isCsatRequested,\n csatSubmittedMessage,\n isCsatSubmitted,\n submittedScore,\n submittedFeedback,\n };\n}\n"],"names":["ComponentRegistry","opts","components","c","component","index","key","_a","context","createContext","WidgetProvider","config","children","storage","loadingComponent","contentIframeRef","useRef","didInitialize","widgetCtx","setWidgetCtx","useState","componentStore","useMemo","useEffect","WidgetCtx","React","version","useWidget","ctx","useContext","useConfig","usePrimitiveState","p","useSyncExternalStore","useContact","useDocumentDir","dir","setDir","updateDir","observer","useMessages","useSessions","oneOpenSessionAllowed","sessionState","sessionsState","openSessions","closedSessions","s","canCreateNewSession","useIsAwaitingBotReply","messagesState","isSessionAssignedToAI","lastMessage","isLastMessageAUserMessage","useWidgetRouter","uploadAbortControllers","useUploadFiles","files","setFiles","api","appendFiles","newFiles","file","v4","prev","uploadFile","updateFileById","id","update","f","removeFileById","fileItem","controller","response","percentage","error","handleCancelUpload","fileId","successFiles","emptyTheFiles","WidgetTriggerProvider","isOpen","setIsOpen","openAfterNSeconds","timeout","useWidgetTrigger","useModes","modesComponents","modes","activeModeId","activeMode","mode","Component","_b","modeComponent","useCsat","messages","csatRequestedMessage","isCsatRequested","csatSubmittedMessage","isCsatSubmitted","submittedScore","submittedFeedback","message"],"mappings":"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"}
|
package/dist/index.js
CHANGED
|
@@ -1,9 +1,8 @@
|
|
|
1
|
-
import
|
|
2
|
-
import { WidgetCtx as
|
|
3
|
-
import
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
class N {
|
|
1
|
+
import E, { createContext as v, useRef as y, useState as h, useMemo as S, useEffect as C, useContext as F, useSyncExternalStore as M } from "react";
|
|
2
|
+
import { WidgetCtx as W } from "@opencx/widget-core";
|
|
3
|
+
import { v4 as T } from "uuid";
|
|
4
|
+
const O = "4.0.15";
|
|
5
|
+
class P {
|
|
7
6
|
constructor(t) {
|
|
8
7
|
this.components = [];
|
|
9
8
|
const { components: n } = t;
|
|
@@ -28,59 +27,59 @@ class N {
|
|
|
28
27
|
return (n = this.get(t)) == null ? void 0 : n.component;
|
|
29
28
|
}
|
|
30
29
|
}
|
|
31
|
-
const
|
|
32
|
-
function
|
|
30
|
+
const U = v(null);
|
|
31
|
+
function B({
|
|
33
32
|
options: e,
|
|
34
33
|
children: t,
|
|
35
34
|
components: n,
|
|
36
35
|
storage: o,
|
|
37
36
|
loadingComponent: i
|
|
38
37
|
}) {
|
|
39
|
-
const a = y(null), d = y(!1), [l, g] =
|
|
40
|
-
() => new
|
|
38
|
+
const a = y(null), d = y(!1), [l, g] = h(null), c = S(
|
|
39
|
+
() => new P({
|
|
41
40
|
components: n
|
|
42
41
|
}),
|
|
43
42
|
[n]
|
|
44
43
|
);
|
|
45
44
|
return C(() => {
|
|
46
|
-
d.current || (d.current = !0,
|
|
47
|
-
}, []), l ? /* @__PURE__ */
|
|
48
|
-
|
|
45
|
+
d.current || (d.current = !0, W.initialize({ config: e, storage: o }).then(g).catch(console.error));
|
|
46
|
+
}, []), l ? /* @__PURE__ */ E.createElement(
|
|
47
|
+
U.Provider,
|
|
49
48
|
{
|
|
50
49
|
value: {
|
|
51
50
|
widgetCtx: l,
|
|
52
51
|
config: e,
|
|
53
52
|
components: n,
|
|
54
53
|
componentStore: c,
|
|
55
|
-
version:
|
|
54
|
+
version: O,
|
|
56
55
|
contentIframeRef: a
|
|
57
56
|
}
|
|
58
57
|
},
|
|
59
58
|
t
|
|
60
59
|
) : i || null;
|
|
61
60
|
}
|
|
62
|
-
function
|
|
63
|
-
const e = F(
|
|
61
|
+
function f() {
|
|
62
|
+
const e = F(U);
|
|
64
63
|
if (!e)
|
|
65
64
|
throw new Error("useWidget must be used within a WidgetProvider");
|
|
66
65
|
return e;
|
|
67
66
|
}
|
|
68
67
|
function x() {
|
|
69
|
-
const { config: e } =
|
|
68
|
+
const { config: e } = f();
|
|
70
69
|
return e;
|
|
71
70
|
}
|
|
72
71
|
function w(e) {
|
|
73
|
-
return
|
|
72
|
+
return M(e.subscribe, e.get, e.get);
|
|
74
73
|
}
|
|
75
|
-
function
|
|
76
|
-
const { widgetCtx: e } =
|
|
74
|
+
function D() {
|
|
75
|
+
const { widgetCtx: e } = f();
|
|
77
76
|
return {
|
|
78
77
|
contactState: w(e.contactCtx.state),
|
|
79
78
|
createUnverifiedContact: e.contactCtx.createUnverifiedContact
|
|
80
79
|
};
|
|
81
80
|
}
|
|
82
|
-
function
|
|
83
|
-
const [e, t] =
|
|
81
|
+
function I() {
|
|
82
|
+
const [e, t] = h("ltr");
|
|
84
83
|
return C(() => {
|
|
85
84
|
const n = () => {
|
|
86
85
|
typeof document > "u" || t(
|
|
@@ -100,12 +99,12 @@ function Y() {
|
|
|
100
99
|
};
|
|
101
100
|
}, []), { dir: e };
|
|
102
101
|
}
|
|
103
|
-
function
|
|
104
|
-
const { widgetCtx: e } =
|
|
102
|
+
function R() {
|
|
103
|
+
const { widgetCtx: e } = f();
|
|
105
104
|
return { messagesState: w(e.messageCtx.state), sendMessage: e.messageCtx.sendMessage };
|
|
106
105
|
}
|
|
107
106
|
function k() {
|
|
108
|
-
const { widgetCtx: e } =
|
|
107
|
+
const { widgetCtx: e } = f(), { oneOpenSessionAllowed: t } = x(), n = w(e.sessionCtx.sessionState), o = w(e.sessionCtx.sessionsState), { openSessions: i, closedSessions: a } = S(() => ({
|
|
109
108
|
openSessions: o.data.filter((l) => l.isOpened === !0),
|
|
110
109
|
closedSessions: o.data.filter((l) => l.isOpened === !1)
|
|
111
110
|
}), [o.data]), d = S(() => t ? i.length === 0 : !0, [t, i.length]);
|
|
@@ -120,34 +119,28 @@ function k() {
|
|
|
120
119
|
canCreateNewSession: d
|
|
121
120
|
};
|
|
122
121
|
}
|
|
123
|
-
function
|
|
122
|
+
function z() {
|
|
124
123
|
var d;
|
|
125
|
-
const { sessionState: e } = k(), { messagesState: t } =
|
|
124
|
+
const { sessionState: e } = k(), { messagesState: t } = R(), n = ((d = e.session) == null ? void 0 : d.assignee.kind) === "ai", o = t.messages.length > 0 ? t.messages[t.messages.length - 1] : null, i = (o == null ? void 0 : o.type) === "USER";
|
|
126
125
|
return { isAwaitingBotReply: (n || e.isCreatingSession) && (t.isSendingMessage || i) };
|
|
127
126
|
}
|
|
128
|
-
function
|
|
129
|
-
const { widgetCtx: e } =
|
|
130
|
-
return P([e.config.token], e.api.widgetPrelude, {
|
|
131
|
-
revalidateOnFocus: !1
|
|
132
|
-
});
|
|
133
|
-
}
|
|
134
|
-
function j() {
|
|
135
|
-
const { widgetCtx: e } = p();
|
|
127
|
+
function Y() {
|
|
128
|
+
const { widgetCtx: e } = f();
|
|
136
129
|
return {
|
|
137
130
|
routerState: w(e.routerCtx.state),
|
|
138
131
|
toSessionsScreen: e.routerCtx.toSessionsScreen,
|
|
139
132
|
toChatScreen: e.routerCtx.toChatScreen
|
|
140
133
|
};
|
|
141
134
|
}
|
|
142
|
-
const
|
|
143
|
-
function
|
|
144
|
-
const [e, t] =
|
|
135
|
+
const p = /* @__PURE__ */ new Map();
|
|
136
|
+
function _() {
|
|
137
|
+
const [e, t] = h([]), {
|
|
145
138
|
widgetCtx: { api: n }
|
|
146
|
-
} =
|
|
139
|
+
} = f();
|
|
147
140
|
function o(s) {
|
|
148
141
|
const r = s.map((u) => ({
|
|
149
142
|
file: u,
|
|
150
|
-
id:
|
|
143
|
+
id: T(),
|
|
151
144
|
status: "pending",
|
|
152
145
|
progress: 0
|
|
153
146
|
}));
|
|
@@ -163,11 +156,11 @@ function G() {
|
|
|
163
156
|
}
|
|
164
157
|
const d = async (s) => {
|
|
165
158
|
const r = new AbortController();
|
|
166
|
-
|
|
159
|
+
p.set(s.id, r);
|
|
167
160
|
try {
|
|
168
161
|
t(
|
|
169
162
|
(m) => m.map(
|
|
170
|
-
(
|
|
163
|
+
(b) => b.id === s.id ? { ...b, status: "uploading", progress: 0 } : b
|
|
171
164
|
)
|
|
172
165
|
);
|
|
173
166
|
const u = await n.uploadFile({
|
|
@@ -189,17 +182,17 @@ function G() {
|
|
|
189
182
|
progress: 0
|
|
190
183
|
});
|
|
191
184
|
} finally {
|
|
192
|
-
|
|
185
|
+
p.delete(s.id);
|
|
193
186
|
}
|
|
194
187
|
}, l = (s) => {
|
|
195
|
-
const r =
|
|
196
|
-
r && (r.abort(),
|
|
188
|
+
const r = p.get(s);
|
|
189
|
+
r && (r.abort(), p.delete(s)), a(s);
|
|
197
190
|
}, g = S(() => e.filter((s) => s.status === "success" && s.fileUrl), [e]);
|
|
198
191
|
function c() {
|
|
199
|
-
|
|
192
|
+
p.forEach((s) => s.abort()), p.clear(), t([]);
|
|
200
193
|
}
|
|
201
194
|
return C(() => () => {
|
|
202
|
-
|
|
195
|
+
p.forEach((s) => s.abort()), p.clear();
|
|
203
196
|
}, []), {
|
|
204
197
|
allFiles: e,
|
|
205
198
|
appendFiles: o,
|
|
@@ -219,9 +212,9 @@ function G() {
|
|
|
219
212
|
isUploading: e.some((s) => s.status === "uploading")
|
|
220
213
|
};
|
|
221
214
|
}
|
|
222
|
-
const A =
|
|
223
|
-
function
|
|
224
|
-
const t = x(), [n, o] =
|
|
215
|
+
const A = v(null);
|
|
216
|
+
function $({ children: e }) {
|
|
217
|
+
const t = x(), [n, o] = h(() => t.inline ? !0 : t.isOpen ?? !1);
|
|
225
218
|
return C(() => {
|
|
226
219
|
o((i) => t.isOpen ?? i);
|
|
227
220
|
}, [t.isOpen]), C(() => {
|
|
@@ -230,9 +223,9 @@ function H({ children: e }) {
|
|
|
230
223
|
return;
|
|
231
224
|
const a = setTimeout(() => o(!0), i * 1e3);
|
|
232
225
|
return () => clearTimeout(a);
|
|
233
|
-
}, [t.openAfterNSeconds]), /* @__PURE__ */
|
|
226
|
+
}, [t.openAfterNSeconds]), /* @__PURE__ */ E.createElement(A.Provider, { value: { isOpen: n, setIsOpen: o } }, e);
|
|
234
227
|
}
|
|
235
|
-
function
|
|
228
|
+
function j() {
|
|
236
229
|
const e = F(A);
|
|
237
230
|
if (!e)
|
|
238
231
|
throw new Error(
|
|
@@ -240,9 +233,9 @@ function J() {
|
|
|
240
233
|
);
|
|
241
234
|
return e;
|
|
242
235
|
}
|
|
243
|
-
function
|
|
236
|
+
function G() {
|
|
244
237
|
var l, g;
|
|
245
|
-
const { widgetCtx: e } =
|
|
238
|
+
const { widgetCtx: e } = f(), { modesComponents: t } = x(), { sessionState: n } = k(), o = e.modes, i = (l = n.session) == null ? void 0 : l.modeId, a = o.find((c) => c.id === i), d = (g = t == null ? void 0 : t.find(
|
|
246
239
|
(c) => {
|
|
247
240
|
var s, r;
|
|
248
241
|
return [
|
|
@@ -260,10 +253,10 @@ function K() {
|
|
|
260
253
|
Component: d
|
|
261
254
|
};
|
|
262
255
|
}
|
|
263
|
-
function
|
|
264
|
-
const { widgetCtx: e } =
|
|
256
|
+
function H() {
|
|
257
|
+
const { widgetCtx: e } = f(), {
|
|
265
258
|
messagesState: { messages: t }
|
|
266
|
-
} =
|
|
259
|
+
} = R(), {
|
|
267
260
|
csatRequestedMessage: n,
|
|
268
261
|
isCsatRequested: o,
|
|
269
262
|
csatSubmittedMessage: i,
|
|
@@ -296,21 +289,20 @@ function Q() {
|
|
|
296
289
|
};
|
|
297
290
|
}
|
|
298
291
|
export {
|
|
299
|
-
|
|
300
|
-
|
|
292
|
+
B as WidgetProvider,
|
|
293
|
+
$ as WidgetTriggerProvider,
|
|
301
294
|
x as useConfig,
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
$ as usePreludeData,
|
|
295
|
+
D as useContact,
|
|
296
|
+
H as useCsat,
|
|
297
|
+
I as useDocumentDir,
|
|
298
|
+
z as useIsAwaitingBotReply,
|
|
299
|
+
R as useMessages,
|
|
300
|
+
G as useModes,
|
|
309
301
|
w as usePrimitiveState,
|
|
310
302
|
k as useSessions,
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
303
|
+
_ as useUploadFiles,
|
|
304
|
+
f as useWidget,
|
|
305
|
+
Y as useWidgetRouter,
|
|
306
|
+
j as useWidgetTrigger
|
|
315
307
|
};
|
|
316
308
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../src/ComponentRegistry.ts","../src/WidgetProvider.tsx","../src/hooks/useConfig.ts","../src/hooks/usePrimitiveState.ts","../src/hooks/useContact.ts","../src/hooks/useDocumentDir.ts","../src/hooks/useMessages.ts","../src/hooks/useSessions.ts","../src/hooks/useIsAwaitingBotReply.ts","../src/hooks/usePreludeData.ts","../src/hooks/useWidgetRouter.ts","../src/hooks/useUploadFiles.ts","../src/hooks/useWidgetTrigger.tsx","../src/hooks/useModes.ts","../src/hooks/useCsat.ts"],"sourcesContent":["import type { WidgetComponentKey } from '@opencx/widget-core';\nimport type { WidgetComponentType } from './types/components';\n\nexport class ComponentRegistry {\n components: WidgetComponentType[] = [];\n\n constructor(opts: { components?: WidgetComponentType[] }) {\n const { components } = opts;\n\n if (components) {\n components.forEach((c) => this.register(c));\n }\n\n if (this.components.length === 0) {\n throw new Error('No components registered');\n }\n if (!this.get('fallback')) {\n throw new Error('No fallback component registered');\n }\n }\n\n // TODO test that this registers or replaces the component\n register(component: WidgetComponentType) {\n // Replace the key if it already exists\n const index = this.components.findIndex((c) => c.key === component.key);\n if (index !== -1) {\n this.components[index] = component;\n } else {\n this.components.push(component);\n }\n return this;\n }\n\n private get(key: WidgetComponentKey) {\n const c = this.components.find(\n (c) => c.key.toUpperCase() === key.toUpperCase(),\n );\n if (c) return c;\n return null;\n }\n\n public getComponent(key: string) {\n return this.get(key)?.component;\n }\n}\n","import React, {\n createContext,\n useContext,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { version } from '../package.json';\nimport { type ExternalStorage, type WidgetConfig, WidgetCtx } from '@opencx/widget-core';\nimport { ComponentRegistry } from './ComponentRegistry';\nimport type { WidgetComponentType } from './types/components';\n\ninterface WidgetProviderValue {\n widgetCtx: WidgetCtx;\n config: WidgetConfig;\n components?: WidgetComponentType[];\n componentStore: ComponentRegistry;\n version: string;\n contentIframeRef?: React.MutableRefObject<HTMLIFrameElement | null>;\n}\n\nconst context = createContext<WidgetProviderValue | null>(null);\n\nexport function WidgetProvider({\n options: config,\n children,\n components,\n storage,\n loadingComponent,\n}: {\n options: WidgetConfig;\n children: React.ReactNode;\n components?: WidgetComponentType[];\n storage?: ExternalStorage;\n /**\n * Custom loading component while the widget is initializing\n * Not to be confused with the `loading` custom component which renders when the bot's reply is pending\n */\n loadingComponent?: React.ReactNode;\n}) {\n const contentIframeRef = useRef<HTMLIFrameElement | null>(null);\n\n const didInitialize = useRef(false);\n const [widgetCtx, setWidgetCtx] = useState<WidgetCtx | null>(null);\n\n const componentStore = useMemo(\n () =>\n new ComponentRegistry({\n components: components,\n }),\n [components],\n );\n\n useEffect(() => {\n if (didInitialize.current) return;\n didInitialize.current = true;\n\n WidgetCtx.initialize({ config, storage }).then(setWidgetCtx);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n if (!widgetCtx) {\n return loadingComponent || null;\n }\n\n return (\n <context.Provider\n value={{\n widgetCtx,\n config,\n components,\n componentStore,\n version,\n contentIframeRef,\n }}\n >\n {children}\n </context.Provider>\n );\n}\n\nexport function useWidget() {\n const ctx = useContext(context);\n if (!ctx) {\n throw new Error('useWidget must be used within a WidgetProvider');\n }\n return ctx;\n}\n","import { useWidget } from '../WidgetProvider';\n\nexport function useConfig() {\n const { config } = useWidget();\n\n return config;\n}\n","import { useSyncExternalStore } from 'react';\nimport type { PrimitiveState } from '@opencx/widget-core';\n\nexport function usePrimitiveState<T>(p: PrimitiveState<T>) {\n return useSyncExternalStore(p.subscribe, p.get, p.get);\n}\n","import { useWidget } from '../WidgetProvider';\nimport { usePrimitiveState } from './usePrimitiveState';\n\nexport function useContact() {\n const { widgetCtx } = useWidget();\n const contactState = usePrimitiveState(widgetCtx.contactCtx.state);\n\n return {\n contactState,\n createUnverifiedContact: widgetCtx.contactCtx.createUnverifiedContact,\n };\n}\n","import { useEffect, useState } from 'react';\nimport type { StringOrLiteral } from '@opencx/widget-core';\n\nexport function useDocumentDir() {\n const [dir, setDir] = useState<StringOrLiteral<'ltr' | 'rtl'>>('ltr');\n\n useEffect(() => {\n const updateDir = () => {\n if (typeof document === 'undefined') return;\n setDir(\n window.getComputedStyle((window.top || window).document.body).direction,\n );\n };\n\n // Set initial direction\n updateDir();\n\n // Watch for direction changes on both document and documentElement\n const observer = new MutationObserver(updateDir);\n\n // Observe both document and documentElement\n observer.observe(document.documentElement, {\n attributes: true,\n attributeFilter: ['dir'],\n });\n\n observer.observe(document.body, {\n attributes: true,\n attributeFilter: ['dir'],\n });\n\n // Add event listener for dynamic changes\n window.addEventListener('languagechange', updateDir);\n\n return () => {\n observer.disconnect();\n window.removeEventListener('languagechange', updateDir);\n };\n }, []);\n\n return { dir };\n}\n","import { usePrimitiveState } from './usePrimitiveState';\nimport { useWidget } from '../WidgetProvider';\n\nexport function useMessages() {\n const { widgetCtx } = useWidget();\n const messagesState = usePrimitiveState(widgetCtx.messageCtx.state);\n\n return { messagesState, sendMessage: widgetCtx.messageCtx.sendMessage };\n}\n","import { useMemo } from 'react';\nimport { useWidget } from '../WidgetProvider';\nimport { usePrimitiveState } from './usePrimitiveState';\nimport { useConfig } from './useConfig';\n\nexport function useSessions() {\n const { widgetCtx } = useWidget();\n const { oneOpenSessionAllowed } = useConfig();\n const sessionState = usePrimitiveState(widgetCtx.sessionCtx.sessionState);\n const sessionsState = usePrimitiveState(widgetCtx.sessionCtx.sessionsState);\n\n const { openSessions, closedSessions } = useMemo(() => {\n return {\n openSessions: sessionsState.data.filter((s) => s.isOpened === true),\n closedSessions: sessionsState.data.filter((s) => s.isOpened === false),\n };\n }, [sessionsState.data]);\n\n const canCreateNewSession = useMemo(() => {\n if (oneOpenSessionAllowed) {\n return openSessions.length === 0;\n }\n return true;\n }, [oneOpenSessionAllowed, openSessions.length]);\n\n return {\n sessionState,\n sessionsState,\n loadMoreSessions: widgetCtx.sessionCtx.loadMoreSessions,\n resolveSession: widgetCtx.sessionCtx.resolveSession,\n createStateCheckpoint: widgetCtx.sessionCtx.createStateCheckpoint,\n openSessions,\n closedSessions,\n canCreateNewSession,\n };\n}\n","import { useMessages } from './useMessages';\nimport { useSessions } from './useSessions';\n\nexport function useIsAwaitingBotReply() {\n const { sessionState } = useSessions();\n const { messagesState } = useMessages();\n\n const isSessionAssignedToAI = sessionState.session?.assignee.kind === 'ai';\n // This check is useful in cases where the user might navigate in and out of a chat, and `isSendingMessage` is reset back to its default value\n const lastMessage =\n messagesState.messages.length > 0\n ? messagesState.messages[messagesState.messages.length - 1]\n : null;\n const isLastMessageAUserMessage = lastMessage?.type === 'USER';\n\n const isAwaitingBotReply =\n (isSessionAssignedToAI || sessionState.isCreatingSession) &&\n (messagesState.isSendingMessage || isLastMessageAUserMessage);\n\n return { isAwaitingBotReply };\n}\n","import useSWR from 'swr';\nimport { useWidget } from '../WidgetProvider';\n\nfunction usePreludeData() {\n const { widgetCtx } = useWidget();\n\n // TODO remove swr dependency\n return useSWR([widgetCtx.config.token], widgetCtx.api.widgetPrelude, {\n revalidateOnFocus: false,\n });\n}\n\nexport { usePreludeData };\n","import { useWidget } from '../WidgetProvider';\nimport { usePrimitiveState } from './usePrimitiveState';\n\nexport function useWidgetRouter() {\n const { widgetCtx } = useWidget();\n\n const routerState = usePrimitiveState(widgetCtx.routerCtx.state);\n\n return {\n routerState,\n toSessionsScreen: widgetCtx.routerCtx.toSessionsScreen,\n toChatScreen: widgetCtx.routerCtx.toChatScreen,\n };\n}\n","import { useEffect, useMemo, useState } from 'react';\nimport { useWidget } from '../WidgetProvider';\nimport { v4 } from 'uuid';\n\nconst uploadAbortControllers: Map<string, AbortController> = new Map();\n\ninterface FileWithProgress {\n status: 'pending' | 'uploading' | 'success' | 'error';\n id: string;\n file: File;\n fileUrl?: string;\n progress: number;\n error?: string;\n}\n\nfunction useUploadFiles() {\n const [files, setFiles] = useState<FileWithProgress[]>([]);\n const {\n widgetCtx: { api },\n } = useWidget();\n function appendFiles(files: File[]) {\n const newFiles = files.map((file) => ({\n file,\n id: v4(),\n status: 'pending' as const,\n progress: 0,\n }));\n\n setFiles((prev) => [...prev, ...newFiles]);\n newFiles.forEach(uploadFile);\n }\n\n function updateFileById(id: string, update: Partial<FileWithProgress>) {\n setFiles((prev) =>\n prev.map((f) => (f.id === id ? { ...f, ...update } : f)),\n );\n }\n\n function removeFileById(id: string) {\n setFiles((prev) => prev.filter((f) => f.id !== id));\n }\n\n const uploadFile = async (fileItem: FileWithProgress) => {\n const controller = new AbortController();\n uploadAbortControllers.set(fileItem.id, controller);\n\n try {\n setFiles((prev) =>\n prev.map((f) =>\n f.id === fileItem.id ? { ...f, status: 'uploading', progress: 0 } : f,\n ),\n );\n\n const response = await api.uploadFile({\n file: fileItem.file,\n abortSignal: controller.signal,\n onProgress: (percentage) => {\n updateFileById(fileItem.id, { progress: percentage });\n },\n });\n\n updateFileById(fileItem.id, {\n status: 'success',\n fileUrl: response.fileUrl,\n progress: 100,\n });\n } catch (error) {\n if (!controller.signal.aborted) {\n updateFileById(fileItem.id, {\n status: 'error',\n error: error instanceof Error ? error.message : 'Upload failed',\n progress: 0,\n });\n }\n } finally {\n uploadAbortControllers.delete(fileItem.id);\n }\n };\n\n const handleCancelUpload = (fileId: string) => {\n const controller = uploadAbortControllers.get(fileId);\n if (controller) {\n controller.abort();\n uploadAbortControllers.delete(fileId);\n }\n removeFileById(fileId);\n };\n\n const successFiles = useMemo(() => {\n return files.filter((f) => f.status === 'success' && f.fileUrl);\n }, [files]);\n\n function emptyTheFiles() {\n uploadAbortControllers.forEach((controller) => controller.abort());\n uploadAbortControllers.clear();\n setFiles([]);\n }\n\n useEffect(() => {\n return () => {\n uploadAbortControllers.forEach((controller) => controller.abort());\n uploadAbortControllers.clear();\n };\n }, []);\n\n return {\n allFiles: files,\n appendFiles,\n handleCancelUpload,\n successFiles,\n emptyTheFiles,\n getFileById: (id: string) => files.find((f) => f.id === id),\n getUploadProgress: (id: string) =>\n files.find((f) => f.id === id)?.progress ?? 0,\n getUploadStatus: (id: string) => files.find((f) => f.id === id)?.status,\n hasErrors: files.some((f) => f.status === 'error'),\n isUploading: files.some((f) => f.status === 'uploading'),\n };\n}\n\nexport { useUploadFiles, type FileWithProgress };\n","import React, {\n createContext,\n useContext,\n useEffect,\n useState,\n type Dispatch,\n type ReactNode,\n type SetStateAction,\n} from 'react';\nimport { useConfig } from './useConfig';\n\ntype WidgetTriggerCtx = {\n isOpen: boolean;\n setIsOpen: Dispatch<SetStateAction<boolean>>;\n};\n\nconst context = createContext<WidgetTriggerCtx | null>(null);\n\nexport function WidgetTriggerProvider({ children }: { children: ReactNode }) {\n const config = useConfig();\n const [isOpen, setIsOpen] = useState(() => {\n if (config.inline) return true;\n return config.isOpen ?? false;\n });\n\n useEffect(() => {\n setIsOpen((prev) => config.isOpen ?? prev);\n }, [config.isOpen]);\n\n useEffect(() => {\n const openAfterNSeconds = config.openAfterNSeconds;\n if (typeof openAfterNSeconds !== 'number' || isNaN(openAfterNSeconds))\n return;\n\n const timeout = setTimeout(() => setIsOpen(true), openAfterNSeconds * 1000);\n\n return () => clearTimeout(timeout);\n }, [config.openAfterNSeconds]);\n\n return (\n <context.Provider value={{ isOpen, setIsOpen }}>\n {children}\n </context.Provider>\n );\n}\n\nexport function useWidgetTrigger() {\n const ctx = useContext(context);\n if (!ctx) {\n throw new Error(\n 'useWidgetTrigger must be used within a WidgetTriggerProvider',\n );\n }\n return ctx;\n}\n","import { useWidget } from '../WidgetProvider';\nimport { useConfig } from './useConfig';\nimport { useSessions } from './useSessions';\n\nexport function useModes() {\n const { widgetCtx } = useWidget();\n const { modesComponents } = useConfig();\n const { sessionState } = useSessions();\n\n const modes = widgetCtx.modes;\n const activeModeId = sessionState.session?.modeId;\n const activeMode = modes.find((mode) => mode.id === activeModeId);\n\n const Component = modesComponents?.find((modeComponent) =>\n [\n activeMode?.id || '',\n activeMode?.name?.toLowerCase() || '',\n activeMode?.slug?.toLowerCase() || '',\n ].includes(modeComponent.key.toLowerCase()),\n )?.component;\n\n return {\n modes,\n modesComponents,\n activeModeId,\n activeMode,\n Component,\n };\n}\n","import type {\n WidgetSystemMessage__CsatRequested,\n WidgetSystemMessage__CsatSubmitted,\n} from '@opencx/widget-core';\nimport { useMemo } from 'react';\nimport { useMessages } from './useMessages';\nimport { useWidget } from '../WidgetProvider';\n\nexport function useCsat() {\n const { widgetCtx } = useWidget();\n const {\n messagesState: { messages },\n } = useMessages();\n\n const {\n csatRequestedMessage,\n isCsatRequested,\n csatSubmittedMessage,\n isCsatSubmitted,\n submittedScore,\n submittedFeedback,\n } = useMemo(() => {\n const csatRequestedMessage = messages.find(\n (message): message is WidgetSystemMessage__CsatRequested =>\n message.type === 'SYSTEM' && message.subtype === 'csat_requested',\n );\n const csatSubmittedMessage = messages.findLast(\n (message): message is WidgetSystemMessage__CsatSubmitted =>\n message.type === 'SYSTEM' && message.subtype === 'csat_submitted',\n );\n\n return {\n csatRequestedMessage,\n isCsatRequested: !!csatRequestedMessage && !csatSubmittedMessage,\n csatSubmittedMessage,\n isCsatSubmitted: !!csatSubmittedMessage,\n submittedScore: csatSubmittedMessage?.data.payload.score,\n submittedFeedback: csatSubmittedMessage?.data.payload.feedback,\n };\n }, [messages]);\n\n return {\n submitCsat: widgetCtx.csatCtx.submitCsat,\n csatRequestedMessage,\n isCsatRequested,\n csatSubmittedMessage,\n isCsatSubmitted,\n submittedScore,\n submittedFeedback,\n };\n}\n"],"names":["ComponentRegistry","opts","components","c","component","index","key","_a","context","createContext","WidgetProvider","config","children","storage","loadingComponent","contentIframeRef","useRef","didInitialize","widgetCtx","setWidgetCtx","useState","componentStore","useMemo","useEffect","WidgetCtx","React","version","useWidget","ctx","useContext","useConfig","usePrimitiveState","p","useSyncExternalStore","useContact","useDocumentDir","dir","setDir","updateDir","observer","useMessages","useSessions","oneOpenSessionAllowed","sessionState","sessionsState","openSessions","closedSessions","s","canCreateNewSession","useIsAwaitingBotReply","messagesState","isSessionAssignedToAI","lastMessage","isLastMessageAUserMessage","usePreludeData","useSWR","useWidgetRouter","uploadAbortControllers","useUploadFiles","files","setFiles","api","appendFiles","newFiles","file","v4","prev","uploadFile","updateFileById","id","update","f","removeFileById","fileItem","controller","response","percentage","error","handleCancelUpload","fileId","successFiles","emptyTheFiles","WidgetTriggerProvider","isOpen","setIsOpen","openAfterNSeconds","timeout","useWidgetTrigger","useModes","modesComponents","modes","activeModeId","activeMode","mode","Component","_b","modeComponent","useCsat","messages","csatRequestedMessage","isCsatRequested","csatSubmittedMessage","isCsatSubmitted","submittedScore","submittedFeedback","message"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../src/ComponentRegistry.ts","../src/WidgetProvider.tsx","../src/hooks/useConfig.ts","../src/hooks/usePrimitiveState.ts","../src/hooks/useContact.ts","../src/hooks/useDocumentDir.ts","../src/hooks/useMessages.ts","../src/hooks/useSessions.ts","../src/hooks/useIsAwaitingBotReply.ts","../src/hooks/useWidgetRouter.ts","../src/hooks/useUploadFiles.ts","../src/hooks/useWidgetTrigger.tsx","../src/hooks/useModes.ts","../src/hooks/useCsat.ts"],"sourcesContent":["import type { WidgetComponentKey } from '@opencx/widget-core';\nimport type { WidgetComponentType } from './types/components';\n\nexport class ComponentRegistry {\n components: WidgetComponentType[] = [];\n\n constructor(opts: { components?: WidgetComponentType[] }) {\n const { components } = opts;\n\n if (components) {\n components.forEach((c) => this.register(c));\n }\n\n if (this.components.length === 0) {\n throw new Error('No components registered');\n }\n if (!this.get('fallback')) {\n throw new Error('No fallback component registered');\n }\n }\n\n // TODO test that this registers or replaces the component\n register(component: WidgetComponentType) {\n // Replace the key if it already exists\n const index = this.components.findIndex((c) => c.key === component.key);\n if (index !== -1) {\n this.components[index] = component;\n } else {\n this.components.push(component);\n }\n return this;\n }\n\n private get(key: WidgetComponentKey) {\n const c = this.components.find(\n (c) => c.key.toUpperCase() === key.toUpperCase(),\n );\n if (c) return c;\n return null;\n }\n\n public getComponent(key: string) {\n return this.get(key)?.component;\n }\n}\n","import React, {\n createContext,\n useContext,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { version } from '../package.json';\nimport {\n type ExternalStorage,\n type WidgetConfig,\n WidgetCtx,\n} from '@opencx/widget-core';\nimport { ComponentRegistry } from './ComponentRegistry';\nimport type { WidgetComponentType } from './types/components';\n\ninterface WidgetProviderValue {\n widgetCtx: WidgetCtx;\n config: WidgetConfig;\n components?: WidgetComponentType[];\n componentStore: ComponentRegistry;\n version: string;\n contentIframeRef?: React.MutableRefObject<HTMLIFrameElement | null>;\n}\n\nconst context = createContext<WidgetProviderValue | null>(null);\n\nexport function WidgetProvider({\n options: config,\n children,\n components,\n storage,\n loadingComponent,\n}: {\n options: WidgetConfig;\n children: React.ReactNode;\n components?: WidgetComponentType[];\n storage?: ExternalStorage;\n /**\n * Custom loading component while the widget is initializing\n * Not to be confused with the `loading` custom component which renders when the bot's reply is pending\n */\n loadingComponent?: React.ReactNode;\n}) {\n const contentIframeRef = useRef<HTMLIFrameElement | null>(null);\n\n const didInitialize = useRef(false);\n const [widgetCtx, setWidgetCtx] = useState<WidgetCtx | null>(null);\n\n const componentStore = useMemo(\n () =>\n new ComponentRegistry({\n components: components,\n }),\n [components],\n );\n\n useEffect(() => {\n if (didInitialize.current) return;\n didInitialize.current = true;\n\n WidgetCtx.initialize({ config, storage })\n .then(setWidgetCtx)\n .catch(console.error);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n if (!widgetCtx) {\n return loadingComponent || null;\n }\n\n return (\n <context.Provider\n value={{\n widgetCtx,\n config,\n components,\n componentStore,\n version,\n contentIframeRef,\n }}\n >\n {children}\n </context.Provider>\n );\n}\n\nexport function useWidget() {\n const ctx = useContext(context);\n if (!ctx) {\n throw new Error('useWidget must be used within a WidgetProvider');\n }\n return ctx;\n}\n","import { useWidget } from '../WidgetProvider';\n\nexport function useConfig() {\n const { config } = useWidget();\n\n return config;\n}\n","import { useSyncExternalStore } from 'react';\nimport type { PrimitiveState } from '@opencx/widget-core';\n\nexport function usePrimitiveState<T>(p: PrimitiveState<T>) {\n return useSyncExternalStore(p.subscribe, p.get, p.get);\n}\n","import { useWidget } from '../WidgetProvider';\nimport { usePrimitiveState } from './usePrimitiveState';\n\nexport function useContact() {\n const { widgetCtx } = useWidget();\n const contactState = usePrimitiveState(widgetCtx.contactCtx.state);\n\n return {\n contactState,\n createUnverifiedContact: widgetCtx.contactCtx.createUnverifiedContact,\n };\n}\n","import { useEffect, useState } from 'react';\nimport type { StringOrLiteral } from '@opencx/widget-core';\n\nexport function useDocumentDir() {\n const [dir, setDir] = useState<StringOrLiteral<'ltr' | 'rtl'>>('ltr');\n\n useEffect(() => {\n const updateDir = () => {\n if (typeof document === 'undefined') return;\n setDir(\n window.getComputedStyle((window.top || window).document.body).direction,\n );\n };\n\n // Set initial direction\n updateDir();\n\n // Watch for direction changes on both document and documentElement\n const observer = new MutationObserver(updateDir);\n\n // Observe both document and documentElement\n observer.observe(document.documentElement, {\n attributes: true,\n attributeFilter: ['dir'],\n });\n\n observer.observe(document.body, {\n attributes: true,\n attributeFilter: ['dir'],\n });\n\n // Add event listener for dynamic changes\n window.addEventListener('languagechange', updateDir);\n\n return () => {\n observer.disconnect();\n window.removeEventListener('languagechange', updateDir);\n };\n }, []);\n\n return { dir };\n}\n","import { usePrimitiveState } from './usePrimitiveState';\nimport { useWidget } from '../WidgetProvider';\n\nexport function useMessages() {\n const { widgetCtx } = useWidget();\n const messagesState = usePrimitiveState(widgetCtx.messageCtx.state);\n\n return { messagesState, sendMessage: widgetCtx.messageCtx.sendMessage };\n}\n","import { useMemo } from 'react';\nimport { useWidget } from '../WidgetProvider';\nimport { usePrimitiveState } from './usePrimitiveState';\nimport { useConfig } from './useConfig';\n\nexport function useSessions() {\n const { widgetCtx } = useWidget();\n const { oneOpenSessionAllowed } = useConfig();\n const sessionState = usePrimitiveState(widgetCtx.sessionCtx.sessionState);\n const sessionsState = usePrimitiveState(widgetCtx.sessionCtx.sessionsState);\n\n const { openSessions, closedSessions } = useMemo(() => {\n return {\n openSessions: sessionsState.data.filter((s) => s.isOpened === true),\n closedSessions: sessionsState.data.filter((s) => s.isOpened === false),\n };\n }, [sessionsState.data]);\n\n const canCreateNewSession = useMemo(() => {\n if (oneOpenSessionAllowed) {\n return openSessions.length === 0;\n }\n return true;\n }, [oneOpenSessionAllowed, openSessions.length]);\n\n return {\n sessionState,\n sessionsState,\n loadMoreSessions: widgetCtx.sessionCtx.loadMoreSessions,\n resolveSession: widgetCtx.sessionCtx.resolveSession,\n createStateCheckpoint: widgetCtx.sessionCtx.createStateCheckpoint,\n openSessions,\n closedSessions,\n canCreateNewSession,\n };\n}\n","import { useMessages } from './useMessages';\nimport { useSessions } from './useSessions';\n\nexport function useIsAwaitingBotReply() {\n const { sessionState } = useSessions();\n const { messagesState } = useMessages();\n\n const isSessionAssignedToAI = sessionState.session?.assignee.kind === 'ai';\n // This check is useful in cases where the user might navigate in and out of a chat, and `isSendingMessage` is reset back to its default value\n const lastMessage =\n messagesState.messages.length > 0\n ? messagesState.messages[messagesState.messages.length - 1]\n : null;\n const isLastMessageAUserMessage = lastMessage?.type === 'USER';\n\n const isAwaitingBotReply =\n (isSessionAssignedToAI || sessionState.isCreatingSession) &&\n (messagesState.isSendingMessage || isLastMessageAUserMessage);\n\n return { isAwaitingBotReply };\n}\n","import { useWidget } from '../WidgetProvider';\nimport { usePrimitiveState } from './usePrimitiveState';\n\nexport function useWidgetRouter() {\n const { widgetCtx } = useWidget();\n\n const routerState = usePrimitiveState(widgetCtx.routerCtx.state);\n\n return {\n routerState,\n toSessionsScreen: widgetCtx.routerCtx.toSessionsScreen,\n toChatScreen: widgetCtx.routerCtx.toChatScreen,\n };\n}\n","import { useEffect, useMemo, useState } from 'react';\nimport { useWidget } from '../WidgetProvider';\nimport { v4 } from 'uuid';\n\nconst uploadAbortControllers: Map<string, AbortController> = new Map();\n\ninterface FileWithProgress {\n status: 'pending' | 'uploading' | 'success' | 'error';\n id: string;\n file: File;\n fileUrl?: string;\n progress: number;\n error?: string;\n}\n\nfunction useUploadFiles() {\n const [files, setFiles] = useState<FileWithProgress[]>([]);\n const {\n widgetCtx: { api },\n } = useWidget();\n function appendFiles(files: File[]) {\n const newFiles = files.map((file) => ({\n file,\n id: v4(),\n status: 'pending' as const,\n progress: 0,\n }));\n\n setFiles((prev) => [...prev, ...newFiles]);\n newFiles.forEach(uploadFile);\n }\n\n function updateFileById(id: string, update: Partial<FileWithProgress>) {\n setFiles((prev) =>\n prev.map((f) => (f.id === id ? { ...f, ...update } : f)),\n );\n }\n\n function removeFileById(id: string) {\n setFiles((prev) => prev.filter((f) => f.id !== id));\n }\n\n const uploadFile = async (fileItem: FileWithProgress) => {\n const controller = new AbortController();\n uploadAbortControllers.set(fileItem.id, controller);\n\n try {\n setFiles((prev) =>\n prev.map((f) =>\n f.id === fileItem.id ? { ...f, status: 'uploading', progress: 0 } : f,\n ),\n );\n\n const response = await api.uploadFile({\n file: fileItem.file,\n abortSignal: controller.signal,\n onProgress: (percentage) => {\n updateFileById(fileItem.id, { progress: percentage });\n },\n });\n\n updateFileById(fileItem.id, {\n status: 'success',\n fileUrl: response.fileUrl,\n progress: 100,\n });\n } catch (error) {\n if (!controller.signal.aborted) {\n updateFileById(fileItem.id, {\n status: 'error',\n error: error instanceof Error ? error.message : 'Upload failed',\n progress: 0,\n });\n }\n } finally {\n uploadAbortControllers.delete(fileItem.id);\n }\n };\n\n const handleCancelUpload = (fileId: string) => {\n const controller = uploadAbortControllers.get(fileId);\n if (controller) {\n controller.abort();\n uploadAbortControllers.delete(fileId);\n }\n removeFileById(fileId);\n };\n\n const successFiles = useMemo(() => {\n return files.filter((f) => f.status === 'success' && f.fileUrl);\n }, [files]);\n\n function emptyTheFiles() {\n uploadAbortControllers.forEach((controller) => controller.abort());\n uploadAbortControllers.clear();\n setFiles([]);\n }\n\n useEffect(() => {\n return () => {\n uploadAbortControllers.forEach((controller) => controller.abort());\n uploadAbortControllers.clear();\n };\n }, []);\n\n return {\n allFiles: files,\n appendFiles,\n handleCancelUpload,\n successFiles,\n emptyTheFiles,\n getFileById: (id: string) => files.find((f) => f.id === id),\n getUploadProgress: (id: string) =>\n files.find((f) => f.id === id)?.progress ?? 0,\n getUploadStatus: (id: string) => files.find((f) => f.id === id)?.status,\n hasErrors: files.some((f) => f.status === 'error'),\n isUploading: files.some((f) => f.status === 'uploading'),\n };\n}\n\nexport { useUploadFiles, type FileWithProgress };\n","import React, {\n createContext,\n useContext,\n useEffect,\n useState,\n type Dispatch,\n type ReactNode,\n type SetStateAction,\n} from 'react';\nimport { useConfig } from './useConfig';\n\ntype WidgetTriggerCtx = {\n isOpen: boolean;\n setIsOpen: Dispatch<SetStateAction<boolean>>;\n};\n\nconst context = createContext<WidgetTriggerCtx | null>(null);\n\nexport function WidgetTriggerProvider({ children }: { children: ReactNode }) {\n const config = useConfig();\n const [isOpen, setIsOpen] = useState(() => {\n if (config.inline) return true;\n return config.isOpen ?? false;\n });\n\n useEffect(() => {\n setIsOpen((prev) => config.isOpen ?? prev);\n }, [config.isOpen]);\n\n useEffect(() => {\n const openAfterNSeconds = config.openAfterNSeconds;\n if (typeof openAfterNSeconds !== 'number' || isNaN(openAfterNSeconds))\n return;\n\n const timeout = setTimeout(() => setIsOpen(true), openAfterNSeconds * 1000);\n\n return () => clearTimeout(timeout);\n }, [config.openAfterNSeconds]);\n\n return (\n <context.Provider value={{ isOpen, setIsOpen }}>\n {children}\n </context.Provider>\n );\n}\n\nexport function useWidgetTrigger() {\n const ctx = useContext(context);\n if (!ctx) {\n throw new Error(\n 'useWidgetTrigger must be used within a WidgetTriggerProvider',\n );\n }\n return ctx;\n}\n","import { useWidget } from '../WidgetProvider';\nimport { useConfig } from './useConfig';\nimport { useSessions } from './useSessions';\n\nexport function useModes() {\n const { widgetCtx } = useWidget();\n const { modesComponents } = useConfig();\n const { sessionState } = useSessions();\n\n const modes = widgetCtx.modes;\n const activeModeId = sessionState.session?.modeId;\n const activeMode = modes.find((mode) => mode.id === activeModeId);\n\n const Component = modesComponents?.find((modeComponent) =>\n [\n activeMode?.id || '',\n activeMode?.name?.toLowerCase() || '',\n activeMode?.slug?.toLowerCase() || '',\n ].includes(modeComponent.key.toLowerCase()),\n )?.component;\n\n return {\n modes,\n modesComponents,\n activeModeId,\n activeMode,\n Component,\n };\n}\n","import type {\n WidgetSystemMessage__CsatRequested,\n WidgetSystemMessage__CsatSubmitted,\n} from '@opencx/widget-core';\nimport { useMemo } from 'react';\nimport { useMessages } from './useMessages';\nimport { useWidget } from '../WidgetProvider';\n\nexport function useCsat() {\n const { widgetCtx } = useWidget();\n const {\n messagesState: { messages },\n } = useMessages();\n\n const {\n csatRequestedMessage,\n isCsatRequested,\n csatSubmittedMessage,\n isCsatSubmitted,\n submittedScore,\n submittedFeedback,\n } = useMemo(() => {\n const csatRequestedMessage = messages.find(\n (message): message is WidgetSystemMessage__CsatRequested =>\n message.type === 'SYSTEM' && message.subtype === 'csat_requested',\n );\n const csatSubmittedMessage = messages.findLast(\n (message): message is WidgetSystemMessage__CsatSubmitted =>\n message.type === 'SYSTEM' && message.subtype === 'csat_submitted',\n );\n\n return {\n csatRequestedMessage,\n isCsatRequested: !!csatRequestedMessage && !csatSubmittedMessage,\n csatSubmittedMessage,\n isCsatSubmitted: !!csatSubmittedMessage,\n submittedScore: csatSubmittedMessage?.data.payload.score,\n submittedFeedback: csatSubmittedMessage?.data.payload.feedback,\n };\n }, [messages]);\n\n return {\n submitCsat: widgetCtx.csatCtx.submitCsat,\n csatRequestedMessage,\n isCsatRequested,\n csatSubmittedMessage,\n isCsatSubmitted,\n submittedScore,\n submittedFeedback,\n };\n}\n"],"names":["ComponentRegistry","opts","components","c","component","index","key","_a","context","createContext","WidgetProvider","config","children","storage","loadingComponent","contentIframeRef","useRef","didInitialize","widgetCtx","setWidgetCtx","useState","componentStore","useMemo","useEffect","WidgetCtx","React","version","useWidget","ctx","useContext","useConfig","usePrimitiveState","p","useSyncExternalStore","useContact","useDocumentDir","dir","setDir","updateDir","observer","useMessages","useSessions","oneOpenSessionAllowed","sessionState","sessionsState","openSessions","closedSessions","s","canCreateNewSession","useIsAwaitingBotReply","messagesState","isSessionAssignedToAI","lastMessage","isLastMessageAUserMessage","useWidgetRouter","uploadAbortControllers","useUploadFiles","files","setFiles","api","appendFiles","newFiles","file","v4","prev","uploadFile","updateFileById","id","update","f","removeFileById","fileItem","controller","response","percentage","error","handleCancelUpload","fileId","successFiles","emptyTheFiles","WidgetTriggerProvider","isOpen","setIsOpen","openAfterNSeconds","timeout","useWidgetTrigger","useModes","modesComponents","modes","activeModeId","activeMode","mode","Component","_b","modeComponent","useCsat","messages","csatRequestedMessage","isCsatRequested","csatSubmittedMessage","isCsatSubmitted","submittedScore","submittedFeedback","message"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WidgetProvider.d.ts","sourceRoot":"","sources":["../../src/WidgetProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,KAON,MAAM,OAAO,CAAC;AAEf,OAAO,
|
|
1
|
+
{"version":3,"file":"WidgetProvider.d.ts","sourceRoot":"","sources":["../../src/WidgetProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,KAON,MAAM,OAAO,CAAC;AAEf,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,YAAY,EACjB,SAAS,EACV,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAE9D,UAAU,mBAAmB;IAC3B,SAAS,EAAE,SAAS,CAAC;IACrB,MAAM,EAAE,YAAY,CAAC;IACrB,UAAU,CAAC,EAAE,mBAAmB,EAAE,CAAC;IACnC,cAAc,EAAE,iBAAiB,CAAC;IAClC,OAAO,EAAE,MAAM,CAAC;IAChB,gBAAgB,CAAC,EAAE,KAAK,CAAC,gBAAgB,CAAC,iBAAiB,GAAG,IAAI,CAAC,CAAC;CACrE;AAID,wBAAgB,cAAc,CAAC,EAC7B,OAAO,EAAE,MAAM,EACf,QAAQ,EACR,UAAU,EACV,OAAO,EACP,gBAAgB,GACjB,EAAE;IACD,OAAO,EAAE,YAAY,CAAC;IACtB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,UAAU,CAAC,EAAE,mBAAmB,EAAE,CAAC;IACnC,OAAO,CAAC,EAAE,eAAe,CAAC;IAC1B;;;OAGG;IACH,gBAAgB,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CACpC,oRA0CA;AAED,wBAAgB,SAAS,wBAMxB"}
|
package/dist/src/index.d.ts
CHANGED
|
@@ -5,7 +5,6 @@ export { useContact } from './hooks/useContact';
|
|
|
5
5
|
export { useDocumentDir } from './hooks/useDocumentDir';
|
|
6
6
|
export { useIsAwaitingBotReply } from './hooks/useIsAwaitingBotReply';
|
|
7
7
|
export { useMessages } from './hooks/useMessages';
|
|
8
|
-
export { usePreludeData } from './hooks/usePreludeData';
|
|
9
8
|
export { usePrimitiveState } from './hooks/usePrimitiveState';
|
|
10
9
|
export { useSessions } from './hooks/useSessions';
|
|
11
10
|
export { useWidgetRouter } from './hooks/useWidgetRouter';
|
package/dist/src/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,YAAY,EACV,mBAAmB,EACnB,oBAAoB,GACrB,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7D,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,qBAAqB,EAAE,MAAM,+BAA+B,CAAC;AACtE,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,YAAY,EACV,mBAAmB,EACnB,oBAAoB,GACrB,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7D,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,qBAAqB,EAAE,MAAM,+BAA+B,CAAC;AACtE,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,KAAK,gBAAgB,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAC/E,OAAO,EACL,gBAAgB,EAChB,qBAAqB,GACtB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@opencx/widget-react-headless",
|
|
3
3
|
"private": false,
|
|
4
|
-
"version": "4.0.
|
|
4
|
+
"version": "4.0.15",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"repository": {
|
|
7
7
|
"type": "git",
|
|
@@ -20,7 +20,7 @@
|
|
|
20
20
|
"dependencies": {
|
|
21
21
|
"swr": "^2.2.5",
|
|
22
22
|
"uuid": "^11.0.4",
|
|
23
|
-
"@opencx/widget-core": "4.0.
|
|
23
|
+
"@opencx/widget-core": "4.0.15"
|
|
24
24
|
},
|
|
25
25
|
"peerDependencies": {
|
|
26
26
|
"@types/react": ">=18 <20",
|
|
@@ -29,8 +29,8 @@
|
|
|
29
29
|
"react-dom": ">=18 <20"
|
|
30
30
|
},
|
|
31
31
|
"devDependencies": {
|
|
32
|
-
"@opencx/
|
|
33
|
-
"@opencx/
|
|
32
|
+
"@opencx/eslint-config": "0.0.0",
|
|
33
|
+
"@opencx/tsconfig": "0.0.1"
|
|
34
34
|
},
|
|
35
35
|
"scripts": {
|
|
36
36
|
"clean": "rm -rf node_modules dist .turbo",
|
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
declare function usePreludeData(): import('swr').SWRResponse<import('openapi-fetch').FetchResponse<{
|
|
2
|
-
parameters: {
|
|
3
|
-
query?: never;
|
|
4
|
-
header: {
|
|
5
|
-
"X-Bot-Token": string;
|
|
6
|
-
};
|
|
7
|
-
path?: never;
|
|
8
|
-
cookie?: never;
|
|
9
|
-
};
|
|
10
|
-
requestBody?: never;
|
|
11
|
-
responses: {
|
|
12
|
-
200: {
|
|
13
|
-
headers: {
|
|
14
|
-
[name: string]: unknown;
|
|
15
|
-
};
|
|
16
|
-
content: {
|
|
17
|
-
"application/json": {
|
|
18
|
-
initialQuestions: string[];
|
|
19
|
-
aiEnabled: boolean;
|
|
20
|
-
officeHours: unknown & {
|
|
21
|
-
monday?: {
|
|
22
|
-
from: string;
|
|
23
|
-
to: string;
|
|
24
|
-
};
|
|
25
|
-
tuesday?: {
|
|
26
|
-
from: string;
|
|
27
|
-
to: string;
|
|
28
|
-
};
|
|
29
|
-
wednesday?: {
|
|
30
|
-
from: string;
|
|
31
|
-
to: string;
|
|
32
|
-
};
|
|
33
|
-
thursday?: {
|
|
34
|
-
from: string;
|
|
35
|
-
to: string;
|
|
36
|
-
};
|
|
37
|
-
friday?: {
|
|
38
|
-
from: string;
|
|
39
|
-
to: string;
|
|
40
|
-
};
|
|
41
|
-
saturday?: {
|
|
42
|
-
from: string;
|
|
43
|
-
to: string;
|
|
44
|
-
};
|
|
45
|
-
sunday?: {
|
|
46
|
-
from: string;
|
|
47
|
-
to: string;
|
|
48
|
-
};
|
|
49
|
-
Everyday?: {
|
|
50
|
-
from: string;
|
|
51
|
-
to: string;
|
|
52
|
-
};
|
|
53
|
-
WeekDays?: {
|
|
54
|
-
from: string;
|
|
55
|
-
to: string;
|
|
56
|
-
};
|
|
57
|
-
};
|
|
58
|
-
officeHoursTimezone: string | null;
|
|
59
|
-
organizationName: string;
|
|
60
|
-
};
|
|
61
|
-
};
|
|
62
|
-
};
|
|
63
|
-
500: {
|
|
64
|
-
headers: {
|
|
65
|
-
[name: string]: unknown;
|
|
66
|
-
};
|
|
67
|
-
content: {
|
|
68
|
-
"application/json": {
|
|
69
|
-
statusCode?: number;
|
|
70
|
-
message?: string;
|
|
71
|
-
error?: string;
|
|
72
|
-
};
|
|
73
|
-
};
|
|
74
|
-
};
|
|
75
|
-
};
|
|
76
|
-
}, {
|
|
77
|
-
params: {
|
|
78
|
-
header: {
|
|
79
|
-
"X-Bot-Token": string;
|
|
80
|
-
};
|
|
81
|
-
};
|
|
82
|
-
}, `${string}/${string}`>, any, {
|
|
83
|
-
revalidateOnFocus: false;
|
|
84
|
-
}>;
|
|
85
|
-
export { usePreludeData };
|
|
86
|
-
//# sourceMappingURL=usePreludeData.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"usePreludeData.d.ts","sourceRoot":"","sources":["../../../src/hooks/usePreludeData.ts"],"names":[],"mappings":"AAGA,iBAAS,cAAc;;aAUutC,CAAC;;;;YAAqG,CAAC;cAA2B,CAAC;;;;;;;;;;;;;8BAA62T,CAAC;;;;+BAAgH,CAAC;;;;iCAAkH,CAAC;;;;gCAAiH,CAAC;;;;8BAA+G,CAAC;;;;gCAAiH,CAAC;;;;8BAA+G,CAAC;;;;gCAAiH,CAAC;;;;gCAAiH,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAH1mY;AAED,OAAO,EAAE,cAAc,EAAE,CAAC"}
|