@botonic/react 0.30.0-alpha.1 → 0.30.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 (251) hide show
  1. package/lib/cjs/components/carousel.js +6 -3
  2. package/lib/cjs/components/carousel.js.map +1 -1
  3. package/lib/cjs/constants.d.ts +0 -6
  4. package/lib/cjs/constants.js +0 -6
  5. package/lib/cjs/constants.js.map +1 -1
  6. package/lib/cjs/contexts.d.ts +1 -1
  7. package/lib/cjs/contexts.js +9 -3
  8. package/lib/cjs/contexts.js.map +1 -1
  9. package/lib/cjs/index-types.d.ts +7 -1
  10. package/lib/cjs/index-types.js +0 -5
  11. package/lib/cjs/index-types.js.map +1 -1
  12. package/lib/cjs/node-app.d.ts +0 -5
  13. package/lib/cjs/node-app.js +0 -5
  14. package/lib/cjs/node-app.js.map +1 -1
  15. package/lib/cjs/util/dom.d.ts +0 -10
  16. package/lib/cjs/util/dom.js +3 -29
  17. package/lib/cjs/util/dom.js.map +1 -1
  18. package/lib/cjs/webchat/actions.d.ts +0 -1
  19. package/lib/cjs/webchat/actions.js +0 -1
  20. package/lib/cjs/webchat/actions.js.map +1 -1
  21. package/lib/cjs/webchat/constants.d.ts +8 -0
  22. package/lib/cjs/webchat/constants.js +13 -0
  23. package/lib/cjs/webchat/constants.js.map +1 -0
  24. package/lib/cjs/webchat/header.d.ts +2 -2
  25. package/lib/cjs/webchat/header.js +14 -13
  26. package/lib/cjs/webchat/header.js.map +1 -1
  27. package/lib/cjs/webchat/hooks/index.d.ts +6 -0
  28. package/lib/cjs/webchat/hooks/index.js +13 -1
  29. package/lib/cjs/webchat/hooks/index.js.map +1 -1
  30. package/lib/cjs/webchat/hooks/use-device-adapter.d.ts +3 -0
  31. package/lib/cjs/webchat/hooks/use-device-adapter.js +46 -0
  32. package/lib/cjs/webchat/hooks/use-device-adapter.js.map +1 -0
  33. package/lib/cjs/webchat/hooks/use-scroll-to-bottom.d.ts +7 -0
  34. package/lib/cjs/webchat/hooks/use-scroll-to-bottom.js +26 -0
  35. package/lib/cjs/webchat/hooks/use-scroll-to-bottom.js.map +1 -0
  36. package/lib/cjs/webchat/hooks/use-scrollbar-controller.d.ts +6 -0
  37. package/lib/cjs/webchat/hooks/use-scrollbar-controller.js +140 -0
  38. package/lib/cjs/webchat/hooks/use-scrollbar-controller.js.map +1 -0
  39. package/lib/cjs/webchat/hooks/use-virtual-keyboard-detection.d.ts +3 -0
  40. package/lib/cjs/webchat/hooks/use-virtual-keyboard-detection.js +28 -0
  41. package/lib/cjs/webchat/hooks/use-virtual-keyboard-detection.js.map +1 -0
  42. package/lib/cjs/webchat/hooks/use-webchat-dimensions.d.ts +4 -0
  43. package/lib/cjs/webchat/hooks/use-webchat-dimensions.js +39 -0
  44. package/lib/cjs/webchat/hooks/use-webchat-dimensions.js.map +1 -0
  45. package/lib/cjs/webchat/hooks/use-webchat-resizer.d.ts +4 -0
  46. package/lib/cjs/webchat/hooks/use-webchat-resizer.js +34 -0
  47. package/lib/cjs/webchat/hooks/use-webchat-resizer.js.map +1 -0
  48. package/lib/cjs/webchat/hooks/use-webchat.d.ts +6 -1
  49. package/lib/cjs/webchat/hooks/use-webchat.js +12 -8
  50. package/lib/cjs/webchat/hooks/use-webchat.js.map +1 -1
  51. package/lib/cjs/webchat/index-types.d.ts +0 -1
  52. package/lib/cjs/webchat/message-list/index.js +4 -9
  53. package/lib/cjs/webchat/message-list/index.js.map +1 -1
  54. package/lib/cjs/webchat/message-list/scroll-button.js.map +1 -1
  55. package/lib/cjs/webchat/message-list/styles.d.ts +1 -0
  56. package/lib/cjs/webchat/message-list/styles.js +10 -1
  57. package/lib/cjs/webchat/message-list/styles.js.map +1 -1
  58. package/lib/cjs/webchat/replies.js +8 -4
  59. package/lib/cjs/webchat/replies.js.map +1 -1
  60. package/lib/cjs/webchat/typing-indicator/index.d.ts +1 -0
  61. package/lib/cjs/webchat/typing-indicator/index.js +9 -0
  62. package/lib/cjs/webchat/typing-indicator/index.js.map +1 -0
  63. package/lib/cjs/webchat/typing-indicator/styles.d.ts +6 -0
  64. package/lib/cjs/webchat/typing-indicator/styles.js +47 -0
  65. package/lib/cjs/webchat/typing-indicator/styles.js.map +1 -0
  66. package/lib/cjs/webchat/webchat-chat-area/index.d.ts +1 -0
  67. package/lib/cjs/webchat/webchat-chat-area/index.js +22 -0
  68. package/lib/cjs/webchat/webchat-chat-area/index.js.map +1 -0
  69. package/lib/cjs/webchat/webchat-chat-area/styles.d.ts +3 -0
  70. package/lib/cjs/webchat/webchat-chat-area/styles.js +13 -0
  71. package/lib/cjs/webchat/webchat-chat-area/styles.js.map +1 -0
  72. package/lib/cjs/webchat/webchat-input-panel/index.d.ts +2 -3
  73. package/lib/cjs/webchat/webchat-input-panel/index.js +4 -3
  74. package/lib/cjs/webchat/webchat-input-panel/index.js.map +1 -1
  75. package/lib/cjs/webchat/webchat-input-panel/textarea.d.ts +2 -3
  76. package/lib/cjs/webchat/webchat-input-panel/textarea.js +5 -7
  77. package/lib/cjs/webchat/webchat-input-panel/textarea.js.map +1 -1
  78. package/lib/cjs/webchat/webchat-reducer.js +0 -2
  79. package/lib/cjs/webchat/webchat-reducer.js.map +1 -1
  80. package/lib/cjs/webchat/webchat.js +18 -18
  81. package/lib/cjs/webchat/webchat.js.map +1 -1
  82. package/lib/cjs/webchat/webview.js +13 -22
  83. package/lib/cjs/webchat/webview.js.map +1 -1
  84. package/lib/cjs/webchat-app.d.ts +1 -1
  85. package/lib/cjs/webchat-app.js +3 -1
  86. package/lib/cjs/webchat-app.js.map +1 -1
  87. package/lib/cjs/webview-app.js +11 -11
  88. package/lib/cjs/webview-app.js.map +1 -1
  89. package/lib/esm/components/carousel.js +6 -3
  90. package/lib/esm/components/carousel.js.map +1 -1
  91. package/lib/esm/constants.d.ts +0 -6
  92. package/lib/esm/constants.js +0 -6
  93. package/lib/esm/constants.js.map +1 -1
  94. package/lib/esm/contexts.d.ts +1 -1
  95. package/lib/esm/contexts.js +9 -3
  96. package/lib/esm/contexts.js.map +1 -1
  97. package/lib/esm/index-types.d.ts +7 -1
  98. package/lib/esm/index-types.js +0 -5
  99. package/lib/esm/index-types.js.map +1 -1
  100. package/lib/esm/node-app.d.ts +0 -5
  101. package/lib/esm/node-app.js +0 -5
  102. package/lib/esm/node-app.js.map +1 -1
  103. package/lib/esm/util/dom.d.ts +0 -10
  104. package/lib/esm/util/dom.js +2 -25
  105. package/lib/esm/util/dom.js.map +1 -1
  106. package/lib/esm/webchat/actions.d.ts +0 -1
  107. package/lib/esm/webchat/actions.js +0 -1
  108. package/lib/esm/webchat/actions.js.map +1 -1
  109. package/lib/esm/webchat/constants.d.ts +8 -0
  110. package/lib/esm/webchat/constants.js +10 -0
  111. package/lib/esm/webchat/constants.js.map +1 -0
  112. package/lib/esm/webchat/header.d.ts +2 -2
  113. package/lib/esm/webchat/header.js +14 -12
  114. package/lib/esm/webchat/header.js.map +1 -1
  115. package/lib/esm/webchat/hooks/index.d.ts +6 -0
  116. package/lib/esm/webchat/hooks/index.js +6 -0
  117. package/lib/esm/webchat/hooks/index.js.map +1 -1
  118. package/lib/esm/webchat/hooks/use-device-adapter.d.ts +3 -0
  119. package/lib/esm/webchat/hooks/use-device-adapter.js +42 -0
  120. package/lib/esm/webchat/hooks/use-device-adapter.js.map +1 -0
  121. package/lib/esm/webchat/hooks/use-scroll-to-bottom.d.ts +7 -0
  122. package/lib/esm/webchat/hooks/use-scroll-to-bottom.js +22 -0
  123. package/lib/esm/webchat/hooks/use-scroll-to-bottom.js.map +1 -0
  124. package/lib/esm/webchat/hooks/use-scrollbar-controller.d.ts +6 -0
  125. package/lib/esm/webchat/hooks/use-scrollbar-controller.js +136 -0
  126. package/lib/esm/webchat/hooks/use-scrollbar-controller.js.map +1 -0
  127. package/lib/esm/webchat/hooks/use-virtual-keyboard-detection.d.ts +3 -0
  128. package/lib/esm/webchat/hooks/use-virtual-keyboard-detection.js +24 -0
  129. package/lib/esm/webchat/hooks/use-virtual-keyboard-detection.js.map +1 -0
  130. package/lib/esm/webchat/hooks/use-webchat-dimensions.d.ts +4 -0
  131. package/lib/esm/webchat/hooks/use-webchat-dimensions.js +35 -0
  132. package/lib/esm/webchat/hooks/use-webchat-dimensions.js.map +1 -0
  133. package/lib/esm/webchat/hooks/use-webchat-resizer.d.ts +4 -0
  134. package/lib/esm/webchat/hooks/use-webchat-resizer.js +30 -0
  135. package/lib/esm/webchat/hooks/use-webchat-resizer.js.map +1 -0
  136. package/lib/esm/webchat/hooks/use-webchat.d.ts +6 -1
  137. package/lib/esm/webchat/hooks/use-webchat.js +13 -9
  138. package/lib/esm/webchat/hooks/use-webchat.js.map +1 -1
  139. package/lib/esm/webchat/index-types.d.ts +0 -1
  140. package/lib/esm/webchat/message-list/index.js +6 -11
  141. package/lib/esm/webchat/message-list/index.js.map +1 -1
  142. package/lib/esm/webchat/message-list/scroll-button.js.map +1 -1
  143. package/lib/esm/webchat/message-list/styles.d.ts +1 -0
  144. package/lib/esm/webchat/message-list/styles.js +9 -0
  145. package/lib/esm/webchat/message-list/styles.js.map +1 -1
  146. package/lib/esm/webchat/replies.js +8 -4
  147. package/lib/esm/webchat/replies.js.map +1 -1
  148. package/lib/esm/webchat/typing-indicator/index.d.ts +1 -0
  149. package/lib/esm/webchat/typing-indicator/index.js +5 -0
  150. package/lib/esm/webchat/typing-indicator/index.js.map +1 -0
  151. package/lib/esm/webchat/typing-indicator/styles.d.ts +6 -0
  152. package/lib/esm/webchat/typing-indicator/styles.js +43 -0
  153. package/lib/esm/webchat/typing-indicator/styles.js.map +1 -0
  154. package/lib/esm/webchat/webchat-chat-area/index.d.ts +1 -0
  155. package/lib/esm/webchat/webchat-chat-area/index.js +18 -0
  156. package/lib/esm/webchat/webchat-chat-area/index.js.map +1 -0
  157. package/lib/esm/webchat/webchat-chat-area/styles.d.ts +3 -0
  158. package/lib/esm/webchat/webchat-chat-area/styles.js +9 -0
  159. package/lib/esm/webchat/webchat-chat-area/styles.js.map +1 -0
  160. package/lib/esm/webchat/webchat-input-panel/index.d.ts +2 -3
  161. package/lib/esm/webchat/webchat-input-panel/index.js +4 -3
  162. package/lib/esm/webchat/webchat-input-panel/index.js.map +1 -1
  163. package/lib/esm/webchat/webchat-input-panel/textarea.d.ts +2 -3
  164. package/lib/esm/webchat/webchat-input-panel/textarea.js +5 -7
  165. package/lib/esm/webchat/webchat-input-panel/textarea.js.map +1 -1
  166. package/lib/esm/webchat/webchat-reducer.js +0 -2
  167. package/lib/esm/webchat/webchat-reducer.js.map +1 -1
  168. package/lib/esm/webchat/webchat.js +19 -19
  169. package/lib/esm/webchat/webchat.js.map +1 -1
  170. package/lib/esm/webchat/webview.js +14 -22
  171. package/lib/esm/webchat/webview.js.map +1 -1
  172. package/lib/esm/webchat-app.d.ts +1 -1
  173. package/lib/esm/webchat-app.js +3 -1
  174. package/lib/esm/webchat-app.js.map +1 -1
  175. package/lib/esm/webview-app.js +11 -11
  176. package/lib/esm/webview-app.js.map +1 -1
  177. package/package.json +3 -6
  178. package/src/components/carousel.jsx +8 -10
  179. package/src/constants.js +0 -6
  180. package/src/contexts.tsx +9 -3
  181. package/src/index-types.ts +7 -52
  182. package/src/node-app.jsx +0 -6
  183. package/src/util/dom.js +2 -35
  184. package/src/webchat/actions.ts +0 -1
  185. package/src/webchat/constants.ts +9 -0
  186. package/src/webchat/header.jsx +31 -20
  187. package/src/webchat/hooks/index.ts +6 -0
  188. package/src/webchat/hooks/use-device-adapter.ts +50 -0
  189. package/src/webchat/hooks/use-scroll-to-bottom.ts +29 -0
  190. package/src/webchat/hooks/use-scrollbar-controller.ts +159 -0
  191. package/src/webchat/hooks/use-virtual-keyboard-detection.ts +27 -0
  192. package/src/webchat/hooks/use-webchat-dimensions.ts +50 -0
  193. package/src/webchat/hooks/use-webchat-resizer.ts +43 -0
  194. package/src/webchat/hooks/use-webchat.ts +14 -10
  195. package/src/webchat/index-types.ts +0 -1
  196. package/src/webchat/message-list/index.tsx +9 -19
  197. package/src/webchat/message-list/scroll-button.tsx +1 -3
  198. package/src/webchat/message-list/styles.ts +10 -0
  199. package/src/webchat/replies.jsx +13 -11
  200. package/src/webchat/typing-indicator/index.tsx +16 -0
  201. package/src/webchat/typing-indicator/styles.ts +50 -0
  202. package/src/webchat/webchat-chat-area/index.tsx +35 -0
  203. package/src/webchat/webchat-chat-area/styles.ts +9 -0
  204. package/src/webchat/webchat-input-panel/index.tsx +7 -4
  205. package/src/webchat/webchat-input-panel/textarea.tsx +7 -11
  206. package/src/webchat/webchat-reducer.ts +0 -2
  207. package/src/webchat/webchat.jsx +27 -20
  208. package/src/webchat/webview.jsx +14 -23
  209. package/src/webchat-app.jsx +2 -2
  210. package/src/webview-app.tsx +16 -11
  211. package/lib/cjs/webchat/components/styled-scrollbar.d.ts +0 -2
  212. package/lib/cjs/webchat/components/styled-scrollbar.js +0 -54
  213. package/lib/cjs/webchat/components/styled-scrollbar.js.map +0 -1
  214. package/lib/cjs/webchat/components/styled-scrollbar.scss +0 -12
  215. package/lib/cjs/webchat/components/typing-indicator.d.ts +0 -1
  216. package/lib/cjs/webchat/components/typing-indicator.js +0 -11
  217. package/lib/cjs/webchat/components/typing-indicator.js.map +0 -1
  218. package/lib/cjs/webchat/components/typing-indicator.scss +0 -38
  219. package/lib/cjs/webchat/devices/device-adapter.d.ts +0 -12
  220. package/lib/cjs/webchat/devices/device-adapter.js +0 -44
  221. package/lib/cjs/webchat/devices/device-adapter.js.map +0 -1
  222. package/lib/cjs/webchat/devices/scrollbar-controller.d.ts +0 -12
  223. package/lib/cjs/webchat/devices/scrollbar-controller.js +0 -103
  224. package/lib/cjs/webchat/devices/scrollbar-controller.js.map +0 -1
  225. package/lib/cjs/webchat/devices/webchat-resizer.d.ts +0 -9
  226. package/lib/cjs/webchat/devices/webchat-resizer.js +0 -47
  227. package/lib/cjs/webchat/devices/webchat-resizer.js.map +0 -1
  228. package/lib/esm/webchat/components/styled-scrollbar.d.ts +0 -2
  229. package/lib/esm/webchat/components/styled-scrollbar.js +0 -50
  230. package/lib/esm/webchat/components/styled-scrollbar.js.map +0 -1
  231. package/lib/esm/webchat/components/styled-scrollbar.scss +0 -12
  232. package/lib/esm/webchat/components/typing-indicator.d.ts +0 -1
  233. package/lib/esm/webchat/components/typing-indicator.js +0 -6
  234. package/lib/esm/webchat/components/typing-indicator.js.map +0 -1
  235. package/lib/esm/webchat/components/typing-indicator.scss +0 -38
  236. package/lib/esm/webchat/devices/device-adapter.d.ts +0 -12
  237. package/lib/esm/webchat/devices/device-adapter.js +0 -40
  238. package/lib/esm/webchat/devices/device-adapter.js.map +0 -1
  239. package/lib/esm/webchat/devices/scrollbar-controller.d.ts +0 -12
  240. package/lib/esm/webchat/devices/scrollbar-controller.js +0 -99
  241. package/lib/esm/webchat/devices/scrollbar-controller.js.map +0 -1
  242. package/lib/esm/webchat/devices/webchat-resizer.d.ts +0 -9
  243. package/lib/esm/webchat/devices/webchat-resizer.js +0 -43
  244. package/lib/esm/webchat/devices/webchat-resizer.js.map +0 -1
  245. package/src/webchat/components/styled-scrollbar.jsx +0 -60
  246. package/src/webchat/components/styled-scrollbar.scss +0 -12
  247. package/src/webchat/components/typing-indicator.jsx +0 -17
  248. package/src/webchat/components/typing-indicator.scss +0 -38
  249. package/src/webchat/devices/device-adapter.js +0 -43
  250. package/src/webchat/devices/scrollbar-controller.js +0 -107
  251. package/src/webchat/devices/webchat-resizer.js +0 -45
@@ -1 +0,0 @@
1
- {"version":3,"file":"webchat-resizer.js","sourceRoot":"","sources":["../../../../src/webchat/devices/webchat-resizer.js"],"names":[],"mappings":";;;AAAA,wCAAkE;AAClE,wBAA2B;AAE3B,MAAa,cAAc;IACzB,YAAY,aAAa,EAAE,IAAI;QAC7B,IAAI,CAAC,aAAa,GAAG,aAAa,CAAA;QAClC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAA;QAChB,IAAI,CAAC,OAAO,GAAG,IAAA,uBAAiB,EAAC,IAAI,CAAC,CAAA;IACxC,CAAC;IAED,OAAO,CAAC,iBAAiB;QACvB,IAAI,IAAI,CAAC,aAAa,KAAK,UAAO,CAAC,MAAM,CAAC,MAAM;YAAE,OAAM;QACxD;;;UAGE;QACF,MAAM,wBAAwB,GAAG,GAAG,CAAA;QACpC,MAAM,gCAAgC,GAAG,GAAG,EAAE;YAC5C,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAA;YAC/C,4GAA4G;YAC5G,MAAM,cAAc,GAClB,CAAC,MAAM,CAAC,cAAc,IAAI,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC;gBACvD,MAAM,CAAC,WAAW,CAAA;YACpB,IAAI,0BAA0B,GAAG,cAAc,GAAG,aAAa,CAAA;YAC/D,MAAM,YAAY,GAAG,OAAO,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,CAAC,GAAG,GAAG,CAAA;YAC/D,0BAA0B;gBACxB,YAAY,CAAC,0BAA0B,CAAC,GAAG,GAAG,CAAA;YAChD,OAAO,0BAA0B,CAAA;QACnC,CAAC,CAAA;QACD,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,uBAAuB,CAAC,GAAG,gCAAgC,EAAE,GAAG,CAAC,CAAA;YACtE,4BAA4B;YAC5B,iBAAiB,EAAE,CAAA;QACrB,CAAC,EAAE,wBAAwB,CAAC,CAAA;IAC9B,CAAC;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,aAAa,KAAK,UAAO,CAAC,MAAM,CAAC,MAAM;YAAE,OAAM;QACxD,IAAI,CAAC,uBAAuB,CAAC,MAAM,CAAC,CAAA;IACtC,CAAC;IAED,uBAAuB,CAAC,SAAS;QAC/B,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,GAAG,SAAS,CAAA;IACvC,CAAC;CACF;AAzCD,wCAyCC"}
@@ -1,2 +0,0 @@
1
- export const StyledScrollbar: import("styled-components").StyledComponent<typeof SimpleBar, any, {}, never>;
2
- import SimpleBar from "simplebar-react";
@@ -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 === 'true' &&
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":"","sources":["../../../../src/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,KAAK,MAAM;IACpC,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;QACvD,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO;QACzB,CAAC,CAAC,MAAM;;;wBAGM,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,12 +0,0 @@
1
- #botonic-scrollable-content
2
- > div.simplebar-wrapper
3
- > div.simplebar-mask
4
- > div
5
- > div {
6
- overscroll-behavior: contain; // https://css-tricks.com/almanac/properties/o/overscroll-behavior/
7
- -webkit-overflow-scrolling: touch;
8
- ::-webkit-scrollbar {
9
- // https://github.com/Grsmto/simplebar/issues/445#issuecomment-586902814
10
- display: none;
11
- }
12
- }
@@ -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":"","sources":["../../../../src/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,38 +0,0 @@
1
- .typing-indicator {
2
- will-change: transform;
3
- width: 44px;
4
- line-height: 0px;
5
- border-radius: 20px;
6
- padding: 8px 2px 8px;
7
- text-align: center;
8
- display: block;
9
- margin: 8px;
10
- position: relative;
11
- animation: 2s bulge infinite ease-out;
12
- span {
13
- height: 6px;
14
- width: 6px;
15
- margin: 0 1px;
16
- background-color: #9e9ea1;
17
- display: inline-block;
18
- border-radius: 50%;
19
- opacity: 0.4;
20
- @for $i from 1 through 3 {
21
- &:nth-of-type(#{$i}) {
22
- animation: 1s blink infinite ($i * 0.3333s);
23
- }
24
- }
25
- }
26
- }
27
-
28
- @keyframes blink {
29
- 50% {
30
- opacity: 1;
31
- }
32
- }
33
-
34
- @keyframes bulge {
35
- 50% {
36
- transform: scale(1.05);
37
- }
38
- }
@@ -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(): void;
8
- onBlur(): void;
9
- fontSize(defaultFontSize?: number): number | "initial";
10
- }
11
- import { WebchatResizer } from "./webchat-resizer";
12
- import { ScrollbarController } from "./scrollbar-controller";
@@ -1,40 +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() {
21
- setTimeout(() => {
22
- var _a;
23
- // 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
24
- (_a = this.webchatResizer) === null || _a === void 0 ? void 0 : _a.onFocus(() => this.scrollbarController.handleOnTouchMoveEvents());
25
- }, 0);
26
- }
27
- onBlur() {
28
- if (this.currentDevice !== DEVICES.MOBILE.IPHONE)
29
- return;
30
- this.webchatResizer.onBlur();
31
- this.scrollbarController.handleOnTouchMoveEvents();
32
- }
33
- fontSize(defaultFontSize = 14) {
34
- if (this.currentDevice !== DEVICES.MOBILE.IPHONE)
35
- return defaultFontSize;
36
- // Disabling auto-zoom on input (iPhone devices): https://stackoverflow.com/a/25614477, https://stackoverflow.com/a/6394497
37
- return 'initial';
38
- }
39
- }
40
- //# sourceMappingURL=device-adapter.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"device-adapter.js","sourceRoot":"","sources":["../../../../src/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;QACL,UAAU,CAAC,GAAG,EAAE;;YACd,iNAAiN;YACjN,MAAA,IAAI,CAAC,cAAc,0CAAE,OAAO,CAAC,GAAG,EAAE,CAChC,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,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
@@ -1 +0,0 @@
1
- {"version":3,"file":"scrollbar-controller.js","sourceRoot":"","sources":["../../../../src/webchat/devices/scrollbar-controller.js"],"names":[],"mappings":"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"}
@@ -1,9 +0,0 @@
1
- export class WebchatResizer {
2
- constructor(currentDevice: any, host: any);
3
- currentDevice: any;
4
- host: any;
5
- webchat: any;
6
- onFocus(onKeyboardShownFn: any): void;
7
- onBlur(): void;
8
- setWebchatElementHeight(newHeight: any): void;
9
- }
@@ -1,43 +0,0 @@
1
- import { getWebchatElement, scrollToBottom } from '../../util/dom';
2
- import { DEVICES } from '.';
3
- export class WebchatResizer {
4
- constructor(currentDevice, host) {
5
- this.currentDevice = currentDevice;
6
- this.host = host;
7
- this.webchat = getWebchatElement(host);
8
- }
9
- onFocus(onKeyboardShownFn) {
10
- if (this.currentDevice !== DEVICES.MOBILE.IPHONE)
11
- return;
12
- /*
13
- Based on Tip #4 from https://blog.opendigerati.com/the-eccentric-ways-of-ios-safari-with-the-keyboard-b5aa3f34228d,
14
- taking window.innerHeight as the amount of pixels the virtual keyboard adds
15
- */
16
- const waitUntilKeyboardIsShown = 400;
17
- const calculateNewWebchatElementHeight = () => {
18
- const webchatHeight = this.webchat.clientHeight;
19
- // Some iOS versions keep track of this height with VisualViewport API: https://stackoverflow.com/a/59056851
20
- const keyboardOffset = (window.visualViewport && window.visualViewport.height) ||
21
- window.innerHeight;
22
- let newWebchatPercentualHeight = keyboardOffset / webchatHeight;
23
- const toTwoDecimal = toRound => Math.round(toRound * 100) / 100;
24
- newWebchatPercentualHeight =
25
- toTwoDecimal(newWebchatPercentualHeight) * 100;
26
- return newWebchatPercentualHeight;
27
- };
28
- setTimeout(() => {
29
- this.setWebchatElementHeight(`${calculateNewWebchatElementHeight()}%`);
30
- // scrollToBottom(this.host)
31
- onKeyboardShownFn();
32
- }, waitUntilKeyboardIsShown);
33
- }
34
- onBlur() {
35
- if (this.currentDevice !== DEVICES.MOBILE.IPHONE)
36
- return;
37
- this.setWebchatElementHeight('100%');
38
- }
39
- setWebchatElementHeight(newHeight) {
40
- this.webchat.style.height = newHeight;
41
- }
42
- }
43
- //# sourceMappingURL=webchat-resizer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"webchat-resizer.js","sourceRoot":"","sources":["../../../../src/webchat/devices/webchat-resizer.js"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,GAAG,CAAA;AAE3B,MAAM,OAAO,cAAc;IACzB,YAAY,aAAa,EAAE,IAAI;QAC7B,IAAI,CAAC,aAAa,GAAG,aAAa,CAAA;QAClC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAA;QAChB,IAAI,CAAC,OAAO,GAAG,iBAAiB,CAAC,IAAI,CAAC,CAAA;IACxC,CAAC;IAED,OAAO,CAAC,iBAAiB;QACvB,IAAI,IAAI,CAAC,aAAa,KAAK,OAAO,CAAC,MAAM,CAAC,MAAM;YAAE,OAAM;QACxD;;;UAGE;QACF,MAAM,wBAAwB,GAAG,GAAG,CAAA;QACpC,MAAM,gCAAgC,GAAG,GAAG,EAAE;YAC5C,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAA;YAC/C,4GAA4G;YAC5G,MAAM,cAAc,GAClB,CAAC,MAAM,CAAC,cAAc,IAAI,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC;gBACvD,MAAM,CAAC,WAAW,CAAA;YACpB,IAAI,0BAA0B,GAAG,cAAc,GAAG,aAAa,CAAA;YAC/D,MAAM,YAAY,GAAG,OAAO,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,CAAC,GAAG,GAAG,CAAA;YAC/D,0BAA0B;gBACxB,YAAY,CAAC,0BAA0B,CAAC,GAAG,GAAG,CAAA;YAChD,OAAO,0BAA0B,CAAA;QACnC,CAAC,CAAA;QACD,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,uBAAuB,CAAC,GAAG,gCAAgC,EAAE,GAAG,CAAC,CAAA;YACtE,4BAA4B;YAC5B,iBAAiB,EAAE,CAAA;QACrB,CAAC,EAAE,wBAAwB,CAAC,CAAA;IAC9B,CAAC;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,aAAa,KAAK,OAAO,CAAC,MAAM,CAAC,MAAM;YAAE,OAAM;QACxD,IAAI,CAAC,uBAAuB,CAAC,MAAM,CAAC,CAAA;IACtC,CAAC;IAED,uBAAuB,CAAC,SAAS;QAC/B,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,GAAG,SAAS,CAAA;IACvC,CAAC;CACF"}
@@ -1,60 +0,0 @@
1
- import 'simplebar/dist/simplebar.css'
2
- import './styled-scrollbar.scss'
3
-
4
- import SimpleBar from 'simplebar-react'
5
- import styled, { css } from 'styled-components'
6
-
7
- import { COLORS } from '../../constants'
8
-
9
- export const StyledScrollbar = styled(SimpleBar)`
10
- ${props =>
11
- props.ismessagescontainer === 'true' &&
12
- css`
13
- display: flex;
14
- flex-direction: column;
15
- overflow-y: auto;
16
- overflow-x: hidden;
17
- `}
18
- & .simplebar-scrollbar::before {
19
- background-color: ${({ scrollbar }) =>
20
- scrollbar && scrollbar.thumb && scrollbar.thumb.color
21
- ? scrollbar.thumb.color
22
- : `${COLORS.GRAY}`};
23
- background-image: ${({ scrollbar }) =>
24
- scrollbar && scrollbar.thumb && scrollbar.thumb.bgcolor
25
- ? scrollbar.thumb.bgcolor
26
- : `${COLORS.GRAY}`};
27
- border-radius: ${({ scrollbar }) =>
28
- scrollbar && scrollbar.thumb && scrollbar.thumb.border
29
- ? scrollbar.thumb.border
30
- : '20px'};
31
- }
32
- & .simplebar-track .simplebar-scrollbar.simplebar-visible::before {
33
- opacity: ${({ scrollbar }) =>
34
- scrollbar && !scrollbar.enable
35
- ? '0'
36
- : scrollbar && scrollbar.thumb && scrollbar.thumb.opacity
37
- ? scrollbar.thumb.opacity
38
- : '0.75'};
39
- }
40
- & .simplebar-track {
41
- background-color: ${({ scrollbar }) =>
42
- scrollbar &&
43
- scrollbar.track &&
44
- scrollbar.track.color &&
45
- !(scrollbar && !scrollbar.enable)
46
- ? scrollbar.track.color
47
- : COLORS.TRANSPARENT};
48
- background-image: ${({ scrollbar }) =>
49
- scrollbar &&
50
- scrollbar.track &&
51
- scrollbar.track.bgcolor &&
52
- !(scrollbar && !scrollbar.enable)
53
- ? scrollbar.track.bgcolor
54
- : COLORS.TRANSPARENT};
55
- border-radius: ${({ scrollbar }) =>
56
- scrollbar && scrollbar.track && scrollbar.track.border
57
- ? scrollbar.track.border
58
- : '20px'};
59
- }
60
- `
@@ -1,12 +0,0 @@
1
- #botonic-scrollable-content
2
- > div.simplebar-wrapper
3
- > div.simplebar-mask
4
- > div
5
- > div {
6
- overscroll-behavior: contain; // https://css-tricks.com/almanac/properties/o/overscroll-behavior/
7
- -webkit-overflow-scrolling: touch;
8
- ::-webkit-scrollbar {
9
- // https://github.com/Grsmto/simplebar/issues/445#issuecomment-586902814
10
- display: none;
11
- }
12
- }
@@ -1,17 +0,0 @@
1
- import './typing-indicator.scss'
2
-
3
- import React from 'react'
4
-
5
- import { COLORS, ROLES } from '../../constants'
6
-
7
- export const TypingIndicator = props => (
8
- <div
9
- role={ROLES.TYPING_INDICATOR}
10
- className='typing-indicator'
11
- style={{ backgroundColor: COLORS.SEASHELL_WHITE }}
12
- >
13
- <span />
14
- <span />
15
- <span />
16
- </div>
17
- )
@@ -1,38 +0,0 @@
1
- .typing-indicator {
2
- will-change: transform;
3
- width: 44px;
4
- line-height: 0px;
5
- border-radius: 20px;
6
- padding: 8px 2px 8px;
7
- text-align: center;
8
- display: block;
9
- margin: 8px;
10
- position: relative;
11
- animation: 2s bulge infinite ease-out;
12
- span {
13
- height: 6px;
14
- width: 6px;
15
- margin: 0 1px;
16
- background-color: #9e9ea1;
17
- display: inline-block;
18
- border-radius: 50%;
19
- opacity: 0.4;
20
- @for $i from 1 through 3 {
21
- &:nth-of-type(#{$i}) {
22
- animation: 1s blink infinite ($i * 0.3333s);
23
- }
24
- }
25
- }
26
- }
27
-
28
- @keyframes blink {
29
- 50% {
30
- opacity: 1;
31
- }
32
- }
33
-
34
- @keyframes bulge {
35
- 50% {
36
- transform: scale(1.05);
37
- }
38
- }
@@ -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
-
6
- export class DeviceAdapter {
7
- constructor() {
8
- this.currentDevice = this.getCurrentDevice()
9
- }
10
-
11
- init(host) {
12
- this.webchatResizer = new WebchatResizer(this.currentDevice, host)
13
- this.scrollbarController = new ScrollbarController(this.currentDevice, host)
14
- this.scrollbarController.handleScrollEvents()
15
- }
16
-
17
- getCurrentDevice() {
18
- // navigator.platform deprecated. Ref: (https://erikmartinjordan.com/navigator-platform-deprecated-alternative)
19
- if (navigator.userAgentData) return navigator.userAgentData.platform
20
- return navigator.platform
21
- }
22
-
23
- onFocus() {
24
- setTimeout(() => {
25
- // 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
26
- this.webchatResizer?.onFocus(() =>
27
- this.scrollbarController.handleOnTouchMoveEvents()
28
- )
29
- }, 0)
30
- }
31
-
32
- onBlur() {
33
- if (this.currentDevice !== DEVICES.MOBILE.IPHONE) return
34
- this.webchatResizer.onBlur()
35
- this.scrollbarController.handleOnTouchMoveEvents()
36
- }
37
-
38
- fontSize(defaultFontSize = 14) {
39
- if (this.currentDevice !== DEVICES.MOBILE.IPHONE) return defaultFontSize
40
- // Disabling auto-zoom on input (iPhone devices): https://stackoverflow.com/a/25614477, https://stackoverflow.com/a/6394497
41
- return 'initial'
42
- }
43
- }
@@ -1,107 +0,0 @@
1
- import {
2
- getScrollableArea,
3
- getScrollableContent,
4
- getWebchatElement,
5
- } from '../../util/dom'
6
- import { DEVICES, isMobileDevice } from '.'
7
-
8
- const debounced = (delay, fn) => {
9
- let timerId
10
- return function (...args) {
11
- if (timerId) {
12
- clearTimeout(timerId)
13
- }
14
- timerId = setTimeout(() => {
15
- fn(...args)
16
- timerId = null
17
- }, delay)
18
- }
19
- }
20
-
21
- const stopAtScrollLimit = element => {
22
- if (element.scrollTop === 0) element.scrollTop = 1
23
- if (element.scrollHeight - element.scrollTop === element.clientHeight)
24
- element.scrollTop -= 1
25
- }
26
-
27
- export class ScrollbarController {
28
- constructor(currentDevice, host) {
29
- this.currentDevice = currentDevice
30
- this.webchat = getWebchatElement(host)
31
- }
32
-
33
- handleScrollEvents() {
34
- /*
35
- It handles scroll events for Mobile/Desktop.
36
- "ontouchmove" is the phone equivalent for "onmouseover"
37
- */
38
- if (isMobileDevice()) {
39
- if (this.currentDevice !== DEVICES.MOBILE.IPHONE) return
40
- this.limitScrollBoundaries()
41
- this.webchat.ontouchstart = e => {
42
- this.handleOnTouchMoveEvents(e)
43
- }
44
- this.webchat.ontouchmove = e => {
45
- this.handleOnTouchMoveEvents(e)
46
- }
47
- } else {
48
- this.webchat.onmouseover = e => this.handleOnMouseOverEvents(e)
49
- }
50
- }
51
-
52
- hasScrollbar() {
53
- const scrollableArea = getScrollableArea(this.webchat)
54
- const isScrollable =
55
- scrollableArea.visible.clientHeight - scrollableArea.full.clientHeight < 0
56
- return isScrollable
57
- }
58
-
59
- handleOnMouseOverEvents(e) {
60
- let target = e.currentTarget
61
- while (target) {
62
- this.toggleOnMouseWheelEvents()
63
- target = target.parentNode
64
- }
65
- }
66
-
67
- toggleOnMouseWheelEvents() {
68
- const scrollableContent = getScrollableContent(this.webchat)
69
- if (this.hasScrollbar()) {
70
- scrollableContent.onmousewheel = {}
71
- return
72
- }
73
- scrollableContent.onmousewheel = e => e.preventDefault()
74
- }
75
-
76
- handleOnTouchMoveEvents(e) {
77
- this.toggleOnTouchMoveEvents()
78
- }
79
-
80
- toggleOnTouchMoveEvents() {
81
- if (this.hasScrollbar()) {
82
- this.webchat.ontouchmove = {}
83
- this.webchat.ontouchstart = {}
84
- return
85
- }
86
- this.webchat.ontouchmove = e => {
87
- if (e.target === e.currentTarget) e.preventDefault()
88
- }
89
- }
90
-
91
- limitScrollBoundaries() {
92
- if (this.currentDevice !== DEVICES.MOBILE.IPHONE) return
93
- /*
94
- It adds a bounce effect when top or bottom limits of the scrollbar are reached for iOS,
95
- as an alternative of overscroll-behavior (https://developer.mozilla.org/en-US/docs/Web/CSS/overscroll-behavior)
96
- */
97
- const frame = getScrollableArea(this.webchat).visible
98
- const dStopAtScrollLimit = debounced(100, stopAtScrollLimit)
99
- if (frame) {
100
- if (window.addEventListener) {
101
- frame.addEventListener('scroll', () => dStopAtScrollLimit(frame), true)
102
- } else if (window.attachEvent) {
103
- frame.attachEvent('scroll', () => dStopAtScrollLimit(frame))
104
- }
105
- }
106
- }
107
- }