@opencx/widget 2.6.3 → 3.0.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 +89 -89
- package/dist/basic.cjs.map +1 -1
- package/dist/basic.d.ts +1 -1
- package/dist/basic.js +34088 -34127
- package/dist/basic.js.map +1 -1
- package/dist/index.cjs +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +3 -22
- package/dist/react.cjs +1 -1
- package/dist/react.cjs.map +1 -1
- package/dist/react.d.ts +1 -1
- package/dist/react.js +20 -10
- package/dist/react.js.map +1 -1
- package/dist/src/designs/react/basic/index.d.ts +10 -0
- package/dist/src/designs/{basic → react/basic}/utils/group-messages-by-type.d.ts +1 -1
- package/dist/src/{@components → designs/react/components}/BotOrAgentMessage.d.ts +1 -1
- package/dist/src/{@components → designs/react/components}/BotOrAgentMessageGroup.d.ts +2 -2
- package/dist/src/designs/react/components/BotOrAgentMessageWrapper.d.ts +7 -0
- package/dist/src/{@components → designs/react/components}/Fallback.component.d.ts +2 -2
- package/dist/src/{components → designs/react/components}/RenderFile.d.ts +2 -2
- package/dist/src/{components/keyboard.d.ts → designs/react/components/SuggestedReplies.d.ts} +2 -2
- package/dist/src/{@components → designs/react/components}/Text.component.d.ts +1 -1
- package/dist/src/{components → designs/react/components}/UserMessageGroup.d.ts +1 -1
- package/dist/src/{components → designs/react/components}/VoteButtons.d.ts +1 -1
- package/dist/src/{components → designs/react/components/lib}/button.d.ts +1 -1
- package/dist/src/{components → designs/react/components/lib}/dialog.d.ts +7 -7
- package/dist/src/{components → designs/react/components/lib}/dropdown-menu.d.ts +2 -2
- package/dist/src/designs/{constants.d.ts → react/constants.d.ts} +2 -4
- package/dist/src/designs/react/hooks/useLocale.d.ts +6 -0
- package/dist/src/{index.d.ts → designs/react/index.d.ts} +2 -2
- package/dist/src/designs/translation/ar.locale.d.ts +2 -0
- package/dist/src/designs/translation/de.locale.d.ts +2 -0
- package/dist/src/designs/translation/en.locale.d.ts +2 -0
- package/dist/src/designs/translation/fr.locale.d.ts +2 -0
- package/dist/src/designs/translation/index.d.ts +14 -0
- package/dist/src/designs/translation/nl.locale.d.ts +2 -0
- package/dist/src/designs/translation/pt.locale.d.ts +2 -0
- package/dist/src/designs/translation/translation.types.d.ts +4 -0
- package/dist/{core/client → src/headless/core}/api.d.ts +49 -103
- package/dist/src/headless/core/context/contact.d.ts +24 -0
- package/dist/src/headless/core/context/message.d.ts +42 -0
- package/dist/src/headless/core/context/session.d.ts +74 -0
- package/dist/src/headless/core/context/widget.d.ts +16 -0
- package/dist/src/headless/core/index.d.ts +10 -0
- package/dist/src/headless/core/types/WidgetConfig.d.ts +34 -0
- package/dist/src/headless/core/types/agent-or-bot.d.ts +6 -0
- package/dist/src/headless/core/types/helpers.d.ts +4 -0
- package/dist/{core → src/headless/core}/types/messages.d.ts +11 -31
- package/dist/src/headless/core/types/schemas.d.ts +9 -0
- package/dist/src/headless/core/utils/Poller.d.ts +12 -0
- package/dist/{core/types/pub-sub.d.ts → src/headless/core/utils/PubSub.d.ts} +6 -9
- package/dist/{react-web/core-integration/components.d.ts → src/headless/react/ComponentRegistry.d.ts} +1 -1
- package/dist/src/headless/react/WidgetProvider.d.ts +17 -0
- package/dist/src/headless/react/hooks/useConfig.d.ts +1 -0
- package/dist/src/headless/react/hooks/useContact.d.ts +10 -0
- package/dist/src/headless/react/hooks/useIsAwaitingBotReply.d.ts +3 -0
- package/dist/src/headless/react/hooks/useMessages.d.ts +8 -0
- package/dist/{react-web/core-integration → src/headless/react}/hooks/usePreludeData.d.ts +2 -2
- package/dist/{react-web/core-integration → src/headless/react}/hooks/usePubsub.d.ts +1 -1
- package/dist/src/headless/react/hooks/useSession.d.ts +6 -0
- package/dist/{react-web/core-integration → src/headless/react}/hooks/useVote.d.ts +2 -2
- package/dist/src/headless/react/index.d.ts +10 -0
- package/dist/{react-web → src/headless/react}/types/components.d.ts +6 -5
- package/dist/style.css +1 -1
- package/dist/useUploadFiles-CEd5c5iE.js +1336 -0
- package/dist/useUploadFiles-CEd5c5iE.js.map +1 -0
- package/dist/useUploadFiles-CNkahO3s.cjs +18 -0
- package/dist/useUploadFiles-CNkahO3s.cjs.map +1 -0
- package/dist/widget-BeNOCqB5.js +517 -0
- package/dist/widget-BeNOCqB5.js.map +1 -0
- package/dist/widget-DlAUwHzU.cjs +2 -0
- package/dist/widget-DlAUwHzU.cjs.map +1 -0
- package/dist-embed/script.js +137 -157
- package/dist-embed/script.js.map +1 -1
- package/package.json +9 -4
- package/dist/api-CAm3rFZk.js +0 -1070
- package/dist/api-CAm3rFZk.js.map +0 -1
- package/dist/api-oIDR-KZx.cjs +0 -2
- package/dist/api-oIDR-KZx.cjs.map +0 -1
- package/dist/core/client/chat.d.ts +0 -101
- package/dist/core/client/config.d.ts +0 -43
- package/dist/core/client/contact.d.ts +0 -29
- package/dist/core/client/index.d.ts +0 -4
- package/dist/core/errors/index.d.ts +0 -27
- package/dist/core/index.d.ts +0 -9
- package/dist/core/platform/audio.d.ts +0 -38
- package/dist/core/platform/index.d.ts +0 -15
- package/dist/core/platform/logger.d.ts +0 -14
- package/dist/core/platform/storage.d.ts +0 -52
- package/dist/core/tests/platform/logger.test.d.ts +0 -1
- package/dist/core/tests/platform/storage.test.d.ts +0 -1
- package/dist/core/tests/test-utils.d.ts +0 -2
- package/dist/core/tests/types/pub-sub.test.d.ts +0 -1
- package/dist/core/types/contact.d.ts +0 -2
- package/dist/core/types/helpers.d.ts +0 -20
- package/dist/core/types/index.d.ts +0 -52
- package/dist/core/types/prelude.d.ts +0 -14
- package/dist/core/types/schemas-v2.d.ts +0 -10
- package/dist/index-CSptf_Dw.cjs +0 -18
- package/dist/index-CSptf_Dw.cjs.map +0 -1
- package/dist/index-cUkS-tdv.js +0 -1232
- package/dist/index-cUkS-tdv.js.map +0 -1
- package/dist/react-web/core-integration/ChatProvider.d.ts +0 -107
- package/dist/react-web/core-integration/hooks/useChatMessages.d.ts +0 -70
- package/dist/react-web/core-integration/hooks/useChatSession.d.ts +0 -83
- package/dist/react-web/core-integration/hooks/useConfig.d.ts +0 -1
- package/dist/react-web/core-integration/hooks/useContact.d.ts +0 -17
- package/dist/react-web/core-integration/hooks/useLocale.d.ts +0 -4
- package/dist/react-web/core-integration/hooks.d.ts +0 -9
- package/dist/react-web/core-integration/index.d.ts +0 -2
- package/dist/react-web/core-integration/locales/ar.locale.d.ts +0 -2
- package/dist/react-web/core-integration/locales/de.locale.d.ts +0 -2
- package/dist/react-web/core-integration/locales/en.locale.d.ts +0 -55
- package/dist/react-web/core-integration/locales/fr.locale.d.ts +0 -2
- package/dist/react-web/core-integration/locales/helper.d.ts +0 -65
- package/dist/react-web/core-integration/locales/index.d.ts +0 -3
- package/dist/react-web/core-integration/locales/nl.locale.d.ts +0 -2
- package/dist/react-web/core-integration/locales/pt.locale.d.ts +0 -2
- package/dist/react-web/hooks/useScrollTo.d.ts +0 -2
- package/dist/react-web/index.d.ts +0 -4
- package/dist/react-web/types/index.d.ts +0 -8
- package/dist/react-web/types/options.d.ts +0 -17
- package/dist/src/@components/BotOrAgentMessageWrapper.d.ts +0 -9
- package/dist/src/@components/ChatEvent.component.d.ts +0 -9
- package/dist/src/@components/index.d.ts +0 -6
- package/dist/src/designs/basic/index.d.ts +0 -8
- /package/dist/src/designs/{basic → react/basic}/WidgetPopoverTrigger.d.ts +0 -0
- /package/dist/src/designs/{basic → react/basic}/screens/chat-screen/ChatFooter.d.ts +0 -0
- /package/dist/src/designs/{basic → react/basic}/screens/chat-screen/ChatHeader.d.ts +0 -0
- /package/dist/src/designs/{basic → react/basic}/screens/chat-screen/ChatMain.d.ts +0 -0
- /package/dist/src/designs/{basic → react/basic}/screens/chat-screen/ChatScreen.d.ts +0 -0
- /package/dist/src/designs/{basic → react/basic}/screens/root-screen.d.ts +0 -0
- /package/dist/src/designs/{basic → react/basic}/screens/welcome-screen/WelcomeScreen.d.ts +0 -0
- /package/dist/{core/tests/client/integration-perisitance.test.d.ts → src/designs/react/basic/widget-interaction-tests/widget.test.d.ts} +0 -0
- /package/dist/src/{@components → designs/react/components}/Loading.component.d.ts +0 -0
- /package/dist/src/{@components → designs/react/components}/OpenLogoSvg.d.ts +0 -0
- /package/dist/src/{components → designs/react/components/lib}/MotionDiv.d.ts +0 -0
- /package/dist/src/{components → designs/react/components/lib}/avatar.d.ts +0 -0
- /package/dist/src/{components → designs/react/components/lib}/input.d.ts +0 -0
- /package/dist/src/{components → designs/react/components/lib}/popover.d.ts +0 -0
- /package/dist/src/{components → designs/react/components/lib}/skeleton.d.ts +0 -0
- /package/dist/src/{components → designs/react/components/lib}/switch.d.ts +0 -0
- /package/dist/src/{components → designs/react/components/lib}/tooltip.d.ts +0 -0
- /package/dist/src/{utils.d.ts → designs/react/components/lib/utils/cn.d.ts} +0 -0
- /package/dist/src/{components → designs/react/components/lib}/wobble.d.ts +0 -0
- /package/dist/src/{@components → designs/react/components}/markdown.d.ts +0 -0
- /package/dist/{react-web → src/designs/react}/hooks/useWidgetContentHeight.d.ts +0 -0
- /package/dist/src/{render.d.ts → designs/react/render.d.ts} +0 -0
- /package/dist/{core → src/headless/core}/sdk/index.d.ts +0 -0
- /package/dist/{core/tests/client/integration.test.d.ts → src/headless/core/utils/PubSub.test.d.ts} +0 -0
- /package/dist/{core/utils/genUuid.d.ts → src/headless/core/utils/uuid.d.ts} +0 -0
- /package/dist/{react-web/core-integration → src/headless/react}/hooks/useUploadFiles.d.ts +0 -0
- /package/dist/{react-web → src/headless/react}/utils/create-safe-context.d.ts +0 -0
- /package/dist/{core/tests/platform/audio.test.d.ts → vitest/setup.d.ts} +0 -0
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import { PubSub } from '../types/pub-sub';
|
|
2
|
-
import { ApiCaller } from './api';
|
|
3
|
-
import { Platform } from '../platform';
|
|
4
|
-
import { LoadingState, ErrorState } from '../types/helpers';
|
|
5
|
-
import { ConfigInstance } from './config';
|
|
6
|
-
import { Contact } from '../types/contact';
|
|
7
|
-
import { Dto } from '../sdk';
|
|
8
|
-
type ContactState = {
|
|
9
|
-
contact: Contact | null;
|
|
10
|
-
loading: LoadingState;
|
|
11
|
-
error: ErrorState;
|
|
12
|
-
};
|
|
13
|
-
export type CreateContactOptions = {
|
|
14
|
-
api: ApiCaller;
|
|
15
|
-
config: ConfigInstance;
|
|
16
|
-
};
|
|
17
|
-
export declare function createContactHandler({ config, api }: CreateContactOptions, platform: Platform): {
|
|
18
|
-
contactState: PubSub<ContactState>;
|
|
19
|
-
shouldCollectData: () => {
|
|
20
|
-
should: boolean;
|
|
21
|
-
reason: string;
|
|
22
|
-
} | {
|
|
23
|
-
should: boolean;
|
|
24
|
-
reason?: undefined;
|
|
25
|
-
};
|
|
26
|
-
cleanup: () => Promise<void>;
|
|
27
|
-
createUnauthenticatedContact: (payload: Dto["CreateContactDto"]) => Promise<Dto["WidgetContactDto"] | null>;
|
|
28
|
-
};
|
|
29
|
-
export {};
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
export declare class OpenCXError extends Error {
|
|
2
|
-
constructor(message: string);
|
|
3
|
-
}
|
|
4
|
-
export declare class ConnectionError extends OpenCXError {
|
|
5
|
-
constructor(message?: string);
|
|
6
|
-
}
|
|
7
|
-
export declare class AuthenticationError extends OpenCXError {
|
|
8
|
-
constructor(message?: string);
|
|
9
|
-
}
|
|
10
|
-
export declare class SessionError extends OpenCXError {
|
|
11
|
-
constructor(message?: string);
|
|
12
|
-
}
|
|
13
|
-
export declare class SessionNotDefinedError extends SessionError {
|
|
14
|
-
constructor(message?: string);
|
|
15
|
-
}
|
|
16
|
-
export declare class TransportError extends OpenCXError {
|
|
17
|
-
constructor(message?: string);
|
|
18
|
-
}
|
|
19
|
-
export declare class FileUploadError extends OpenCXError {
|
|
20
|
-
constructor(message?: string);
|
|
21
|
-
}
|
|
22
|
-
export declare class StorageNotAvailableError extends OpenCXError {
|
|
23
|
-
constructor(message?: string);
|
|
24
|
-
}
|
|
25
|
-
export declare class ExternalIdNotDefinedError extends OpenCXError {
|
|
26
|
-
constructor(message?: string);
|
|
27
|
-
}
|
package/dist/core/index.d.ts
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
export * from './errors';
|
|
2
|
-
export * from './types';
|
|
3
|
-
export * from './platform';
|
|
4
|
-
export { createChat } from './client/chat';
|
|
5
|
-
export { createContactHandler } from './client/contact';
|
|
6
|
-
export { createConfig } from './client/config';
|
|
7
|
-
export { ApiCaller } from './client/api';
|
|
8
|
-
export { createLogger } from './platform/logger';
|
|
9
|
-
export { PubSub } from './types/pub-sub';
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Platform-agnostic audio interface that can be implemented
|
|
3
|
-
* for different environments (web, mobile, desktop, etc.)
|
|
4
|
-
*/
|
|
5
|
-
export interface Audio {
|
|
6
|
-
/**
|
|
7
|
-
* Plays a notification sound
|
|
8
|
-
* @returns Promise that resolves when the sound finishes playing or rejects on error
|
|
9
|
-
*/
|
|
10
|
-
playNotification(): Promise<void>;
|
|
11
|
-
/**
|
|
12
|
-
* Checks if audio playback is available and working
|
|
13
|
-
* @returns true if audio is available and working
|
|
14
|
-
*/
|
|
15
|
-
isAvailable?(): boolean;
|
|
16
|
-
}
|
|
17
|
-
/**
|
|
18
|
-
* Helper function to check if audio is available and working
|
|
19
|
-
*/
|
|
20
|
-
export declare function isAudioAvailable(audio: Audio | undefined): audio is Audio;
|
|
21
|
-
/**
|
|
22
|
-
* Type for the result of a safe audio operation
|
|
23
|
-
*/
|
|
24
|
-
export type AudioOperationResult = {
|
|
25
|
-
success: true;
|
|
26
|
-
error: null;
|
|
27
|
-
} | {
|
|
28
|
-
success: false;
|
|
29
|
-
error: {
|
|
30
|
-
message: string;
|
|
31
|
-
code: string;
|
|
32
|
-
context: string;
|
|
33
|
-
};
|
|
34
|
-
};
|
|
35
|
-
/**
|
|
36
|
-
* Helper function to safely perform audio operations
|
|
37
|
-
*/
|
|
38
|
-
export declare function safeAudioOperation(operation: () => Promise<void>, errorContext: string): Promise<AudioOperationResult>;
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { Storage } from './storage';
|
|
2
|
-
import { Audio } from './audio';
|
|
3
|
-
import { Logger } from './logger';
|
|
4
|
-
export * from './storage';
|
|
5
|
-
export * from './logger';
|
|
6
|
-
export * from './audio';
|
|
7
|
-
export type { Storage, Audio, Logger };
|
|
8
|
-
export interface Platform {
|
|
9
|
-
storage?: Storage;
|
|
10
|
-
logger?: Logger;
|
|
11
|
-
env: {
|
|
12
|
-
platform: string;
|
|
13
|
-
};
|
|
14
|
-
audio?: Audio;
|
|
15
|
-
}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
export type LogLevel = 'debug' | 'info' | 'warn' | 'error';
|
|
2
|
-
export interface Logger {
|
|
3
|
-
debug(message: string, ...args: any[]): void;
|
|
4
|
-
info(message: string, ...args: any[]): void;
|
|
5
|
-
warn(message: string, ...args: any[]): void;
|
|
6
|
-
error(message: string, ...args: any[]): void;
|
|
7
|
-
setLevel(level: LogLevel): void;
|
|
8
|
-
}
|
|
9
|
-
export type LoggerOptions = {
|
|
10
|
-
level?: LogLevel;
|
|
11
|
-
prefix?: string;
|
|
12
|
-
enabled?: boolean;
|
|
13
|
-
};
|
|
14
|
-
export declare function createLogger(options?: LoggerOptions): Logger;
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Platform-agnostic storage interface that can be implemented
|
|
3
|
-
* for different environments (web, mobile, desktop, etc.)
|
|
4
|
-
*/
|
|
5
|
-
export interface Storage {
|
|
6
|
-
/**
|
|
7
|
-
* Retrieves the value associated with the given key
|
|
8
|
-
* @param key The key to look up
|
|
9
|
-
* @returns The stored value or null if not found
|
|
10
|
-
*/
|
|
11
|
-
getItem(key: string): Promise<string | null>;
|
|
12
|
-
/**
|
|
13
|
-
* Stores a value with the given key
|
|
14
|
-
* @param key The key to store under
|
|
15
|
-
* @param value The value to store
|
|
16
|
-
*/
|
|
17
|
-
setItem(key: string, value: string): Promise<void>;
|
|
18
|
-
/**
|
|
19
|
-
* Removes the value associated with the given key
|
|
20
|
-
* @param key The key to remove
|
|
21
|
-
*/
|
|
22
|
-
removeItem(key: string): Promise<void>;
|
|
23
|
-
/**
|
|
24
|
-
* Checks if the storage is available and working
|
|
25
|
-
* @returns true if storage is available and working
|
|
26
|
-
*/
|
|
27
|
-
isAvailable?(): boolean;
|
|
28
|
-
}
|
|
29
|
-
/**
|
|
30
|
-
* Helper function to check if storage is available and working
|
|
31
|
-
*/
|
|
32
|
-
export declare function isStorageAvailable(storage: Storage | undefined): storage is Storage;
|
|
33
|
-
/**
|
|
34
|
-
* Type for the result of a safe storage operation
|
|
35
|
-
*/
|
|
36
|
-
export type StorageOperationResult<T> = {
|
|
37
|
-
success: true;
|
|
38
|
-
result: T;
|
|
39
|
-
error: null;
|
|
40
|
-
} | {
|
|
41
|
-
success: false;
|
|
42
|
-
result: null;
|
|
43
|
-
error: {
|
|
44
|
-
message: string;
|
|
45
|
-
code: string;
|
|
46
|
-
context: string;
|
|
47
|
-
};
|
|
48
|
-
};
|
|
49
|
-
/**
|
|
50
|
-
* Helper function to safely perform storage operations
|
|
51
|
-
*/
|
|
52
|
-
export declare function safeStorageOperation<T>(operation: () => Promise<T>, errorContext: string): Promise<StorageOperationResult<T>>;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
export type PromiseType<P extends Promise<unknown>> = P extends Promise<infer T> ? T : never;
|
|
2
|
-
export type FunctionReturningPromise = (...args: any[]) => Promise<any>;
|
|
3
|
-
export type MakeKeysNotNullable<T, K extends keyof T> = Omit<T, K> & {
|
|
4
|
-
[P in K]-?: NonNullable<T[P]>;
|
|
5
|
-
};
|
|
6
|
-
export type LoadingReason = 'sending_message_to_bot' | 'sending_message_to_agent' | 'creating_session' | 'polling' | 'loading_contact' | 'saving_contact' | 'cleaning_up' | 'creating_unauthenticated_contact' | null;
|
|
7
|
-
export type LoadingState = {
|
|
8
|
-
isLoading: boolean;
|
|
9
|
-
reason: LoadingReason;
|
|
10
|
-
};
|
|
11
|
-
export type ErrorCode = 'SESSION_CREATION_FAILED' | 'SESSION_CLEAR_FAILED' | 'SESSION_PERSISTENCE_FAILED' | 'SESSION_POLLING_FAILED' | 'MESSAGES_POLLING_FAILED' | 'MESSAGE_SEND_FAILED' | 'NO_ACTIVE_SESSION' | 'CONTACT_PERSISTENCE_FAILED' | 'CONTACT_LOAD_FAILED' | 'CONTACT_SAVE_FAILED' | 'CONTACT_CLEANUP_FAILED' | 'CONTACT_CREATION_FAILED';
|
|
12
|
-
export type ErrorState = {
|
|
13
|
-
hasError: boolean;
|
|
14
|
-
message?: string;
|
|
15
|
-
code?: ErrorCode;
|
|
16
|
-
};
|
|
17
|
-
export type SomeOptional<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;
|
|
18
|
-
export type SafeOmit<T, K extends keyof T> = Omit<T, K>;
|
|
19
|
-
export type SafeExtract<T, K extends T> = Extract<T, K>;
|
|
20
|
-
export type StringOrLiteral<T extends string> = T | (string & {});
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
import { AgentType } from './messages';
|
|
2
|
-
import { ChatAttachmentType } from './schemas-v2';
|
|
3
|
-
export * from './messages';
|
|
4
|
-
export * from './schemas-v2';
|
|
5
|
-
export * from './pub-sub';
|
|
6
|
-
export * from './helpers';
|
|
7
|
-
export interface User {
|
|
8
|
-
external_id?: string;
|
|
9
|
-
name?: string;
|
|
10
|
-
email?: string;
|
|
11
|
-
phone?: string;
|
|
12
|
-
customData?: Record<string, string>;
|
|
13
|
-
avatarUrl?: string;
|
|
14
|
-
}
|
|
15
|
-
export interface SendMessageInput extends Record<string, unknown> {
|
|
16
|
-
content: {
|
|
17
|
-
text: string;
|
|
18
|
-
};
|
|
19
|
-
attachments?: Array<ChatAttachmentType>;
|
|
20
|
-
id?: string;
|
|
21
|
-
language?: string;
|
|
22
|
-
user?: User;
|
|
23
|
-
}
|
|
24
|
-
export interface CoreOptions {
|
|
25
|
-
token: string;
|
|
26
|
-
apiUrl?: string;
|
|
27
|
-
headers?: Record<string, string>;
|
|
28
|
-
queryParams?: Record<string, string>;
|
|
29
|
-
pathParams?: Record<string, string>;
|
|
30
|
-
collectUserData?: boolean;
|
|
31
|
-
debug?: boolean;
|
|
32
|
-
initialMessages?: string[];
|
|
33
|
-
language?: string;
|
|
34
|
-
user?: User;
|
|
35
|
-
contactToken?: string;
|
|
36
|
-
bot?: AgentType;
|
|
37
|
-
pollingInterval?: number;
|
|
38
|
-
soundEffectFiles?: {
|
|
39
|
-
messageArrived?: string;
|
|
40
|
-
};
|
|
41
|
-
theme?: {
|
|
42
|
-
primaryColor?: string;
|
|
43
|
-
triggerOffset?: string;
|
|
44
|
-
};
|
|
45
|
-
settings?: {
|
|
46
|
-
persistSession?: boolean;
|
|
47
|
-
useSoundEffects?: boolean;
|
|
48
|
-
};
|
|
49
|
-
assets?: {
|
|
50
|
-
organizationLogo?: string;
|
|
51
|
-
};
|
|
52
|
-
}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
export interface PreludeData {
|
|
2
|
-
initial_questions?: string[];
|
|
3
|
-
organization_name?: string;
|
|
4
|
-
}
|
|
5
|
-
export interface WorkingHours {
|
|
6
|
-
timezone: string;
|
|
7
|
-
weekdays: {
|
|
8
|
-
[key: string]: {
|
|
9
|
-
enabled: boolean;
|
|
10
|
-
start: string;
|
|
11
|
-
end: string;
|
|
12
|
-
};
|
|
13
|
-
};
|
|
14
|
-
}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { Dto } from '../sdk';
|
|
2
|
-
export type WidgetVoteResponseDto = Dto['WidgetVoteResponseDto'];
|
|
3
|
-
export type HandleContactMessageOutputSchema = Dto['HandleContactMessageOutputDto'];
|
|
4
|
-
export type SendChatDto = Dto['HttpChatInputDto'];
|
|
5
|
-
export type WidgetSessionDto = Dto['WidgetSessionDto'];
|
|
6
|
-
export type WidgetHistoryDto = Dto['WidgetHistoryDto'];
|
|
7
|
-
export type WidgetPreludeDto = Dto['WidgetPreludeDto'];
|
|
8
|
-
export type WidgetVoteDto = Dto['WidgetVoteDto'];
|
|
9
|
-
export type ChatAttachmentType = NonNullable<Dto['WidgetHistoryDto']['attachments']>[number];
|
|
10
|
-
export type MessageTypeU = Dto['WidgetHistoryDto']['type'];
|
package/dist/index-CSptf_Dw.cjs
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
"use strict";var it=Object.defineProperty;var at=(e,t,n)=>t in e?it(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n;var qe=(e,t,n)=>at(e,typeof t!="symbol"?t+"":t,n);const f=require("react"),ct=require("uuid"),ut=require("react/jsx-runtime"),ne=require("./api-oIDR-KZx.cjs"),pe=require("zod");function lt(e){const t=f.createContext({});return[()=>{const i=f.useContext(t);if(i===void 0)throw new Error("useSafeContext must be used within a Provider");return i},t.Provider]}class dt{constructor(t){qe(this,"components",[{key:"fallback",component:t=>"fallback"},{key:"loading",component:t=>"loading"}]);const{components:n}=t;if(n&&n.forEach(i=>this.register(i)),this.components.length===0)throw new Error("No components registered");if(!this.get("fallback"))throw new Error("No fallback component registered")}register(t){const n=this.components.findIndex(i=>i.key===t.key);return n!==-1?this.components[n]=t:this.components.push(t),this}get(t){const n=this.components.find(i=>i.key.toUpperCase()===t.toUpperCase());return n||null}getOrFallback(t){return t?this.get(t)||this.get("fallback"):this.get("fallback")}getComponent(t,n){var i;return n?this.getOrFallback(t).component:(i=this.get(t))==null?void 0:i.component}}const ft={ok:"حسنا",yes:"نعم",no:"لا",agree:"موافق",cancel:"إلغاء","yes-exit":"نعم، اخرج","yes-reset":"نعم، إعادة تعيين","no-cancel":"لا، إلغاء","are-you-sure":"هل أنت متأكد؟",recording:"تسجيل","thank-you":"شكرا","sorry-try-again":"عذرا، حاول مرة أخرى","error-occurred":"حدث خطأ","please-try-again":"يرجى المحاولة مرة أخرى","write-a-message":"اكتب رسالة...","send-message":"إرسال رسالة",connected:"متصل",connecting:"جاري الاتصال",reconnecting:"جاري إعادة الاتصال",reconnected:"تم إعادة الاتصال",disconnecting:"جاري قطع الاتصال",disconnected:"قطع الاتصال",error:"خطأ","persist-session":"حفظ الجلسة",settings:"إعدادات",close:"إغلاق",help:"مساعدة",chat:"محادثة",send:"إرسال",copy:"نسخ",copied:"تم النسخ","sound-effects":"التاثيرات الصوتية",language:"اللغة",select:"اختر",agent:"الوكيل",user:"المستخدم",bot:"البوت","reset-conversation-confirm":"هل أنت متأكد من أنك تريد إعادة تعيين المحادثة؟","close-widget":"إغلاق الودجة","got-any-questions":"هل لديك أي أسئلة؟ تحدث معنا!","typical-response-time":"عادة ما نرد في أقل من دقيقة واحدة","session-closed-lead":"تم حل مشكلتك!",exit:"خروج","create-new-ticket":"إنشاء تذكرة جديدة","reset-conversation":"إعادة تعيين المحادثة","welcome-title":"مرحبًا بك في دردشة الدعم الخاصة بنا","welcome-description":"نحن هنا للمساعدة! ابدأ محادثة وسنرد عليك في أقرب وقت ممكن.","your-name":"اسمك","your-email":"عنوان بريدك الإلكتروني","start-chat":"تحدث إلى الدعم","starting-chat":"جاري الاتصال...","hello-greeting":"مرحبًا! كيف يمكننا مساعدتك اليوم؟"},gt={ok:"OK",yes:"Ja",no:"Nein",agree:"Zustimmen",cancel:"Stornieren","yes-exit":"Ja, beenden","yes-reset":"Ja, zurücksetzen","no-cancel":"Nein, abbrechen","are-you-sure":"Sind Sie sicher?",recording:"Aufnahme läuft","thank-you":"Vielen Dank","sorry-try-again":"Entschuldigung, bitte versuchen Sie es erneut","error-occurred":"Ein Fehler ist aufgetreten","please-try-again":"Bitte versuchen Sie es erneut","write-a-message":"Nachricht schreiben...","send-message":"Nachricht senden",connected:"Verbunden",connecting:"Verbindung wird hergestellt",reconnecting:"Verbindung wird wiederhergestellt",reconnected:"Wieder verbunden",disconnecting:"Verbindung wird getrennt",disconnected:"Verbindung getrennt",error:"Fehler","persist-session":"Sitzung beibehalten",settings:"Einstellungen",close:"Schließen",help:"Hilfe",chat:"Chat",send:"Senden",copy:"Kopieren",copied:"Kopiert","sound-effects":"Soundeffekte",language:"Sprache",select:"Auswählen",agent:"Agent",user:"Benutzer",bot:"Bot","got-any-questions":"Haben Sie Fragen? Chatten Sie mit uns!","typical-response-time":"Üblicherweise antworten wir in weniger als 1 Minute","reset-conversation-confirm":"Möchten Sie die Konversation wirklich zurücksetzen?","close-widget":"Widget schließen","session-closed-lead":"Ihr Problem wurde gelöst!","create-new-ticket":"Neues Ticket erstellen",exit:"Beenden","reset-conversation":"Konversation zurücksetzen","welcome-title":"Willkommen in unserem Support-Chat","welcome-description":"Wir sind hier, um zu helfen! Beginnen Sie ein Gespräch und wir werden so schnell wie möglich antworten.","your-name":"Ihr Name","your-email":"Ihre E-Mail-Adresse","start-chat":"Mit dem Support sprechen","starting-chat":"Verbindung wird hergestellt...","hello-greeting":"Hallo! Wie können wir Ihnen heute helfen?"},pt={ok:"OK",yes:"Yes",no:"No",agree:"Agree",cancel:"Cancel","yes-exit":"Yes, exit","yes-reset":"Yes, reset","no-cancel":"No, cancel","are-you-sure":"Are you sure?",recording:"Recording...","thank-you":"Thank you","sorry-try-again":"Sorry, please try again","error-occurred":"An error occurred","please-try-again":"Please try again","write-a-message":"Write a message...","send-message":"Send message",connected:"Connected",connecting:"Connecting",reconnecting:"Reconnecting",reconnected:"Reconnected",disconnecting:"Disconnecting",disconnected:"Disconnected",error:"Error","persist-session":"Persist session",settings:"Settings",close:"Close",help:"Help",chat:"Chat",send:"Send",copy:"Copy",copied:"Copied","sound-effects":"Sound effects",language:"Language",select:"Select",agent:"Agent",user:"User",bot:"Bot","reset-conversation-confirm":"Are you sure you want to reset the conversation?","close-widget":"Close widget","got-any-questions":"Got any questions? Chat with us!","typical-response-time":"Typically respond in less than 1 minute","session-closed-lead":"Your issue has been resolved!","create-new-ticket":"Create new ticket",exit:"Exit","reset-conversation":"Reset conversation","welcome-title":"Welcome to our support chat","welcome-description":"We're here to help! Start a conversation and we'll get back to you as soon as possible.","your-name":"Your name","your-email":"Your email address","start-chat":"Talk to support","starting-chat":"Connecting...","hello-greeting":"Hi there!"},ht={ok:"D'accord",yes:"Oui",no:"Non",agree:"Accepter",cancel:"Annuler","yes-exit":"Oui, quitter","yes-reset":"Oui, réinitialiser","no-cancel":"Non, annuler","are-you-sure":"Êtes-vous sûr ?",recording:"Enregistrement...","thank-you":"Merci","sorry-try-again":"Désolé, veuillez réessayer","error-occurred":"Une erreur s'est produite","please-try-again":"Veuillez réessayer","write-a-message":"Écrivez un message...","send-message":"Envoyer le message",connected:"Connecté",connecting:"Connexion en cours",reconnecting:"Reconnexion en cours",reconnected:"Reconnecté",disconnecting:"Déconnexion en cours",disconnected:"Déconnecté",error:"Erreur","persist-session":"Conserver la session",settings:"Paramètres",close:"Fermer",help:"Aide",chat:"Chat",send:"Envoyer",copy:"Copier",copied:"Copié","sound-effects":"Effets sonores",language:"Langue",select:"Sélectionner",agent:"Agent",user:"Utilisateur",bot:"Bot","reset-conversation-confirm":"Êtes-vous sûr de vouloir réinitialiser la conversation ?","close-widget":"Fermer le widget","got-any-questions":"Vous avez des questions ? Chattez avec nous !","typical-response-time":"Nous répondons généralement en moins d'une minute","session-closed-lead":"Votre problème a été résolu !","create-new-ticket":"Créer un nouveau ticket",exit:"Sortie","reset-conversation":"Réinitialiser la conversation","welcome-title":"Bienvenue dans notre chat de support","welcome-description":"Nous sommes là pour vous aider ! Commencez une conversation et nous vous répondrons dès que possible.","your-name":"Votre nom","your-email":"Votre adresse e-mail","start-chat":"Parler au support","starting-chat":"Connexion...","hello-greeting":"Bonjour ! Comment pouvons-nous vous aider aujourd'hui ?"},mt={ok:"OK",yes:"Ja",no:"Nee",agree:"Akkoord",cancel:"Annuleren","yes-exit":"Ja, afsluiten","yes-reset":"Ja, resetten","no-cancel":"Nee, annuleren","are-you-sure":"Weet u het zeker?",recording:"Opname...","thank-you":"Dank u","sorry-try-again":"Sorry, probeer het opnieuw","error-occurred":"Er is een fout opgetreden","please-try-again":"Probeer het opnieuw","write-a-message":"Schrijf een bericht...","send-message":"Bericht verzenden",connected:"Verbonden",connecting:"Verbinding maken",reconnecting:"Opnieuw verbinding maken",reconnected:"Opnieuw verbonden",disconnecting:"Verbinding verbreken",disconnected:"Verbinding verbroken",error:"Fout","persist-session":"Sessie behouden",settings:"Instellingen",close:"Sluiten",help:"Help",chat:"Chat",send:"Verzenden",copy:"Kopiëren",copied:"Gekopieerd","sound-effects":"Geluidseffecten",language:"Taal",select:"Selecteren",agent:"Agent",user:"Gebruiker",bot:"Bot","reset-conversation-confirm":"Weet u zeker dat u het gesprek wilt resetten?","close-widget":"Widget sluiten","got-any-questions":"Heeft u vragen? Chat met ons!","typical-response-time":"We reageren doorgaans binnen 1 minuut","session-closed-lead":"Uw probleem is opgelost!","create-new-ticket":"Nieuw ticket aanmaken",exit:"Afsluiten","reset-conversation":"Gesprek resetten","welcome-title":"Welkom bij onze supportchat","welcome-description":"We zijn hier om te helpen! Begin een gesprek en we nemen zo snel mogelijk contact met u op.","your-name":"Uw naam","your-email":"Uw e-mailadres","start-chat":"Praat met ondersteuning","starting-chat":"Verbinding maken...","hello-greeting":"Hallo! Hoe kunnen we u vandaag helpen?"},St={ok:"OK",yes:"Sim",no:"Não",agree:"Concordo",cancel:"Cancelar","yes-exit":"Sim, sair","yes-reset":"Sim, redefinir","no-cancel":"Não, cancelar","are-you-sure":"Você tem certeza?",recording:"Gravando...","thank-you":"Obrigado","sorry-try-again":"Desculpe, tente novamente","error-occurred":"Ocorreu um erro","please-try-again":"Por favor, tente novamente","write-a-message":"Escreva uma mensagem...","send-message":"Enviar mensagem",connected:"Conectado",connecting:"Conectando",reconnecting:"Reconectando",reconnected:"Reconectado",disconnecting:"Desconectando",disconnected:"Desconectado",error:"Erro","persist-session":"Persistir sessão",settings:"Configurações",close:"Fechar",help:"Ajuda",chat:"Bate-papo",send:"Enviar",copy:"Copiar",copied:"Copiado","sound-effects":"Efeitos sonoros",language:"Idioma",select:"Selecionar",agent:"Agente",user:"Usuário",bot:"Bot","reset-conversation-confirm":"Você tem certeza de que deseja redefinir a conversa?","close-widget":"Fechar widget","got-any-questions":"Tem alguma dúvida? Converse conosco!","typical-response-time":"Geralmente respondemos em menos de 1 minuto","session-closed-lead":"Seu problema foi resolvido!","create-new-ticket":"Criar novo ticket",exit:"Sair","reset-conversation":"Redefinir conversa","welcome-title":"Bem-vindo ao nosso chat de suporte","welcome-description":"Estamos aqui para ajudar! Inicie uma conversa e responderemos o mais rápido possível.","your-name":"Seu nome","your-email":"Seu endereço de email","start-chat":"Falar com o suporte","starting-chat":"Conectando...","hello-greeting":"Olá! Como podemos ajudar você hoje?"},Et={en:pt,ar:ft,nl:mt,fr:ht,de:gt,pt:St};function vt(e,t){const n=Et[t];return n&&n[e]||""}const yt={getItem:async e=>localStorage.getItem(e),setItem:async(e,t)=>localStorage.setItem(e,t),removeItem:async e=>localStorage.removeItem(e),isAvailable:()=>!0},ae={env:{platform:"web"},storage:yt,logger:ne.createLogger({level:"debug"})},wt=pe.z.object({persistSession:pe.z.boolean().optional(),useSoundEffects:pe.z.boolean().optional()});function Ct({options:e,platform:t}){var g,b;const[n,i]=f.useState({persistSession:((g=e.settings)==null?void 0:g.persistSession)??!1,useSoundEffects:((b=e.settings)==null?void 0:b.useSoundEffects)??!1}),o=f.useMemo(()=>{var s;return{env:{platform:((s=t==null?void 0:t.env)==null?void 0:s.platform)??ae.env.platform},storage:(t==null?void 0:t.storage)??ae.storage,logger:(t==null?void 0:t.logger)??ae.logger,audio:(t==null?void 0:t.audio)??ae.audio}},[t]),c=f.useMemo(()=>ne.createConfig({...e,settings:n},o),[e,o,n]);f.useEffect(()=>{(async()=>{if(ne.isStorageAvailable(o.storage))try{const r=await o.storage.getItem(`${e.token}:settings`);if(r){const a=wt.parse(JSON.parse(r));i(u=>({...u,...a}))}}catch(r){console.error("Failed to load settings:",r)}})()},[o.storage,e.token]);const d=f.useMemo(()=>new ne.ApiCaller({config:c.getConfig()}),[c.config]),p=f.useMemo(()=>ne.createChat({api:d,config:c,platform:o}),[c,o,d]);return f.useEffect(()=>()=>{p.cleanup()},[p]),{config:c,chat:p,api:d,widgetSettings:n,setWidgetSettings:i}}const[K,_t]=lt();function bt({options:e,children:t,components:n,platform:i}){const o=Ct({options:e,platform:i}),c=f.useMemo(()=>new dt({components:n}),[n]),d=f.useMemo(()=>{const p=o.config.getConfig();return{get:(g,b)=>vt(g,p.language)+(b??""),lang:p.language}},[o.config.getConfig().language]);return ut.jsx(_t,{value:{...o,componentStore:c,version:void 0,locale:d},children:t})}function le(e){return f.useSyncExternalStore(e.subscribe,e.getState,e.getState)}function Rt(){const{chat:e}=K();return{chatState:le(e.chatState),chat:e}}function Ot(){const{chat:e}=K(),t=le(e.sessionState);return{chat:e,chatSession:t}}function Pe(){const{config:e}=K();return e}var Ce={exports:{}},he={};/**
|
|
2
|
-
* @license React
|
|
3
|
-
* use-sync-external-store-shim.production.min.js
|
|
4
|
-
*
|
|
5
|
-
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
6
|
-
*
|
|
7
|
-
* This source code is licensed under the MIT license found in the
|
|
8
|
-
* LICENSE file in the root directory of this source tree.
|
|
9
|
-
*/var ze;function Tt(){if(ze)return he;ze=1;var e=f;function t(r,a){return r===a&&(r!==0||1/r===1/a)||r!==r&&a!==a}var n=typeof Object.is=="function"?Object.is:t,i=e.useState,o=e.useEffect,c=e.useLayoutEffect,d=e.useDebugValue;function p(r,a){var u=a(),R=i({inst:{value:u,getSnapshot:a}}),E=R[0].inst,M=R[1];return c(function(){E.value=u,E.getSnapshot=a,g(E)&&M({inst:E})},[r,u,a]),o(function(){return g(E)&&M({inst:E}),r(function(){g(E)&&M({inst:E})})},[r]),d(u),u}function g(r){var a=r.getSnapshot;r=r.value;try{var u=a();return!n(r,u)}catch{return!0}}function b(r,a){return a()}var s=typeof window>"u"||typeof window.document>"u"||typeof window.document.createElement>"u"?b:p;return he.useSyncExternalStore=e.useSyncExternalStore!==void 0?e.useSyncExternalStore:s,he}var me={};/**
|
|
10
|
-
* @license React
|
|
11
|
-
* use-sync-external-store-shim.development.js
|
|
12
|
-
*
|
|
13
|
-
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
14
|
-
*
|
|
15
|
-
* This source code is licensed under the MIT license found in the
|
|
16
|
-
* LICENSE file in the root directory of this source tree.
|
|
17
|
-
*/var Be;function At(){return Be||(Be=1,process.env.NODE_ENV!=="production"&&function(){typeof __REACT_DEVTOOLS_GLOBAL_HOOK__<"u"&&typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart=="function"&&__REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart(new Error);var e=f,t=e.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;function n(_){{for(var m=arguments.length,v=new Array(m>1?m-1:0),S=1;S<m;S++)v[S-1]=arguments[S];i("error",_,v)}}function i(_,m,v){{var S=t.ReactDebugCurrentFrame,x=S.getStackAddendum();x!==""&&(m+="%s",v=v.concat([x]));var y=v.map(function(T){return String(T)});y.unshift("Warning: "+m),Function.prototype.apply.call(console[_],console,y)}}function o(_,m){return _===m&&(_!==0||1/_===1/m)||_!==_&&m!==m}var c=typeof Object.is=="function"?Object.is:o,d=e.useState,p=e.useEffect,g=e.useLayoutEffect,b=e.useDebugValue,s=!1,r=!1;function a(_,m,v){s||e.startTransition!==void 0&&(s=!0,n("You are using an outdated, pre-release alpha of React 18 that does not support useSyncExternalStore. The use-sync-external-store shim will not work correctly. Upgrade to a newer pre-release."));var S=m();if(!r){var x=m();c(S,x)||(n("The result of getSnapshot should be cached to avoid an infinite loop"),r=!0)}var y=d({inst:{value:S,getSnapshot:m}}),T=y[0].inst,L=y[1];return g(function(){T.value=S,T.getSnapshot=m,u(T)&&L({inst:T})},[_,S,m]),p(function(){u(T)&&L({inst:T});var B=function(){u(T)&&L({inst:T})};return _(B)},[_]),b(S),S}function u(_){var m=_.getSnapshot,v=_.value;try{var S=m();return!c(v,S)}catch{return!0}}function R(_,m,v){return m()}var E=typeof window<"u"&&typeof window.document<"u"&&typeof window.document.createElement<"u",M=!E,l=M?R:a,J=e.useSyncExternalStore!==void 0?e.useSyncExternalStore:l;me.useSyncExternalStore=J,typeof __REACT_DEVTOOLS_GLOBAL_HOOK__<"u"&&typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop=="function"&&__REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop(new Error)}()),me}process.env.NODE_ENV==="production"?Ce.exports=Tt():Ce.exports=At();var Dt=Ce.exports;const j=()=>{},k=j(),Se=Object,h=e=>e===k,U=e=>typeof e=="function",G=(e,t)=>({...e,...t}),Vt=e=>U(e.then),ce=new WeakMap;let Lt=0;const re=e=>{const t=typeof e,n=e&&e.constructor,i=n==Date;let o,c;if(Se(e)===e&&!i&&n!=RegExp){if(o=ce.get(e),o)return o;if(o=++Lt+"~",ce.set(e,o),n==Array){for(o="@",c=0;c<e.length;c++)o+=re(e[c])+",";ce.set(e,o)}if(n==Se){o="#";const d=Se.keys(e).sort();for(;!h(c=d.pop());)h(e[c])||(o+=c+":"+re(e[c])+",");ce.set(e,o)}}else o=i?e.toJSON():t=="symbol"?e.toString():t=="string"?JSON.stringify(e):""+e;return o},z=new WeakMap,Ee={},ue={},Ae="undefined",de=typeof window!=Ae,_e=typeof document!=Ae,kt=()=>de&&typeof window.requestAnimationFrame!=Ae,Je=(e,t)=>{const n=z.get(e);return[()=>!h(t)&&e.get(t)||Ee,i=>{if(!h(t)){const o=e.get(t);t in ue||(ue[t]=o),n[5](t,G(o,i),o||Ee)}},n[6],()=>!h(t)&&t in ue?ue[t]:!h(t)&&e.get(t)||Ee]};let be=!0;const xt=()=>be,[Re,Oe]=de&&window.addEventListener?[window.addEventListener.bind(window),window.removeEventListener.bind(window)]:[j,j],Nt=()=>{const e=_e&&document.visibilityState;return h(e)||e!=="hidden"},It=e=>(_e&&document.addEventListener("visibilitychange",e),Re("focus",e),()=>{_e&&document.removeEventListener("visibilitychange",e),Oe("focus",e)}),Ft=e=>{const t=()=>{be=!0,e()},n=()=>{be=!1};return Re("online",t),Re("offline",n),()=>{Oe("online",t),Oe("offline",n)}},Ut={isOnline:xt,isVisible:Nt},Mt={initFocus:It,initReconnect:Ft},He=!f.useId,oe=!de||"Deno"in window,Wt=e=>kt()?window.requestAnimationFrame(e):setTimeout(e,1),ve=oe?f.useEffect:f.useLayoutEffect,ye=typeof navigator<"u"&&navigator.connection,je=!oe&&ye&&(["slow-2g","2g"].includes(ye.effectiveType)||ye.saveData),De=e=>{if(U(e))try{e=e()}catch{e=""}const t=e;return e=typeof e=="string"?e:(Array.isArray(e)?e.length:e)?re(e):"",[e,t]};let qt=0;const Te=()=>++qt,Ye=0,$e=1,Xe=2,zt=3;var te={__proto__:null,ERROR_REVALIDATE_EVENT:zt,FOCUS_EVENT:Ye,MUTATE_EVENT:Xe,RECONNECT_EVENT:$e};async function Ze(...e){const[t,n,i,o]=e,c=G({populateCache:!0,throwOnError:!0},typeof o=="boolean"?{revalidate:o}:o||{});let d=c.populateCache;const p=c.rollbackOnError;let g=c.optimisticData;const b=a=>typeof p=="function"?p(a):p!==!1,s=c.throwOnError;if(U(n)){const a=n,u=[],R=t.keys();for(const E of R)!/^\$(inf|sub)\$/.test(E)&&a(t.get(E)._k)&&u.push(E);return Promise.all(u.map(r))}return r(n);async function r(a){const[u]=De(a);if(!u)return;const[R,E]=Je(t,u),[M,l,J,_]=z.get(t),m=()=>{const I=M[u];return(U(c.revalidate)?c.revalidate(R().data,a):c.revalidate!==!1)&&(delete J[u],delete _[u],I&&I[0])?I[0](Xe).then(()=>R().data):R().data};if(e.length<3)return m();let v=i,S;const x=Te();l[u]=[x,0];const y=!h(g),T=R(),L=T.data,B=T._c,P=h(B)?L:B;if(y&&(g=U(g)?g(P,L):g,E({data:g,_c:P})),U(v))try{v=v(P)}catch(I){S=I}if(v&&Vt(v))if(v=await v.catch(I=>{S=I}),x!==l[u][0]){if(S)throw S;return v}else S&&y&&b(S)&&(d=!0,E({data:P,_c:k}));if(d&&!S)if(U(d)){const I=d(v,P);E({data:I,error:k,_c:k})}else E({data:v,error:k,_c:k});if(l[u][1]=Te(),Promise.resolve(m()).then(()=>{E({_c:k})}),S){if(s)throw S;return}return v}}const Ge=(e,t)=>{for(const n in e)e[n][0]&&e[n][0](t)},Bt=(e,t)=>{if(!z.has(e)){const n=G(Mt,t),i={},o=Ze.bind(k,e);let c=j;const d={},p=(s,r)=>{const a=d[s]||[];return d[s]=a,a.push(r),()=>a.splice(a.indexOf(r),1)},g=(s,r,a)=>{e.set(s,r);const u=d[s];if(u)for(const R of u)R(r,a)},b=()=>{if(!z.has(e)&&(z.set(e,[i,{},{},{},o,g,p]),!oe)){const s=n.initFocus(setTimeout.bind(k,Ge.bind(k,i,Ye))),r=n.initReconnect(setTimeout.bind(k,Ge.bind(k,i,$e)));c=()=>{s&&s(),r&&r(),z.delete(e)}}};return b(),[e,o,b,c]}return[e,z.get(e)[4]]},Ht=(e,t,n,i,o)=>{const c=n.errorRetryCount,d=o.retryCount,p=~~((Math.random()+.5)*(1<<(d<8?d:8)))*n.errorRetryInterval;!h(c)&&d>c||setTimeout(i,p,o)},jt=(e,t)=>re(e)==re(t),[Qe,Gt]=Bt(new Map),Kt=G({onLoadingSlow:j,onSuccess:j,onError:j,onErrorRetry:Ht,onDiscarded:j,revalidateOnFocus:!0,revalidateOnReconnect:!0,revalidateIfStale:!0,shouldRetryOnError:!0,errorRetryInterval:je?1e4:5e3,focusThrottleInterval:5*1e3,dedupingInterval:2*1e3,loadingTimeout:je?5e3:3e3,compare:jt,isPaused:()=>!1,cache:Qe,mutate:Gt,fallback:{}},Ut),Pt=(e,t)=>{const n=G(e,t);if(t){const{use:i,fallback:o}=e,{use:c,fallback:d}=t;i&&c&&(n.use=i.concat(c)),o&&d&&(n.fallback=G(o,d))}return n},Jt=f.createContext({}),Yt="$inf$",et=de&&window.__SWR_DEVTOOLS_USE__,$t=et?window.__SWR_DEVTOOLS_USE__:[],Xt=()=>{et&&(window.__SWR_DEVTOOLS_REACT__=f)},Zt=e=>U(e[1])?[e[0],e[1],e[2]||{}]:[e[0],null,(e[1]===null?e[2]:e[1])||{}],Qt=()=>G(Kt,f.useContext(Jt)),en=e=>(t,n,i)=>e(t,n&&((...c)=>{const[d]=De(t),[,,,p]=z.get(Qe);if(d.startsWith(Yt))return n(...c);const g=p[d];return h(g)?n(...c):(delete p[d],g)}),i),tn=$t.concat(en),nn=e=>function(...n){const i=Qt(),[o,c,d]=Zt(n),p=Pt(i,d);let g=e;const{use:b}=p,s=(b||[]).concat(tn);for(let r=s.length;r--;)g=s[r](g);return g(o,c||p.fetcher||null,p)},rn=(e,t,n)=>{const i=t[e]||(t[e]=[]);return i.push(n),()=>{const o=i.indexOf(n);o>=0&&(i[o]=i[i.length-1],i.pop())}};Xt();const Ke=f.use||(e=>{if(e.status==="pending")throw e;if(e.status==="fulfilled")return e.value;throw e.status==="rejected"?e.reason:(e.status="pending",e.then(t=>{e.status="fulfilled",e.value=t},t=>{e.status="rejected",e.reason=t}),e)}),we={dedupe:!0},on=(e,t,n)=>{const{cache:i,compare:o,suspense:c,fallbackData:d,revalidateOnMount:p,revalidateIfStale:g,refreshInterval:b,refreshWhenHidden:s,refreshWhenOffline:r,keepPreviousData:a}=n,[u,R,E,M]=z.get(i),[l,J]=De(e),_=f.useRef(!1),m=f.useRef(!1),v=f.useRef(l),S=f.useRef(t),x=f.useRef(n),y=()=>x.current,T=()=>y().isVisible()&&y().isOnline(),[L,B,P,I]=Je(i,l),Y=f.useRef({}).current,tt=h(d)?n.fallback[l]:d,Ve=(w,C)=>{for(const D in Y){const O=D;if(O==="data"){if(!o(w[O],C[O])&&(!h(w[O])||!o(ie,C[O])))return!1}else if(C[O]!==w[O])return!1}return!0},Le=f.useMemo(()=>{const w=!l||!t?!1:h(p)?y().isPaused()||c?!1:h(g)?!0:g:p,C=V=>{const W=G(V);return delete W._k,w?{isValidating:!0,isLoading:!0,...W}:W},D=L(),O=I(),F=C(D),Q=D===O?F:C(O);let A=F;return[()=>{const V=C(L());return Ve(V,A)?(A.data=V.data,A.isLoading=V.isLoading,A.isValidating=V.isValidating,A.error=V.error,A):(A=V,V)},()=>Q]},[i,l]),$=Dt.useSyncExternalStore(f.useCallback(w=>P(l,(C,D)=>{Ve(D,C)||w()}),[i,l]),Le[0],Le[1]),ke=!_.current,nt=u[l]&&u[l].length>0,X=$.data,Z=h(X)?tt:X,se=$.error,xe=f.useRef(Z),ie=a?h(X)?xe.current:X:Z,Ne=nt&&!h(se)?!1:ke&&!h(p)?p:y().isPaused()?!1:c?h(Z)?!1:g:h(Z)||g,Ie=!!(l&&t&&ke&&Ne),rt=h($.isValidating)?Ie:$.isValidating,ot=h($.isLoading)?Ie:$.isLoading,ee=f.useCallback(async w=>{const C=S.current;if(!l||!C||m.current||y().isPaused())return!1;let D,O,F=!0;const Q=w||{},A=!E[l]||!Q.dedupe,V=()=>He?!m.current&&l===v.current&&_.current:l===v.current,W={isValidating:!1,isLoading:!1},Ue=()=>{B(W)},Me=()=>{const N=E[l];N&&N[1]===O&&delete E[l]},We={isValidating:!0};h(L().data)&&(We.isLoading=!0);try{if(A&&(B(We),n.loadingTimeout&&h(L().data)&&setTimeout(()=>{F&&V()&&y().onLoadingSlow(l,n)},n.loadingTimeout),E[l]=[C(J),Te()]),[D,O]=E[l],D=await D,A&&setTimeout(Me,n.dedupingInterval),!E[l]||E[l][1]!==O)return A&&V()&&y().onDiscarded(l),!1;W.error=k;const N=R[l];if(!h(N)&&(O<=N[0]||O<=N[1]||N[1]===0))return Ue(),A&&V()&&y().onDiscarded(l),!1;const q=L().data;W.data=o(q,D)?q:D,A&&V()&&y().onSuccess(D,l,n)}catch(N){Me();const q=y(),{shouldRetryOnError:fe}=q;q.isPaused()||(W.error=N,A&&V()&&(q.onError(N,l,q),(fe===!0||U(fe)&&fe(N))&&(!y().revalidateOnFocus||!y().revalidateOnReconnect||T())&&q.onErrorRetry(N,l,q,st=>{const ge=u[l];ge&&ge[0]&&ge[0](te.ERROR_REVALIDATE_EVENT,st)},{retryCount:(Q.retryCount||0)+1,dedupe:!0})))}return F=!1,Ue(),!0},[l,i]),Fe=f.useCallback((...w)=>Ze(i,v.current,...w),[]);if(ve(()=>{S.current=t,x.current=n,h(X)||(xe.current=X)}),ve(()=>{if(!l)return;const w=ee.bind(k,we);let C=0;const O=rn(l,u,(F,Q={})=>{if(F==te.FOCUS_EVENT){const A=Date.now();y().revalidateOnFocus&&A>C&&T()&&(C=A+y().focusThrottleInterval,w())}else if(F==te.RECONNECT_EVENT)y().revalidateOnReconnect&&T()&&w();else{if(F==te.MUTATE_EVENT)return ee();if(F==te.ERROR_REVALIDATE_EVENT)return ee(Q)}});return m.current=!1,v.current=l,_.current=!0,B({_k:J}),Ne&&(h(Z)||oe?w():Wt(w)),()=>{m.current=!0,O()}},[l]),ve(()=>{let w;function C(){const O=U(b)?b(L().data):b;O&&w!==-1&&(w=setTimeout(D,O))}function D(){!L().error&&(s||y().isVisible())&&(r||y().isOnline())?ee(we).then(C):C()}return C(),()=>{w&&(clearTimeout(w),w=-1)}},[b,s,r,l]),f.useDebugValue(ie),c&&h(Z)&&l){if(!He&&oe)throw new Error("Fallback data is required when using suspense in SSR.");S.current=t,x.current=n,m.current=!1;const w=M[l];if(!h(w)){const C=Fe(w);Ke(C)}if(h(se)){const C=ee(we);h(ie)||(C.status="fulfilled",C.value=!0),Ke(C)}else throw se}return{mutate:Fe,get data(){return Y.data=!0,ie},get error(){return Y.error=!0,se},get isValidating(){return Y.isValidating=!0,rt},get isLoading(){return Y.isLoading=!0,ot}}},sn=nn(on);function an(){const{api:e}=K(),t=Pe();return sn([t.config.apiUrl],e.widgetPrelude)}function cn(){const{locale:e}=K();return e}const H=new Map;function un(){const[e,t]=f.useState([]),{api:n}=K();function i(s){const r=s.map(a=>({file:a,id:ct.v4(),status:"pending",progress:0}));t(a=>[...a,...r]),r.forEach(d)}function o(s,r){t(a=>a.map(u=>u.id===s?{...u,...r}:u))}function c(s){t(r=>r.filter(a=>a.id!==s))}const d=async s=>{const r=new AbortController;H.set(s.id,r);try{t(u=>u.map(R=>R.id===s.id?{...R,status:"uploading",progress:0}:R));const a=await n.uploadFile(s,{signal:r.signal,onUploadProgress:u=>{if(!u.total)return;const R=Math.round(u.loaded*100/u.total);o(s.id,{progress:R})}});o(s.id,{status:"success",fileUrl:a.fileUrl,progress:100})}catch(a){r.signal.aborted||o(s.id,{status:"error",error:a instanceof Error?a.message:"Upload failed",progress:0})}finally{H.delete(s.id)}},p=s=>{const r=H.get(s);r&&(r.abort(),H.delete(s)),c(s)},g=f.useMemo(()=>e.filter(s=>s.status==="success"&&s.fileUrl),[e]);function b(){H.forEach(s=>s.abort()),H.clear(),t([])}return f.useEffect(()=>()=>{H.forEach(s=>s.abort()),H.clear()},[]),{allFiles:e,appendFiles:i,handleCancelUpload:p,successFiles:g,emptyTheFiles:b,getFileById:s=>e.find(r=>r.id===s),getUploadProgress:s=>{var r;return((r=e.find(a=>a.id===s))==null?void 0:r.progress)??0},getUploadStatus:s=>{var r;return(r=e.find(a=>a.id===s))==null?void 0:r.status},hasErrors:e.some(s=>s.status==="error"),isUploading:e.some(s=>s.status==="uploading")}}function ln(){const{chat:e}=K();return{contactState:le(e.contactState),contactManager:e.contactManager}}exports.ChatProvider=bt;exports.useChat=K;exports.useChatSession=Ot;exports.useChatState=Rt;exports.useConfig=Pe;exports.useContact=ln;exports.useLocale=cn;exports.usePreludeData=an;exports.usePubsub=le;exports.useUploadFiles=un;
|
|
18
|
-
//# sourceMappingURL=index-CSptf_Dw.cjs.map
|