@botonic/react 0.24.0-alpha.2 → 0.24.0-alpha.3

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 (304) hide show
  1. package/lib/cjs/webchat/trigger-button/index.js +2 -3
  2. package/lib/cjs/webchat/trigger-button/index.js.map +1 -1
  3. package/package.json +1 -1
  4. package/src/webchat/trigger-button/index.tsx +5 -10
  5. package/lib/esm/app.d.ts +0 -2
  6. package/lib/esm/app.js +0 -6
  7. package/lib/esm/app.js.map +0 -1
  8. package/lib/esm/assets/index-types.d.ts +0 -4
  9. package/lib/esm/assets/index-types.js +0 -2
  10. package/lib/esm/assets/index-types.js.map +0 -1
  11. package/lib/esm/botonic-tester.d.ts +0 -18
  12. package/lib/esm/botonic-tester.js +0 -62
  13. package/lib/esm/botonic-tester.js.map +0 -1
  14. package/lib/esm/components/audio.d.ts +0 -8
  15. package/lib/esm/components/audio.js +0 -18
  16. package/lib/esm/components/audio.js.map +0 -1
  17. package/lib/esm/components/button.d.ts +0 -15
  18. package/lib/esm/components/button.js +0 -140
  19. package/lib/esm/components/button.js.map +0 -1
  20. package/lib/esm/components/buttons-disabler.d.ts +0 -24
  21. package/lib/esm/components/buttons-disabler.js +0 -84
  22. package/lib/esm/components/buttons-disabler.js.map +0 -1
  23. package/lib/esm/components/carousel.d.ts +0 -10
  24. package/lib/esm/components/carousel.js +0 -102
  25. package/lib/esm/components/carousel.js.map +0 -1
  26. package/lib/esm/components/components.d.ts +0 -12
  27. package/lib/esm/components/components.js +0 -17
  28. package/lib/esm/components/components.js.map +0 -1
  29. package/lib/esm/components/custom-message.d.ts +0 -12
  30. package/lib/esm/components/custom-message.js +0 -55
  31. package/lib/esm/components/custom-message.js.map +0 -1
  32. package/lib/esm/components/document.d.ts +0 -8
  33. package/lib/esm/components/document.js +0 -42
  34. package/lib/esm/components/document.js.map +0 -1
  35. package/lib/esm/components/element.d.ts +0 -4
  36. package/lib/esm/components/element.js +0 -51
  37. package/lib/esm/components/element.js.map +0 -1
  38. package/lib/esm/components/handoff.d.ts +0 -1
  39. package/lib/esm/components/handoff.js +0 -49
  40. package/lib/esm/components/handoff.js.map +0 -1
  41. package/lib/esm/components/image.d.ts +0 -8
  42. package/lib/esm/components/image.js +0 -35
  43. package/lib/esm/components/image.js.map +0 -1
  44. package/lib/esm/components/index-types.d.ts +0 -189
  45. package/lib/esm/components/index-types.js +0 -16
  46. package/lib/esm/components/index-types.js.map +0 -1
  47. package/lib/esm/components/index.d.ts +0 -23
  48. package/lib/esm/components/index.js +0 -24
  49. package/lib/esm/components/index.js.map +0 -1
  50. package/lib/esm/components/location.d.ts +0 -11
  51. package/lib/esm/components/location.js +0 -27
  52. package/lib/esm/components/location.js.map +0 -1
  53. package/lib/esm/components/markdown.d.ts +0 -7
  54. package/lib/esm/components/markdown.js +0 -152
  55. package/lib/esm/components/markdown.js.map +0 -1
  56. package/lib/esm/components/message-template.d.ts +0 -1
  57. package/lib/esm/components/message-template.js +0 -9
  58. package/lib/esm/components/message-template.js.map +0 -1
  59. package/lib/esm/components/message.d.ts +0 -1
  60. package/lib/esm/components/message.js +0 -188
  61. package/lib/esm/components/message.js.map +0 -1
  62. package/lib/esm/components/multichannel/facebook/facebook.d.ts +0 -17
  63. package/lib/esm/components/multichannel/facebook/facebook.js +0 -43
  64. package/lib/esm/components/multichannel/facebook/facebook.js.map +0 -1
  65. package/lib/esm/components/multichannel/index-types.d.ts +0 -46
  66. package/lib/esm/components/multichannel/index-types.js +0 -2
  67. package/lib/esm/components/multichannel/index-types.js.map +0 -1
  68. package/lib/esm/components/multichannel/index.d.ts +0 -11
  69. package/lib/esm/components/multichannel/index.js +0 -12
  70. package/lib/esm/components/multichannel/index.js.map +0 -1
  71. package/lib/esm/components/multichannel/multichannel-button.d.ts +0 -1
  72. package/lib/esm/components/multichannel/multichannel-button.js +0 -71
  73. package/lib/esm/components/multichannel/multichannel-button.js.map +0 -1
  74. package/lib/esm/components/multichannel/multichannel-carousel.d.ts +0 -1
  75. package/lib/esm/components/multichannel/multichannel-carousel.js +0 -73
  76. package/lib/esm/components/multichannel/multichannel-carousel.js.map +0 -1
  77. package/lib/esm/components/multichannel/multichannel-context.d.ts +0 -11
  78. package/lib/esm/components/multichannel/multichannel-context.js +0 -12
  79. package/lib/esm/components/multichannel/multichannel-context.js.map +0 -1
  80. package/lib/esm/components/multichannel/multichannel-reply.d.ts +0 -1
  81. package/lib/esm/components/multichannel/multichannel-reply.js +0 -20
  82. package/lib/esm/components/multichannel/multichannel-reply.js.map +0 -1
  83. package/lib/esm/components/multichannel/multichannel-text.d.ts +0 -1
  84. package/lib/esm/components/multichannel/multichannel-text.js +0 -153
  85. package/lib/esm/components/multichannel/multichannel-text.js.map +0 -1
  86. package/lib/esm/components/multichannel/multichannel-utils.d.ts +0 -26
  87. package/lib/esm/components/multichannel/multichannel-utils.js +0 -69
  88. package/lib/esm/components/multichannel/multichannel-utils.js.map +0 -1
  89. package/lib/esm/components/multichannel/multichannel.d.ts +0 -1
  90. package/lib/esm/components/multichannel/multichannel.js +0 -55
  91. package/lib/esm/components/multichannel/multichannel.js.map +0 -1
  92. package/lib/esm/components/multichannel/whatsapp/markdown.d.ts +0 -1
  93. package/lib/esm/components/multichannel/whatsapp/markdown.js +0 -53
  94. package/lib/esm/components/multichannel/whatsapp/markdown.js.map +0 -1
  95. package/lib/esm/components/pic.d.ts +0 -6
  96. package/lib/esm/components/pic.js +0 -25
  97. package/lib/esm/components/pic.js.map +0 -1
  98. package/lib/esm/components/raw.d.ts +0 -9
  99. package/lib/esm/components/raw.js +0 -39
  100. package/lib/esm/components/raw.js.map +0 -1
  101. package/lib/esm/components/reply.d.ts +0 -9
  102. package/lib/esm/components/reply.js +0 -49
  103. package/lib/esm/components/reply.js.map +0 -1
  104. package/lib/esm/components/share-button.d.ts +0 -1
  105. package/lib/esm/components/share-button.js +0 -9
  106. package/lib/esm/components/share-button.js.map +0 -1
  107. package/lib/esm/components/subtitle.d.ts +0 -6
  108. package/lib/esm/components/subtitle.js +0 -19
  109. package/lib/esm/components/subtitle.js.map +0 -1
  110. package/lib/esm/components/text.d.ts +0 -8
  111. package/lib/esm/components/text.js +0 -42
  112. package/lib/esm/components/text.js.map +0 -1
  113. package/lib/esm/components/timestamps.d.ts +0 -10
  114. package/lib/esm/components/timestamps.js +0 -45
  115. package/lib/esm/components/timestamps.js.map +0 -1
  116. package/lib/esm/components/title.d.ts +0 -6
  117. package/lib/esm/components/title.js +0 -17
  118. package/lib/esm/components/title.js.map +0 -1
  119. package/lib/esm/components/video.d.ts +0 -8
  120. package/lib/esm/components/video.js +0 -26
  121. package/lib/esm/components/video.js.map +0 -1
  122. package/lib/esm/components/webchat-settings.d.ts +0 -3
  123. package/lib/esm/components/webchat-settings.js +0 -69
  124. package/lib/esm/components/webchat-settings.js.map +0 -1
  125. package/lib/esm/components/whatsapp-button-list.d.ts +0 -17
  126. package/lib/esm/components/whatsapp-button-list.js +0 -22
  127. package/lib/esm/components/whatsapp-button-list.js.map +0 -1
  128. package/lib/esm/components/whatsapp-template.d.ts +0 -1
  129. package/lib/esm/components/whatsapp-template.js +0 -20
  130. package/lib/esm/components/whatsapp-template.js.map +0 -1
  131. package/lib/esm/constants.d.ts +0 -172
  132. package/lib/esm/constants.js +0 -192
  133. package/lib/esm/constants.js.map +0 -1
  134. package/lib/esm/contexts.d.ts +0 -12
  135. package/lib/esm/contexts.js +0 -67
  136. package/lib/esm/contexts.js.map +0 -1
  137. package/lib/esm/dev-app.d.ts +0 -30
  138. package/lib/esm/dev-app.js +0 -74
  139. package/lib/esm/dev-app.js.map +0 -1
  140. package/lib/esm/index-types.d.ts +0 -128
  141. package/lib/esm/index-types.js +0 -12
  142. package/lib/esm/index-types.js.map +0 -1
  143. package/lib/esm/index.d.ts +0 -11
  144. package/lib/esm/index.js +0 -12
  145. package/lib/esm/index.js.map +0 -1
  146. package/lib/esm/message-utils.d.ts +0 -19
  147. package/lib/esm/message-utils.js +0 -41
  148. package/lib/esm/message-utils.js.map +0 -1
  149. package/lib/esm/msg-to-botonic.d.ts +0 -18
  150. package/lib/esm/msg-to-botonic.js +0 -135
  151. package/lib/esm/msg-to-botonic.js.map +0 -1
  152. package/lib/esm/node-app.d.ts +0 -12
  153. package/lib/esm/node-app.js +0 -21
  154. package/lib/esm/node-app.js.map +0 -1
  155. package/lib/esm/react-bot.d.ts +0 -8
  156. package/lib/esm/react-bot.js +0 -29
  157. package/lib/esm/react-bot.js.map +0 -1
  158. package/lib/esm/util/dom.d.ts +0 -13
  159. package/lib/esm/util/dom.js +0 -46
  160. package/lib/esm/util/dom.js.map +0 -1
  161. package/lib/esm/util/environment.d.ts +0 -6
  162. package/lib/esm/util/environment.js +0 -61
  163. package/lib/esm/util/environment.js.map +0 -1
  164. package/lib/esm/util/error-boundary.d.ts +0 -7
  165. package/lib/esm/util/error-boundary.js +0 -28
  166. package/lib/esm/util/error-boundary.js.map +0 -1
  167. package/lib/esm/util/index.d.ts +0 -8
  168. package/lib/esm/util/index.js +0 -9
  169. package/lib/esm/util/index.js.map +0 -1
  170. package/lib/esm/util/logs.d.ts +0 -2
  171. package/lib/esm/util/logs.js +0 -15
  172. package/lib/esm/util/logs.js.map +0 -1
  173. package/lib/esm/util/objects.d.ts +0 -3
  174. package/lib/esm/util/objects.js +0 -38
  175. package/lib/esm/util/objects.js.map +0 -1
  176. package/lib/esm/util/react.d.ts +0 -12
  177. package/lib/esm/util/react.js +0 -34
  178. package/lib/esm/util/react.js.map +0 -1
  179. package/lib/esm/util/regexs.d.ts +0 -2
  180. package/lib/esm/util/regexs.js +0 -18
  181. package/lib/esm/util/regexs.js.map +0 -1
  182. package/lib/esm/util/webchat.d.ts +0 -11
  183. package/lib/esm/util/webchat.js +0 -53
  184. package/lib/esm/util/webchat.js.map +0 -1
  185. package/lib/esm/webchat/actions.d.ts +0 -27
  186. package/lib/esm/webchat/actions.js +0 -29
  187. package/lib/esm/webchat/actions.js.map +0 -1
  188. package/lib/esm/webchat/components/attachment.d.ts +0 -5
  189. package/lib/esm/webchat/components/attachment.js +0 -24
  190. package/lib/esm/webchat/components/attachment.js.map +0 -1
  191. package/lib/esm/webchat/components/common.d.ts +0 -1
  192. package/lib/esm/webchat/components/common.js +0 -9
  193. package/lib/esm/webchat/components/common.js.map +0 -1
  194. package/lib/esm/webchat/components/conditional-animation.d.ts +0 -1
  195. package/lib/esm/webchat/components/conditional-animation.js +0 -12
  196. package/lib/esm/webchat/components/conditional-animation.js.map +0 -1
  197. package/lib/esm/webchat/components/emoji-picker.d.ts +0 -5
  198. package/lib/esm/webchat/components/emoji-picker.js +0 -37
  199. package/lib/esm/webchat/components/emoji-picker.js.map +0 -1
  200. package/lib/esm/webchat/components/persistent-menu.d.ts +0 -10
  201. package/lib/esm/webchat/components/persistent-menu.js +0 -39
  202. package/lib/esm/webchat/components/persistent-menu.js.map +0 -1
  203. package/lib/esm/webchat/components/send-button.d.ts +0 -3
  204. package/lib/esm/webchat/components/send-button.js +0 -14
  205. package/lib/esm/webchat/components/send-button.js.map +0 -1
  206. package/lib/esm/webchat/components/styled-scrollbar.d.ts +0 -1
  207. package/lib/esm/webchat/components/styled-scrollbar.js +0 -50
  208. package/lib/esm/webchat/components/styled-scrollbar.js.map +0 -1
  209. package/lib/esm/webchat/components/typing-indicator.d.ts +0 -1
  210. package/lib/esm/webchat/components/typing-indicator.js +0 -6
  211. package/lib/esm/webchat/components/typing-indicator.js.map +0 -1
  212. package/lib/esm/webchat/devices/device-adapter.d.ts +0 -12
  213. package/lib/esm/webchat/devices/device-adapter.js +0 -43
  214. package/lib/esm/webchat/devices/device-adapter.js.map +0 -1
  215. package/lib/esm/webchat/devices/index.d.ts +0 -11
  216. package/lib/esm/webchat/devices/index.js +0 -18
  217. package/lib/esm/webchat/devices/index.js.map +0 -1
  218. package/lib/esm/webchat/devices/scrollbar-controller.d.ts +0 -12
  219. package/lib/esm/webchat/devices/scrollbar-controller.js +0 -99
  220. package/lib/esm/webchat/devices/scrollbar-controller.js.map +0 -1
  221. package/lib/esm/webchat/devices/webchat-resizer.d.ts +0 -9
  222. package/lib/esm/webchat/devices/webchat-resizer.js +0 -43
  223. package/lib/esm/webchat/devices/webchat-resizer.js.map +0 -1
  224. package/lib/esm/webchat/header.d.ts +0 -3
  225. package/lib/esm/webchat/header.js +0 -79
  226. package/lib/esm/webchat/header.js.map +0 -1
  227. package/lib/esm/webchat/hooks/index.d.ts +0 -5
  228. package/lib/esm/webchat/hooks/index.js +0 -6
  229. package/lib/esm/webchat/hooks/index.js.map +0 -1
  230. package/lib/esm/webchat/hooks/use-component-visible.d.ts +0 -8
  231. package/lib/esm/webchat/hooks/use-component-visible.js +0 -20
  232. package/lib/esm/webchat/hooks/use-component-visible.js.map +0 -1
  233. package/lib/esm/webchat/hooks/use-component-will-mount.d.ts +0 -1
  234. package/lib/esm/webchat/hooks/use-component-will-mount.js +0 -5
  235. package/lib/esm/webchat/hooks/use-component-will-mount.js.map +0 -1
  236. package/lib/esm/webchat/hooks/use-previous.d.ts +0 -1
  237. package/lib/esm/webchat/hooks/use-previous.js +0 -9
  238. package/lib/esm/webchat/hooks/use-previous.js.map +0 -1
  239. package/lib/esm/webchat/hooks/use-typing.d.ts +0 -10
  240. package/lib/esm/webchat/hooks/use-typing.js +0 -26
  241. package/lib/esm/webchat/hooks/use-typing.js.map +0 -1
  242. package/lib/esm/webchat/hooks/use-webchat.d.ts +0 -41
  243. package/lib/esm/webchat/hooks/use-webchat.js +0 -177
  244. package/lib/esm/webchat/hooks/use-webchat.js.map +0 -1
  245. package/lib/esm/webchat/index-types.d.ts +0 -62
  246. package/lib/esm/webchat/index-types.js +0 -2
  247. package/lib/esm/webchat/index-types.js.map +0 -1
  248. package/lib/esm/webchat/index.d.ts +0 -4
  249. package/lib/esm/webchat/index.js +0 -10
  250. package/lib/esm/webchat/index.js.map +0 -1
  251. package/lib/esm/webchat/message-list/index.d.ts +0 -1
  252. package/lib/esm/webchat/message-list/index.js +0 -73
  253. package/lib/esm/webchat/message-list/index.js.map +0 -1
  254. package/lib/esm/webchat/message-list/intro-message.d.ts +0 -1
  255. package/lib/esm/webchat/message-list/intro-message.js +0 -18
  256. package/lib/esm/webchat/message-list/intro-message.js.map +0 -1
  257. package/lib/esm/webchat/message-list/scroll-button.d.ts +0 -5
  258. package/lib/esm/webchat/message-list/scroll-button.js +0 -17
  259. package/lib/esm/webchat/message-list/scroll-button.js.map +0 -1
  260. package/lib/esm/webchat/message-list/styles.d.ts +0 -4
  261. package/lib/esm/webchat/message-list/styles.js +0 -46
  262. package/lib/esm/webchat/message-list/styles.js.map +0 -1
  263. package/lib/esm/webchat/message-list/unread-messages-banner.d.ts +0 -6
  264. package/lib/esm/webchat/message-list/unread-messages-banner.js +0 -16
  265. package/lib/esm/webchat/message-list/unread-messages-banner.js.map +0 -1
  266. package/lib/esm/webchat/message-list/use-debounce.d.ts +0 -1
  267. package/lib/esm/webchat/message-list/use-debounce.js +0 -14
  268. package/lib/esm/webchat/message-list/use-debounce.js.map +0 -1
  269. package/lib/esm/webchat/messages-reducer.d.ts +0 -6
  270. package/lib/esm/webchat/messages-reducer.js +0 -82
  271. package/lib/esm/webchat/messages-reducer.js.map +0 -1
  272. package/lib/esm/webchat/replies.d.ts +0 -1
  273. package/lib/esm/webchat/replies.js +0 -38
  274. package/lib/esm/webchat/replies.js.map +0 -1
  275. package/lib/esm/webchat/session-view.d.ts +0 -1
  276. package/lib/esm/webchat/session-view.js +0 -96
  277. package/lib/esm/webchat/session-view.js.map +0 -1
  278. package/lib/esm/webchat/trigger-button/index.d.ts +0 -1
  279. package/lib/esm/webchat/trigger-button/index.js +0 -28
  280. package/lib/esm/webchat/trigger-button/index.js.map +0 -1
  281. package/lib/esm/webchat/trigger-button/styles.d.ts +0 -3
  282. package/lib/esm/webchat/trigger-button/styles.js +0 -36
  283. package/lib/esm/webchat/trigger-button/styles.js.map +0 -1
  284. package/lib/esm/webchat/use-storage-state-hook.d.ts +0 -1
  285. package/lib/esm/webchat/use-storage-state-hook.js +0 -38
  286. package/lib/esm/webchat/use-storage-state-hook.js.map +0 -1
  287. package/lib/esm/webchat/webchat-dev.d.ts +0 -7
  288. package/lib/esm/webchat/webchat-dev.js +0 -56
  289. package/lib/esm/webchat/webchat-dev.js.map +0 -1
  290. package/lib/esm/webchat/webchat-reducer.d.ts +0 -6
  291. package/lib/esm/webchat/webchat-reducer.js +0 -46
  292. package/lib/esm/webchat/webchat-reducer.js.map +0 -1
  293. package/lib/esm/webchat/webchat.d.ts +0 -3
  294. package/lib/esm/webchat/webchat.js +0 -637
  295. package/lib/esm/webchat/webchat.js.map +0 -1
  296. package/lib/esm/webchat/webview.d.ts +0 -2
  297. package/lib/esm/webchat/webview.js +0 -78
  298. package/lib/esm/webchat/webview.js.map +0 -1
  299. package/lib/esm/webchat-app.d.ts +0 -99
  300. package/lib/esm/webchat-app.js +0 -281
  301. package/lib/esm/webchat-app.js.map +0 -1
  302. package/lib/esm/webview-app.d.ts +0 -7
  303. package/lib/esm/webview-app.js +0 -95
  304. package/lib/esm/webview-app.js.map +0 -1
@@ -1,53 +0,0 @@
1
- import merge from 'lodash.merge';
2
- import UAParser from 'ua-parser-js';
3
- import { v4 as uuidv4 } from 'uuid';
4
- import { WEBCHAT } from '../constants';
5
- import { getProperty } from './objects';
6
- /**
7
- * Returns the value of a property defined in bot's theme based on WEBCHAT.CUSTOM_PROPERTIES dictionary.
8
- * It gives preference to nested defined properties (e.g.: header.style) over plain properties (e.g.: headerStyle).
9
- * If property doesn't exist, returns the defaultValue.
10
- */
11
- export const _getThemeProperty = theme => (property, defaultValue = undefined) => {
12
- for (const [k, v] of Object.entries(WEBCHAT.CUSTOM_PROPERTIES)) {
13
- if (v == property) {
14
- const nestedProperty = getProperty(theme, v);
15
- if (nestedProperty !== undefined)
16
- return nestedProperty;
17
- const plainProperty = getProperty(theme, k);
18
- if (plainProperty !== undefined)
19
- return plainProperty;
20
- return defaultValue;
21
- }
22
- }
23
- return undefined;
24
- };
25
- export const createUser = () => {
26
- const parser = new UAParser();
27
- const ua = parser.getResult();
28
- let name = `${ua.os.name} ${ua.browser.name}`;
29
- if (ua.device && ua.device.type)
30
- name = `${ua.device.type} ${name}`;
31
- return {
32
- id: uuidv4(),
33
- name,
34
- };
35
- };
36
- export const initSession = session => {
37
- if (!session)
38
- session = {};
39
- const hasUserId = session.user && session.user.id !== undefined;
40
- if (!session.user || Object.keys(session.user).length === 0 || !hasUserId)
41
- session.user = !hasUserId ? merge(session.user, createUser()) : createUser();
42
- return session;
43
- };
44
- export const shouldKeepSessionOnReload = ({ initialDevSettings, devSettings, }) => !initialDevSettings || (devSettings && devSettings.keepSessionOnReload);
45
- export const getServerErrorMessage = serverConfig => {
46
- if (!serverConfig || !serverConfig.errorMessage)
47
- return 'Connection issues';
48
- if (typeof serverConfig.errorMessage === 'function') {
49
- return serverConfig.errorMessage();
50
- }
51
- return serverConfig.errorMessage;
52
- };
53
- //# sourceMappingURL=webchat.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"webchat.js","sourceRoot":"src/","sources":["util/webchat.js"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,cAAc,CAAA;AAChC,OAAO,QAAQ,MAAM,cAAc,CAAA;AACnC,OAAO,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,MAAM,CAAA;AAEnC,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AACtC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AAEvC;;;;GAIG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAC5B,KAAK,CAAC,EAAE,CACR,CAAC,QAAQ,EAAE,YAAY,GAAG,SAAS,EAAE,EAAE;IACrC,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,iBAAiB,CAAC,EAAE;QAC9D,IAAI,CAAC,IAAI,QAAQ,EAAE;YACjB,MAAM,cAAc,GAAG,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC,CAAA;YAC5C,IAAI,cAAc,KAAK,SAAS;gBAAE,OAAO,cAAc,CAAA;YACvD,MAAM,aAAa,GAAG,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC,CAAA;YAC3C,IAAI,aAAa,KAAK,SAAS;gBAAE,OAAO,aAAa,CAAA;YACrD,OAAO,YAAY,CAAA;SACpB;KACF;IACD,OAAO,SAAS,CAAA;AAClB,CAAC,CAAA;AAEH,MAAM,CAAC,MAAM,UAAU,GAAG,GAAG,EAAE;IAC7B,MAAM,MAAM,GAAG,IAAI,QAAQ,EAAE,CAAA;IAC7B,MAAM,EAAE,GAAG,MAAM,CAAC,SAAS,EAAE,CAAA;IAC7B,IAAI,IAAI,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,CAAA;IAC7C,IAAI,EAAE,CAAC,MAAM,IAAI,EAAE,CAAC,MAAM,CAAC,IAAI;QAAE,IAAI,GAAG,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,IAAI,IAAI,EAAE,CAAA;IACnE,OAAO;QACL,EAAE,EAAE,MAAM,EAAE;QACZ,IAAI;KACL,CAAA;AACH,CAAC,CAAA;AACD,MAAM,CAAC,MAAM,WAAW,GAAG,OAAO,CAAC,EAAE;IACnC,IAAI,CAAC,OAAO;QAAE,OAAO,GAAG,EAAE,CAAA;IAC1B,MAAM,SAAS,GAAG,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,EAAE,KAAK,SAAS,CAAA;IAC/D,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,IAAI,CAAC,SAAS;QACvE,OAAO,CAAC,IAAI,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC,UAAU,EAAE,CAAA;IAC9E,OAAO,OAAO,CAAA;AAChB,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,yBAAyB,GAAG,CAAC,EACxC,kBAAkB,EAClB,WAAW,GACZ,EAAE,EAAE,CAAC,CAAC,kBAAkB,IAAI,CAAC,WAAW,IAAI,WAAW,CAAC,mBAAmB,CAAC,CAAA;AAE7E,MAAM,CAAC,MAAM,qBAAqB,GAAG,YAAY,CAAC,EAAE;IAClD,IAAI,CAAC,YAAY,IAAI,CAAC,YAAY,CAAC,YAAY;QAAE,OAAO,mBAAmB,CAAA;IAC3E,IAAI,OAAO,YAAY,CAAC,YAAY,KAAK,UAAU,EAAE;QACnD,OAAO,YAAY,CAAC,YAAY,EAAE,CAAA;KACnC;IACD,OAAO,YAAY,CAAC,YAAY,CAAA;AAClC,CAAC,CAAA"}
@@ -1,27 +0,0 @@
1
- export declare enum WebchatAction {
2
- ADD_MESSAGE = "addMessage",
3
- ADD_MESSAGE_COMPONENT = "addMessageComponent",
4
- CLEAR_MESSAGES = "clearMessages",
5
- DO_RENDER_CUSTOM_COMPONENT = "doRenderCustomComponent",
6
- RESET_UNREAD_MESSAGES = "resetUnreadMessages",
7
- SET_CURRENT_ATTACHMENT = "setCurrentAttachment",
8
- SET_ERROR = "setError",
9
- SET_LAST_MESSAGE_VISIBLE = "setlastMessageVisible",
10
- SET_ONLINE = "setOnline",
11
- TOGGLE_COVER_COMPONENT = "toggleCoverComponent",
12
- TOGGLE_EMOJI_PICKER = "toggleEmojiPicker",
13
- TOGGLE_PERSISTENT_MENU = "togglePersistentMenu",
14
- TOGGLE_WEBCHAT = "toggleWebchat",
15
- UPDATE_DEV_SETTINGS = "updateDevSettings",
16
- UPDATE_HANDOFF = "updateHandoff",
17
- UPDATE_JWT = "updateJwt",
18
- UPDATE_LAST_MESSAGE_DATE = "updateLastMessageDate",
19
- UPDATE_LAST_ROUTE_PATH = "updateLastRoutePath",
20
- UPDATE_LATEST_INPUT = "updateLatestInput",
21
- UPDATE_MESSAGE = "updateMessage",
22
- UPDATE_REPLIES = "updateReplies",
23
- UPDATE_SESSION = "updateSession",
24
- UPDATE_THEME = "updateTheme",
25
- UPDATE_TYPING = "updateTyping",
26
- UPDATE_WEBVIEW = "updateWebview"
27
- }
@@ -1,29 +0,0 @@
1
- export var WebchatAction;
2
- (function (WebchatAction) {
3
- WebchatAction["ADD_MESSAGE"] = "addMessage";
4
- WebchatAction["ADD_MESSAGE_COMPONENT"] = "addMessageComponent";
5
- WebchatAction["CLEAR_MESSAGES"] = "clearMessages";
6
- WebchatAction["DO_RENDER_CUSTOM_COMPONENT"] = "doRenderCustomComponent";
7
- WebchatAction["RESET_UNREAD_MESSAGES"] = "resetUnreadMessages";
8
- WebchatAction["SET_CURRENT_ATTACHMENT"] = "setCurrentAttachment";
9
- WebchatAction["SET_ERROR"] = "setError";
10
- WebchatAction["SET_LAST_MESSAGE_VISIBLE"] = "setlastMessageVisible";
11
- WebchatAction["SET_ONLINE"] = "setOnline";
12
- WebchatAction["TOGGLE_COVER_COMPONENT"] = "toggleCoverComponent";
13
- WebchatAction["TOGGLE_EMOJI_PICKER"] = "toggleEmojiPicker";
14
- WebchatAction["TOGGLE_PERSISTENT_MENU"] = "togglePersistentMenu";
15
- WebchatAction["TOGGLE_WEBCHAT"] = "toggleWebchat";
16
- WebchatAction["UPDATE_DEV_SETTINGS"] = "updateDevSettings";
17
- WebchatAction["UPDATE_HANDOFF"] = "updateHandoff";
18
- WebchatAction["UPDATE_JWT"] = "updateJwt";
19
- WebchatAction["UPDATE_LAST_MESSAGE_DATE"] = "updateLastMessageDate";
20
- WebchatAction["UPDATE_LAST_ROUTE_PATH"] = "updateLastRoutePath";
21
- WebchatAction["UPDATE_LATEST_INPUT"] = "updateLatestInput";
22
- WebchatAction["UPDATE_MESSAGE"] = "updateMessage";
23
- WebchatAction["UPDATE_REPLIES"] = "updateReplies";
24
- WebchatAction["UPDATE_SESSION"] = "updateSession";
25
- WebchatAction["UPDATE_THEME"] = "updateTheme";
26
- WebchatAction["UPDATE_TYPING"] = "updateTyping";
27
- WebchatAction["UPDATE_WEBVIEW"] = "updateWebview";
28
- })(WebchatAction || (WebchatAction = {}));
29
- //# sourceMappingURL=actions.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"actions.js","sourceRoot":"src/","sources":["webchat/actions.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,aA0BX;AA1BD,WAAY,aAAa;IACvB,2CAA0B,CAAA;IAC1B,8DAA6C,CAAA;IAC7C,iDAAgC,CAAA;IAChC,uEAAsD,CAAA;IACtD,8DAA6C,CAAA;IAC7C,gEAA+C,CAAA;IAC/C,uCAAsB,CAAA;IACtB,mEAAkD,CAAA;IAClD,yCAAwB,CAAA;IACxB,gEAA+C,CAAA;IAC/C,0DAAyC,CAAA;IACzC,gEAA+C,CAAA;IAC/C,iDAAgC,CAAA;IAChC,0DAAyC,CAAA;IACzC,iDAAgC,CAAA;IAChC,yCAAwB,CAAA;IACxB,mEAAkD,CAAA;IAClD,+DAA8C,CAAA;IAC9C,0DAAyC,CAAA;IACzC,iDAAgC,CAAA;IAChC,iDAAgC,CAAA;IAChC,iDAAgC,CAAA;IAChC,6CAA4B,CAAA;IAC5B,+CAA8B,CAAA;IAC9B,iDAAgC,CAAA;AAClC,CAAC,EA1BW,aAAa,KAAb,aAAa,QA0BxB"}
@@ -1,5 +0,0 @@
1
- export function Attachment({ onChange, accept, enableAttachments }: {
2
- onChange: any;
3
- accept: any;
4
- enableAttachments: any;
5
- }): JSX.Element;
@@ -1,24 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
- import React, { useContext, useRef } from 'react';
3
- import AttachmentIcon from '../../assets/attachment-icon.svg';
4
- import { ROLES, WEBCHAT } from '../../constants';
5
- import { WebchatContext } from '../../contexts';
6
- import { ConditionalAnimation } from '../components/conditional-animation';
7
- import { Icon } from './common';
8
- export const Attachment = ({ onChange, accept, enableAttachments }) => {
9
- const { getThemeProperty } = useContext(WebchatContext);
10
- const fileInputRef = useRef(null);
11
- const CustomAttachments = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.customAttachments, undefined);
12
- const isAttachmentsEnabled = () => {
13
- var _a;
14
- const hasCustomAttachments = !!CustomAttachments;
15
- return ((_a = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.enableAttachments, enableAttachments)) !== null && _a !== void 0 ? _a : hasCustomAttachments);
16
- };
17
- const attachmentsEnabled = isAttachmentsEnabled();
18
- const handleOnChange = event => {
19
- onChange(event);
20
- fileInputRef.current.value = null;
21
- };
22
- return (_jsx(_Fragment, { children: attachmentsEnabled ? (_jsx(ConditionalAnimation, { children: _jsxs("div", Object.assign({ role: ROLES.ATTACHMENT_ICON }, { children: [_jsx("label", Object.assign({ htmlFor: 'attachment', style: { marginTop: 4 } }, { children: CustomAttachments ? (_jsx(CustomAttachments, {})) : (_jsx(Icon, { src: AttachmentIcon })) })), _jsx("input", { ref: fileInputRef, type: 'file', name: 'file', id: 'attachment', style: { display: 'none' }, onChange: handleOnChange, accept: accept })] })) })) : null }));
23
- };
24
- //# sourceMappingURL=attachment.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"attachment.js","sourceRoot":"src/","sources":["webchat/components/attachment.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,OAAO,CAAA;AAEjD,OAAO,cAAc,MAAM,kCAAkC,CAAA;AAC7D,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,qCAAqC,CAAA;AAC1E,OAAO,EAAE,IAAI,EAAE,MAAM,UAAU,CAAA;AAE/B,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,iBAAiB,EAAE,EAAE,EAAE;IACpE,MAAM,EAAE,gBAAgB,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IAEvD,MAAM,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC,CAAA;IAEjC,MAAM,iBAAiB,GAAG,gBAAgB,CACxC,OAAO,CAAC,iBAAiB,CAAC,iBAAiB,EAC3C,SAAS,CACV,CAAA;IAED,MAAM,oBAAoB,GAAG,GAAG,EAAE;;QAChC,MAAM,oBAAoB,GAAG,CAAC,CAAC,iBAAiB,CAAA;QAChD,OAAO,CACL,MAAA,gBAAgB,CACd,OAAO,CAAC,iBAAiB,CAAC,iBAAiB,EAC3C,iBAAiB,CAClB,mCAAI,oBAAoB,CAC1B,CAAA;IACH,CAAC,CAAA;IACD,MAAM,kBAAkB,GAAG,oBAAoB,EAAE,CAAA;IAEjD,MAAM,cAAc,GAAG,KAAK,CAAC,EAAE;QAC7B,QAAQ,CAAC,KAAK,CAAC,CAAA;QACf,YAAY,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAA;IACnC,CAAC,CAAA;IAED,OAAO,CACL,4BACG,kBAAkB,CAAC,CAAC,CAAC,CACpB,KAAC,oBAAoB,cACnB,6BAAK,IAAI,EAAE,KAAK,CAAC,eAAe,iBAC9B,8BAAO,OAAO,EAAC,YAAY,EAAC,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC,EAAE,gBAChD,iBAAiB,CAAC,CAAC,CAAC,CACnB,KAAC,iBAAiB,KAAG,CACtB,CAAC,CAAC,CAAC,CACF,KAAC,IAAI,IAAC,GAAG,EAAE,cAAc,GAAI,CAC9B,IACK,EACR,gBACE,GAAG,EAAE,YAAY,EACjB,IAAI,EAAC,MAAM,EACX,IAAI,EAAC,MAAM,EACX,EAAE,EAAC,YAAY,EACf,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,EAC1B,QAAQ,EAAE,cAAc,EACxB,MAAM,EAAE,MAAM,GACd,KACE,GACe,CACxB,CAAC,CAAC,CAAC,IAAI,GACP,CACJ,CAAA;AACH,CAAC,CAAA"}
@@ -1 +0,0 @@
1
- export function Icon(props: any): JSX.Element;
@@ -1,9 +0,0 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import React from 'react';
3
- import styled from 'styled-components';
4
- import { resolveImage } from '../../util/environment';
5
- const PointerImage = styled.img `
6
- cursor: pointer;
7
- `;
8
- export const Icon = props => _jsx(PointerImage, { src: resolveImage(props.src) });
9
- //# sourceMappingURL=common.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"common.js","sourceRoot":"src/","sources":["webchat/components/common.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAA;AAErD,MAAM,YAAY,GAAG,MAAM,CAAC,GAAG,CAAA;;CAE9B,CAAA;AACD,MAAM,CAAC,MAAM,IAAI,GAAG,KAAK,CAAC,EAAE,CAAC,KAAC,YAAY,IAAC,GAAG,EAAE,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,GAAI,CAAA"}
@@ -1 +0,0 @@
1
- export function ConditionalAnimation(props: any): JSX.Element;
@@ -1,12 +0,0 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { motion } from 'framer-motion';
3
- import React, { useContext } from 'react';
4
- import { WEBCHAT } from '../../constants';
5
- import { WebchatContext } from '../../contexts';
6
- import { ConditionalWrapper } from '../../util/react';
7
- export const ConditionalAnimation = props => {
8
- const { getThemeProperty } = useContext(WebchatContext);
9
- const animationsEnabled = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.enableAnimations, props.enableAnimations !== undefined ? props.enableAnimations : true);
10
- return (_jsx(ConditionalWrapper, Object.assign({ condition: animationsEnabled, wrapper: children => (_jsx(motion.div, Object.assign({ whileHover: { scale: 1.2 } }, { children: children }))) }, { children: props.children })));
11
- };
12
- //# sourceMappingURL=conditional-animation.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"conditional-animation.js","sourceRoot":"src/","sources":["webchat/components/conditional-animation.jsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAA;AACtC,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAEzC,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAA;AAErD,MAAM,CAAC,MAAM,oBAAoB,GAAG,KAAK,CAAC,EAAE;IAC1C,MAAM,EAAE,gBAAgB,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IAEvD,MAAM,iBAAiB,GAAG,gBAAgB,CACxC,OAAO,CAAC,iBAAiB,CAAC,gBAAgB,EAC1C,KAAK,CAAC,gBAAgB,KAAK,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CACrE,CAAA;IACD,OAAO,CACL,KAAC,kBAAkB,kBACjB,SAAS,EAAE,iBAAiB,EAC5B,OAAO,EAAE,QAAQ,CAAC,EAAE,CAAC,CACnB,KAAC,MAAM,CAAC,GAAG,kBAAC,UAAU,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,gBAAG,QAAQ,IAAc,CAChE,gBAEA,KAAK,CAAC,QAAQ,IACI,CACtB,CAAA;AACH,CAAC,CAAA"}
@@ -1,5 +0,0 @@
1
- export function EmojiPicker({ enableEmojiPicker, onClick }: {
2
- enableEmojiPicker: any;
3
- onClick: any;
4
- }): JSX.Element;
5
- export function OpenedEmojiPicker(props: any): JSX.Element;
@@ -1,37 +0,0 @@
1
- import { jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
2
- import Picker from 'emoji-picker-react';
3
- import React, { useContext } from 'react';
4
- import styled from 'styled-components';
5
- import LogoEmoji from '../../assets/emojiButton.svg';
6
- import { ROLES, WEBCHAT } from '../../constants';
7
- import { WebchatContext } from '../../contexts';
8
- import { ConditionalAnimation } from '../components/conditional-animation';
9
- import { useComponentVisible } from '../hooks';
10
- import { Icon } from './common';
11
- export const EmojiPicker = ({ enableEmojiPicker, onClick }) => {
12
- const { getThemeProperty } = useContext(WebchatContext);
13
- const CustomEmojiPicker = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.customEmojiPicker, undefined);
14
- const isEmojiPickerEnabled = () => {
15
- var _a;
16
- const hasCustomEmojiPicker = !!CustomEmojiPicker;
17
- return ((_a = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.enableEmojiPicker, enableEmojiPicker)) !== null && _a !== void 0 ? _a : hasCustomEmojiPicker);
18
- };
19
- const emojiPickerEnabled = isEmojiPickerEnabled();
20
- const handleClick = event => {
21
- onClick();
22
- event.stopPropagation();
23
- };
24
- return (_jsx(_Fragment, { children: emojiPickerEnabled ? (_jsx(ConditionalAnimation, { children: _jsx("div", Object.assign({ role: ROLES.EMOJI_PICKER_ICON, onClick: handleClick }, { children: CustomEmojiPicker ? (_jsx(CustomEmojiPicker, {})) : (_jsx(Icon, { src: LogoEmoji })) })) })) : null }));
25
- };
26
- const Container = styled.div `
27
- display: flex;
28
- justify-content: flex-end;
29
- position: absolute;
30
- right: 3px;
31
- top: -324px;
32
- `;
33
- export const OpenedEmojiPicker = props => {
34
- const { ref, isComponentVisible } = useComponentVisible(true, props.onClick);
35
- return (_jsx("div", Object.assign({ ref: ref }, { children: isComponentVisible && (_jsx(Container, Object.assign({ role: ROLES.EMOJI_PICKER }, { children: _jsx(Picker, { width: '100%', height: '19rem', previewConfig: { showPreview: false }, onEmojiClick: props.onEmojiClick, disableAutoFocus: true }) }))) })));
36
- };
37
- //# sourceMappingURL=emoji-picker.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"emoji-picker.js","sourceRoot":"src/","sources":["webchat/components/emoji-picker.jsx"],"names":[],"mappings":";AAAA,OAAO,MAAM,MAAM,oBAAoB,CAAA;AACvC,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AACzC,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,SAAS,MAAM,8BAA8B,CAAA;AACpD,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,qCAAqC,CAAA;AAC1E,OAAO,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAA;AAC9C,OAAO,EAAE,IAAI,EAAE,MAAM,UAAU,CAAA;AAE/B,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,EAAE,iBAAiB,EAAE,OAAO,EAAE,EAAE,EAAE;IAC5D,MAAM,EAAE,gBAAgB,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IAEvD,MAAM,iBAAiB,GAAG,gBAAgB,CACxC,OAAO,CAAC,iBAAiB,CAAC,iBAAiB,EAC3C,SAAS,CACV,CAAA;IAED,MAAM,oBAAoB,GAAG,GAAG,EAAE;;QAChC,MAAM,oBAAoB,GAAG,CAAC,CAAC,iBAAiB,CAAA;QAChD,OAAO,CACL,MAAA,gBAAgB,CACd,OAAO,CAAC,iBAAiB,CAAC,iBAAiB,EAC3C,iBAAiB,CAClB,mCAAI,oBAAoB,CAC1B,CAAA;IACH,CAAC,CAAA;IACD,MAAM,kBAAkB,GAAG,oBAAoB,EAAE,CAAA;IAEjD,MAAM,WAAW,GAAG,KAAK,CAAC,EAAE;QAC1B,OAAO,EAAE,CAAA;QACT,KAAK,CAAC,eAAe,EAAE,CAAA;IACzB,CAAC,CAAA;IAED,OAAO,CACL,4BACG,kBAAkB,CAAC,CAAC,CAAC,CACpB,KAAC,oBAAoB,cACnB,4BAAK,IAAI,EAAE,KAAK,CAAC,iBAAiB,EAAE,OAAO,EAAE,WAAW,gBACrD,iBAAiB,CAAC,CAAC,CAAC,CACnB,KAAC,iBAAiB,KAAG,CACtB,CAAC,CAAC,CAAC,CACF,KAAC,IAAI,IAAC,GAAG,EAAE,SAAS,GAAI,CACzB,IACG,GACe,CACxB,CAAC,CAAC,CAAC,IAAI,GACP,CACJ,CAAA;AACH,CAAC,CAAA;AAED,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;;CAM3B,CAAA;AAED,MAAM,CAAC,MAAM,iBAAiB,GAAG,KAAK,CAAC,EAAE;IACvC,MAAM,EAAE,GAAG,EAAE,kBAAkB,EAAE,GAAG,mBAAmB,CAAC,IAAI,EAAE,KAAK,CAAC,OAAO,CAAC,CAAA;IAC5E,OAAO,CACL,4BAAK,GAAG,EAAE,GAAG,gBACV,kBAAkB,IAAI,CACrB,KAAC,SAAS,kBAAC,IAAI,EAAE,KAAK,CAAC,YAAY,gBACjC,KAAC,MAAM,IACL,KAAK,EAAC,MAAM,EACZ,MAAM,EAAC,OAAO,EACd,aAAa,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,EACrC,YAAY,EAAE,KAAK,CAAC,YAAY,EAChC,gBAAgB,EAAE,IAAI,GACtB,IACQ,CACb,IACG,CACP,CAAA;AACH,CAAC,CAAA"}
@@ -1,10 +0,0 @@
1
- export function OpenedPersistentMenu({ onClick, options, borderRadius }: {
2
- onClick: any;
3
- options: any;
4
- borderRadius: any;
5
- }): JSX.Element;
6
- export function PersistentMenu({ onClick, persistentMenu }: {
7
- onClick: any;
8
- persistentMenu: any;
9
- }): JSX.Element;
10
- export default OpenedPersistentMenu;
@@ -1,39 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
- import React, { useContext } from 'react';
3
- import styled from 'styled-components';
4
- import LogoMenu from '../../assets/menuButton.svg';
5
- import { Button } from '../../components/button';
6
- import { ROLES, WEBCHAT } from '../../constants';
7
- import { WebchatContext } from '../../contexts';
8
- import { ConditionalAnimation } from '../components/conditional-animation';
9
- import { useComponentVisible } from '../hooks';
10
- import { Icon } from './common';
11
- const ButtonsContainer = styled.div `
12
- position: absolute;
13
- z-index: 2;
14
- width: 100%;
15
- bottom: 0;
16
- text-align: center;
17
- `;
18
- export const OpenedPersistentMenu = ({ onClick, options, borderRadius }) => {
19
- const { ref, isComponentVisible } = useComponentVisible(true, onClick);
20
- const { getThemeProperty } = useContext(WebchatContext);
21
- const CustomPersistentMenu = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.customPersistentMenu, undefined);
22
- let closeLabel = 'Cancel';
23
- try {
24
- closeLabel = options.filter(opt => opt.closeLabel !== undefined)[0]
25
- .closeLabel;
26
- }
27
- catch (e) { }
28
- return (_jsx("div", Object.assign({ ref: ref, role: ROLES.PERSISTENT_MENU }, { children: isComponentVisible && CustomPersistentMenu ? (_jsx(CustomPersistentMenu, { onClick: onClick, options: options })) : (_jsxs(ButtonsContainer, { children: [Object.values(options).map((e, i) => {
29
- return (e.label && (_jsx(Button, Object.assign({ onClick: onClick, url: e.url, target: e.target, webview: e.webview, payload: e.payload }, { children: e.label }), i)));
30
- }), _jsx(Button, Object.assign({ onClick: onClick, bottomRadius: borderRadius }, { children: closeLabel }))] })) })));
31
- };
32
- export const PersistentMenu = ({ onClick, persistentMenu }) => {
33
- const { getThemeProperty } = useContext(WebchatContext);
34
- const persistentMenuOptions = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.persistentMenu, persistentMenu);
35
- const CustomMenuButton = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.customMenuButton, undefined);
36
- return (_jsx(_Fragment, { children: persistentMenuOptions ? (_jsx(ConditionalAnimation, { children: _jsx("div", Object.assign({ role: ROLES.PERSISTENT_MENU_ICON, onClick: onClick }, { children: CustomMenuButton ? _jsx(CustomMenuButton, {}) : _jsx(Icon, { src: LogoMenu }) })) })) : null }));
37
- };
38
- export default OpenedPersistentMenu;
39
- //# sourceMappingURL=persistent-menu.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"persistent-menu.js","sourceRoot":"src/","sources":["webchat/components/persistent-menu.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AACzC,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,QAAQ,MAAM,6BAA6B,CAAA;AAClD,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAChD,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,qCAAqC,CAAA;AAC1E,OAAO,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAA;AAC9C,OAAO,EAAE,IAAI,EAAE,MAAM,UAAU,CAAA;AAE/B,MAAM,gBAAgB,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;;CAMlC,CAAA;AAED,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,EAAE,EAAE;IACzE,MAAM,EAAE,GAAG,EAAE,kBAAkB,EAAE,GAAG,mBAAmB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;IACtE,MAAM,EAAE,gBAAgB,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IACvD,MAAM,oBAAoB,GAAG,gBAAgB,CAC3C,OAAO,CAAC,iBAAiB,CAAC,oBAAoB,EAC9C,SAAS,CACV,CAAA;IACD,IAAI,UAAU,GAAG,QAAQ,CAAA;IACzB,IAAI;QACF,UAAU,GAAG,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,UAAU,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC;aAChE,UAAU,CAAA;KACd;IAAC,OAAO,CAAC,EAAE,GAAE;IACd,OAAO,CACL,4BAAK,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,CAAC,eAAe,gBACvC,kBAAkB,IAAI,oBAAoB,CAAC,CAAC,CAAC,CAC5C,KAAC,oBAAoB,IAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,GAAI,CAC7D,CAAC,CAAC,CAAC,CACF,MAAC,gBAAgB,eACd,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;oBACnC,OAAO,CACL,CAAC,CAAC,KAAK,IAAI,CACT,KAAC,MAAM,kBACL,OAAO,EAAE,OAAO,EAChB,GAAG,EAAE,CAAC,CAAC,GAAG,EACV,MAAM,EAAE,CAAC,CAAC,MAAM,EAChB,OAAO,EAAE,CAAC,CAAC,OAAO,EAClB,OAAO,EAAE,CAAC,CAAC,OAAO,gBAGjB,CAAC,CAAC,KAAK,KAFH,CAAC,CAGC,CACV,CACF,CAAA;gBACH,CAAC,CAAC,EACF,KAAC,MAAM,kBAAC,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,YAAY,gBACjD,UAAU,IACJ,IACQ,CACpB,IACG,CACP,CAAA;AACH,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,EAAE,OAAO,EAAE,cAAc,EAAE,EAAE,EAAE;IAC5D,MAAM,EAAE,gBAAgB,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IAEvD,MAAM,qBAAqB,GAAG,gBAAgB,CAC5C,OAAO,CAAC,iBAAiB,CAAC,cAAc,EACxC,cAAc,CACf,CAAA;IAED,MAAM,gBAAgB,GAAG,gBAAgB,CACvC,OAAO,CAAC,iBAAiB,CAAC,gBAAgB,EAC1C,SAAS,CACV,CAAA;IAED,OAAO,CACL,4BACG,qBAAqB,CAAC,CAAC,CAAC,CACvB,KAAC,oBAAoB,cACnB,4BAAK,IAAI,EAAE,KAAK,CAAC,oBAAoB,EAAE,OAAO,EAAE,OAAO,gBACpD,gBAAgB,CAAC,CAAC,CAAC,KAAC,gBAAgB,KAAG,CAAC,CAAC,CAAC,KAAC,IAAI,IAAC,GAAG,EAAE,QAAQ,GAAI,IAC9D,GACe,CACxB,CAAC,CAAC,CAAC,IAAI,GACP,CACJ,CAAA;AACH,CAAC,CAAA;AAED,eAAe,oBAAoB,CAAA"}
@@ -1,3 +0,0 @@
1
- export function SendButton({ onClick }: {
2
- onClick: any;
3
- }): JSX.Element;
@@ -1,14 +0,0 @@
1
- import { jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
2
- import React, { useContext } from 'react';
3
- import SendButtonIcon from '../../assets/send-button.svg';
4
- import { ROLES, WEBCHAT } from '../../constants';
5
- import { WebchatContext } from '../../contexts';
6
- import { ConditionalAnimation } from '../components/conditional-animation';
7
- import { Icon } from './common';
8
- export const SendButton = ({ onClick }) => {
9
- const { getThemeProperty } = useContext(WebchatContext);
10
- const sendButtonEnabled = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.enableSendButton, true);
11
- const CustomSendButton = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.customSendButton, undefined);
12
- return (_jsx(_Fragment, { children: sendButtonEnabled || CustomSendButton ? (_jsx(ConditionalAnimation, { children: _jsx("div", Object.assign({ onClick: onClick, role: ROLES.SEND_BUTTON_ICON }, { children: CustomSendButton ? (_jsx(CustomSendButton, {})) : (_jsx(Icon, { src: SendButtonIcon })) })) })) : null }));
13
- };
14
- //# sourceMappingURL=send-button.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"send-button.js","sourceRoot":"src/","sources":["webchat/components/send-button.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAEzC,OAAO,cAAc,MAAM,8BAA8B,CAAA;AACzD,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,qCAAqC,CAAA;AAC1E,OAAO,EAAE,IAAI,EAAE,MAAM,UAAU,CAAA;AAE/B,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE;IACxC,MAAM,EAAE,gBAAgB,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IAEvD,MAAM,iBAAiB,GAAG,gBAAgB,CACxC,OAAO,CAAC,iBAAiB,CAAC,gBAAgB,EAC1C,IAAI,CACL,CAAA;IAED,MAAM,gBAAgB,GAAG,gBAAgB,CACvC,OAAO,CAAC,iBAAiB,CAAC,gBAAgB,EAC1C,SAAS,CACV,CAAA;IAED,OAAO,CACL,4BACG,iBAAiB,IAAI,gBAAgB,CAAC,CAAC,CAAC,CACvC,KAAC,oBAAoB,cACnB,4BAAK,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,CAAC,gBAAgB,gBAChD,gBAAgB,CAAC,CAAC,CAAC,CAClB,KAAC,gBAAgB,KAAG,CACrB,CAAC,CAAC,CAAC,CACF,KAAC,IAAI,IAAC,GAAG,EAAE,cAAc,GAAI,CAC9B,IACG,GACe,CACxB,CAAC,CAAC,CAAC,IAAI,GACP,CACJ,CAAA;AACH,CAAC,CAAA"}
@@ -1 +0,0 @@
1
- export const StyledScrollbar: any;
@@ -1,50 +0,0 @@
1
- import 'simplebar/dist/simplebar.css';
2
- import './styled-scrollbar.scss';
3
- import SimpleBar from 'simplebar-react';
4
- import styled, { css } from 'styled-components';
5
- import { COLORS } from '../../constants';
6
- export const StyledScrollbar = styled(SimpleBar) `
7
- ${props => props.isMessagesContainer &&
8
- css `
9
- display: flex;
10
- flex-direction: column;
11
- overflow-y: auto;
12
- overflow-x: hidden;
13
- `}
14
- & .simplebar-scrollbar::before {
15
- background-color: ${({ scrollbar }) => scrollbar && scrollbar.thumb && scrollbar.thumb.color
16
- ? scrollbar.thumb.color
17
- : `${COLORS.GRAY}`};
18
- background-image: ${({ scrollbar }) => scrollbar && scrollbar.thumb && scrollbar.thumb.bgcolor
19
- ? scrollbar.thumb.bgcolor
20
- : `${COLORS.GRAY}`};
21
- border-radius: ${({ scrollbar }) => scrollbar && scrollbar.thumb && scrollbar.thumb.border
22
- ? scrollbar.thumb.border
23
- : '20px'};
24
- }
25
- & .simplebar-track .simplebar-scrollbar.simplebar-visible::before {
26
- opacity: ${({ scrollbar }) => scrollbar && !scrollbar.enable
27
- ? '0'
28
- : scrollbar && scrollbar.thumb && scrollbar.thumb.opacity
29
- ? scrollbar.thumb.opacity
30
- : '0.75'};
31
- }
32
- & .simplebar-track {
33
- background-color: ${({ scrollbar }) => scrollbar &&
34
- scrollbar.track &&
35
- scrollbar.track.color &&
36
- !(scrollbar && !scrollbar.enable)
37
- ? scrollbar.track.color
38
- : COLORS.TRANSPARENT};
39
- background-image: ${({ scrollbar }) => scrollbar &&
40
- scrollbar.track &&
41
- scrollbar.track.bgcolor &&
42
- !(scrollbar && !scrollbar.enable)
43
- ? scrollbar.track.bgcolor
44
- : COLORS.TRANSPARENT};
45
- border-radius: ${({ scrollbar }) => scrollbar && scrollbar.track && scrollbar.track.border
46
- ? scrollbar.track.border
47
- : '20px'};
48
- }
49
- `;
50
- //# sourceMappingURL=styled-scrollbar.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"styled-scrollbar.js","sourceRoot":"src/","sources":["webchat/components/styled-scrollbar.jsx"],"names":[],"mappings":"AAAA,OAAO,8BAA8B,CAAA;AACrC,OAAO,yBAAyB,CAAA;AAEhC,OAAO,SAAS,MAAM,iBAAiB,CAAA;AACvC,OAAO,MAAM,EAAE,EAAE,GAAG,EAAE,MAAM,mBAAmB,CAAA;AAE/C,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AAExC,MAAM,CAAC,MAAM,eAAe,GAAG,MAAM,CAAC,SAAS,CAAC,CAAA;IAC5C,KAAK,CAAC,EAAE,CACR,KAAK,CAAC,mBAAmB;IACzB,GAAG,CAAA;;;;;KAKF;;wBAEmB,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,CACpC,SAAS,IAAI,SAAS,CAAC,KAAK,IAAI,SAAS,CAAC,KAAK,CAAC,KAAK;IACnD,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK;IACvB,CAAC,CAAC,GAAG,MAAM,CAAC,IAAI,EAAE;wBACF,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,CACpC,SAAS,IAAI,SAAS,CAAC,KAAK,IAAI,SAAS,CAAC,KAAK,CAAC,OAAO;IACrD,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO;IACzB,CAAC,CAAC,GAAG,MAAM,CAAC,IAAI,EAAE;qBACL,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,CACjC,SAAS,IAAI,SAAS,CAAC,KAAK,IAAI,SAAS,CAAC,KAAK,CAAC,MAAM;IACpD,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM;IACxB,CAAC,CAAC,MAAM;;;eAGD,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,CAC3B,SAAS,IAAI,CAAC,SAAS,CAAC,MAAM;IAC5B,CAAC,CAAC,GAAG;IACL,CAAC,CAAC,SAAS,IAAI,SAAS,CAAC,KAAK,IAAI,SAAS,CAAC,KAAK,CAAC,OAAO;QACzD,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO;QACzB,CAAC,CAAC,MAAM;;;wBAGQ,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,CACpC,SAAS;IACT,SAAS,CAAC,KAAK;IACf,SAAS,CAAC,KAAK,CAAC,KAAK;IACrB,CAAC,CAAC,SAAS,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;IAC/B,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK;IACvB,CAAC,CAAC,MAAM,CAAC,WAAW;wBACJ,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,CACpC,SAAS;IACT,SAAS,CAAC,KAAK;IACf,SAAS,CAAC,KAAK,CAAC,OAAO;IACvB,CAAC,CAAC,SAAS,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;IAC/B,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO;IACzB,CAAC,CAAC,MAAM,CAAC,WAAW;qBACP,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,CACjC,SAAS,IAAI,SAAS,CAAC,KAAK,IAAI,SAAS,CAAC,KAAK,CAAC,MAAM;IACpD,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM;IACxB,CAAC,CAAC,MAAM;;CAEf,CAAA"}
@@ -1 +0,0 @@
1
- export function TypingIndicator(props: any): JSX.Element;
@@ -1,6 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import './typing-indicator.scss';
3
- import React from 'react';
4
- import { COLORS, ROLES } from '../../constants';
5
- export const TypingIndicator = props => (_jsxs("div", Object.assign({ role: ROLES.TYPING_INDICATOR, className: 'typing-indicator', style: { backgroundColor: COLORS.SEASHELL_WHITE } }, { children: [_jsx("span", {}), _jsx("span", {}), _jsx("span", {})] })));
6
- //# sourceMappingURL=typing-indicator.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"typing-indicator.js","sourceRoot":"src/","sources":["webchat/components/typing-indicator.jsx"],"names":[],"mappings":";AAAA,OAAO,yBAAyB,CAAA;AAEhC,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAA;AAE/C,MAAM,CAAC,MAAM,eAAe,GAAG,KAAK,CAAC,EAAE,CAAC,CACtC,6BACE,IAAI,EAAE,KAAK,CAAC,gBAAgB,EAC5B,SAAS,EAAC,kBAAkB,EAC5B,KAAK,EAAE,EAAE,eAAe,EAAE,MAAM,CAAC,cAAc,EAAE,iBAEjD,gBAAQ,EACR,gBAAQ,EACR,gBAAQ,KACJ,CACP,CAAA"}
@@ -1,12 +0,0 @@
1
- export class DeviceAdapter {
2
- currentDevice: any;
3
- init(host: any): void;
4
- webchatResizer: WebchatResizer | undefined;
5
- scrollbarController: ScrollbarController | undefined;
6
- getCurrentDevice(): any;
7
- onFocus(host: any): void;
8
- onBlur(): void;
9
- fontSize(defaultFontSize?: number): number | "initial";
10
- }
11
- import { WebchatResizer } from './webchat-resizer';
12
- import { ScrollbarController } from './scrollbar-controller';
@@ -1,43 +0,0 @@
1
- import { scrollToBottom } from '../../util/dom';
2
- import { DEVICES } from '.';
3
- import { ScrollbarController } from './scrollbar-controller';
4
- import { WebchatResizer } from './webchat-resizer';
5
- export class DeviceAdapter {
6
- constructor() {
7
- this.currentDevice = this.getCurrentDevice();
8
- }
9
- init(host) {
10
- this.webchatResizer = new WebchatResizer(this.currentDevice, host);
11
- this.scrollbarController = new ScrollbarController(this.currentDevice, host);
12
- this.scrollbarController.handleScrollEvents();
13
- }
14
- getCurrentDevice() {
15
- // navigator.platform deprecated. Ref: (https://erikmartinjordan.com/navigator-platform-deprecated-alternative)
16
- if (navigator.userAgentData)
17
- return navigator.userAgentData.platform;
18
- return navigator.platform;
19
- }
20
- onFocus(host) {
21
- if (this.currentDevice !== DEVICES.MOBILE.IPHONE) {
22
- // scrollToBottom({ host, timeout: 800 })
23
- return;
24
- }
25
- setTimeout(() => {
26
- // Place onFocus logic to be run the last on the queue of asynchronous events to give enough time to init method to be called. Ref: https://developer.mozilla.org/en-US/docs/Web/JavaScript/EventLoop#zero_delays
27
- this.webchatResizer.onFocus(() => this.scrollbarController.handleOnTouchMoveEvents());
28
- }, 0);
29
- }
30
- onBlur() {
31
- if (this.currentDevice !== DEVICES.MOBILE.IPHONE)
32
- return;
33
- this.webchatResizer.onBlur();
34
- this.scrollbarController.handleOnTouchMoveEvents();
35
- }
36
- fontSize(defaultFontSize = 14) {
37
- if (this.currentDevice !== DEVICES.MOBILE.IPHONE)
38
- return defaultFontSize;
39
- // Disabling auto-zoom on input (iPhone devices): https://stackoverflow.com/a/25614477, https://stackoverflow.com/a/6394497
40
- return 'initial';
41
- }
42
- }
43
- //# sourceMappingURL=device-adapter.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"device-adapter.js","sourceRoot":"src/","sources":["webchat/devices/device-adapter.js"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,GAAG,CAAA;AAC3B,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAA;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAA;AAElD,MAAM,OAAO,aAAa;IACxB;QACE,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAA;IAC9C,CAAC;IAED,IAAI,CAAC,IAAI;QACP,IAAI,CAAC,cAAc,GAAG,IAAI,cAAc,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,CAAA;QAClE,IAAI,CAAC,mBAAmB,GAAG,IAAI,mBAAmB,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,CAAA;QAC5E,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,EAAE,CAAA;IAC/C,CAAC;IAED,gBAAgB;QACd,+GAA+G;QAC/G,IAAI,SAAS,CAAC,aAAa;YAAE,OAAO,SAAS,CAAC,aAAa,CAAC,QAAQ,CAAA;QACpE,OAAO,SAAS,CAAC,QAAQ,CAAA;IAC3B,CAAC;IAED,OAAO,CAAC,IAAI;QACV,IAAI,IAAI,CAAC,aAAa,KAAK,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE;YAChD,yCAAyC;YACzC,OAAM;SACP;QACD,UAAU,CAAC,GAAG,EAAE;YACd,iNAAiN;YACjN,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,GAAG,EAAE,CAC/B,IAAI,CAAC,mBAAmB,CAAC,uBAAuB,EAAE,CACnD,CAAA;QACH,CAAC,EAAE,CAAC,CAAC,CAAA;IACP,CAAC;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,aAAa,KAAK,OAAO,CAAC,MAAM,CAAC,MAAM;YAAE,OAAM;QACxD,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,CAAA;QAC5B,IAAI,CAAC,mBAAmB,CAAC,uBAAuB,EAAE,CAAA;IACpD,CAAC;IAED,QAAQ,CAAC,eAAe,GAAG,EAAE;QAC3B,IAAI,IAAI,CAAC,aAAa,KAAK,OAAO,CAAC,MAAM,CAAC,MAAM;YAAE,OAAO,eAAe,CAAA;QACxE,2HAA2H;QAC3H,OAAO,SAAS,CAAA;IAClB,CAAC;CACF"}
@@ -1,11 +0,0 @@
1
- export const DEVICES: Readonly<{
2
- MOBILE: {
3
- IPHONE: string;
4
- ANDROID: string;
5
- WEBOS: string;
6
- BLACKBERRY: string;
7
- WINDOWS_PHONE: string;
8
- };
9
- }>;
10
- export function isDevice(deviceName: any): boolean;
11
- export function isMobileDevice(): boolean;
@@ -1,18 +0,0 @@
1
- export const DEVICES = Object.freeze({
2
- MOBILE: {
3
- IPHONE: 'iPhone',
4
- ANDROID: 'Android',
5
- WEBOS: 'webOS',
6
- BLACKBERRY: 'BlackBerry',
7
- WINDOWS_PHONE: 'Windows Phone',
8
- },
9
- });
10
- export const isDevice = deviceName => {
11
- // https://stackoverflow.com/questions/19877924/what-is-the-list-of-possible-values-for-navigator-platform-as-of-today
12
- return (!!navigator.platform &&
13
- navigator.platform.toLowerCase().includes(deviceName.toLowerCase()));
14
- };
15
- export const isMobileDevice = () => {
16
- return Object.values(DEVICES.MOBILE).some(deviceName => isDevice(deviceName));
17
- };
18
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"src/","sources":["webchat/devices/index.js"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC;IACnC,MAAM,EAAE;QACN,MAAM,EAAE,QAAQ;QAChB,OAAO,EAAE,SAAS;QAClB,KAAK,EAAE,OAAO;QACd,UAAU,EAAE,YAAY;QACxB,aAAa,EAAE,eAAe;KAC/B;CACF,CAAC,CAAA;AAEF,MAAM,CAAC,MAAM,QAAQ,GAAG,UAAU,CAAC,EAAE;IACnC,sHAAsH;IACtH,OAAO,CACL,CAAC,CAAC,SAAS,CAAC,QAAQ;QACpB,SAAS,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC,CACpE,CAAA;AACH,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,cAAc,GAAG,GAAG,EAAE;IACjC,OAAO,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAA;AAC/E,CAAC,CAAA"}
@@ -1,12 +0,0 @@
1
- export class ScrollbarController {
2
- constructor(currentDevice: any, host: any);
3
- currentDevice: any;
4
- webchat: any;
5
- handleScrollEvents(): void;
6
- hasScrollbar(): boolean;
7
- handleOnMouseOverEvents(e: any): void;
8
- toggleOnMouseWheelEvents(): void;
9
- handleOnTouchMoveEvents(e: any): void;
10
- toggleOnTouchMoveEvents(): void;
11
- limitScrollBoundaries(): void;
12
- }
@@ -1,99 +0,0 @@
1
- import { getScrollableArea, getScrollableContent, getWebchatElement, } from '../../util/dom';
2
- import { DEVICES, isMobileDevice } from '.';
3
- const debounced = (delay, fn) => {
4
- let timerId;
5
- return function (...args) {
6
- if (timerId) {
7
- clearTimeout(timerId);
8
- }
9
- timerId = setTimeout(() => {
10
- fn(...args);
11
- timerId = null;
12
- }, delay);
13
- };
14
- };
15
- const stopAtScrollLimit = element => {
16
- if (element.scrollTop === 0)
17
- element.scrollTop = 1;
18
- if (element.scrollHeight - element.scrollTop === element.clientHeight)
19
- element.scrollTop -= 1;
20
- };
21
- export class ScrollbarController {
22
- constructor(currentDevice, host) {
23
- this.currentDevice = currentDevice;
24
- this.webchat = getWebchatElement(host);
25
- }
26
- handleScrollEvents() {
27
- /*
28
- It handles scroll events for Mobile/Desktop.
29
- "ontouchmove" is the phone equivalent for "onmouseover"
30
- */
31
- if (isMobileDevice()) {
32
- if (this.currentDevice !== DEVICES.MOBILE.IPHONE)
33
- return;
34
- this.limitScrollBoundaries();
35
- this.webchat.ontouchstart = e => {
36
- this.handleOnTouchMoveEvents(e);
37
- };
38
- this.webchat.ontouchmove = e => {
39
- this.handleOnTouchMoveEvents(e);
40
- };
41
- }
42
- else {
43
- this.webchat.onmouseover = e => this.handleOnMouseOverEvents(e);
44
- }
45
- }
46
- hasScrollbar() {
47
- const scrollableArea = getScrollableArea(this.webchat);
48
- const isScrollable = scrollableArea.visible.clientHeight - scrollableArea.full.clientHeight < 0;
49
- return isScrollable;
50
- }
51
- handleOnMouseOverEvents(e) {
52
- let target = e.currentTarget;
53
- while (target) {
54
- this.toggleOnMouseWheelEvents();
55
- target = target.parentNode;
56
- }
57
- }
58
- toggleOnMouseWheelEvents() {
59
- const scrollableContent = getScrollableContent(this.webchat);
60
- if (this.hasScrollbar()) {
61
- scrollableContent.onmousewheel = {};
62
- return;
63
- }
64
- scrollableContent.onmousewheel = e => e.preventDefault();
65
- }
66
- handleOnTouchMoveEvents(e) {
67
- this.toggleOnTouchMoveEvents();
68
- }
69
- toggleOnTouchMoveEvents() {
70
- if (this.hasScrollbar()) {
71
- this.webchat.ontouchmove = {};
72
- this.webchat.ontouchstart = {};
73
- return;
74
- }
75
- this.webchat.ontouchmove = e => {
76
- if (e.target === e.currentTarget)
77
- e.preventDefault();
78
- };
79
- }
80
- limitScrollBoundaries() {
81
- if (this.currentDevice !== DEVICES.MOBILE.IPHONE)
82
- return;
83
- /*
84
- It adds a bounce effect when top or bottom limits of the scrollbar are reached for iOS,
85
- as an alternative of overscroll-behavior (https://developer.mozilla.org/en-US/docs/Web/CSS/overscroll-behavior)
86
- */
87
- const frame = getScrollableArea(this.webchat).visible;
88
- const dStopAtScrollLimit = debounced(100, stopAtScrollLimit);
89
- if (frame) {
90
- if (window.addEventListener) {
91
- frame.addEventListener('scroll', () => dStopAtScrollLimit(frame), true);
92
- }
93
- else if (window.attachEvent) {
94
- frame.attachEvent('scroll', () => dStopAtScrollLimit(frame));
95
- }
96
- }
97
- }
98
- }
99
- //# sourceMappingURL=scrollbar-controller.js.map