@touchvue/chat 1.0.0-beta.46 → 1.0.0-beta.48

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 (139) hide show
  1. package/README.md +70 -70
  2. package/es/package.json.css +1 -1
  3. package/es/package.json.mjs +1 -1
  4. package/es/packages/components/resolver.mjs.map +1 -1
  5. package/es/packages/components/touchchat/component/AiRobot/HelloChat.vue2.mjs.map +1 -1
  6. package/es/packages/components/touchchat/component/AiRobot/letter.vue.mjs +1 -1
  7. package/es/packages/components/touchchat/component/AiRobot/letter.vue2.mjs +8 -8
  8. package/es/packages/components/touchchat/component/AiRobot/letter.vue2.mjs.map +1 -1
  9. package/es/packages/components/touchchat/component/FileContent.vue2.mjs +9 -4
  10. package/es/packages/components/touchchat/component/FileContent.vue2.mjs.map +1 -1
  11. package/es/packages/components/touchchat/component/FileView.vue2.mjs +2 -2
  12. package/es/packages/components/touchchat/component/FileView.vue2.mjs.map +1 -1
  13. package/es/packages/components/touchchat/component/HelloChat.vue2.mjs.map +1 -1
  14. package/es/packages/components/touchchat/component/ImageFile.vue2.mjs +6 -6
  15. package/es/packages/components/touchchat/component/ImageFile.vue2.mjs.map +1 -1
  16. package/es/packages/components/touchchat/component/ImageView.vue2.mjs +1 -1
  17. package/es/packages/components/touchchat/component/ImageView.vue2.mjs.map +1 -1
  18. package/es/packages/components/touchchat/component/LinkView.vue2.mjs +4 -4
  19. package/es/packages/components/touchchat/component/LinkView.vue2.mjs.map +1 -1
  20. package/es/packages/components/touchchat/component/MarkLayer.vue2.mjs +1 -1
  21. package/es/packages/components/touchchat/component/MarkLayer.vue2.mjs.map +1 -1
  22. package/es/packages/components/touchchat/component/ModuleSelect.vue2.mjs +2 -2
  23. package/es/packages/components/touchchat/component/ModuleSelect.vue2.mjs.map +1 -1
  24. package/es/packages/components/touchchat/component/PDFFile.vue2.mjs +14 -8
  25. package/es/packages/components/touchchat/component/PDFFile.vue2.mjs.map +1 -1
  26. package/es/packages/components/touchchat/component/QuoteContent.vue2.mjs.map +1 -1
  27. package/es/packages/components/touchchat/component/RealtimeVoice.vue2.mjs +1 -1
  28. package/es/packages/components/touchchat/component/RealtimeVoice.vue2.mjs.map +1 -1
  29. package/es/packages/components/touchchat/component/VideoFile.vue.mjs +7 -0
  30. package/es/packages/components/touchchat/component/VideoFile.vue.mjs.map +1 -0
  31. package/es/packages/components/touchchat/component/VideoFile.vue2.mjs +33 -0
  32. package/es/packages/components/touchchat/component/VideoFile.vue2.mjs.map +1 -0
  33. package/es/packages/components/touchchat/src/AiChat/AgentsView.vue2.mjs +1 -1
  34. package/es/packages/components/touchchat/src/AiChat/AgentsView.vue2.mjs.map +1 -1
  35. package/es/packages/components/touchchat/src/AiChat/AiMessage.vue2.mjs +65 -27
  36. package/es/packages/components/touchchat/src/AiChat/AiMessage.vue2.mjs.map +1 -1
  37. package/es/packages/components/touchchat/src/AiChat/Chat/scriptMatcher.mjs.map +1 -1
  38. package/es/packages/components/touchchat/src/AiChat/Chat/types.mjs.map +1 -1
  39. package/es/packages/components/touchchat/src/AiChat/Chat/useChat.mjs +7 -4
  40. package/es/packages/components/touchchat/src/AiChat/Chat/useChat.mjs.map +1 -1
  41. package/es/packages/components/touchchat/src/AiChat/Chat/useCopy.mjs.map +1 -1
  42. package/es/packages/components/touchchat/src/AiChat/Chat/useMessageRender.mjs.map +1 -1
  43. package/es/packages/components/touchchat/src/AiChat/Chat/useSSE.mjs +39 -86
  44. package/es/packages/components/touchchat/src/AiChat/Chat/useSSE.mjs.map +1 -1
  45. package/es/packages/components/touchchat/src/AiChat/ChatInput.vue2.mjs +5 -5
  46. package/es/packages/components/touchchat/src/AiChat/ChatInput.vue2.mjs.map +1 -1
  47. package/es/packages/components/touchchat/src/AiChat/HistoryList.vue2.mjs +1 -1
  48. package/es/packages/components/touchchat/src/AiChat/HistoryList.vue2.mjs.map +1 -1
  49. package/es/packages/components/touchchat/src/AiChat/HistorySidebar.vue2.mjs +3 -3
  50. package/es/packages/components/touchchat/src/AiChat/HistorySidebar.vue2.mjs.map +1 -1
  51. package/es/packages/components/touchchat/src/AiChat/MessageActions.vue2.mjs +11 -11
  52. package/es/packages/components/touchchat/src/AiChat/MessageActions.vue2.mjs.map +1 -1
  53. package/es/packages/components/touchchat/src/AiChat/SiderBarView.vue2.mjs +3 -3
  54. package/es/packages/components/touchchat/src/AiChat/SiderBarView.vue2.mjs.map +1 -1
  55. package/es/packages/components/touchchat/src/AiChat/TouchAgent.vue2.mjs +2 -0
  56. package/es/packages/components/touchchat/src/AiChat/TouchAgent.vue2.mjs.map +1 -1
  57. package/es/packages/components/touchchat/src/AiChat/TouchChat.vue2.mjs +20 -3
  58. package/es/packages/components/touchchat/src/AiChat/TouchChat.vue2.mjs.map +1 -1
  59. package/es/packages/components/touchchat/src/AiChat/TouchHistory.vue2.mjs +6 -0
  60. package/es/packages/components/touchchat/src/AiChat/TouchHistory.vue2.mjs.map +1 -1
  61. package/es/packages/components/touchchat/src/AiChat/UserMessage.vue2.mjs +16 -16
  62. package/es/packages/components/touchchat/src/AiChat/UserMessage.vue2.mjs.map +1 -1
  63. package/es/packages/components/touchchat/src/index.vue2.mjs +19 -9
  64. package/es/packages/components/touchchat/src/index.vue2.mjs.map +1 -1
  65. package/es/packages/components/touchchat/utils/a2aService.mjs +18 -12
  66. package/es/packages/components/touchchat/utils/a2aService.mjs.map +1 -1
  67. package/es/packages/components/touchchat/utils/fetchStream.mjs.map +1 -1
  68. package/lib/package.json.css +1 -1
  69. package/lib/package.json.js +1 -1
  70. package/lib/packages/components/resolver.js.map +1 -1
  71. package/lib/packages/components/touchchat/component/AiRobot/HelloChat.vue2.js.map +1 -1
  72. package/lib/packages/components/touchchat/component/AiRobot/letter.vue.js +1 -1
  73. package/lib/packages/components/touchchat/component/AiRobot/letter.vue2.js +8 -8
  74. package/lib/packages/components/touchchat/component/AiRobot/letter.vue2.js.map +1 -1
  75. package/lib/packages/components/touchchat/component/FileContent.vue2.js +9 -4
  76. package/lib/packages/components/touchchat/component/FileContent.vue2.js.map +1 -1
  77. package/lib/packages/components/touchchat/component/FileView.vue2.js +2 -2
  78. package/lib/packages/components/touchchat/component/FileView.vue2.js.map +1 -1
  79. package/lib/packages/components/touchchat/component/HelloChat.vue2.js.map +1 -1
  80. package/lib/packages/components/touchchat/component/ImageFile.vue2.js +6 -6
  81. package/lib/packages/components/touchchat/component/ImageFile.vue2.js.map +1 -1
  82. package/lib/packages/components/touchchat/component/ImageView.vue2.js +1 -1
  83. package/lib/packages/components/touchchat/component/ImageView.vue2.js.map +1 -1
  84. package/lib/packages/components/touchchat/component/LinkView.vue2.js +4 -4
  85. package/lib/packages/components/touchchat/component/LinkView.vue2.js.map +1 -1
  86. package/lib/packages/components/touchchat/component/MarkLayer.vue2.js +1 -1
  87. package/lib/packages/components/touchchat/component/MarkLayer.vue2.js.map +1 -1
  88. package/lib/packages/components/touchchat/component/ModuleSelect.vue2.js +2 -2
  89. package/lib/packages/components/touchchat/component/ModuleSelect.vue2.js.map +1 -1
  90. package/lib/packages/components/touchchat/component/PDFFile.vue2.js +14 -8
  91. package/lib/packages/components/touchchat/component/PDFFile.vue2.js.map +1 -1
  92. package/lib/packages/components/touchchat/component/QuoteContent.vue2.js.map +1 -1
  93. package/lib/packages/components/touchchat/component/RealtimeVoice.vue2.js +1 -1
  94. package/lib/packages/components/touchchat/component/RealtimeVoice.vue2.js.map +1 -1
  95. package/lib/packages/components/touchchat/component/VideoFile.vue.js +11 -0
  96. package/lib/packages/components/touchchat/component/VideoFile.vue.js.map +1 -0
  97. package/lib/packages/components/touchchat/component/VideoFile.vue2.js +37 -0
  98. package/lib/packages/components/touchchat/component/VideoFile.vue2.js.map +1 -0
  99. package/lib/packages/components/touchchat/src/AiChat/AgentsView.vue2.js +1 -1
  100. package/lib/packages/components/touchchat/src/AiChat/AgentsView.vue2.js.map +1 -1
  101. package/lib/packages/components/touchchat/src/AiChat/AiMessage.vue2.js +65 -27
  102. package/lib/packages/components/touchchat/src/AiChat/AiMessage.vue2.js.map +1 -1
  103. package/lib/packages/components/touchchat/src/AiChat/Chat/scriptMatcher.js.map +1 -1
  104. package/lib/packages/components/touchchat/src/AiChat/Chat/types.js.map +1 -1
  105. package/lib/packages/components/touchchat/src/AiChat/Chat/useChat.js +7 -4
  106. package/lib/packages/components/touchchat/src/AiChat/Chat/useChat.js.map +1 -1
  107. package/lib/packages/components/touchchat/src/AiChat/Chat/useCopy.js.map +1 -1
  108. package/lib/packages/components/touchchat/src/AiChat/Chat/useMessageRender.js.map +1 -1
  109. package/lib/packages/components/touchchat/src/AiChat/Chat/useSSE.js +39 -86
  110. package/lib/packages/components/touchchat/src/AiChat/Chat/useSSE.js.map +1 -1
  111. package/lib/packages/components/touchchat/src/AiChat/ChatInput.vue2.js +5 -5
  112. package/lib/packages/components/touchchat/src/AiChat/ChatInput.vue2.js.map +1 -1
  113. package/lib/packages/components/touchchat/src/AiChat/HistoryList.vue2.js +1 -1
  114. package/lib/packages/components/touchchat/src/AiChat/HistoryList.vue2.js.map +1 -1
  115. package/lib/packages/components/touchchat/src/AiChat/HistorySidebar.vue2.js +3 -3
  116. package/lib/packages/components/touchchat/src/AiChat/HistorySidebar.vue2.js.map +1 -1
  117. package/lib/packages/components/touchchat/src/AiChat/MessageActions.vue2.js +11 -11
  118. package/lib/packages/components/touchchat/src/AiChat/MessageActions.vue2.js.map +1 -1
  119. package/lib/packages/components/touchchat/src/AiChat/SiderBarView.vue2.js +3 -3
  120. package/lib/packages/components/touchchat/src/AiChat/SiderBarView.vue2.js.map +1 -1
  121. package/lib/packages/components/touchchat/src/AiChat/TouchAgent.vue2.js +2 -0
  122. package/lib/packages/components/touchchat/src/AiChat/TouchAgent.vue2.js.map +1 -1
  123. package/lib/packages/components/touchchat/src/AiChat/TouchChat.vue2.js +19 -2
  124. package/lib/packages/components/touchchat/src/AiChat/TouchChat.vue2.js.map +1 -1
  125. package/lib/packages/components/touchchat/src/AiChat/TouchHistory.vue2.js +6 -0
  126. package/lib/packages/components/touchchat/src/AiChat/TouchHistory.vue2.js.map +1 -1
  127. package/lib/packages/components/touchchat/src/AiChat/UserMessage.vue2.js +16 -16
  128. package/lib/packages/components/touchchat/src/AiChat/UserMessage.vue2.js.map +1 -1
  129. package/lib/packages/components/touchchat/src/index.vue2.js +19 -9
  130. package/lib/packages/components/touchchat/src/index.vue2.js.map +1 -1
  131. package/lib/packages/components/touchchat/utils/a2aService.js +18 -12
  132. package/lib/packages/components/touchchat/utils/a2aService.js.map +1 -1
  133. package/lib/packages/components/touchchat/utils/fetchStream.js.map +1 -1
  134. package/package.json +83 -83
  135. package/theme/components/index.css +26 -0
  136. package/theme/font/iconfont.woff +0 -0
  137. package/theme/font/iconfont.woff2 +0 -0
  138. package/theme/index.css +26 -0
  139. package/theme/skin/default.css +26 -0
package/README.md CHANGED
@@ -1,70 +1,70 @@
1
- # TouchVue Chat 组件库
2
-
3
- ## 介绍
4
-
5
- TouchVue Chat 是一个基于 Vue 3 的 AI 聊天组件库,提供了一系列高质量的组件,帮助开发者快速构建应用。
6
-
7
- ## 安装
8
-
9
- ```bash
10
- npm install @touchvue/ui
11
- # 或者
12
- yarn add @touchvue/ui
13
- # 或者
14
- pnpm add @touchvue/ui
15
- ```
16
-
17
- ## 使用
18
-
19
- ### 完整引入
20
-
21
- ```js
22
- import { createApp } from 'vue'
23
- import TouchVueUI from '@touchvue/ui'
24
- import '@touchvue/ui/theme/index.css'
25
- import App from './App.vue'
26
-
27
- const app = createApp(App)
28
- app.use(TouchVueUI)
29
- app.mount('#app')
30
- ```
31
-
32
- ### 按需引入
33
-
34
- #### 手动引入
35
-
36
- ```js
37
- import { ToButton, ToIcon } from '@touchvue/ui'
38
- import '@touchvue/ui/theme/button/index.css'
39
- import '@touchvue/ui/theme/icon/index.css'
40
- ```
41
-
42
- #### 自动引入(推荐)
43
-
44
- 我们提供了与 [unplugin-vue-components](https://github.com/antfu/unplugin-vue-components) 和 [unplugin-auto-import](https://github.com/antfu/unplugin-auto-import) 的集成。
45
-
46
- ##### Vite 配置
47
-
48
- ```js
49
- // vite.config.js
50
- import { defineConfig } from 'vite'
51
- import vue from '@vitejs/plugin-vue'
52
- import AutoImport from 'unplugin-auto-import/vite'
53
- import Components from 'unplugin-vue-components/vite'
54
- import { TouchVueResolver } from '@touchvue/ui'
55
-
56
- export default defineConfig({
57
- plugins: [
58
- vue(),
59
- Components({
60
- resolvers: [TouchVueResolver()]
61
- })
62
- ]
63
- })
64
- ```
65
-
66
- ## 组件列表
67
-
68
- - ToButton - 按钮组件
69
- - ToIcon - 图标组件
70
- - 更多组件正在开发中...
1
+ # TouchVue Chat 组件库
2
+
3
+ ## 介绍
4
+
5
+ TouchVue Chat 是一个基于 Vue 3 的 AI 聊天组件库,提供了一系列高质量的组件,帮助开发者快速构建应用。
6
+
7
+ ## 安装
8
+
9
+ ```bash
10
+ npm install @touchvue/ui
11
+ # 或者
12
+ yarn add @touchvue/ui
13
+ # 或者
14
+ pnpm add @touchvue/ui
15
+ ```
16
+
17
+ ## 使用
18
+
19
+ ### 完整引入
20
+
21
+ ```js
22
+ import { createApp } from 'vue'
23
+ import TouchVueUI from '@touchvue/ui'
24
+ import '@touchvue/ui/theme/index.css'
25
+ import App from './App.vue'
26
+
27
+ const app = createApp(App)
28
+ app.use(TouchVueUI)
29
+ app.mount('#app')
30
+ ```
31
+
32
+ ### 按需引入
33
+
34
+ #### 手动引入
35
+
36
+ ```js
37
+ import { ToButton, ToIcon } from '@touchvue/ui'
38
+ import '@touchvue/ui/theme/button/index.css'
39
+ import '@touchvue/ui/theme/icon/index.css'
40
+ ```
41
+
42
+ #### 自动引入(推荐)
43
+
44
+ 我们提供了与 [unplugin-vue-components](https://github.com/antfu/unplugin-vue-components) 和 [unplugin-auto-import](https://github.com/antfu/unplugin-auto-import) 的集成。
45
+
46
+ ##### Vite 配置
47
+
48
+ ```js
49
+ // vite.config.js
50
+ import { defineConfig } from 'vite'
51
+ import vue from '@vitejs/plugin-vue'
52
+ import AutoImport from 'unplugin-auto-import/vite'
53
+ import Components from 'unplugin-vue-components/vite'
54
+ import { TouchVueResolver } from '@touchvue/ui'
55
+
56
+ export default defineConfig({
57
+ plugins: [
58
+ vue(),
59
+ Components({
60
+ resolvers: [TouchVueResolver()]
61
+ })
62
+ ]
63
+ })
64
+ ```
65
+
66
+ ## 组件列表
67
+
68
+ - ToButton - 按钮组件
69
+ - ToIcon - 图标组件
70
+ - 更多组件正在开发中...
@@ -1 +1 @@
1
- .typewriter-container[data-v-6fd1b883]{position:relative}.loading-container[data-v-6fd1b883]{min-height:40px}.typewriter-loading[data-v-6fd1b883]{align-items:center;color:#666;display:flex;font-size:14px;gap:8px;line-height:1;margin-top:12px;padding:8px 0}.loading-dot[data-v-6fd1b883]{animation:bounce-6fd1b883 1.4s ease-in-out infinite both;background-color:#666;border-radius:50%;display:inline-block;height:8px;width:8px}.loading-text[data-v-6fd1b883]{user-select:none}@keyframes bounce-6fd1b883{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.markdown-content[data-v-6fd1b883]{color:#333}.markdown-content h1[data-v-6fd1b883],.markdown-content h2[data-v-6fd1b883]{margin:1em 0 .5em}.markdown-content p[data-v-6fd1b883]{margin:.5em 0}.markdown-content code[data-v-6fd1b883]{background:#f0f0f0;border-radius:4px;padding:.2em .4em}.hljs{background:#fafafa;color:#383a42;display:block;overflow-x:auto;padding:.5em}.hljs-comment,.hljs-quote{color:#a0a1a7;font-style:italic}.hljs-doctag,.hljs-formula,.hljs-keyword{color:#a626a4}.hljs-deletion,.hljs-name,.hljs-section,.hljs-selector-tag,.hljs-subst{color:#e45649}.hljs-literal{color:#0184bb}.hljs-addition,.hljs-attribute,.hljs-meta-string,.hljs-regexp,.hljs-string{color:#50a14f}.hljs-built_in,.hljs-class .hljs-title{color:#c18401}.hljs-attr,.hljs-number,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-pseudo,.hljs-template-variable,.hljs-type,.hljs-variable{color:#986801}.hljs-bullet,.hljs-link,.hljs-meta,.hljs-selector-id,.hljs-symbol,.hljs-title{color:#4078f2}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.hljs-link{text-decoration:underline}
1
+ .video-File[data-v-7305b796]{height:auto;width:5em}.video-play[data-v-7305b796]{width:100%}.typewriter-container[data-v-5bee9536]{position:relative}.loading-container[data-v-5bee9536]{min-height:40px}.typewriter-loading[data-v-5bee9536]{align-items:center;color:#666;display:flex;font-size:14px;gap:8px;line-height:1;margin-top:12px;padding:8px 0}.loading-dot[data-v-5bee9536]{animation:bounce-5bee9536 1.4s ease-in-out infinite both;background-color:#666;border-radius:50%;display:inline-block;height:8px;width:8px}.loading-text[data-v-5bee9536]{user-select:none}@keyframes bounce-5bee9536{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.markdown-content[data-v-5bee9536]{color:#333}.markdown-content h1[data-v-5bee9536],.markdown-content h2[data-v-5bee9536]{margin:1em 0 .5em}.markdown-content p[data-v-5bee9536]{margin:.5em 0}.markdown-content code[data-v-5bee9536]{background:#f0f0f0;border-radius:4px;padding:.2em .4em}.hljs{background:#fafafa;color:#383a42;display:block;overflow-x:auto;padding:.5em}.hljs-comment,.hljs-quote{color:#a0a1a7;font-style:italic}.hljs-doctag,.hljs-formula,.hljs-keyword{color:#a626a4}.hljs-deletion,.hljs-name,.hljs-section,.hljs-selector-tag,.hljs-subst{color:#e45649}.hljs-literal{color:#0184bb}.hljs-addition,.hljs-attribute,.hljs-meta-string,.hljs-regexp,.hljs-string{color:#50a14f}.hljs-built_in,.hljs-class .hljs-title{color:#c18401}.hljs-attr,.hljs-number,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-pseudo,.hljs-template-variable,.hljs-type,.hljs-variable{color:#986801}.hljs-bullet,.hljs-link,.hljs-meta,.hljs-selector-id,.hljs-symbol,.hljs-title{color:#4078f2}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.hljs-link{text-decoration:underline}
@@ -1,5 +1,5 @@
1
1
  var name = "@touchvue/chat";
2
- var version = "1.0.0-beta.46";
2
+ var version = "1.0.0-beta.48";
3
3
  var description = "TouchVue Chat Component Library";
4
4
  var main = "lib/index.js";
5
5
  var module = "es/index.mjs";
@@ -1 +1 @@
1
- {"version":3,"file":"resolver.mjs","sources":["../../../../packages/components/resolver.ts"],"sourcesContent":["/**\r\n * TouchVue Chat 组件解析器\r\n * 用于支持 unplugin-auto-import 和 unplugin-vue-components 插件\r\n */\r\n\r\n// 组件库名称\r\nconst LIBRARY_NAME = '@touchvue/chat'\r\n// 组件前缀\r\nconst PREFIX = 'To'\r\n\r\n/**\r\n * 检查组件名称是否符合规则\r\n * @param name 组件名称\r\n * @returns 是否符合规则\r\n */\r\nconst isValidComponentName = (name: string): boolean => {\r\n\treturn name.startsWith(PREFIX)\r\n}\r\n\r\n/**\r\n * 获取组件名称(不带前缀)\r\n * @param name 组件名称\r\n * @returns 不带前缀的组件名称\r\n */\r\nconst getComponentName = (name: string): string => {\r\n\treturn name.slice(PREFIX.length)\r\n}\r\n\r\nconst getSideEffectsPath = (name: string, prefix: string = LIBRARY_NAME): string => {\r\n\treturn `${prefix}/theme/components/${getComponentName(name).toLowerCase()}/index.css`\r\n}\r\n\r\n/**\r\n * 组件解析器\r\n * 用于 unplugin-vue-components 插件\r\n */\r\nexport function TouchVueResolver() {\r\n\treturn {\r\n\t\ttype: 'component',\r\n\t\tresolve: (name: string) => {\r\n\t\t\tif (!isValidComponentName(name)) return\r\n\t\t\treturn {\r\n\t\t\t\tname,\r\n\t\t\t\tfrom: LIBRARY_NAME,\r\n\t\t\t\tsideEffects: getSideEffectsPath(name)\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n\r\n/**\r\n * 默认导出所有解析器\r\n */\r\nexport default {\r\n\tTouchVueResolver\r\n}\r\n"],"names":[],"mappings":"AAMA,MAAM,YAAe,GAAA,gBAAA,CAAA;AAErB,MAAM,MAAS,GAAA,IAAA,CAAA;AAOf,MAAM,oBAAA,GAAuB,CAAC,IAA0B,KAAA;AACvD,EAAO,OAAA,IAAA,CAAK,WAAW,MAAM,CAAA,CAAA;AAC9B,CAAA,CAAA;AAOA,MAAM,gBAAA,GAAmB,CAAC,IAAyB,KAAA;AAClD,EAAO,OAAA,IAAA,CAAK,KAAM,CAAA,MAAA,CAAO,MAAM,CAAA,CAAA;AAChC,CAAA,CAAA;AAEA,MAAM,kBAAqB,GAAA,CAAC,IAAc,EAAA,MAAA,GAAiB,YAAyB,KAAA;AACnF,EAAA,OAAO,CAAG,EAAA,MAAA,CAAA,kBAAA,EAA2B,gBAAiB,CAAA,IAAI,EAAE,WAAY,EAAA,CAAA,UAAA,CAAA,CAAA;AACzE,CAAA,CAAA;AAMO,SAAS,gBAAmB,GAAA;AAClC,EAAO,OAAA;AAAA,IACN,IAAM,EAAA,WAAA;AAAA,IACN,OAAA,EAAS,CAAC,IAAiB,KAAA;AAC1B,MAAI,IAAA,CAAC,qBAAqB,IAAI,CAAA;AAAG,QAAA,OAAA;AACjC,MAAO,OAAA;AAAA,QACN,IAAA;AAAA,QACA,IAAM,EAAA,YAAA;AAAA,QACN,WAAA,EAAa,mBAAmB,IAAI,CAAA;AAAA,OACrC,CAAA;AAAA,KACD;AAAA,GACD,CAAA;AACD,CAAA;AAKA,eAAe;AAAA,EACd,gBAAA;AACD,CAAA;;;;"}
1
+ {"version":3,"file":"resolver.mjs","sources":["../../../../packages/components/resolver.ts"],"sourcesContent":["/**\n * TouchVue Chat 组件解析器\n * 用于支持 unplugin-auto-import 和 unplugin-vue-components 插件\n */\n\n// 组件库名称\nconst LIBRARY_NAME = '@touchvue/chat'\n// 组件前缀\nconst PREFIX = 'To'\n\n/**\n * 检查组件名称是否符合规则\n * @param name 组件名称\n * @returns 是否符合规则\n */\nconst isValidComponentName = (name: string): boolean => {\n\treturn name.startsWith(PREFIX)\n}\n\n/**\n * 获取组件名称(不带前缀)\n * @param name 组件名称\n * @returns 不带前缀的组件名称\n */\nconst getComponentName = (name: string): string => {\n\treturn name.slice(PREFIX.length)\n}\n\nconst getSideEffectsPath = (name: string, prefix: string = LIBRARY_NAME): string => {\n\treturn `${prefix}/theme/components/${getComponentName(name).toLowerCase()}/index.css`\n}\n\n/**\n * 组件解析器\n * 用于 unplugin-vue-components 插件\n */\nexport function TouchVueResolver() {\n\treturn {\n\t\ttype: 'component',\n\t\tresolve: (name: string) => {\n\t\t\tif (!isValidComponentName(name)) return\n\t\t\treturn {\n\t\t\t\tname,\n\t\t\t\tfrom: LIBRARY_NAME,\n\t\t\t\tsideEffects: getSideEffectsPath(name)\n\t\t\t}\n\t\t}\n\t}\n}\n\n/**\n * 默认导出所有解析器\n */\nexport default {\n\tTouchVueResolver\n}\n"],"names":[],"mappings":"AAMA,MAAM,YAAe,GAAA,gBAAA,CAAA;AAErB,MAAM,MAAS,GAAA,IAAA,CAAA;AAOf,MAAM,oBAAA,GAAuB,CAAC,IAA0B,KAAA;AACvD,EAAO,OAAA,IAAA,CAAK,WAAW,MAAM,CAAA,CAAA;AAC9B,CAAA,CAAA;AAOA,MAAM,gBAAA,GAAmB,CAAC,IAAyB,KAAA;AAClD,EAAO,OAAA,IAAA,CAAK,KAAM,CAAA,MAAA,CAAO,MAAM,CAAA,CAAA;AAChC,CAAA,CAAA;AAEA,MAAM,kBAAqB,GAAA,CAAC,IAAc,EAAA,MAAA,GAAiB,YAAyB,KAAA;AACnF,EAAA,OAAO,CAAG,EAAA,MAAA,CAAA,kBAAA,EAA2B,gBAAiB,CAAA,IAAI,EAAE,WAAY,EAAA,CAAA,UAAA,CAAA,CAAA;AACzE,CAAA,CAAA;AAMO,SAAS,gBAAmB,GAAA;AAClC,EAAO,OAAA;AAAA,IACN,IAAM,EAAA,WAAA;AAAA,IACN,OAAA,EAAS,CAAC,IAAiB,KAAA;AAC1B,MAAI,IAAA,CAAC,qBAAqB,IAAI,CAAA;AAAG,QAAA,OAAA;AACjC,MAAO,OAAA;AAAA,QACN,IAAA;AAAA,QACA,IAAM,EAAA,YAAA;AAAA,QACN,WAAA,EAAa,mBAAmB,IAAI,CAAA;AAAA,OACrC,CAAA;AAAA,KACD;AAAA,GACD,CAAA;AACD,CAAA;AAKA,eAAe;AAAA,EACd,gBAAA;AACD,CAAA;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"HelloChat.vue2.mjs","sources":["../../../../../../../packages/components/touchchat/component/AiRobot/HelloChat.vue"],"sourcesContent":["<script lang=\"ts\">\nconst itemsPerPage = 5\n\nimport { defineComponent as DO_defineComponent } from 'vue';\nexport default /*#__PURE__*/ DO_defineComponent({ name: 'HelloChat' });</script>\n<template>\r\n\t<div class=\"hello-chat\">\r\n\t\t<img src=\"../../img/aiAvatar.png\" alt=\"\" />\r\n\t\t<p class=\"title\">您好,我能帮您处理什么</p>\r\n\t\t<p class=\"sub-info\">作为您的智能伙伴,我既能帮您查账单、办业务,又能陪您聊天、学知识。</p>\r\n\t</div>\r\n\t<div class=\"function-buttons\">\r\n\t\t<ul>\r\n\t\t\t<li v-for=\"item in helloChatList\" :key=\"item.id\" @click=\"handleItemClick(item, '0')\">\r\n\t\t\t\t<img src=\"../../img/icon.png\" alt=\"{{ item.name }}\" class=\"icon\" />\r\n\t\t\t\t<span class=\"ellipsis-text\">{{ item.name }}</span>\r\n\t\t\t</li>\r\n\t\t</ul>\r\n\t</div>\r\n\t<div class=\"option-conter\">\r\n\t\t<div v-if=\"optionList.length > 0\" class=\"option-item item-1\">\r\n\t\t\t<div class=\"item-top\">\r\n\t\t\t\t<div class=\"item-1-left\">\r\n\t\t\t\t\t<p>猜你想所问</p>\r\n\t\t\t\t</div>\r\n\t\t\t\t<div class=\"item-1-right\" @click=\"handleChange\">\r\n\t\t\t\t\t<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"13\" viewBox=\"0 0 12 13\" fill=\"none\">\r\n\t\t\t\t\t\t<path d=\"M10.5 2.40796V6.40796\" stroke=\"#0077FA\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n\t\t\t\t\t\t<path d=\"M1.5 6.40747V10.4075\" stroke=\"#0077FA\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n\t\t\t\t\t\t<path d=\"M10.5 6.40747C10.5 3.9222 8.48528 1.90747 6 1.90747C4.72863 1.90747 3.5804 2.43471 2.76203 3.28247M1.5 6.40747C1.5 8.89275 3.51472 10.9075 6 10.9075C7.2139 10.9075 8.31555 10.4268 9.125 9.64545\" stroke=\"#0077FA\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n\t\t\t\t\t</svg>\r\n\t\t\t\t\t<span>换一换</span>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t\t<div class=\"item-bottom\">\r\n\t\t\t\t<ul>\r\n\t\t\t\t\t<li v-for=\"item in optionList\" :key=\"item.id\" @click=\"handleItemClick(item, '1')\">\r\n\t\t\t\t\t\t<span>{{ item.name }}</span>\r\n\t\t\t\t\t</li>\r\n\t\t\t\t</ul>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t\t<div v-if=\"optionTeam.length\" class=\"option-item item-2\">\r\n\t\t\t<ul>\r\n\t\t\t\t<li v-for=\"item in optionTeam\" :key=\"item.id\" @click=\"handleItemClick(item, '2')\">\r\n\t\t\t\t\t<p class=\"title\">{{ item.name }}</p>\r\n\t\t\t\t\t<p class=\"team\">\r\n\t\t\t\t\t\t<span class=\"content\">{{ item.subTitle }}</span>\r\n\t\t\t\t\t\t<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"17\" viewBox=\"0 0 16 17\" fill=\"none\">\r\n\t\t\t\t\t\t\t<g clip-path=\"url(#clip0_2450_2140)\">\r\n\t\t\t\t\t\t\t\t<path d=\"M8.00006 16.4075C12.4183 16.4075 16.0001 12.8258 16.0001 8.40747C16.0001 3.98919 12.4183 0.407471 8.00006 0.407471C3.58178 0.407471 6.10352e-05 3.98919 6.10352e-05 8.40747C6.10352e-05 12.8258 3.58178 16.4075 8.00006 16.4075Z\" fill=\"url(#paint0_linear_2450_2140)\" />\r\n\t\t\t\t\t\t\t\t<path d=\"M4.83057 8.57422H10.8306\" stroke=\"white\" stroke-width=\"1.3\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n\t\t\t\t\t\t\t\t<path d=\"M7.83057 5.57422L10.8306 8.57422L7.83057 11.5742\" stroke=\"white\" stroke-width=\"1.3\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n\t\t\t\t\t\t\t</g>\r\n\t\t\t\t\t\t\t<defs>\r\n\t\t\t\t\t\t\t\t<linearGradient id=\"paint0_linear_2450_2140\" x1=\"15.6001\" y1=\"14.9055\" x2=\"0.714348\" y2=\"14.9055\" gradientUnits=\"userSpaceOnUse\">\r\n\t\t\t\t\t\t\t\t\t<stop stop-color=\"#3B80FF\" />\r\n\t\t\t\t\t\t\t\t\t<stop offset=\"0.899038\" stop-color=\"#C8B6FF\" />\r\n\t\t\t\t\t\t\t\t</linearGradient>\r\n\t\t\t\t\t\t\t\t<clipPath id=\"clip0_2450_2140\">\r\n\t\t\t\t\t\t\t\t\t<rect width=\"16\" height=\"16\" fill=\"white\" transform=\"translate(0 0.407471)\" />\r\n\t\t\t\t\t\t\t\t</clipPath>\r\n\t\t\t\t\t\t\t</defs>\r\n\t\t\t\t\t\t</svg>\r\n\t\t\t\t\t</p>\r\n\t\t\t\t</li>\r\n\t\t\t</ul>\r\n\t\t</div>\r\n\t\t<div v-if=\"optionOther.length\" class=\"option-item item-3\">\r\n\t\t\t<ul>\r\n\t\t\t\t<li v-for=\"item in optionOther\" :key=\"item.id\" @click=\"handleItemClick(item, '3')\">\r\n\t\t\t\t\t<span>{{ item.name }}</span>\r\n\t\t\t\t</li>\r\n\t\t\t</ul>\r\n\t\t</div>\r\n\t</div>\r\n</template>\r\n\r\n<script setup lang=\"ts\">\r\nimport { inject, ref, computed } from 'vue'\r\n\r\n\r\n// 定义类型\r\ninterface HelloChatInfo {\r\n\tinfo1: any[]\r\n\tinfo2: any[]\r\n\tinfo3: any[]\r\n}\r\n\r\ntype HelloChatItem = { id: string; name: string }\r\n\r\n// 为注入的变量添加类型参数\r\nconst helloChatList = inject<HelloChatItem[]>('helloChatList', [])\r\nconst helloChatInfo = inject<HelloChatInfo>('helloChatInfo', {\r\n\tinfo1: [],\r\n\tinfo2: [],\r\n\tinfo3: []\r\n})\r\n\r\n// 添加当前页码状态,默认为0\r\nconst currentPage = ref(0)\r\n// 每页显示的项目数量\r\n\r\n\r\n// 获取完整的选项列表\r\nconst fullOptionList = ref(helloChatInfo.info1)\r\n\r\n// 计算当前显示的项目\\\r\nconst optionList = computed(() => {\r\n\tif (!fullOptionList.value.length) {\r\n\t\treturn []\r\n\t}\r\n\tconst startIndex = currentPage.value * itemsPerPage\r\n\treturn fullOptionList.value.slice(startIndex, startIndex + itemsPerPage) || []\r\n})\r\n\r\nconst optionTeam = ref(helloChatInfo.info2)\r\nconst optionOther = ref(helloChatInfo.info3)\r\n\r\n// 处理列表项点击事件\r\nconst emit = defineEmits(['handleItemClick'])\r\nconst handleItemClick = (item: HelloChatItem, type: string) => {\r\n\temit('handleItemClick', item, type)\r\n}\r\n\r\n// 实现换一换功能\r\nconst handleChange = () => {\r\n\t// 计算总页数\r\n\tconst totalPages = Math.ceil(fullOptionList.value.length / itemsPerPage)\r\n\t// 切换到下一页,如果是最后一页则回到第一页\r\n\tcurrentPage.value = (currentPage.value + 1) % totalPages\r\n}\r\n</script>\r\n\r\n<!-- <style lang=\"less\" scoped>\r\n@import '../style/HelloChatRobot.less';\r\n</style> -->\r\n"],"names":["DO_defineComponent","_createElementVNode","_createElementBlock","_Fragment","_renderList","_unref","_toDisplayString"],"mappings":"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"}
1
+ {"version":3,"file":"HelloChat.vue2.mjs","sources":["../../../../../../../packages/components/touchchat/component/AiRobot/HelloChat.vue"],"sourcesContent":["<script lang=\"ts\">\nconst itemsPerPage = 5\n\nimport { defineComponent as DO_defineComponent } from 'vue';\nexport default /*#__PURE__*/ DO_defineComponent({ name: 'HelloChat' });</script>\n<template>\n\t<div class=\"hello-chat\">\n\t\t<img src=\"../../img/aiAvatar.png\" alt=\"\" />\n\t\t<p class=\"title\">您好,我能帮您处理什么</p>\n\t\t<p class=\"sub-info\">作为您的智能伙伴,我既能帮您查账单、办业务,又能陪您聊天、学知识。</p>\n\t</div>\n\t<div class=\"function-buttons\">\n\t\t<ul>\n\t\t\t<li v-for=\"item in helloChatList\" :key=\"item.id\" @click=\"handleItemClick(item, '0')\">\n\t\t\t\t<img src=\"../../img/icon.png\" alt=\"{{ item.name }}\" class=\"icon\" />\n\t\t\t\t<span class=\"ellipsis-text\">{{ item.name }}</span>\n\t\t\t</li>\n\t\t</ul>\n\t</div>\n\t<div class=\"option-conter\">\n\t\t<div v-if=\"optionList.length > 0\" class=\"option-item item-1\">\n\t\t\t<div class=\"item-top\">\n\t\t\t\t<div class=\"item-1-left\">\n\t\t\t\t\t<p>猜你想所问</p>\n\t\t\t\t</div>\n\t\t\t\t<div class=\"item-1-right\" @click=\"handleChange\">\n\t\t\t\t\t<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"13\" viewBox=\"0 0 12 13\" fill=\"none\">\n\t\t\t\t\t\t<path d=\"M10.5 2.40796V6.40796\" stroke=\"#0077FA\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n\t\t\t\t\t\t<path d=\"M1.5 6.40747V10.4075\" stroke=\"#0077FA\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n\t\t\t\t\t\t<path d=\"M10.5 6.40747C10.5 3.9222 8.48528 1.90747 6 1.90747C4.72863 1.90747 3.5804 2.43471 2.76203 3.28247M1.5 6.40747C1.5 8.89275 3.51472 10.9075 6 10.9075C7.2139 10.9075 8.31555 10.4268 9.125 9.64545\" stroke=\"#0077FA\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n\t\t\t\t\t</svg>\n\t\t\t\t\t<span>换一换</span>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t\t<div class=\"item-bottom\">\n\t\t\t\t<ul>\n\t\t\t\t\t<li v-for=\"item in optionList\" :key=\"item.id\" @click=\"handleItemClick(item, '1')\">\n\t\t\t\t\t\t<span>{{ item.name }}</span>\n\t\t\t\t\t</li>\n\t\t\t\t</ul>\n\t\t\t</div>\n\t\t</div>\n\t\t<div v-if=\"optionTeam.length\" class=\"option-item item-2\">\n\t\t\t<ul>\n\t\t\t\t<li v-for=\"item in optionTeam\" :key=\"item.id\" @click=\"handleItemClick(item, '2')\">\n\t\t\t\t\t<p class=\"title\">{{ item.name }}</p>\n\t\t\t\t\t<p class=\"team\">\n\t\t\t\t\t\t<span class=\"content\">{{ item.subTitle }}</span>\n\t\t\t\t\t\t<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"17\" viewBox=\"0 0 16 17\" fill=\"none\">\n\t\t\t\t\t\t\t<g clip-path=\"url(#clip0_2450_2140)\">\n\t\t\t\t\t\t\t\t<path d=\"M8.00006 16.4075C12.4183 16.4075 16.0001 12.8258 16.0001 8.40747C16.0001 3.98919 12.4183 0.407471 8.00006 0.407471C3.58178 0.407471 6.10352e-05 3.98919 6.10352e-05 8.40747C6.10352e-05 12.8258 3.58178 16.4075 8.00006 16.4075Z\" fill=\"url(#paint0_linear_2450_2140)\" />\n\t\t\t\t\t\t\t\t<path d=\"M4.83057 8.57422H10.8306\" stroke=\"white\" stroke-width=\"1.3\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n\t\t\t\t\t\t\t\t<path d=\"M7.83057 5.57422L10.8306 8.57422L7.83057 11.5742\" stroke=\"white\" stroke-width=\"1.3\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n\t\t\t\t\t\t\t</g>\n\t\t\t\t\t\t\t<defs>\n\t\t\t\t\t\t\t\t<linearGradient id=\"paint0_linear_2450_2140\" x1=\"15.6001\" y1=\"14.9055\" x2=\"0.714348\" y2=\"14.9055\" gradientUnits=\"userSpaceOnUse\">\n\t\t\t\t\t\t\t\t\t<stop stop-color=\"#3B80FF\" />\n\t\t\t\t\t\t\t\t\t<stop offset=\"0.899038\" stop-color=\"#C8B6FF\" />\n\t\t\t\t\t\t\t\t</linearGradient>\n\t\t\t\t\t\t\t\t<clipPath id=\"clip0_2450_2140\">\n\t\t\t\t\t\t\t\t\t<rect width=\"16\" height=\"16\" fill=\"white\" transform=\"translate(0 0.407471)\" />\n\t\t\t\t\t\t\t\t</clipPath>\n\t\t\t\t\t\t\t</defs>\n\t\t\t\t\t\t</svg>\n\t\t\t\t\t</p>\n\t\t\t\t</li>\n\t\t\t</ul>\n\t\t</div>\n\t\t<div v-if=\"optionOther.length\" class=\"option-item item-3\">\n\t\t\t<ul>\n\t\t\t\t<li v-for=\"item in optionOther\" :key=\"item.id\" @click=\"handleItemClick(item, '3')\">\n\t\t\t\t\t<span>{{ item.name }}</span>\n\t\t\t\t</li>\n\t\t\t</ul>\n\t\t</div>\n\t</div>\n</template>\n\n<script setup lang=\"ts\">\nimport { inject, ref, computed } from 'vue'\n\n\n// 定义类型\ninterface HelloChatInfo {\n\tinfo1: any[]\n\tinfo2: any[]\n\tinfo3: any[]\n}\n\ntype HelloChatItem = { id: string; name: string }\n\n// 为注入的变量添加类型参数\nconst helloChatList = inject<HelloChatItem[]>('helloChatList', [])\nconst helloChatInfo = inject<HelloChatInfo>('helloChatInfo', {\n\tinfo1: [],\n\tinfo2: [],\n\tinfo3: []\n})\n\n// 添加当前页码状态,默认为0\nconst currentPage = ref(0)\n// 每页显示的项目数量\n\n\n// 获取完整的选项列表\nconst fullOptionList = ref(helloChatInfo.info1)\n\n// 计算当前显示的项目\\\nconst optionList = computed(() => {\n\tif (!fullOptionList.value.length) {\n\t\treturn []\n\t}\n\tconst startIndex = currentPage.value * itemsPerPage\n\treturn fullOptionList.value.slice(startIndex, startIndex + itemsPerPage) || []\n})\n\nconst optionTeam = ref(helloChatInfo.info2)\nconst optionOther = ref(helloChatInfo.info3)\n\n// 处理列表项点击事件\nconst emit = defineEmits(['handleItemClick'])\nconst handleItemClick = (item: HelloChatItem, type: string) => {\n\temit('handleItemClick', item, type)\n}\n\n// 实现换一换功能\nconst handleChange = () => {\n\t// 计算总页数\n\tconst totalPages = Math.ceil(fullOptionList.value.length / itemsPerPage)\n\t// 切换到下一页,如果是最后一页则回到第一页\n\tcurrentPage.value = (currentPage.value + 1) % totalPages\n}\n</script>\n\n<!-- <style lang=\"less\" scoped>\n@import '../style/HelloChatRobot.less';\n</style> -->\n"],"names":["DO_defineComponent","_createElementVNode","_createElementBlock","_Fragment","_renderList","_unref","_toDisplayString"],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  import _sfc_main from './letter.vue2.mjs';
2
2
  import _export_sfc from '../../../../../_virtual/_plugin-vue_export-helper.mjs';
3
3
 
4
- var Letter = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-6fd1b883"], ["__file", "letter.vue"]]);
4
+ var Letter = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-5bee9536"], ["__file", "letter.vue"]]);
5
5
 
6
6
  export { Letter as default };
7
7
  //# sourceMappingURL=letter.vue.mjs.map
@@ -180,14 +180,14 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
180
180
  innerHTML: displayContent.value
181
181
  }, null, 10, ["innerHTML"]),
182
182
  createCommentVNode(" \u6761\u4EF6\u663E\u793Aloading\uFF0C\u4EC5\u5728HTML\u6A21\u5F0F\u4E14\u6B63\u5728\u6253\u5B57\u65F6\u663E\u793A "),
183
- createCommentVNode(` <div v-if="isTyping" class="typewriter-loading">\r
184
- <span class="loading-dot" :style="{ animationDelay: '0ms' }"></span>\r
185
- <span class="loading-dot" :style="{ animationDelay: '200ms' }"></span>\r
186
- <span class="loading-dot" :style="{ animationDelay: '400ms' }"></span>\r
187
- <span class="loading-text">{{ loadingText ?? '\u6B63\u5728\u6E32\u67D3\u5185\u5BB9' }}</span>\r
188
- <span class="loading-dot" :style="{ animationDelay: '0ms' }"></span>\r
189
- <span class="loading-dot" :style="{ animationDelay: '200ms' }"></span>\r
190
- <span class="loading-dot" :style="{ animationDelay: '400ms' }"></span>\r
183
+ createCommentVNode(` <div v-if="isTyping" class="typewriter-loading">
184
+ <span class="loading-dot" :style="{ animationDelay: '0ms' }"></span>
185
+ <span class="loading-dot" :style="{ animationDelay: '200ms' }"></span>
186
+ <span class="loading-dot" :style="{ animationDelay: '400ms' }"></span>
187
+ <span class="loading-text">{{ loadingText ?? '\u6B63\u5728\u6E32\u67D3\u5185\u5BB9' }}</span>
188
+ <span class="loading-dot" :style="{ animationDelay: '0ms' }"></span>
189
+ <span class="loading-dot" :style="{ animationDelay: '200ms' }"></span>
190
+ <span class="loading-dot" :style="{ animationDelay: '400ms' }"></span>
191
191
  </div> `)
192
192
  ],
193
193
  2
@@ -1 +1 @@
1
- {"version":3,"file":"letter.vue2.mjs","sources":["../../../../../../../packages/components/touchchat/component/AiRobot/letter.vue"],"sourcesContent":["<script lang=\"ts\">\nimport { defineComponent as DO_defineComponent } from 'vue';\nexport default /*#__PURE__*/ DO_defineComponent({ name: 'Touchletter' });\n</script>\n<template>\r\n\t<div class=\"typewriter-container\" :class=\"isTyping ? 'loading-container' : ''\">\r\n\t\t<div\r\n\t\t\tclass=\"typewriter-content\"\r\n\t\t\t:class=\"{\r\n\t\t\t\t'markdown-content': currentType === 'markdown',\r\n\t\t\t\t'html-content': currentType === 'html'\r\n\t\t\t}\"\r\n\t\t\tv-html=\"displayContent\"\r\n\t\t/>\r\n\t\t<!-- 条件显示loading,仅在HTML模式且正在打字时显示 -->\r\n\t\t<!-- <div v-if=\"isTyping\" class=\"typewriter-loading\">\r\n\t\t\t<span class=\"loading-dot\" :style=\"{ animationDelay: '0ms' }\"></span>\r\n\t\t\t<span class=\"loading-dot\" :style=\"{ animationDelay: '200ms' }\"></span>\r\n\t\t\t<span class=\"loading-dot\" :style=\"{ animationDelay: '400ms' }\"></span>\r\n\t\t\t<span class=\"loading-text\">{{ loadingText ?? '正在渲染内容' }}</span>\r\n\t\t\t<span class=\"loading-dot\" :style=\"{ animationDelay: '0ms' }\"></span>\r\n\t\t\t<span class=\"loading-dot\" :style=\"{ animationDelay: '200ms' }\"></span>\r\n\t\t\t<span class=\"loading-dot\" :style=\"{ animationDelay: '400ms' }\"></span>\r\n\t\t</div> -->\r\n\t</div>\r\n</template>\r\n\r\n<script setup lang=\"ts\">\r\nimport { ref, computed, onMounted, watch, Ref, onUnmounted, inject } from 'vue'\r\n// import { marked } from 'marked';\r\n\r\n// DOMPurify 模块缓存\r\nlet DOMPurifyModule: any = null\r\n\r\n// 动态加载 DOMPurify\r\nconst loadDOMPurify = async () => {\r\n\tif (!DOMPurifyModule) {\r\n\t\tif (typeof window !== 'undefined') {\r\n\t\t\tDOMPurifyModule = await import('dompurify')\r\n\t\t}\r\n\t}\r\n\treturn DOMPurifyModule?.default || null\r\n}\r\n\r\n\r\n\r\ntype ContentType = 'text' | 'markdown' | 'html'\r\n\r\nconst props = defineProps<{\r\n\tdata: any\r\n\tspeed?: number\r\n\tcontentType?: ContentType | 'auto'\r\n\t// onComplete?: () => void\r\n\tsanitizeHtml?: boolean\r\n\tloadingText?: string\r\n}>()\r\n\r\nconst emits = defineEmits<{\r\n\t(e: 'complete'): void\r\n\t(e: 'start'): void\r\n}>()\r\n\r\nconst injectSpeed = inject<number>('speed', 10)\r\n\r\n// 默认值处理\r\nconst speed = computed(() => Math.max(1, props.speed || injectSpeed || 10))\r\nconst sanitizeHtml = computed(() => props.sanitizeHtml !== false)\r\n// const loadingText = computed(() => props.loadingText || '正在渲染内容...')\r\n\r\n// 内部状态\r\nconst currentIndex = ref(0)\r\nconst validContent = ref('')\r\nconst isTyping = ref(false)\r\nconst timer: Ref<number | null> = ref(null)\r\nconst tagStack = ref<string[]>([])\r\n\r\n// 内容类型检测与处理\r\nconst detectContentType = (content: string): ContentType => {\r\n\tif (/<\\/?[a-z][\\s\\S]*>/i.test(content)) {\r\n\t\treturn 'html'\r\n\t}\r\n\tif (/^#{1,6}\\s+/.test(content) || /\\*\\*.*\\*\\*/.test(content) || /```/.test(content)) {\r\n\t\treturn 'markdown'\r\n\t}\r\n\treturn 'text'\r\n}\r\n\r\nconst currentType = computed<ContentType>(() => {\r\n\tif (props.contentType && props.contentType !== 'auto') {\r\n\t\treturn props.contentType\r\n\t}\r\n\treturn detectContentType(props.data)\r\n})\r\n\r\n// 显示内容处理\r\nconst displayContent = computed(() => {\r\n\tlet content = validContent.value\r\n\tswitch (currentType.value) {\r\n\t\tcase 'html':\r\n\t\t\tif (sanitizeHtml.value && typeof window !== 'undefined') {\r\n\t\t\t\t// 动态加载并使用 DOMPurify\r\n\t\t\t\treturn DOMPurifyModule ? DOMPurifyModule.sanitize(content) : content\r\n\t\t\t}\r\n\t\t\treturn content\r\n\t\t// case 'markdown':\r\n\t\t// \treturn marked.parse(content);\r\n\t\tcase 'text':\r\n\t\t\treturn content.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/\\n/g, '<br>').replace(/ {2}/g, '&nbsp;&nbsp;')\r\n\t\tdefault:\r\n\t\t\treturn content\r\n\t}\r\n})\r\n\r\n// 打字间隔计算\r\nconst getInterval = (isTag: boolean) => {\r\n\tconst baseInterval = 1000 / speed.value\r\n\treturn baseInterval * (isTag ? 1.2 : 0.8 + Math.random() * 0.4)\r\n}\r\n\r\n// 标签处理工具函数\r\nconst isSelfClosingTag = (tag: string) => {\r\n\tconst selfClosingTags = ['area', 'base', 'br', 'col', 'embed', 'hr', 'img', 'input', 'link', 'meta', 'param', 'source', 'track', 'wbr']\r\n\tconst tagNameMatch = tag.match(/<\\/?([a-z0-9]+)/i)\r\n\tif (tagNameMatch && tagNameMatch[1]) {\r\n\t\tconst tagName = tagNameMatch[1].toLowerCase()\r\n\t\treturn selfClosingTags.includes(tagName) || tag.endsWith('/>')\r\n\t}\r\n\treturn false\r\n}\r\n\r\nconst processTag = (tag: string) => {\r\n\tif (tag.startsWith('</')) {\r\n\t\tconst tagName = tag.match(/<\\/([a-z0-9]+)/i)?.[1]?.toLowerCase()\r\n\t\tif (tagName && tagStack.value.at(-1) === tagName) {\r\n\t\t\ttagStack.value.pop()\r\n\t\t}\r\n\t} else if (tag.startsWith('<') && !isSelfClosingTag(tag)) {\r\n\t\tconst tagName = tag.match(/<([a-z0-9]+)/i)?.[1]?.toLowerCase()\r\n\t\tif (tagName) {\r\n\t\t\ttagStack.value.push(tagName)\r\n\t\t}\r\n\t}\r\n}\r\n\r\n// 核心打字逻辑\r\nconst typeNext = () => {\r\n\tif (currentIndex.value >= props.data.length) {\r\n\t\twhile (tagStack.value.length > 0) {\r\n\t\t\tconst tag = tagStack.value.pop()\r\n\t\t\tvalidContent.value += `</${tag}>`\r\n\t\t}\r\n\t\tcompleteTyping()\r\n\t\treturn\r\n\t}\r\n\r\n\tconst currentChar = props.data[currentIndex.value]\r\n\tlet nextIndex = currentIndex.value\r\n\tlet newContent = ''\r\n\tlet isTag = false\r\n\r\n\tif (currentChar === '<') {\r\n\t\tisTag = true\r\n\t\tconst endIndex = props.data.indexOf('>', currentIndex.value)\r\n\t\tif (endIndex === -1) {\r\n\t\t\tnextIndex = currentIndex.value + 1\r\n\t\t\tnewContent = currentChar\r\n\t\t} else {\r\n\t\t\tnextIndex = endIndex + 1\r\n\t\t\tnewContent = props.data.substring(currentIndex.value, nextIndex)\r\n\t\t\tprocessTag(newContent)\r\n\t\t}\r\n\t} else {\r\n\t\tnextIndex = currentIndex.value + 1\r\n\t\tnewContent = currentChar\r\n\t}\r\n\r\n\tcurrentIndex.value = nextIndex\r\n\tvalidContent.value += newContent\r\n\ttimer.value = window.setTimeout(typeNext, getInterval(isTag))\r\n}\r\n\r\n// 控制方法\r\nconst startTyping = () => {\r\n\tif (isTyping.value || currentIndex.value >= props.data.length) return\r\n\tisTyping.value = true\r\n\temits('start')\r\n\ttypeNext()\r\n}\r\n\r\nconst stopTyping = () => {\r\n\tif (timer.value) {\r\n\t\tclearTimeout(timer.value)\r\n\t\ttimer.value = null\r\n\t\tisTyping.value = false\r\n\t}\r\n}\r\n\r\nconst resetTyping = () => {\r\n\tstopTyping()\r\n\tcurrentIndex.value = 0\r\n\tvalidContent.value = ''\r\n\ttagStack.value = []\r\n}\r\n\r\nconst completeTyping = () => {\r\n\tstopTyping()\r\n\t// props.onComplete?.()\r\n\t// complete\r\n\temits('complete')\r\n}\r\n\r\n// 监听内容变化\r\nwatch(\r\n\t() => props.data,\r\n\t() => {\r\n\t\tresetTyping()\r\n\t\tstartTyping()\r\n\t},\r\n\t{ immediate: true }\r\n)\r\n\r\nwatch(\r\n\t() => props.contentType,\r\n\t() => {\r\n\t\tvalidContent.value = props.data.substring(0, currentIndex.value)\r\n\t}\r\n)\r\n\r\nonMounted(async () => {\r\n\tif (currentIndex.value === 0) {\r\n\t\tstartTyping()\r\n\t}\r\n\tawait loadDOMPurify()\r\n})\r\n\r\nonUnmounted(() => stopTyping())\r\n\r\ndefineExpose({ startTyping, stopTyping, resetTyping, currentIndex, isTyping })\r\n</script>\r\n\r\n<style scoped>\r\n.typewriter-container {\r\n\tposition: relative;\r\n}\r\n.loading-container {\r\n\tmin-height: 40px;\r\n}\r\n\r\n/* .typewriter-content {\r\n\twhite-space: pre-wrap;\r\n\tword-break: break-word;\r\n\tline-height: 1.6;\r\n\tfont-family: 'Courier New', Courier, monospace;\r\n} */\r\n\r\n/* loading样式 */\r\n.typewriter-loading {\r\n\tmargin-top: 12px;\r\n\tdisplay: flex;\r\n\talign-items: center;\r\n\tgap: 8px;\r\n\tcolor: #666;\r\n\tfont-size: 14px;\r\n\tline-height: 1;\r\n\tpadding: 8px 0;\r\n}\r\n\r\n.loading-dot {\r\n\tdisplay: inline-block;\r\n\twidth: 8px;\r\n\theight: 8px;\r\n\tborder-radius: 50%;\r\n\tbackground-color: #666;\r\n\tanimation: bounce 1.4s infinite ease-in-out both;\r\n}\r\n\r\n.loading-text {\r\n\tuser-select: none;\r\n}\r\n\r\n@keyframes bounce {\r\n\t0%,\r\n\t80%,\r\n\t100% {\r\n\t\ttransform: scale(0);\r\n\t}\r\n\r\n\t40% {\r\n\t\ttransform: scale(1);\r\n\t}\r\n}\r\n\r\n/* 内容样式 */\r\n.markdown-content {\r\n\tcolor: #333;\r\n}\r\n\r\n.markdown-content h1,\r\n.markdown-content h2 {\r\n\tmargin: 1em 0 0.5em;\r\n}\r\n\r\n.markdown-content p {\r\n\tmargin: 0.5em 0;\r\n}\r\n\r\n.markdown-content code {\r\n\tbackground: #f0f0f0;\r\n\tpadding: 0.2em 0.4em;\r\n\tborder-radius: 4px;\r\n}\r\n\r\n/* .html-content {\r\n\t\r\n} */\r\n</style>\r\n"],"names":["DO_defineComponent","_createElementBlock","_normalizeClass","_createElementVNode","_createCommentVNode"],"mappings":"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"}
1
+ {"version":3,"file":"letter.vue2.mjs","sources":["../../../../../../../packages/components/touchchat/component/AiRobot/letter.vue"],"sourcesContent":["<script lang=\"ts\">\nimport { defineComponent as DO_defineComponent } from 'vue';\nexport default /*#__PURE__*/ DO_defineComponent({ name: 'Touchletter' });\n</script>\n<template>\n\t<div class=\"typewriter-container\" :class=\"isTyping ? 'loading-container' : ''\">\n\t\t<div\n\t\t\tclass=\"typewriter-content\"\n\t\t\t:class=\"{\n\t\t\t\t'markdown-content': currentType === 'markdown',\n\t\t\t\t'html-content': currentType === 'html'\n\t\t\t}\"\n\t\t\tv-html=\"displayContent\"\n\t\t/>\n\t\t<!-- 条件显示loading,仅在HTML模式且正在打字时显示 -->\n\t\t<!-- <div v-if=\"isTyping\" class=\"typewriter-loading\">\n\t\t\t<span class=\"loading-dot\" :style=\"{ animationDelay: '0ms' }\"></span>\n\t\t\t<span class=\"loading-dot\" :style=\"{ animationDelay: '200ms' }\"></span>\n\t\t\t<span class=\"loading-dot\" :style=\"{ animationDelay: '400ms' }\"></span>\n\t\t\t<span class=\"loading-text\">{{ loadingText ?? '正在渲染内容' }}</span>\n\t\t\t<span class=\"loading-dot\" :style=\"{ animationDelay: '0ms' }\"></span>\n\t\t\t<span class=\"loading-dot\" :style=\"{ animationDelay: '200ms' }\"></span>\n\t\t\t<span class=\"loading-dot\" :style=\"{ animationDelay: '400ms' }\"></span>\n\t\t</div> -->\n\t</div>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref, computed, onMounted, watch, Ref, onUnmounted, inject } from 'vue'\n// import { marked } from 'marked';\n\n// DOMPurify 模块缓存\nlet DOMPurifyModule: any = null\n\n// 动态加载 DOMPurify\nconst loadDOMPurify = async () => {\n\tif (!DOMPurifyModule) {\n\t\tif (typeof window !== 'undefined') {\n\t\t\tDOMPurifyModule = await import('dompurify')\n\t\t}\n\t}\n\treturn DOMPurifyModule?.default || null\n}\n\n\n\ntype ContentType = 'text' | 'markdown' | 'html'\n\nconst props = defineProps<{\n\tdata: any\n\tspeed?: number\n\tcontentType?: ContentType | 'auto'\n\t// onComplete?: () => void\n\tsanitizeHtml?: boolean\n\tloadingText?: string\n}>()\n\nconst emits = defineEmits<{\n\t(e: 'complete'): void\n\t(e: 'start'): void\n}>()\n\nconst injectSpeed = inject<number>('speed', 10)\n\n// 默认值处理\nconst speed = computed(() => Math.max(1, props.speed || injectSpeed || 10))\nconst sanitizeHtml = computed(() => props.sanitizeHtml !== false)\n// const loadingText = computed(() => props.loadingText || '正在渲染内容...')\n\n// 内部状态\nconst currentIndex = ref(0)\nconst validContent = ref('')\nconst isTyping = ref(false)\nconst timer: Ref<number | null> = ref(null)\nconst tagStack = ref<string[]>([])\n\n// 内容类型检测与处理\nconst detectContentType = (content: string): ContentType => {\n\tif (/<\\/?[a-z][\\s\\S]*>/i.test(content)) {\n\t\treturn 'html'\n\t}\n\tif (/^#{1,6}\\s+/.test(content) || /\\*\\*.*\\*\\*/.test(content) || /```/.test(content)) {\n\t\treturn 'markdown'\n\t}\n\treturn 'text'\n}\n\nconst currentType = computed<ContentType>(() => {\n\tif (props.contentType && props.contentType !== 'auto') {\n\t\treturn props.contentType\n\t}\n\treturn detectContentType(props.data)\n})\n\n// 显示内容处理\nconst displayContent = computed(() => {\n\tlet content = validContent.value\n\tswitch (currentType.value) {\n\t\tcase 'html':\n\t\t\tif (sanitizeHtml.value && typeof window !== 'undefined') {\n\t\t\t\t// 动态加载并使用 DOMPurify\n\t\t\t\treturn DOMPurifyModule ? DOMPurifyModule.sanitize(content) : content\n\t\t\t}\n\t\t\treturn content\n\t\t// case 'markdown':\n\t\t// \treturn marked.parse(content);\n\t\tcase 'text':\n\t\t\treturn content.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/\\n/g, '<br>').replace(/ {2}/g, '&nbsp;&nbsp;')\n\t\tdefault:\n\t\t\treturn content\n\t}\n})\n\n// 打字间隔计算\nconst getInterval = (isTag: boolean) => {\n\tconst baseInterval = 1000 / speed.value\n\treturn baseInterval * (isTag ? 1.2 : 0.8 + Math.random() * 0.4)\n}\n\n// 标签处理工具函数\nconst isSelfClosingTag = (tag: string) => {\n\tconst selfClosingTags = ['area', 'base', 'br', 'col', 'embed', 'hr', 'img', 'input', 'link', 'meta', 'param', 'source', 'track', 'wbr']\n\tconst tagNameMatch = tag.match(/<\\/?([a-z0-9]+)/i)\n\tif (tagNameMatch && tagNameMatch[1]) {\n\t\tconst tagName = tagNameMatch[1].toLowerCase()\n\t\treturn selfClosingTags.includes(tagName) || tag.endsWith('/>')\n\t}\n\treturn false\n}\n\nconst processTag = (tag: string) => {\n\tif (tag.startsWith('</')) {\n\t\tconst tagName = tag.match(/<\\/([a-z0-9]+)/i)?.[1]?.toLowerCase()\n\t\tif (tagName && tagStack.value.at(-1) === tagName) {\n\t\t\ttagStack.value.pop()\n\t\t}\n\t} else if (tag.startsWith('<') && !isSelfClosingTag(tag)) {\n\t\tconst tagName = tag.match(/<([a-z0-9]+)/i)?.[1]?.toLowerCase()\n\t\tif (tagName) {\n\t\t\ttagStack.value.push(tagName)\n\t\t}\n\t}\n}\n\n// 核心打字逻辑\nconst typeNext = () => {\n\tif (currentIndex.value >= props.data.length) {\n\t\twhile (tagStack.value.length > 0) {\n\t\t\tconst tag = tagStack.value.pop()\n\t\t\tvalidContent.value += `</${tag}>`\n\t\t}\n\t\tcompleteTyping()\n\t\treturn\n\t}\n\n\tconst currentChar = props.data[currentIndex.value]\n\tlet nextIndex = currentIndex.value\n\tlet newContent = ''\n\tlet isTag = false\n\n\tif (currentChar === '<') {\n\t\tisTag = true\n\t\tconst endIndex = props.data.indexOf('>', currentIndex.value)\n\t\tif (endIndex === -1) {\n\t\t\tnextIndex = currentIndex.value + 1\n\t\t\tnewContent = currentChar\n\t\t} else {\n\t\t\tnextIndex = endIndex + 1\n\t\t\tnewContent = props.data.substring(currentIndex.value, nextIndex)\n\t\t\tprocessTag(newContent)\n\t\t}\n\t} else {\n\t\tnextIndex = currentIndex.value + 1\n\t\tnewContent = currentChar\n\t}\n\n\tcurrentIndex.value = nextIndex\n\tvalidContent.value += newContent\n\ttimer.value = window.setTimeout(typeNext, getInterval(isTag))\n}\n\n// 控制方法\nconst startTyping = () => {\n\tif (isTyping.value || currentIndex.value >= props.data.length) return\n\tisTyping.value = true\n\temits('start')\n\ttypeNext()\n}\n\nconst stopTyping = () => {\n\tif (timer.value) {\n\t\tclearTimeout(timer.value)\n\t\ttimer.value = null\n\t\tisTyping.value = false\n\t}\n}\n\nconst resetTyping = () => {\n\tstopTyping()\n\tcurrentIndex.value = 0\n\tvalidContent.value = ''\n\ttagStack.value = []\n}\n\nconst completeTyping = () => {\n\tstopTyping()\n\t// props.onComplete?.()\n\t// complete\n\temits('complete')\n}\n\n// 监听内容变化\nwatch(\n\t() => props.data,\n\t() => {\n\t\tresetTyping()\n\t\tstartTyping()\n\t},\n\t{ immediate: true }\n)\n\nwatch(\n\t() => props.contentType,\n\t() => {\n\t\tvalidContent.value = props.data.substring(0, currentIndex.value)\n\t}\n)\n\nonMounted(async () => {\n\tif (currentIndex.value === 0) {\n\t\tstartTyping()\n\t}\n\tawait loadDOMPurify()\n})\n\nonUnmounted(() => stopTyping())\n\ndefineExpose({ startTyping, stopTyping, resetTyping, currentIndex, isTyping })\n</script>\n\n<style scoped>\n.typewriter-container {\n\tposition: relative;\n}\n.loading-container {\n\tmin-height: 40px;\n}\n\n/* .typewriter-content {\n\twhite-space: pre-wrap;\n\tword-break: break-word;\n\tline-height: 1.6;\n\tfont-family: 'Courier New', Courier, monospace;\n} */\n\n/* loading样式 */\n.typewriter-loading {\n\tmargin-top: 12px;\n\tdisplay: flex;\n\talign-items: center;\n\tgap: 8px;\n\tcolor: #666;\n\tfont-size: 14px;\n\tline-height: 1;\n\tpadding: 8px 0;\n}\n\n.loading-dot {\n\tdisplay: inline-block;\n\twidth: 8px;\n\theight: 8px;\n\tborder-radius: 50%;\n\tbackground-color: #666;\n\tanimation: bounce 1.4s infinite ease-in-out both;\n}\n\n.loading-text {\n\tuser-select: none;\n}\n\n@keyframes bounce {\n\t0%,\n\t80%,\n\t100% {\n\t\ttransform: scale(0);\n\t}\n\n\t40% {\n\t\ttransform: scale(1);\n\t}\n}\n\n/* 内容样式 */\n.markdown-content {\n\tcolor: #333;\n}\n\n.markdown-content h1,\n.markdown-content h2 {\n\tmargin: 1em 0 0.5em;\n}\n\n.markdown-content p {\n\tmargin: 0.5em 0;\n}\n\n.markdown-content code {\n\tbackground: #f0f0f0;\n\tpadding: 0.2em 0.4em;\n\tborder-radius: 4px;\n}\n\n/* .html-content {\n\t\n} */\n</style>\n"],"names":["DO_defineComponent","_createElementBlock","_normalizeClass","_createElementVNode","_createCommentVNode"],"mappings":"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"}
@@ -1,6 +1,7 @@
1
1
  import { defineComponent, ref, onMounted, onUnmounted, openBlock, createElementBlock, createElementVNode, Fragment, renderList, createBlock, withDirectives, vShow } from 'vue';
2
2
  import ImageFile from './ImageFile.vue.mjs';
3
3
  import PDFFile from './PDFFile.vue.mjs';
4
+ import VideoFile from './VideoFile.vue.mjs';
4
5
 
5
6
  var _sfc_main = /* @__PURE__ */ defineComponent({
6
7
  __name: "FileContent",
@@ -102,7 +103,7 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
102
103
  (openBlock(true), createElementBlock(
103
104
  Fragment,
104
105
  null,
105
- renderList(__props.fileList, (item, index) => {
106
+ renderList(_ctx.fileList, (item, index) => {
106
107
  return openBlock(), createElementBlock(
107
108
  Fragment,
108
109
  {
@@ -113,13 +114,17 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
113
114
  key: 0,
114
115
  item,
115
116
  index,
116
- "has-colse": __props.hasColse,
117
+ "has-colse": _ctx.hasColse,
117
118
  onColse: handleColse
118
- }, null, 8, ["item", "index", "has-colse"])) : (openBlock(), createBlock(PDFFile, {
119
+ }, null, 8, ["item", "index", "has-colse"])) : item.fileType.includes("mp4") ? (openBlock(), createBlock(VideoFile, {
119
120
  key: 1,
120
121
  item,
122
+ index
123
+ }, null, 8, ["item", "index"])) : (openBlock(), createBlock(PDFFile, {
124
+ key: 2,
125
+ item,
121
126
  index,
122
- "has-colse": __props.hasColse,
127
+ "has-colse": _ctx.hasColse,
123
128
  onColse: handleColse
124
129
  }, null, 8, ["item", "index", "has-colse"]))
125
130
  ],
@@ -1 +1 @@
1
- {"version":3,"file":"FileContent.vue2.mjs","sources":["../../../../../../packages/components/touchchat/component/FileContent.vue"],"sourcesContent":["<template>\n\t<div class=\"file-content\">\n\t\t<div ref=\"scrollContainer\" class=\"file-content-scroll\">\n\t\t\t<template v-for=\"(item, index) in fileList\" :key=\"item.id\">\n\t\t\t\t<ImageFile v-if=\"item.fileType.includes('image')\" :item=\"item\" :index=\"index\" :has-colse=\"hasColse\" @colse=\"handleColse\" />\n\t\t\t\t<PDFFile v-else :item=\"item\" :index=\"index\" :has-colse=\"hasColse\" @colse=\"handleColse\" />\n\t\t\t</template>\n\t\t</div>\n\t\t<div v-show=\"showRightTip\" class=\"file-content-right-tip\">\n\t\t\t<div class=\"file-content-svg\" @click=\"scrollRightFn\">\n\t\t\t\t<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"5\" height=\"9\" viewBox=\"0 0 5 9\" fill=\"none\">\n\t\t\t\t\t<path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M1.01036 0.877808L4.5968 4.46425C4.80562 4.67307 4.80562 5.01164 4.5968 5.22046L1.01036 8.8069L0.25415 8.05069L3.46248 4.84235L0.25415 1.63402L1.01036 0.877808Z\" fill=\"#1D2129\" />\n\t\t\t\t</svg>\n\t\t\t</div>\n\t\t</div>\n\t\t<div v-show=\"showLeftTip\" class=\"file-content-left-tip\">\n\t\t\t<div class=\"file-content-svg\" @click=\"scrollLeftFn\">\n\t\t\t\t<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"5\" height=\"9\" viewBox=\"0 0 5 9\" fill=\"none\">\n\t\t\t\t\t<path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M1.01036 0.877808L4.5968 4.46425C4.80562 4.67307 4.80562 5.01164 4.5968 5.22046L1.01036 8.8069L0.25415 8.05069L3.46248 4.84235L0.25415 1.63402L1.01036 0.877808Z\" fill=\"#1D2129\" />\n\t\t\t\t</svg>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</template>\n<script lang=\"ts\" setup>\nimport ImageFile from './ImageFile.vue'\nimport PDFFile from './PDFFile.vue'\nimport { ref, onMounted, onUnmounted } from 'vue'\nimport type { FileItem } from '../src/AiChat/Chat/types'\n\nconst showRightTip = ref(false)\nconst showLeftTip = ref(false)\nconst scrollDistance = ref(256) // 每次滚动的距离\nconst scrollContainer = ref<HTMLDivElement | null>(null)\n\nconst props = defineProps<{\n\tfileList: FileItem[]\n\thasColse: boolean\n\ttype: string\n}>()\nconst emits = defineEmits<{\n\t(e: 'colse', id: string): void\n\t(e: 'userMessageFileList', value: FileItem, index: number): void\n}>()\n\nlet edgeDetectionDebounce: NodeJS.Timeout | null = null\n\n// 处理鼠标滚轮事件,将纵向滚动转为横向滚动\nconst handleWheel = (e: WheelEvent) => {\n\tif (!scrollContainer.value) return\n\n\t// 阻止默认的纵向滚动\n\te.preventDefault()\n\tshowRightTip.value = true\n\tshowLeftTip.value = true\n\tconst { scrollLeft, clientWidth, scrollWidth } = scrollContainer.value\n\n\t// 左边缘检测(允许1px的误差)\n\tif (scrollLeft <= 1) {\n\t\tshowLeftTip.value = false\n\t}\n\n\t// 右边缘检测(允许1px的误差)\n\tif (scrollLeft + clientWidth >= scrollWidth - 1) {\n\t\tshowRightTip.value = false\n\t}\n\n\t// 计算滚动距离,添加一些乘数使滚动更自然\n\tconst scrollAmount = e.deltaY * 0.8\n\n\t// 平滑滚动\n\tscrollContainer.value.scrollBy({\n\t\tleft: scrollAmount,\n\t\tbehavior: 'smooth'\n\t})\n}\n\nconst handleScroll = (e: WheelEvent) => {\n\t// 防抖处理,避免滚动过程中频繁触发\n\tif (edgeDetectionDebounce) {\n\t\tclearTimeout(edgeDetectionDebounce)\n\t}\n\n\tedgeDetectionDebounce = setTimeout(() => {\n\t\thandleWheel(e)\n\t}, 50) // 50ms的防抖延迟\n}\n\n// 向左滚动(模拟向上滚轮事件)\nconst scrollLeftFn = () => {\n\tif (!showLeftTip.value || !scrollContainer.value) return\n\n\t// 模拟向上滚动的滚轮事件(deltaY 为负值)\n\tconst mockEvent = new WheelEvent('wheel', {\n\t\tdeltaY: -scrollDistance.value, // 负值表示向上滚动,我们将其转换为向左滚动\n\t\tbubbles: true,\n\t\tcancelable: true\n\t})\n\n\t// 复用 handleWheel 方法处理模拟事件\n\thandleWheel(mockEvent)\n}\n\n// 向右滚动(模拟向下滚轮事件)\nconst scrollRightFn = () => {\n\tif (!showRightTip.value || !scrollContainer.value) return\n\n\t// 模拟向下滚动的滚轮事件(deltaY 为正值)\n\tconst mockEvent = new WheelEvent('wheel', {\n\t\tdeltaY: scrollDistance.value, // 正值表示向下滚动,我们将其转换为向右滚动\n\t\tbubbles: true,\n\t\tcancelable: true\n\t})\n\n\t// 复用 handleWheel 方法处理模拟事件\n\thandleWheel(mockEvent)\n}\n\nconst handleColse = (id: string) => {\n\temits('colse', id)\n}\n\nconst init = () => {\n\tif (props.type === 'UserMessage' && props.fileList.length > 0) {\n\t\tconst list = props.fileList\n\t\tlist.forEach((item, index) => {\n\t\t\temits('userMessageFileList', item, index)\n\t\t})\n\t}\n}\n\nonMounted(() => {\n\tif (scrollContainer.value) {\n\t\t// 添加事件监听,passive: false 允许我们调用 preventDefault\n\t\tscrollContainer.value.addEventListener('wheel', handleScroll, { passive: false })\n\t}\n\tinit()\n})\n\nonUnmounted(() => {\n\tif (scrollContainer.value) {\n\t\tscrollContainer.value.removeEventListener('wheel', handleScroll)\n\t}\n})\n</script>\n"],"names":["_createElementBlock","_createElementVNode","_openBlock","_Fragment","_renderList","_createBlock"],"mappings":"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"}
1
+ {"version":3,"file":"FileContent.vue2.mjs","sources":["../../../../../../packages/components/touchchat/component/FileContent.vue"],"sourcesContent":["<template>\n\t<div class=\"file-content\">\n\t\t<div ref=\"scrollContainer\" class=\"file-content-scroll\">\n\t\t\t<template v-for=\"(item, index) in fileList\" :key=\"item.id\">\n\t\t\t\t<ImageFile v-if=\"item.fileType.includes('image')\" :item=\"item\" :index=\"index\" :has-colse=\"hasColse\" @colse=\"handleColse\" />\n\t\t\t\t<VideoFile v-else-if=\"item.fileType.includes('mp4')\" :item=\"item\" :index=\"index\" />\n\t\t\t\t<PDFFile v-else :item=\"item\" :index=\"index\" :has-colse=\"hasColse\" @colse=\"handleColse\" />\n\t\t\t</template>\n\t\t</div>\n\t\t<div v-show=\"showRightTip\" class=\"file-content-right-tip\">\n\t\t\t<div class=\"file-content-svg\" @click=\"scrollRightFn\">\n\t\t\t\t<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"5\" height=\"9\" viewBox=\"0 0 5 9\" fill=\"none\">\n\t\t\t\t\t<path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M1.01036 0.877808L4.5968 4.46425C4.80562 4.67307 4.80562 5.01164 4.5968 5.22046L1.01036 8.8069L0.25415 8.05069L3.46248 4.84235L0.25415 1.63402L1.01036 0.877808Z\" fill=\"#1D2129\" />\n\t\t\t\t</svg>\n\t\t\t</div>\n\t\t</div>\n\t\t<div v-show=\"showLeftTip\" class=\"file-content-left-tip\">\n\t\t\t<div class=\"file-content-svg\" @click=\"scrollLeftFn\">\n\t\t\t\t<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"5\" height=\"9\" viewBox=\"0 0 5 9\" fill=\"none\">\n\t\t\t\t\t<path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M1.01036 0.877808L4.5968 4.46425C4.80562 4.67307 4.80562 5.01164 4.5968 5.22046L1.01036 8.8069L0.25415 8.05069L3.46248 4.84235L0.25415 1.63402L1.01036 0.877808Z\" fill=\"#1D2129\" />\n\t\t\t\t</svg>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</template>\n<script lang=\"ts\" setup>\nimport ImageFile from './ImageFile.vue'\nimport PDFFile from './PDFFile.vue'\nimport VideoFile from './VideoFile.vue'\nimport { ref, onMounted, onUnmounted } from 'vue'\nimport type { FileItem } from '../src/AiChat/Chat/types'\n\nconst showRightTip = ref(false)\nconst showLeftTip = ref(false)\nconst scrollDistance = ref(256) // 每次滚动的距离\nconst scrollContainer = ref<HTMLDivElement | null>(null)\n\nconst props = defineProps<{\n\tfileList: FileItem[]\n\thasColse: boolean\n\ttype: string\n}>()\nconst emits = defineEmits<{\n\t(e: 'colse', id: string): void\n\t(e: 'userMessageFileList', value: FileItem, index: number): void\n}>()\n\nlet edgeDetectionDebounce: NodeJS.Timeout | null = null\n// 处理鼠标滚轮事件,将纵向滚动转为横向滚动\nconst handleWheel = (e: WheelEvent) => {\n\tif (!scrollContainer.value) return\n\n\t// 阻止默认的纵向滚动\n\te.preventDefault()\n\tshowRightTip.value = true\n\tshowLeftTip.value = true\n\tconst { scrollLeft, clientWidth, scrollWidth } = scrollContainer.value\n\n\t// 左边缘检测(允许1px的误差)\n\tif (scrollLeft <= 1) {\n\t\tshowLeftTip.value = false\n\t}\n\n\t// 右边缘检测(允许1px的误差)\n\tif (scrollLeft + clientWidth >= scrollWidth - 1) {\n\t\tshowRightTip.value = false\n\t}\n\n\t// 计算滚动距离,添加一些乘数使滚动更自然\n\tconst scrollAmount = e.deltaY * 0.8\n\n\t// 平滑滚动\n\tscrollContainer.value.scrollBy({\n\t\tleft: scrollAmount,\n\t\tbehavior: 'smooth'\n\t})\n}\n\nconst handleScroll = (e: WheelEvent) => {\n\t// 防抖处理,避免滚动过程中频繁触发\n\tif (edgeDetectionDebounce) {\n\t\tclearTimeout(edgeDetectionDebounce)\n\t}\n\n\tedgeDetectionDebounce = setTimeout(() => {\n\t\thandleWheel(e)\n\t}, 50) // 50ms的防抖延迟\n}\n\n// 向左滚动(模拟向上滚轮事件)\nconst scrollLeftFn = () => {\n\tif (!showLeftTip.value || !scrollContainer.value) return\n\n\t// 模拟向上滚动的滚轮事件(deltaY 为负值)\n\tconst mockEvent = new WheelEvent('wheel', {\n\t\tdeltaY: -scrollDistance.value, // 负值表示向上滚动,我们将其转换为向左滚动\n\t\tbubbles: true,\n\t\tcancelable: true\n\t})\n\n\t// 复用 handleWheel 方法处理模拟事件\n\thandleWheel(mockEvent)\n}\n\n// 向右滚动(模拟向下滚轮事件)\nconst scrollRightFn = () => {\n\tif (!showRightTip.value || !scrollContainer.value) return\n\n\t// 模拟向下滚动的滚轮事件(deltaY 为正值)\n\tconst mockEvent = new WheelEvent('wheel', {\n\t\tdeltaY: scrollDistance.value, // 正值表示向下滚动,我们将其转换为向右滚动\n\t\tbubbles: true,\n\t\tcancelable: true\n\t})\n\n\t// 复用 handleWheel 方法处理模拟事件\n\thandleWheel(mockEvent)\n}\n\nconst handleColse = (id: string) => {\n\temits('colse', id)\n}\n\nconst init = () => {\n\tif (props.type === 'UserMessage' && props.fileList.length > 0) {\n\t\tconst list = props.fileList\n\t\tlist.forEach((item, index) => {\n\t\t\temits('userMessageFileList', item, index)\n\t\t})\n\t}\n}\n\nonMounted(() => {\n\tif (scrollContainer.value) {\n\t\t// 添加事件监听,passive: false 允许我们调用 preventDefault\n\t\tscrollContainer.value.addEventListener('wheel', handleScroll, { passive: false })\n\t}\n\tinit()\n})\n\nonUnmounted(() => {\n\tif (scrollContainer.value) {\n\t\tscrollContainer.value.removeEventListener('wheel', handleScroll)\n\t}\n})\n</script>\n"],"names":["_createElementBlock","_createElementVNode","_openBlock","_Fragment","fileList","_createBlock","hasColse"],"mappings":"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"}
@@ -40,14 +40,14 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
40
40
  createElementVNode(
41
41
  "div",
42
42
  { class: "file-name" },
43
- toDisplayString(__props.item.fileName || "\u672A\u77E5\u6587\u4EF6"),
43
+ toDisplayString(_ctx.item.fileName || "\u672A\u77E5\u6587\u4EF6"),
44
44
  1
45
45
  /* TEXT */
46
46
  ),
47
47
  createElementVNode(
48
48
  "div",
49
49
  { class: "file-size" },
50
- toDisplayString(formatFileSize(__props.item.fileSize)),
50
+ toDisplayString(formatFileSize(_ctx.item.fileSize)),
51
51
  1
52
52
  /* TEXT */
53
53
  )
@@ -1 +1 @@
1
- {"version":3,"file":"FileView.vue2.mjs","sources":["../../../../../../packages/components/touchchat/component/FileView.vue"],"sourcesContent":["<script lang=\"ts\">\nimport { defineComponent as DO_defineComponent } from 'vue';\nexport default /*#__PURE__*/ DO_defineComponent({ name: 'FileView' });\n</script>\n<template>\n <div class=\"file-view\" @click=\"handleFileClick\">\n <img src=\"../img/file.png\" alt=\"文件图标\" class=\"file-icon\" />\n <div class=\"file-info\">\n <div class=\"file-name\">{{ item.fileName || '未知文件' }}</div>\n <div class=\"file-size\">{{ formatFileSize(item.fileSize) }}</div>\n </div>\n <!-- <div class=\"file-action\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\">\n <path d=\"M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4\"></path>\n <polyline points=\"7 10 12 15 17 10\"></polyline>\n <line x1=\"12\" y1=\"15\" x2=\"12\" y2=\"3\"></line>\n </svg>\n </div> -->\n </div>\n</template>\n\n<script lang=\"ts\" setup>\n// import type { ChatMessage } from '../src/AiChat/TouchChat.vue';\ninterface ChatMessage {\n chatId?: string;\n user: string;\n type: string;\n content: string;\n isChating?: boolean;\n thinkContent?: string;\n reasoningContent?: string;\n isLiked?: boolean;\n isDisliked?: boolean;\n isEditing?: boolean;\n editContent?: string;\n componentName?: string;\n thinkStatus?: 'thinking' | 'completed' | 'stopped';\n thinkStartTime?: number;\n thinkTime?: number;\n [key: string]: unknown;\n}\n\n;\n\nconst props = defineProps<{\n item: ChatMessage & { fileName?: string; fileSize?: number };\n index: number;\n}>();\n\nconst emit = defineEmits<{\n (e: 'fileClick', fileName: string, index: number): void;\n}>();\n\n// 格式化文件大小\nconst formatFileSize = (size?: number): string => {\n if (!size) return '未知大小';\n if (size < 1024) return `${size} B`;\n if (size < 1024 * 1024) return `${(size / 1024).toFixed(1)} KB`;\n return `${(size / (1024 * 1024)).toFixed(1)} MB`;\n};\n\n// 处理文件点击事件\nconst handleFileClick = () => {\n if (props.item.fileName) {\n emit('fileClick', props.item.fileName, props.index);\n }\n};\n</script>\n\n<!-- <style scoped lang=\"less\">\n@import './style/FileView.less';\n</style> -->\n"],"names":["DO_defineComponent","_createElementBlock","_createElementVNode","_toDisplayString","_createCommentVNode"],"mappings":";;;AAEA,MAAA,WAA6B,GAAAA,eAAA,CAAmB,EAAE,IAAA,EAAM,YAAY,CAAA,CAAA;;;;;;;;;AA0CpE,IAAA,MAAM,KAAQ,GAAA,OAAA,CAAA;AAKd,IAAA,MAAM,IAAO,GAAA,MAAA,CAAA;AAKb,IAAM,MAAA,cAAA,GAAiB,CAAC,IAA0B,KAAA;AAChD,MAAA,IAAI,CAAC,IAAA;AAAM,QAAO,OAAA,0BAAA,CAAA;AAClB,MAAA,IAAI,IAAO,GAAA,IAAA;AAAM,QAAA,OAAO,CAAG,EAAA,IAAA,CAAA,EAAA,CAAA,CAAA;AAC3B,MAAA,IAAI,OAAO,IAAO,GAAA,IAAA;AAAM,QAAA,OAAO,CAAI,EAAA,CAAA,IAAA,GAAO,IAAM,EAAA,OAAA,CAAQ,CAAC,CAAA,CAAA,GAAA,CAAA,CAAA;AACzD,MAAA,OAAO,CAAI,EAAA,CAAA,IAAA,IAAQ,IAAO,GAAA,IAAA,CAAA,EAAO,QAAQ,CAAC,CAAA,CAAA,GAAA,CAAA,CAAA;AAAA,KAC5C,CAAA;AAGA,IAAA,MAAM,kBAAkB,MAAM;AAC5B,MAAI,IAAA,KAAA,CAAM,KAAK,QAAU,EAAA;AACvB,QAAA,IAAA,CAAK,WAAa,EAAA,KAAA,CAAM,IAAK,CAAA,QAAA,EAAU,MAAM,KAAK,CAAA,CAAA;AAAA,OACpD;AAAA,KACF,CAAA;;wBA7DE,EAAAC,kBAAA,CAaM,KAAA,EAAA;AAAA,QAbD,KAAM,EAAA,WAAA;AAAA,QAAa,OAAO,EAAA,eAAA;AAAA;QAC7BC,mBAA0D,KAAA,EAAA;AAAA,UAArD,GAAA,EAAA,UAAA;AAAA,UAAsB,GAAI,EAAA,0BAAA;AAAA,UAAO,KAAM,EAAA,WAAA;AAAA;QAC5CA,kBAGM,CAAA,KAAA,EAAA,EAHD,KAAA,EAAM,aAAW,EAAA;AAAA,UACpBA,kBAAA;AAAA,YAA0D,KAAA;AAAA,cAArD,OAAM,WAAe,EAAA;AAAA,YAAAC,eAAA,CAAA,OAAA,CAAA,IAAK,CAAA,QAAA,IAAQ,0BAAA,CAAA;AAAA,YAAA,CAAA;AAAA;AAAA,WAAA;AAAA,UACvCD,kBAAA;AAAA,YAAgE,KAAA;AAAA,YAAA,EAA3D,OAAM;2BAAe,CAAA,cAAA,CAAe,OAAI,CAAA,IAAA,CAAC,QAAQ,CAAA,CAAA;AAAA,YAAA,CAAA;AAAA;AAAA,WAAA;AAAA;QAExDE,mBAMU,yXAAA,CAAA;AAAA;;;;;;;"}
1
+ {"version":3,"file":"FileView.vue2.mjs","sources":["../../../../../../packages/components/touchchat/component/FileView.vue"],"sourcesContent":["<script lang=\"ts\">\nimport { defineComponent as DO_defineComponent } from 'vue';\nexport default /*#__PURE__*/ DO_defineComponent({ name: 'FileView' });\n</script>\n<template>\n <div class=\"file-view\" @click=\"handleFileClick\">\n <img src=\"../img/file.png\" alt=\"文件图标\" class=\"file-icon\" />\n <div class=\"file-info\">\n <div class=\"file-name\">{{ item.fileName || '未知文件' }}</div>\n <div class=\"file-size\">{{ formatFileSize(item.fileSize) }}</div>\n </div>\n <!-- <div class=\"file-action\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\">\n <path d=\"M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4\"></path>\n <polyline points=\"7 10 12 15 17 10\"></polyline>\n <line x1=\"12\" y1=\"15\" x2=\"12\" y2=\"3\"></line>\n </svg>\n </div> -->\n </div>\n</template>\n\n<script lang=\"ts\" setup>\n// import type { ChatMessage } from '../src/AiChat/TouchChat.vue';\ninterface ChatMessage {\n chatId?: string;\n user: string;\n type: string;\n content: string;\n isChating?: boolean;\n thinkContent?: string;\n reasoningContent?: string;\n isLiked?: boolean;\n isDisliked?: boolean;\n isEditing?: boolean;\n editContent?: string;\n componentName?: string;\n thinkStatus?: 'thinking' | 'completed' | 'stopped';\n thinkStartTime?: number;\n thinkTime?: number;\n [key: string]: unknown;\n}\n\n;\n\nconst props = defineProps<{\n item: ChatMessage & { fileName?: string; fileSize?: number };\n index: number;\n}>();\n\nconst emit = defineEmits<{\n (e: 'fileClick', fileName: string, index: number): void;\n}>();\n\n// 格式化文件大小\nconst formatFileSize = (size?: number): string => {\n if (!size) return '未知大小';\n if (size < 1024) return `${size} B`;\n if (size < 1024 * 1024) return `${(size / 1024).toFixed(1)} KB`;\n return `${(size / (1024 * 1024)).toFixed(1)} MB`;\n};\n\n// 处理文件点击事件\nconst handleFileClick = () => {\n if (props.item.fileName) {\n emit('fileClick', props.item.fileName, props.index);\n }\n};\n</script>\n\n<!-- <style scoped lang=\"less\">\n@import './style/FileView.less';\n</style> -->\n"],"names":["DO_defineComponent","_createElementBlock","_createElementVNode","item","_createCommentVNode"],"mappings":";;;AAEA,MAAA,WAA6B,GAAAA,eAAA,CAAmB,EAAE,IAAA,EAAM,YAAY,CAAA,CAAA;;;;;;;;;AA0CpE,IAAA,MAAM,KAAQ,GAAA,OAAA,CAAA;AAKd,IAAA,MAAM,IAAO,GAAA,MAAA,CAAA;AAKb,IAAM,MAAA,cAAA,GAAiB,CAAC,IAA0B,KAAA;AAChD,MAAA,IAAI,CAAC,IAAA;AAAM,QAAO,OAAA,0BAAA,CAAA;AAClB,MAAA,IAAI,IAAO,GAAA,IAAA;AAAM,QAAA,OAAO,CAAG,EAAA,IAAA,CAAA,EAAA,CAAA,CAAA;AAC3B,MAAA,IAAI,OAAO,IAAO,GAAA,IAAA;AAAM,QAAA,OAAO,CAAI,EAAA,CAAA,IAAA,GAAO,IAAM,EAAA,OAAA,CAAQ,CAAC,CAAA,CAAA,GAAA,CAAA,CAAA;AACzD,MAAA,OAAO,CAAI,EAAA,CAAA,IAAA,IAAQ,IAAO,GAAA,IAAA,CAAA,EAAO,QAAQ,CAAC,CAAA,CAAA,GAAA,CAAA,CAAA;AAAA,KAC5C,CAAA;AAGA,IAAA,MAAM,kBAAkB,MAAM;AAC5B,MAAI,IAAA,KAAA,CAAM,KAAK,QAAU,EAAA;AACvB,QAAA,IAAA,CAAK,WAAa,EAAA,KAAA,CAAM,IAAK,CAAA,QAAA,EAAU,MAAM,KAAK,CAAA,CAAA;AAAA,OACpD;AAAA,KACF,CAAA;;wBA7DE,EAAAC,kBAAA,CAaM,KAAA,EAAA;AAAA,QAbD,KAAM,EAAA,WAAA;AAAA,QAAa,OAAO,EAAA,eAAA;AAAA;QAC7BC,mBAA0D,KAAA,EAAA;AAAA,UAArD,GAAA,EAAA,UAAA;AAAA,UAAsB,GAAI,EAAA,0BAAA;AAAA,UAAO,KAAM,EAAA,WAAA;AAAA;QAC5CA,kBAGM,CAAA,KAAA,EAAA,EAHD,KAAA,EAAM,aAAW,EAAA;AAAA,UACpBA,kBAAA;AAAA,YAA0D,KAAA;AAAA,cAArD,OAAM,WAAeC,EAAAA;AAAAA,YAAAA,eAAAA,CAAAA,IAAAA,CAAAA,IAAK,CAAA,QAAA,IAAQ,0BAAA,CAAA;AAAA,YAAA,CAAA;AAAA;AAAA,WAAA;AAAA,UACvCD,kBAAA;AAAA,YAAgE,KAAA;AAAA,YAAA,EAA3D,OAAM;2BAAe,CAAA,cAAA,CAAeC,IAAI,CAAA,IAAA,CAAC,QAAQ,CAAA,CAAA;AAAA,YAAA,CAAA;AAAA;AAAA,WAAA;AAAA;QAExDC,mBAMU,yXAAA,CAAA;AAAA;;;;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"HelloChat.vue2.mjs","sources":["../../../../../../packages/components/touchchat/component/HelloChat.vue"],"sourcesContent":["<script lang=\"ts\">\nimport { defineComponent as DO_defineComponent } from 'vue';\nexport default /*#__PURE__*/ DO_defineComponent({ name: 'HelloChat' });\n</script>\n<template>\r\n\t<div>\r\n\t\t<div class=\"hello-chat\">\r\n\t\t\t<p class=\"title\">你好,我是 touchchat</p>\r\n\t\t\t<p class=\"sub-info\">作为您的智能伙伴,我既能帮您查账单、办业务,又能陪您聊天、学知识。</p>\r\n\t\t</div>\r\n\t\t<div v-if=\"helloChatList.length\" class=\"function-buttons\">\r\n\t\t\t<ul>\r\n\t\t\t\t<li v-for=\"item in helloChatList\" :key=\"item.id\" @click=\"handleItemClick(item)\">\r\n\t\t\t\t\t<img src=\"../../touchchat/img/icon.png\" alt=\"{{ item.name }}\" class=\"icon\" />\r\n\t\t\t\t\t<span class=\"ellipsis-text\">{{ item.name }}</span>\r\n\t\t\t\t</li>\r\n\t\t\t</ul>\r\n\t\t</div>\r\n\t</div>\r\n</template>\r\n\r\n<script setup lang=\"ts\">\r\nimport { inject } from 'vue'\r\n\r\n\r\n// 定义接口来描述helloChatList中项的结构\r\ninterface HelloChatItem {\r\n\tid: number\r\n\tname: string\r\n\t// 可以根据实际情况添加其他属性\r\n}\r\n\r\n// 为注入的helloChatList指定类型\r\nconst helloChatList = inject<HelloChatItem[]>('helloChatList', [])\r\n\r\nconst emit = defineEmits(['sendMessage'])\r\n\r\nconst handleItemClick = (item: HelloChatItem) => {\r\n\temit('sendMessage', item)\r\n}\r\n</script>\r\n\r\n<!-- <style scoped lang=\"less\">\r\n@import './style/HelloChat.less';\r\n</style> -->\r\n"],"names":["DO_defineComponent","_createElementBlock","_createElementVNode","_unref","_Fragment","_renderList","_imports_0","_toDisplayString"],"mappings":";;;AAEA,MAAA,WAA6B,GAAAA,eAAA,CAAmB,EAAE,IAAA,EAAM,aAAa,CAAA,CAAA;;;;;AA+BrE,IAAA,MAAM,aAAgB,GAAA,MAAA,CAAwB,eAAiB,EAAA,EAAE,CAAA,CAAA;AAEjE,IAAA,MAAM,IAAO,GAAA,MAAA,CAAA;AAEb,IAAM,MAAA,eAAA,GAAkB,CAAC,IAAwB,KAAA;AAChD,MAAA,IAAA,CAAK,eAAe,IAAI,CAAA,CAAA;AAAA,KACzB,CAAA;;0BAlCCC,kBAaM,CAAA,KAAA,EAAA,IAAA,EAAA;AAAA,QAZLC,kBAGM,CAAA,KAAA,EAAA,EAHD,KAAA,EAAM,cAAY,EAAA;AAAA,UACtBA,mBAAoC,GAAjC,EAAA,EAAA,KAAM,EAAA,OAAA,IAAQ,0CAAe,CAAA;AAAA,UAChCA,mBAAyD,GAAtD,EAAA,EAAA,KAAM,EAAA,UAAA,IAAW,wMAAiC,CAAA;AAAA;QAE3CC,MAAA,aAAA,CAAA,CAAc,uBAAzBF,mBAOM,KAAA,EAAA;AAAA;UAP2B,KAAM,EAAA,kBAAA;AAAA;UACtCC,kBAAA,CAKK,MAAA,IAAA,EAAA;AAAA,4BAJJ,EAAAD,kBAAA;AAAA,cAGKG,QAAA;AAAA,cAAA,IAAA;AAAA,cAAAC,UAHc,CAAAF,KAAA,CAAa,aAAA,CAAA,EAAA,CAArB,IAAI,KAAA;kCAAf,EAAAF,kBAAA,CAGK,IAAA,EAAA;AAAA,kBAH8B,KAAK,IAAK,CAAA,EAAA;AAAA,kBAAK,OAAK,EAAA,CAAA,MAAE,KAAA,eAAA,CAAgB,IAAI,CAAA;AAAA;kBAC5EC,mBAA6E,KAAA,EAAA;AAAA,oBAAxE,GAAA,EAAAI,UAAA;AAAA,oBAAmC,GAAI,EAAA,iBAAA;AAAA,oBAAkB,KAAM,EAAA,MAAA;AAAA;kBACpEJ,kBAAA;AAAA,oBAAkD,MAAA;AAAA,sBAA5C,OAAM,eAAmB,EAAA;AAAA,oBAAAK,eAAA,CAAA,KAAK,IAAI,CAAA;AAAA,oBAAA,CAAA;AAAA;AAAA,mBAAA;AAAA;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"HelloChat.vue2.mjs","sources":["../../../../../../packages/components/touchchat/component/HelloChat.vue"],"sourcesContent":["<script lang=\"ts\">\nimport { defineComponent as DO_defineComponent } from 'vue';\nexport default /*#__PURE__*/ DO_defineComponent({ name: 'HelloChat' });\n</script>\n<template>\n\t<div>\n\t\t<div class=\"hello-chat\">\n\t\t\t<p class=\"title\">你好,我是 touchchat</p>\n\t\t\t<p class=\"sub-info\">作为您的智能伙伴,我既能帮您查账单、办业务,又能陪您聊天、学知识。</p>\n\t\t</div>\n\t\t<div v-if=\"helloChatList.length\" class=\"function-buttons\">\n\t\t\t<ul>\n\t\t\t\t<li v-for=\"item in helloChatList\" :key=\"item.id\" @click=\"handleItemClick(item)\">\n\t\t\t\t\t<img src=\"../../touchchat/img/icon.png\" alt=\"{{ item.name }}\" class=\"icon\" />\n\t\t\t\t\t<span class=\"ellipsis-text\">{{ item.name }}</span>\n\t\t\t\t</li>\n\t\t\t</ul>\n\t\t</div>\n\t</div>\n</template>\n\n<script setup lang=\"ts\">\nimport { inject } from 'vue'\n\n\n// 定义接口来描述helloChatList中项的结构\ninterface HelloChatItem {\n\tid: number\n\tname: string\n\t// 可以根据实际情况添加其他属性\n}\n\n// 为注入的helloChatList指定类型\nconst helloChatList = inject<HelloChatItem[]>('helloChatList', [])\n\nconst emit = defineEmits(['sendMessage'])\n\nconst handleItemClick = (item: HelloChatItem) => {\n\temit('sendMessage', item)\n}\n</script>\n\n<!-- <style scoped lang=\"less\">\n@import './style/HelloChat.less';\n</style> -->\n"],"names":["DO_defineComponent","_createElementBlock","_createElementVNode","_unref","_Fragment","_renderList","_imports_0","_toDisplayString"],"mappings":";;;AAEA,MAAA,WAA6B,GAAAA,eAAA,CAAmB,EAAE,IAAA,EAAM,aAAa,CAAA,CAAA;;;;;AA+BrE,IAAA,MAAM,aAAgB,GAAA,MAAA,CAAwB,eAAiB,EAAA,EAAE,CAAA,CAAA;AAEjE,IAAA,MAAM,IAAO,GAAA,MAAA,CAAA;AAEb,IAAM,MAAA,eAAA,GAAkB,CAAC,IAAwB,KAAA;AAChD,MAAA,IAAA,CAAK,eAAe,IAAI,CAAA,CAAA;AAAA,KACzB,CAAA;;0BAlCCC,kBAaM,CAAA,KAAA,EAAA,IAAA,EAAA;AAAA,QAZLC,kBAGM,CAAA,KAAA,EAAA,EAHD,KAAA,EAAM,cAAY,EAAA;AAAA,UACtBA,mBAAoC,GAAjC,EAAA,EAAA,KAAM,EAAA,OAAA,IAAQ,0CAAe,CAAA;AAAA,UAChCA,mBAAyD,GAAtD,EAAA,EAAA,KAAM,EAAA,UAAA,IAAW,wMAAiC,CAAA;AAAA;QAE3CC,MAAA,aAAA,CAAA,CAAc,uBAAzBF,mBAOM,KAAA,EAAA;AAAA;UAP2B,KAAM,EAAA,kBAAA;AAAA;UACtCC,kBAAA,CAKK,MAAA,IAAA,EAAA;AAAA,4BAJJ,EAAAD,kBAAA;AAAA,cAGKG,QAAA;AAAA,cAAA,IAAA;AAAA,cAAAC,UAHc,CAAAF,KAAA,CAAa,aAAA,CAAA,EAAA,CAArB,IAAI,KAAA;kCAAf,EAAAF,kBAAA,CAGK,IAAA,EAAA;AAAA,kBAH8B,KAAK,IAAK,CAAA,EAAA;AAAA,kBAAK,OAAK,EAAA,CAAA,MAAE,KAAA,eAAA,CAAgB,IAAI,CAAA;AAAA;kBAC5EC,mBAA6E,KAAA,EAAA;AAAA,oBAAxE,GAAA,EAAAI,UAAA;AAAA,oBAAmC,GAAI,EAAA,iBAAA;AAAA,oBAAkB,KAAM,EAAA,MAAA;AAAA;kBACpEJ,kBAAA;AAAA,oBAAkD,MAAA;AAAA,sBAA5C,OAAM,eAAmB,EAAA;AAAA,oBAAAK,eAAA,CAAA,KAAK,IAAI,CAAA;AAAA,oBAAA,CAAA;AAAA;AAAA,mBAAA;AAAA;;;;;;;;;;;;;;"}
@@ -35,14 +35,14 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
35
35
  return openBlock(), createElementBlock("div", { class: "image-file" }, [
36
36
  createElementVNode("div", { class: "image-file-content" }, [
37
37
  createElementVNode("img", {
38
- src: (_a = __props.item.base64) != null ? _a : "../img/link.png",
38
+ src: (_a = _ctx.item.base64) != null ? _a : "../img/link.png",
39
39
  alt: "\u56FE\u7247",
40
40
  onClick: ($event) => showPreview.value = true
41
41
  }, null, 8, ["src", "onClick"]),
42
- !(showLoading.value || __props.item.uploadError) && __props.hasColse ? (openBlock(), createElementBlock("div", {
42
+ !(showLoading.value || _ctx.item.uploadError) && _ctx.hasColse ? (openBlock(), createElementBlock("div", {
43
43
  key: 0,
44
44
  class: "image-file-colse",
45
- onClick: ($event) => emits("colse", __props.item.id)
45
+ onClick: ($event) => emits("colse", _ctx.item.id)
46
46
  }, [
47
47
  (openBlock(), createElementBlock("svg", {
48
48
  xmlns: "http://www.w3.org/2000/svg",
@@ -57,7 +57,7 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
57
57
  })
58
58
  ]))
59
59
  ], 8, ["onClick"])) : createCommentVNode("v-if", true),
60
- showLoading.value && !__props.item.uploadError ? (openBlock(), createElementBlock("div", {
60
+ showLoading.value && !_ctx.item.uploadError ? (openBlock(), createElementBlock("div", {
61
61
  key: 1,
62
62
  class: "img-file-loading"
63
63
  }, [
@@ -110,7 +110,7 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
110
110
  /* TEXT */
111
111
  )
112
112
  ])) : createCommentVNode("v-if", true),
113
- __props.item.uploadError ? (openBlock(), createElementBlock("div", {
113
+ _ctx.item.uploadError ? (openBlock(), createElementBlock("div", {
114
114
  key: 2,
115
115
  class: "img-file-loading img-error-loading",
116
116
  onClick: handleReset
@@ -146,7 +146,7 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
146
146
  }, [
147
147
  createElementVNode("div", { class: "image-preview-content" }, [
148
148
  createElementVNode("img", {
149
- src: (_b = __props.item.base64) != null ? _b : "../img/link.png",
149
+ src: (_b = _ctx.item.base64) != null ? _b : "../img/link.png",
150
150
  alt: "\u9884\u89C8\u56FE\u7247"
151
151
  }, null, 8, ["src"])
152
152
  ])