@botpress/webchat 0.5.1 → 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (295) hide show
  1. package/dist/App.d.ts +10 -0
  2. package/dist/Utils/colors.d.ts +18 -0
  3. package/dist/Utils/eventEmitter.d.ts +12 -0
  4. package/dist/Utils/index.d.ts +2 -0
  5. package/dist/client/MessagingClient.d.ts +27 -0
  6. package/dist/client/adapters/Audio.d.ts +19 -0
  7. package/dist/client/adapters/Card.d.ts +188 -0
  8. package/dist/client/adapters/Carousel.d.ts +147 -0
  9. package/dist/client/adapters/Choice.d.ts +45 -0
  10. package/dist/client/adapters/Dropdown.d.ts +46 -0
  11. package/dist/client/adapters/File.d.ts +19 -0
  12. package/dist/client/adapters/Image.d.ts +19 -0
  13. package/dist/client/adapters/Location.d.ts +27 -0
  14. package/dist/client/adapters/Message.d.ts +433 -0
  15. package/dist/client/adapters/Text.d.ts +20 -0
  16. package/dist/client/adapters/Utils.d.ts +5 -0
  17. package/dist/client/adapters/Video.d.ts +19 -0
  18. package/dist/client/adapters/Voice.d.ts +15 -0
  19. package/dist/client/adapters/index.d.ts +12 -0
  20. package/dist/client/index.d.ts +2 -0
  21. package/dist/components/Avatar.d.ts +6 -0
  22. package/dist/components/Block.d.ts +4 -0
  23. package/dist/components/Composer.d.ts +12 -14
  24. package/dist/components/Container.d.ts +2 -12
  25. package/dist/components/Header.d.ts +36 -26
  26. package/dist/components/LoadingIndicator.d.ts +2 -0
  27. package/dist/components/Message.d.ts +7 -0
  28. package/dist/components/MessageList.d.ts +2 -0
  29. package/dist/components/Modal.d.ts +17 -0
  30. package/dist/components/RestartConversation.d.ts +5 -0
  31. package/dist/components/Webchat.d.ts +6 -0
  32. package/dist/components/dev-tools/DevTools.d.ts +1 -0
  33. package/dist/components/dev-tools/configuration.d.ts +2 -0
  34. package/dist/components/dev-tools/helpers.d.ts +5 -0
  35. package/dist/components/index.d.ts +12 -0
  36. package/dist/components/renderers/Audio.d.ts +3 -0
  37. package/dist/components/renderers/Bubble.d.ts +5 -0
  38. package/dist/components/renderers/Button.d.ts +4 -0
  39. package/dist/components/renderers/Carousel.d.ts +3 -0
  40. package/dist/components/renderers/Column.d.ts +5 -0
  41. package/dist/components/renderers/Dropdown.d.ts +5 -0
  42. package/dist/components/renderers/File.d.ts +3 -0
  43. package/dist/components/renderers/Image.d.ts +3 -0
  44. package/dist/components/renderers/Location.d.ts +3 -0
  45. package/dist/components/renderers/Row.d.ts +5 -0
  46. package/dist/components/renderers/Text.d.ts +4 -0
  47. package/dist/components/renderers/Video.d.ts +3 -0
  48. package/dist/components/renderers/index.d.ts +2 -0
  49. package/dist/contexts/ComposerContext.d.ts +8 -0
  50. package/dist/contexts/MessageContext.d.ts +8 -0
  51. package/dist/contexts/ModalContext.d.ts +14 -0
  52. package/dist/contexts/WebchatContext.d.ts +56 -0
  53. package/dist/contexts/index.d.ts +4 -0
  54. package/dist/hooks/index.d.ts +3 -0
  55. package/dist/hooks/useImageSize.d.ts +2 -0
  56. package/dist/hooks/useRefresh.d.ts +10 -0
  57. package/dist/hooks/useWebchatStore.d.ts +30 -0
  58. package/dist/index.d.ts +3 -17
  59. package/dist/index.js +43569 -48
  60. package/dist/index.umd.cjs +702 -0
  61. package/dist/main.d.ts +11 -13
  62. package/dist/providers/ModalProvider.d.ts +8 -0
  63. package/dist/providers/WebchatProvider.d.ts +13 -0
  64. package/dist/providers/index.d.ts +2 -0
  65. package/dist/schemas/index.d.ts +1 -0
  66. package/dist/schemas/theme.d.ts +3371 -0
  67. package/dist/services/clipboard.d.ts +1 -0
  68. package/dist/services/images.d.ts +2 -0
  69. package/dist/services/index.d.ts +3 -0
  70. package/dist/services/toast.d.ts +17 -0
  71. package/dist/themes/dawn.d.ts +2 -0
  72. package/dist/themes/duskTheme.d.ts +2 -0
  73. package/dist/themes/eggplant.d.ts +2 -0
  74. package/dist/themes/galaxy.d.ts +2 -0
  75. package/dist/themes/index.d.ts +6 -0
  76. package/dist/themes/midnight.d.ts +2 -0
  77. package/dist/themes/prism.d.ts +2 -0
  78. package/dist/twind.config.d.ts +9 -0
  79. package/dist/types/block-type.d.ts +93 -0
  80. package/dist/types/image.d.ts +11 -0
  81. package/dist/types/index.d.ts +2 -0
  82. package/dist/vite.svg +1 -0
  83. package/index.html +18 -0
  84. package/package.json +60 -49
  85. package/public/vite.svg +1 -0
  86. package/src/App.tsx +41 -0
  87. package/src/Utils/colors.ts +45 -0
  88. package/src/Utils/eventEmitter.ts +31 -0
  89. package/src/Utils/index.ts +2 -0
  90. package/src/assets/check-circle-bold.svg +5 -0
  91. package/src/assets/chevron-up.svg +3 -0
  92. package/src/assets/file-05.svg +6 -0
  93. package/src/assets/globe-02.svg +6 -0
  94. package/src/assets/help-circle.svg +3 -0
  95. package/src/assets/info-circle.svg +3 -0
  96. package/src/assets/lock-01.svg +4 -0
  97. package/src/assets/mail-01.svg +6 -0
  98. package/src/assets/minus-circle.svg +3 -0
  99. package/src/assets/phone.svg +6 -0
  100. package/src/assets/send-03.svg +4 -0
  101. package/src/assets/share-04.svg +5 -0
  102. package/src/assets/slash-circle-01.svg +3 -0
  103. package/src/assets/x-circle-bold.svg +5 -0
  104. package/src/assets/x-close.svg +3 -0
  105. package/src/assets/x.svg +3 -0
  106. package/src/client/MessagingClient.ts +87 -0
  107. package/src/client/adapters/Audio.ts +10 -0
  108. package/src/client/adapters/Card.ts +104 -0
  109. package/src/client/adapters/Carousel.ts +11 -0
  110. package/src/client/adapters/Choice.ts +48 -0
  111. package/src/client/adapters/Dropdown.ts +39 -0
  112. package/src/client/adapters/File.ts +10 -0
  113. package/src/client/adapters/Image.ts +10 -0
  114. package/src/client/adapters/Location.ts +18 -0
  115. package/src/client/adapters/Message.ts +26 -0
  116. package/src/client/adapters/Text.ts +11 -0
  117. package/src/client/adapters/Utils.ts +11 -0
  118. package/src/client/adapters/Video.ts +10 -0
  119. package/src/client/adapters/Voice.ts +9 -0
  120. package/src/client/adapters/index.ts +12 -0
  121. package/src/client/index.ts +2 -0
  122. package/src/components/Avatar.tsx +22 -0
  123. package/src/components/Block.tsx +17 -0
  124. package/src/components/Composer.tsx +115 -0
  125. package/src/components/Container.tsx +17 -0
  126. package/src/components/Header.tsx +141 -0
  127. package/src/components/LoadingIndicator.tsx +15 -0
  128. package/src/components/Message.tsx +52 -0
  129. package/src/components/MessageList.tsx +75 -0
  130. package/src/components/Modal.tsx +49 -0
  131. package/src/components/RestartConversation.tsx +52 -0
  132. package/src/components/Webchat.tsx +68 -0
  133. package/src/components/dev-tools/DevTools.tsx +496 -0
  134. package/src/components/dev-tools/configuration.tsx +27 -0
  135. package/src/components/dev-tools/helpers.ts +21 -0
  136. package/src/components/index.ts +12 -0
  137. package/src/components/renderers/Audio.tsx +11 -0
  138. package/src/components/renderers/Bubble.tsx +12 -0
  139. package/src/components/renderers/Button.tsx +59 -0
  140. package/src/components/renderers/Carousel.tsx +51 -0
  141. package/src/components/renderers/Column.tsx +22 -0
  142. package/src/components/renderers/Dropdown.tsx +170 -0
  143. package/src/components/renderers/File.tsx +13 -0
  144. package/src/components/renderers/Image.tsx +63 -0
  145. package/src/components/renderers/Location.tsx +16 -0
  146. package/src/components/renderers/Row.tsx +22 -0
  147. package/src/components/renderers/Text.tsx +32 -0
  148. package/src/components/renderers/Video.tsx +11 -0
  149. package/src/components/renderers/index.ts +28 -0
  150. package/src/contexts/ComposerContext.ts +16 -0
  151. package/src/contexts/MessageContext.ts +16 -0
  152. package/src/contexts/ModalContext.ts +19 -0
  153. package/src/contexts/WebchatContext.ts +61 -0
  154. package/src/contexts/index.ts +4 -0
  155. package/src/hooks/index.ts +3 -0
  156. package/src/hooks/useImageSize.ts +30 -0
  157. package/src/hooks/useRefresh.ts +33 -0
  158. package/src/hooks/useWebchatStore.ts +45 -0
  159. package/src/index.css +18 -0
  160. package/src/index.ts +3 -0
  161. package/src/main.tsx +33 -0
  162. package/src/providers/ModalProvider.tsx +35 -0
  163. package/src/providers/WebchatProvider.tsx +107 -0
  164. package/src/providers/index.ts +2 -0
  165. package/src/schemas/index.ts +1 -0
  166. package/src/schemas/theme.ts +188 -0
  167. package/src/services/clipboard.ts +8 -0
  168. package/src/services/images.ts +39 -0
  169. package/src/services/index.ts +3 -0
  170. package/src/services/toast.tsx +71 -0
  171. package/src/themes/dawn.ts +277 -0
  172. package/src/themes/duskTheme.ts +349 -0
  173. package/src/themes/eggplant.ts +353 -0
  174. package/src/themes/galaxy.ts +323 -0
  175. package/src/themes/index.ts +6 -0
  176. package/src/themes/midnight.ts +276 -0
  177. package/src/themes/prism.ts +349 -0
  178. package/src/twind.config.ts +31 -0
  179. package/src/types/block-type.ts +150 -0
  180. package/src/types/image.ts +10 -0
  181. package/src/types/index.ts +2 -0
  182. package/src/vite-env.d.ts +1 -0
  183. package/tailwind.config.js +0 -0
  184. package/tsconfig.json +30 -0
  185. package/tsconfig.node.json +10 -0
  186. package/vite.config.ts +31 -0
  187. package/README.md +0 -41
  188. package/assets/fonts/roboto/roboto.woff2 +0 -0
  189. package/assets/fonts/roboto/roboto500.woff2 +0 -0
  190. package/assets/fonts/roboto.css +0 -128
  191. package/assets/notification.mp3 +0 -0
  192. package/dist/components/Composer.js +0 -118
  193. package/dist/components/Container.js +0 -62
  194. package/dist/components/ConversationList.d.ts +0 -10
  195. package/dist/components/ConversationList.js +0 -41
  196. package/dist/components/Footer.d.ts +0 -3
  197. package/dist/components/Footer.js +0 -21
  198. package/dist/components/Header.js +0 -181
  199. package/dist/components/VoiceRecorder.d.ts +0 -10
  200. package/dist/components/VoiceRecorder.js +0 -137
  201. package/dist/components/common/Avatar/index.d.ts +0 -9
  202. package/dist/components/common/Avatar/index.js +0 -13
  203. package/dist/components/common/BotInfo/index.d.ts +0 -10
  204. package/dist/components/common/BotInfo/index.js +0 -107
  205. package/dist/components/common/BotInfo/style.scss +0 -88
  206. package/dist/components/common/ConfirmDialog/index.d.ts +0 -11
  207. package/dist/components/common/ConfirmDialog/index.js +0 -78
  208. package/dist/components/common/ConfirmDialog/style.module.scss +0 -48
  209. package/dist/components/common/Dialog/index.d.ts +0 -17
  210. package/dist/components/common/Dialog/index.js +0 -57
  211. package/dist/components/common/Dialog/style.module.scss +0 -29
  212. package/dist/components/common/ToolTip/index.d.ts +0 -10
  213. package/dist/components/common/ToolTip/index.js +0 -163
  214. package/dist/components/common/ToolTip/style.module.scss +0 -108
  215. package/dist/components/common/ToolTip/utils.d.ts +0 -15
  216. package/dist/components/common/ToolTip/utils.js +0 -78
  217. package/dist/components/common/variables.scss +0 -38
  218. package/dist/components/messages/InlineFeedback.d.ts +0 -11
  219. package/dist/components/messages/InlineFeedback.js +0 -56
  220. package/dist/components/messages/Message.d.ts +0 -11
  221. package/dist/components/messages/Message.js +0 -106
  222. package/dist/components/messages/MessageGroup.d.ts +0 -23
  223. package/dist/components/messages/MessageGroup.js +0 -63
  224. package/dist/components/messages/MessageList.d.ts +0 -10
  225. package/dist/components/messages/MessageList.js +0 -148
  226. package/dist/core/api.d.ts +0 -23
  227. package/dist/core/api.js +0 -117
  228. package/dist/core/constants.d.ts +0 -14
  229. package/dist/core/constants.js +0 -29
  230. package/dist/core/socket.d.ts +0 -14
  231. package/dist/core/socket.js +0 -57
  232. package/dist/declaration.d.ts +0 -2
  233. package/dist/declaration.js +0 -1
  234. package/dist/fonts/roboto.d.ts +0 -4
  235. package/dist/fonts/roboto.js +0 -9
  236. package/dist/globals.d.ts +0 -7
  237. package/dist/globals.js +0 -2
  238. package/dist/icons/Add.d.ts +0 -6
  239. package/dist/icons/Add.js +0 -10
  240. package/dist/icons/Cancel.d.ts +0 -5
  241. package/dist/icons/Cancel.js +0 -10
  242. package/dist/icons/Chat.d.ts +0 -6
  243. package/dist/icons/Chat.js +0 -9
  244. package/dist/icons/Close.d.ts +0 -3
  245. package/dist/icons/Close.js +0 -10
  246. package/dist/icons/Delete.d.ts +0 -3
  247. package/dist/icons/Delete.js +0 -11
  248. package/dist/icons/Download.d.ts +0 -3
  249. package/dist/icons/Download.js +0 -10
  250. package/dist/icons/Email.d.ts +0 -3
  251. package/dist/icons/Email.js +0 -8
  252. package/dist/icons/Information.d.ts +0 -3
  253. package/dist/icons/Information.js +0 -12
  254. package/dist/icons/List.d.ts +0 -3
  255. package/dist/icons/List.js +0 -15
  256. package/dist/icons/Microphone.d.ts +0 -5
  257. package/dist/icons/Microphone.js +0 -12
  258. package/dist/icons/Phone.d.ts +0 -3
  259. package/dist/icons/Phone.js +0 -8
  260. package/dist/icons/Reload.d.ts +0 -3
  261. package/dist/icons/Reload.js +0 -10
  262. package/dist/icons/ThumbsDown.d.ts +0 -3
  263. package/dist/icons/ThumbsDown.js +0 -11
  264. package/dist/icons/ThumbsUp.d.ts +0 -3
  265. package/dist/icons/ThumbsUp.js +0 -11
  266. package/dist/icons/Website.d.ts +0 -3
  267. package/dist/icons/Website.js +0 -8
  268. package/dist/main.js +0 -336
  269. package/dist/store/composer.d.ts +0 -17
  270. package/dist/store/composer.js +0 -98
  271. package/dist/store/index.d.ts +0 -89
  272. package/dist/store/index.js +0 -604
  273. package/dist/store/view.d.ts +0 -61
  274. package/dist/store/view.js +0 -365
  275. package/dist/translations/ar.json +0 -30
  276. package/dist/translations/de.json +0 -32
  277. package/dist/translations/en.json +0 -40
  278. package/dist/translations/es.json +0 -19
  279. package/dist/translations/fr.json +0 -40
  280. package/dist/translations/index.d.ts +0 -9
  281. package/dist/translations/index.js +0 -95
  282. package/dist/translations/it.json +0 -38
  283. package/dist/translations/pt.json +0 -19
  284. package/dist/translations/ru.json +0 -24
  285. package/dist/translations/uk.json +0 -24
  286. package/dist/typings.d.ts +0 -410
  287. package/dist/typings.js +0 -2
  288. package/dist/utils/analytics.d.ts +0 -5
  289. package/dist/utils/analytics.js +0 -37
  290. package/dist/utils/index.d.ts +0 -3
  291. package/dist/utils/index.js +0 -27
  292. package/dist/utils/storage.d.ts +0 -16
  293. package/dist/utils/storage.js +0 -129
  294. package/dist/utils/webchatEvents.d.ts +0 -2
  295. package/dist/utils/webchatEvents.js +0 -14
@@ -0,0 +1,5 @@
1
+ import { ArrowPathIcon } from '@heroicons/react/20/solid';
2
+ import { ComponentProps } from 'react';
3
+ type Props = {} & ComponentProps<typeof ArrowPathIcon>;
4
+ export declare const RestartConversation: ({ ...props }: Props) => JSX.Element;
5
+ export {};
@@ -0,0 +1,6 @@
1
+ import { Configuration } from '../contexts';
2
+ type Props = {
3
+ configuration: Configuration;
4
+ };
5
+ export declare const Webchat: ({ configuration }: Props) => JSX.Element;
6
+ export {};
@@ -0,0 +1 @@
1
+ export declare const DevTools: () => JSX.Element;
@@ -0,0 +1,2 @@
1
+ import { Configuration } from '../../contexts';
2
+ export declare const defaultConfiguration: Configuration;
@@ -0,0 +1,5 @@
1
+ import { BlockObject, MessageObject } from '../../types';
2
+ type Direction = 'incoming' | 'outgoing' | 'system';
3
+ export declare function messageInBubble(block: BlockObject, direction?: Direction): MessageObject;
4
+ export declare function splitCamelCase(text: string): string;
5
+ export {};
@@ -0,0 +1,12 @@
1
+ export * from './Avatar';
2
+ export * from './Block';
3
+ export * from './Composer';
4
+ export * from './Container';
5
+ export * from './Header';
6
+ export * from './LoadingIndicator';
7
+ export * from './Message';
8
+ export * from './MessageList';
9
+ export * from './Modal';
10
+ export * from './RestartConversation';
11
+ export * from './Webchat';
12
+ export * from './renderers';
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ import { CommonBlockProps, AudioBlock } from '../../types';
3
+ export declare const Audio: import("react").ForwardRefExoticComponent<CommonBlockProps & AudioBlock & import("react").RefAttributes<HTMLAudioElement>>;
@@ -0,0 +1,5 @@
1
+ import { ComponentProps } from 'react';
2
+ import { BubbleBlock, CommonBlockProps } from '../../types';
3
+ type Props = CommonBlockProps & BubbleBlock & ComponentProps<'div'>;
4
+ export declare const Bubble: import("react").ForwardRefExoticComponent<Omit<Props, "ref"> & import("react").RefAttributes<HTMLDivElement>>;
5
+ export {};
@@ -0,0 +1,4 @@
1
+ import { ButtonBlock, CommonBlockProps } from '../../types';
2
+ type Props = CommonBlockProps & ButtonBlock;
3
+ export declare const Button: ({ text, buttonValue, type, styles, variant, groupId, reusable, ...props }: Props) => JSX.Element;
4
+ export {};
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ import { CarouselBlock, CommonBlockProps } from '../../types';
3
+ export declare const Carousel: import("react").ForwardRefExoticComponent<CommonBlockProps & CarouselBlock & import("react").RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,5 @@
1
+ import { ComponentProps } from 'react';
2
+ import { ColumnBlock, CommonBlockProps } from '../../types';
3
+ type Props = CommonBlockProps & ColumnBlock & ComponentProps<'div'>;
4
+ export declare const Column: import("react").ForwardRefExoticComponent<Omit<Props, "ref"> & import("react").RefAttributes<HTMLDivElement>>;
5
+ export {};
@@ -0,0 +1,5 @@
1
+ import { CommonBlockProps, DropdownBlock } from '../../types';
2
+ import { ComponentProps } from 'react';
3
+ type Props = CommonBlockProps & DropdownBlock & ComponentProps<'div'>;
4
+ export declare const Dropdown: ({ styles, type, options, label, reusable }: Props) => JSX.Element;
5
+ export {};
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ import { CommonBlockProps, FileBlock } from '../../types';
3
+ export declare const File: import("react").ForwardRefExoticComponent<CommonBlockProps & FileBlock & import("react").RefAttributes<HTMLAnchorElement>>;
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ import { CommonBlockProps, ImageBlock } from '../../types';
3
+ export declare const Image: import("react").ForwardRefExoticComponent<CommonBlockProps & ImageBlock & import("react").RefAttributes<HTMLImageElement>>;
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ import { CommonBlockProps, LocationBlock } from '../../types';
3
+ export declare const Location: import("react").ForwardRefExoticComponent<CommonBlockProps & LocationBlock & import("react").RefAttributes<HTMLAnchorElement>>;
@@ -0,0 +1,5 @@
1
+ import { ComponentProps } from 'react';
2
+ import { RowBlock, CommonBlockProps } from '../../types';
3
+ type Props = CommonBlockProps & RowBlock & ComponentProps<'div'>;
4
+ export declare const Row: import("react").ForwardRefExoticComponent<Omit<Props, "ref"> & import("react").RefAttributes<HTMLDivElement>>;
5
+ export {};
@@ -0,0 +1,4 @@
1
+ import { CommonBlockProps, TextBlock } from '../../types';
2
+ type Props = CommonBlockProps & TextBlock;
3
+ export declare const Text: ({ text, type, styles }: Props) => JSX.Element;
4
+ export {};
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ import { CommonBlockProps, VideoBlock } from '../../types';
3
+ export declare const Video: import("react").ForwardRefExoticComponent<CommonBlockProps & VideoBlock & import("react").RefAttributes<HTMLVideoElement>>;
@@ -0,0 +1,2 @@
1
+ import { Renderers } from '../../contexts';
2
+ export declare const renderers: Renderers;
@@ -0,0 +1,8 @@
1
+ /// <reference types="react" />
2
+ type ComposerContextValue = {
3
+ value: string;
4
+ setValue: (value: string) => void;
5
+ };
6
+ export declare const ComposerContext: import("react").Context<ComposerContextValue | null>;
7
+ export declare function useComposerContext(): ComposerContextValue;
8
+ export {};
@@ -0,0 +1,8 @@
1
+ import { Dispatch, SetStateAction } from 'react';
2
+ type MessageContextVaue = {
3
+ isLoading: string[];
4
+ setIsLoading: Dispatch<SetStateAction<string[]>>;
5
+ };
6
+ export declare const MessageContext: import("react").Context<MessageContextVaue | null>;
7
+ export declare function useMessageContext(): MessageContextVaue;
8
+ export {};
@@ -0,0 +1,14 @@
1
+ import { ReactNode } from 'react';
2
+ type ModalContextVaue = {
3
+ open: boolean;
4
+ showModal: (props: {
5
+ title: string;
6
+ content: ReactNode;
7
+ }) => void;
8
+ hideModal: () => void;
9
+ title: string;
10
+ content: ReactNode | null;
11
+ };
12
+ export declare const ModalContext: import("react").Context<ModalContextVaue | null>;
13
+ export declare function useModalContext(): ModalContextVaue;
14
+ export {};
@@ -0,0 +1,56 @@
1
+ import { CSSProperties, FC, ReactNode } from 'react';
2
+ import type { BlockObject, BlockStyles, MessageObject } from '../types';
3
+ import { EventEmitter, Events } from '../Utils';
4
+ import { Theme } from '../schemas';
5
+ import { type WebchatClient } from '../client';
6
+ export type StyleOptions = {
7
+ className?: string;
8
+ style?: CSSProperties;
9
+ };
10
+ type DescriptionItem = {
11
+ title: string;
12
+ link?: string;
13
+ };
14
+ export type Configuration = {
15
+ composerPlaceholder?: string;
16
+ botName?: string;
17
+ botAvatar?: string;
18
+ botDescription?: string;
19
+ website?: DescriptionItem;
20
+ email?: DescriptionItem;
21
+ phone?: DescriptionItem;
22
+ privacyPolicy?: DescriptionItem;
23
+ termsOfService?: DescriptionItem;
24
+ };
25
+ export type Renderers<P extends BlockObject = BlockObject> = {
26
+ [T in P['type']]: FC<Extract<P, {
27
+ type: T;
28
+ }> & {
29
+ styles: BlockStyles;
30
+ }>;
31
+ };
32
+ export type ModalProps = {
33
+ title: string | null;
34
+ content: ReactNode | null;
35
+ };
36
+ type ContextVaue = {
37
+ theme: Theme;
38
+ renderers: Renderers;
39
+ messages: MessageObject[];
40
+ eventEmitter: EventEmitter<Events>;
41
+ configuration: Configuration;
42
+ setConfiguration: React.Dispatch<React.SetStateAction<Configuration>>;
43
+ state: {
44
+ disableComposer: boolean;
45
+ };
46
+ client: {
47
+ on: WebchatClient['on'];
48
+ sendMessage: WebchatClient['sendMessage'];
49
+ restartConversation: () => void;
50
+ };
51
+ setState: (state: Partial<ContextVaue['state']>) => void;
52
+ setTheme: (styles: Partial<Theme>) => void;
53
+ };
54
+ export declare const WebchatContext: import("react").Context<ContextVaue | null>;
55
+ export declare function useWebchatContext(): ContextVaue;
56
+ export {};
@@ -0,0 +1,4 @@
1
+ export * from './ComposerContext';
2
+ export * from './MessageContext';
3
+ export * from './ModalContext';
4
+ export * from './WebchatContext';
@@ -0,0 +1,3 @@
1
+ export * from './useImageSize';
2
+ export * from './useWebchatStore';
3
+ export * from './useRefresh.ts';
@@ -0,0 +1,2 @@
1
+ import { Options, UseImageSizeResult } from '../types';
2
+ export declare const useImageSize: (url: string, options?: Options) => UseImageSizeResult;
@@ -0,0 +1,10 @@
1
+ export declare const defaultGetRefreshTime: (expiresAt: Date) => number;
2
+ /**
3
+ * Utility hooks to force a state fresh based on a date
4
+ * @example
5
+ * const [onRefresh, setDate] = useDateRefresh()
6
+ * useEffect(() => {}, [onRefresh])
7
+ * setDate(futureDate) // The refresh function will trigger when the date passes
8
+ * @returns value to observe for refreshing and a function that set the refresh date
9
+ */
10
+ export declare const useRefresh: (getRefreshTimeInMs?: (expiresAt: Date) => number) => [number, (date: Date) => void];
@@ -0,0 +1,30 @@
1
+ import { UserCredentials } from '@botpress/messaging-socket';
2
+ type WebchatState = {
3
+ messageHistory: {
4
+ [key: string]: string[];
5
+ };
6
+ user?: UserCredentials;
7
+ conversationId?: string;
8
+ addMessageToHistory: (props: {
9
+ userId: string;
10
+ message: string;
11
+ }) => void;
12
+ setUser: (userId?: UserCredentials) => void;
13
+ setConversationId: (conversationId?: string) => void;
14
+ };
15
+ export declare const useWebchatStore: import("zustand").UseBoundStore<Omit<Omit<import("zustand").StoreApi<WebchatState>, "setState"> & {
16
+ setState<A extends string | {
17
+ type: unknown;
18
+ }>(partial: WebchatState | Partial<WebchatState> | ((state: WebchatState) => WebchatState | Partial<WebchatState>), replace?: boolean | undefined, action?: A | undefined): void;
19
+ }, "persist"> & {
20
+ persist: {
21
+ setOptions: (options: Partial<import("zustand/middleware").PersistOptions<WebchatState, WebchatState>>) => void;
22
+ clearStorage: () => void;
23
+ rehydrate: () => void | Promise<void>;
24
+ hasHydrated: () => boolean;
25
+ onHydrate: (fn: (state: WebchatState) => void) => () => void;
26
+ onFinishHydration: (fn: (state: WebchatState) => void) => () => void;
27
+ getOptions: () => Partial<import("zustand/middleware").PersistOptions<WebchatState, WebchatState>>;
28
+ };
29
+ }>;
30
+ export {};
package/dist/index.d.ts CHANGED
@@ -1,17 +1,3 @@
1
- import React from 'react';
2
- import { RootStore } from './store';
3
- import { Config } from './typings';
4
- interface State {
5
- store: RootStore;
6
- }
7
- interface Props {
8
- config?: Config;
9
- fullscreen?: boolean;
10
- }
11
- export declare class ExposedWebChat extends React.Component<Props, State> {
12
- constructor(props: Props);
13
- render(): JSX.Element;
14
- }
15
- export declare const Embedded: (props: Props) => ExposedWebChat;
16
- export declare const Fullscreen: (props: Props) => ExposedWebChat;
17
- export * from './typings';
1
+ export * from './components';
2
+ export * from './providers';
3
+ export * from './types';