@opencx/widget 2.4.4-rn.0 → 2.4.4-rn.1
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/basic.cjs +1 -1
- package/dist/basic.js +1 -1
- package/dist/core/index.d.ts +2 -0
- package/dist/{index-BVoLVQCZ.cjs → index-Bx4hrNc7.cjs} +2 -2
- package/dist/{index-BVoLVQCZ.cjs.map → index-Bx4hrNc7.cjs.map} +1 -1
- package/dist/{index-Cjs7ckCU.js → index-ENMg5VOh.js} +2 -2
- package/dist/{index-Cjs7ckCU.js.map → index-ENMg5VOh.js.map} +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +313 -258
- package/dist/index.js.map +1 -1
- package/dist/package.json.d.ts +1 -1
- package/dist/react.cjs +1 -1
- package/dist/react.js +1 -1
- package/dist-embed/script.js +1 -1
- package/package.json +1 -1
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/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';\r\n\r\nexport type Subscriber<T> = (data: T) => void\r\n\r\nexport enum LifecycleEvent {\r\n INIT = 'init',\r\n STATE_CHANGE = 'stateChange',\r\n BEFORE_UPDATE = 'beforeUpdate',\r\n AFTER_UPDATE = 'afterUpdate',\r\n DESTROY = 'destroy',\r\n ERROR = 'error'\r\n}\r\n\r\ntype LifecycleListener = (event: { type: LifecycleEvent; timestamp: number; data?: any }) => void;\r\n\r\nexport class PubSub<S> {\r\n private subscribers = new Set<Subscriber<S>>();\r\n #state: S;\r\n private initialState: S;\r\n #lastUpdated: number | null;\r\n private lifecycleListeners: Map<LifecycleEvent, Set<LifecycleListener>> = new Map();\r\n\r\n constructor(state: S) {\r\n this.#state = state;\r\n this.initialState = state;\r\n this.#lastUpdated = Date.now();\r\n this.emitLifecycle(LifecycleEvent.INIT, { initialState: this.#state });\r\n }\r\n\r\n private emitLifecycle = (event: LifecycleEvent, data?: any) => {\r\n const listeners = this.lifecycleListeners.get(event);\r\n if (listeners) {\r\n const eventData = {\r\n type: event,\r\n timestamp: Date.now(),\r\n data\r\n };\r\n listeners.forEach(listener => listener(eventData));\r\n }\r\n }\r\n\r\n /**\r\n * Subscribe to state changes\r\n * @param callback Function to call when state changes\r\n * @returns Unsubscribe function\r\n */\r\n subscribe = (callback: Subscriber<S>): () => void => {\r\n this.subscribers.add(callback);\r\n callback(this.#state);\r\n\r\n return () => {\r\n this.subscribers.delete(callback);\r\n };\r\n }\r\n\r\n onLifecycle = (event: LifecycleEvent, listener: LifecycleListener): () => void => {\r\n if (!this.lifecycleListeners.has(event)) {\r\n this.lifecycleListeners.set(event, new Set());\r\n }\r\n const listeners = this.lifecycleListeners.get(event)!;\r\n listeners.add(listener);\r\n\r\n return () => {\r\n listeners.delete(listener);\r\n if (listeners.size === 0) {\r\n this.lifecycleListeners.delete(event);\r\n }\r\n };\r\n }\r\n\r\n /**\r\n * Get the current state\r\n */\r\n getState = (): S => {\r\n return this.#state;\r\n }\r\n\r\n /**\r\n * Set the state and notify subscribers if the state changes\r\n * @param newState The new state to set\r\n */\r\n setState = (newState: S): void => {\r\n this.emitLifecycle(LifecycleEvent.BEFORE_UPDATE, {\r\n previousState: this.#state,\r\n nextState: newState\r\n });\r\n\r\n if (!isEqual(this.#state, newState)) {\r\n this.#state = newState;\r\n this.#lastUpdated = Date.now();\r\n this.emitLifecycle(LifecycleEvent.STATE_CHANGE, { state: newState });\r\n this.subscribers.forEach(callback => {\r\n try {\r\n callback(newState);\r\n } catch (error) {\r\n this.emitLifecycle(LifecycleEvent.ERROR, { error });\r\n }\r\n });\r\n }\r\n\r\n this.emitLifecycle(LifecycleEvent.AFTER_UPDATE, { state: newState });\r\n }\r\n\r\n setStatePartial = (_s: Partial<S>): void => {\r\n const newState = { ...this.#state, ..._s };\r\n this.setState(newState);\r\n }\r\n\r\n /**\r\n * Clear all subscriptions\r\n */\r\n clear = (): void => {\r\n this.emitLifecycle(LifecycleEvent.DESTROY);\r\n this.subscribers.clear();\r\n this.lifecycleListeners.clear();\r\n }\r\n\r\n reset = (): void => {\r\n this.setState(this.initialState);\r\n }\r\n\r\n lastUpdated = (): number | null => {\r\n return this.#lastUpdated;\r\n }\r\n}\r\n\r\nexport function createPubSub<S>(state: S): PubSub<S> {\r\n return new PubSub<S>(state);\r\n}","export class OpenCXError extends Error {\r\n constructor(message: string) {\r\n super(message);\r\n this.name = \"OpenCXError\";\r\n }\r\n}\r\n\r\nexport class ConnectionError extends OpenCXError {\r\n constructor(message = \"Connection failed\") {\r\n super(message);\r\n this.name = \"ConnectionError\";\r\n }\r\n}\r\n\r\nexport class AuthenticationError extends OpenCXError {\r\n constructor(message = \"Authentication failed\") {\r\n super(message);\r\n this.name = \"AuthenticationError\";\r\n }\r\n}\r\n\r\nexport class SessionError extends OpenCXError {\r\n constructor(message = \"Session error occurred\") {\r\n super(message);\r\n this.name = \"SessionError\";\r\n }\r\n}\r\n\r\nexport class SessionNotDefinedError extends SessionError {\r\n constructor(message = \"Session not defined\") {\r\n super(message);\r\n this.name = \"SessionNotDefinedError\";\r\n }\r\n}\r\n\r\nexport class TransportError extends OpenCXError {\r\n constructor(message = \"Transport error occurred\") {\r\n super(message);\r\n this.name = \"TransportError\";\r\n }\r\n}\r\n\r\nexport class FileUploadError extends OpenCXError {\r\n constructor(message = \"File upload failed\") {\r\n super(message);\r\n this.name = \"FileUploadError\";\r\n }\r\n}\r\n","/**\r\n * Platform-agnostic storage interface that can be implemented\r\n * for different environments (web, mobile, desktop, etc.)\r\n */\r\nexport interface Storage {\r\n /**\r\n * Retrieves the value associated with the given key\r\n * @param key The key to look up\r\n * @returns The stored value or null if not found\r\n */\r\n getItem(key: string): Promise<string | null>;\r\n\r\n /**\r\n * Stores a value with the given key\r\n * @param key The key to store under\r\n * @param value The value to store\r\n */\r\n setItem(key: string, value: string): Promise<void>;\r\n\r\n /**\r\n * Removes the value associated with the given key\r\n * @param key The key to remove\r\n */\r\n removeItem(key: string): Promise<void>;\r\n\r\n /**\r\n * Checks if the storage is available and working\r\n * @returns true if storage is available and working\r\n */\r\n isAvailable?(): boolean;\r\n}\r\n\r\n/**\r\n * Helper function to check if storage is available and working\r\n */\r\nexport function isStorageAvailable(storage: Storage | undefined): storage is Storage {\r\n if (!storage) return false;\r\n try {\r\n return typeof storage.isAvailable === 'function'\r\n ? storage.isAvailable()\r\n : true; // If isAvailable is not implemented, assume storage is available\r\n } catch {\r\n return false;\r\n }\r\n}\r\n\r\n/**\r\n * Type for the result of a safe storage operation\r\n */\r\nexport type StorageOperationResult<T> =\r\n | { success: true; result: T }\r\n | { success: false; error: Error };\r\n\r\n/**\r\n * Helper function to safely perform storage operations\r\n */\r\nexport async function safeStorageOperation<T>(\r\n operation: () => Promise<T>,\r\n errorMessage: string\r\n): Promise<StorageOperationResult<T>> {\r\n try {\r\n const result = await operation();\r\n return { success: true, result };\r\n } catch (error) {\r\n console.error(errorMessage, error);\r\n return {\r\n success: false,\r\n error: error instanceof Error ? error : new Error(errorMessage)\r\n };\r\n }\r\n} ","import { PubSub } from \"../types/pub-sub\";\nimport { MessageType } from \"../types\";\nimport { ApiCaller } from \"./api\";\nimport { genId } from \"../utils/genId\";\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\";\n\n// Constants\nconst POLLING_INTERVALS = {\n SESSION: 10000, // every 10 seconds\n MESSAGES: 5000 // every 5 seconds\n} as const;\n\n// Types\ntype ChatState = {\n messages: MessageType[];\n keyboard: { options: string[] } | null;\n loading: LoadingState;\n error: ErrorState;\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 || genId(),\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 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\n // Get the latest message timestamp\n const lastMessage = messages[messages.length - 1];\n const lastTimestamp = new Date(lastMessage.timestamp);\n // Add 1 second to avoid getting the same message\n lastTimestamp.setSeconds(lastTimestamp.getSeconds() + 1);\n const lastMessageTimestamp = lastTimestamp.toISOString();\n\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: genId(),\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 || genId(),\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: genId(),\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: genId(),\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 sessionStorageKey = `${config.getConfig().user.external_id}:${config.getConfig().token}:session`;\n const persistSession = options.config.getSettings().persistSession;\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 function setupSessionPersistence() {\n if (!storage) return;\n\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 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 response = await api.getSession(session.id);\n if (response) {\n sessionState.setState(response);\n }\n } catch (error) {\n logger?.error('Error polling session:', error);\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 await messageHandler.fetchHistoryMessages(session);\n } catch (error) {\n logger?.error('Error polling messages:', error);\n }\n }, POLLING_INTERVALS.MESSAGES)\n );\n\n stopPolling = () => {\n logger?.debug('Stopping polling');\n intervals.forEach(clearInterval);\n };\n }\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 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 && isStorageAvailable(storage)) {\n storage.removeItem(sessionStorageKey);\n }\n\n chatState.setState({\n messages: [],\n keyboard: null,\n loading: { isLoading: false },\n error: { hasError: false }\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 function cleanup() {\n try {\n if (stopPolling) {\n stopPolling();\n stopPolling = null;\n }\n\n if (persistSession && storage && isStorageAvailable(storage)) {\n storage.removeItem(sessionStorageKey);\n }\n\n chatState.setState({\n messages: [],\n keyboard: null,\n loading: { isLoading: false },\n error: { hasError: false }\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 // 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 };\n}\n\n// Main Chat Function\nexport function createChat(options: ChatOptions) {\n const logger = options.platform?.logger;\n logger?.info('Initializing chat');\n\n const state = new PubSub<ChatState>({\n messages: [],\n keyboard: null,\n loading: { isLoading: false },\n error: { hasError: false }\n });\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: SomeOptional<Omit<HttpChatInputSchema, \"bot_token\">, \"session_id\" | \"user\">) {\n let session = sessionState.getState();\n if (!session?.id) {\n logger?.debug('No active session, creating new session');\n session = await sessionManager.createSession();\n if (!session) return false;\n }\n\n try {\n logger?.debug('Sending message', { sessionId: session.id });\n state.setStatePartial({\n loading: { isLoading: true, reason: 'sending_message' },\n error: { hasError: false }\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 bot_token: config.token,\n headers: config.headers,\n query_params: config.queryParams,\n session_id: session.id,\n ...input,\n });\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 } 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 }\n\n return true;\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 false;\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 };\n} ","import { PubSub } from \"../types/pub-sub\";\r\nimport { ConsumerType } from \"../types\";\r\nimport { ApiCaller } from \"./api\";\r\nimport { Platform, Storage, isStorageAvailable, safeStorageOperation } from \"../platform\";\r\nimport { LoadingState, ErrorState } from \"../types/helpers\";\r\nimport { ConfigInstance } from \"./config\";\r\n\r\ntype ContactState = {\r\n contact: ConsumerType | null;\r\n loading: LoadingState;\r\n error: ErrorState;\r\n};\r\n\r\ntype ContactOptions = {\r\n api: ApiCaller;\r\n platform: Platform;\r\n config: ConfigInstance\r\n};\r\n\r\nexport function createContact(options: ContactOptions) {\r\n const config = options.config.getConfig();\r\n options.config.getConfig\r\n const storageKey = `${config.token}:contact:${config.user.external_id}`;\r\n const storage = isStorageAvailable(options.platform.storage) ? options.platform.storage : undefined;\r\n\r\n // Initialize state from storage if available\r\n let initialContact: ConsumerType | null = null;\r\n if (storage) {\r\n safeStorageOperation(\r\n async () => {\r\n const stored = await storage.getItem(storageKey);\r\n return stored ? JSON.parse(stored) : null;\r\n },\r\n \"Error loading contact from storage\"\r\n ).then((result) => {\r\n if (result.success) {\r\n initialContact = result.result;\r\n }\r\n });\r\n }\r\n\r\n const state = new PubSub<ContactState>({\r\n contact: initialContact,\r\n loading: { isLoading: false },\r\n error: { hasError: false }\r\n });\r\n\r\n // Subscribe to state changes to persist\r\n if (isStorageAvailable(storage)) {\r\n state.subscribe((currentState) => {\r\n const result = safeStorageOperation(\r\n async () => {\r\n if (currentState.contact) {\r\n await storage.setItem(storageKey, JSON.stringify(currentState.contact));\r\n } else {\r\n storage.removeItem(storageKey);\r\n }\r\n },\r\n \"Error persisting contact state\"\r\n ).then((result) => {\r\n if (!result.success) {\r\n state.setStatePartial({\r\n error: {\r\n hasError: true,\r\n message: result.error.message,\r\n code: 'CONTACT_PERSISTENCE_FAILED'\r\n }\r\n });\r\n }\r\n });\r\n });\r\n }\r\n\r\n async function loadContact() {\r\n try {\r\n state.setStatePartial({\r\n loading: { isLoading: true, reason: 'loading_contact' },\r\n error: { hasError: false }\r\n });\r\n\r\n if (storage) {\r\n const result = await safeStorageOperation(\r\n async () => {\r\n const stored = await storage.getItem(storageKey);\r\n return stored ? JSON.parse(stored) : null;\r\n },\r\n \"Error loading contact\"\r\n );\r\n\r\n if (!result.success) {\r\n throw result.error;\r\n }\r\n\r\n state.setStatePartial({\r\n contact: result.result,\r\n error: { hasError: false }\r\n });\r\n\r\n return result.result;\r\n }\r\n\r\n return state.getState().contact;\r\n } catch (error) {\r\n state.setStatePartial({\r\n error: {\r\n hasError: true,\r\n message: error instanceof Error ? error.message : 'Failed to load contact',\r\n code: 'CONTACT_LOAD_FAILED'\r\n }\r\n });\r\n return null;\r\n } finally {\r\n state.setStatePartial({\r\n loading: { isLoading: false, reason: null }\r\n });\r\n }\r\n }\r\n\r\n async function saveContact(contactData: Partial<ConsumerType>) {\r\n try {\r\n state.setStatePartial({\r\n loading: { isLoading: true, reason: 'saving_contact' },\r\n error: { hasError: false }\r\n });\r\n\r\n const currentContact = state.getState().contact;\r\n const updatedContact: ConsumerType = {\r\n id: contactData.id || currentContact?.id || '',\r\n name: contactData.name ?? currentContact?.name ?? null,\r\n created_at: contactData.created_at || currentContact?.created_at || new Date().toISOString(),\r\n avatar_url: contactData.avatar_url ?? currentContact?.avatar_url ?? null,\r\n email: contactData.email ?? currentContact?.email ?? null\r\n };\r\n\r\n if (isStorageAvailable(storage)) {\r\n const result = await safeStorageOperation(\r\n () => storage.setItem(storageKey, JSON.stringify(updatedContact)),\r\n \"Error saving contact\"\r\n );\r\n\r\n if (!result.success) {\r\n throw result.error;\r\n }\r\n }\r\n\r\n state.setStatePartial({\r\n contact: updatedContact,\r\n error: { hasError: false }\r\n });\r\n\r\n return updatedContact;\r\n } catch (error) {\r\n state.setStatePartial({\r\n error: {\r\n hasError: true,\r\n message: error instanceof Error ? error.message : 'Failed to save contact',\r\n code: 'CONTACT_SAVE_FAILED'\r\n }\r\n });\r\n return null;\r\n } finally {\r\n state.setStatePartial({\r\n loading: { isLoading: false, reason: null }\r\n });\r\n }\r\n }\r\n\r\n function shouldCollectData(): { should: boolean; reason?: string } {\r\n const currentState = state.getState();\r\n\r\n if (!currentState.contact?.id && config.collectUserData) {\r\n return {\r\n should: true,\r\n reason: \"No contact id and collectUserData is true\"\r\n };\r\n }\r\n\r\n return {\r\n should: false\r\n };\r\n }\r\n\r\n async function cleanup() {\r\n try {\r\n state.setStatePartial({\r\n loading: { isLoading: true, reason: 'cleaning_up' },\r\n error: { hasError: false }\r\n });\r\n\r\n if (storage) {\r\n const result = await safeStorageOperation(\r\n () => storage.removeItem(storageKey),\r\n \"Error removing contact data\"\r\n );\r\n\r\n if (!result.success) {\r\n throw result.error;\r\n }\r\n }\r\n\r\n state.setState({\r\n contact: null,\r\n loading: { isLoading: false },\r\n error: { hasError: false }\r\n });\r\n\r\n state.clear();\r\n } catch (error) {\r\n console.error(\"Error cleaning up contact:\", error);\r\n state.setStatePartial({\r\n error: {\r\n hasError: true,\r\n message: error instanceof Error ? error.message : 'Failed to cleanup contact data',\r\n code: 'CONTACT_CLEANUP_FAILED'\r\n }\r\n });\r\n } finally {\r\n state.setStatePartial({\r\n loading: { isLoading: false, reason: null }\r\n });\r\n }\r\n }\r\n\r\n return {\r\n contactState: state,\r\n shouldCollectData,\r\n loadContact,\r\n saveContact,\r\n cleanup,\r\n };\r\n} ","import { CoreOptions } from \"../types\";\r\n\r\nconst DEFAULT_SOUND_EFFECTS = {\r\n messageArrived: \"https://cloud.opencopilot.so/sfx/notification3.mp3\"\r\n};\r\n\r\nconst DEFAULT_THEME = {\r\n primaryColor: \"hsl(211,65%,59%)\",\r\n triggerOffset: \"20px\"\r\n};\r\n\r\nexport type NormalizedConfig = Required<Omit<CoreOptions, 'contactToken'>> & {\r\n contactToken: string | undefined | null;\r\n soundEffectFiles: {\r\n messageArrived: string;\r\n };\r\n theme: {\r\n primaryColor: string;\r\n triggerOffset: string;\r\n };\r\n settings: {\r\n persistSession: boolean;\r\n useSoundEffects: boolean;\r\n };\r\n};\r\n\r\nexport type ConfigInstance = {\r\n getConfig: () => NormalizedConfig;\r\n getApiConfig: () => {\r\n apiUrl: string;\r\n token: string;\r\n headers: Record<string, string>;\r\n queryParams: Record<string, string>;\r\n pathParams: Record<string, string>;\r\n };\r\n getBotConfig: () => NormalizedConfig['bot'];\r\n getThemeConfig: () => NormalizedConfig['theme'];\r\n getSettings: () => NormalizedConfig['settings'];\r\n getSoundEffects: () => NormalizedConfig['soundEffectFiles'];\r\n getUser: () => NormalizedConfig['user'];\r\n getLanguage: () => string;\r\n getDebugMode: () => boolean;\r\n};\r\n\r\nconst MIN_POLLING_INTERVAL = 1000 * 3;\r\n\r\nexport function createConfig(options: CoreOptions): ConfigInstance {\r\n if (!options.token) {\r\n throw new Error(\"Token is required\");\r\n }\r\n\r\n if (options.pollingInterval && options.pollingInterval < MIN_POLLING_INTERVAL) {\r\n throw new Error(\"Polling interval must be at least 3 seconds\");\r\n }\r\n\r\n const normalizedConfig: NormalizedConfig = {\r\n ...options,\r\n collectUserData: options.collectUserData ?? false,\r\n apiUrl: options.apiUrl ?? \"https://api-v2.opencopilot.so/backend\",\r\n socketUrl: options.socketUrl ?? \"https://api-v2.opencopilot.so\",\r\n pollingInterval: options.pollingInterval ?? 3000,\r\n headers: options.headers ?? {},\r\n queryParams: options.queryParams ?? {},\r\n pathParams: options.pathParams ?? {},\r\n bot: {\r\n name: options.bot?.name ?? \"Bot\",\r\n avatarUrl: options.bot?.avatarUrl,\r\n id: options.bot?.id ?? null,\r\n is_ai: options.bot?.is_ai ?? true\r\n },\r\n contactToken: options.contactToken,\r\n debug: options.debug ?? false,\r\n language: options.language ?? \"en\",\r\n user: options.user ?? {},\r\n soundEffectFiles: {\r\n messageArrived: options.soundEffectFiles?.messageArrived ?? DEFAULT_SOUND_EFFECTS.messageArrived\r\n },\r\n theme: {\r\n primaryColor: options.theme?.primaryColor ?? DEFAULT_THEME.primaryColor,\r\n triggerOffset: options.theme?.triggerOffset ?? DEFAULT_THEME.triggerOffset\r\n },\r\n settings: {\r\n persistSession: options.settings?.persistSession ?? false,\r\n useSoundEffects: options.settings?.useSoundEffects ?? false\r\n },\r\n };\r\n\r\n return {\r\n getConfig: () => normalizedConfig,\r\n getApiConfig: () => ({\r\n apiUrl: normalizedConfig.apiUrl,\r\n token: normalizedConfig.token,\r\n headers: normalizedConfig.headers,\r\n queryParams: normalizedConfig.queryParams,\r\n pathParams: normalizedConfig.pathParams\r\n }),\r\n getBotConfig: () => normalizedConfig.bot,\r\n getThemeConfig: () => normalizedConfig.theme,\r\n getSettings: () => normalizedConfig.settings,\r\n getSoundEffects: () => normalizedConfig.soundEffectFiles,\r\n getUser: () => normalizedConfig.user,\r\n getLanguage: () => normalizedConfig.language,\r\n getDebugMode: () => normalizedConfig.debug\r\n };\r\n} ","type RequestInterceptor = (config: RequestConfig) => RequestConfig | Promise<RequestConfig>;\r\ntype ResponseInterceptor = (response: Response) => Response | Promise<Response>;\r\ntype ErrorInterceptor = (error: any) => any;\r\n\r\ninterface RequestConfig extends RequestInit {\r\n baseURL?: string;\r\n headers?: HeadersInit;\r\n params?: Record<string, string>;\r\n}\r\n\r\nexport interface CustomFetch {\r\n (url: string, config?: RequestConfig): Promise<Response>;\r\n interceptors: {\r\n request: {\r\n use: (interceptor: RequestInterceptor) => number;\r\n eject: (id: number) => void;\r\n };\r\n response: {\r\n use: (interceptor: ResponseInterceptor, errorInterceptor?: ErrorInterceptor) => number;\r\n eject: (id: number) => void;\r\n };\r\n };\r\n}\r\n\r\nexport function createFetch(defaultConfig: RequestConfig = {}): CustomFetch {\r\n const requestInterceptors: RequestInterceptor[] = [];\r\n const responseInterceptors: ResponseInterceptor[] = [];\r\n const errorInterceptors: ErrorInterceptor[] = [];\r\n\r\n const customFetch: CustomFetch = async (url: string, config: RequestConfig = {}) => {\r\n // Merge configs\r\n let mergedConfig: RequestConfig = {\r\n ...defaultConfig,\r\n ...config,\r\n headers: {\r\n ...defaultConfig.headers,\r\n ...config.headers,\r\n },\r\n };\r\n\r\n try {\r\n // Apply request interceptors\r\n for (const interceptor of requestInterceptors) {\r\n mergedConfig = await interceptor(mergedConfig);\r\n }\r\n\r\n // Handle URL params\r\n const queryParams = mergedConfig.params\r\n ? '?' + new URLSearchParams(mergedConfig.params).toString()\r\n : '';\r\n\r\n // Construct full URL\r\n const fullUrl = mergedConfig.baseURL\r\n ? `${mergedConfig.baseURL}${url}${queryParams}`.replace(/([^:]\\/)\\/+/g, '$1')\r\n : `${url}${queryParams}`;\r\n\r\n // Make the fetch call\r\n let response = await fetch(fullUrl, mergedConfig);\r\n\r\n // Apply response interceptors\r\n for (const interceptor of responseInterceptors) {\r\n response = await interceptor(response);\r\n }\r\n\r\n return response;\r\n } catch (error) {\r\n // Apply error interceptors\r\n let processedError = error;\r\n for (const interceptor of errorInterceptors) {\r\n processedError = await interceptor(processedError);\r\n }\r\n throw processedError;\r\n }\r\n };\r\n\r\n // Add interceptors management\r\n customFetch.interceptors = {\r\n request: {\r\n use: (interceptor: RequestInterceptor) => {\r\n requestInterceptors.push(interceptor);\r\n return requestInterceptors.length - 1;\r\n },\r\n eject: (id: number) => {\r\n requestInterceptors.splice(id, 1);\r\n },\r\n },\r\n response: {\r\n use: (interceptor: ResponseInterceptor, errorInterceptor?: ErrorInterceptor) => {\r\n responseInterceptors.push(interceptor);\r\n if (errorInterceptor) {\r\n errorInterceptors.push(errorInterceptor);\r\n }\r\n return responseInterceptors.length - 1;\r\n },\r\n eject: (id: number) => {\r\n responseInterceptors.splice(id, 1);\r\n errorInterceptors.splice(id, 1);\r\n },\r\n },\r\n };\r\n\r\n return customFetch;\r\n}\r\n\r\n// Helper method to handle JSON responses\r\nexport async function handleJsonResponse<T>(response: Response): Promise<T> {\r\n if (!response.ok) {\r\n throw new Error(`HTTP error! status: ${response.status}`);\r\n }\r\n return response.json();\r\n}\r\n\r\n// Usage example:\r\n/*\r\nconst api = createFetch({\r\n baseURL: 'https://api.example.com',\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n },\r\n});\r\n\r\n// Add request interceptor\r\napi.interceptors.request.use((config) => {\r\n config.headers = {\r\n ...config.headers,\r\n 'Authorization': `Bearer ${getToken()}`,\r\n };\r\n return config;\r\n});\r\n\r\n// Add response interceptor\r\napi.interceptors.response.use(\r\n async (response) => {\r\n if (!response.ok) {\r\n throw new Error(`HTTP error! status: ${response.status}`);\r\n }\r\n return response;\r\n },\r\n (error) => {\r\n console.error('Request failed:', error);\r\n throw error;\r\n }\r\n);\r\n*/\r\n","import { createFetch, CustomFetch } from \"../utils/create-fetch\";\r\nimport { HandleContactMessageOutputSchema, HttpChatInputSchema, WidgetHistorySchema, WidgetPreludeSchema, WidgetSessionSchema } from \"../types/schemas-v2\";\r\nimport { CoreOptions, ConsumerType } from \"../types\";\r\nimport { NormalizedConfig } from \"./config\";\r\n\r\nexport interface ApiCallerOptions {\r\n config: NormalizedConfig;\r\n}\r\n\r\nexport class ApiCaller {\r\n #fetch: CustomFetch\r\n constructor(private readonly options: ApiCallerOptions) {\r\n const user = this.options.config.user;\r\n const consumerHeader = {\r\n claim: '',\r\n value: ''\r\n }\r\n\r\n if (user?.email) {\r\n consumerHeader.claim = 'email';\r\n consumerHeader.value = user.email;\r\n }\r\n\r\n else if (user?.phone) {\r\n consumerHeader.claim = 'phone';\r\n consumerHeader.value = user.phone;\r\n }\r\n\r\n const headers: Record<string, string> = {\r\n 'X-Bot-Token': this.options.config.token,\r\n 'X-Consumer-Id': `${consumerHeader.claim}:${consumerHeader.value}`,\r\n \"Content-Type\": \"application/json\",\r\n \"Accept\": \"application/json\"\r\n }\r\n\r\n // Only add Authorization header if contactToken exists\r\n if (this.options.config.contactToken) {\r\n headers['Authorization'] = `Bearer ${this.options.config.contactToken}`\r\n }\r\n\r\n this.#fetch = createFetch({\r\n baseURL: `${this.options.config.apiUrl}/widget/v2`,\r\n headers\r\n })\r\n }\r\n\r\n async me(): Promise<{\r\n contactId: string;\r\n contactName: string;\r\n }> {\r\n // GET /me\r\n const response = await this.#fetch('/me')\r\n return response.json()\r\n }\r\n\r\n async widgetPrelude(): Promise<WidgetPreludeSchema> {\r\n // GET /prelude\r\n const response = await this.#fetch('/prelude')\r\n return response.json()\r\n }\r\n\r\n async handleMessage(message: HttpChatInputSchema) {\r\n // POST /chat/send\r\n const response = await this.#fetch('/chat/send', {\r\n method: \"POST\",\r\n body: JSON.stringify(message)\r\n })\r\n return response.json() as Promise<HandleContactMessageOutputSchema>\r\n }\r\n\r\n async getSessionHistory(sessionId: string, lastMessageTimestamp?: string): Promise<WidgetHistorySchema[]> {\r\n // session/history/:sessionId\r\n const queryParams = new URLSearchParams({\r\n lastMessageTimestamp: lastMessageTimestamp || ''\r\n })\r\n\r\n const url = `/session/history/${sessionId}?${queryParams.toString()}`\r\n\r\n const response = await this.#fetch(url, {\r\n method: 'GET'\r\n })\r\n\r\n return response.json()\r\n }\r\n\r\n async createSession(): Promise<WidgetSessionSchema> {\r\n // POST /create-session\r\n const response = await this.#fetch('/create-session', {\r\n method: 'POST'\r\n })\r\n return response.json()\r\n }\r\n\r\n async getSession(sessionId: string): Promise<WidgetSessionSchema> {\r\n // GET /session/:sessionId\r\n const response = await this.#fetch(`/session/${sessionId}`, {\r\n method: 'GET'\r\n })\r\n return response.json()\r\n }\r\n\r\n async createContact(user: {\r\n external_id?: string;\r\n name?: string;\r\n email?: string;\r\n phone?: string;\r\n customData?: Record<string, string>;\r\n avatarUrl?: string;\r\n }): Promise<ConsumerType> {\r\n const response = await this.#fetch('/contact/upsert', {\r\n method: 'POST',\r\n body: JSON.stringify(user)\r\n });\r\n return response.json();\r\n }\r\n}\r\n"],"names":["LifecycleEvent","PubSub","state","__publicField","__privateAdd","_state","_lastUpdated","event","data","listeners","eventData","listener","callback","__privateGet","newState","isEqual","__privateSet","error","_s","createPubSub","OpenCXError","message","ConnectionError","AuthenticationError","SessionError","SessionNotDefinedError","TransportError","FileUploadError","isStorageAvailable","storage","safeStorageOperation","operation","errorMessage","POLLING_INTERVALS","mapHistoryToMessage","history","commonFields","genId","createMessageHandler","api","logger","fetchHistoryMessages","session","messages","response","lastMessage","lastTimestamp","lastMessageTimestamp","newMessages","newMsg","existingMsg","m","addUserMessage","content","attachments","addBotMessage","uiVal","addErrorMessage","createSessionManager","sessionState","chatState","messageHandler","config","options","_a","stopPolling","_b","sessionStorageKey","persistSession","restoreSession","storedSession","startPolling","setupSessionPersistence","intervals","createSession","errorState","clearSession","cleanup","createChat","sessionManager","sendMessage","input","userMessage","currentMessages","botMessage","updatedMessages","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","requestInterceptors","responseInterceptors","errorInterceptors","customFetch","url","mergedConfig","interceptor","queryParams","fullUrl","processedError","id","errorInterceptor","ApiCaller","_fetch","user","consumerHeader","headers","sessionId"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../core/types/pub-sub.ts","../core/errors/index.ts","../core/platform/storage.ts","../core/client/chat.ts","../core/client/contact.ts","../core/client/config.ts","../core/utils/create-fetch.ts","../core/client/api.ts","../core/platform/logger.ts"],"sourcesContent":["import isEqual from 'lodash.isequal';\r\n\r\nexport type Subscriber<T> = (data: T) => void\r\n\r\nexport enum LifecycleEvent {\r\n INIT = 'init',\r\n STATE_CHANGE = 'stateChange',\r\n BEFORE_UPDATE = 'beforeUpdate',\r\n AFTER_UPDATE = 'afterUpdate',\r\n DESTROY = 'destroy',\r\n ERROR = 'error'\r\n}\r\n\r\ntype LifecycleListener = (event: { type: LifecycleEvent; timestamp: number; data?: any }) => void;\r\n\r\nexport class PubSub<S> {\r\n private subscribers = new Set<Subscriber<S>>();\r\n #state: S;\r\n private initialState: S;\r\n #lastUpdated: number | null;\r\n private lifecycleListeners: Map<LifecycleEvent, Set<LifecycleListener>> = new Map();\r\n\r\n constructor(state: S) {\r\n this.#state = state;\r\n this.initialState = state;\r\n this.#lastUpdated = Date.now();\r\n this.emitLifecycle(LifecycleEvent.INIT, { initialState: this.#state });\r\n }\r\n\r\n private emitLifecycle = (event: LifecycleEvent, data?: any) => {\r\n const listeners = this.lifecycleListeners.get(event);\r\n if (listeners) {\r\n const eventData = {\r\n type: event,\r\n timestamp: Date.now(),\r\n data\r\n };\r\n listeners.forEach(listener => listener(eventData));\r\n }\r\n }\r\n\r\n /**\r\n * Subscribe to state changes\r\n * @param callback Function to call when state changes\r\n * @returns Unsubscribe function\r\n */\r\n subscribe = (callback: Subscriber<S>): () => void => {\r\n this.subscribers.add(callback);\r\n callback(this.#state);\r\n\r\n return () => {\r\n this.subscribers.delete(callback);\r\n };\r\n }\r\n\r\n onLifecycle = (event: LifecycleEvent, listener: LifecycleListener): () => void => {\r\n if (!this.lifecycleListeners.has(event)) {\r\n this.lifecycleListeners.set(event, new Set());\r\n }\r\n const listeners = this.lifecycleListeners.get(event)!;\r\n listeners.add(listener);\r\n\r\n return () => {\r\n listeners.delete(listener);\r\n if (listeners.size === 0) {\r\n this.lifecycleListeners.delete(event);\r\n }\r\n };\r\n }\r\n\r\n /**\r\n * Get the current state\r\n */\r\n getState = (): S => {\r\n return this.#state;\r\n }\r\n\r\n /**\r\n * Set the state and notify subscribers if the state changes\r\n * @param newState The new state to set\r\n */\r\n setState = (newState: S): void => {\r\n this.emitLifecycle(LifecycleEvent.BEFORE_UPDATE, {\r\n previousState: this.#state,\r\n nextState: newState\r\n });\r\n\r\n if (!isEqual(this.#state, newState)) {\r\n this.#state = newState;\r\n this.#lastUpdated = Date.now();\r\n this.emitLifecycle(LifecycleEvent.STATE_CHANGE, { state: newState });\r\n this.subscribers.forEach(callback => {\r\n try {\r\n callback(newState);\r\n } catch (error) {\r\n this.emitLifecycle(LifecycleEvent.ERROR, { error });\r\n }\r\n });\r\n }\r\n\r\n this.emitLifecycle(LifecycleEvent.AFTER_UPDATE, { state: newState });\r\n }\r\n\r\n setStatePartial = (_s: Partial<S>): void => {\r\n const newState = { ...this.#state, ..._s };\r\n this.setState(newState);\r\n }\r\n\r\n /**\r\n * Clear all subscriptions\r\n */\r\n clear = (): void => {\r\n this.emitLifecycle(LifecycleEvent.DESTROY);\r\n this.subscribers.clear();\r\n this.lifecycleListeners.clear();\r\n }\r\n\r\n reset = (): void => {\r\n this.setState(this.initialState);\r\n }\r\n\r\n lastUpdated = (): number | null => {\r\n return this.#lastUpdated;\r\n }\r\n}\r\n\r\nexport function createPubSub<S>(state: S): PubSub<S> {\r\n return new PubSub<S>(state);\r\n}","export class OpenCXError extends Error {\r\n constructor(message: string) {\r\n super(message);\r\n this.name = \"OpenCXError\";\r\n }\r\n}\r\n\r\nexport class ConnectionError extends OpenCXError {\r\n constructor(message = \"Connection failed\") {\r\n super(message);\r\n this.name = \"ConnectionError\";\r\n }\r\n}\r\n\r\nexport class AuthenticationError extends OpenCXError {\r\n constructor(message = \"Authentication failed\") {\r\n super(message);\r\n this.name = \"AuthenticationError\";\r\n }\r\n}\r\n\r\nexport class SessionError extends OpenCXError {\r\n constructor(message = \"Session error occurred\") {\r\n super(message);\r\n this.name = \"SessionError\";\r\n }\r\n}\r\n\r\nexport class SessionNotDefinedError extends SessionError {\r\n constructor(message = \"Session not defined\") {\r\n super(message);\r\n this.name = \"SessionNotDefinedError\";\r\n }\r\n}\r\n\r\nexport class TransportError extends OpenCXError {\r\n constructor(message = \"Transport error occurred\") {\r\n super(message);\r\n this.name = \"TransportError\";\r\n }\r\n}\r\n\r\nexport class FileUploadError extends OpenCXError {\r\n constructor(message = \"File upload failed\") {\r\n super(message);\r\n this.name = \"FileUploadError\";\r\n }\r\n}\r\n","/**\r\n * Platform-agnostic storage interface that can be implemented\r\n * for different environments (web, mobile, desktop, etc.)\r\n */\r\nexport interface Storage {\r\n /**\r\n * Retrieves the value associated with the given key\r\n * @param key The key to look up\r\n * @returns The stored value or null if not found\r\n */\r\n getItem(key: string): Promise<string | null>;\r\n\r\n /**\r\n * Stores a value with the given key\r\n * @param key The key to store under\r\n * @param value The value to store\r\n */\r\n setItem(key: string, value: string): Promise<void>;\r\n\r\n /**\r\n * Removes the value associated with the given key\r\n * @param key The key to remove\r\n */\r\n removeItem(key: string): Promise<void>;\r\n\r\n /**\r\n * Checks if the storage is available and working\r\n * @returns true if storage is available and working\r\n */\r\n isAvailable?(): boolean;\r\n}\r\n\r\n/**\r\n * Helper function to check if storage is available and working\r\n */\r\nexport function isStorageAvailable(storage: Storage | undefined): storage is Storage {\r\n if (!storage) return false;\r\n try {\r\n return typeof storage.isAvailable === 'function'\r\n ? storage.isAvailable()\r\n : true; // If isAvailable is not implemented, assume storage is available\r\n } catch {\r\n return false;\r\n }\r\n}\r\n\r\n/**\r\n * Type for the result of a safe storage operation\r\n */\r\nexport type StorageOperationResult<T> =\r\n | { success: true; result: T }\r\n | { success: false; error: Error };\r\n\r\n/**\r\n * Helper function to safely perform storage operations\r\n */\r\nexport async function safeStorageOperation<T>(\r\n operation: () => Promise<T>,\r\n errorMessage: string\r\n): Promise<StorageOperationResult<T>> {\r\n try {\r\n const result = await operation();\r\n return { success: true, result };\r\n } catch (error) {\r\n console.error(errorMessage, error);\r\n return {\r\n success: false,\r\n error: error instanceof Error ? error : new Error(errorMessage)\r\n };\r\n }\r\n} ","import { PubSub } from \"../types/pub-sub\";\nimport { MessageType } from \"../types\";\nimport { ApiCaller } from \"./api\";\nimport { genId } from \"../utils/genId\";\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\";\n\n// Constants\nconst POLLING_INTERVALS = {\n SESSION: 10000, // every 10 seconds\n MESSAGES: 5000 // every 5 seconds\n} as const;\n\n// Types\ntype ChatState = {\n messages: MessageType[];\n keyboard: { options: string[] } | null;\n loading: LoadingState;\n error: ErrorState;\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 || genId(),\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 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\n // Get the latest message timestamp\n const lastMessage = messages[messages.length - 1];\n const lastTimestamp = new Date(lastMessage.timestamp);\n // Add 1 second to avoid getting the same message\n lastTimestamp.setSeconds(lastTimestamp.getSeconds() + 1);\n const lastMessageTimestamp = lastTimestamp.toISOString();\n\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: genId(),\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 || genId(),\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: genId(),\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: genId(),\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 sessionStorageKey = `${config.getConfig().user.external_id}:${config.getConfig().token}:session`;\n const persistSession = options.config.getSettings().persistSession;\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 function setupSessionPersistence() {\n if (!storage) return;\n\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 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 response = await api.getSession(session.id);\n if (response) {\n sessionState.setState(response);\n }\n } catch (error) {\n logger?.error('Error polling session:', error);\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 await messageHandler.fetchHistoryMessages(session);\n } catch (error) {\n logger?.error('Error polling messages:', error);\n }\n }, POLLING_INTERVALS.MESSAGES)\n );\n\n stopPolling = () => {\n logger?.debug('Stopping polling');\n intervals.forEach(clearInterval);\n };\n }\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 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 && isStorageAvailable(storage)) {\n storage.removeItem(sessionStorageKey);\n }\n\n chatState.setState({\n messages: [],\n keyboard: null,\n loading: { isLoading: false },\n error: { hasError: false }\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 function cleanup() {\n try {\n if (stopPolling) {\n stopPolling();\n stopPolling = null;\n }\n\n if (persistSession && storage && isStorageAvailable(storage)) {\n storage.removeItem(sessionStorageKey);\n }\n\n chatState.setState({\n messages: [],\n keyboard: null,\n loading: { isLoading: false },\n error: { hasError: false }\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 // 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 };\n}\n\n// Main Chat Function\nexport function createChat(options: ChatOptions) {\n const logger = options.platform?.logger;\n logger?.info('Initializing chat');\n\n const state = new PubSub<ChatState>({\n messages: [],\n keyboard: null,\n loading: { isLoading: false },\n error: { hasError: false }\n });\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: SomeOptional<Omit<HttpChatInputSchema, \"bot_token\">, \"session_id\" | \"user\">) {\n let session = sessionState.getState();\n if (!session?.id) {\n logger?.debug('No active session, creating new session');\n session = await sessionManager.createSession();\n if (!session) return false;\n }\n\n try {\n logger?.debug('Sending message', { sessionId: session.id });\n state.setStatePartial({\n loading: { isLoading: true, reason: 'sending_message' },\n error: { hasError: false }\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 bot_token: config.token,\n headers: config.headers,\n query_params: config.queryParams,\n session_id: session.id,\n ...input,\n });\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 } 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 }\n\n return true;\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 false;\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 };\n} ","import { PubSub } from \"../types/pub-sub\";\r\nimport { ConsumerType } from \"../types\";\r\nimport { ApiCaller } from \"./api\";\r\nimport { Platform, Storage, isStorageAvailable, safeStorageOperation } from \"../platform\";\r\nimport { LoadingState, ErrorState } from \"../types/helpers\";\r\nimport { ConfigInstance } from \"./config\";\r\n\r\ntype ContactState = {\r\n contact: ConsumerType | null;\r\n loading: LoadingState;\r\n error: ErrorState;\r\n};\r\n\r\ntype ContactOptions = {\r\n api: ApiCaller;\r\n platform: Platform;\r\n config: ConfigInstance\r\n};\r\n\r\nexport function createContact(options: ContactOptions) {\r\n const config = options.config.getConfig();\r\n options.config.getConfig\r\n const storageKey = `${config.token}:contact:${config.user.external_id}`;\r\n const storage = isStorageAvailable(options.platform.storage) ? options.platform.storage : undefined;\r\n\r\n // Initialize state from storage if available\r\n let initialContact: ConsumerType | null = null;\r\n if (storage) {\r\n safeStorageOperation(\r\n async () => {\r\n const stored = await storage.getItem(storageKey);\r\n return stored ? JSON.parse(stored) : null;\r\n },\r\n \"Error loading contact from storage\"\r\n ).then((result) => {\r\n if (result.success) {\r\n initialContact = result.result;\r\n }\r\n });\r\n }\r\n\r\n const state = new PubSub<ContactState>({\r\n contact: initialContact,\r\n loading: { isLoading: false },\r\n error: { hasError: false }\r\n });\r\n\r\n // Subscribe to state changes to persist\r\n if (isStorageAvailable(storage)) {\r\n state.subscribe((currentState) => {\r\n const result = safeStorageOperation(\r\n async () => {\r\n if (currentState.contact) {\r\n await storage.setItem(storageKey, JSON.stringify(currentState.contact));\r\n } else {\r\n storage.removeItem(storageKey);\r\n }\r\n },\r\n \"Error persisting contact state\"\r\n ).then((result) => {\r\n if (!result.success) {\r\n state.setStatePartial({\r\n error: {\r\n hasError: true,\r\n message: result.error.message,\r\n code: 'CONTACT_PERSISTENCE_FAILED'\r\n }\r\n });\r\n }\r\n });\r\n });\r\n }\r\n\r\n async function loadContact() {\r\n try {\r\n state.setStatePartial({\r\n loading: { isLoading: true, reason: 'loading_contact' },\r\n error: { hasError: false }\r\n });\r\n\r\n if (storage) {\r\n const result = await safeStorageOperation(\r\n async () => {\r\n const stored = await storage.getItem(storageKey);\r\n return stored ? JSON.parse(stored) : null;\r\n },\r\n \"Error loading contact\"\r\n );\r\n\r\n if (!result.success) {\r\n throw result.error;\r\n }\r\n\r\n state.setStatePartial({\r\n contact: result.result,\r\n error: { hasError: false }\r\n });\r\n\r\n return result.result;\r\n }\r\n\r\n return state.getState().contact;\r\n } catch (error) {\r\n state.setStatePartial({\r\n error: {\r\n hasError: true,\r\n message: error instanceof Error ? error.message : 'Failed to load contact',\r\n code: 'CONTACT_LOAD_FAILED'\r\n }\r\n });\r\n return null;\r\n } finally {\r\n state.setStatePartial({\r\n loading: { isLoading: false, reason: null }\r\n });\r\n }\r\n }\r\n\r\n async function saveContact(contactData: Partial<ConsumerType>) {\r\n try {\r\n state.setStatePartial({\r\n loading: { isLoading: true, reason: 'saving_contact' },\r\n error: { hasError: false }\r\n });\r\n\r\n const currentContact = state.getState().contact;\r\n const updatedContact: ConsumerType = {\r\n id: contactData.id || currentContact?.id || '',\r\n name: contactData.name ?? currentContact?.name ?? null,\r\n created_at: contactData.created_at || currentContact?.created_at || new Date().toISOString(),\r\n avatar_url: contactData.avatar_url ?? currentContact?.avatar_url ?? null,\r\n email: contactData.email ?? currentContact?.email ?? null\r\n };\r\n\r\n if (isStorageAvailable(storage)) {\r\n const result = await safeStorageOperation(\r\n () => storage.setItem(storageKey, JSON.stringify(updatedContact)),\r\n \"Error saving contact\"\r\n );\r\n\r\n if (!result.success) {\r\n throw result.error;\r\n }\r\n }\r\n\r\n state.setStatePartial({\r\n contact: updatedContact,\r\n error: { hasError: false }\r\n });\r\n\r\n return updatedContact;\r\n } catch (error) {\r\n state.setStatePartial({\r\n error: {\r\n hasError: true,\r\n message: error instanceof Error ? error.message : 'Failed to save contact',\r\n code: 'CONTACT_SAVE_FAILED'\r\n }\r\n });\r\n return null;\r\n } finally {\r\n state.setStatePartial({\r\n loading: { isLoading: false, reason: null }\r\n });\r\n }\r\n }\r\n\r\n function shouldCollectData(): { should: boolean; reason?: string } {\r\n const currentState = state.getState();\r\n\r\n if (!currentState.contact?.id && config.collectUserData) {\r\n return {\r\n should: true,\r\n reason: \"No contact id and collectUserData is true\"\r\n };\r\n }\r\n\r\n return {\r\n should: false\r\n };\r\n }\r\n\r\n async function cleanup() {\r\n try {\r\n state.setStatePartial({\r\n loading: { isLoading: true, reason: 'cleaning_up' },\r\n error: { hasError: false }\r\n });\r\n\r\n if (storage) {\r\n const result = await safeStorageOperation(\r\n () => storage.removeItem(storageKey),\r\n \"Error removing contact data\"\r\n );\r\n\r\n if (!result.success) {\r\n throw result.error;\r\n }\r\n }\r\n\r\n state.setState({\r\n contact: null,\r\n loading: { isLoading: false },\r\n error: { hasError: false }\r\n });\r\n\r\n state.clear();\r\n } catch (error) {\r\n console.error(\"Error cleaning up contact:\", error);\r\n state.setStatePartial({\r\n error: {\r\n hasError: true,\r\n message: error instanceof Error ? error.message : 'Failed to cleanup contact data',\r\n code: 'CONTACT_CLEANUP_FAILED'\r\n }\r\n });\r\n } finally {\r\n state.setStatePartial({\r\n loading: { isLoading: false, reason: null }\r\n });\r\n }\r\n }\r\n\r\n return {\r\n contactState: state,\r\n shouldCollectData,\r\n loadContact,\r\n saveContact,\r\n cleanup,\r\n };\r\n} ","import { CoreOptions } from \"../types\";\r\n\r\nconst DEFAULT_SOUND_EFFECTS = {\r\n messageArrived: \"https://cloud.opencopilot.so/sfx/notification3.mp3\"\r\n};\r\n\r\nconst DEFAULT_THEME = {\r\n primaryColor: \"hsl(211,65%,59%)\",\r\n triggerOffset: \"20px\"\r\n};\r\n\r\nexport type NormalizedConfig = Required<Omit<CoreOptions, 'contactToken'>> & {\r\n contactToken: string | undefined | null;\r\n soundEffectFiles: {\r\n messageArrived: string;\r\n };\r\n theme: {\r\n primaryColor: string;\r\n triggerOffset: string;\r\n };\r\n settings: {\r\n persistSession: boolean;\r\n useSoundEffects: boolean;\r\n };\r\n};\r\n\r\nexport type ConfigInstance = {\r\n getConfig: () => NormalizedConfig;\r\n getApiConfig: () => {\r\n apiUrl: string;\r\n token: string;\r\n headers: Record<string, string>;\r\n queryParams: Record<string, string>;\r\n pathParams: Record<string, string>;\r\n };\r\n getBotConfig: () => NormalizedConfig['bot'];\r\n getThemeConfig: () => NormalizedConfig['theme'];\r\n getSettings: () => NormalizedConfig['settings'];\r\n getSoundEffects: () => NormalizedConfig['soundEffectFiles'];\r\n getUser: () => NormalizedConfig['user'];\r\n getLanguage: () => string;\r\n getDebugMode: () => boolean;\r\n};\r\n\r\nconst MIN_POLLING_INTERVAL = 1000 * 3;\r\n\r\nexport function createConfig(options: CoreOptions): ConfigInstance {\r\n if (!options.token) {\r\n throw new Error(\"Token is required\");\r\n }\r\n\r\n if (options.pollingInterval && options.pollingInterval < MIN_POLLING_INTERVAL) {\r\n throw new Error(\"Polling interval must be at least 3 seconds\");\r\n }\r\n\r\n const normalizedConfig: NormalizedConfig = {\r\n ...options,\r\n collectUserData: options.collectUserData ?? false,\r\n apiUrl: options.apiUrl ?? \"https://api-v2.opencopilot.so/backend\",\r\n socketUrl: options.socketUrl ?? \"https://api-v2.opencopilot.so\",\r\n pollingInterval: options.pollingInterval ?? 3000,\r\n headers: options.headers ?? {},\r\n queryParams: options.queryParams ?? {},\r\n pathParams: options.pathParams ?? {},\r\n bot: {\r\n name: options.bot?.name ?? \"Bot\",\r\n avatarUrl: options.bot?.avatarUrl,\r\n id: options.bot?.id ?? null,\r\n is_ai: options.bot?.is_ai ?? true\r\n },\r\n contactToken: options.contactToken,\r\n debug: options.debug ?? false,\r\n language: options.language ?? \"en\",\r\n user: options.user ?? {},\r\n soundEffectFiles: {\r\n messageArrived: options.soundEffectFiles?.messageArrived ?? DEFAULT_SOUND_EFFECTS.messageArrived\r\n },\r\n theme: {\r\n primaryColor: options.theme?.primaryColor ?? DEFAULT_THEME.primaryColor,\r\n triggerOffset: options.theme?.triggerOffset ?? DEFAULT_THEME.triggerOffset\r\n },\r\n settings: {\r\n persistSession: options.settings?.persistSession ?? false,\r\n useSoundEffects: options.settings?.useSoundEffects ?? false\r\n },\r\n };\r\n\r\n return {\r\n getConfig: () => normalizedConfig,\r\n getApiConfig: () => ({\r\n apiUrl: normalizedConfig.apiUrl,\r\n token: normalizedConfig.token,\r\n headers: normalizedConfig.headers,\r\n queryParams: normalizedConfig.queryParams,\r\n pathParams: normalizedConfig.pathParams\r\n }),\r\n getBotConfig: () => normalizedConfig.bot,\r\n getThemeConfig: () => normalizedConfig.theme,\r\n getSettings: () => normalizedConfig.settings,\r\n getSoundEffects: () => normalizedConfig.soundEffectFiles,\r\n getUser: () => normalizedConfig.user,\r\n getLanguage: () => normalizedConfig.language,\r\n getDebugMode: () => normalizedConfig.debug\r\n };\r\n} ","type RequestInterceptor = (config: RequestConfig) => RequestConfig | Promise<RequestConfig>;\r\ntype ResponseInterceptor = (response: Response) => Response | Promise<Response>;\r\ntype ErrorInterceptor = (error: any) => any;\r\n\r\ninterface RequestConfig extends RequestInit {\r\n baseURL?: string;\r\n headers?: HeadersInit;\r\n params?: Record<string, string>;\r\n}\r\n\r\nexport interface CustomFetch {\r\n (url: string, config?: RequestConfig): Promise<Response>;\r\n interceptors: {\r\n request: {\r\n use: (interceptor: RequestInterceptor) => number;\r\n eject: (id: number) => void;\r\n };\r\n response: {\r\n use: (interceptor: ResponseInterceptor, errorInterceptor?: ErrorInterceptor) => number;\r\n eject: (id: number) => void;\r\n };\r\n };\r\n}\r\n\r\nexport function createFetch(defaultConfig: RequestConfig = {}): CustomFetch {\r\n const requestInterceptors: RequestInterceptor[] = [];\r\n const responseInterceptors: ResponseInterceptor[] = [];\r\n const errorInterceptors: ErrorInterceptor[] = [];\r\n\r\n const customFetch: CustomFetch = async (url: string, config: RequestConfig = {}) => {\r\n // Merge configs\r\n let mergedConfig: RequestConfig = {\r\n ...defaultConfig,\r\n ...config,\r\n headers: {\r\n ...defaultConfig.headers,\r\n ...config.headers,\r\n },\r\n };\r\n\r\n try {\r\n // Apply request interceptors\r\n for (const interceptor of requestInterceptors) {\r\n mergedConfig = await interceptor(mergedConfig);\r\n }\r\n\r\n // Handle URL params\r\n const queryParams = mergedConfig.params\r\n ? '?' + new URLSearchParams(mergedConfig.params).toString()\r\n : '';\r\n\r\n // Construct full URL\r\n const fullUrl = mergedConfig.baseURL\r\n ? `${mergedConfig.baseURL}${url}${queryParams}`.replace(/([^:]\\/)\\/+/g, '$1')\r\n : `${url}${queryParams}`;\r\n\r\n // Make the fetch call\r\n let response = await fetch(fullUrl, mergedConfig);\r\n\r\n // Apply response interceptors\r\n for (const interceptor of responseInterceptors) {\r\n response = await interceptor(response);\r\n }\r\n\r\n return response;\r\n } catch (error) {\r\n // Apply error interceptors\r\n let processedError = error;\r\n for (const interceptor of errorInterceptors) {\r\n processedError = await interceptor(processedError);\r\n }\r\n throw processedError;\r\n }\r\n };\r\n\r\n // Add interceptors management\r\n customFetch.interceptors = {\r\n request: {\r\n use: (interceptor: RequestInterceptor) => {\r\n requestInterceptors.push(interceptor);\r\n return requestInterceptors.length - 1;\r\n },\r\n eject: (id: number) => {\r\n requestInterceptors.splice(id, 1);\r\n },\r\n },\r\n response: {\r\n use: (interceptor: ResponseInterceptor, errorInterceptor?: ErrorInterceptor) => {\r\n responseInterceptors.push(interceptor);\r\n if (errorInterceptor) {\r\n errorInterceptors.push(errorInterceptor);\r\n }\r\n return responseInterceptors.length - 1;\r\n },\r\n eject: (id: number) => {\r\n responseInterceptors.splice(id, 1);\r\n errorInterceptors.splice(id, 1);\r\n },\r\n },\r\n };\r\n\r\n return customFetch;\r\n}\r\n\r\n// Helper method to handle JSON responses\r\nexport async function handleJsonResponse<T>(response: Response): Promise<T> {\r\n if (!response.ok) {\r\n throw new Error(`HTTP error! status: ${response.status}`);\r\n }\r\n return response.json();\r\n}\r\n\r\n// Usage example:\r\n/*\r\nconst api = createFetch({\r\n baseURL: 'https://api.example.com',\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n },\r\n});\r\n\r\n// Add request interceptor\r\napi.interceptors.request.use((config) => {\r\n config.headers = {\r\n ...config.headers,\r\n 'Authorization': `Bearer ${getToken()}`,\r\n };\r\n return config;\r\n});\r\n\r\n// Add response interceptor\r\napi.interceptors.response.use(\r\n async (response) => {\r\n if (!response.ok) {\r\n throw new Error(`HTTP error! status: ${response.status}`);\r\n }\r\n return response;\r\n },\r\n (error) => {\r\n console.error('Request failed:', error);\r\n throw error;\r\n }\r\n);\r\n*/\r\n","import { createFetch, CustomFetch } from \"../utils/create-fetch\";\r\nimport { HandleContactMessageOutputSchema, HttpChatInputSchema, WidgetHistorySchema, WidgetPreludeSchema, WidgetSessionSchema } from \"../types/schemas-v2\";\r\nimport { CoreOptions, ConsumerType } from \"../types\";\r\nimport { NormalizedConfig } from \"./config\";\r\n\r\nexport interface ApiCallerOptions {\r\n config: NormalizedConfig;\r\n}\r\n\r\nexport class ApiCaller {\r\n #fetch: CustomFetch\r\n constructor(private readonly options: ApiCallerOptions) {\r\n const user = this.options.config.user;\r\n const consumerHeader = {\r\n claim: '',\r\n value: ''\r\n }\r\n\r\n if (user?.email) {\r\n consumerHeader.claim = 'email';\r\n consumerHeader.value = user.email;\r\n }\r\n\r\n else if (user?.phone) {\r\n consumerHeader.claim = 'phone';\r\n consumerHeader.value = user.phone;\r\n }\r\n\r\n const headers: Record<string, string> = {\r\n 'X-Bot-Token': this.options.config.token,\r\n 'X-Consumer-Id': `${consumerHeader.claim}:${consumerHeader.value}`,\r\n \"Content-Type\": \"application/json\",\r\n \"Accept\": \"application/json\"\r\n }\r\n\r\n // Only add Authorization header if contactToken exists\r\n if (this.options.config.contactToken) {\r\n headers['Authorization'] = `Bearer ${this.options.config.contactToken}`\r\n }\r\n\r\n this.#fetch = createFetch({\r\n baseURL: `${this.options.config.apiUrl}/widget/v2`,\r\n headers\r\n })\r\n }\r\n\r\n async me(): Promise<{\r\n contactId: string;\r\n contactName: string;\r\n }> {\r\n // GET /me\r\n const response = await this.#fetch('/me')\r\n return response.json()\r\n }\r\n\r\n async widgetPrelude(): Promise<WidgetPreludeSchema> {\r\n // GET /prelude\r\n const response = await this.#fetch('/prelude')\r\n return response.json()\r\n }\r\n\r\n async handleMessage(message: HttpChatInputSchema) {\r\n // POST /chat/send\r\n const response = await this.#fetch('/chat/send', {\r\n method: \"POST\",\r\n body: JSON.stringify(message)\r\n })\r\n return response.json() as Promise<HandleContactMessageOutputSchema>\r\n }\r\n\r\n async getSessionHistory(sessionId: string, lastMessageTimestamp?: string): Promise<WidgetHistorySchema[]> {\r\n // session/history/:sessionId\r\n const queryParams = new URLSearchParams({\r\n lastMessageTimestamp: lastMessageTimestamp || ''\r\n })\r\n\r\n const url = `/session/history/${sessionId}?${queryParams.toString()}`\r\n\r\n const response = await this.#fetch(url, {\r\n method: 'GET'\r\n })\r\n\r\n return response.json()\r\n }\r\n\r\n async createSession(): Promise<WidgetSessionSchema> {\r\n // POST /create-session\r\n const response = await this.#fetch('/create-session', {\r\n method: 'POST'\r\n })\r\n return response.json()\r\n }\r\n\r\n async getSession(sessionId: string): Promise<WidgetSessionSchema> {\r\n // GET /session/:sessionId\r\n const response = await this.#fetch(`/session/${sessionId}`, {\r\n method: 'GET'\r\n })\r\n return response.json()\r\n }\r\n\r\n async createContact(user: {\r\n external_id?: string;\r\n name?: string;\r\n email?: string;\r\n phone?: string;\r\n customData?: Record<string, string>;\r\n avatarUrl?: string;\r\n }): Promise<ConsumerType> {\r\n const response = await this.#fetch('/contact/upsert', {\r\n method: 'POST',\r\n body: JSON.stringify(user)\r\n });\r\n return response.json();\r\n }\r\n}\r\n","export type LogLevel = 'debug' | 'info' | 'warn' | 'error';\r\n\r\nexport interface Logger {\r\n debug(message: string, ...args: any[]): void;\r\n info(message: string, ...args: any[]): void;\r\n warn(message: string, ...args: any[]): void;\r\n error(message: string, ...args: any[]): void;\r\n setLevel(level: LogLevel): void;\r\n}\r\n\r\nexport type LoggerOptions = {\r\n level?: LogLevel;\r\n prefix?: string;\r\n enabled?: boolean;\r\n};\r\n\r\nexport function createLogger(options: LoggerOptions = {}): Logger {\r\n const {\r\n level = 'info',\r\n prefix = '[openCx]',\r\n enabled = true\r\n } = options;\r\n\r\n let currentLevel = level;\r\n const levels: Record<LogLevel, number> = {\r\n debug: 0,\r\n info: 1,\r\n warn: 2,\r\n error: 3\r\n };\r\n\r\n function shouldLog(messageLevel: LogLevel): boolean {\r\n return enabled && levels[messageLevel] >= levels[currentLevel];\r\n }\r\n\r\n function formatMessage(message: string): string {\r\n return `${prefix} ${message}`;\r\n }\r\n\r\n function formatArgs(args: any[]): any[] {\r\n return args.map(arg => {\r\n if (arg instanceof Error) {\r\n return {\r\n name: arg.name,\r\n message: arg.message,\r\n stack: arg.stack\r\n };\r\n }\r\n if (typeof arg === 'object') {\r\n try {\r\n return JSON.stringify(arg, null, 2);\r\n } catch {\r\n return arg;\r\n }\r\n }\r\n return arg;\r\n });\r\n }\r\n\r\n return {\r\n debug(message: string, ...args: any[]) {\r\n if (shouldLog('debug')) {\r\n console.debug(formatMessage(message), ...formatArgs(args));\r\n }\r\n },\r\n\r\n info(message: string, ...args: any[]) {\r\n if (shouldLog('info')) {\r\n console.info(formatMessage(message), ...formatArgs(args));\r\n }\r\n },\r\n\r\n warn(message: string, ...args: any[]) {\r\n if (shouldLog('warn')) {\r\n console.warn(formatMessage(message), ...formatArgs(args));\r\n }\r\n },\r\n\r\n error(message: string, ...args: any[]) {\r\n if (shouldLog('error')) {\r\n console.error(formatMessage(message), ...formatArgs(args));\r\n }\r\n },\r\n\r\n setLevel(level: LogLevel) {\r\n currentLevel = level;\r\n }\r\n };\r\n} "],"names":["LifecycleEvent","PubSub","state","__publicField","__privateAdd","_state","_lastUpdated","event","data","listeners","eventData","listener","callback","__privateGet","newState","isEqual","__privateSet","error","_s","createPubSub","OpenCXError","message","ConnectionError","AuthenticationError","SessionError","SessionNotDefinedError","TransportError","FileUploadError","isStorageAvailable","storage","safeStorageOperation","operation","errorMessage","POLLING_INTERVALS","mapHistoryToMessage","history","commonFields","genId","createMessageHandler","api","logger","fetchHistoryMessages","session","messages","response","lastMessage","lastTimestamp","lastMessageTimestamp","newMessages","newMsg","existingMsg","m","addUserMessage","content","attachments","addBotMessage","uiVal","addErrorMessage","createSessionManager","sessionState","chatState","messageHandler","config","options","_a","stopPolling","_b","sessionStorageKey","persistSession","restoreSession","storedSession","startPolling","setupSessionPersistence","intervals","createSession","errorState","clearSession","cleanup","createChat","sessionManager","sendMessage","input","userMessage","currentMessages","botMessage","updatedMessages","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","requestInterceptors","responseInterceptors","errorInterceptors","customFetch","url","mergedConfig","interceptor","queryParams","fullUrl","processedError","id","errorInterceptor","ApiCaller","_fetch","user","consumerHeader","headers","sessionId","createLogger","level","prefix","enabled","currentLevel","levels","shouldLog","messageLevel","formatMessage","formatArgs","args","arg"],"mappings":"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"}
|
package/dist/package.json.d.ts
CHANGED
package/dist/react.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./index-
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./index-Bx4hrNc7.cjs"),s=["monday","tuesday","wednesday","thursday","friday","saturday","sunday","WeekDays","Everyday"];exports.WidgetRoot=e.WidgetRoot;exports.useChat=e.useChat;exports.useConfigData=e.useConfigData;exports.useContact=e.useContact;exports.useDownvote=e.useDownvote;exports.useLocale=e.useLocale;exports.usePreludeData=e.usePreludeData;exports.useUploadFiles=e.useUploadFiles;exports.useUpvote=e.useUpvote;exports.useVote=e.useVote;exports.useWidgetSoundEffects=e.useWidgetSoundEffects;exports.workingDays=s;
|
|
2
2
|
//# sourceMappingURL=react.cjs.map
|
package/dist/react.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { W as t, f as o, a as u, b as d, m as y, e as n, d as r, h as f, l as i, u as l, n as D } from "./index-
|
|
1
|
+
import { W as t, f as o, a as u, b as d, m as y, e as n, d as r, h as f, l as i, u as l, n as D } from "./index-ENMg5VOh.js";
|
|
2
2
|
const a = [
|
|
3
3
|
"monday",
|
|
4
4
|
"tuesday",
|
package/dist-embed/script.js
CHANGED
|
@@ -14,7 +14,7 @@ var iae=Object.defineProperty;var aae=(xi,Hr,Xn)=>Hr in xi?iae(xi,Hr,{enumerable
|
|
|
14
14
|
*
|
|
15
15
|
* This source code is licensed under the MIT license found in the
|
|
16
16
|
* LICENSE file in the root directory of this source tree.
|
|
17
|
-
*/var PI=y,OI=Symbol.for("react.element"),II=Symbol.for("react.fragment"),DI=Object.prototype.hasOwnProperty,LI=PI.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,MI={key:!0,ref:!0,__self:!0,__source:!0};function iv(e,t,n){var r,i={},a=null,o=null;n!==void 0&&(a=""+n),t.key!==void 0&&(a=""+t.key),t.ref!==void 0&&(o=t.ref);for(r in t)DI.call(t,r)&&!MI.hasOwnProperty(r)&&(i[r]=t[r]);if(e&&e.defaultProps)for(r in t=e.defaultProps,t)i[r]===void 0&&(i[r]=t[r]);return{$$typeof:OI,type:e,key:a,ref:o,props:i,_owner:LI.current}}ac.Fragment=II,ac.jsx=iv,ac.jsxs=iv,Wy.exports=ac;var E=Wy.exports;const FI="@opencx/widget",Zp="2.4.4-rn.0",BI={name:FI,private:!1,version:Zp,type:"module",publishConfig:{access:"public"},scripts:{clean:"rm -rf ./dist ./dist-embed","clean:dist":"rm -rf ./dist ./dist-embed",prepublishOnly:"pnpm clean && pnpm test && pnpm batman","build:lib":"vite build",dev:"vite -c vite.config.ts","build:embed":"vite build -c vite.embed.config.ts",test:"vitest run",batman:"pnpm build:lib && pnpm build:embed","test:watch":"vitest --watch",cs:"changeset",csv:"changeset version",csp:"changeset publish","type-check":"tsc --noEmit",lint:"biome lint --fix",format:"biome format --fix"},peerDependencies:{"lucide-react":"^0.412.0",react:"^18.3.1","rehype-raw":"^7.0.0"},peerDependenciesMeta:{react:{optional:!0}},optionalDependencies:{axios:"^1.7.5",zod:"^3.23.8"},dependencies:{"@radix-ui/react-avatar":"^1.1.0","@radix-ui/react-dropdown-menu":"^2.1.4","@radix-ui/react-slot":"^1.1.0","@radix-ui/react-switch":"^1.1.0","@radix-ui/react-tooltip":"^1.1.2",clsx:"^2.1.1","date-fns":"^4.1.0","framer-motion":"^11.3.30","lodash.isequal":"^4.5.0","lodash.set":"^4.3.2","lucide-react":"^0.436.0",mutative:"^1.0.11","react-dropzone":"^14.3.5","react-hot-toast":"^2.4.1",tinycolor2:"^1.6.0",zod:"^3.23.8"},overrides:{"@opencx/widget":{react:{optional:!0,dependencies:{"react-hot-toast":"^2.4.1","react-markdown":"^9.0.1","framer-motion":"^11.3.30","date-fns":"^4.1.0"}}}},conditionalDependencies:{react:{"react-hot-toast":"^2.4.1","react-markdown":"^9.0.1","framer-motion":"^11.3.30","date-fns":"^4.1.0"}},files:["dist","dist-embed"],bugs:{url:"https://github.com/openchatai/widget/issues"},author:{name:"openchatai",url:"https://github.com/openchatai"},main:"./dist/index.js",module:"./dist/index.js",types:"./dist/index.d.ts",sideEffects:!1,exports:{".":{types:"./dist/index.d.ts",import:"./dist/index.js",require:"./dist/index.cjs"},"./basic":{types:"./dist/basic.d.ts",import:"./dist/basic.js",require:"./dist/basic.cjs"},"./react":{types:"./dist/react.d.ts",import:"./dist/react.js",require:"./dist/react.cjs"},"./package.json":"./package.json","./dist/*.css":"./dist/*.css"},devDependencies:{"@biomejs/biome":"1.9.4","@changesets/cli":"^2.27.9","@radix-ui/react-popover":"^1.1.2","@tailwindcss/typography":"^0.5.15","@testing-library/dom":"^10.4.0","@testing-library/jest-dom":"^6.5.0","@testing-library/react":"^16.0.1","@types/lodash.debounce":"^4.0.9","@types/lodash.isequal":"^4.5.8","@types/lodash.set":"^4.3.9","@types/node":"^20.14.8","@types/react":"^18.3.4","@types/react-dom":"^18.3.0","@types/tinycolor2":"^1.4.6","@uiw/react-iframe":"^1.0.3","@vitejs/plugin-react":"^4.3.4",autoprefixer:"^10.4.20",axios:"^1.7.5","class-variance-authority":"^0.7.0",jsdom:"^25.0.1",mutative:"^1.0.11",postcss:"^8.4.41","postcss-prefix-selector":"^1.16.1",react:"^18.3.1","react-dom":"^18.3.1","react-markdown":"^9.0.1","react-use":"^17.5.1","rehype-raw":"^7.0.0","remark-gfm":"^4.0.0",swr:"^2.2.5","tailwind-merge":"^2.4.0",tailwindcss:"^3.4.6","tailwindcss-animate":"^1.0.7",typescript:"^5.5.4",vite:"^5.4.2","vite-plugin-dts":"4.0.3","vite-plugin-externalize-deps":"^0.8.0","vite-tsconfig-paths":"^5.0.1",vitest:"^2.0.5"}},jI=typeof window>"u",av={getItem:()=>null,setItem:()=>{},removeItem:()=>{}};function zI(e){return jI?av:e==="local"?localStorage:e==="session"?sessionStorage:av}function Jp(e,t,n="session"){const r=y.useMemo(()=>zI(n),[n]),[i,a]=y.useState(()=>{const l=r.getItem(e);if(l!==null)try{return JSON.parse(l)}catch(u){console.error(`Error parsing stored value for key '${e}':`,u)}return typeof t=="function"?t():t??null}),o=y.useCallback(l=>{if(a(l),l===null)r.removeItem(e);else try{r.setItem(e,JSON.stringify(l))}catch(u){console.error(`Error saving state to storage for key '${e}':`,u)}},[e,r]),s=y.useCallback(()=>{a(null),r.removeItem(e)},[e,r]);return y.useEffect(()=>{const l=u=>{u.key===e&&u.newValue!==JSON.stringify(i)&&a(u.newValue?JSON.parse(u.newValue):null)};return window.addEventListener("storage",l),()=>{window.removeEventListener("storage",l)}},[e,i]),[i,o,s]}function ov(e,t){return function(){return e.apply(t,arguments)}}const{toString:UI}=Object.prototype,{getPrototypeOf:eh}=Object,uc=(e=>t=>{const n=UI.call(t);return e[n]||(e[n]=n.slice(8,-1).toLowerCase())})(Object.create(null)),Qn=e=>(e=e.toLowerCase(),t=>uc(t)===e),cc=e=>t=>typeof t===e,{isArray:co}=Array,js=cc("undefined");function HI(e){return e!==null&&!js(e)&&e.constructor!==null&&!js(e.constructor)&&yn(e.constructor.isBuffer)&&e.constructor.isBuffer(e)}const sv=Qn("ArrayBuffer");function VI(e){let t;return typeof ArrayBuffer<"u"&&ArrayBuffer.isView?t=ArrayBuffer.isView(e):t=e&&e.buffer&&sv(e.buffer),t}const $I=cc("string"),yn=cc("function"),lv=cc("number"),dc=e=>e!==null&&typeof e=="object",WI=e=>e===!0||e===!1,fc=e=>{if(uc(e)!=="object")return!1;const t=eh(e);return(t===null||t===Object.prototype||Object.getPrototypeOf(t)===null)&&!(Symbol.toStringTag in e)&&!(Symbol.iterator in e)},YI=Qn("Date"),qI=Qn("File"),GI=Qn("Blob"),KI=Qn("FileList"),XI=e=>dc(e)&&yn(e.pipe),QI=e=>{let t;return e&&(typeof FormData=="function"&&e instanceof FormData||yn(e.append)&&((t=uc(e))==="formdata"||t==="object"&&yn(e.toString)&&e.toString()==="[object FormData]"))},ZI=Qn("URLSearchParams"),[JI,e6,t6,n6]=["ReadableStream","Request","Response","Headers"].map(Qn),r6=e=>e.trim?e.trim():e.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,"");function zs(e,t,{allOwnKeys:n=!1}={}){if(e===null||typeof e>"u")return;let r,i;if(typeof e!="object"&&(e=[e]),co(e))for(r=0,i=e.length;r<i;r++)t.call(null,e[r],r,e);else{const a=n?Object.getOwnPropertyNames(e):Object.keys(e),o=a.length;let s;for(r=0;r<o;r++)s=a[r],t.call(null,e[s],s,e)}}function uv(e,t){t=t.toLowerCase();const n=Object.keys(e);let r=n.length,i;for(;r-- >0;)if(i=n[r],t===i.toLowerCase())return i;return null}const xa=typeof globalThis<"u"?globalThis:typeof self<"u"?self:typeof window<"u"?window:global,cv=e=>!js(e)&&e!==xa;function th(){const{caseless:e}=cv(this)&&this||{},t={},n=(r,i)=>{const a=e&&uv(t,i)||i;fc(t[a])&&fc(r)?t[a]=th(t[a],r):fc(r)?t[a]=th({},r):co(r)?t[a]=r.slice():t[a]=r};for(let r=0,i=arguments.length;r<i;r++)arguments[r]&&zs(arguments[r],n);return t}const i6=(e,t,n,{allOwnKeys:r}={})=>(zs(t,(i,a)=>{n&&yn(i)?e[a]=ov(i,n):e[a]=i},{allOwnKeys:r}),e),a6=e=>(e.charCodeAt(0)===65279&&(e=e.slice(1)),e),o6=(e,t,n,r)=>{e.prototype=Object.create(t.prototype,r),e.prototype.constructor=e,Object.defineProperty(e,"super",{value:t.prototype}),n&&Object.assign(e.prototype,n)},s6=(e,t,n,r)=>{let i,a,o;const s={};if(t=t||{},e==null)return t;do{for(i=Object.getOwnPropertyNames(e),a=i.length;a-- >0;)o=i[a],(!r||r(o,e,t))&&!s[o]&&(t[o]=e[o],s[o]=!0);e=n!==!1&&eh(e)}while(e&&(!n||n(e,t))&&e!==Object.prototype);return t},l6=(e,t,n)=>{e=String(e),(n===void 0||n>e.length)&&(n=e.length),n-=t.length;const r=e.indexOf(t,n);return r!==-1&&r===n},u6=e=>{if(!e)return null;if(co(e))return e;let t=e.length;if(!lv(t))return null;const n=new Array(t);for(;t-- >0;)n[t]=e[t];return n},c6=(e=>t=>e&&t instanceof e)(typeof Uint8Array<"u"&&eh(Uint8Array)),d6=(e,t)=>{const r=(e&&e[Symbol.iterator]).call(e);let i;for(;(i=r.next())&&!i.done;){const a=i.value;t.call(e,a[0],a[1])}},f6=(e,t)=>{let n;const r=[];for(;(n=e.exec(t))!==null;)r.push(n);return r},p6=Qn("HTMLFormElement"),h6=e=>e.toLowerCase().replace(/[-_\s]([a-z\d])(\w*)/g,function(n,r,i){return r.toUpperCase()+i}),dv=(({hasOwnProperty:e})=>(t,n)=>e.call(t,n))(Object.prototype),m6=Qn("RegExp"),fv=(e,t)=>{const n=Object.getOwnPropertyDescriptors(e),r={};zs(n,(i,a)=>{let o;(o=t(i,a,e))!==!1&&(r[a]=o||i)}),Object.defineProperties(e,r)},g6=e=>{fv(e,(t,n)=>{if(yn(e)&&["arguments","caller","callee"].indexOf(n)!==-1)return!1;const r=e[n];if(yn(r)){if(t.enumerable=!1,"writable"in t){t.writable=!1;return}t.set||(t.set=()=>{throw Error("Can not rewrite read-only method '"+n+"'")})}})},w6=(e,t)=>{const n={},r=i=>{i.forEach(a=>{n[a]=!0})};return co(e)?r(e):r(String(e).split(t)),n},y6=()=>{},v6=(e,t)=>e!=null&&Number.isFinite(e=+e)?e:t,nh="abcdefghijklmnopqrstuvwxyz",pv="0123456789",hv={DIGIT:pv,ALPHA:nh,ALPHA_DIGIT:nh+nh.toUpperCase()+pv},b6=(e=16,t=hv.ALPHA_DIGIT)=>{let n="";const{length:r}=t;for(;e--;)n+=t[Math.random()*r|0];return n};function x6(e){return!!(e&&yn(e.append)&&e[Symbol.toStringTag]==="FormData"&&e[Symbol.iterator])}const E6=e=>{const t=new Array(10),n=(r,i)=>{if(dc(r)){if(t.indexOf(r)>=0)return;if(!("toJSON"in r)){t[i]=r;const a=co(r)?[]:{};return zs(r,(o,s)=>{const l=n(o,i+1);!js(l)&&(a[s]=l)}),t[i]=void 0,a}}return r};return n(e,0)},T6=Qn("AsyncFunction"),_6=e=>e&&(dc(e)||yn(e))&&yn(e.then)&&yn(e.catch),mv=((e,t)=>e?setImmediate:t?((n,r)=>(xa.addEventListener("message",({source:i,data:a})=>{i===xa&&a===n&&r.length&&r.shift()()},!1),i=>{r.push(i),xa.postMessage(n,"*")}))(`axios@${Math.random()}`,[]):n=>setTimeout(n))(typeof setImmediate=="function",yn(xa.postMessage)),S6=typeof queueMicrotask<"u"?queueMicrotask.bind(xa):typeof process<"u"&&process.nextTick||mv,j={isArray:co,isArrayBuffer:sv,isBuffer:HI,isFormData:QI,isArrayBufferView:VI,isString:$I,isNumber:lv,isBoolean:WI,isObject:dc,isPlainObject:fc,isReadableStream:JI,isRequest:e6,isResponse:t6,isHeaders:n6,isUndefined:js,isDate:YI,isFile:qI,isBlob:GI,isRegExp:m6,isFunction:yn,isStream:XI,isURLSearchParams:ZI,isTypedArray:c6,isFileList:KI,forEach:zs,merge:th,extend:i6,trim:r6,stripBOM:a6,inherits:o6,toFlatObject:s6,kindOf:uc,kindOfTest:Qn,endsWith:l6,toArray:u6,forEachEntry:d6,matchAll:f6,isHTMLForm:p6,hasOwnProperty:dv,hasOwnProp:dv,reduceDescriptors:fv,freezeMethods:g6,toObjectSet:w6,toCamelCase:h6,noop:y6,toFiniteNumber:v6,findKey:uv,global:xa,isContextDefined:cv,ALPHABET:hv,generateString:b6,isSpecCompliantForm:x6,toJSONObject:E6,isAsyncFn:T6,isThenable:_6,setImmediate:mv,asap:S6};function ge(e,t,n,r,i){Error.call(this),Error.captureStackTrace?Error.captureStackTrace(this,this.constructor):this.stack=new Error().stack,this.message=e,this.name="AxiosError",t&&(this.code=t),n&&(this.config=n),r&&(this.request=r),i&&(this.response=i,this.status=i.status?i.status:null)}j.inherits(ge,Error,{toJSON:function(){return{message:this.message,name:this.name,description:this.description,number:this.number,fileName:this.fileName,lineNumber:this.lineNumber,columnNumber:this.columnNumber,stack:this.stack,config:j.toJSONObject(this.config),code:this.code,status:this.status}}});const gv=ge.prototype,wv={};["ERR_BAD_OPTION_VALUE","ERR_BAD_OPTION","ECONNABORTED","ETIMEDOUT","ERR_NETWORK","ERR_FR_TOO_MANY_REDIRECTS","ERR_DEPRECATED","ERR_BAD_RESPONSE","ERR_BAD_REQUEST","ERR_CANCELED","ERR_NOT_SUPPORT","ERR_INVALID_URL"].forEach(e=>{wv[e]={value:e}}),Object.defineProperties(ge,wv),Object.defineProperty(gv,"isAxiosError",{value:!0}),ge.from=(e,t,n,r,i,a)=>{const o=Object.create(gv);return j.toFlatObject(e,o,function(l){return l!==Error.prototype},s=>s!=="isAxiosError"),ge.call(o,e.message,t,n,r,i),o.cause=e,o.name=e.name,a&&Object.assign(o,a),o};const k6=null;function rh(e){return j.isPlainObject(e)||j.isArray(e)}function yv(e){return j.endsWith(e,"[]")?e.slice(0,-2):e}function vv(e,t,n){return e?e.concat(t).map(function(i,a){return i=yv(i),!n&&a?"["+i+"]":i}).join(n?".":""):t}function C6(e){return j.isArray(e)&&!e.some(rh)}const A6=j.toFlatObject(j,{},null,function(t){return/^is[A-Z]/.test(t)});function pc(e,t,n){if(!j.isObject(e))throw new TypeError("target must be an object");t=t||new FormData,n=j.toFlatObject(n,{metaTokens:!0,dots:!1,indexes:!1},!1,function(g,b){return!j.isUndefined(b[g])});const r=n.metaTokens,i=n.visitor||c,a=n.dots,o=n.indexes,l=(n.Blob||typeof Blob<"u"&&Blob)&&j.isSpecCompliantForm(t);if(!j.isFunction(i))throw new TypeError("visitor must be a function");function u(m){if(m===null)return"";if(j.isDate(m))return m.toISOString();if(!l&&j.isBlob(m))throw new ge("Blob is not supported. Use a Buffer instead.");return j.isArrayBuffer(m)||j.isTypedArray(m)?l&&typeof Blob=="function"?new Blob([m]):Buffer.from(m):m}function c(m,g,b){let w=m;if(m&&!b&&typeof m=="object"){if(j.endsWith(g,"{}"))g=r?g:g.slice(0,-2),m=JSON.stringify(m);else if(j.isArray(m)&&C6(m)||(j.isFileList(m)||j.endsWith(g,"[]"))&&(w=j.toArray(m)))return g=yv(g),w.forEach(function(x,T){!(j.isUndefined(x)||x===null)&&t.append(o===!0?vv([g],T,a):o===null?g:g+"[]",u(x))}),!1}return rh(m)?!0:(t.append(vv(b,g,a),u(m)),!1)}const d=[],f=Object.assign(A6,{defaultVisitor:c,convertValue:u,isVisitable:rh});function p(m,g){if(!j.isUndefined(m)){if(d.indexOf(m)!==-1)throw Error("Circular reference detected in "+g.join("."));d.push(m),j.forEach(m,function(w,v){(!(j.isUndefined(w)||w===null)&&i.call(t,w,j.isString(v)?v.trim():v,g,f))===!0&&p(w,g?g.concat(v):[v])}),d.pop()}}if(!j.isObject(e))throw new TypeError("data must be an object");return p(e),t}function bv(e){const t={"!":"%21","'":"%27","(":"%28",")":"%29","~":"%7E","%20":"+","%00":"\0"};return encodeURIComponent(e).replace(/[!'()~]|%20|%00/g,function(r){return t[r]})}function ih(e,t){this._pairs=[],e&&pc(e,this,t)}const xv=ih.prototype;xv.append=function(t,n){this._pairs.push([t,n])},xv.toString=function(t){const n=t?function(r){return t.call(this,r,bv)}:bv;return this._pairs.map(function(i){return n(i[0])+"="+n(i[1])},"").join("&")};function R6(e){return encodeURIComponent(e).replace(/%3A/gi,":").replace(/%24/g,"$").replace(/%2C/gi,",").replace(/%20/g,"+").replace(/%5B/gi,"[").replace(/%5D/gi,"]")}function Ev(e,t,n){if(!t)return e;const r=n&&n.encode||R6,i=n&&n.serialize;let a;if(i?a=i(t,n):a=j.isURLSearchParams(t)?t.toString():new ih(t,n).toString(r),a){const o=e.indexOf("#");o!==-1&&(e=e.slice(0,o)),e+=(e.indexOf("?")===-1?"?":"&")+a}return e}class Tv{constructor(){this.handlers=[]}use(t,n,r){return this.handlers.push({fulfilled:t,rejected:n,synchronous:r?r.synchronous:!1,runWhen:r?r.runWhen:null}),this.handlers.length-1}eject(t){this.handlers[t]&&(this.handlers[t]=null)}clear(){this.handlers&&(this.handlers=[])}forEach(t){j.forEach(this.handlers,function(r){r!==null&&t(r)})}}const _v={silentJSONParsing:!0,forcedJSONParsing:!0,clarifyTimeoutError:!1},N6={isBrowser:!0,classes:{URLSearchParams:typeof URLSearchParams<"u"?URLSearchParams:ih,FormData:typeof FormData<"u"?FormData:null,Blob:typeof Blob<"u"?Blob:null},protocols:["http","https","file","blob","url","data"]},ah=typeof window<"u"&&typeof document<"u",oh=typeof navigator=="object"&&navigator||void 0,P6=ah&&(!oh||["ReactNative","NativeScript","NS"].indexOf(oh.product)<0),O6=typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope&&typeof self.importScripts=="function",I6=ah&&window.location.href||"http://localhost",an={...Object.freeze(Object.defineProperty({__proto__:null,hasBrowserEnv:ah,hasStandardBrowserEnv:P6,hasStandardBrowserWebWorkerEnv:O6,navigator:oh,origin:I6},Symbol.toStringTag,{value:"Module"})),...N6};function D6(e,t){return pc(e,new an.classes.URLSearchParams,Object.assign({visitor:function(n,r,i,a){return an.isNode&&j.isBuffer(n)?(this.append(r,n.toString("base64")),!1):a.defaultVisitor.apply(this,arguments)}},t))}function L6(e){return j.matchAll(/\w+|\[(\w*)]/g,e).map(t=>t[0]==="[]"?"":t[1]||t[0])}function M6(e){const t={},n=Object.keys(e);let r;const i=n.length;let a;for(r=0;r<i;r++)a=n[r],t[a]=e[a];return t}function Sv(e){function t(n,r,i,a){let o=n[a++];if(o==="__proto__")return!0;const s=Number.isFinite(+o),l=a>=n.length;return o=!o&&j.isArray(i)?i.length:o,l?(j.hasOwnProp(i,o)?i[o]=[i[o],r]:i[o]=r,!s):((!i[o]||!j.isObject(i[o]))&&(i[o]=[]),t(n,r,i[o],a)&&j.isArray(i[o])&&(i[o]=M6(i[o])),!s)}if(j.isFormData(e)&&j.isFunction(e.entries)){const n={};return j.forEachEntry(e,(r,i)=>{t(L6(r),i,n,0)}),n}return null}function F6(e,t,n){if(j.isString(e))try{return(t||JSON.parse)(e),j.trim(e)}catch(r){if(r.name!=="SyntaxError")throw r}return(0,JSON.stringify)(e)}const Us={transitional:_v,adapter:["xhr","http","fetch"],transformRequest:[function(t,n){const r=n.getContentType()||"",i=r.indexOf("application/json")>-1,a=j.isObject(t);if(a&&j.isHTMLForm(t)&&(t=new FormData(t)),j.isFormData(t))return i?JSON.stringify(Sv(t)):t;if(j.isArrayBuffer(t)||j.isBuffer(t)||j.isStream(t)||j.isFile(t)||j.isBlob(t)||j.isReadableStream(t))return t;if(j.isArrayBufferView(t))return t.buffer;if(j.isURLSearchParams(t))return n.setContentType("application/x-www-form-urlencoded;charset=utf-8",!1),t.toString();let s;if(a){if(r.indexOf("application/x-www-form-urlencoded")>-1)return D6(t,this.formSerializer).toString();if((s=j.isFileList(t))||r.indexOf("multipart/form-data")>-1){const l=this.env&&this.env.FormData;return pc(s?{"files[]":t}:t,l&&new l,this.formSerializer)}}return a||i?(n.setContentType("application/json",!1),F6(t)):t}],transformResponse:[function(t){const n=this.transitional||Us.transitional,r=n&&n.forcedJSONParsing,i=this.responseType==="json";if(j.isResponse(t)||j.isReadableStream(t))return t;if(t&&j.isString(t)&&(r&&!this.responseType||i)){const o=!(n&&n.silentJSONParsing)&&i;try{return JSON.parse(t)}catch(s){if(o)throw s.name==="SyntaxError"?ge.from(s,ge.ERR_BAD_RESPONSE,this,null,this.response):s}}return t}],timeout:0,xsrfCookieName:"XSRF-TOKEN",xsrfHeaderName:"X-XSRF-TOKEN",maxContentLength:-1,maxBodyLength:-1,env:{FormData:an.classes.FormData,Blob:an.classes.Blob},validateStatus:function(t){return t>=200&&t<300},headers:{common:{Accept:"application/json, text/plain, */*","Content-Type":void 0}}};j.forEach(["delete","get","head","post","put","patch"],e=>{Us.headers[e]={}});const B6=j.toObjectSet(["age","authorization","content-length","content-type","etag","expires","from","host","if-modified-since","if-unmodified-since","last-modified","location","max-forwards","proxy-authorization","referer","retry-after","user-agent"]),j6=e=>{const t={};let n,r,i;return e&&e.split(`
|
|
17
|
+
*/var PI=y,OI=Symbol.for("react.element"),II=Symbol.for("react.fragment"),DI=Object.prototype.hasOwnProperty,LI=PI.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,MI={key:!0,ref:!0,__self:!0,__source:!0};function iv(e,t,n){var r,i={},a=null,o=null;n!==void 0&&(a=""+n),t.key!==void 0&&(a=""+t.key),t.ref!==void 0&&(o=t.ref);for(r in t)DI.call(t,r)&&!MI.hasOwnProperty(r)&&(i[r]=t[r]);if(e&&e.defaultProps)for(r in t=e.defaultProps,t)i[r]===void 0&&(i[r]=t[r]);return{$$typeof:OI,type:e,key:a,ref:o,props:i,_owner:LI.current}}ac.Fragment=II,ac.jsx=iv,ac.jsxs=iv,Wy.exports=ac;var E=Wy.exports;const FI="@opencx/widget",Zp="2.4.4-rn.1",BI={name:FI,private:!1,version:Zp,type:"module",publishConfig:{access:"public"},scripts:{clean:"rm -rf ./dist ./dist-embed","clean:dist":"rm -rf ./dist ./dist-embed",prepublishOnly:"pnpm clean && pnpm test && pnpm batman","build:lib":"vite build",dev:"vite -c vite.config.ts","build:embed":"vite build -c vite.embed.config.ts",test:"vitest run",batman:"pnpm build:lib && pnpm build:embed","test:watch":"vitest --watch",cs:"changeset",csv:"changeset version",csp:"changeset publish","type-check":"tsc --noEmit",lint:"biome lint --fix",format:"biome format --fix"},peerDependencies:{"lucide-react":"^0.412.0",react:"^18.3.1","rehype-raw":"^7.0.0"},peerDependenciesMeta:{react:{optional:!0}},optionalDependencies:{axios:"^1.7.5",zod:"^3.23.8"},dependencies:{"@radix-ui/react-avatar":"^1.1.0","@radix-ui/react-dropdown-menu":"^2.1.4","@radix-ui/react-slot":"^1.1.0","@radix-ui/react-switch":"^1.1.0","@radix-ui/react-tooltip":"^1.1.2",clsx:"^2.1.1","date-fns":"^4.1.0","framer-motion":"^11.3.30","lodash.isequal":"^4.5.0","lodash.set":"^4.3.2","lucide-react":"^0.436.0",mutative:"^1.0.11","react-dropzone":"^14.3.5","react-hot-toast":"^2.4.1",tinycolor2:"^1.6.0",zod:"^3.23.8"},overrides:{"@opencx/widget":{react:{optional:!0,dependencies:{"react-hot-toast":"^2.4.1","react-markdown":"^9.0.1","framer-motion":"^11.3.30","date-fns":"^4.1.0"}}}},conditionalDependencies:{react:{"react-hot-toast":"^2.4.1","react-markdown":"^9.0.1","framer-motion":"^11.3.30","date-fns":"^4.1.0"}},files:["dist","dist-embed"],bugs:{url:"https://github.com/openchatai/widget/issues"},author:{name:"openchatai",url:"https://github.com/openchatai"},main:"./dist/index.js",module:"./dist/index.js",types:"./dist/index.d.ts",sideEffects:!1,exports:{".":{types:"./dist/index.d.ts",import:"./dist/index.js",require:"./dist/index.cjs"},"./basic":{types:"./dist/basic.d.ts",import:"./dist/basic.js",require:"./dist/basic.cjs"},"./react":{types:"./dist/react.d.ts",import:"./dist/react.js",require:"./dist/react.cjs"},"./package.json":"./package.json","./dist/*.css":"./dist/*.css"},devDependencies:{"@biomejs/biome":"1.9.4","@changesets/cli":"^2.27.9","@radix-ui/react-popover":"^1.1.2","@tailwindcss/typography":"^0.5.15","@testing-library/dom":"^10.4.0","@testing-library/jest-dom":"^6.5.0","@testing-library/react":"^16.0.1","@types/lodash.debounce":"^4.0.9","@types/lodash.isequal":"^4.5.8","@types/lodash.set":"^4.3.9","@types/node":"^20.14.8","@types/react":"^18.3.4","@types/react-dom":"^18.3.0","@types/tinycolor2":"^1.4.6","@uiw/react-iframe":"^1.0.3","@vitejs/plugin-react":"^4.3.4",autoprefixer:"^10.4.20",axios:"^1.7.5","class-variance-authority":"^0.7.0",jsdom:"^25.0.1",mutative:"^1.0.11",postcss:"^8.4.41","postcss-prefix-selector":"^1.16.1",react:"^18.3.1","react-dom":"^18.3.1","react-markdown":"^9.0.1","react-use":"^17.5.1","rehype-raw":"^7.0.0","remark-gfm":"^4.0.0",swr:"^2.2.5","tailwind-merge":"^2.4.0",tailwindcss:"^3.4.6","tailwindcss-animate":"^1.0.7",typescript:"^5.5.4",vite:"^5.4.2","vite-plugin-dts":"4.0.3","vite-plugin-externalize-deps":"^0.8.0","vite-tsconfig-paths":"^5.0.1",vitest:"^2.0.5"}},jI=typeof window>"u",av={getItem:()=>null,setItem:()=>{},removeItem:()=>{}};function zI(e){return jI?av:e==="local"?localStorage:e==="session"?sessionStorage:av}function Jp(e,t,n="session"){const r=y.useMemo(()=>zI(n),[n]),[i,a]=y.useState(()=>{const l=r.getItem(e);if(l!==null)try{return JSON.parse(l)}catch(u){console.error(`Error parsing stored value for key '${e}':`,u)}return typeof t=="function"?t():t??null}),o=y.useCallback(l=>{if(a(l),l===null)r.removeItem(e);else try{r.setItem(e,JSON.stringify(l))}catch(u){console.error(`Error saving state to storage for key '${e}':`,u)}},[e,r]),s=y.useCallback(()=>{a(null),r.removeItem(e)},[e,r]);return y.useEffect(()=>{const l=u=>{u.key===e&&u.newValue!==JSON.stringify(i)&&a(u.newValue?JSON.parse(u.newValue):null)};return window.addEventListener("storage",l),()=>{window.removeEventListener("storage",l)}},[e,i]),[i,o,s]}function ov(e,t){return function(){return e.apply(t,arguments)}}const{toString:UI}=Object.prototype,{getPrototypeOf:eh}=Object,uc=(e=>t=>{const n=UI.call(t);return e[n]||(e[n]=n.slice(8,-1).toLowerCase())})(Object.create(null)),Qn=e=>(e=e.toLowerCase(),t=>uc(t)===e),cc=e=>t=>typeof t===e,{isArray:co}=Array,js=cc("undefined");function HI(e){return e!==null&&!js(e)&&e.constructor!==null&&!js(e.constructor)&&yn(e.constructor.isBuffer)&&e.constructor.isBuffer(e)}const sv=Qn("ArrayBuffer");function VI(e){let t;return typeof ArrayBuffer<"u"&&ArrayBuffer.isView?t=ArrayBuffer.isView(e):t=e&&e.buffer&&sv(e.buffer),t}const $I=cc("string"),yn=cc("function"),lv=cc("number"),dc=e=>e!==null&&typeof e=="object",WI=e=>e===!0||e===!1,fc=e=>{if(uc(e)!=="object")return!1;const t=eh(e);return(t===null||t===Object.prototype||Object.getPrototypeOf(t)===null)&&!(Symbol.toStringTag in e)&&!(Symbol.iterator in e)},YI=Qn("Date"),qI=Qn("File"),GI=Qn("Blob"),KI=Qn("FileList"),XI=e=>dc(e)&&yn(e.pipe),QI=e=>{let t;return e&&(typeof FormData=="function"&&e instanceof FormData||yn(e.append)&&((t=uc(e))==="formdata"||t==="object"&&yn(e.toString)&&e.toString()==="[object FormData]"))},ZI=Qn("URLSearchParams"),[JI,e6,t6,n6]=["ReadableStream","Request","Response","Headers"].map(Qn),r6=e=>e.trim?e.trim():e.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,"");function zs(e,t,{allOwnKeys:n=!1}={}){if(e===null||typeof e>"u")return;let r,i;if(typeof e!="object"&&(e=[e]),co(e))for(r=0,i=e.length;r<i;r++)t.call(null,e[r],r,e);else{const a=n?Object.getOwnPropertyNames(e):Object.keys(e),o=a.length;let s;for(r=0;r<o;r++)s=a[r],t.call(null,e[s],s,e)}}function uv(e,t){t=t.toLowerCase();const n=Object.keys(e);let r=n.length,i;for(;r-- >0;)if(i=n[r],t===i.toLowerCase())return i;return null}const xa=typeof globalThis<"u"?globalThis:typeof self<"u"?self:typeof window<"u"?window:global,cv=e=>!js(e)&&e!==xa;function th(){const{caseless:e}=cv(this)&&this||{},t={},n=(r,i)=>{const a=e&&uv(t,i)||i;fc(t[a])&&fc(r)?t[a]=th(t[a],r):fc(r)?t[a]=th({},r):co(r)?t[a]=r.slice():t[a]=r};for(let r=0,i=arguments.length;r<i;r++)arguments[r]&&zs(arguments[r],n);return t}const i6=(e,t,n,{allOwnKeys:r}={})=>(zs(t,(i,a)=>{n&&yn(i)?e[a]=ov(i,n):e[a]=i},{allOwnKeys:r}),e),a6=e=>(e.charCodeAt(0)===65279&&(e=e.slice(1)),e),o6=(e,t,n,r)=>{e.prototype=Object.create(t.prototype,r),e.prototype.constructor=e,Object.defineProperty(e,"super",{value:t.prototype}),n&&Object.assign(e.prototype,n)},s6=(e,t,n,r)=>{let i,a,o;const s={};if(t=t||{},e==null)return t;do{for(i=Object.getOwnPropertyNames(e),a=i.length;a-- >0;)o=i[a],(!r||r(o,e,t))&&!s[o]&&(t[o]=e[o],s[o]=!0);e=n!==!1&&eh(e)}while(e&&(!n||n(e,t))&&e!==Object.prototype);return t},l6=(e,t,n)=>{e=String(e),(n===void 0||n>e.length)&&(n=e.length),n-=t.length;const r=e.indexOf(t,n);return r!==-1&&r===n},u6=e=>{if(!e)return null;if(co(e))return e;let t=e.length;if(!lv(t))return null;const n=new Array(t);for(;t-- >0;)n[t]=e[t];return n},c6=(e=>t=>e&&t instanceof e)(typeof Uint8Array<"u"&&eh(Uint8Array)),d6=(e,t)=>{const r=(e&&e[Symbol.iterator]).call(e);let i;for(;(i=r.next())&&!i.done;){const a=i.value;t.call(e,a[0],a[1])}},f6=(e,t)=>{let n;const r=[];for(;(n=e.exec(t))!==null;)r.push(n);return r},p6=Qn("HTMLFormElement"),h6=e=>e.toLowerCase().replace(/[-_\s]([a-z\d])(\w*)/g,function(n,r,i){return r.toUpperCase()+i}),dv=(({hasOwnProperty:e})=>(t,n)=>e.call(t,n))(Object.prototype),m6=Qn("RegExp"),fv=(e,t)=>{const n=Object.getOwnPropertyDescriptors(e),r={};zs(n,(i,a)=>{let o;(o=t(i,a,e))!==!1&&(r[a]=o||i)}),Object.defineProperties(e,r)},g6=e=>{fv(e,(t,n)=>{if(yn(e)&&["arguments","caller","callee"].indexOf(n)!==-1)return!1;const r=e[n];if(yn(r)){if(t.enumerable=!1,"writable"in t){t.writable=!1;return}t.set||(t.set=()=>{throw Error("Can not rewrite read-only method '"+n+"'")})}})},w6=(e,t)=>{const n={},r=i=>{i.forEach(a=>{n[a]=!0})};return co(e)?r(e):r(String(e).split(t)),n},y6=()=>{},v6=(e,t)=>e!=null&&Number.isFinite(e=+e)?e:t,nh="abcdefghijklmnopqrstuvwxyz",pv="0123456789",hv={DIGIT:pv,ALPHA:nh,ALPHA_DIGIT:nh+nh.toUpperCase()+pv},b6=(e=16,t=hv.ALPHA_DIGIT)=>{let n="";const{length:r}=t;for(;e--;)n+=t[Math.random()*r|0];return n};function x6(e){return!!(e&&yn(e.append)&&e[Symbol.toStringTag]==="FormData"&&e[Symbol.iterator])}const E6=e=>{const t=new Array(10),n=(r,i)=>{if(dc(r)){if(t.indexOf(r)>=0)return;if(!("toJSON"in r)){t[i]=r;const a=co(r)?[]:{};return zs(r,(o,s)=>{const l=n(o,i+1);!js(l)&&(a[s]=l)}),t[i]=void 0,a}}return r};return n(e,0)},T6=Qn("AsyncFunction"),_6=e=>e&&(dc(e)||yn(e))&&yn(e.then)&&yn(e.catch),mv=((e,t)=>e?setImmediate:t?((n,r)=>(xa.addEventListener("message",({source:i,data:a})=>{i===xa&&a===n&&r.length&&r.shift()()},!1),i=>{r.push(i),xa.postMessage(n,"*")}))(`axios@${Math.random()}`,[]):n=>setTimeout(n))(typeof setImmediate=="function",yn(xa.postMessage)),S6=typeof queueMicrotask<"u"?queueMicrotask.bind(xa):typeof process<"u"&&process.nextTick||mv,j={isArray:co,isArrayBuffer:sv,isBuffer:HI,isFormData:QI,isArrayBufferView:VI,isString:$I,isNumber:lv,isBoolean:WI,isObject:dc,isPlainObject:fc,isReadableStream:JI,isRequest:e6,isResponse:t6,isHeaders:n6,isUndefined:js,isDate:YI,isFile:qI,isBlob:GI,isRegExp:m6,isFunction:yn,isStream:XI,isURLSearchParams:ZI,isTypedArray:c6,isFileList:KI,forEach:zs,merge:th,extend:i6,trim:r6,stripBOM:a6,inherits:o6,toFlatObject:s6,kindOf:uc,kindOfTest:Qn,endsWith:l6,toArray:u6,forEachEntry:d6,matchAll:f6,isHTMLForm:p6,hasOwnProperty:dv,hasOwnProp:dv,reduceDescriptors:fv,freezeMethods:g6,toObjectSet:w6,toCamelCase:h6,noop:y6,toFiniteNumber:v6,findKey:uv,global:xa,isContextDefined:cv,ALPHABET:hv,generateString:b6,isSpecCompliantForm:x6,toJSONObject:E6,isAsyncFn:T6,isThenable:_6,setImmediate:mv,asap:S6};function ge(e,t,n,r,i){Error.call(this),Error.captureStackTrace?Error.captureStackTrace(this,this.constructor):this.stack=new Error().stack,this.message=e,this.name="AxiosError",t&&(this.code=t),n&&(this.config=n),r&&(this.request=r),i&&(this.response=i,this.status=i.status?i.status:null)}j.inherits(ge,Error,{toJSON:function(){return{message:this.message,name:this.name,description:this.description,number:this.number,fileName:this.fileName,lineNumber:this.lineNumber,columnNumber:this.columnNumber,stack:this.stack,config:j.toJSONObject(this.config),code:this.code,status:this.status}}});const gv=ge.prototype,wv={};["ERR_BAD_OPTION_VALUE","ERR_BAD_OPTION","ECONNABORTED","ETIMEDOUT","ERR_NETWORK","ERR_FR_TOO_MANY_REDIRECTS","ERR_DEPRECATED","ERR_BAD_RESPONSE","ERR_BAD_REQUEST","ERR_CANCELED","ERR_NOT_SUPPORT","ERR_INVALID_URL"].forEach(e=>{wv[e]={value:e}}),Object.defineProperties(ge,wv),Object.defineProperty(gv,"isAxiosError",{value:!0}),ge.from=(e,t,n,r,i,a)=>{const o=Object.create(gv);return j.toFlatObject(e,o,function(l){return l!==Error.prototype},s=>s!=="isAxiosError"),ge.call(o,e.message,t,n,r,i),o.cause=e,o.name=e.name,a&&Object.assign(o,a),o};const k6=null;function rh(e){return j.isPlainObject(e)||j.isArray(e)}function yv(e){return j.endsWith(e,"[]")?e.slice(0,-2):e}function vv(e,t,n){return e?e.concat(t).map(function(i,a){return i=yv(i),!n&&a?"["+i+"]":i}).join(n?".":""):t}function C6(e){return j.isArray(e)&&!e.some(rh)}const A6=j.toFlatObject(j,{},null,function(t){return/^is[A-Z]/.test(t)});function pc(e,t,n){if(!j.isObject(e))throw new TypeError("target must be an object");t=t||new FormData,n=j.toFlatObject(n,{metaTokens:!0,dots:!1,indexes:!1},!1,function(g,b){return!j.isUndefined(b[g])});const r=n.metaTokens,i=n.visitor||c,a=n.dots,o=n.indexes,l=(n.Blob||typeof Blob<"u"&&Blob)&&j.isSpecCompliantForm(t);if(!j.isFunction(i))throw new TypeError("visitor must be a function");function u(m){if(m===null)return"";if(j.isDate(m))return m.toISOString();if(!l&&j.isBlob(m))throw new ge("Blob is not supported. Use a Buffer instead.");return j.isArrayBuffer(m)||j.isTypedArray(m)?l&&typeof Blob=="function"?new Blob([m]):Buffer.from(m):m}function c(m,g,b){let w=m;if(m&&!b&&typeof m=="object"){if(j.endsWith(g,"{}"))g=r?g:g.slice(0,-2),m=JSON.stringify(m);else if(j.isArray(m)&&C6(m)||(j.isFileList(m)||j.endsWith(g,"[]"))&&(w=j.toArray(m)))return g=yv(g),w.forEach(function(x,T){!(j.isUndefined(x)||x===null)&&t.append(o===!0?vv([g],T,a):o===null?g:g+"[]",u(x))}),!1}return rh(m)?!0:(t.append(vv(b,g,a),u(m)),!1)}const d=[],f=Object.assign(A6,{defaultVisitor:c,convertValue:u,isVisitable:rh});function p(m,g){if(!j.isUndefined(m)){if(d.indexOf(m)!==-1)throw Error("Circular reference detected in "+g.join("."));d.push(m),j.forEach(m,function(w,v){(!(j.isUndefined(w)||w===null)&&i.call(t,w,j.isString(v)?v.trim():v,g,f))===!0&&p(w,g?g.concat(v):[v])}),d.pop()}}if(!j.isObject(e))throw new TypeError("data must be an object");return p(e),t}function bv(e){const t={"!":"%21","'":"%27","(":"%28",")":"%29","~":"%7E","%20":"+","%00":"\0"};return encodeURIComponent(e).replace(/[!'()~]|%20|%00/g,function(r){return t[r]})}function ih(e,t){this._pairs=[],e&&pc(e,this,t)}const xv=ih.prototype;xv.append=function(t,n){this._pairs.push([t,n])},xv.toString=function(t){const n=t?function(r){return t.call(this,r,bv)}:bv;return this._pairs.map(function(i){return n(i[0])+"="+n(i[1])},"").join("&")};function R6(e){return encodeURIComponent(e).replace(/%3A/gi,":").replace(/%24/g,"$").replace(/%2C/gi,",").replace(/%20/g,"+").replace(/%5B/gi,"[").replace(/%5D/gi,"]")}function Ev(e,t,n){if(!t)return e;const r=n&&n.encode||R6,i=n&&n.serialize;let a;if(i?a=i(t,n):a=j.isURLSearchParams(t)?t.toString():new ih(t,n).toString(r),a){const o=e.indexOf("#");o!==-1&&(e=e.slice(0,o)),e+=(e.indexOf("?")===-1?"?":"&")+a}return e}class Tv{constructor(){this.handlers=[]}use(t,n,r){return this.handlers.push({fulfilled:t,rejected:n,synchronous:r?r.synchronous:!1,runWhen:r?r.runWhen:null}),this.handlers.length-1}eject(t){this.handlers[t]&&(this.handlers[t]=null)}clear(){this.handlers&&(this.handlers=[])}forEach(t){j.forEach(this.handlers,function(r){r!==null&&t(r)})}}const _v={silentJSONParsing:!0,forcedJSONParsing:!0,clarifyTimeoutError:!1},N6={isBrowser:!0,classes:{URLSearchParams:typeof URLSearchParams<"u"?URLSearchParams:ih,FormData:typeof FormData<"u"?FormData:null,Blob:typeof Blob<"u"?Blob:null},protocols:["http","https","file","blob","url","data"]},ah=typeof window<"u"&&typeof document<"u",oh=typeof navigator=="object"&&navigator||void 0,P6=ah&&(!oh||["ReactNative","NativeScript","NS"].indexOf(oh.product)<0),O6=typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope&&typeof self.importScripts=="function",I6=ah&&window.location.href||"http://localhost",an={...Object.freeze(Object.defineProperty({__proto__:null,hasBrowserEnv:ah,hasStandardBrowserEnv:P6,hasStandardBrowserWebWorkerEnv:O6,navigator:oh,origin:I6},Symbol.toStringTag,{value:"Module"})),...N6};function D6(e,t){return pc(e,new an.classes.URLSearchParams,Object.assign({visitor:function(n,r,i,a){return an.isNode&&j.isBuffer(n)?(this.append(r,n.toString("base64")),!1):a.defaultVisitor.apply(this,arguments)}},t))}function L6(e){return j.matchAll(/\w+|\[(\w*)]/g,e).map(t=>t[0]==="[]"?"":t[1]||t[0])}function M6(e){const t={},n=Object.keys(e);let r;const i=n.length;let a;for(r=0;r<i;r++)a=n[r],t[a]=e[a];return t}function Sv(e){function t(n,r,i,a){let o=n[a++];if(o==="__proto__")return!0;const s=Number.isFinite(+o),l=a>=n.length;return o=!o&&j.isArray(i)?i.length:o,l?(j.hasOwnProp(i,o)?i[o]=[i[o],r]:i[o]=r,!s):((!i[o]||!j.isObject(i[o]))&&(i[o]=[]),t(n,r,i[o],a)&&j.isArray(i[o])&&(i[o]=M6(i[o])),!s)}if(j.isFormData(e)&&j.isFunction(e.entries)){const n={};return j.forEachEntry(e,(r,i)=>{t(L6(r),i,n,0)}),n}return null}function F6(e,t,n){if(j.isString(e))try{return(t||JSON.parse)(e),j.trim(e)}catch(r){if(r.name!=="SyntaxError")throw r}return(0,JSON.stringify)(e)}const Us={transitional:_v,adapter:["xhr","http","fetch"],transformRequest:[function(t,n){const r=n.getContentType()||"",i=r.indexOf("application/json")>-1,a=j.isObject(t);if(a&&j.isHTMLForm(t)&&(t=new FormData(t)),j.isFormData(t))return i?JSON.stringify(Sv(t)):t;if(j.isArrayBuffer(t)||j.isBuffer(t)||j.isStream(t)||j.isFile(t)||j.isBlob(t)||j.isReadableStream(t))return t;if(j.isArrayBufferView(t))return t.buffer;if(j.isURLSearchParams(t))return n.setContentType("application/x-www-form-urlencoded;charset=utf-8",!1),t.toString();let s;if(a){if(r.indexOf("application/x-www-form-urlencoded")>-1)return D6(t,this.formSerializer).toString();if((s=j.isFileList(t))||r.indexOf("multipart/form-data")>-1){const l=this.env&&this.env.FormData;return pc(s?{"files[]":t}:t,l&&new l,this.formSerializer)}}return a||i?(n.setContentType("application/json",!1),F6(t)):t}],transformResponse:[function(t){const n=this.transitional||Us.transitional,r=n&&n.forcedJSONParsing,i=this.responseType==="json";if(j.isResponse(t)||j.isReadableStream(t))return t;if(t&&j.isString(t)&&(r&&!this.responseType||i)){const o=!(n&&n.silentJSONParsing)&&i;try{return JSON.parse(t)}catch(s){if(o)throw s.name==="SyntaxError"?ge.from(s,ge.ERR_BAD_RESPONSE,this,null,this.response):s}}return t}],timeout:0,xsrfCookieName:"XSRF-TOKEN",xsrfHeaderName:"X-XSRF-TOKEN",maxContentLength:-1,maxBodyLength:-1,env:{FormData:an.classes.FormData,Blob:an.classes.Blob},validateStatus:function(t){return t>=200&&t<300},headers:{common:{Accept:"application/json, text/plain, */*","Content-Type":void 0}}};j.forEach(["delete","get","head","post","put","patch"],e=>{Us.headers[e]={}});const B6=j.toObjectSet(["age","authorization","content-length","content-type","etag","expires","from","host","if-modified-since","if-unmodified-since","last-modified","location","max-forwards","proxy-authorization","referer","retry-after","user-agent"]),j6=e=>{const t={};let n,r,i;return e&&e.split(`
|
|
18
18
|
`).forEach(function(o){i=o.indexOf(":"),n=o.substring(0,i).trim().toLowerCase(),r=o.substring(i+1).trim(),!(!n||t[n]&&B6[n])&&(n==="set-cookie"?t[n]?t[n].push(r):t[n]=[r]:t[n]=t[n]?t[n]+", "+r:r)}),t},kv=Symbol("internals");function Hs(e){return e&&String(e).trim().toLowerCase()}function hc(e){return e===!1||e==null?e:j.isArray(e)?e.map(hc):String(e)}function z6(e){const t=Object.create(null),n=/([^\s,;=]+)\s*(?:=\s*([^,;]+))?/g;let r;for(;r=n.exec(e);)t[r[1]]=r[2];return t}const U6=e=>/^[-_a-zA-Z0-9^`|~,!#$%&'*+.]+$/.test(e.trim());function sh(e,t,n,r,i){if(j.isFunction(r))return r.call(this,t,n);if(i&&(t=n),!!j.isString(t)){if(j.isString(r))return t.indexOf(r)!==-1;if(j.isRegExp(r))return r.test(t)}}function H6(e){return e.trim().toLowerCase().replace(/([a-z\d])(\w*)/g,(t,n,r)=>n.toUpperCase()+r)}function V6(e,t){const n=j.toCamelCase(" "+t);["get","set","has"].forEach(r=>{Object.defineProperty(e,r+n,{value:function(i,a,o){return this[r].call(this,t,i,a,o)},configurable:!0})})}class on{constructor(t){t&&this.set(t)}set(t,n,r){const i=this;function a(s,l,u){const c=Hs(l);if(!c)throw new Error("header name must be a non-empty string");const d=j.findKey(i,c);(!d||i[d]===void 0||u===!0||u===void 0&&i[d]!==!1)&&(i[d||l]=hc(s))}const o=(s,l)=>j.forEach(s,(u,c)=>a(u,c,l));if(j.isPlainObject(t)||t instanceof this.constructor)o(t,n);else if(j.isString(t)&&(t=t.trim())&&!U6(t))o(j6(t),n);else if(j.isHeaders(t))for(const[s,l]of t.entries())a(l,s,r);else t!=null&&a(n,t,r);return this}get(t,n){if(t=Hs(t),t){const r=j.findKey(this,t);if(r){const i=this[r];if(!n)return i;if(n===!0)return z6(i);if(j.isFunction(n))return n.call(this,i,r);if(j.isRegExp(n))return n.exec(i);throw new TypeError("parser must be boolean|regexp|function")}}}has(t,n){if(t=Hs(t),t){const r=j.findKey(this,t);return!!(r&&this[r]!==void 0&&(!n||sh(this,this[r],r,n)))}return!1}delete(t,n){const r=this;let i=!1;function a(o){if(o=Hs(o),o){const s=j.findKey(r,o);s&&(!n||sh(r,r[s],s,n))&&(delete r[s],i=!0)}}return j.isArray(t)?t.forEach(a):a(t),i}clear(t){const n=Object.keys(this);let r=n.length,i=!1;for(;r--;){const a=n[r];(!t||sh(this,this[a],a,t,!0))&&(delete this[a],i=!0)}return i}normalize(t){const n=this,r={};return j.forEach(this,(i,a)=>{const o=j.findKey(r,a);if(o){n[o]=hc(i),delete n[a];return}const s=t?H6(a):String(a).trim();s!==a&&delete n[a],n[s]=hc(i),r[s]=!0}),this}concat(...t){return this.constructor.concat(this,...t)}toJSON(t){const n=Object.create(null);return j.forEach(this,(r,i)=>{r!=null&&r!==!1&&(n[i]=t&&j.isArray(r)?r.join(", "):r)}),n}[Symbol.iterator](){return Object.entries(this.toJSON())[Symbol.iterator]()}toString(){return Object.entries(this.toJSON()).map(([t,n])=>t+": "+n).join(`
|
|
19
19
|
`)}get[Symbol.toStringTag](){return"AxiosHeaders"}static from(t){return t instanceof this?t:new this(t)}static concat(t,...n){const r=new this(t);return n.forEach(i=>r.set(i)),r}static accessor(t){const r=(this[kv]=this[kv]={accessors:{}}).accessors,i=this.prototype;function a(o){const s=Hs(o);r[s]||(V6(i,o),r[s]=!0)}return j.isArray(t)?t.forEach(a):a(t),this}}on.accessor(["Content-Type","Content-Length","Accept","Accept-Encoding","User-Agent","Authorization"]),j.reduceDescriptors(on.prototype,({value:e},t)=>{let n=t[0].toUpperCase()+t.slice(1);return{get:()=>e,set(r){this[n]=r}}}),j.freezeMethods(on);function lh(e,t){const n=this||Us,r=t||n,i=on.from(r.headers);let a=r.data;return j.forEach(e,function(s){a=s.call(n,a,i.normalize(),t?t.status:void 0)}),i.normalize(),a}function Cv(e){return!!(e&&e.__CANCEL__)}function fo(e,t,n){ge.call(this,e??"canceled",ge.ERR_CANCELED,t,n),this.name="CanceledError"}j.inherits(fo,ge,{__CANCEL__:!0});function Av(e,t,n){const r=n.config.validateStatus;!n.status||!r||r(n.status)?e(n):t(new ge("Request failed with status code "+n.status,[ge.ERR_BAD_REQUEST,ge.ERR_BAD_RESPONSE][Math.floor(n.status/100)-4],n.config,n.request,n))}function $6(e){const t=/^([-+\w]{1,25})(:?\/\/|:)/.exec(e);return t&&t[1]||""}function W6(e,t){e=e||10;const n=new Array(e),r=new Array(e);let i=0,a=0,o;return t=t!==void 0?t:1e3,function(l){const u=Date.now(),c=r[a];o||(o=u),n[i]=l,r[i]=u;let d=a,f=0;for(;d!==i;)f+=n[d++],d=d%e;if(i=(i+1)%e,i===a&&(a=(a+1)%e),u-o<t)return;const p=c&&u-c;return p?Math.round(f*1e3/p):void 0}}function Y6(e,t){let n=0,r=1e3/t,i,a;const o=(u,c=Date.now())=>{n=c,i=null,a&&(clearTimeout(a),a=null),e.apply(null,u)};return[(...u)=>{const c=Date.now(),d=c-n;d>=r?o(u,c):(i=u,a||(a=setTimeout(()=>{a=null,o(i)},r-d)))},()=>i&&o(i)]}const mc=(e,t,n=3)=>{let r=0;const i=W6(50,250);return Y6(a=>{const o=a.loaded,s=a.lengthComputable?a.total:void 0,l=o-r,u=i(l),c=o<=s;r=o;const d={loaded:o,total:s,progress:s?o/s:void 0,bytes:l,rate:u||void 0,estimated:u&&s&&c?(s-o)/u:void 0,event:a,lengthComputable:s!=null,[t?"download":"upload"]:!0};e(d)},n)},Rv=(e,t)=>{const n=e!=null;return[r=>t[0]({lengthComputable:n,total:e,loaded:r}),t[1]]},Nv=e=>(...t)=>j.asap(()=>e(...t)),q6=an.hasStandardBrowserEnv?function(){const t=an.navigator&&/(msie|trident)/i.test(an.navigator.userAgent),n=document.createElement("a");let r;function i(a){let o=a;return t&&(n.setAttribute("href",o),o=n.href),n.setAttribute("href",o),{href:n.href,protocol:n.protocol?n.protocol.replace(/:$/,""):"",host:n.host,search:n.search?n.search.replace(/^\?/,""):"",hash:n.hash?n.hash.replace(/^#/,""):"",hostname:n.hostname,port:n.port,pathname:n.pathname.charAt(0)==="/"?n.pathname:"/"+n.pathname}}return r=i(window.location.href),function(o){const s=j.isString(o)?i(o):o;return s.protocol===r.protocol&&s.host===r.host}}():function(){return function(){return!0}}(),G6=an.hasStandardBrowserEnv?{write(e,t,n,r,i,a){const o=[e+"="+encodeURIComponent(t)];j.isNumber(n)&&o.push("expires="+new Date(n).toGMTString()),j.isString(r)&&o.push("path="+r),j.isString(i)&&o.push("domain="+i),a===!0&&o.push("secure"),document.cookie=o.join("; ")},read(e){const t=document.cookie.match(new RegExp("(^|;\\s*)("+e+")=([^;]*)"));return t?decodeURIComponent(t[3]):null},remove(e){this.write(e,"",Date.now()-864e5)}}:{write(){},read(){return null},remove(){}};function K6(e){return/^([a-z][a-z\d+\-.]*:)?\/\//i.test(e)}function X6(e,t){return t?e.replace(/\/?\/$/,"")+"/"+t.replace(/^\/+/,""):e}function Pv(e,t){return e&&!K6(t)?X6(e,t):t}const Ov=e=>e instanceof on?{...e}:e;function Ea(e,t){t=t||{};const n={};function r(u,c,d){return j.isPlainObject(u)&&j.isPlainObject(c)?j.merge.call({caseless:d},u,c):j.isPlainObject(c)?j.merge({},c):j.isArray(c)?c.slice():c}function i(u,c,d){if(j.isUndefined(c)){if(!j.isUndefined(u))return r(void 0,u,d)}else return r(u,c,d)}function a(u,c){if(!j.isUndefined(c))return r(void 0,c)}function o(u,c){if(j.isUndefined(c)){if(!j.isUndefined(u))return r(void 0,u)}else return r(void 0,c)}function s(u,c,d){if(d in t)return r(u,c);if(d in e)return r(void 0,u)}const l={url:a,method:a,data:a,baseURL:o,transformRequest:o,transformResponse:o,paramsSerializer:o,timeout:o,timeoutMessage:o,withCredentials:o,withXSRFToken:o,adapter:o,responseType:o,xsrfCookieName:o,xsrfHeaderName:o,onUploadProgress:o,onDownloadProgress:o,decompress:o,maxContentLength:o,maxBodyLength:o,beforeRedirect:o,transport:o,httpAgent:o,httpsAgent:o,cancelToken:o,socketPath:o,responseEncoding:o,validateStatus:s,headers:(u,c)=>i(Ov(u),Ov(c),!0)};return j.forEach(Object.keys(Object.assign({},e,t)),function(c){const d=l[c]||i,f=d(e[c],t[c],c);j.isUndefined(f)&&d!==s||(n[c]=f)}),n}const Iv=e=>{const t=Ea({},e);let{data:n,withXSRFToken:r,xsrfHeaderName:i,xsrfCookieName:a,headers:o,auth:s}=t;t.headers=o=on.from(o),t.url=Ev(Pv(t.baseURL,t.url),e.params,e.paramsSerializer),s&&o.set("Authorization","Basic "+btoa((s.username||"")+":"+(s.password?unescape(encodeURIComponent(s.password)):"")));let l;if(j.isFormData(n)){if(an.hasStandardBrowserEnv||an.hasStandardBrowserWebWorkerEnv)o.setContentType(void 0);else if((l=o.getContentType())!==!1){const[u,...c]=l?l.split(";").map(d=>d.trim()).filter(Boolean):[];o.setContentType([u||"multipart/form-data",...c].join("; "))}}if(an.hasStandardBrowserEnv&&(r&&j.isFunction(r)&&(r=r(t)),r||r!==!1&&q6(t.url))){const u=i&&a&&G6.read(a);u&&o.set(i,u)}return t},Q6=typeof XMLHttpRequest<"u"&&function(e){return new Promise(function(n,r){const i=Iv(e);let a=i.data;const o=on.from(i.headers).normalize();let{responseType:s,onUploadProgress:l,onDownloadProgress:u}=i,c,d,f,p,m;function g(){p&&p(),m&&m(),i.cancelToken&&i.cancelToken.unsubscribe(c),i.signal&&i.signal.removeEventListener("abort",c)}let b=new XMLHttpRequest;b.open(i.method.toUpperCase(),i.url,!0),b.timeout=i.timeout;function w(){if(!b)return;const x=on.from("getAllResponseHeaders"in b&&b.getAllResponseHeaders()),_={data:!s||s==="text"||s==="json"?b.responseText:b.response,status:b.status,statusText:b.statusText,headers:x,config:e,request:b};Av(function(P){n(P),g()},function(P){r(P),g()},_),b=null}"onloadend"in b?b.onloadend=w:b.onreadystatechange=function(){!b||b.readyState!==4||b.status===0&&!(b.responseURL&&b.responseURL.indexOf("file:")===0)||setTimeout(w)},b.onabort=function(){b&&(r(new ge("Request aborted",ge.ECONNABORTED,e,b)),b=null)},b.onerror=function(){r(new ge("Network Error",ge.ERR_NETWORK,e,b)),b=null},b.ontimeout=function(){let T=i.timeout?"timeout of "+i.timeout+"ms exceeded":"timeout exceeded";const _=i.transitional||_v;i.timeoutErrorMessage&&(T=i.timeoutErrorMessage),r(new ge(T,_.clarifyTimeoutError?ge.ETIMEDOUT:ge.ECONNABORTED,e,b)),b=null},a===void 0&&o.setContentType(null),"setRequestHeader"in b&&j.forEach(o.toJSON(),function(T,_){b.setRequestHeader(_,T)}),j.isUndefined(i.withCredentials)||(b.withCredentials=!!i.withCredentials),s&&s!=="json"&&(b.responseType=i.responseType),u&&([f,m]=mc(u,!0),b.addEventListener("progress",f)),l&&b.upload&&([d,p]=mc(l),b.upload.addEventListener("progress",d),b.upload.addEventListener("loadend",p)),(i.cancelToken||i.signal)&&(c=x=>{b&&(r(!x||x.type?new fo(null,e,b):x),b.abort(),b=null)},i.cancelToken&&i.cancelToken.subscribe(c),i.signal&&(i.signal.aborted?c():i.signal.addEventListener("abort",c)));const v=$6(i.url);if(v&&an.protocols.indexOf(v)===-1){r(new ge("Unsupported protocol "+v+":",ge.ERR_BAD_REQUEST,e));return}b.send(a||null)})},Z6=(e,t)=>{const{length:n}=e=e?e.filter(Boolean):[];if(t||n){let r=new AbortController,i;const a=function(u){if(!i){i=!0,s();const c=u instanceof Error?u:this.reason;r.abort(c instanceof ge?c:new fo(c instanceof Error?c.message:c))}};let o=t&&setTimeout(()=>{o=null,a(new ge(`timeout ${t} of ms exceeded`,ge.ETIMEDOUT))},t);const s=()=>{e&&(o&&clearTimeout(o),o=null,e.forEach(u=>{u.unsubscribe?u.unsubscribe(a):u.removeEventListener("abort",a)}),e=null)};e.forEach(u=>u.addEventListener("abort",a));const{signal:l}=r;return l.unsubscribe=()=>j.asap(s),l}},J6=function*(e,t){let n=e.byteLength;if(n<t){yield e;return}let r=0,i;for(;r<n;)i=r+t,yield e.slice(r,i),r=i},e5=async function*(e,t){for await(const n of t5(e))yield*J6(n,t)},t5=async function*(e){if(e[Symbol.asyncIterator]){yield*e;return}const t=e.getReader();try{for(;;){const{done:n,value:r}=await t.read();if(n)break;yield r}}finally{await t.cancel()}},Dv=(e,t,n,r)=>{const i=e5(e,t);let a=0,o,s=l=>{o||(o=!0,r&&r(l))};return new ReadableStream({async pull(l){try{const{done:u,value:c}=await i.next();if(u){s(),l.close();return}let d=c.byteLength;if(n){let f=a+=d;n(f)}l.enqueue(new Uint8Array(c))}catch(u){throw s(u),u}},cancel(l){return s(l),i.return()}},{highWaterMark:2})},gc=typeof fetch=="function"&&typeof Request=="function"&&typeof Response=="function",Lv=gc&&typeof ReadableStream=="function",n5=gc&&(typeof TextEncoder=="function"?(e=>t=>e.encode(t))(new TextEncoder):async e=>new Uint8Array(await new Response(e).arrayBuffer())),Mv=(e,...t)=>{try{return!!e(...t)}catch{return!1}},r5=Lv&&Mv(()=>{let e=!1;const t=new Request(an.origin,{body:new ReadableStream,method:"POST",get duplex(){return e=!0,"half"}}).headers.has("Content-Type");return e&&!t}),Fv=64*1024,uh=Lv&&Mv(()=>j.isReadableStream(new Response("").body)),wc={stream:uh&&(e=>e.body)};gc&&(e=>{["text","arrayBuffer","blob","formData","stream"].forEach(t=>{!wc[t]&&(wc[t]=j.isFunction(e[t])?n=>n[t]():(n,r)=>{throw new ge(`Response type '${t}' is not supported`,ge.ERR_NOT_SUPPORT,r)})})})(new Response);const i5=async e=>{if(e==null)return 0;if(j.isBlob(e))return e.size;if(j.isSpecCompliantForm(e))return(await new Request(an.origin,{method:"POST",body:e}).arrayBuffer()).byteLength;if(j.isArrayBufferView(e)||j.isArrayBuffer(e))return e.byteLength;if(j.isURLSearchParams(e)&&(e=e+""),j.isString(e))return(await n5(e)).byteLength},a5=async(e,t)=>{const n=j.toFiniteNumber(e.getContentLength());return n??i5(t)},ch={http:k6,xhr:Q6,fetch:gc&&(async e=>{let{url:t,method:n,data:r,signal:i,cancelToken:a,timeout:o,onDownloadProgress:s,onUploadProgress:l,responseType:u,headers:c,withCredentials:d="same-origin",fetchOptions:f}=Iv(e);u=u?(u+"").toLowerCase():"text";let p=Z6([i,a&&a.toAbortSignal()],o),m;const g=p&&p.unsubscribe&&(()=>{p.unsubscribe()});let b;try{if(l&&r5&&n!=="get"&&n!=="head"&&(b=await a5(c,r))!==0){let _=new Request(t,{method:"POST",body:r,duplex:"half"}),S;if(j.isFormData(r)&&(S=_.headers.get("content-type"))&&c.setContentType(S),_.body){const[P,O]=Rv(b,mc(Nv(l)));r=Dv(_.body,Fv,P,O)}}j.isString(d)||(d=d?"include":"omit");const w="credentials"in Request.prototype;m=new Request(t,{...f,signal:p,method:n.toUpperCase(),headers:c.normalize().toJSON(),body:r,duplex:"half",credentials:w?d:void 0});let v=await fetch(m);const x=uh&&(u==="stream"||u==="response");if(uh&&(s||x&&g)){const _={};["status","statusText","headers"].forEach(z=>{_[z]=v[z]});const S=j.toFiniteNumber(v.headers.get("content-length")),[P,O]=s&&Rv(S,mc(Nv(s),!0))||[];v=new Response(Dv(v.body,Fv,P,()=>{O&&O(),g&&g()}),_)}u=u||"text";let T=await wc[j.findKey(wc,u)||"text"](v,e);return!x&&g&&g(),await new Promise((_,S)=>{Av(_,S,{data:T,headers:on.from(v.headers),status:v.status,statusText:v.statusText,config:e,request:m})})}catch(w){throw g&&g(),w&&w.name==="TypeError"&&/fetch/i.test(w.message)?Object.assign(new ge("Network Error",ge.ERR_NETWORK,e,m),{cause:w.cause||w}):ge.from(w,w&&w.code,e,m)}})};j.forEach(ch,(e,t)=>{if(e){try{Object.defineProperty(e,"name",{value:t})}catch{}Object.defineProperty(e,"adapterName",{value:t})}});const Bv=e=>`- ${e}`,o5=e=>j.isFunction(e)||e===null||e===!1,jv={getAdapter:e=>{e=j.isArray(e)?e:[e];const{length:t}=e;let n,r;const i={};for(let a=0;a<t;a++){n=e[a];let o;if(r=n,!o5(n)&&(r=ch[(o=String(n)).toLowerCase()],r===void 0))throw new ge(`Unknown adapter '${o}'`);if(r)break;i[o||"#"+a]=r}if(!r){const a=Object.entries(i).map(([s,l])=>`adapter ${s} `+(l===!1?"is not supported by the environment":"is not available in the build"));let o=t?a.length>1?`since :
|
|
20
20
|
`+a.map(Bv).join(`
|