@tencentcloud/ai-desk-customer-vue 0.1.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 (351) hide show
  1. package/.code.yml +17 -0
  2. package/.eslintignore +6 -0
  3. package/.stylelintrc.json +40 -0
  4. package/CHANGELOG.md +5 -0
  5. package/README.md +12 -0
  6. package/adapter-vue-web.ts +73 -0
  7. package/adapter-vue.ts +10 -0
  8. package/assets/audio-before-delete.svg +4 -0
  9. package/assets/audio-blue.png +0 -0
  10. package/assets/audio-bubble-blue.svg +3 -0
  11. package/assets/audio-bubble-red.svg +3 -0
  12. package/assets/audio-delete.svg +10 -0
  13. package/assets/audio.svg +6 -0
  14. package/assets/back.svg +16 -0
  15. package/assets/background_mobile.png +0 -0
  16. package/assets/camera-uni.png +0 -0
  17. package/assets/close-quote-icon.svg +3 -0
  18. package/assets/customer_avatar.png +0 -0
  19. package/assets/customer_avatar_mobile.png +0 -0
  20. package/assets/dialog-close.png +0 -0
  21. package/assets/double-arrow.svg +1 -0
  22. package/assets/download.svg +6 -0
  23. package/assets/emoji.png +0 -0
  24. package/assets/face-uni.png +0 -0
  25. package/assets/face.png +0 -0
  26. package/assets/file-h5.png +0 -0
  27. package/assets/files.png +0 -0
  28. package/assets/form-dialog-bg.png +0 -0
  29. package/assets/icon-arrow-left.svg +7 -0
  30. package/assets/icon-close.svg +6 -0
  31. package/assets/iconRight.svg +3 -0
  32. package/assets/icon_form.png +0 -0
  33. package/assets/icon_form_filled.png +0 -0
  34. package/assets/icon_question.png +0 -0
  35. package/assets/icon_refresh.png +0 -0
  36. package/assets/icon_success.png +0 -0
  37. package/assets/imRobotGuess.svg +4 -0
  38. package/assets/image-uni.png +0 -0
  39. package/assets/image.png +0 -0
  40. package/assets/keyboard_icon.png +0 -0
  41. package/assets/loading.png +0 -0
  42. package/assets/more-uni.png +0 -0
  43. package/assets/more_tools.png +0 -0
  44. package/assets/msg-audio.svg +1 -0
  45. package/assets/msg-copy.svg +30 -0
  46. package/assets/msg-del.svg +33 -0
  47. package/assets/msg-quote.svg +8 -0
  48. package/assets/msg-revoke.svg +29 -0
  49. package/assets/radio-check.png +0 -0
  50. package/assets/radio-uncheck.png +0 -0
  51. package/assets/radio.svg +6 -0
  52. package/assets/refresh.svg +4 -0
  53. package/assets/rotate-left.svg +7 -0
  54. package/assets/rotate-right.svg +7 -0
  55. package/assets/star.png +0 -0
  56. package/assets/starLine.png +0 -0
  57. package/assets/translate.svg +12 -0
  58. package/assets/video-play.png +0 -0
  59. package/assets/video-uni.png +0 -0
  60. package/assets/video.png +0 -0
  61. package/assets/zoom-in.svg +9 -0
  62. package/assets/zoom-out.svg +9 -0
  63. package/components/CustomerServiceChat/chat-header/index-web.vue +141 -0
  64. package/components/CustomerServiceChat/emoji-config/custom-emoji.ts +15 -0
  65. package/components/CustomerServiceChat/emoji-config/default-emoji.ts +114 -0
  66. package/components/CustomerServiceChat/emoji-config/index.ts +140 -0
  67. package/components/CustomerServiceChat/emoji-config/locales/en.ts +66 -0
  68. package/components/CustomerServiceChat/emoji-config/locales/zh_cn.ts +66 -0
  69. package/components/CustomerServiceChat/index-web.vue +250 -0
  70. package/components/CustomerServiceChat/message-input/index-web.vue +214 -0
  71. package/components/CustomerServiceChat/message-input/index.ts +2 -0
  72. package/components/CustomerServiceChat/message-input/message-input-button.vue +95 -0
  73. package/components/CustomerServiceChat/message-input/message-input-editor-web.vue +884 -0
  74. package/components/CustomerServiceChat/message-input/message-input-file-web.ts +38 -0
  75. package/components/CustomerServiceChat/message-input/message-input-quote/index.vue +204 -0
  76. package/components/CustomerServiceChat/message-input-toolbar/emoji-dialog-mobile/emoji-dialog-mobile.vue +145 -0
  77. package/components/CustomerServiceChat/message-input-toolbar/emoji-picker/emoji-picker-dialog.vue +180 -0
  78. package/components/CustomerServiceChat/message-input-toolbar/emoji-picker/index.ts +2 -0
  79. package/components/CustomerServiceChat/message-input-toolbar/emoji-picker/index.vue +90 -0
  80. package/components/CustomerServiceChat/message-input-toolbar/emoji-picker/style/h5.scss +26 -0
  81. package/components/CustomerServiceChat/message-input-toolbar/emoji-picker/style/index.scss +4 -0
  82. package/components/CustomerServiceChat/message-input-toolbar/emoji-picker/style/web.scss +55 -0
  83. package/components/CustomerServiceChat/message-input-toolbar/file-upload/index.ts +2 -0
  84. package/components/CustomerServiceChat/message-input-toolbar/file-upload/index.vue +77 -0
  85. package/components/CustomerServiceChat/message-input-toolbar/image-upload/index.ts +2 -0
  86. package/components/CustomerServiceChat/message-input-toolbar/image-upload/index.vue +185 -0
  87. package/components/CustomerServiceChat/message-input-toolbar/index-web.vue +191 -0
  88. package/components/CustomerServiceChat/message-input-toolbar/index.ts +2 -0
  89. package/components/CustomerServiceChat/message-input-toolbar/style/uni.scss +111 -0
  90. package/components/CustomerServiceChat/message-input-toolbar/toolbar-item-container/index.vue +149 -0
  91. package/components/CustomerServiceChat/message-input-toolbar/toolbar-item-container/style/color.scss +6 -0
  92. package/components/CustomerServiceChat/message-input-toolbar/toolbar-item-container/style/h5.scss +20 -0
  93. package/components/CustomerServiceChat/message-input-toolbar/toolbar-item-container/style/index.scss +5 -0
  94. package/components/CustomerServiceChat/message-input-toolbar/toolbar-item-container/style/uni.scss +36 -0
  95. package/components/CustomerServiceChat/message-input-toolbar/toolbar-item-container/style/web.scss +19 -0
  96. package/components/CustomerServiceChat/message-input-toolbar/video-upload/index.ts +2 -0
  97. package/components/CustomerServiceChat/message-input-toolbar/video-upload/index.vue +146 -0
  98. package/components/CustomerServiceChat/message-list/index-web.vue +712 -0
  99. package/components/CustomerServiceChat/message-list/link/index.ts +23 -0
  100. package/components/CustomerServiceChat/message-list/message-elements/message-audio-web.vue +223 -0
  101. package/components/CustomerServiceChat/message-list/message-elements/message-bubble-web.vue +504 -0
  102. package/components/CustomerServiceChat/message-list/message-elements/message-custom.vue +5 -0
  103. package/components/CustomerServiceChat/message-list/message-elements/message-face.vue +45 -0
  104. package/components/CustomerServiceChat/message-list/message-elements/message-file.vue +151 -0
  105. package/components/CustomerServiceChat/message-list/message-elements/message-image-web.vue +97 -0
  106. package/components/CustomerServiceChat/message-list/message-elements/message-location.vue +34 -0
  107. package/components/CustomerServiceChat/message-list/message-elements/message-quote/index-web.vue +286 -0
  108. package/components/CustomerServiceChat/message-list/message-elements/message-quote/interface.ts +60 -0
  109. package/components/CustomerServiceChat/message-list/message-elements/message-record/index.vue +139 -0
  110. package/components/CustomerServiceChat/message-list/message-elements/message-text.vue +94 -0
  111. package/components/CustomerServiceChat/message-list/message-elements/message-timestamp.vue +76 -0
  112. package/components/CustomerServiceChat/message-list/message-elements/message-video-web.vue +319 -0
  113. package/components/CustomerServiceChat/message-list/message-elements/plugins/plugin-components/index.ts +9 -0
  114. package/components/CustomerServiceChat/message-list/message-elements/plugins/plugin-components/message-customer/index.ts +5 -0
  115. package/components/CustomerServiceChat/message-list/message-elements/plugins/plugin-components/message-customer/message-customer-service.vue +22 -0
  116. package/components/CustomerServiceChat/message-list/message-elements/plugins/plugin-components/message-plugin-layout-web.vue +133 -0
  117. package/components/CustomerServiceChat/message-list/message-elements/plugins/plugin-components/message-plugin-web.vue +83 -0
  118. package/components/CustomerServiceChat/message-list/message-elements/read-status/index.vue +193 -0
  119. package/components/CustomerServiceChat/message-list/message-elements/simple-message-list/index.vue +462 -0
  120. package/components/CustomerServiceChat/message-list/message-elements/simple-message-list/message-container.vue +105 -0
  121. package/components/CustomerServiceChat/message-list/message-elements/video-play.vue +59 -0
  122. package/components/CustomerServiceChat/message-list/message-tool/index-web.vue +312 -0
  123. package/components/CustomerServiceChat/message-list/message-tool/message-revoked.vue +63 -0
  124. package/components/CustomerServiceChat/message-list/scroll-button/index.vue +201 -0
  125. package/components/CustomerServiceChat/message-list/style/color.scss +32 -0
  126. package/components/CustomerServiceChat/message-list/style/h5.scss +16 -0
  127. package/components/CustomerServiceChat/message-list/style/index.scss +11 -0
  128. package/components/CustomerServiceChat/message-list/style/web.scss +180 -0
  129. package/components/CustomerServiceChat/style/common.scss +59 -0
  130. package/components/CustomerServiceChat/style/h5.scss +51 -0
  131. package/components/CustomerServiceChat/style/index.scss +12 -0
  132. package/components/CustomerServiceChat/style/uni.scss +13 -0
  133. package/components/CustomerServiceChat/style/web.scss +46 -0
  134. package/components/CustomerServiceChat/style/wx.scss +5 -0
  135. package/components/CustomerServiceChat/utils/conversationDraft.ts +86 -0
  136. package/components/CustomerServiceChat/utils/sendMessage.ts +140 -0
  137. package/components/common/Avatar/index.vue +148 -0
  138. package/components/common/BottomPopup/index.ts +3 -0
  139. package/components/common/BottomPopup/index.vue +160 -0
  140. package/components/common/BottomPopup/style/h5.scss +62 -0
  141. package/components/common/BottomPopup/style/index.scss +3 -0
  142. package/components/common/BottomPopup/style/modal.scss +5 -0
  143. package/components/common/Dialog/index.ts +3 -0
  144. package/components/common/Dialog/index.vue +120 -0
  145. package/components/common/Dialog/style/color.scss +43 -0
  146. package/components/common/Dialog/style/dialog.scss +4 -0
  147. package/components/common/Dialog/style/h5.scss +56 -0
  148. package/components/common/Dialog/style/web.scss +61 -0
  149. package/components/common/Drawer/index.vue +164 -0
  150. package/components/common/Icon.vue +83 -0
  151. package/components/common/ImagePreviewer/image-item-web.vue +42 -0
  152. package/components/common/ImagePreviewer/index-web.vue +682 -0
  153. package/components/common/ImagePreviewer/index.ts +3 -0
  154. package/components/common/Overlay/index.vue +126 -0
  155. package/components/common/ProgressMessage/index.vue +95 -0
  156. package/components/common/RadioSelect/index.vue +59 -0
  157. package/components/common/RichText/LICENSE +21 -0
  158. package/components/common/RichText/README.md +244 -0
  159. package/components/common/RichText/dist/mp-alipay/index.acss +1 -0
  160. package/components/common/RichText/dist/mp-alipay/index.axml +1 -0
  161. package/components/common/RichText/dist/mp-alipay/index.js +8 -0
  162. package/components/common/RichText/dist/mp-alipay/index.json +1 -0
  163. package/components/common/RichText/dist/mp-alipay/node/node.acss +1 -0
  164. package/components/common/RichText/dist/mp-alipay/node/node.axml +1 -0
  165. package/components/common/RichText/dist/mp-alipay/node/node.js +1 -0
  166. package/components/common/RichText/dist/mp-alipay/node/node.json +1 -0
  167. package/components/common/RichText/dist/mp-alipay/parser.js +1 -0
  168. package/components/common/RichText/dist/mp-baidu/index.css +1 -0
  169. package/components/common/RichText/dist/mp-baidu/index.js +8 -0
  170. package/components/common/RichText/dist/mp-baidu/index.json +1 -0
  171. package/components/common/RichText/dist/mp-baidu/index.swan +1 -0
  172. package/components/common/RichText/dist/mp-baidu/node/node.css +1 -0
  173. package/components/common/RichText/dist/mp-baidu/node/node.js +1 -0
  174. package/components/common/RichText/dist/mp-baidu/node/node.json +1 -0
  175. package/components/common/RichText/dist/mp-baidu/node/node.swan +1 -0
  176. package/components/common/RichText/dist/mp-baidu/parser.js +1 -0
  177. package/components/common/RichText/dist/mp-qq/index.js +8 -0
  178. package/components/common/RichText/dist/mp-qq/index.json +1 -0
  179. package/components/common/RichText/dist/mp-qq/index.qml +1 -0
  180. package/components/common/RichText/dist/mp-qq/index.qss +1 -0
  181. package/components/common/RichText/dist/mp-qq/node/node.js +1 -0
  182. package/components/common/RichText/dist/mp-qq/node/node.json +1 -0
  183. package/components/common/RichText/dist/mp-qq/node/node.qml +1 -0
  184. package/components/common/RichText/dist/mp-qq/node/node.qss +1 -0
  185. package/components/common/RichText/dist/mp-qq/parser.js +1 -0
  186. package/components/common/RichText/dist/mp-toutiao/index.js +8 -0
  187. package/components/common/RichText/dist/mp-toutiao/index.json +1 -0
  188. package/components/common/RichText/dist/mp-toutiao/index.ttml +1 -0
  189. package/components/common/RichText/dist/mp-toutiao/index.ttss +1 -0
  190. package/components/common/RichText/dist/mp-toutiao/node/node.js +1 -0
  191. package/components/common/RichText/dist/mp-toutiao/node/node.json +1 -0
  192. package/components/common/RichText/dist/mp-toutiao/node/node.ttml +1 -0
  193. package/components/common/RichText/dist/mp-toutiao/node/node.ttss +1 -0
  194. package/components/common/RichText/dist/mp-toutiao/parser.js +1 -0
  195. package/components/common/RichText/dist/mp-weixin/index.js +8 -0
  196. package/components/common/RichText/dist/mp-weixin/index.json +1 -0
  197. package/components/common/RichText/dist/mp-weixin/index.wxml +1 -0
  198. package/components/common/RichText/dist/mp-weixin/index.wxss +1 -0
  199. package/components/common/RichText/dist/mp-weixin/node/node.js +1 -0
  200. package/components/common/RichText/dist/mp-weixin/node/node.json +1 -0
  201. package/components/common/RichText/dist/mp-weixin/node/node.wxml +1 -0
  202. package/components/common/RichText/dist/mp-weixin/node/node.wxss +1 -0
  203. package/components/common/RichText/dist/mp-weixin/parser.js +1 -0
  204. package/components/common/RichText/dist/uni-app/components/mp-html/mp-html.vue +498 -0
  205. package/components/common/RichText/dist/uni-app/components/mp-html/node/node.vue +587 -0
  206. package/components/common/RichText/dist/uni-app/components/mp-html/parser.js +1393 -0
  207. package/components/common/RichText/dist/uni-app/static/app-plus/mp-html/js/handler.js +1 -0
  208. package/components/common/RichText/dist/uni-app/static/app-plus/mp-html/js/uni.webview.min.js +1 -0
  209. package/components/common/RichText/dist/uni-app/static/app-plus/mp-html/local.html +1 -0
  210. package/components/common/RichText/docs/.nojekyll +0 -0
  211. package/components/common/RichText/docs/index.html +50 -0
  212. package/components/common/RichText/docs/lib/docsify.min.js +1 -0
  213. package/components/common/RichText/docs/lib/prism-bash.min.js +1 -0
  214. package/components/common/RichText/docs/lib/search.min.js +1 -0
  215. package/components/common/RichText/docs/lib/vue.css +858 -0
  216. package/components/common/RichText/gulpfile.js +113 -0
  217. package/components/common/RichText/lint.js +63 -0
  218. package/components/common/RichText/package.json +74 -0
  219. package/components/common/RichText/plugins/README.md +2 -0
  220. package/components/common/RichText/plugins/audio/README.md +25 -0
  221. package/components/common/RichText/plugins/audio/build.js +11 -0
  222. package/components/common/RichText/plugins/audio/context.js +7 -0
  223. package/components/common/RichText/plugins/audio/index.js +34 -0
  224. package/components/common/RichText/plugins/audio/miniprogram/audio.js +189 -0
  225. package/components/common/RichText/plugins/audio/miniprogram/audio.json +3 -0
  226. package/components/common/RichText/plugins/audio/miniprogram/audio.wxml +17 -0
  227. package/components/common/RichText/plugins/audio/miniprogram/audio.wxss +127 -0
  228. package/components/common/RichText/plugins/audio/miniprogram/build.js +3 -0
  229. package/components/common/RichText/plugins/audio/uni-app/audio.vue +269 -0
  230. package/components/common/RichText/plugins/audio/uni-app/build.js +3 -0
  231. package/components/common/RichText/plugins/card/README.md +30 -0
  232. package/components/common/RichText/plugins/card/build.js +14 -0
  233. package/components/common/RichText/plugins/card/index.js +7 -0
  234. package/components/common/RichText/plugins/card/miniprogram/build.js +3 -0
  235. package/components/common/RichText/plugins/card/miniprogram/card.js +26 -0
  236. package/components/common/RichText/plugins/card/miniprogram/card.json +3 -0
  237. package/components/common/RichText/plugins/card/miniprogram/card.wxml +9 -0
  238. package/components/common/RichText/plugins/card/miniprogram/card.wxss +55 -0
  239. package/components/common/RichText/plugins/card/uni-app/build.js +3 -0
  240. package/components/common/RichText/plugins/card/uni-app/card.vue +122 -0
  241. package/components/common/RichText/plugins/editable/README.md +137 -0
  242. package/components/common/RichText/plugins/editable/config.js +15 -0
  243. package/components/common/RichText/plugins/editable/miniprogram/build.js +813 -0
  244. package/components/common/RichText/plugins/editable/miniprogram/index.js +551 -0
  245. package/components/common/RichText/plugins/editable/uni-app/build.js +744 -0
  246. package/components/common/RichText/plugins/editable/uni-app/index.js +553 -0
  247. package/components/common/RichText/plugins/emoji/README.md +15 -0
  248. package/components/common/RichText/plugins/emoji/index.js +203 -0
  249. package/components/common/RichText/plugins/highlight/README.md +26 -0
  250. package/components/common/RichText/plugins/highlight/config.js +5 -0
  251. package/components/common/RichText/plugins/highlight/index.js +96 -0
  252. package/components/common/RichText/plugins/highlight/miniprogram/build.js +88 -0
  253. package/components/common/RichText/plugins/highlight/prism.css +125 -0
  254. package/components/common/RichText/plugins/highlight/prism.min.js +7 -0
  255. package/components/common/RichText/plugins/highlight/uni-app/build.js +88 -0
  256. package/components/common/RichText/plugins/img-cache/README.md +24 -0
  257. package/components/common/RichText/plugins/img-cache/build.js +16 -0
  258. package/components/common/RichText/plugins/img-cache/index.js +138 -0
  259. package/components/common/RichText/plugins/latex/README.md +16 -0
  260. package/components/common/RichText/plugins/latex/build.js +14 -0
  261. package/components/common/RichText/plugins/latex/index.js +77 -0
  262. package/components/common/RichText/plugins/latex/katex.css +1070 -0
  263. package/components/common/RichText/plugins/latex/katex.min.js +1 -0
  264. package/components/common/RichText/plugins/markdown/README.md +17 -0
  265. package/components/common/RichText/plugins/markdown/index.js +34 -0
  266. package/components/common/RichText/plugins/markdown/marked.min.js +6 -0
  267. package/components/common/RichText/plugins/markdown/miniprogram/build.js +70 -0
  268. package/components/common/RichText/plugins/markdown/uni-app/build.js +68 -0
  269. package/components/common/RichText/plugins/search/README.md +46 -0
  270. package/components/common/RichText/plugins/search/miniprogram/index.js +137 -0
  271. package/components/common/RichText/plugins/search/uni-app/index.js +132 -0
  272. package/components/common/RichText/plugins/style/README.md +30 -0
  273. package/components/common/RichText/plugins/style/index.js +129 -0
  274. package/components/common/RichText/plugins/style/parser.js +175 -0
  275. package/components/common/RichText/plugins/template/README.md +2 -0
  276. package/components/common/RichText/plugins/template/build.js +65 -0
  277. package/components/common/RichText/plugins/template/index.js +67 -0
  278. package/components/common/RichText/plugins/txv-video/README.md +18 -0
  279. package/components/common/RichText/plugins/txv-video/build.js +3 -0
  280. package/components/common/RichText/plugins/txv-video/index.js +46 -0
  281. package/components/common/RichText/plugins/txv-video/miniprogram/build.js +6 -0
  282. package/components/common/RichText/plugins/txv-video/uni-app/build.js +3 -0
  283. package/components/common/RichText/src/miniprogram/index.js +396 -0
  284. package/components/common/RichText/src/miniprogram/index.json +6 -0
  285. package/components/common/RichText/src/miniprogram/index.wxml +7 -0
  286. package/components/common/RichText/src/miniprogram/index.wxss +13 -0
  287. package/components/common/RichText/src/miniprogram/node/node.js +247 -0
  288. package/components/common/RichText/src/miniprogram/node/node.json +6 -0
  289. package/components/common/RichText/src/miniprogram/node/node.wxml +112 -0
  290. package/components/common/RichText/src/miniprogram/node/node.wxss +164 -0
  291. package/components/common/RichText/src/miniprogram/parser.js +1269 -0
  292. package/components/common/RichText/src/uni-app/components/mp-html/mp-html.vue +498 -0
  293. package/components/common/RichText/src/uni-app/components/mp-html/node/node.vue +585 -0
  294. package/components/common/RichText/src/uni-app/components/mp-html/parser.js +1393 -0
  295. package/components/common/RichText/src/uni-app/static/app-plus/mp-html/js/handler.js +254 -0
  296. package/components/common/RichText/src/uni-app/static/app-plus/mp-html/js/uni.webview.min.js +1 -0
  297. package/components/common/RichText/src/uni-app/static/app-plus/mp-html/local.html +33 -0
  298. package/components/common/RichText/tools/config.js +82 -0
  299. package/components/common/RichText/tools/converter.js +205 -0
  300. package/components/common/RichText/tools/ifdef.js +115 -0
  301. package/components/common/RichText/tools/minifier.js +40 -0
  302. package/components/common/RichText/tools/plugin.js +248 -0
  303. package/components/common/Toast/index-web.ts +122 -0
  304. package/components/common/Toast/index-web.vue +178 -0
  305. package/components/common/Toast/type.ts +8 -0
  306. package/components/common/common.scss +59 -0
  307. package/components/customer-icon.vue +56 -0
  308. package/components/message-branch.vue +120 -0
  309. package/components/message-customer-service.vue +114 -0
  310. package/components/message-form/form-branch.vue +68 -0
  311. package/components/message-form/form-input.vue +242 -0
  312. package/components/message-form/index.vue +80 -0
  313. package/components/message-multi-branch/branch-pc.vue +79 -0
  314. package/components/message-multi-branch/index.vue +60 -0
  315. package/components/message-multi-form/component-mobile/form-popup.vue +37 -0
  316. package/components/message-multi-form/component-mobile/input-mobile.vue +102 -0
  317. package/components/message-multi-form/component-mobile/label-mobile.vue +32 -0
  318. package/components/message-multi-form/component-mobile/radios-mobile.vue +161 -0
  319. package/components/message-multi-form/component-pc/input-pc.vue +93 -0
  320. package/components/message-multi-form/component-pc/label-pc.vue +33 -0
  321. package/components/message-multi-form/component-pc/radio-pc.vue +98 -0
  322. package/components/message-multi-form/form-mobile.vue +385 -0
  323. package/components/message-multi-form/form-pc.vue +184 -0
  324. package/components/message-multi-form/index.vue +61 -0
  325. package/components/message-product-card.vue +129 -0
  326. package/components/message-rating/index.vue +56 -0
  327. package/components/message-rating/message-rating-number.vue +247 -0
  328. package/components/message-rating/message-rating-star.vue +237 -0
  329. package/components/message-rich-text.vue +155 -0
  330. package/components/message-robot-welcome.vue +181 -0
  331. package/components/message-stream.vue +109 -0
  332. package/constant.ts +122 -0
  333. package/excluded-list.txt +6 -0
  334. package/index.ts +30 -0
  335. package/index.vue +60 -0
  336. package/interface.ts +176 -0
  337. package/logger/index.ts +12 -0
  338. package/logger/main.ts +120 -0
  339. package/package.json +62 -0
  340. package/script/fileCopy.js +60 -0
  341. package/script/syncVersion.js +35 -0
  342. package/server.ts +128 -0
  343. package/styles/common.scss +116 -0
  344. package/tsconfig.json +34 -0
  345. package/typings.d.ts +20 -0
  346. package/utils/chatStorage.ts +70 -0
  347. package/utils/copy-web.ts +141 -0
  348. package/utils/enableSampleTaskStatus.ts +8 -0
  349. package/utils/env.ts +15 -0
  350. package/utils/index.ts +59 -0
  351. package/utils/utils.ts +162 -0
@@ -0,0 +1,76 @@
1
+ <template>
2
+ <div
3
+ v-if="timestampShowFlag"
4
+ class="message-timestamp"
5
+ >
6
+ {{ timestampShowContent }}
7
+ </div>
8
+ </template>
9
+ <script setup lang="ts">
10
+ import vue from '../../../../adapter-vue';
11
+ import { calculateTimestamp } from '../../../../utils/utils';
12
+ const { toRefs, ref, watch } = vue;
13
+
14
+ const props = defineProps({
15
+ currTime: {
16
+ type: Number,
17
+ default: 0,
18
+ },
19
+ prevTime: {
20
+ type: Number,
21
+ default: 0,
22
+ },
23
+ });
24
+ const { currTime, prevTime } = toRefs(props);
25
+ const timestampShowFlag = ref(false);
26
+ const timestampShowContent = ref('');
27
+
28
+ const handleItemTime = (currTime: number, prevTime: number) => {
29
+ timestampShowFlag.value = false;
30
+ if (currTime <= 0) {
31
+ return '';
32
+ } else if (!prevTime || prevTime <= 0) {
33
+ timestampShowFlag.value = true;
34
+ return calculateTimestamp(currTime * 1000);
35
+ } else {
36
+ const minDiffToShow = 10 * 60; // 10min 10*60s
37
+ const diff = currTime - prevTime; // s
38
+ if (diff >= minDiffToShow) {
39
+ timestampShowFlag.value = true;
40
+ return calculateTimestamp(currTime * 1000);
41
+ }
42
+ }
43
+ return '';
44
+ };
45
+
46
+ watch(
47
+ () => [currTime.value, prevTime.value],
48
+ (newVal: any, oldVal: any) => {
49
+ if (newVal?.toString() === oldVal?.toString()) {
50
+ return;
51
+ } else {
52
+ timestampShowContent.value = handleItemTime(
53
+ currTime.value,
54
+ prevTime.value,
55
+ );
56
+ }
57
+ },
58
+ {
59
+ immediate: true,
60
+ },
61
+ );
62
+ </script>
63
+ <style lang="scss" scoped>
64
+ @import "../../style/common";
65
+
66
+ .message-timestamp {
67
+ font-family: PingFangSC-Regular;
68
+ margin: 10px auto;
69
+ color: #999;
70
+ font-size: 12px;
71
+ overflow-wrap: anywhere;
72
+ display: flex;
73
+ align-items: center;
74
+ text-align: center;
75
+ }
76
+ </style>
@@ -0,0 +1,319 @@
1
+ <template>
2
+ <div class="message-video">
3
+ <div
4
+ ref="skeleton"
5
+ class="message-video-box"
6
+ :class="[
7
+ (!props.messageItem.progress || props.messageItem.progress === 1) &&
8
+ !isPC &&
9
+ 'message-video-cover',
10
+ ]"
11
+ @click="toggleVideoPreviewer"
12
+ >
13
+ <img
14
+ v-if="
15
+ (props.messageItem.progress > 0 &&
16
+ props.messageItem.progress < 1 &&
17
+ poster) ||
18
+ (!isPC && poster)
19
+ "
20
+ class="message-img"
21
+ :class="[isWidth ? 'is-width' : 'is-height']"
22
+ :src="poster"
23
+ >
24
+ <video
25
+ v-else-if="!isPC"
26
+ ref="videoRef"
27
+ class="message-img video-h5-uploading"
28
+ :src="props.content.url + '#t=0.1'"
29
+ :poster="props.content.url"
30
+ preload="auto"
31
+ muted
32
+ />
33
+ <video
34
+ v-else
35
+ ref="videoRef"
36
+ class="message-img video-web"
37
+ :src="props.content.url"
38
+ controls
39
+ preload="metadata"
40
+ :poster="poster"
41
+ />
42
+ </div>
43
+ <div
44
+ v-if="isShow && !isPC"
45
+ class="dialog-video"
46
+ >
47
+ <div
48
+ class="dialog-video-close"
49
+ @click.stop="toggleVideoPreviewer"
50
+ >
51
+ <Icon :file="closeSVG" />
52
+ </div>
53
+ <div
54
+ class="dialog-video-box"
55
+ :class="[!isPC ? 'dialog-video-h5' : '']"
56
+ @click.self="toggleVideoPreviewer"
57
+ >
58
+ <video
59
+ :class="[isWidth ? 'is-width' : 'is-height']"
60
+ :src="props.content.url"
61
+ controls
62
+ autoplay
63
+ />
64
+ </div>
65
+ </div>
66
+ </div>
67
+ </template>
68
+
69
+ <script lang="ts" setup>
70
+ import vue from '../../../../adapter-vue';
71
+ import { IMessageModel } from '@tencentcloud/chat-uikit-engine';
72
+ import { handleSkeletonSize } from '../../../../utils/utils';
73
+ import Icon from '../../../common/Icon.vue';
74
+ import closeSVG from '../../../../assets/icon-close.svg';
75
+ import type { IVideoMessageContent } from '../../../../interface';
76
+ import { isPC } from '../../../../utils/env';
77
+ const { ref, watch, computed, nextTick, watchEffect, withDefaults } = vue;
78
+
79
+ const props = withDefaults(
80
+ defineProps<{
81
+ content: IVideoMessageContent;
82
+ messageItem: IMessageModel;
83
+ }>(),
84
+ {
85
+ content: () => ({} as IVideoMessageContent),
86
+ messageItem: () => ({} as IMessageModel),
87
+ },
88
+ );
89
+
90
+ const emits = defineEmits(['uploading']);
91
+ const isShow = ref(false);
92
+ const poster = ref('');
93
+ const posterWidth = ref(0);
94
+ const posterHeight = ref(0);
95
+ const skeleton = ref();
96
+ const videoRef = ref();
97
+ const transparentPosterUrl
98
+ = 'https://web.sdk.qcloud.com/im/assets/images/transparent.png';
99
+
100
+ watchEffect(async () => {
101
+ if (!props.content) return;
102
+ poster.value = await handlePosterUrl(props.content, props.messageItem);
103
+ nextTick(async () => {
104
+ const containerWidth
105
+ = document.getElementById('messageScrollList')?.clientWidth || 0;
106
+ const max = !isPC ? Math.min(containerWidth - 172, 300) : 300;
107
+ let size;
108
+ if (props.messageItem.status === 'success') {
109
+ let { snapshotWidth = 0, snapshotHeight = 0 } = props.content;
110
+ const { snapshotUrl } = props.content;
111
+ if (snapshotWidth === 0 || snapshotHeight === 0) return;
112
+ if (snapshotUrl === transparentPosterUrl) {
113
+ snapshotWidth = posterWidth.value;
114
+ snapshotHeight = posterHeight.value;
115
+ }
116
+ size = handleSkeletonSize(snapshotWidth, snapshotHeight, max, max);
117
+ skeleton?.value?.style
118
+ && (skeleton.value.style.width = `${size.width}px`);
119
+ skeleton?.value?.style
120
+ && (skeleton.value.style.height = `${size.height}px`);
121
+ if (isPC) {
122
+ videoRef?.value?.style
123
+ && (videoRef.value.style.width = `${size.width}px`);
124
+ videoRef?.value?.style
125
+ && (videoRef.value.style.height = `${size.height}px`);
126
+ }
127
+ } else {
128
+ emits('uploading');
129
+ }
130
+ });
131
+ });
132
+
133
+ const isWidth = computed(() => {
134
+ const { snapshotWidth = 0, snapshotHeight = 0 } = props.messageItem.payload;
135
+ return snapshotWidth >= snapshotHeight;
136
+ });
137
+
138
+ watch(
139
+ () => props.messageItem.status,
140
+ (newVal: string, oldVal: string) => {
141
+ if (newVal === 'success' && oldVal !== 'success') {
142
+ emits('uploading');
143
+ }
144
+ },
145
+ );
146
+
147
+ function toggleVideoPreviewer() {
148
+ // Video upload process does not support full-screen playback.
149
+ if (props.messageItem.progress > 0 && props.messageItem.progress < 1) {
150
+ return;
151
+ }
152
+ isShow.value = !isShow.value;
153
+ }
154
+
155
+ // For H5, some browsers (Safari/WeChat) have an issue where the cover image of the<video>` tag is empty before the video is fully uploaded.
156
+ // A separate processing and clipping method is required to display the cover image before the video upload is complete.
157
+ function getVideoBase64(url: string) {
158
+ return new Promise((resolve) => {
159
+ let dataURL = '';
160
+ const video = document.createElement('video');
161
+ video.setAttribute('crossOrigin', 'anonymous');
162
+ video.setAttribute('src', url);
163
+ video.setAttribute('preload', 'auto');
164
+ video.addEventListener(
165
+ 'loadeddata',
166
+ function () {
167
+ const canvas = document.createElement('canvas'),
168
+ width = video.videoWidth,
169
+ height = video.videoHeight;
170
+ canvas.width = width;
171
+ canvas.height = height;
172
+ (canvas as any).getContext('2d').drawImage(video, 0, 0, width, height);
173
+ dataURL = canvas.toDataURL('image/jpeg');
174
+ posterWidth.value = width;
175
+ posterHeight.value = height;
176
+ resolve(dataURL);
177
+ },
178
+ { once: true },
179
+ );
180
+ });
181
+ }
182
+
183
+ async function handlePosterUrl(
184
+ messgeContent: IVideoMessageContent,
185
+ messageItem: IMessageModel,
186
+ ) {
187
+ if (!messageItem) return '';
188
+ if (messageItem.status !== 'success') {
189
+ return await getVideoBase64(messgeContent.url);
190
+ } else {
191
+ return (
192
+ (messgeContent.snapshotUrl !== transparentPosterUrl
193
+ && messgeContent.snapshotUrl)
194
+ || (messageItem?.payload?.snapshotUrl !== transparentPosterUrl
195
+ && messageItem?.payload?.snapshotUrl)
196
+ || (messageItem.payload?.thumbUrl !== transparentPosterUrl
197
+ && messageItem?.payload?.thumbUrl)
198
+ || (await getVideoBase64(messgeContent.url))
199
+ );
200
+ }
201
+ }
202
+ </script>
203
+
204
+ <style lang="scss" scoped>
205
+ @import "../../style/common";
206
+
207
+ .message-video {
208
+ position: relative;
209
+ display: flex;
210
+ justify-content: center;
211
+ overflow: hidden;
212
+
213
+ &-box {
214
+ max-width: min(calc(100vw - 180px), 300px);
215
+ font-size: 0;
216
+
217
+ video {
218
+ max-width: min(calc(100vw - 180px), 300px);
219
+ max-height: min(calc(100vw - 180px), 300px);
220
+ width: inherit;
221
+ height: inherit;
222
+ border-radius: 10px;
223
+ }
224
+
225
+ img {
226
+ max-width: min(calc(100vw - 180px), 300px);
227
+ max-height: min(calc(100vw - 180px), 300px);
228
+ width: inherit;
229
+ height: inherit;
230
+ border-radius: 10px;
231
+ }
232
+
233
+ img[src=""],
234
+ img:not([src]) {
235
+ opacity: 0;
236
+ }
237
+ }
238
+
239
+ &-cover {
240
+ display: inline-block;
241
+ position: relative;
242
+
243
+ &::before {
244
+ position: absolute;
245
+ z-index: 1;
246
+ content: "";
247
+ width: 0;
248
+ height: 0;
249
+ border: 10px solid transparent;
250
+ border-left: 15px solid #fff;
251
+ top: 0;
252
+ left: 0;
253
+ bottom: 0;
254
+ right: 0;
255
+ margin: auto;
256
+ transform: translate(5px, 0);
257
+ }
258
+
259
+ video {
260
+ max-width: min(calc(100vw - 180px), 300px);
261
+ max-height: min(calc(100vw - 180px), 300px);
262
+ width: inherit;
263
+ height: inherit;
264
+ border-radius: 10px;
265
+ }
266
+ }
267
+ }
268
+
269
+ .dialog-video {
270
+ position: fixed;
271
+ z-index: 12;
272
+ width: 100vw;
273
+ height: 100vh;
274
+ top: 0;
275
+ left: 0;
276
+ display: flex;
277
+ flex-direction: column;
278
+ align-items: center;
279
+
280
+ &-close {
281
+ display: flex;
282
+ justify-content: flex-end;
283
+ background: #000;
284
+ width: 100%;
285
+ box-sizing: border-box;
286
+ padding: 10px;
287
+ }
288
+
289
+ &-box {
290
+ display: flex;
291
+ flex: 1;
292
+ max-height: 100%;
293
+ padding: 6rem;
294
+ box-sizing: border-box;
295
+ justify-content: center;
296
+ align-items: center;
297
+
298
+ video {
299
+ max-width: 100%;
300
+ max-height: 100%;
301
+ }
302
+ }
303
+ }
304
+
305
+ .dialog-video-h5 {
306
+ width: 100%;
307
+ height: 100%;
308
+ background: #000;
309
+ padding: 30px 0;
310
+ }
311
+
312
+ .is-width {
313
+ width: 100%;
314
+ }
315
+
316
+ .is-height {
317
+ height: 100%;
318
+ }
319
+ </style>
@@ -0,0 +1,9 @@
1
+ import TUIChatEngine, { IMessageModel } from '@tencentcloud/chat-uikit-engine';
2
+ import { isCustomerServicePluginMessage } from './message-customer/index';
3
+
4
+ export function isPluginMessage(message: IMessageModel): boolean {
5
+ return (
6
+ message.type === TUIChatEngine.TYPES.MSG_CUSTOM
7
+ && isCustomerServicePluginMessage(message as any)
8
+ );
9
+ }
@@ -0,0 +1,5 @@
1
+ import {
2
+ isCustomerServicePluginMessage,
3
+ isMessageInvisible as isCustomServiceMessageInvisible,
4
+ } from '../../../../../../../index';
5
+ export { isCustomerServicePluginMessage, isCustomServiceMessageInvisible };
@@ -0,0 +1,22 @@
1
+ <template>
2
+ <TUICustomerServicePlugin :message="props.message" @showFormPopup="handleShowFormPopup"/>
3
+ </template>
4
+ <script setup lang="ts">
5
+ import { IMessageModel } from '@tencentcloud/chat-uikit-engine';
6
+ import TUICustomerServicePlugin from '../../../../../../../index.vue';
7
+ interface IProps {
8
+ message: IMessageModel;
9
+ }
10
+ const props = withDefaults(defineProps<IProps>(), {
11
+ message: () => ({} as IMessageModel),
12
+ });
13
+ const emits = defineEmits([
14
+ 'showFormPopup'
15
+ ]);
16
+ function handleShowFormPopup(data: any) {
17
+ emits('showFormPopup', data);
18
+ }
19
+ </script>
20
+ <style lang="scss" scoped>
21
+ /* stylelint-disable-next-line no-empty-source */
22
+ </style>
@@ -0,0 +1,133 @@
1
+ <template>
2
+ <div class="message-plugin">
3
+ <!-- The following is displayed in the form of messageTip -->
4
+ <div
5
+ v-if="props.showStyle === 'tip'"
6
+ class="message-plugin-tip"
7
+ >
8
+ <slot name="messageTip" />
9
+ </div>
10
+ <!-- The following is displayed in the form of messageBubble -->
11
+ <div
12
+ v-else-if="props.showStyle === 'bubble'"
13
+ class="message-plugin-bubble-content"
14
+ @longpress="handleToggleMessageItem($event, messageModel, true)"
15
+ @click.prevent.right="handleToggleMessageItem($event, messageModel)"
16
+ @touchstart="handleH5LongPress($event, messageModel, 'touchstart')"
17
+ @touchend="handleH5LongPress($event, messageModel, 'touchend')"
18
+ @mouseover="handleH5LongPress($event, messageModel, 'touchend')"
19
+ >
20
+ <MessageBubble
21
+ :messageItem="messageModel"
22
+ :content="messageModel.getMessageContent()"
23
+ :blinkMessageIDList="props.blinkMessageIDList"
24
+ :classNameList="props.bubbleClassNameList"
25
+ @resendMessage="resendMessage(messageModel)"
26
+ >
27
+ <!-- web message-bubble is a named slot, content area slotName is messageElement -->
28
+ <template #messageElement>
29
+ <slot
30
+ v-if="!isUniFrameWork"
31
+ name="messageBubble"
32
+ />
33
+ </template>
34
+ <!-- uni-app message-bubble is an anonymous slot, no slotName -->
35
+ <slot
36
+ v-if="isUniFrameWork"
37
+ name="messageBubble"
38
+ />
39
+ </MessageBubble>
40
+ </div>
41
+ </div>
42
+ </template>
43
+
44
+ <script lang="ts" setup>
45
+ import vue from '../../../../../../adapter-vue';
46
+ import { TUIStore, IMessageModel } from '@tencentcloud/chat-uikit-engine';
47
+ import MessageBubble from '../../message-bubble-web.vue';
48
+ import { isUniFrameWork } from '../../../../../../utils/env';
49
+ const { computed } = vue;
50
+ interface IProps {
51
+ message: IMessageModel;
52
+ showStyle: string;
53
+ bubbleClassNameList?: string[];
54
+ blinkMessageIDList?: string[];
55
+ }
56
+
57
+ const props = withDefaults(defineProps<IProps>(), {
58
+ message: () => ({} as IMessageModel),
59
+ showStyle: '',
60
+ bubbleClassNameList: () => [] as string[],
61
+ blinkMessageIDList: () => [] as string[],
62
+ });
63
+
64
+ const emits = defineEmits([
65
+ 'resendMessage',
66
+ 'handleToggleMessageItem',
67
+ 'handleH5LongPress',
68
+ ]);
69
+ const messageModel = computed(() =>
70
+ TUIStore.getMessageModel(props.message?.ID),
71
+ );
72
+
73
+ // The following is for external interaction such as messageTool, no special processing is required, do not change
74
+ const resendMessage = (message: IMessageModel) => {
75
+ emits('resendMessage', message);
76
+ };
77
+ const handleToggleMessageItem = (
78
+ e: any,
79
+ message: IMessageModel,
80
+ isLongpress = false,
81
+ ) => {
82
+ emits('handleToggleMessageItem', e, message, isLongpress);
83
+ };
84
+ const handleH5LongPress = (e: any, message: IMessageModel, type: string) => {
85
+ emits('handleH5LongPress', e, message, type);
86
+ };
87
+ </script>
88
+
89
+ <style lang="scss" scoped>
90
+ .message-plugin-tip {
91
+ color: #999;
92
+ font-size: 12px;
93
+ overflow-wrap: anywhere;
94
+ display: flex;
95
+ place-content: center center;
96
+ align-items: center;
97
+ text-align: center;
98
+ margin: 0 10px 10px;
99
+ }
100
+
101
+ .message-tip-highlight {
102
+ animation: highlight 1000ms infinite;
103
+
104
+ @keyframes highlight {
105
+ 50% {
106
+ color: #ff9c19;
107
+ }
108
+ }
109
+
110
+ @keyframes highlight {
111
+ 50% {
112
+ color: #ff9c19;
113
+ }
114
+ }
115
+ }
116
+
117
+ :deep(.message-bubble-room) {
118
+ .message-bubble-main-content {
119
+ .message-body {
120
+ .message-body-main {
121
+ .message-body-content {
122
+ &.content-in,
123
+ &.content-out {
124
+ background-color: transparent;
125
+ border-radius: 0;
126
+ padding: 0;
127
+ }
128
+ }
129
+ }
130
+ }
131
+ }
132
+ }
133
+ </style>
@@ -0,0 +1,83 @@
1
+ <template>
2
+ <MessagePluginLayout
3
+ :message="props.message"
4
+ :showStyle="pluginMessageType.showStyle"
5
+ :bubbleClassNameList="[
6
+ pluginMessageType.pluginType === 'room' ? 'message-bubble-room' : '',
7
+ ]"
8
+ @resendMessage="resendMessage"
9
+ @handleToggleMessageItem="handleToggleMessageItem"
10
+ @handleH5LongPress="handleH5LongPress"
11
+ >
12
+ <template #messageBubble>
13
+ <MessageCustomerService
14
+ v-if="pluginMessageType.pluginType === 'customer'"
15
+ :message="props.message"
16
+ />
17
+ </template>
18
+ </MessagePluginLayout>
19
+ </template>
20
+
21
+ <script lang="ts" setup>
22
+ import vue from '../../../../../../adapter-vue';
23
+ import { TUIStore } from '@tencentcloud/chat-uikit-engine';
24
+ import { IMessageModel } from '@tencentcloud/chat-uikit-engine';
25
+ import {
26
+ isCustomerServicePluginMessage,
27
+ isCustomServiceMessageInvisible,
28
+ } from './message-customer/index';
29
+ import MessagePluginLayout from './message-plugin-layout-web.vue';
30
+ import MessageCustomerService from './message-customer/message-customer-service.vue';
31
+ const { computed } = vue;
32
+
33
+ interface IProps {
34
+ message: IMessageModel;
35
+ blinkMessageIDList?: string[];
36
+ }
37
+
38
+ const props = withDefaults(defineProps<IProps>(), {
39
+ message: () => ({} as IMessageModel),
40
+ blinkMessageIDList: () => [] as string[],
41
+ });
42
+
43
+ const emits = defineEmits([
44
+ 'resendMessage',
45
+ 'handleToggleMessageItem',
46
+ 'handleH5LongPress',
47
+ ]);
48
+ const messageModel = computed(() => TUIStore.getMessageModel(props.message.ID));
49
+
50
+ const pluginMessageType = computed<{ pluginType: string; showStyle: string }>(
51
+ () => {
52
+ let typeObj = { pluginType: '', showStyle: '' };
53
+ if (isCustomerServicePluginMessage(messageModel.value)) {
54
+ typeObj = {
55
+ pluginType: 'customer',
56
+ showStyle: isCustomServiceMessageInvisible(messageModel.value)
57
+ ? ''
58
+ : 'bubble',
59
+ };
60
+ }
61
+ return typeObj;
62
+ },
63
+ );
64
+
65
+ // The following are for external interaction such as messageTool, no special processing is required, please do not touch
66
+ const resendMessage = (message: IMessageModel) => {
67
+ emits('resendMessage', message);
68
+ };
69
+ const handleToggleMessageItem = (
70
+ e: any,
71
+ message: IMessageModel,
72
+ isLongpress = false,
73
+ ) => {
74
+ emits('handleToggleMessageItem', e, message, isLongpress);
75
+ };
76
+ const handleH5LongPress = (e: any, message: IMessageModel, type: string) => {
77
+ emits('handleH5LongPress', e, message, type);
78
+ };
79
+ </script>
80
+
81
+ <style lang="scss" scoped>
82
+ /* stylelint-disable-next-line no-empty-source */
83
+ </style>