@opencx/widget 2.6.0 → 2.6.2

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.
Files changed (102) hide show
  1. package/dist/api-BEtFfKMB.cjs +2 -0
  2. package/dist/api-BEtFfKMB.cjs.map +1 -0
  3. package/dist/api-Cez5T-se.js +1393 -0
  4. package/dist/api-Cez5T-se.js.map +1 -0
  5. package/dist/basic.cjs +85 -85
  6. package/dist/basic.cjs.map +1 -1
  7. package/dist/basic.js +13159 -12639
  8. package/dist/basic.js.map +1 -1
  9. package/dist/core/client/api.d.ts +414 -40
  10. package/dist/core/client/chat.d.ts +33 -19
  11. package/dist/core/client/config.d.ts +13 -3
  12. package/dist/core/client/contact.d.ts +9 -13
  13. package/dist/core/client/index.d.ts +1 -1
  14. package/dist/core/index.d.ts +1 -1
  15. package/dist/core/sdk/index.d.ts +11 -0
  16. package/dist/core/types/contact.d.ts +2 -0
  17. package/dist/core/types/helpers.d.ts +5 -2
  18. package/dist/core/types/index.d.ts +6 -6
  19. package/dist/core/types/messages.d.ts +20 -9
  20. package/dist/core/types/schemas-v2.d.ts +10 -713
  21. package/dist/index-BzidnDPX.cjs +18 -0
  22. package/dist/index-BzidnDPX.cjs.map +1 -0
  23. package/dist/index-DUlnC30_.js +1219 -0
  24. package/dist/index-DUlnC30_.js.map +1 -0
  25. package/dist/index.cjs +1 -1
  26. package/dist/index.cjs.map +1 -1
  27. package/dist/index.js +22 -1071
  28. package/dist/index.js.map +1 -1
  29. package/dist/react-web/core-integration/ChatProvider.d.ts +107 -0
  30. package/dist/react-web/core-integration/components.d.ts +11 -0
  31. package/dist/react-web/core-integration/hooks/useChatMessages.d.ts +70 -0
  32. package/dist/react-web/core-integration/hooks/useChatSession.d.ts +83 -0
  33. package/dist/react-web/core-integration/hooks/useConfig.d.ts +1 -0
  34. package/dist/react-web/core-integration/hooks/useContact.d.ts +17 -0
  35. package/dist/react-web/core-integration/hooks/useLocale.d.ts +4 -0
  36. package/dist/react-web/core-integration/hooks/usePreludeData.d.ts +36 -0
  37. package/dist/react-web/core-integration/hooks/usePubsub.d.ts +2 -0
  38. package/dist/react-web/{hooks → core-integration/hooks}/useUploadFiles.d.ts +2 -2
  39. package/dist/react-web/{hooks → core-integration/hooks}/useVote.d.ts +2 -2
  40. package/dist/react-web/core-integration/hooks.d.ts +9 -0
  41. package/dist/react-web/core-integration/index.d.ts +2 -0
  42. package/dist/react-web/index.d.ts +4 -10
  43. package/dist/react-web/types/components.d.ts +6 -3
  44. package/dist/react-web/types/index.d.ts +3 -2
  45. package/dist/react-web/types/options.d.ts +4 -30
  46. package/dist/react.cjs +1 -1
  47. package/dist/react.cjs.map +1 -1
  48. package/dist/react.js +10 -46
  49. package/dist/react.js.map +1 -1
  50. package/dist/src/@components/BotOrAgentMessageGroup.d.ts +1 -2
  51. package/dist/src/@components/BotOrAgentMessageWrapper.d.ts +2 -2
  52. package/dist/src/@components/ChatEvent.component.d.ts +3 -3
  53. package/dist/src/@components/Text.component.d.ts +1 -1
  54. package/dist/src/components/button.d.ts +1 -1
  55. package/dist/src/components/dialog.d.ts +9 -9
  56. package/dist/src/designs/basic/index.d.ts +1 -1
  57. package/dist/style.css +1 -1
  58. package/dist-embed/script.js +119 -124
  59. package/dist-embed/script.js.map +1 -1
  60. package/package.json +7 -4
  61. package/dist/core/tests/utils/create-fetch.test.d.ts +0 -1
  62. package/dist/core/types/schemas.d.ts +0 -543
  63. package/dist/core/utils/create-fetch.d.ts +0 -25
  64. package/dist/core/utils/genId.d.ts +0 -2
  65. package/dist/core/utils/history-to-widget-messages.d.ts +0 -4
  66. package/dist/genUuid-C12yFv3j.js +0 -137
  67. package/dist/genUuid-C12yFv3j.js.map +0 -1
  68. package/dist/genUuid-DdeSE04H.cjs +0 -2
  69. package/dist/genUuid-DdeSE04H.cjs.map +0 -1
  70. package/dist/index-C87obATS.js +0 -2616
  71. package/dist/index-C87obATS.js.map +0 -1
  72. package/dist/index-ChwS_h0D.cjs +0 -18
  73. package/dist/index-ChwS_h0D.cjs.map +0 -1
  74. package/dist/package.json.d.ts +0 -158
  75. package/dist/react-web/Root.d.ts +0 -6
  76. package/dist/react-web/hooks/index.d.ts +0 -6
  77. package/dist/react-web/hooks/use-sound.d.ts +0 -13
  78. package/dist/react-web/hooks/use-sound.test.d.ts +0 -1
  79. package/dist/react-web/hooks/use-sync-state.test.d.ts +0 -1
  80. package/dist/react-web/hooks/useAbstractChat.d.ts +0 -157
  81. package/dist/react-web/hooks/useAxiosInstance.d.ts +0 -190
  82. package/dist/react-web/hooks/useSyncState.d.ts +0 -4
  83. package/dist/react-web/hooks/useTimeoutState.d.ts +0 -3
  84. package/dist/react-web/providers/ChatProvider.d.ts +0 -143
  85. package/dist/react-web/providers/ConfigDataProvider.d.ts +0 -62
  86. package/dist/react-web/providers/ContactProvider.d.ts +0 -58
  87. package/dist/react-web/providers/LocalesProvider.d.ts +0 -11
  88. package/dist/react-web/providers/componentRegistry.d.ts +0 -13
  89. package/dist/react-web/providers/use-widget-sfx.d.ts +0 -7
  90. package/dist/react-web/providers/usePreludeData.d.ts +0 -2
  91. package/dist/react-web/utils/debug.d.ts +0 -2
  92. package/dist/react-web/utils/getters.d.ts +0 -24
  93. package/dist/react-web/utils/index.d.ts +0 -1
  94. package/dist/src/hooks/useShouldCollectData.d.ts +0 -3
  95. /package/dist/react-web/{locales → core-integration/locales}/ar.locale.d.ts +0 -0
  96. /package/dist/react-web/{locales → core-integration/locales}/de.locale.d.ts +0 -0
  97. /package/dist/react-web/{locales → core-integration/locales}/en.locale.d.ts +0 -0
  98. /package/dist/react-web/{locales → core-integration/locales}/fr.locale.d.ts +0 -0
  99. /package/dist/react-web/{locales → core-integration/locales}/helper.d.ts +0 -0
  100. /package/dist/react-web/{locales → core-integration/locales}/index.d.ts +0 -0
  101. /package/dist/react-web/{locales → core-integration/locales}/nl.locale.d.ts +0 -0
  102. /package/dist/react-web/{locales → core-integration/locales}/pt.locale.d.ts +0 -0
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../core/types/pub-sub.ts","../core/errors/index.ts","../core/platform/storage.ts","../core/platform/logger.ts","../core/platform/audio.ts","../core/client/chat.ts","../core/client/contact.ts","../core/client/config.ts","../core/utils/create-fetch.ts","../core/client/api.ts"],"sourcesContent":["import isEqual from 'lodash.isequal';\n\nexport type Subscriber<T> = (data: T) => void\n\nexport enum LifecycleEvent {\n INIT = 'init',\n STATE_CHANGE = 'stateChange',\n BEFORE_UPDATE = 'beforeUpdate',\n AFTER_UPDATE = 'afterUpdate',\n DESTROY = 'destroy',\n ERROR = 'error'\n}\n\ntype LifecycleListener = (event: { type: LifecycleEvent; timestamp: number; data?: any }) => void;\n\nexport class PubSub<S> {\n private subscribers = new Set<Subscriber<S>>();\n #state: S;\n private initialState: S;\n #lastUpdated: number | null;\n private lifecycleListeners: Map<LifecycleEvent, Set<LifecycleListener>> = new Map();\n\n constructor(state: S) {\n this.#state = state;\n this.initialState = state;\n this.#lastUpdated = Date.now();\n this.emitLifecycle(LifecycleEvent.INIT, { initialState: this.#state });\n }\n\n private emitLifecycle = (event: LifecycleEvent, data?: any) => {\n const listeners = this.lifecycleListeners.get(event);\n if (listeners) {\n const eventData = {\n type: event,\n timestamp: Date.now(),\n data\n };\n listeners.forEach(listener => {\n try {\n listener(eventData);\n } catch (error) {\n console.error('Error in lifecycle listener:', error);\n }\n });\n }\n }\n\n private notifySubscribers = (state: S) => {\n const subscribersArray = Array.from(this.subscribers);\n subscribersArray.forEach(callback => {\n try {\n callback(state);\n } catch (error) {\n this.emitLifecycle(LifecycleEvent.ERROR, { error });\n console.error('Error in subscriber:', error);\n }\n });\n }\n\n /**\n * Subscribe to state changes\n * @param callback Function to call when state changes\n * @returns Unsubscribe function\n */\n subscribe = (callback: Subscriber<S>): () => void => {\n this.subscribers.add(callback);\n // Don't call the callback immediately with current state\n return () => {\n this.subscribers.delete(callback);\n };\n }\n\n onLifecycle = (event: LifecycleEvent, listener: LifecycleListener): () => void => {\n if (!this.lifecycleListeners.has(event)) {\n this.lifecycleListeners.set(event, new Set());\n }\n const listeners = this.lifecycleListeners.get(event)!;\n listeners.add(listener);\n\n return () => {\n listeners.delete(listener);\n if (listeners.size === 0) {\n this.lifecycleListeners.delete(event);\n }\n };\n }\n\n /**\n * Get the current state\n */\n getState = (): S => {\n return this.#state;\n }\n\n /**\n * Set the state and notify subscribers if the state changes\n * @param newState The new state to set\n */\n setState = (newState: S): void => {\n this.emitLifecycle(LifecycleEvent.BEFORE_UPDATE, {\n previousState: this.#state,\n nextState: newState\n });\n\n if (!isEqual(this.#state, newState)) {\n this.#state = newState;\n this.#lastUpdated = Date.now();\n this.emitLifecycle(LifecycleEvent.STATE_CHANGE, { state: newState });\n this.notifySubscribers(newState);\n }\n\n this.emitLifecycle(LifecycleEvent.AFTER_UPDATE, { state: newState });\n }\n\n setStatePartial = (_s: Partial<S>): void => {\n if (_s === undefined || _s === null) return;\n const newState = { ...this.#state, ..._s };\n this.setState(newState);\n }\n\n /**\n * Clear all subscriptions\n */\n clear = (): void => {\n this.emitLifecycle(LifecycleEvent.DESTROY);\n this.subscribers = new Set(); // Create a new Set instead of just clearing\n this.lifecycleListeners = new Map();\n }\n\n reset = (): void => {\n this.setState(this.initialState);\n }\n\n lastUpdated = (): number | null => {\n return this.#lastUpdated;\n }\n}\n\nexport function createPubSub<S>(state: S): PubSub<S> {\n return new PubSub<S>(state);\n}","export class OpenCXError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"OpenCXError\";\n }\n}\n\nexport class ConnectionError extends OpenCXError {\n constructor(message = \"Connection failed\") {\n super(message);\n this.name = \"ConnectionError\";\n }\n}\n\nexport class AuthenticationError extends OpenCXError {\n constructor(message = \"Authentication failed\") {\n super(message);\n this.name = \"AuthenticationError\";\n }\n}\n\nexport class SessionError extends OpenCXError {\n constructor(message = \"Session error occurred\") {\n super(message);\n this.name = \"SessionError\";\n }\n}\n\nexport class SessionNotDefinedError extends SessionError {\n constructor(message = \"Session not defined\") {\n super(message);\n this.name = \"SessionNotDefinedError\";\n }\n}\n\nexport class TransportError extends OpenCXError {\n constructor(message = \"Transport error occurred\") {\n super(message);\n this.name = \"TransportError\";\n }\n}\n\nexport class FileUploadError extends OpenCXError {\n constructor(message = \"File upload failed\") {\n super(message);\n this.name = \"FileUploadError\";\n }\n}\n\nexport class StorageNotAvailableError extends OpenCXError {\n constructor(message = \"Storage is not available\") {\n super(message);\n this.name = \"StorageNotAvailableError\";\n }\n}\n\nexport class ExternalIdNotDefinedError extends OpenCXError {\n constructor(message = \"External ID is not defined\") {\n super(message);\n this.name = \"ExternalIdNotDefinedError\";\n }\n}\n","/**\n * Platform-agnostic storage interface that can be implemented\n * for different environments (web, mobile, desktop, etc.)\n */\nexport interface Storage {\n /**\n * Retrieves the value associated with the given key\n * @param key The key to look up\n * @returns The stored value or null if not found\n */\n getItem(key: string): Promise<string | null>;\n\n /**\n * Stores a value with the given key\n * @param key The key to store under\n * @param value The value to store\n */\n setItem(key: string, value: string): Promise<void>;\n\n /**\n * Removes the value associated with the given key\n * @param key The key to remove\n */\n removeItem(key: string): Promise<void>;\n\n /**\n * Checks if the storage is available and working\n * @returns true if storage is available and working\n */\n isAvailable?(): boolean;\n}\n\n/**\n * Helper function to check if storage is available and working\n */\nexport function isStorageAvailable(storage: Storage | undefined): storage is Storage {\n if (!storage) return false;\n try {\n return typeof storage.isAvailable === 'function'\n ? storage.isAvailable()\n : true; // If isAvailable is not implemented, assume storage is available\n } catch {\n return false;\n }\n}\n\n/**\n * Type for the result of a safe storage operation\n */\nexport type StorageOperationResult<T> =\n | { success: true; result: T; error: null }\n | { success: false; result: null; error: { message: string; code: string; context: string } };\n\n/**\n * Helper function to safely perform storage operations\n */\nexport async function safeStorageOperation<T>(\n operation: () => Promise<T>,\n errorContext: string\n): Promise<StorageOperationResult<T>> {\n try {\n const result = await operation();\n return { success: true, result, error: null };\n } catch (error) {\n console.error(errorContext, error);\n return {\n success: false,\n result: null,\n error: {\n message: error instanceof Error\n ? (error.message || 'Unknown error')\n : (error?.toString() || 'Unknown error'),\n code: 'STORAGE_OPERATION_FAILED',\n context: errorContext\n }\n };\n }\n} ","export type LogLevel = 'debug' | 'info' | 'warn' | 'error';\n\nexport interface Logger {\n debug(message: string, ...args: any[]): void;\n info(message: string, ...args: any[]): void;\n warn(message: string, ...args: any[]): void;\n error(message: string, ...args: any[]): void;\n setLevel(level: LogLevel): void;\n}\n\nexport type LoggerOptions = {\n level?: LogLevel;\n prefix?: string;\n enabled?: boolean;\n};\n\nexport function createLogger(options: LoggerOptions = {}): Logger {\n const {\n level = 'info',\n prefix = '[openCx]',\n enabled = true\n } = options;\n\n let currentLevel = level;\n const levels: Record<LogLevel, number> = {\n debug: 0,\n info: 1,\n warn: 2,\n error: 3\n };\n\n function shouldLog(messageLevel: LogLevel): boolean {\n return enabled && levels[messageLevel] >= levels[currentLevel];\n }\n\n function formatMessage(message: string): string {\n return `${prefix} ${message}`;\n }\n\n function formatArgs(args: any[]): any[] {\n return args.map(arg => {\n if (arg instanceof Error) {\n return {\n name: arg.name,\n message: arg.message,\n stack: arg.stack\n };\n }\n if (typeof arg === 'object') {\n try {\n return JSON.stringify(arg, null, 2);\n } catch {\n return arg;\n }\n }\n return arg;\n });\n }\n\n return {\n debug(message: string, ...args: any[]) {\n if (shouldLog('debug')) {\n console.debug(formatMessage(message), ...formatArgs(args));\n }\n },\n\n info(message: string, ...args: any[]) {\n if (shouldLog('info')) {\n console.info(formatMessage(message), ...formatArgs(args));\n }\n },\n\n warn(message: string, ...args: any[]) {\n if (shouldLog('warn')) {\n console.warn(formatMessage(message), ...formatArgs(args));\n }\n },\n\n error(message: string, ...args: any[]) {\n if (shouldLog('error')) {\n console.error(formatMessage(message), ...formatArgs(args));\n }\n },\n\n setLevel(level: LogLevel) {\n currentLevel = level;\n }\n };\n} ","/**\n * Platform-agnostic audio interface that can be implemented\n * for different environments (web, mobile, desktop, etc.)\n */\nexport interface Audio {\n /**\n * Plays a notification sound\n * @returns Promise that resolves when the sound finishes playing or rejects on error\n */\n playNotification(): Promise<void>;\n\n /**\n * Checks if audio playback is available and working\n * @returns true if audio is available and working\n */\n isAvailable?(): boolean;\n}\n\n/**\n * Helper function to check if audio is available and working\n */\nexport function isAudioAvailable(audio: Audio | undefined): audio is Audio {\n if (!audio) return false;\n try {\n return typeof audio.isAvailable === 'function'\n ? audio.isAvailable()\n : true; // If isAvailable is not implemented, assume audio is available\n } catch {\n return false;\n }\n}\n\n/**\n * Type for the result of a safe audio operation\n */\nexport type AudioOperationResult =\n | { success: true; error: null }\n | { success: false; error: { message: string; code: string; context: string } };\n\n/**\n * Helper function to safely perform audio operations\n */\nexport async function safeAudioOperation(\n operation: () => Promise<void>,\n errorContext: string\n): Promise<AudioOperationResult> {\n try {\n await operation();\n return { success: true, error: null };\n } catch (error) {\n console.error(errorContext, error);\n return {\n success: false,\n error: {\n message: error instanceof Error\n ? (error.message || 'Unknown error')\n : (error?.toString() || 'Unknown error'),\n code: 'AUDIO_OPERATION_FAILED',\n context: errorContext\n }\n };\n }\n}\n","import { PubSub } from \"../types/pub-sub\";\nimport { MessageType } from \"../types\";\nimport { ApiCaller } from \"./api\";\nimport { genUuid } from \"../utils/genUuid\";\nimport { HandleContactMessageOutputSchema, HttpChatInputSchema, WidgetHistorySchema, WidgetSessionSchema } from \"../types/schemas-v2\";\nimport { LoadingState, ErrorState, SomeOptional } from \"../types/helpers\";\nimport { ConfigInstance } from \"./config\";\nimport { Platform, isStorageAvailable } from \"../platform\";\nimport { Logger } from \"../platform/logger\";\nimport { ExternalIdNotDefinedError, StorageNotAvailableError } from \"@core/errors\";\n\n// Constants\nconst POLLING_INTERVALS = {\n SESSION: 10000, // every 10 seconds\n MESSAGES: 5000 // every 5 seconds\n} as const;\n\n// Types\nexport type PollingType = 'session' | 'messages';\n\nexport type PollingState = {\n isPolling: boolean;\n lastPollTime: string | null;\n nextPollTime: string | null;\n error: ErrorState;\n};\n\nexport type PollingStates = {\n [K in PollingType]: PollingState;\n};\n\nexport type ChatState = {\n messages: MessageType[];\n keyboard: { options: string[] } | null;\n loading: LoadingState;\n error: ErrorState;\n polling: PollingStates;\n};\n\ntype ChatOptions = {\n api: ApiCaller;\n config: ConfigInstance;\n onSessionDestroy?: () => void;\n platform: Platform;\n};\n\n// Message Mapping\nfunction mapHistoryToMessage(history: WidgetHistorySchema): MessageType {\n const commonFields = {\n id: history.publicId,\n timestamp: history.sentAt || \"\",\n attachments: history.attachments || undefined\n };\n\n if (history.sender.kind === 'user') {\n return {\n ...commonFields,\n type: \"FROM_USER\",\n content: history.content.text || \"\",\n deliveredAt: history.sentAt || \"\",\n };\n }\n\n if (history.sender.kind === 'agent') {\n return {\n id: history.publicId,\n type: \"FROM_AGENT\",\n component: history.type,\n data: {\n text: history.content.text\n },\n timestamp: history.sentAt || \"\",\n attachments: history.attachments || undefined\n }\n }\n\n return {\n ...commonFields,\n type: \"FROM_BOT\",\n component: 'TEXT',\n agent: {\n id: null,\n name: history.sender.name || '',\n is_ai: history.sender.kind === 'ai',\n profile_picture: history.sender.avatar\n },\n data: {\n message: history.content.text\n },\n };\n}\n\n// Message Handling\nfunction createMessageHandler(api: ApiCaller, state: PubSub<ChatState>, logger?: Logger) {\n async function fetchHistoryMessages(session: WidgetSessionSchema) {\n const messages = state.getState().messages;\n if (messages.length === 0) {\n logger?.debug('No messages yet, fetching all history', { sessionId: session.id });\n const response = await api.getSessionHistory(session.id, \"\");\n if (response && response.length > 0) {\n state.setStatePartial({\n messages: response.map(mapHistoryToMessage)\n });\n }\n return;\n }\n const lastMessageTimestamp = state.getState().messages.at(-1)?.timestamp\n logger?.debug('Fetching history messages after timestamp', {\n sessionId: session.id,\n lastMessageTimestamp,\n currentMessageCount: messages.length\n });\n\n const response = await api.getSessionHistory(session.id, lastMessageTimestamp);\n\n if (response && response.length > 0) {\n // Map and filter out any potential duplicates by ID\n const newMessages = response\n .map(mapHistoryToMessage)\n .filter(newMsg => !messages.some(existingMsg => existingMsg.id === newMsg.id));\n\n if (newMessages.length > 0) {\n logger?.debug('Adding new messages to state', {\n count: newMessages.length,\n messageIds: newMessages.map(m => m.id),\n messageTypes: newMessages.map(m => m.type)\n });\n state.setStatePartial({\n messages: [...messages, ...newMessages]\n });\n }\n }\n }\n\n function addUserMessage(content: string, attachments?: any[]) {\n return {\n id: genUuid(),\n type: \"FROM_USER\" as const,\n content,\n deliveredAt: new Date().toISOString(),\n attachments,\n timestamp: new Date().toISOString()\n };\n }\n\n function addBotMessage(response: HandleContactMessageOutputSchema) {\n if (response.success && response.autopilotResponse) {\n return {\n type: \"FROM_BOT\" as const,\n id: response.autopilotResponse.id || genUuid(),\n timestamp: new Date().toISOString(),\n component: \"TEXT\",\n data: {\n message: response.autopilotResponse.value.content,\n }\n };\n }\n\n if (response.success && response.uiResponse) {\n const uiVal = response.uiResponse.value;\n return {\n type: \"FROM_BOT\" as const,\n id: genUuid(),\n timestamp: new Date().toISOString(),\n component: uiVal.name,\n data: uiVal.request_response,\n };\n }\n\n return null;\n }\n\n function addErrorMessage(message: string) {\n return {\n type: \"FROM_BOT\" as const,\n id: genUuid(),\n timestamp: new Date().toISOString(),\n component: \"TEXT\",\n data: {\n message,\n variant: \"error\"\n }\n };\n }\n\n return {\n fetchHistoryMessages,\n addUserMessage,\n addBotMessage,\n addErrorMessage\n };\n}\n\n// Session Management\nfunction createSessionManager(\n api: ApiCaller,\n sessionState: PubSub<WidgetSessionSchema | null>,\n chatState: PubSub<ChatState>,\n messageHandler: ReturnType<typeof createMessageHandler>,\n config: ConfigInstance,\n options: ChatOptions\n) {\n const logger = options.platform?.logger;\n let stopPolling: (() => void) | null = null;\n const storage = options.platform?.storage;\n const persistSession = config.getSettings().persistSession;\n\n if (persistSession && !isStorageAvailable(storage)) {\n throw new StorageNotAvailableError()\n }\n\n if (persistSession && !config.getConfig().user.external_id) {\n throw new ExternalIdNotDefinedError(\"session persistence is enabled but external id is not defined\")\n }\n\n const sessionStorageKey = `${config.getConfig().user.external_id}:${config.getConfig().token}:session`;\n /**\n * Restores the session from storage\n */\n async function restoreSession() {\n if (!storage) return;\n try {\n logger?.debug('Attempting to restore session from storage');\n const storedSession = await storage.getItem(sessionStorageKey);\n if (storedSession) {\n const session = JSON.parse(storedSession) as WidgetSessionSchema;\n logger?.info('Session restored from storage', { sessionId: session.id });\n sessionState.setState(session);\n await messageHandler.fetchHistoryMessages(session);\n startPolling();\n }\n } catch (error) {\n logger?.error('Error restoring session from storage:', error);\n }\n }\n\n /**\n * Sets up session persistence\n */\n function setupSessionPersistence() {\n if (!storage) return;\n logger?.debug('Setting up session persistence');\n sessionState.subscribe(async (session) => {\n try {\n if (session) {\n await storage.setItem(sessionStorageKey, JSON.stringify(session));\n logger?.debug('Session persisted to storage', { sessionId: session.id });\n } else {\n await storage.removeItem(sessionStorageKey);\n logger?.debug('Session removed from storage');\n }\n } catch (error) {\n logger?.error('Error persisting session:', error);\n chatState.setStatePartial({\n error: {\n hasError: true,\n message: error instanceof Error ? error.message : 'Failed to persist session',\n code: 'SESSION_PERSISTENCE_FAILED'\n }\n });\n }\n });\n }\n\n /**\n * Starts polling for the session and messages\n */\n function startPolling() {\n if (stopPolling) return;\n\n logger?.debug('Starting polling');\n const intervals: NodeJS.Timeout[] = [];\n\n // Poll session\n intervals.push(\n setInterval(async () => {\n const session = sessionState.getState();\n if (!session?.id) return;\n\n try {\n const now = new Date();\n chatState.setStatePartial({\n polling: {\n ...chatState.getState().polling,\n session: {\n isPolling: true,\n lastPollTime: now.toISOString(),\n nextPollTime: new Date(now.getTime() + POLLING_INTERVALS.SESSION).toISOString(),\n error: { hasError: false }\n }\n }\n });\n\n const response = await api.getSession(session.id);\n if (response) {\n sessionState.setState(response);\n }\n\n chatState.setStatePartial({\n polling: {\n ...chatState.getState().polling,\n session: {\n ...chatState.getState().polling.session,\n isPolling: false\n }\n }\n });\n } catch (error) {\n logger?.error('Error polling session:', error);\n chatState.setStatePartial({\n polling: {\n ...chatState.getState().polling,\n session: {\n ...chatState.getState().polling.session,\n isPolling: false,\n error: {\n hasError: true,\n message: error instanceof Error ? error.message : 'Failed to poll session',\n code: 'SESSION_POLLING_FAILED'\n }\n }\n }\n });\n }\n }, POLLING_INTERVALS.SESSION)\n );\n\n // Poll messages\n intervals.push(\n setInterval(async () => {\n const session = sessionState.getState();\n if (!session?.id) return;\n try {\n const now = new Date();\n chatState.setStatePartial({\n polling: {\n ...chatState.getState().polling,\n messages: {\n isPolling: true,\n lastPollTime: now.toISOString(),\n nextPollTime: new Date(now.getTime() + POLLING_INTERVALS.MESSAGES).toISOString(),\n error: { hasError: false }\n }\n }\n });\n\n await messageHandler.fetchHistoryMessages(session);\n\n chatState.setStatePartial({\n polling: {\n ...chatState.getState().polling,\n messages: {\n ...chatState.getState().polling.messages,\n isPolling: false\n }\n }\n });\n } catch (error) {\n logger?.error('Error polling messages:', error);\n chatState.setStatePartial({\n polling: {\n ...chatState.getState().polling,\n messages: {\n ...chatState.getState().polling.messages,\n isPolling: false,\n error: {\n hasError: true,\n message: error instanceof Error ? error.message : 'Failed to poll messages',\n code: 'MESSAGES_POLLING_FAILED'\n }\n }\n }\n });\n }\n }, POLLING_INTERVALS.MESSAGES)\n );\n\n stopPolling = () => {\n logger?.debug('Stopping polling');\n intervals.forEach(clearInterval);\n // Reset polling states\n chatState.setStatePartial({\n polling: {\n session: {\n isPolling: false,\n lastPollTime: null,\n nextPollTime: null,\n error: { hasError: false }\n },\n messages: {\n isPolling: false,\n lastPollTime: null,\n nextPollTime: null,\n error: { hasError: false }\n }\n }\n });\n };\n }\n\n /**\n * Creates a new session\n * @returns The session\n */\n async function createSession() {\n try {\n logger?.info('Creating new session');\n chatState.setStatePartial({\n loading: { isLoading: true, reason: 'creating_session' },\n error: { hasError: false }\n });\n\n const session = await api.createSession();\n logger?.info('Session created successfully', { sessionId: session.id });\n sessionState.setState(session);\n startPolling();\n return session;\n } catch (error) {\n logger?.error('Failed to create session:', error);\n const errorState = {\n hasError: true,\n message: error instanceof Error ? error.message : 'Failed to create session',\n code: 'SESSION_CREATION_FAILED' as const\n };\n chatState.setStatePartial({ error: errorState });\n return null;\n } finally {\n chatState.setStatePartial({\n loading: { isLoading: false, reason: null }\n });\n }\n }\n\n /**\n * Clears the session and stops polling\n */\n async function clearSession() {\n const session = sessionState.getState();\n if (!session?.id) return;\n\n try {\n if (stopPolling) {\n stopPolling();\n stopPolling = null;\n }\n sessionState.setState(null);\n\n if (persistSession && storage) {\n await storage.removeItem(sessionStorageKey);\n }\n\n chatState.setState({\n messages: [],\n keyboard: null,\n loading: { isLoading: false, reason: null },\n error: { hasError: false },\n polling: {\n session: {\n isPolling: false,\n lastPollTime: null,\n nextPollTime: null,\n error: { hasError: false }\n },\n messages: {\n isPolling: false,\n lastPollTime: null,\n nextPollTime: null,\n error: { hasError: false }\n }\n }\n });\n\n options.onSessionDestroy?.();\n } catch (error) {\n console.error(\"Error clearing session:\", error);\n chatState.setStatePartial({\n error: {\n hasError: true,\n message: error instanceof Error ? error.message : 'Failed to clear session',\n code: 'SESSION_CLEAR_FAILED'\n }\n });\n }\n }\n\n /**\n * Cleans up the session and stops polling\n */\n function cleanup(removeSession = false) {\n try {\n if (stopPolling) {\n stopPolling();\n stopPolling = null;\n }\n\n if (removeSession && persistSession && storage && isStorageAvailable(storage)) {\n storage.removeItem(sessionStorageKey);\n }\n\n chatState.setState({\n messages: [],\n keyboard: null,\n loading: { isLoading: false, reason: null },\n error: { hasError: false },\n polling: {\n session: {\n isPolling: false,\n lastPollTime: null,\n nextPollTime: null,\n error: { hasError: false }\n },\n messages: {\n isPolling: false,\n lastPollTime: null,\n nextPollTime: null,\n error: { hasError: false }\n }\n }\n });\n\n sessionState.setState(null);\n chatState.clear();\n sessionState.clear();\n } catch (error) {\n console.error(\"Error in cleanup:\", error);\n chatState.setStatePartial({\n error: {\n hasError: true,\n message: error instanceof Error ? error.message : 'Failed to cleanup',\n code: 'SESSION_CLEAR_FAILED'\n }\n });\n }\n }\n\n /**\n * Fetches the session from the API\n * @param id - The ID of the session to fetch\n * @returns The session\n */\n async function fetchSession(id: string) {\n return api.getSession(id);\n }\n\n /**\n * Refetches the session and updates the state\n */\n async function refetchSession() {\n const session = sessionState.getState();\n if (!session?.id) return;\n const newSession = await fetchSession(session.id);\n if (newSession) {\n sessionState.setState(newSession);\n }\n return newSession;\n }\n\n // Initialize session if persistence is enabled\n if (persistSession && isStorageAvailable(storage)) {\n restoreSession();\n setupSessionPersistence();\n }\n\n return {\n createSession,\n clearSession,\n cleanup,\n startPolling,\n fetchSession,\n refetchSession,\n sessionStorageKey\n };\n}\nexport type SendMessageInput = SomeOptional<Omit<HttpChatInputSchema, \"bot_token\">, \"session_id\" | \"user\">\n// Main Chat Function\nexport function createChat(options: ChatOptions) {\n const logger = options.platform?.logger;\n const initialState = <ChatState>{\n messages: [],\n keyboard: null,\n loading: { isLoading: false, reason: null },\n error: { hasError: false },\n polling: {\n session: {\n isPolling: false,\n lastPollTime: null,\n nextPollTime: null,\n error: { hasError: false }\n },\n messages: {\n isPolling: false,\n lastPollTime: null,\n nextPollTime: null,\n error: { hasError: false }\n }\n }\n }\n const state = new PubSub<ChatState>(initialState);\n\n const sessionState = new PubSub<WidgetSessionSchema | null>(null);\n const messageHandler = createMessageHandler(options.api, state, logger);\n const sessionManager = createSessionManager(\n options.api,\n sessionState,\n state,\n messageHandler,\n options.config,\n options\n );\n\n async function sendMessage(input: SendMessageInput, abort?: AbortSignal) {\n let session = sessionState.getState();\n let createdSession = false;\n\n if (!session?.id) {\n logger?.debug('No active session, creating new session');\n session = await sessionManager.createSession();\n if (!session) return {\n success: false,\n createdSession,\n }\n createdSession = true;\n }\n\n if (session.assignee.kind === 'ai') {\n session = (await sessionManager.refetchSession()) ?? session;\n }\n\n try {\n logger?.debug('Sending message', { sessionId: session.id });\n if (session.assignee.kind === 'ai') {\n state.setStatePartial({\n loading: { isLoading: true, reason: 'sending_message_to_bot' },\n error: { hasError: false }\n });\n } else {\n state.setStatePartial({\n loading: { isLoading: true, reason: 'sending_message_to_agent' },\n error: { hasError: false }\n });\n }\n\n const userMessage = messageHandler.addUserMessage(input.content, input.attachments || undefined);\n const currentMessages = state.getState().messages;\n state.setStatePartial({\n messages: [...currentMessages, userMessage]\n });\n\n const config = options.config.getConfig();\n const data = await options.api.handleMessage({\n uuid: input.uuid || genUuid(),\n bot_token: config.token,\n headers: config.headers,\n query_params: config.queryParams,\n session_id: session.id,\n user: config.user,\n ...input,\n }, abort);\n\n if (data.success) {\n logger?.debug('Message sent successfully');\n const botMessage = messageHandler.addBotMessage(data);\n if (botMessage) {\n const updatedMessages = state.getState().messages;\n state.setStatePartial({\n messages: [...updatedMessages, botMessage]\n });\n }\n return {\n success: true,\n createdSession,\n botMessage\n }\n } else {\n logger?.warn('Message send failed', data.error);\n const errorMessage = messageHandler.addErrorMessage(data.error?.message || \"Unknown error occurred\");\n const currentMessages = state.getState().messages;\n state.setStatePartial({\n messages: [...currentMessages, errorMessage]\n });\n return {\n success: false,\n createdSession,\n error: data.error\n }\n }\n } catch (error) {\n logger?.error('Error sending message:', error);\n state.setStatePartial({\n error: {\n hasError: true,\n message: error instanceof Error ? error.message : 'Failed to send message',\n code: 'MESSAGE_SEND_FAILED'\n }\n });\n return {\n success: false,\n createdSession,\n error\n }\n } finally {\n state.setStatePartial({\n loading: { isLoading: false, reason: null }\n });\n }\n }\n\n return {\n chatState: state,\n sessionState,\n sendMessage,\n createSession: sessionManager.createSession,\n clearSession: sessionManager.clearSession,\n cleanup: sessionManager.cleanup,\n initialState,\n sessionStorageKey: sessionManager.sessionStorageKey\n };\n} ","import { PubSub } from \"../types/pub-sub\";\nimport { ApiCaller } from \"./api\";\nimport { Platform, isStorageAvailable, safeStorageOperation } from \"../platform\";\nimport { LoadingState, ErrorState } from \"../types/helpers\";\nimport { ConfigInstance } from \"./config\";\nimport { ConsumerType } from \"@core/types/schemas\";\n\ntype ContactState = {\n contact: ConsumerType | null;\n loading: LoadingState;\n error: ErrorState;\n};\n\nexport type CreateContactOptions = {\n api: ApiCaller;\n platform: Platform;\n config: ConfigInstance\n};\n\nexport function createContact(options: CreateContactOptions) {\n const config = options.config.getConfig();\n options.config.getConfig\n const storageKey = `${config.token}:contact:${config.user.external_id}`;\n const storage = isStorageAvailable(options.platform.storage) ? options.platform.storage : undefined;\n\n // Initialize state from storage if available\n let initialContact: ConsumerType | null = null;\n if (storage) {\n safeStorageOperation(\n async () => {\n const stored = await storage.getItem(storageKey);\n return stored ? JSON.parse(stored) : null;\n },\n \"Error loading contact from storage\"\n ).then((result) => {\n if (result.success) {\n initialContact = result.result;\n }\n });\n }\n\n const state = new PubSub<ContactState>({\n contact: initialContact,\n loading: { isLoading: false, reason: null },\n error: { hasError: false }\n });\n\n // Subscribe to state changes to persist\n if (isStorageAvailable(storage)) {\n state.subscribe((currentState) => {\n safeStorageOperation(\n async () => {\n if (currentState.contact) {\n await storage.setItem(storageKey, JSON.stringify(currentState.contact));\n } else {\n storage.removeItem(storageKey);\n }\n },\n \"Error persisting contact state\"\n ).then((result) => {\n if (!result.success) {\n state.setStatePartial({\n error: {\n hasError: true,\n message: result.error.message,\n code: 'CONTACT_PERSISTENCE_FAILED'\n }\n });\n }\n });\n });\n }\n\n async function loadContact() {\n try {\n state.setStatePartial({\n loading: { isLoading: true, reason: 'loading_contact' },\n error: { hasError: false }\n });\n\n if (storage) {\n const result = await safeStorageOperation(\n async () => {\n const stored = await storage.getItem(storageKey);\n return stored ? JSON.parse(stored) : null;\n },\n \"Error loading contact\"\n );\n\n if (!result.success) {\n throw result.error;\n }\n\n state.setStatePartial({\n contact: result.result,\n error: { hasError: false }\n });\n\n return result.result;\n }\n\n return state.getState().contact;\n } catch (error) {\n state.setStatePartial({\n error: {\n hasError: true,\n message: error instanceof Error ? error.message : 'Failed to load contact',\n code: 'CONTACT_LOAD_FAILED'\n }\n });\n return null;\n } finally {\n state.setStatePartial({\n loading: { isLoading: false, reason: null }\n });\n }\n }\n\n async function saveContact(contactData: Partial<ConsumerType>) {\n try {\n state.setStatePartial({\n loading: { isLoading: true, reason: 'saving_contact' },\n error: { hasError: false }\n });\n\n const currentContact = state.getState().contact;\n const updatedContact: ConsumerType = {\n id: contactData.id || currentContact?.id || '',\n name: contactData.name ?? currentContact?.name ?? null,\n created_at: contactData.created_at || currentContact?.created_at || new Date().toISOString(),\n avatar_url: contactData.avatar_url ?? currentContact?.avatar_url ?? null,\n email: contactData.email ?? currentContact?.email ?? null\n };\n\n if (isStorageAvailable(storage)) {\n const result = await safeStorageOperation(\n () => storage.setItem(storageKey, JSON.stringify(updatedContact)),\n \"Error saving contact\"\n );\n\n if (!result.success) {\n throw result.error;\n }\n }\n\n state.setStatePartial({\n contact: updatedContact,\n error: { hasError: false }\n });\n\n return updatedContact;\n } catch (error) {\n state.setStatePartial({\n error: {\n hasError: true,\n message: error instanceof Error ? error.message : 'Failed to save contact',\n code: 'CONTACT_SAVE_FAILED'\n }\n });\n return null;\n } finally {\n state.setStatePartial({\n loading: { isLoading: false, reason: null }\n });\n }\n }\n\n function shouldCollectData(): { should: boolean; reason?: string } {\n const currentState = state.getState();\n\n if (!currentState.contact?.id && config.collectUserData) {\n return {\n should: true,\n reason: \"No contact id and collectUserData is true\"\n };\n }\n\n return {\n should: false\n };\n }\n\n async function cleanup() {\n try {\n state.setStatePartial({\n loading: { isLoading: true, reason: 'cleaning_up' },\n error: { hasError: false }\n });\n\n if (storage) {\n const result = await safeStorageOperation(\n () => storage.removeItem(storageKey),\n \"Error removing contact data\"\n );\n\n if (!result.success) {\n throw result.error;\n }\n }\n\n state.setState({\n contact: null,\n loading: { isLoading: false, reason: null },\n error: { hasError: false }\n });\n\n state.clear();\n } catch (error) {\n console.error(\"Error cleaning up contact:\", error);\n state.setStatePartial({\n error: {\n hasError: true,\n message: error instanceof Error ? error.message : 'Failed to cleanup contact data',\n code: 'CONTACT_CLEANUP_FAILED'\n }\n });\n } finally {\n state.setStatePartial({\n loading: { isLoading: false, reason: null }\n });\n }\n }\n\n return {\n contactState: state,\n shouldCollectData,\n loadContact,\n saveContact,\n cleanup,\n };\n} ","import { CoreOptions } from \"../types\";\n\nconst DEFAULT_SOUND_EFFECTS = {\n messageArrived: \"https://cloud.opencopilot.so/sfx/notification3.mp3\"\n};\n\nconst DEFAULT_THEME = {\n primaryColor: \"hsl(211,65%,59%)\",\n triggerOffset: \"20px\"\n};\n\nexport type NormalizedConfig = Required<Omit<CoreOptions, 'contactToken'>> & {\n contactToken: string | undefined | null;\n soundEffectFiles: {\n messageArrived: string;\n };\n theme: {\n primaryColor: string;\n triggerOffset: string;\n };\n settings: {\n persistSession: boolean;\n useSoundEffects: boolean;\n };\n};\n\nexport type ConfigInstance = {\n getConfig: () => NormalizedConfig;\n getApiConfig: () => {\n apiUrl: string;\n token: string;\n headers: Record<string, string>;\n queryParams: Record<string, string>;\n pathParams: Record<string, string>;\n };\n getBotConfig: () => NormalizedConfig['bot'];\n getThemeConfig: () => NormalizedConfig['theme'];\n getSettings: () => NormalizedConfig['settings'];\n getSoundEffects: () => NormalizedConfig['soundEffectFiles'];\n getUser: () => NormalizedConfig['user'];\n getLanguage: () => string;\n getDebugMode: () => boolean;\n};\n\nconst MIN_POLLING_INTERVAL = 1000 * 3;\n\nexport function createConfig(options: CoreOptions): ConfigInstance {\n if (!options.token) {\n throw new Error(\"Token is required\");\n }\n\n if (options.pollingInterval && options.pollingInterval < MIN_POLLING_INTERVAL) {\n throw new Error(\"Polling interval must be at least 3 seconds\");\n }\n\n const normalizedConfig: NormalizedConfig = {\n ...options,\n collectUserData: options.collectUserData ?? false,\n apiUrl: options.apiUrl ?? \"https://api.open.cx/backend\",\n pollingInterval: options.pollingInterval ?? 3000,\n headers: options.headers ?? {},\n queryParams: options.queryParams ?? {},\n pathParams: options.pathParams ?? {},\n bot: {\n name: options.bot?.name ?? \"Bot\",\n avatarUrl: options.bot?.avatarUrl,\n id: options.bot?.id ?? null,\n is_ai: options.bot?.is_ai ?? true\n },\n contactToken: options.contactToken,\n debug: options.debug ?? false,\n language: options.language ?? \"en\",\n user: options.user ?? {},\n soundEffectFiles: {\n messageArrived: options.soundEffectFiles?.messageArrived ?? DEFAULT_SOUND_EFFECTS.messageArrived\n },\n theme: {\n primaryColor: options.theme?.primaryColor ?? DEFAULT_THEME.primaryColor,\n triggerOffset: options.theme?.triggerOffset ?? DEFAULT_THEME.triggerOffset\n },\n settings: {\n persistSession: options.settings?.persistSession ?? false,\n useSoundEffects: options.settings?.useSoundEffects ?? false\n },\n };\n\n return {\n getConfig: () => normalizedConfig,\n getApiConfig: () => ({\n apiUrl: normalizedConfig.apiUrl,\n token: normalizedConfig.token,\n headers: normalizedConfig.headers,\n queryParams: normalizedConfig.queryParams,\n pathParams: normalizedConfig.pathParams\n }),\n getBotConfig: () => normalizedConfig.bot,\n getThemeConfig: () => normalizedConfig.theme,\n getSettings: () => normalizedConfig.settings,\n getSoundEffects: () => normalizedConfig.soundEffectFiles,\n getUser: () => normalizedConfig.user,\n getLanguage: () => normalizedConfig.language,\n getDebugMode: () => normalizedConfig.debug\n };\n} ","import \"whatwg-fetch\";\ntype RequestInterceptor = (config: RequestConfig) => RequestConfig | Promise<RequestConfig>;\ntype ResponseInterceptor = (response: Response) => Response | Promise<Response>;\ntype ErrorInterceptor = (error: any) => any;\n\ninterface RequestConfig extends RequestInit {\n baseURL?: string;\n headers?: HeadersInit;\n params?: Record<string, string>;\n}\n\nexport interface CustomFetch {\n (url: string, config?: RequestConfig): Promise<Response>;\n interceptors: {\n request: {\n use: (interceptor: RequestInterceptor) => number;\n eject: (id: number) => void;\n };\n response: {\n use: (interceptor: ResponseInterceptor, errorInterceptor?: ErrorInterceptor) => number;\n eject: (id: number) => void;\n };\n };\n}\n\ntype Fetch = typeof globalThis.fetch;\n\nexport function createFetch(defaultConfig: RequestConfig = {}, fetch: Fetch = globalThis.fetch): CustomFetch {\n const requestInterceptors: RequestInterceptor[] = [];\n const responseInterceptors: ResponseInterceptor[] = [];\n const errorInterceptors: ErrorInterceptor[] = [];\n\n const customFetch: CustomFetch = async (url: string, config: RequestConfig = {}) => {\n // Merge configs\n let mergedConfig: RequestConfig = {\n ...defaultConfig,\n ...config,\n headers: {\n ...defaultConfig.headers,\n ...config.headers,\n },\n };\n\n try {\n // Apply request interceptors\n for (const interceptor of requestInterceptors) {\n mergedConfig = await interceptor(mergedConfig);\n }\n\n // Handle URL params\n const queryParams = mergedConfig.params\n ? '?' + new URLSearchParams(mergedConfig.params).toString()\n : '';\n\n // Construct full URL\n const fullUrl = mergedConfig.baseURL\n ? `${mergedConfig.baseURL}${url}${queryParams}`.replace(/([^:]\\/)\\/+/g, '$1')\n : `${url}${queryParams}`;\n\n // Make the fetch call\n let response = await fetch(fullUrl, mergedConfig);\n\n // Apply response interceptors\n for (const interceptor of responseInterceptors) {\n response = await interceptor(response);\n }\n\n return response;\n } catch (error) {\n // Apply error interceptors\n let processedError = error;\n for (const interceptor of errorInterceptors) {\n processedError = await interceptor(processedError);\n }\n throw processedError;\n }\n };\n\n // Add interceptors management\n customFetch.interceptors = {\n request: {\n use: (interceptor: RequestInterceptor) => {\n requestInterceptors.push(interceptor);\n return requestInterceptors.length - 1;\n },\n eject: (id: number) => {\n requestInterceptors.splice(id, 1);\n },\n },\n response: {\n use: (interceptor: ResponseInterceptor, errorInterceptor?: ErrorInterceptor) => {\n responseInterceptors.push(interceptor);\n if (errorInterceptor) {\n errorInterceptors.push(errorInterceptor);\n }\n return responseInterceptors.length - 1;\n },\n eject: (id: number) => {\n responseInterceptors.splice(id, 1);\n errorInterceptors.splice(id, 1);\n },\n },\n };\n\n return customFetch;\n}\n\n// Helper method to handle JSON responses\nexport async function handleJsonResponse<T>(response: Response): Promise<T> {\n if (!response.ok) {\n throw new Error(`HTTP error! status: ${response.status}`);\n }\n return response.json();\n}\n\n// Usage example:\n/*\nconst api = createFetch({\n baseURL: 'https://api.example.com',\n headers: {\n 'Content-Type': 'application/json',\n },\n});\n\n// Add request interceptor\napi.interceptors.request.use((config) => {\n config.headers = {\n ...config.headers,\n 'Authorization': `Bearer ${getToken()}`,\n };\n return config;\n});\n\n// Add response interceptor\napi.interceptors.response.use(\n async (response) => {\n if (!response.ok) {\n throw new Error(`HTTP error! status: ${response.status}`);\n }\n return response;\n },\n (error) => {\n console.error('Request failed:', error);\n throw error;\n }\n);\n*/\n","import { createFetch, CustomFetch } from \"../utils/create-fetch\";\nimport { HandleContactMessageOutputSchema, HttpChatInputSchema, WidgetHistorySchema, WidgetPreludeSchema, WidgetSessionSchema } from \"../types/schemas-v2\";\nimport { NormalizedConfig } from \"./config\";\nimport { ConsumerType } from \"@core/types/schemas\";\n\nexport interface ApiCallerOptions {\n config: NormalizedConfig;\n}\n\nexport class ApiCaller {\n #fetch: CustomFetch\n constructor(private readonly options: ApiCallerOptions) {\n const user = this.options.config.user;\n const consumerHeader = {\n claim: '',\n value: ''\n }\n\n if (user?.email) {\n consumerHeader.claim = 'email';\n consumerHeader.value = user.email;\n }\n\n else if (user?.phone) {\n consumerHeader.claim = 'phone';\n consumerHeader.value = user.phone;\n }\n\n const headers: Record<string, string> = {\n 'X-Bot-Token': this.options.config.token,\n 'X-Consumer-Id': `${consumerHeader.claim}:${consumerHeader.value}`,\n \"Content-Type\": \"application/json\",\n \"Accept\": \"application/json\"\n }\n\n // Only add Authorization header if contactToken exists\n if (this.options.config.contactToken) {\n headers['Authorization'] = `Bearer ${this.options.config.contactToken}`\n }\n\n this.#fetch = createFetch({\n baseURL: `${this.options.config.apiUrl}/widget/v2`,\n headers\n })\n }\n\n async me(): Promise<{\n contactId: string;\n contactName: string;\n }> {\n // GET /me\n const response = await this.#fetch('/me')\n return response.json()\n }\n\n async widgetPrelude(): Promise<WidgetPreludeSchema> {\n // GET /prelude\n const response = await this.#fetch('/prelude')\n return response.json()\n }\n\n async handleMessage(message: HttpChatInputSchema, abortSignal?: AbortSignal) {\n // POST /chat/send\n const response = await this.#fetch('/chat/send', {\n method: \"POST\",\n body: JSON.stringify(message),\n signal: abortSignal\n })\n return response.json() as Promise<HandleContactMessageOutputSchema>\n }\n\n async getSessionHistory(sessionId: string, lastMessageTimestamp?: string): Promise<WidgetHistorySchema[]> {\n // session/history/:sessionId\n const queryParams = new URLSearchParams({\n lastMessageTimestamp: lastMessageTimestamp || ''\n })\n\n const url = `/session/history/${sessionId}?${queryParams.toString()}`\n\n const response = await this.#fetch(url, {\n method: 'GET'\n })\n\n return response.json()\n }\n\n async createSession(): Promise<WidgetSessionSchema> {\n // POST /create-session\n const response = await this.#fetch('/create-session', {\n method: 'POST'\n })\n return response.json()\n }\n\n async getSession(sessionId: string): Promise<WidgetSessionSchema> {\n // GET /session/:sessionId\n const response = await this.#fetch(`/session/${sessionId}`, {\n method: 'GET'\n })\n return response.json()\n }\n}\n"],"names":["LifecycleEvent","PubSub","state","__publicField","__privateAdd","_state","_lastUpdated","event","data","listeners","eventData","listener","error","callback","__privateGet","newState","isEqual","__privateSet","_s","createPubSub","OpenCXError","message","ConnectionError","AuthenticationError","SessionError","SessionNotDefinedError","TransportError","FileUploadError","StorageNotAvailableError","ExternalIdNotDefinedError","isStorageAvailable","storage","safeStorageOperation","operation","errorContext","createLogger","options","level","prefix","enabled","currentLevel","levels","shouldLog","messageLevel","formatMessage","formatArgs","args","arg","isAudioAvailable","audio","safeAudioOperation","POLLING_INTERVALS","mapHistoryToMessage","history","commonFields","createMessageHandler","api","logger","fetchHistoryMessages","session","messages","response","lastMessageTimestamp","_a","newMessages","newMsg","existingMsg","m","addUserMessage","content","attachments","genUuid","addBotMessage","uiVal","addErrorMessage","createSessionManager","sessionState","chatState","messageHandler","config","stopPolling","_b","persistSession","sessionStorageKey","restoreSession","storedSession","startPolling","setupSessionPersistence","intervals","now","createSession","errorState","clearSession","cleanup","removeSession","fetchSession","id","refetchSession","newSession","createChat","initialState","sessionManager","sendMessage","input","abort","createdSession","userMessage","currentMessages","botMessage","updatedMessages","errorMessage","createContact","storageKey","initialContact","stored","result","currentState","loadContact","saveContact","contactData","currentContact","updatedContact","shouldCollectData","DEFAULT_SOUND_EFFECTS","DEFAULT_THEME","MIN_POLLING_INTERVAL","createConfig","normalizedConfig","_c","_d","_e","_f","_g","_h","_i","createFetch","defaultConfig","fetch","requestInterceptors","responseInterceptors","errorInterceptors","customFetch","url","mergedConfig","interceptor","queryParams","fullUrl","processedError","errorInterceptor","ApiCaller","_fetch","user","consumerHeader","headers","abortSignal","sessionId"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
@@ -0,0 +1,107 @@
1
+ import { CoreOptions, ApiCaller, Platform } from '../../core/index';
2
+ import { WidgetComponentType } from '../types';
3
+ import { default as React } from 'react';
4
+ import { ComponentRegistry } from './components';
5
+ import { TranslationKeysType } from './locales/en.locale';
6
+ import { LangType } from './locales';
7
+ interface InitializeChatOptions {
8
+ options: CoreOptions;
9
+ platform?: Partial<Platform>;
10
+ }
11
+ declare function useInitializeChat({ options, platform: customPlatform, }: InitializeChatOptions): {
12
+ config: import('../../core/client/config').ConfigInstance;
13
+ chat: {
14
+ chatState: import('../../core/index').PubSub<import('../../core/client/chat').ChatState>;
15
+ sessionState: import('../../core/index').PubSub<{
16
+ id: string;
17
+ createdAt: string;
18
+ updatedAt: string;
19
+ isHandedOff: boolean;
20
+ isOpened: boolean;
21
+ assignee: {
22
+ kind: "human" | "ai" | "none" | "unknown";
23
+ name: string | null;
24
+ avatarUrl: string | null;
25
+ };
26
+ channel: string;
27
+ isVerified: boolean;
28
+ } | null>;
29
+ sendMessage: (input: import('../../core/client/chat').SendMessageInput, abort?: AbortSignal) => Promise<{
30
+ success: boolean;
31
+ createdSession: boolean;
32
+ botMessage?: undefined;
33
+ error?: undefined;
34
+ } | {
35
+ success: boolean;
36
+ createdSession: boolean;
37
+ botMessage: import('../../core/index').BotMessageType | null;
38
+ error?: undefined;
39
+ } | {
40
+ success: boolean;
41
+ createdSession: boolean;
42
+ error: unknown;
43
+ botMessage?: undefined;
44
+ }>;
45
+ createSession: () => Promise<{
46
+ id: string;
47
+ createdAt: string;
48
+ updatedAt: string;
49
+ isHandedOff: boolean;
50
+ isOpened: boolean;
51
+ assignee: {
52
+ kind: "human" | "ai" | "none" | "unknown";
53
+ name: string | null;
54
+ avatarUrl: string | null;
55
+ };
56
+ channel: string;
57
+ isVerified: boolean;
58
+ } | null>;
59
+ clearSession: () => Promise<void>;
60
+ cleanup: () => void;
61
+ initialState: import('../../core/client/chat').ChatState;
62
+ sessionStorageKey: string;
63
+ recreateSession: () => Promise<void>;
64
+ contactState: import('../../core/index').PubSub<{
65
+ contact: import('../../core/types/contact').Contact | null;
66
+ loading: import('../../core/index').LoadingState;
67
+ error: import('../../core/index').ErrorState;
68
+ }>;
69
+ contactManager: {
70
+ shouldCollectData: () => {
71
+ should: boolean;
72
+ reason: string;
73
+ } | {
74
+ should: boolean;
75
+ reason?: undefined;
76
+ };
77
+ createUnauthenticatedContact: (payload: import('../../core/sdk').Dto["CreateContactDto"]) => Promise<import('../../core/sdk').Dto["WidgetContactDto"] | null>;
78
+ };
79
+ };
80
+ api: ApiCaller;
81
+ widgetSettings: {
82
+ persistSession?: boolean | undefined;
83
+ useSoundEffects?: boolean | undefined;
84
+ };
85
+ setWidgetSettings: React.Dispatch<React.SetStateAction<{
86
+ persistSession?: boolean | undefined;
87
+ useSoundEffects?: boolean | undefined;
88
+ }>>;
89
+ };
90
+ interface ChatProviderValue extends ReturnType<typeof useInitializeChat> {
91
+ components?: WidgetComponentType[];
92
+ componentStore: ComponentRegistry;
93
+ version: string;
94
+ locale: {
95
+ get: (key: TranslationKeysType, pfx?: string) => string;
96
+ lang: LangType;
97
+ };
98
+ }
99
+ declare const useChat: () => ChatProviderValue;
100
+ interface ChatProviderProps {
101
+ options: CoreOptions;
102
+ children: React.ReactNode;
103
+ components?: WidgetComponentType[];
104
+ platform?: Partial<Platform>;
105
+ }
106
+ declare function ChatProvider({ options, children, components, platform, }: ChatProviderProps): React.JSX.Element;
107
+ export { useChat, ChatProvider };
@@ -0,0 +1,11 @@
1
+ import { WidgetComponentType } from '../types';
2
+ export declare class ComponentRegistry {
3
+ components: WidgetComponentType[];
4
+ constructor(opts: {
5
+ components?: WidgetComponentType[];
6
+ });
7
+ register(com: WidgetComponentType): this;
8
+ private get;
9
+ private getOrFallback;
10
+ getComponent(key: string, getFallback?: boolean): import('react').ElementType<any, keyof import("react").JSX.IntrinsicElements> | undefined;
11
+ }
@@ -0,0 +1,70 @@
1
+ export declare function useChatState(): {
2
+ chatState: import('../../../core/client/chat').ChatState;
3
+ chat: {
4
+ chatState: import('../../../core').PubSub<import('../../../core/client/chat').ChatState>;
5
+ sessionState: import('../../../core').PubSub<{
6
+ id: string;
7
+ createdAt: string;
8
+ updatedAt: string;
9
+ isHandedOff: boolean;
10
+ isOpened: boolean;
11
+ assignee: {
12
+ kind: "human" | "ai" | "none" | "unknown";
13
+ name: string | null;
14
+ avatarUrl: string | null;
15
+ };
16
+ channel: string;
17
+ isVerified: boolean;
18
+ } | null>;
19
+ sendMessage: (input: import('../../../core/client/chat').SendMessageInput, abort?: AbortSignal) => Promise<{
20
+ success: boolean;
21
+ createdSession: boolean;
22
+ botMessage?: undefined;
23
+ error?: undefined;
24
+ } | {
25
+ success: boolean;
26
+ createdSession: boolean;
27
+ botMessage: import('../../../core').BotMessageType | null;
28
+ error?: undefined;
29
+ } | {
30
+ success: boolean;
31
+ createdSession: boolean;
32
+ error: unknown;
33
+ botMessage?: undefined;
34
+ }>;
35
+ createSession: () => Promise<{
36
+ id: string;
37
+ createdAt: string;
38
+ updatedAt: string;
39
+ isHandedOff: boolean;
40
+ isOpened: boolean;
41
+ assignee: {
42
+ kind: "human" | "ai" | "none" | "unknown";
43
+ name: string | null;
44
+ avatarUrl: string | null;
45
+ };
46
+ channel: string;
47
+ isVerified: boolean;
48
+ } | null>;
49
+ clearSession: () => Promise<void>;
50
+ cleanup: () => void;
51
+ initialState: import('../../../core/client/chat').ChatState;
52
+ sessionStorageKey: string;
53
+ recreateSession: () => Promise<void>;
54
+ contactState: import('../../../core').PubSub<{
55
+ contact: import('../../../core/types/contact').Contact | null;
56
+ loading: import('../../../core').LoadingState;
57
+ error: import('../../../core').ErrorState;
58
+ }>;
59
+ contactManager: {
60
+ shouldCollectData: () => {
61
+ should: boolean;
62
+ reason: string;
63
+ } | {
64
+ should: boolean;
65
+ reason?: undefined;
66
+ };
67
+ createUnauthenticatedContact: (payload: import('../../../core/sdk').Dto["CreateContactDto"]) => Promise<import('../../../core/sdk').Dto["WidgetContactDto"] | null>;
68
+ };
69
+ };
70
+ };
@@ -0,0 +1,83 @@
1
+ export declare function useChatSession(): {
2
+ chat: {
3
+ chatState: import('../../../core').PubSub<import('../../../core/client/chat').ChatState>;
4
+ sessionState: import('../../../core').PubSub<{
5
+ id: string;
6
+ createdAt: string;
7
+ updatedAt: string;
8
+ isHandedOff: boolean;
9
+ isOpened: boolean;
10
+ assignee: {
11
+ kind: "human" | "ai" | "none" | "unknown";
12
+ name: string | null;
13
+ avatarUrl: string | null;
14
+ };
15
+ channel: string;
16
+ isVerified: boolean;
17
+ } | null>;
18
+ sendMessage: (input: import('../../../core/client/chat').SendMessageInput, abort?: AbortSignal) => Promise<{
19
+ success: boolean;
20
+ createdSession: boolean;
21
+ botMessage?: undefined;
22
+ error?: undefined;
23
+ } | {
24
+ success: boolean;
25
+ createdSession: boolean;
26
+ botMessage: import('../../../core').BotMessageType | null;
27
+ error?: undefined;
28
+ } | {
29
+ success: boolean;
30
+ createdSession: boolean;
31
+ error: unknown;
32
+ botMessage?: undefined;
33
+ }>;
34
+ createSession: () => Promise<{
35
+ id: string;
36
+ createdAt: string;
37
+ updatedAt: string;
38
+ isHandedOff: boolean;
39
+ isOpened: boolean;
40
+ assignee: {
41
+ kind: "human" | "ai" | "none" | "unknown";
42
+ name: string | null;
43
+ avatarUrl: string | null;
44
+ };
45
+ channel: string;
46
+ isVerified: boolean;
47
+ } | null>;
48
+ clearSession: () => Promise<void>;
49
+ cleanup: () => void;
50
+ initialState: import('../../../core/client/chat').ChatState;
51
+ sessionStorageKey: string;
52
+ recreateSession: () => Promise<void>;
53
+ contactState: import('../../../core').PubSub<{
54
+ contact: import('../../../core/types/contact').Contact | null;
55
+ loading: import('../../../core').LoadingState;
56
+ error: import('../../../core').ErrorState;
57
+ }>;
58
+ contactManager: {
59
+ shouldCollectData: () => {
60
+ should: boolean;
61
+ reason: string;
62
+ } | {
63
+ should: boolean;
64
+ reason?: undefined;
65
+ };
66
+ createUnauthenticatedContact: (payload: import('../../../core/sdk').Dto["CreateContactDto"]) => Promise<import('../../../core/sdk').Dto["WidgetContactDto"] | null>;
67
+ };
68
+ };
69
+ chatSession: {
70
+ id: string;
71
+ createdAt: string;
72
+ updatedAt: string;
73
+ isHandedOff: boolean;
74
+ isOpened: boolean;
75
+ assignee: {
76
+ kind: "human" | "ai" | "none" | "unknown";
77
+ name: string | null;
78
+ avatarUrl: string | null;
79
+ };
80
+ channel: string;
81
+ isVerified: boolean;
82
+ } | null;
83
+ };
@@ -0,0 +1 @@
1
+ export declare function useConfig(): import('../../../core/client/config').ConfigInstance;
@@ -0,0 +1,17 @@
1
+ export declare function useContact(): {
2
+ contactState: {
3
+ contact: import('../../../core/types/contact').Contact | null;
4
+ loading: import('../../../core').LoadingState;
5
+ error: import('../../../core').ErrorState;
6
+ };
7
+ contactManager: {
8
+ shouldCollectData: () => {
9
+ should: boolean;
10
+ reason: string;
11
+ } | {
12
+ should: boolean;
13
+ reason?: undefined;
14
+ };
15
+ createUnauthenticatedContact: (payload: import('../../../core/sdk').Dto["CreateContactDto"]) => Promise<import('../../../core/sdk').Dto["WidgetContactDto"] | null>;
16
+ };
17
+ };
@@ -0,0 +1,4 @@
1
+ export declare function useLocale(): {
2
+ get: (key: import('../locales/en.locale').TranslationKeysType, pfx?: string) => string;
3
+ lang: import('../locales').LangType;
4
+ };
@@ -0,0 +1,36 @@
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": import('../../../core/sdk/schema').components["schemas"]["WidgetPreludeDto"];
18
+ };
19
+ };
20
+ 500: {
21
+ headers: {
22
+ [name: string]: unknown;
23
+ };
24
+ content: {
25
+ "application/json": import('../../../core/sdk/schema').components["schemas"]["ErrorDto"];
26
+ };
27
+ };
28
+ };
29
+ }, {
30
+ params: {
31
+ header: {
32
+ "X-Bot-Token": string;
33
+ };
34
+ };
35
+ }, `${string}/${string}`>, any, any>;
36
+ export { usePreludeData };
@@ -0,0 +1,2 @@
1
+ import { PubSub } from '../../../core/types';
2
+ export declare function usePubsub<T>(p: PubSub<T>): T;
@@ -1,5 +1,5 @@
1
1
  interface FileWithProgress {
2
- status: "pending" | "uploading" | "success" | "error";
2
+ status: 'pending' | 'uploading' | 'success' | 'error';
3
3
  id: string;
4
4
  file: File;
5
5
  fileUrl?: string;
@@ -14,7 +14,7 @@ declare function useUploadFiles(): {
14
14
  emptyTheFiles: () => void;
15
15
  getFileById: (id: string) => FileWithProgress | undefined;
16
16
  getUploadProgress: (id: string) => number;
17
- getUploadStatus: (id: string) => "success" | "error" | "pending" | "uploading" | undefined;
17
+ getUploadStatus: (id: string) => "error" | "success" | "pending" | "uploading" | undefined;
18
18
  hasErrors: boolean;
19
19
  isUploading: boolean;
20
20
  };
@@ -9,10 +9,10 @@ export declare function useVote(id: string, sessionId: string, onSuccess?: () =>
9
9
  * @param onSuccess
10
10
  * @deprecated use useVote instead
11
11
  */
12
- export declare function useUpvote(id: string, onSuccess?: () => void): import('react-use/lib/useAsyncFn').AsyncFnReturn<() => Promise<void>>;
12
+ export declare function useUpvote(id: string, sessionId: string, onSuccess?: () => void): import('react-use/lib/useAsyncFn').AsyncFnReturn<() => Promise<void>>;
13
13
  /**
14
14
  * @param id
15
15
  * @param onSuccess
16
16
  * @deprecated use useVote instead
17
17
  */
18
- export declare function useDownvote(id: string, onSuccess?: () => void): import('react-use/lib/useAsyncFn').AsyncFnReturn<() => Promise<void>>;
18
+ export declare function useDownvote(id: string, sessionId: string, onSuccess?: () => void): import('react-use/lib/useAsyncFn').AsyncFnReturn<() => Promise<void>>;
@@ -0,0 +1,9 @@
1
+ export { useChatState } from './hooks/useChatMessages';
2
+ export { useChatSession } from './hooks/useChatSession';
3
+ export { useChat } from './ChatProvider';
4
+ export { useConfig } from './hooks/useConfig';
5
+ export { usePreludeData } from './hooks/usePreludeData';
6
+ export { useLocale } from './hooks/useLocale';
7
+ export { type FileWithProgress, useUploadFiles } from './hooks/useUploadFiles';
8
+ export { useContact } from './hooks/useContact';
9
+ export { useVote } from './hooks/useVote';
@@ -0,0 +1,2 @@
1
+ export { useChat, ChatProvider } from './ChatProvider';
2
+ export * from './hooks';
@@ -1,10 +1,4 @@
1
- export * from './types';
2
- export * from './utils';
3
- export { useUpvote, useDownvote, useUploadFiles, useVote, type FileWithProgress, } from './hooks';
4
- export { WidgetRoot } from './Root';
5
- export { useConfigData } from './providers/ConfigDataProvider';
6
- export { useChat } from './providers/ChatProvider';
7
- export { useLocale } from './providers/LocalesProvider';
8
- export { useWidgetSoundEffects } from './providers/use-widget-sfx';
9
- export { useContact } from './providers/ContactProvider';
10
- export { usePreludeData } from './providers/usePreludeData';
1
+ export { ChatProvider, useChat } from './core-integration/ChatProvider';
2
+ export { useChatState, useChatSession, useConfig, usePreludeData, useLocale, useContact, type FileWithProgress, useUploadFiles } from './core-integration/hooks';
3
+ export type { CoreOptions } from '../core/types';
4
+ export type { WidgetOptions } from './types/options';
@@ -1,10 +1,13 @@
1
1
  import { default as React } from 'react';
2
2
  import { BotMessageType } from '@core/types/messages';
3
+ import { StringOrLiteral } from '../../core/types';
3
4
  export type ComponentProps<TData> = BotMessageType<TData>;
4
- export type ComponentType = {
5
- key: string;
5
+ export type WidgetLiteralComponentKey = "bot_message" | "agent_message" | "loading" | "fallback";
6
+ export type WidgetComponentKey = StringOrLiteral<WidgetLiteralComponentKey>;
7
+ export type WidgetComponentType = {
8
+ key: WidgetComponentKey;
6
9
  component: React.ElementType;
7
10
  };
8
11
  export type OptionsType = {
9
- components?: ComponentType[];
12
+ components?: WidgetComponentType[];
10
13
  };