askbot-dragon 1.7.44-beta → 1.7.48-beta

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 (95) hide show
  1. package/README.md +27 -27
  2. package/babel.config.js +6 -6
  3. package/dragon.iml +7 -7
  4. package/package.json +56 -56
  5. package/public/index.html +75 -73
  6. package/src/App.vue +31 -31
  7. package/src/api/index.js +1 -1
  8. package/src/api/mock.http +2 -2
  9. package/src/api/requestUrl.js +185 -185
  10. package/src/assets/js/AliyunlssUtil.js +117 -141
  11. package/src/assets/js/Base64Util.js +22 -22
  12. package/src/assets/js/common.js +252 -252
  13. package/src/assets/js/hammer.js +89 -100
  14. package/src/assets/js/script.js +36 -36
  15. package/src/assets/less/common.css +6773 -6773
  16. package/src/assets/less/converSationContainer/common.less +192 -199
  17. package/src/assets/less/converSationContainer/converSatonContainer.less +493 -493
  18. package/src/assets/less/iconfont.css +37 -37
  19. package/src/assets/less/ticketMessage.less +294 -294
  20. package/src/components/ActionAlertIframe.vue +154 -177
  21. package/src/components/AiGuide.vue +471 -438
  22. package/src/components/AnswerDocknowledge.vue +1088 -1091
  23. package/src/components/AnswerVoice.vue +285 -285
  24. package/src/components/AskIFrame.vue +15 -15
  25. package/src/components/ConversationContainer.vue +10873 -10766
  26. package/src/components/FileType.vue +86 -86
  27. package/src/components/Message.vue +27 -27
  28. package/src/components/MyEditor.vue +341 -342
  29. package/src/components/QwFeedback.vue +301 -301
  30. package/src/components/actionSatisfaction.vue +107 -107
  31. package/src/components/actionSendToBot.vue +62 -62
  32. package/src/components/answerDissatisfaction.vue +62 -62
  33. package/src/components/answerRadio.vue +211 -211
  34. package/src/components/ask-components/DissatisfactionOptions.vue +57 -57
  35. package/src/components/ask-components/Msgloading.vue +37 -37
  36. package/src/components/ask-components/SatisfactionV2.vue +15 -15
  37. package/src/components/askVideo.vue +139 -162
  38. package/src/components/assetDetails.vue +378 -378
  39. package/src/components/assetMessage.vue +226 -228
  40. package/src/components/associationIntention.vue +374 -378
  41. package/src/components/attachmentPreview.vue +90 -90
  42. package/src/components/botActionSatisfactor.vue +68 -68
  43. package/src/components/chatContent.vue +513 -513
  44. package/src/components/feedBack.vue +136 -136
  45. package/src/components/fielListView.vue +351 -351
  46. package/src/components/file/AliyunOssComponents.vue +108 -108
  47. package/src/components/formTemplate.vue +3497 -3501
  48. package/src/components/imgView.vue +31 -31
  49. package/src/components/intelligentSummary.vue +229 -231
  50. package/src/components/kkview.vue +1138 -1138
  51. package/src/components/loadingProcess.vue +164 -164
  52. package/src/components/markDownText.vue +197 -197
  53. package/src/components/message/ActionAlertIframe.vue +112 -112
  54. package/src/components/message/ShopMessage.vue +164 -164
  55. package/src/components/message/TextMessage.vue +924 -928
  56. package/src/components/message/TicketMessage.vue +201 -201
  57. package/src/components/message/swiper/index.js +4 -4
  58. package/src/components/message/swiper/ticketSwiper.vue +503 -503
  59. package/src/components/message/swiper/ticketSwiperItem.vue +61 -61
  60. package/src/components/msgLoading.vue +231 -231
  61. package/src/components/myPopup.vue +70 -70
  62. package/src/components/pdfPosition.vue +1342 -1514
  63. package/src/components/popup.vue +227 -227
  64. package/src/components/previewDoc.vue +247 -251
  65. package/src/components/previewPdf.vue +774 -1069
  66. package/src/components/receiverMessagePlatform.vue +66 -65
  67. package/src/components/recommend.vue +80 -80
  68. package/src/components/selector/hOption.vue +20 -20
  69. package/src/components/selector/hSelector.vue +199 -199
  70. package/src/components/selector/hWrapper.vue +216 -216
  71. package/src/components/senderMessagePlatform.vue +55 -50
  72. package/src/components/source/BotMessage.vue +24 -24
  73. package/src/components/source/CustomMessage.vue +24 -24
  74. package/src/components/test.vue +260 -260
  75. package/src/components/tree.vue +307 -307
  76. package/src/components/utils/AliyunIssUtil.js +103 -103
  77. package/src/components/utils/ckeditor.js +185 -185
  78. package/src/components/utils/format_date.js +25 -25
  79. package/src/components/utils/index.js +6 -6
  80. package/src/components/utils/math_utils.js +29 -29
  81. package/src/components/voiceComponent.vue +119 -119
  82. package/src/components/welcomeKnowledgeFile.vue +340 -344
  83. package/src/components/welcomeLlmCard.vue +140 -144
  84. package/src/components/welcomeSuggest.vue +97 -97
  85. package/src/locales/cn.json +61 -71
  86. package/src/locales/en.json +62 -73
  87. package/src/main.js +76 -75
  88. package/vue.config.js +54 -54
  89. package/src/components/newPdfPosition.vue +0 -878
  90. package/src/components/pagination.vue +0 -129
  91. package/src/components/preview/docView.vue +0 -107
  92. package/src/components/preview/excelView.vue +0 -177
  93. package/src/components/preview/newPositionPreview.vue +0 -351
  94. package/src/components/preview/pdfView.vue +0 -760
  95. package/src/locales/jp.json +0 -73
@@ -1,1091 +1,1088 @@
1
- <!--
2
- isLiBang 字段判断 是否为立邦主体
3
- 立邦有自己单独的组件分支,但考虑到后期结构改动如果较大改动会不方便,所以还是在推荐知识消息中 在此判断是否是立邦主体。方便后期维护
4
- -->
5
- <template>
6
- <div class="answer-docknowledge">
7
- <div :class="['answer-docknowledge-header', msg.content.isKnowledgeSummary ? 'bgc' : '']">
8
- <div v-if="msg.content.isKnowledgeSummary" class="tips">AI为您总结生成了以下摘要</div>
9
- <!-- <div v-if="msg.content.type == 0" class="answer-text">
10
- <template v-if="msg.content.renderType == 1">
11
- <p v-html="msg.content.text"></p>
12
- </template>
13
- <template v-else>{{ msg.content.text }}</template>
14
- </div> -->
15
- <div class="answer-text">
16
- <template v-if="msg.content.renderType == 1">
17
- <p v-html="msg.content.text"></p>
18
- </template>
19
- <template v-else-if="msg.content.renderType == 2">
20
- <markDownText :chainValues="msg.content.text" :isHistory="isHistory"></markDownText>
21
- </template>
22
- <template v-else>{{ msg.content.text }}</template>
23
- </div>
24
- <div v-if="msg.content.images && msg.content.images.length != 0" class="answer-kn-image-box">
25
- <img v-for="(imageItem, imageItemIndex) in msg.content.images"
26
- style="max-width: 230px;border-radius: 25px;margin-bottom: 15px" :src="imageItem.url"
27
- :key="imageItemIndex" alt @click="lookAttach(imageItem.url, imageItem, $event)" />
28
- </div>
29
- </div>
30
- <template v-if="!isLiBang">
31
- <div class="ad-list" :class="msg.content.type == 0 ? 'ad-list-recognition' : ''">
32
- <template v-if="msg.content.type == 1">
33
- <div v-for="(item, itemIndex) in msg.content.list" :key="itemIndex"
34
- :style="{ paddingBottom: itemIndex === msg.content.list.length - 1 ? 0 : '10px' }" class="ad-list-cell">
35
- <div class="alc-title">
36
- <div class="alc-box">
37
- <div class="alc-source-left">
38
- <span class="source-form">出自</span>
39
- <img class="alc-title-icon" height="24px" width="24px" :src="getIconSrc(item)" alt=""
40
- srcset="">
41
- <span class="alc-title-from">{{ item.from }}</span>
42
- </div>
43
- </div>
44
- <div v-html="item.introduction" v-if="!srcContentTypeIMG(item)" class="alc-box-introduction">
45
- </div>
46
- <div v-else class="alc-box-introduction">
47
- <img :src="item.expiredUrl" alt="" @click="lookAttach(item.url, item, $event)">
48
- </div>
49
- <div v-if="item.previewImage" class="alc-box-introduction-previewImage">
50
- <img :src="item.previewImage" alt=""
51
- @click="lookAttach(item.previewImage, { url: item.previewImage }, $event)">
52
- </div>
53
- <div class="alc-updateTime">
54
- <div v-show="docSource[item.source]" class="upload-source">
55
- {{ docSource[item.source] }}
56
- </div>
57
- <div v-show="item.url" class="alc-content-text">
58
- <span @click="lookAttach(item.url, item, $event)" class="aci-view">查看 ></span>
59
- </div>
60
- </div>
61
- </div>
62
- <div class="alc-content" v-if="false">
63
- <div v-if="msg.content.type == 1" class="alc-content-text">
64
- {{ item.introduction }}
65
- <span @click="lookAttach(item.url, item, $event)" class="aci-view">查看原文 ></span>
66
- </div>
67
- <span v-if="!isPC" class="alc-title-updateTime">最后更新时间: {{ item.updateTime }}</span>
68
- <div v-if="false" class="alc-content-info">
69
- <div class="alcc-box">
70
- <span class="aci-owner">所有者: {{ item.owner }}</span>
71
- <span class="aci-enterprise">所属企业: {{ item.enterprise }}</span>
72
- <span class="aci-source">文件来源: {{ item.source }}</span>
73
- </div>
74
- </div>
75
- </div>
76
- </div>
77
- </template>
78
- <template v-if="msg.content.type == 0">
79
- <div v-for="(item, itemIndex) in msg.content.list" :key="itemIndex" class="ad-list-cell-recognition">
80
- <div class="alc-source-name" @click="lookAttach(item.url, item, $event)">
81
- <img class="alc-title-icon" height="18px" width="18px" :src="getIconSrc(item)" alt srcset />
82
- <span class="alc-title-from">{{ item.from }}</span>&nbsp;-&nbsp;
83
- <div v-show="docSource[item.source]" class="upload-source">
84
- {{ docSource[item.source] }}
85
- </div>
86
- <i class="iconfont guoran-right"></i>
87
- </div>
88
- </div>
89
- </template>
90
- <div class="ad-loadmore" v-if="loadMoreFlag" @click="lazyLoadKnowledegList">查看更多</div>
91
- </div>
92
- </template>
93
- <template v-if="isLiBang">
94
- <div class="libang_list" :class="msg.content.type == 0 ? 'libang_list_recognition' : ''">
95
- <template v-if="msg.content.type == 1">
96
- <div v-for="(item, itemIndex) in msg.content.list" :key="itemIndex" class="libang_list_cell">
97
- <div class="libang_title">
98
- <div class="libang_box">
99
- <div class="libang_source_left">
100
- <span class="source-form">出自</span>
101
- <img class="libang_title_icon" height="24px" width="24px" :src="getIconSrc(item)" alt=""
102
- srcset="">
103
- <span class="libang_title_from">{{ item.from }}</span>
104
- </div>
105
- </div>
106
- <div v-html="item.introduction" v-if="!srcContentTypeIMG(item)" class="libang_box_introduction">
107
- </div>
108
- <div v-else class="libang_box_introduction">
109
- <img :src="item.expiredUrl" alt="" @click="lookAttach(item.url, item, $event)">
110
- </div>
111
- <div v-if="item.previewImage" class="libang_box_introduction_previewImage">
112
- <img :src="item.previewImage" alt=""
113
- @click="lookAttach(item.previewImage, { url: item.previewImage }, $event)">
114
- </div>
115
- <div class="libang_updateTime">
116
- <div class="libang_updataTime_left">
117
- <div v-show="docSource[item.source]" class="upload-source">
118
- {{ docSource[item.source] }}
119
- </div>
120
- <div class="libang_floder" @click.stop="clickFloder(item)">
121
- <i class="iconfont guoran-tongyichicun-wenjianjia-zhankaizhuangtai--folderOpen"></i>
122
- {{ item.folderName }}
123
- </div>
124
- </div>
125
- <div v-show="item.url" class="libang_content_text">
126
- <span @click="lookAttach(item.url, item, $event)" class="aci-view">查看 ></span>
127
- </div>
128
- </div>
129
- </div>
130
- <!-- <div class="alc-content" v-if="false">
131
- <div v-if="msg.content.type == 1" class="alc-content-text">
132
- {{ item.introduction }}
133
- <span @click="lookAttach(item.url, item, $event)" class="aci-view">查看原文 ></span>
134
- </div>
135
- <span v-if="!isPC" class="alc-title-updateTime">最后更新时间: {{ item.updateTime }}</span>
136
- <div v-if="false" class="alc-content-info">
137
- <div class="alcc-box">
138
- <span class="aci-owner">所有者: {{ item.owner }}</span>
139
- <span class="aci-enterprise">所属企业: {{ item.enterprise }}</span>
140
- <span class="aci-source">文件来源: {{ item.source }}</span>
141
- </div>
142
- </div>
143
- </div> -->
144
- </div>
145
- </template>
146
- <template v-if="msg.content.type == 0">
147
- <div v-for="(item, itemIndex) in msg.content.list" :key="itemIndex"
148
- class="libang_list_cell_recognition" @click="lookAttach(item.url, item, $event)">
149
- <div class="libang_list_cell_left" >
150
- <div class="libang_source_name" >
151
- <img class="libang_title_icon" height="18px" width="18px" :src="getIconSrc(item)" alt srcset />
152
- <span class="libang_title_from">{{ item.from }}</span>&nbsp;-&nbsp;
153
- <div v-show="docSource[item.source]" class="upload_source">
154
- {{ docSource[item.source] }}
155
- </div>
156
- </div>
157
- <div class="libang_source_floder" @click.stop="clickFloder(item)">
158
- <i class="iconfont guoran-tongyichicun-wenjianjia-zhankaizhuangtai--folderOpen"></i>
159
- {{ item.folderName }}
160
- </div>
161
- </div>
162
- <i class="iconfont guoran-right" @click="lookAttach(item.url, item, $event)"></i>
163
- </div>
164
- </template>
165
- <div class="ad-loadmore" v-if="loadMoreFlag" @click="lazyLoadKnowledegList">查看更多</div>
166
- </div>
167
- </template>
168
-
169
- <previewPdf ref="previewPdf" :url="previewHref" :previewOssPath="previewOssPath" :title="title"
170
- :folderName="folderName" :folderUrl="folderUrl"
171
- :sourceFileType="sourceFileType" officePreviewType="pdf" @previewToDialog="previewToDialog"
172
- @recommendQues="recommendQues" @close="close" @open="open" :isHasChat="isHasChat"
173
- :knowledgeId="previewKnowledgeId" :isLiBang="isLiBang" @previewClickFloder="previewClickFloder"></previewPdf>
174
- </div>
175
- </template>
176
-
177
- <script>
178
- /* eslint-disable */
179
- import previewPdf from "./previewPdf";
180
- import { isMobile } from "../assets/js/common";
181
- import markDownText from "./markDownText.vue";
182
- export default {
183
- name: "answerDocknowledge",
184
- components: { previewPdf, markDownText },
185
- data () {
186
- return {
187
- isPC: true,
188
- previewHref: "",
189
- sourceFileType: '',
190
- // docSource: {
191
- // LOCAL_FILE: "来源于本地文件",
192
- // CREATED_BY_ONESELF: "来源于自建知识",
193
- // WECHAT: "来源于微信",
194
- // AUTO_SYN_FROM_LOCAL_FILE: "自动同步于本地",
195
- // YUQUE: "来源于语雀",
196
- // CORP_LOCAL_FILE: '来源于企业知识库',
197
- // FEISHU: '来源于飞书-云文档'
198
- // },
199
- docSource: {
200
- LOCAL_FILE: "个人知识",
201
- CREATED_BY_ONESELF: "个人知识",
202
- WECHAT: "个人知识",
203
- AUTO_SYN_FROM_LOCAL_FILE: "个人知识",
204
- YUQUE: "企业知识",
205
- CORP_LOCAL_FILE: '企业知识',
206
- FEISHU: '企业知识'
207
- },
208
- imageObj: {
209
- PDF: 'pdf1',
210
- pdf: 'pdf1',
211
- TXT: 'txt1',
212
- txt: 'txt1',
213
- selfadd: 'selfadd1',
214
- md: "md2",
215
- html: 'selfadd1',
216
- mode: "mode",
217
- general: 'general',
218
- word: "word1",
219
- Word: "word1",
220
- docx: "word1",
221
- doc: "word1",
222
- WORD: "word1",
223
- Excel: 'excel1',
224
- EXCEL: 'excel1',
225
- excel: 'excel1',
226
- PPT: 'ppt1',
227
- ppt: 'ppt1',
228
- pptx: 'ppt1',
229
- img: "image1",
230
- image: "image1",
231
- video: "video",
232
- audio: 'audio',
233
- link: "link",
234
- wechat: "wechat",
235
- mp4: "video",
236
- MP4: "video",
237
- xlsx: "excel1",
238
- SLSX: "excel1",
239
- xls: "excel1",
240
- XLS: "excel1",
241
- jpg: "image1",
242
- JPG: "image1",
243
- jpeg: "image1",
244
- JPEG: "image1",
245
- png: "image1",
246
- PNG: "image1",
247
- webp: "image1",
248
- WEBP: "image1",
249
- gif: "image1",
250
- GIF: "image1",
251
- svg: "image1",
252
- SVG: "image1",
253
- bmp: "image1",
254
- BMP: "image1",
255
- avi: "video",
256
- AVI: "video",
257
- mov: "video",
258
- MOV: "video",
259
- rmvb: "video",
260
- RMVB: "video",
261
- wav: "audio",
262
- WAV: "audio",
263
- mp3: "audio",
264
- MP3: "audio",
265
- yqhtml: "yqhtml",
266
- feishuhtml: "feishuhtml"
267
- },
268
- allKnowledgeList: [],
269
- loadMoreFlag: false,
270
- title: '',
271
- folderName: '',
272
- folderUrl: '',
273
- previewKnowledgeId: "",
274
- previewKnowledge: {},
275
- previewOssPath: ""
276
- }
277
- },
278
- props: ['msg', 'isAskLightning', 'isMessageRecord', "isApp", "isHasChat", "activeKnowledgeId", "isLiBang","language","isHistory"],
279
- beforeMounted () {
280
- },
281
- watch: {
282
- // msg: {
283
- // handler (n) {
284
- // console.log(n, 'answerDocknowledge');
285
- // n.content.list.forEach(element => {
286
- // console.log(this.imageObj[element.format], 1111);
287
- // element.src = 'https://static.guoranbot.com/cdn-office-website/askbot_doc/' + this.imageObj[element.format] + '.png';
288
- // if ((element.format === "txt" || element.format === "html") && element.source === "WECHAT") {
289
- // element.src = 'https://static.guoranbot.com/cdn-office-website/askbot_doc/wechat.png';
290
- // }
291
- // });
292
- // },
293
- // deep: true,
294
- // immediate: true
295
- // }
296
- },
297
- created () {
298
- var system = {};
299
- system.pingtai = /(Win32|Win16|WinCE|Mac68K|MacIntel|MacIntel|MacPPC|Linux mips64)/i.test(navigator.platform);
300
- if (system.pingtai) {
301
- //电脑
302
- this.isPC = true;
303
- } else {
304
- //手机
305
- this.isPC = false;
306
- }
307
- // this.msg.content.list.forEach(element => {
308
- // console.log(this.imageObj[element.format],1111);
309
- // element.src = 'https://static.guoranbot.com/cdn-office-website/askbot_doc/' + this.imageObj[element.format] + '.png';
310
- // if ((element.format === "txt" || element.format === "html") && element.source === "WECHAT") {
311
- // element.src = 'https://static.guoranbot.com/cdn-office-website/askbot_doc/wechat.png';
312
- // }
313
- // });
314
- },
315
- mounted () {
316
- console.log(this.msg.content, 'this.msg.content');
317
- // if(this.msg.content.type == 1) {
318
-
319
- // }
320
- if (this.msg.content.list && this.msg.content.list.length > 0) {
321
- this.loadMoreFlag = true
322
- this.allKnowledgeList = JSON.parse(JSON.stringify(this.msg.content.list))
323
- // console.log(this.allKnowledgeList.length, 'this.allKnowledgeList');
324
- this.msg.content.list = []
325
- this.lazyLoadKnowledegList()
326
- }
327
- },
328
- methods: {
329
- getIconSrc (element) {
330
- if ((element.format === "txt" || element.format === "html") && element.source === "WECHAT") {
331
- return require("../assets/image/filtType/wechat.png")
332
- } else {
333
- return require("../assets/image/filtType/" + this.imageObj[element.format] + '.png')
334
-
335
- }
336
- },
337
- //预览图片
338
- lookAttach (url, item, event) {
339
- // console.log(item.knowledgeId);
340
- // this.$http.get("/knowledge-api/internal/knowledgeBaseStructure/" + "642ffbccde420e2772f7787b")
341
- // debugger
342
- event.preventDefault();
343
- if (this.isAskLightning == 1 && !this.isApp) {
344
- window.parent.postMessage({
345
- data: "bot_preview",
346
- item: JSON.stringify(item),
347
- url: url
348
- }, "*");
349
- } else {
350
- // if (isMobile()) {
351
- // this.$refs.previewPdf.drawer = true;
352
- // this.$refs.previewPdf.previewShowPopup = false;
353
- // } else {
354
- // this.$refs.previewPdf.drawer = false;
355
- // }
356
- this.title = item.from || item.name
357
- this.folderName = item.folderName
358
- this.folderUrl = item.folderUrl
359
- this.previewKnowledge = item;
360
- this.previewKnowledgeId = item.knowledgeId
361
- this.$refs.previewPdf.previewShowPopup = false;
362
- this.$refs.previewPdf.drawer = false;
363
- this.previewOssPath = url;
364
- let index = url.lastIndexOf('?')
365
- let type = ''
366
- let httpUrl = '/knowledge-api/knowledge/getTemporaryCertificate'
367
- if (index !== -1) {
368
- url = url.substring(0, index)
369
- type = this.fileType(url)
370
- } else {
371
- type = this.fileType(url)
372
- }
373
- if (type === '' || type === 'OTHER' || type == 'IMAGE') {
374
- httpUrl = httpUrl += '?needEncrypt=true'
375
- } else {
376
- httpUrl = httpUrl += '?needEncrypt=false'
377
- }
378
- this.$refs.previewPdf.getOssPath(url);
379
- this.$http.post(httpUrl, {
380
- "fileInOssPath": url
381
- }).then(res => {
382
- if (res.data.code == '0') {
383
- this.previewHref = res.data.data;
384
- this.sourceFileType = url.substring(url.lastIndexOf('.'))
385
- let isOhmPc = sessionStorage.getItem('isOhmPc')
386
- if (isMobile() || isOhmPc == 'true') {
387
- this.$refs.previewPdf.drawer = true;
388
- this.$refs.previewPdf.previewShowPopup = true;
389
- } else {
390
- this.$refs.previewPdf.previewShowPopup = false;
391
- this.$refs.previewPdf.drawer = true;
392
- }
393
- //聊一聊按钮的选中状态
394
- if (this.activeKnowledgeId == item.knowledgeId) {
395
- this.$refs.previewPdf.previewKnowledgeId = this.activeKnowledgeId
396
- } else {
397
- this.$refs.previewPdf.previewKnowledgeId = ""
398
- }
399
- this.$refs.previewPdf.fileType = type
400
- this.$refs.previewPdf.tagIds = item.tagIds;
401
- if (item.tagIds && item.tagIds.length > 0){
402
- this.$refs.previewPdf.getLocationInfo();
403
- }
404
- this.$refs.previewPdf.isMessageRecord = this.isMessageRecord ? true : false;
405
- let index = url.indexOf("?");
406
- let newFileInOssPath = url;
407
- if (index !== -1) {
408
- newFileInOssPath = url.substring(0, url.indexOf("?"))
409
- }
410
- let fileName = newFileInOssPath.substring(newFileInOssPath.lastIndexOf('.'))
411
- if (fileName === '.doc' || fileName === '.docx' || fileName === '.txt' || fileName === '.html') {
412
- this.$refs.previewPdf.fileName = fileName;
413
- } else {
414
- this.$refs.previewPdf.fileName = '';
415
- }
416
- if (item.tagIds && item.tagIds.length != 0 && this.$refs.previewPdf.newFileType !== 'PPT') {
417
- this.$refs.previewPdf.loading = false
418
- return
419
- }
420
- this.$nextTick(() => {
421
- if (item.source == 'CREATED_BY_ONESELF' || type === 'HTML') {
422
- this.$refs.previewPdf.getBolb(item)
423
- }
424
- this.$refs.previewPdf.loadIframe(item)
425
- this.$refs.previewPdf.showSummary = true;
426
- })
427
- }
428
- })
429
- }
430
- },
431
- open () {
432
- this.$emit('openPreviewDialog')
433
- },
434
- close () {
435
- this.$emit('closePreviewDialog')
436
- },
437
- fileType (url) {
438
- const fileType = url.substring(url.lastIndexOf('.'));
439
- if (fileType === '.mp4' || fileType === '.MP4' || fileType === '.MOV' || fileType === '.MOVC' || fileType === '.mov' || fileType === '.movc' || fileType === '.mav' || fileType === '.MAV' || fileType == '.mp3' || fileType == '.MP3' || fileType === '.wav') {
440
- return 'VIDEO'
441
- } else if (fileType === '.html') {
442
- return 'HTML'
443
- } else if (fileType === '.png' || fileType === '.jpg' || fileType === '.jpeg') {
444
- return 'IMAGE'
445
- } else {
446
- return 'OTHER'
447
- }
448
- },
449
- srcContentTypeIMG (item) {
450
- let url = item.url || '';
451
- const type = url.substring(url.lastIndexOf('.'));
452
- if (type === '.jpg' || type === '.jpeg' || type === '.png' || type === '.gif') {
453
- this.getSrc(item)
454
- return true
455
- } else {
456
- return false
457
- }
458
- },
459
- getSrc (item) {
460
- // let imgurl = ''
461
- this.$http.post(
462
- '/knowledge-api/temporary-certificate/or-origin?expired=30',
463
- item.url,
464
- {
465
- headers: {
466
- "Content-Type": "application/json",
467
- },
468
- }).then(res => {
469
- console.log(res, '=====');
470
- // imgurl = await res.bodyText
471
- this.$set(item, 'expiredUrl', res.data ? res.data : res.bodyText)
472
- // return res.data
473
- })
474
- // return imgurl
475
- },
476
- lazyLoadKnowledegList () {
477
- if (this.allKnowledgeList.length !== 0) {
478
- let arr = this.allKnowledgeList.splice(0, 5)
479
- if (arr.length < 5) {
480
- this.loadMoreFlag = false
481
- this.msg.content.list = [...this.msg.content.list, ...arr]
482
- return
483
- }
484
- if (this.allKnowledgeList.length == 0) {
485
- this.loadMoreFlag = false
486
- }
487
- this.msg.content.list = [...this.msg.content.list, ...arr]
488
- return
489
- }
490
- },
491
- previewToDialog (flag) {
492
- if (!flag) {
493
- this.$refs.previewPdf.previewKnowledgeId = ""
494
- } else {
495
- this.$refs.previewPdf.previewKnowledgeId = this.previewKnowledgeId
496
- }
497
- this.$emit('previewToDialog', flag, this.previewKnowledgeId, this.previewKnowledge)
498
- },
499
- clearKnowledgeId () {
500
- this.previewKnowledgeId = "";
501
- },
502
- recommendQues (item, knowledgeId) {
503
- this.$emit('recommendQues', item, knowledgeId)
504
- },
505
- clickFloder (item) {
506
- this.$emit('clickFloder', item)
507
- },
508
- previewClickFloder () {
509
- let item = null
510
- this.msg.content.list.forEach(element => {
511
- if (element.knowledgeId == this.previewKnowledgeId) {
512
- item = element
513
- }
514
- });
515
- this.$emit('clickFloder', item)
516
- }
517
- }
518
- }
519
- </script>
520
-
521
- <style scoped lang="less">
522
- .answer-docknowledge {
523
- min-width: 100px;
524
- background: #ffffff;
525
-
526
- .answer-docknowledge-header {
527
- .tips {
528
- width: 154px;
529
- height: 22px;
530
- background: #366aff;
531
- border-radius: 5px;
532
- text-align: center;
533
- line-height: 22px;
534
- color: #fff;
535
- font-size: 12px;
536
- margin-bottom: 7px;
537
- }
538
-
539
- .answer-text {
540
- // font-size: 13px;
541
- text-align: left;
542
- line-height: 25px;
543
- padding: 0px 0px 12px 0px;
544
-
545
- .aci-view {
546
- // font-size: 13px;
547
- display: inline-block;
548
- // margin-left: 5px;
549
- color: #366aff;
550
- cursor: pointer;
551
- }
552
- }
553
-
554
- &.bgc {
555
- padding: 10px;
556
- background: #eef1ff;
557
- border-radius: 10px;
558
- margin-bottom: 16px;
559
-
560
- .answer-text {
561
- padding: 0;
562
- }
563
- }
564
-
565
- .answer-kn-image-box {
566
- margin-bottom: 10px;
567
- }
568
- }
569
-
570
-
571
- .ad-list-recognition {
572
- display: flex;
573
- align-items: center;
574
- flex-wrap: wrap;
575
- }
576
-
577
- .libang_list_recognition {
578
- display: flex;
579
- align-items: center;
580
- flex-wrap: wrap;
581
- }
582
-
583
- .ad-list {
584
- .ad-list-cell {
585
- border-top: solid 1px #eeeeee;
586
- padding: 10px 0 10px;
587
-
588
- .alc-title {
589
- display: flex;
590
- flex-wrap: wrap;
591
- align-items: center;
592
- justify-content: space-between;
593
- line-height: 16px;
594
-
595
- .alc-box {
596
- display: flex;
597
- align-items: center;
598
- justify-content: space-between;
599
- // font-size: 12px;
600
- width: 100%;
601
-
602
- .alc-source-left {
603
- display: flex;
604
- align-items: center;
605
-
606
- .source-form {
607
- width: 34px;
608
- flex: none;
609
- color: #a9b3c6;
610
- }
611
- }
612
-
613
- .alc-content-text {
614
- width: 55px;
615
- flex: none;
616
-
617
- .aci-view {
618
- color: #366aff;
619
- cursor: pointer;
620
- }
621
- }
622
-
623
- .alc-title-from {
624
- line-height: 22px;
625
- word-break: break-all !important;
626
- text-align: left;
627
- flex: auto;
628
- display: flex;
629
- justify-content: flex-start;
630
- }
631
- .upload-source {
632
- // flex: none;
633
- }
634
- }
635
-
636
- .alc-box-introduction {
637
- overflow: hidden;
638
- text-overflow: ellipsis;
639
- display: -webkit-box;
640
- -webkit-line-clamp: 3;
641
- -webkit-box-orient: vertical;
642
- margin-top: 10px;
643
- color: #616161;
644
- // font-size: 12px;
645
- line-height: 24px;
646
- text-align: left;
647
-
648
- img {
649
- width: 50px;
650
- height: 50px;
651
- margin: 10px;
652
- cursor: pointer;
653
- }
654
- }
655
-
656
- .alc-box-introduction-previewImage {
657
- width: 100%;
658
- display: block;
659
- overflow: hidden;
660
- text-overflow: ellipsis;
661
- display: -webkit-box;
662
- -webkit-line-clamp: 3;
663
- -webkit-box-orient: vertical;
664
- margin-top: 10px;
665
- color: #616161;
666
- // font-size: 12px;
667
- line-height: 24px;
668
- text-align: left;
669
-
670
- img {
671
- max-width: 300px;
672
- width: 100%;
673
- max-height: 150px;
674
- margin: 10px;
675
- cursor: pointer;
676
- }
677
- }
678
-
679
- .alc-updateTime {
680
- display: flex;
681
- align-items: center;
682
- justify-content: space-between;
683
- font-size: 13px;
684
- width: 100%;
685
- margin-top: 10px;
686
-
687
- .upload-source {
688
- flex: none;
689
- height: 18px;
690
- line-height: 18px;
691
- background: #e9f9f8;
692
- border: 1px solid #aff2cd;
693
- border-radius: 2px;
694
- display: flex;
695
- align-items: center;
696
- justify-content: center;
697
- padding: 0 8px;
698
- color: #00c2bb;
699
- }
700
-
701
- .time {
702
- color: #999999;
703
- margin-left: 10px;
704
- }
705
-
706
- .alc-content-text {
707
- color: #366aff;
708
- cursor: pointer;
709
- }
710
- }
711
-
712
- .alc-title-icon {
713
- margin: 0 2px;
714
- width: 18px;
715
- height: 18px;
716
- flex: none;
717
- }
718
-
719
- .alc-title-updateTime {
720
- text-align: right;
721
- color: #999999;
722
- // font-size: 13px;
723
- }
724
- }
725
-
726
- .alc-content {
727
- .alc-title-updateTime {
728
- margin-top: 6px;
729
- display: block;
730
- text-align: right;
731
- color: #999999;
732
- // font-size: 13px;
733
- }
734
-
735
- .alc-content-text {
736
- margin-bottom: 6px;
737
- width: 55px;
738
- flex: none;
739
-
740
- .aci-view {
741
- display: inline-block;
742
- margin-left: 30px;
743
- color: #366aff;
744
- cursor: pointer;
745
- }
746
- }
747
-
748
- .alc-content-info {
749
- display: flex;
750
- flex-wrap: wrap;
751
- justify-content: space-between;
752
-
753
- .alcc-box {
754
- display: flex;
755
- flex-wrap: wrap;
756
- color: #999999;
757
-
758
- .aci-owner {
759
- margin-right: 20px;
760
- }
761
-
762
- .aci-enterprise {
763
- margin-right: 20px;
764
- }
765
- }
766
- }
767
- }
768
- }
769
-
770
- .ad-list-cell-recognition {
771
- max-width: 270px;
772
- margin-right: 12px;
773
- font-size: 12px;
774
- .alc-source-name {
775
- flex: none;
776
- padding: 3px;
777
- margin-right: 5px;
778
- margin-bottom: 5px;
779
- background: #f2f6ff;
780
- border-radius: 5px;
781
- display: flex;
782
- align-items: center;
783
- justify-content: space-between;
784
- cursor: pointer;
785
-
786
- img {
787
- vertical-align: middle;
788
- // width: 16px;
789
- // height: 16px;
790
- margin: 0 3px 0 5px;
791
- }
792
-
793
- .alc-title-from {
794
- // margin-right: 5px;
795
- max-width: 240px;
796
- overflow: hidden;
797
- text-overflow: ellipsis;
798
- white-space: nowrap;
799
- }
800
-
801
- .upload-source {
802
- margin-right: 5px;
803
- flex: none;
804
- }
805
-
806
- i {
807
- font-size: 12px;
808
- }
809
- }
810
- }
811
-
812
- .ad-loadmore {
813
- width: 100%;
814
- height: 40px;
815
- display: flex;
816
- align-items: center;
817
- justify-content: center;
818
- // background: #FFFFFF;
819
- color: #366aff;
820
- font-size: 14px;
821
- margin-top: 8px;
822
- cursor: pointer;
823
- }
824
- }
825
-
826
- .libang_list {
827
- .libang_list_cell {
828
- border-top: solid 1px #eeeeee;
829
- padding: 10px 0 10px;
830
- font-size: 12px;
831
- .libang_title {
832
- display: flex;
833
- flex-wrap: wrap;
834
- align-items: center;
835
- justify-content: space-between;
836
- line-height: 16px;
837
-
838
- .libang_box {
839
- display: flex;
840
- align-items: center;
841
- justify-content: space-between;
842
- // font-size: 12px;
843
- width: 100%;
844
-
845
- .libang_source_left {
846
- display: flex;
847
- align-items: center;
848
-
849
- .source-form {
850
- width: 34px;
851
- flex: none;
852
- color: #a9b3c6;
853
- }
854
- }
855
-
856
- .alc-content-text {
857
- width: 55px;
858
- flex: none;
859
-
860
- .aci-view {
861
- color: #366aff;
862
- cursor: pointer;
863
- }
864
- }
865
-
866
- .libang_title_from {
867
- line-height: 22px;
868
- word-break: break-all !important;
869
- text-align: left;
870
- flex: auto;
871
- display: flex;
872
- justify-content: flex-start;
873
- }
874
- }
875
-
876
- .libang_box_introduction {
877
- overflow: hidden;
878
- text-overflow: ellipsis;
879
- display: -webkit-box;
880
- -webkit-line-clamp: 3;
881
- -webkit-box-orient: vertical;
882
- margin-top: 10px;
883
- color: #616161;
884
- // font-size: 12px;
885
- line-height: 24px;
886
- text-align: left;
887
-
888
- img {
889
- width: 50px;
890
- height: 50px;
891
- margin: 10px;
892
- cursor: pointer;
893
- }
894
- }
895
-
896
- .libang_box_introduction_previewImage {
897
- overflow: hidden;
898
- text-overflow: ellipsis;
899
- display: -webkit-box;
900
- -webkit-line-clamp: 3;
901
- -webkit-box-orient: vertical;
902
- margin-top: 10px;
903
- color: #616161;
904
- // font-size: 12px;
905
- line-height: 24px;
906
- text-align: left;
907
-
908
- img {
909
- max-width: 300px;
910
- width: 100%;
911
- max-height: 150px;
912
- margin: 10px;
913
- cursor: pointer;
914
- }
915
- }
916
-
917
- .libang_updateTime {
918
- display: flex;
919
- align-items: center;
920
- justify-content: space-between;
921
- font-size: 13px;
922
- width: 100%;
923
- margin-top: 10px;
924
- .libang_updataTime_left {
925
- width: calc(100% - 40px);
926
- display: flex;
927
- align-items: center;
928
- .upload-source {
929
- flex: none;
930
- height: 18px;
931
- line-height: 18px;
932
- background: #e9f9f8;
933
- border: 1px solid #aff2cd;
934
- border-radius: 2px;
935
- display: flex;
936
- align-items: center;
937
- justify-content: center;
938
- padding: 0 8px;
939
- color: #00c2bb;
940
- }
941
- .libang_floder {
942
- width:calc(100% - 90px);
943
- // margin-left: 10px;
944
- overflow: hidden;
945
- text-overflow: ellipsis;
946
- white-space: nowrap;
947
- color: #366aff;
948
- cursor: pointer;
949
- text-align: left;
950
- i {
951
- margin-left: 8px;
952
- }
953
- }
954
- }
955
- .libang_content_text {
956
- color: #366aff;
957
- cursor: pointer;
958
- }
959
- .time {
960
- color: #999999;
961
- margin-left: 10px;
962
- }
963
- }
964
- .alc-title-icon {
965
- margin: 0 2px;
966
- width: 18px;
967
- height: 18px;
968
- flex: none;
969
- }
970
-
971
- .alc-title-updateTime {
972
- text-align: right;
973
- color: #999999;
974
- // font-size: 13px;
975
- }
976
- }
977
-
978
- .alc-content {
979
- .alc-title-updateTime {
980
- margin-top: 6px;
981
- display: block;
982
- text-align: right;
983
- color: #999999;
984
- // font-size: 13px;
985
- }
986
-
987
- .alc-content-text {
988
- margin-bottom: 6px;
989
- width: 55px;
990
- flex: none;
991
-
992
- .aci-view {
993
- display: inline-block;
994
- margin-left: 30px;
995
- color: #366aff;
996
- cursor: pointer;
997
- }
998
- }
999
-
1000
- .alc-content-info {
1001
- display: flex;
1002
- flex-wrap: wrap;
1003
- justify-content: space-between;
1004
-
1005
- .alcc-box {
1006
- display: flex;
1007
- flex-wrap: wrap;
1008
- color: #999999;
1009
-
1010
- .aci-owner {
1011
- margin-right: 20px;
1012
- }
1013
-
1014
- .aci-enterprise {
1015
- margin-right: 20px;
1016
- }
1017
- }
1018
- }
1019
- }
1020
- }
1021
-
1022
- .libang_list_cell_recognition {
1023
- background: #f2f6ff;
1024
- display: flex;
1025
- align-items: center;
1026
- justify-content: space-between;
1027
- padding: 3px;
1028
- margin-right: 5px;
1029
- margin-bottom: 5px;
1030
- border-radius: 5px;
1031
- cursor: pointer;
1032
- font-size: 12px;
1033
-
1034
- .libang_list_cell_left {
1035
- margin-right: 5px;
1036
- .libang_source_name {
1037
- display: flex;
1038
- align-items: center;
1039
- height: 20px;
1040
- margin-bottom: 2px;
1041
- img {
1042
- vertical-align: middle;
1043
- // width: 16px;
1044
- // height: 16px;
1045
- margin: 0 3px;
1046
- }
1047
-
1048
- .libang_title_from {
1049
- max-width: 226px;
1050
- overflow: hidden;
1051
- text-overflow: ellipsis;
1052
- white-space: nowrap;
1053
- line-height: 20px;
1054
- }
1055
- .upload_source {
1056
- flex: none;
1057
- }
1058
- }
1059
- .libang_source_floder {
1060
- max-width: calc(226px - 24px);
1061
- text-align: left;
1062
- color: #366aff;
1063
- overflow: hidden;
1064
- text-overflow: ellipsis;
1065
- white-space: nowrap;
1066
- cursor: pointer;
1067
- .iconfont {
1068
- margin: 0 5px;
1069
- font-size: 14px
1070
- }
1071
- }
1072
- }
1073
- i {
1074
- font-size: 12px;
1075
- }
1076
- }
1077
-
1078
- .ad-loadmore {
1079
- width: 100%;
1080
- height: 40px;
1081
- display: flex;
1082
- align-items: center;
1083
- justify-content: center;
1084
- // background: #FFFFFF;
1085
- color: #366aff;
1086
- font-size: 14px;
1087
- margin-top: 8px;
1088
- cursor: pointer;
1089
- }
1090
- }
1091
- }</style>
1
+ <!--
2
+ isLiBang 字段判断 是否为立邦主体
3
+ 立邦有自己单独的组件分支,但考虑到后期结构改动如果较大改动会不方便,所以还是在推荐知识消息中 在此判断是否是立邦主体。方便后期维护
4
+ -->
5
+ <template>
6
+ <div class="answer-docknowledge">
7
+ <div :class="['answer-docknowledge-header', msg.content.isKnowledgeSummary ? 'bgc' : '']">
8
+ <div v-if="msg.content.isKnowledgeSummary" class="tips">{{$t('dragonCommon.summaryGeneratedByAI')}}</div>
9
+ <!-- <div v-if="msg.content.type == 0" class="answer-text">
10
+ <template v-if="msg.content.renderType == 1">
11
+ <p v-html="msg.content.text"></p>
12
+ </template>
13
+ <template v-else>{{ msg.content.text }}</template>
14
+ </div> -->
15
+ <div class="answer-text">
16
+ <template v-if="msg.content.renderType == 1">
17
+ <p v-html="msg.content.text"></p>
18
+ </template>
19
+ <template v-else-if="msg.content.renderType == 2">
20
+ <markDownText :chainValues="msg.content.text" :isHistory="isHistory"></markDownText>
21
+ </template>
22
+ <template v-else>{{ msg.content.text }}</template>
23
+ </div>
24
+ <div v-if="msg.content.images && msg.content.images.length != 0" class="answer-kn-image-box">
25
+ <img v-for="(imageItem, imageItemIndex) in msg.content.images"
26
+ style="max-width: 230px;border-radius: 25px;margin-bottom: 15px" :src="imageItem.url"
27
+ :key="imageItemIndex" alt @click="lookAttach(imageItem.url, imageItem, $event)" />
28
+ </div>
29
+ </div>
30
+ <template v-if="!isLiBang">
31
+ <div class="ad-list" :class="msg.content.type == 0 ? 'ad-list-recognition' : ''">
32
+ <template v-if="msg.content.type == 1">
33
+ <div v-for="(item, itemIndex) in msg.content.list" :key="itemIndex"
34
+ :style="{ paddingBottom: itemIndex === msg.content.list.length - 1 ? 0 : '10px' }" class="ad-list-cell">
35
+ <div class="alc-title">
36
+ <div class="alc-box">
37
+ <div class="alc-source-left">
38
+ <span class="source-form">{{$t('dragonCommon.from')}}</span>
39
+ <img class="alc-title-icon" height="24px" width="24px" :src="getIconSrc(item)" alt=""
40
+ srcset="">
41
+ <span class="alc-title-from">{{ item.from }}</span>
42
+ </div>
43
+ </div>
44
+ <div v-html="item.introduction" v-if="!srcContentTypeIMG(item)" class="alc-box-introduction">
45
+ </div>
46
+ <div v-else class="alc-box-introduction">
47
+ <img :src="item.expiredUrl" alt="" @click="lookAttach(item.url, item, $event)">
48
+ </div>
49
+ <div v-if="item.previewImage" class="alc-box-introduction-previewImage">
50
+ <img :src="item.previewImage" alt=""
51
+ @click="lookAttach(item.previewImage, { url: item.previewImage }, $event)">
52
+ </div>
53
+ <div class="alc-updateTime">
54
+ <div v-show="docSource[item.source]" class="upload-source">
55
+ {{ docSource[item.source] }}
56
+ </div>
57
+ <div v-show="item.url" class="alc-content-text">
58
+ <span @click="lookAttach(item.url, item, $event)" class="aci-view">{{$t('dragonCommon.check')}} ></span>
59
+ </div>
60
+ </div>
61
+ </div>
62
+ <div class="alc-content" v-if="false">
63
+ <div v-if="msg.content.type == 1" class="alc-content-text">
64
+ {{ item.introduction }}
65
+ <span @click="lookAttach(item.url, item, $event)" class="aci-view">{{$t('dragonCommon.viewOriginal')}} ></span>
66
+ </div>
67
+ <span v-if="!isPC" class="alc-title-updateTime">{{$t('dragonCommon.lastUpdateTime')}}: {{ item.updateTime }}</span>
68
+ <div v-if="false" class="alc-content-info">
69
+ <div class="alcc-box">
70
+ <span class="aci-owner">{{$t('dragonCommon.owner')}}: {{ item.owner }}</span>
71
+ <span class="aci-enterprise">{{$t('dragonCommon.enterprise')}}: {{ item.enterprise }}</span>
72
+ <span class="aci-source">{{$t('dragonCommon.source')}}: {{ item.source }}</span>
73
+ </div>
74
+ </div>
75
+ </div>
76
+ </div>
77
+ </template>
78
+ <template v-if="msg.content.type == 0">
79
+ <div v-for="(item, itemIndex) in msg.content.list" :key="itemIndex" class="ad-list-cell-recognition">
80
+ <div class="alc-source-name" @click="lookAttach(item.url, item, $event)">
81
+ <img class="alc-title-icon" height="18px" width="18px" :src="getIconSrc(item)" alt srcset />
82
+ <span class="alc-title-from">{{ item.from }}</span>
83
+ <div v-show="docSource[item.source]" class="upload-source">
84
+ -{{ docSource[item.source] }}
85
+ </div>
86
+ <i class="iconfont guoran-right"></i>
87
+ </div>
88
+ </div>
89
+ </template>
90
+ <div class="ad-loadmore" v-if="loadMoreFlag" @click="lazyLoadKnowledegList">{{$t('dragonCommon.viewMore')}}</div>
91
+ </div>
92
+ </template>
93
+ <template v-if="isLiBang">
94
+ <div class="libang_list" :class="msg.content.type == 0 ? 'libang_list_recognition' : ''">
95
+ <template v-if="msg.content.type == 1">
96
+ <div v-for="(item, itemIndex) in msg.content.list" :key="itemIndex" class="libang_list_cell">
97
+ <div class="libang_title">
98
+ <div class="libang_box">
99
+ <div class="libang_source_left">
100
+ <span class="source-form">{{$t('dragonCommon.from')}}</span>
101
+ <img class="libang_title_icon" height="24px" width="24px" :src="getIconSrc(item)" alt=""
102
+ srcset="">
103
+ <span class="libang_title_from">{{ item.from }}</span>
104
+ </div>
105
+ </div>
106
+ <div v-html="item.introduction" v-if="!srcContentTypeIMG(item)" class="libang_box_introduction">
107
+ </div>
108
+ <div v-else class="libang_box_introduction">
109
+ <img :src="item.expiredUrl" alt="" @click="lookAttach(item.url, item, $event)">
110
+ </div>
111
+ <div v-if="item.previewImage" class="libang_box_introduction_previewImage">
112
+ <img :src="item.previewImage" alt=""
113
+ @click="lookAttach(item.previewImage, { url: item.previewImage }, $event)">
114
+ </div>
115
+ <div class="libang_updateTime">
116
+ <div class="libang_updataTime_left">
117
+ <div v-show="docSource[item.source]" class="upload-source">
118
+ {{ docSource[item.source] }}
119
+ </div>
120
+ <div class="libang_floder" @click.stop="clickFloder(item)">
121
+ <i class="iconfont guoran-tongyichicun-wenjianjia-zhankaizhuangtai--folderOpen"></i>
122
+ {{ item.folderName }}
123
+ </div>
124
+ </div>
125
+ <div v-show="item.url" class="libang_content_text">
126
+ <span @click="lookAttach(item.url, item, $event)" class="aci-view">{{$t('dragonCommon.check')}} ></span>
127
+ </div>
128
+ </div>
129
+ </div>
130
+ <!-- <div class="alc-content" v-if="false">
131
+ <div v-if="msg.content.type == 1" class="alc-content-text">
132
+ {{ item.introduction }}
133
+ <span @click="lookAttach(item.url, item, $event)" class="aci-view">查看原文 ></span>
134
+ </div>
135
+ <span v-if="!isPC" class="alc-title-updateTime">最后更新时间: {{ item.updateTime }}</span>
136
+ <div v-if="false" class="alc-content-info">
137
+ <div class="alcc-box">
138
+ <span class="aci-owner">所有者: {{ item.owner }}</span>
139
+ <span class="aci-enterprise">所属企业: {{ item.enterprise }}</span>
140
+ <span class="aci-source">文件来源: {{ item.source }}</span>
141
+ </div>
142
+ </div>
143
+ </div> -->
144
+ </div>
145
+ </template>
146
+ <template v-if="msg.content.type == 0">
147
+ <div v-for="(item, itemIndex) in msg.content.list" :key="itemIndex"
148
+ class="libang_list_cell_recognition" @click="lookAttach(item.url, item, $event)">
149
+ <div class="libang_list_cell_left" >
150
+ <div class="libang_source_name" >
151
+ <img class="libang_title_icon" height="18px" width="18px" :src="getIconSrc(item)" alt srcset />
152
+ <span class="libang_title_from">{{ item.from }}</span>
153
+ <div v-show="docSource[item.source]" class="upload_source">
154
+ -{{ docSource[item.source] }}
155
+ </div>
156
+ </div>
157
+ <div class="libang_source_floder" @click.stop="clickFloder(item)">
158
+ <i class="iconfont guoran-tongyichicun-wenjianjia-zhankaizhuangtai--folderOpen"></i>
159
+ {{ item.folderName }}
160
+ </div>
161
+ </div>
162
+ <i class="iconfont guoran-right" @click="lookAttach(item.url, item, $event)"></i>
163
+ </div>
164
+ </template>
165
+ <div class="ad-loadmore" v-if="loadMoreFlag" @click="lazyLoadKnowledegList">{{$t('dragonCommon.viewMore')}}</div>
166
+ </div>
167
+ </template>
168
+
169
+ <previewPdf ref="previewPdf" :url="previewHref" :previewOssPath="previewOssPath" :title="title"
170
+ :folderName="folderName" :folderUrl="folderUrl"
171
+ :sourceFileType="sourceFileType" officePreviewType="pdf" @previewToDialog="previewToDialog"
172
+ @recommendQues="recommendQues" @close="close" @open="open" :isHasChat="isHasChat"
173
+ :knowledgeId="previewKnowledgeId" :isLiBang="isLiBang" @previewClickFloder="previewClickFloder"></previewPdf>
174
+ </div>
175
+ </template>
176
+
177
+ <script>
178
+ /* eslint-disable */
179
+ import previewPdf from "./previewPdf";
180
+ import { isMobile } from "../assets/js/common";
181
+ import markDownText from "./markDownText.vue";
182
+ export default {
183
+ name: "answerDocknowledge",
184
+ components: { previewPdf, markDownText },
185
+ data () {
186
+ return {
187
+ isPC: true,
188
+ previewHref: "",
189
+ sourceFileType: '',
190
+ // docSource: {
191
+ // LOCAL_FILE: "来源于本地文件",
192
+ // CREATED_BY_ONESELF: "来源于自建知识",
193
+ // WECHAT: "来源于微信",
194
+ // AUTO_SYN_FROM_LOCAL_FILE: "自动同步于本地",
195
+ // YUQUE: "来源于语雀",
196
+ // CORP_LOCAL_FILE: '来源于企业知识库',
197
+ // FEISHU: '来源于飞书-云文档'
198
+ // },
199
+ docSource: {},
200
+ imageObj: {
201
+ PDF: 'pdf1',
202
+ pdf: 'pdf1',
203
+ TXT: 'txt1',
204
+ txt: 'txt1',
205
+ selfadd: 'selfadd1',
206
+ md: "md2",
207
+ html: 'selfadd1',
208
+ mode: "mode",
209
+ general: 'general',
210
+ word: "word1",
211
+ Word: "word1",
212
+ docx: "word1",
213
+ doc: "word1",
214
+ WORD: "word1",
215
+ Excel: 'excel1',
216
+ EXCEL: 'excel1',
217
+ excel: 'excel1',
218
+ PPT: 'ppt1',
219
+ ppt: 'ppt1',
220
+ pptx: 'ppt1',
221
+ img: "image1",
222
+ image: "image1",
223
+ video: "video",
224
+ audio: 'audio',
225
+ link: "link",
226
+ wechat: "wechat",
227
+ mp4: "video",
228
+ MP4: "video",
229
+ xlsx: "excel1",
230
+ SLSX: "excel1",
231
+ xls: "excel1",
232
+ XLS: "excel1",
233
+ jpg: "image1",
234
+ JPG: "image1",
235
+ jpeg: "image1",
236
+ JPEG: "image1",
237
+ png: "image1",
238
+ PNG: "image1",
239
+ webp: "image1",
240
+ WEBP: "image1",
241
+ gif: "image1",
242
+ GIF: "image1",
243
+ svg: "image1",
244
+ SVG: "image1",
245
+ bmp: "image1",
246
+ BMP: "image1",
247
+ avi: "video",
248
+ AVI: "video",
249
+ mov: "video",
250
+ MOV: "video",
251
+ rmvb: "video",
252
+ RMVB: "video",
253
+ wav: "audio",
254
+ WAV: "audio",
255
+ mp3: "audio",
256
+ MP3: "audio",
257
+ yqhtml: "yqhtml",
258
+ feishuhtml: "feishuhtml"
259
+ },
260
+ allKnowledgeList: [],
261
+ loadMoreFlag: false,
262
+ title: '',
263
+ folderName: '',
264
+ folderUrl: '',
265
+ previewKnowledgeId: "",
266
+ previewKnowledge: {},
267
+ previewOssPath: ""
268
+ }
269
+ },
270
+ props: ['msg', 'isAskLightning', 'isMessageRecord', "isApp", "isHasChat", "activeKnowledgeId", "isLiBang","isHistory"],
271
+ beforeMounted () {
272
+ },
273
+ watch: {
274
+ // msg: {
275
+ // handler (n) {
276
+ // console.log(n, 'answerDocknowledge');
277
+ // n.content.list.forEach(element => {
278
+ // console.log(this.imageObj[element.format], 1111);
279
+ // element.src = 'https://static.guoranbot.com/cdn-office-website/askbot_doc/' + this.imageObj[element.format] + '.png';
280
+ // if ((element.format === "txt" || element.format === "html") && element.source === "WECHAT") {
281
+ // element.src = 'https://static.guoranbot.com/cdn-office-website/askbot_doc/wechat.png';
282
+ // }
283
+ // });
284
+ // },
285
+ // deep: true,
286
+ // immediate: true
287
+ // }
288
+ },
289
+ created () {
290
+ var system = {};
291
+ system.pingtai = /(Win32|Win16|WinCE|Mac68K|MacIntel|MacIntel|MacPPC|Linux mips64)/i.test(navigator.platform);
292
+ if (system.pingtai) {
293
+ //电脑
294
+ this.isPC = true;
295
+ } else {
296
+ //手机
297
+ this.isPC = false;
298
+ }
299
+ // this.msg.content.list.forEach(element => {
300
+ // console.log(this.imageObj[element.format],1111);
301
+ // element.src = 'https://static.guoranbot.com/cdn-office-website/askbot_doc/' + this.imageObj[element.format] + '.png';
302
+ // if ((element.format === "txt" || element.format === "html") && element.source === "WECHAT") {
303
+ // element.src = 'https://static.guoranbot.com/cdn-office-website/askbot_doc/wechat.png';
304
+ // }
305
+ // });
306
+ },
307
+ mounted () {
308
+ this.docSource = {
309
+ LOCAL_FILE: this.$t('dragonCommon.personalknowledge'),
310
+ CREATED_BY_ONESELF: this.$t('dragonCommon.personalknowledge'),
311
+ WECHAT: this.$t('dragonCommon.personalknowledge'),
312
+ AUTO_SYN_FROM_LOCAL_FILE: this.$t('dragonCommon.personalknowledge'),
313
+ YUQUE: this.$t('dragonCommon.enterpriseknowledge'),
314
+ CORP_LOCAL_FILE: this.$t('dragonCommon.enterpriseknowledge'),
315
+ FEISHU: this.$t('dragonCommon.enterpriseknowledge'),
316
+ }
317
+ console.log(this.msg.content, 'this.msg.content');
318
+ // if(this.msg.content.type == 1) {
319
+
320
+ // }
321
+ if (this.msg.content.list && this.msg.content.list.length > 0) {
322
+ this.loadMoreFlag = true
323
+ this.allKnowledgeList = JSON.parse(JSON.stringify(this.msg.content.list))
324
+ // console.log(this.allKnowledgeList.length, 'this.allKnowledgeList');
325
+ this.msg.content.list = []
326
+ this.lazyLoadKnowledegList()
327
+ }
328
+ },
329
+ methods: {
330
+ getIconSrc (element) {
331
+ if ((element.format === "txt" || element.format === "html") && element.source === "WECHAT") {
332
+ return require("../assets/image/filtType/wechat.png")
333
+ } else {
334
+ return require("../assets/image/filtType/" + this.imageObj[element.format] + '.png')
335
+
336
+ }
337
+ },
338
+ //预览图片
339
+ lookAttach (url, item, event) {
340
+ // console.log(item.knowledgeId);
341
+ // this.$http.get("/knowledge-api/internal/knowledgeBaseStructure/" + "642ffbccde420e2772f7787b")
342
+ // debugger
343
+ event.preventDefault();
344
+ if (this.isAskLightning == 1 && !this.isApp) {
345
+ window.parent.postMessage({
346
+ data: "bot_preview",
347
+ item: JSON.stringify(item),
348
+ url: url
349
+ }, "*");
350
+ } else {
351
+ // if (isMobile()) {
352
+ // this.$refs.previewPdf.drawer = true;
353
+ // this.$refs.previewPdf.previewShowPopup = false;
354
+ // } else {
355
+ // this.$refs.previewPdf.drawer = false;
356
+ // }
357
+ this.title = item.from || item.name
358
+ this.folderName = item.folderName
359
+ this.folderUrl = item.folderUrl
360
+ this.previewKnowledge = item;
361
+ this.previewKnowledgeId = item.knowledgeId
362
+ this.$refs.previewPdf.previewShowPopup = false;
363
+ this.$refs.previewPdf.drawer = false;
364
+ this.previewOssPath = url;
365
+ let index = url.lastIndexOf('?')
366
+ let type = ''
367
+ let httpUrl = '/knowledge-api/knowledge/getTemporaryCertificate'
368
+ if (index !== -1) {
369
+ url = url.substring(0, index)
370
+ type = this.fileType(url)
371
+ } else {
372
+ type = this.fileType(url)
373
+ }
374
+ if (type === '' || type === 'OTHER' || type == 'IMAGE') {
375
+ httpUrl = httpUrl += '?needEncrypt=true'
376
+ } else {
377
+ httpUrl = httpUrl += '?needEncrypt=false'
378
+ }
379
+ this.$http.post(httpUrl, {
380
+ "fileInOssPath": url
381
+ }).then(res => {
382
+ if (res.data.code == '0') {
383
+ this.previewHref = res.data.data;
384
+ this.sourceFileType = url.substring(url.lastIndexOf('.'))
385
+ let isOhmPc = sessionStorage.getItem('isOhmPc')
386
+ if (isMobile() || isOhmPc == 'true') {
387
+ this.$refs.previewPdf.drawer = true;
388
+ this.$refs.previewPdf.previewShowPopup = true;
389
+ } else {
390
+ this.$refs.previewPdf.previewShowPopup = false;
391
+ this.$refs.previewPdf.drawer = true;
392
+ }
393
+ //聊一聊按钮的选中状态
394
+ if (this.activeKnowledgeId == item.knowledgeId) {
395
+ this.$refs.previewPdf.previewKnowledgeId = this.activeKnowledgeId
396
+ } else {
397
+ this.$refs.previewPdf.previewKnowledgeId = ""
398
+ }
399
+ this.$refs.previewPdf.fileType = type
400
+ this.$refs.previewPdf.tagIds = item.tagIds
401
+ this.$refs.previewPdf.isMessageRecord = this.isMessageRecord ? true : false;
402
+ let index = url.indexOf("?");
403
+ let newFileInOssPath = url;
404
+ if (index !== -1) {
405
+ newFileInOssPath = url.substring(0, url.indexOf("?"))
406
+ }
407
+ let fileName = newFileInOssPath.substring(newFileInOssPath.lastIndexOf('.'))
408
+ if (fileName === '.doc' || fileName === '.docx' || fileName === '.txt' || fileName === '.html') {
409
+ this.$refs.previewPdf.fileName = fileName;
410
+ } else {
411
+ this.$refs.previewPdf.fileName = '';
412
+ }
413
+ if (item.tagIds && item.tagIds.length != 0) {
414
+ this.$refs.previewPdf.loading = false
415
+ return
416
+ }
417
+ this.$nextTick(() => {
418
+ if (item.source == 'CREATED_BY_ONESELF' || type === 'HTML') {
419
+ this.$refs.previewPdf.getBolb(item)
420
+ }
421
+ this.$refs.previewPdf.loadIframe(item)
422
+ this.$refs.previewPdf.showSummary = true;
423
+ })
424
+ }
425
+ })
426
+ }
427
+ },
428
+ open () {
429
+ this.$emit('openPreviewDialog')
430
+ },
431
+ close () {
432
+ this.$emit('closePreviewDialog')
433
+ },
434
+ fileType (url) {
435
+ const fileType = url.substring(url.lastIndexOf('.'));
436
+ if (fileType === '.mp4' || fileType === '.MP4' || fileType === '.MOV' || fileType === '.MOVC' || fileType === '.mov' || fileType === '.movc' || fileType === '.mav' || fileType === '.MAV' || fileType == '.mp3' || fileType == '.MP3' || fileType === '.wav') {
437
+ return 'VIDEO'
438
+ } else if (fileType === '.html') {
439
+ return 'HTML'
440
+ } else if (fileType === '.png' || fileType === '.jpg' || fileType === '.jpeg') {
441
+ return 'IMAGE'
442
+ } else {
443
+ return 'OTHER'
444
+ }
445
+ },
446
+ srcContentTypeIMG (item) {
447
+ let url = item.url || '';
448
+ const type = url.substring(url.lastIndexOf('.'));
449
+ if (type === '.jpg' || type === '.jpeg' || type === '.png' || type === '.gif') {
450
+ this.getSrc(item)
451
+ return true
452
+ } else {
453
+ return false
454
+ }
455
+ },
456
+ getSrc (item) {
457
+ // let imgurl = ''
458
+ this.$http.post(
459
+ '/knowledge-api/temporary-certificate/or-origin?expired=30',
460
+ item.url,
461
+ {
462
+ headers: {
463
+ "Content-Type": "application/json",
464
+ },
465
+ }).then(res => {
466
+ console.log(res, '=====');
467
+ // imgurl = await res.bodyText
468
+ this.$set(item, 'expiredUrl', res.data ? res.data : res.bodyText)
469
+ // return res.data
470
+ })
471
+ // return imgurl
472
+ },
473
+ lazyLoadKnowledegList () {
474
+ if (this.allKnowledgeList.length !== 0) {
475
+ let arr = this.allKnowledgeList.splice(0, 5)
476
+ if (arr.length < 5) {
477
+ this.loadMoreFlag = false
478
+ this.msg.content.list = [...this.msg.content.list, ...arr]
479
+ return
480
+ }
481
+ if (this.allKnowledgeList.length == 0) {
482
+ this.loadMoreFlag = false
483
+ }
484
+ this.msg.content.list = [...this.msg.content.list, ...arr]
485
+ return
486
+ }
487
+ },
488
+ previewToDialog (flag) {
489
+ if (!flag) {
490
+ this.$refs.previewPdf.previewKnowledgeId = ""
491
+ } else {
492
+ this.$refs.previewPdf.previewKnowledgeId = this.previewKnowledgeId
493
+ }
494
+ this.$emit('previewToDialog', flag, this.previewKnowledgeId, this.previewKnowledge)
495
+ },
496
+ clearKnowledgeId () {
497
+ this.previewKnowledgeId = "";
498
+ },
499
+ recommendQues (item, knowledgeId) {
500
+ this.$emit('recommendQues', item, knowledgeId)
501
+ },
502
+ clickFloder (item) {
503
+ this.$emit('clickFloder', item)
504
+ },
505
+ previewClickFloder () {
506
+ let item = null
507
+ this.msg.content.list.forEach(element => {
508
+ if (element.knowledgeId == this.previewKnowledgeId) {
509
+ item = element
510
+ }
511
+ });
512
+ this.$emit('clickFloder', item)
513
+ }
514
+ }
515
+ }
516
+ </script>
517
+
518
+ <style scoped lang="less">
519
+ .answer-docknowledge {
520
+ min-width: 100px;
521
+ background: #ffffff;
522
+
523
+ .answer-docknowledge-header {
524
+ .tips {
525
+ width: 154px;
526
+ height: 22px;
527
+ background: #366aff;
528
+ border-radius: 5px;
529
+ text-align: center;
530
+ line-height: 22px;
531
+ color: #fff;
532
+ font-size: 12px;
533
+ margin-bottom: 7px;
534
+ }
535
+
536
+ .answer-text {
537
+ // font-size: 13px;
538
+ text-align: left;
539
+ line-height: 25px;
540
+ padding: 0px 0px 12px 0px;
541
+
542
+ .aci-view {
543
+ // font-size: 13px;
544
+ display: inline-block;
545
+ // margin-left: 5px;
546
+ color: #366aff;
547
+ cursor: pointer;
548
+ }
549
+ }
550
+
551
+ &.bgc {
552
+ padding: 10px;
553
+ background: #eef1ff;
554
+ border-radius: 10px;
555
+ margin-bottom: 16px;
556
+
557
+ .answer-text {
558
+ padding: 0;
559
+ }
560
+ }
561
+
562
+ .answer-kn-image-box {
563
+ margin-bottom: 10px;
564
+ }
565
+ }
566
+
567
+
568
+ .ad-list-recognition {
569
+ display: flex;
570
+ align-items: center;
571
+ flex-wrap: wrap;
572
+ }
573
+
574
+ .libang_list_recognition {
575
+ display: flex;
576
+ align-items: center;
577
+ flex-wrap: wrap;
578
+ }
579
+
580
+ .ad-list {
581
+ .ad-list-cell {
582
+ border-top: solid 1px #eeeeee;
583
+ padding: 10px 0 10px;
584
+
585
+ .alc-title {
586
+ display: flex;
587
+ flex-wrap: wrap;
588
+ align-items: center;
589
+ justify-content: space-between;
590
+ line-height: 16px;
591
+
592
+ .alc-box {
593
+ display: flex;
594
+ align-items: center;
595
+ justify-content: space-between;
596
+ // font-size: 12px;
597
+ width: 100%;
598
+
599
+ .alc-source-left {
600
+ display: flex;
601
+ align-items: center;
602
+
603
+ .source-form {
604
+ width: 34px;
605
+ flex: none;
606
+ color: #a9b3c6;
607
+ }
608
+ }
609
+
610
+ .alc-content-text {
611
+ width: 55px;
612
+ flex: none;
613
+
614
+ .aci-view {
615
+ color: #366aff;
616
+ cursor: pointer;
617
+ }
618
+ }
619
+
620
+ .alc-title-from {
621
+ line-height: 22px;
622
+ word-break: break-all !important;
623
+ text-align: left;
624
+ flex: auto;
625
+ display: flex;
626
+ justify-content: flex-start;
627
+ }
628
+ .upload-source {
629
+ // flex: none;
630
+ }
631
+ }
632
+
633
+ .alc-box-introduction {
634
+ overflow: hidden;
635
+ text-overflow: ellipsis;
636
+ display: -webkit-box;
637
+ -webkit-line-clamp: 3;
638
+ -webkit-box-orient: vertical;
639
+ margin-top: 10px;
640
+ color: #616161;
641
+ // font-size: 12px;
642
+ line-height: 24px;
643
+ text-align: left;
644
+
645
+ img {
646
+ width: 50px;
647
+ height: 50px;
648
+ margin: 10px;
649
+ cursor: pointer;
650
+ }
651
+ }
652
+
653
+ .alc-box-introduction-previewImage {
654
+ width: 100%;
655
+ display: block;
656
+ overflow: hidden;
657
+ text-overflow: ellipsis;
658
+ display: -webkit-box;
659
+ -webkit-line-clamp: 3;
660
+ -webkit-box-orient: vertical;
661
+ margin-top: 10px;
662
+ color: #616161;
663
+ // font-size: 12px;
664
+ line-height: 24px;
665
+ text-align: left;
666
+
667
+ img {
668
+ max-width: 300px;
669
+ width: 100%;
670
+ max-height: 150px;
671
+ margin: 10px;
672
+ cursor: pointer;
673
+ }
674
+ }
675
+
676
+ .alc-updateTime {
677
+ display: flex;
678
+ align-items: center;
679
+ justify-content: space-between;
680
+ font-size: 13px;
681
+ width: 100%;
682
+ margin-top: 10px;
683
+
684
+ .upload-source {
685
+ flex: none;
686
+ height: 18px;
687
+ line-height: 18px;
688
+ background: #e9f9f8;
689
+ border: 1px solid #aff2cd;
690
+ border-radius: 2px;
691
+ display: flex;
692
+ align-items: center;
693
+ justify-content: center;
694
+ padding: 0 8px;
695
+ color: #00c2bb;
696
+ }
697
+
698
+ .time {
699
+ color: #999999;
700
+ margin-left: 10px;
701
+ }
702
+
703
+ .alc-content-text {
704
+ color: #366aff;
705
+ cursor: pointer;
706
+ }
707
+ }
708
+
709
+ .alc-title-icon {
710
+ margin: 0 2px;
711
+ width: 18px;
712
+ height: 18px;
713
+ flex: none;
714
+ }
715
+
716
+ .alc-title-updateTime {
717
+ text-align: right;
718
+ color: #999999;
719
+ // font-size: 13px;
720
+ }
721
+ }
722
+
723
+ .alc-content {
724
+ .alc-title-updateTime {
725
+ margin-top: 6px;
726
+ display: block;
727
+ text-align: right;
728
+ color: #999999;
729
+ // font-size: 13px;
730
+ }
731
+
732
+ .alc-content-text {
733
+ margin-bottom: 6px;
734
+ width: 55px;
735
+ flex: none;
736
+
737
+ .aci-view {
738
+ display: inline-block;
739
+ margin-left: 30px;
740
+ color: #366aff;
741
+ cursor: pointer;
742
+ }
743
+ }
744
+
745
+ .alc-content-info {
746
+ display: flex;
747
+ flex-wrap: wrap;
748
+ justify-content: space-between;
749
+
750
+ .alcc-box {
751
+ display: flex;
752
+ flex-wrap: wrap;
753
+ color: #999999;
754
+
755
+ .aci-owner {
756
+ margin-right: 20px;
757
+ }
758
+
759
+ .aci-enterprise {
760
+ margin-right: 20px;
761
+ }
762
+ }
763
+ }
764
+ }
765
+ }
766
+
767
+ .ad-list-cell-recognition {
768
+ max-width: 270px;
769
+ margin-right: 12px;
770
+ font-size: 12px;
771
+ .alc-source-name {
772
+ flex: none;
773
+ padding: 3px;
774
+ margin-right: 5px;
775
+ margin-bottom: 5px;
776
+ background: #f2f6ff;
777
+ border-radius: 5px;
778
+ display: flex;
779
+ align-items: center;
780
+ justify-content: space-between;
781
+ cursor: pointer;
782
+
783
+ img {
784
+ vertical-align: middle;
785
+ // width: 16px;
786
+ // height: 16px;
787
+ margin: 0 3px 0 5px;
788
+ }
789
+
790
+ .alc-title-from {
791
+ // margin-right: 5px;
792
+ max-width: 240px;
793
+ overflow: hidden;
794
+ text-overflow: ellipsis;
795
+ white-space: nowrap;
796
+ }
797
+
798
+ .upload-source {
799
+ margin-right: 5px;
800
+ flex: none;
801
+ }
802
+
803
+ i {
804
+ font-size: 12px;
805
+ }
806
+ }
807
+ }
808
+
809
+ .ad-loadmore {
810
+ width: 100%;
811
+ height: 40px;
812
+ display: flex;
813
+ align-items: center;
814
+ justify-content: center;
815
+ // background: #FFFFFF;
816
+ color: #366aff;
817
+ font-size: 14px;
818
+ margin-top: 8px;
819
+ cursor: pointer;
820
+ }
821
+ }
822
+
823
+ .libang_list {
824
+ .libang_list_cell {
825
+ border-top: solid 1px #eeeeee;
826
+ padding: 10px 0 10px;
827
+ font-size: 12px;
828
+ .libang_title {
829
+ display: flex;
830
+ flex-wrap: wrap;
831
+ align-items: center;
832
+ justify-content: space-between;
833
+ line-height: 16px;
834
+
835
+ .libang_box {
836
+ display: flex;
837
+ align-items: center;
838
+ justify-content: space-between;
839
+ // font-size: 12px;
840
+ width: 100%;
841
+
842
+ .libang_source_left {
843
+ display: flex;
844
+ align-items: center;
845
+
846
+ .source-form {
847
+ width: 34px;
848
+ flex: none;
849
+ color: #a9b3c6;
850
+ }
851
+ }
852
+
853
+ .alc-content-text {
854
+ width: 55px;
855
+ flex: none;
856
+
857
+ .aci-view {
858
+ color: #366aff;
859
+ cursor: pointer;
860
+ }
861
+ }
862
+
863
+ .libang_title_from {
864
+ line-height: 22px;
865
+ word-break: break-all !important;
866
+ text-align: left;
867
+ flex: auto;
868
+ display: flex;
869
+ justify-content: flex-start;
870
+ }
871
+ }
872
+
873
+ .libang_box_introduction {
874
+ overflow: hidden;
875
+ text-overflow: ellipsis;
876
+ display: -webkit-box;
877
+ -webkit-line-clamp: 3;
878
+ -webkit-box-orient: vertical;
879
+ margin-top: 10px;
880
+ color: #616161;
881
+ // font-size: 12px;
882
+ line-height: 24px;
883
+ text-align: left;
884
+
885
+ img {
886
+ width: 50px;
887
+ height: 50px;
888
+ margin: 10px;
889
+ cursor: pointer;
890
+ }
891
+ }
892
+
893
+ .libang_box_introduction_previewImage {
894
+ overflow: hidden;
895
+ text-overflow: ellipsis;
896
+ display: -webkit-box;
897
+ -webkit-line-clamp: 3;
898
+ -webkit-box-orient: vertical;
899
+ margin-top: 10px;
900
+ color: #616161;
901
+ // font-size: 12px;
902
+ line-height: 24px;
903
+ text-align: left;
904
+
905
+ img {
906
+ max-width: 300px;
907
+ width: 100%;
908
+ max-height: 150px;
909
+ margin: 10px;
910
+ cursor: pointer;
911
+ }
912
+ }
913
+
914
+ .libang_updateTime {
915
+ display: flex;
916
+ align-items: center;
917
+ justify-content: space-between;
918
+ font-size: 13px;
919
+ width: 100%;
920
+ margin-top: 10px;
921
+ .libang_updataTime_left {
922
+ width: calc(100% - 40px);
923
+ display: flex;
924
+ align-items: center;
925
+ .upload-source {
926
+ flex: none;
927
+ height: 18px;
928
+ line-height: 18px;
929
+ background: #e9f9f8;
930
+ border: 1px solid #aff2cd;
931
+ border-radius: 2px;
932
+ display: flex;
933
+ align-items: center;
934
+ justify-content: center;
935
+ padding: 0 8px;
936
+ color: #00c2bb;
937
+ }
938
+ .libang_floder {
939
+ width:calc(100% - 90px);
940
+ // margin-left: 10px;
941
+ overflow: hidden;
942
+ text-overflow: ellipsis;
943
+ white-space: nowrap;
944
+ color: #366aff;
945
+ cursor: pointer;
946
+ text-align: left;
947
+ i {
948
+ margin-left: 8px;
949
+ }
950
+ }
951
+ }
952
+ .libang_content_text {
953
+ color: #366aff;
954
+ cursor: pointer;
955
+ }
956
+ .time {
957
+ color: #999999;
958
+ margin-left: 10px;
959
+ }
960
+ }
961
+ .alc-title-icon {
962
+ margin: 0 2px;
963
+ width: 18px;
964
+ height: 18px;
965
+ flex: none;
966
+ }
967
+
968
+ .alc-title-updateTime {
969
+ text-align: right;
970
+ color: #999999;
971
+ // font-size: 13px;
972
+ }
973
+ }
974
+
975
+ .alc-content {
976
+ .alc-title-updateTime {
977
+ margin-top: 6px;
978
+ display: block;
979
+ text-align: right;
980
+ color: #999999;
981
+ // font-size: 13px;
982
+ }
983
+
984
+ .alc-content-text {
985
+ margin-bottom: 6px;
986
+ width: 55px;
987
+ flex: none;
988
+
989
+ .aci-view {
990
+ display: inline-block;
991
+ margin-left: 30px;
992
+ color: #366aff;
993
+ cursor: pointer;
994
+ }
995
+ }
996
+
997
+ .alc-content-info {
998
+ display: flex;
999
+ flex-wrap: wrap;
1000
+ justify-content: space-between;
1001
+
1002
+ .alcc-box {
1003
+ display: flex;
1004
+ flex-wrap: wrap;
1005
+ color: #999999;
1006
+
1007
+ .aci-owner {
1008
+ margin-right: 20px;
1009
+ }
1010
+
1011
+ .aci-enterprise {
1012
+ margin-right: 20px;
1013
+ }
1014
+ }
1015
+ }
1016
+ }
1017
+ }
1018
+
1019
+ .libang_list_cell_recognition {
1020
+ background: #f2f6ff;
1021
+ display: flex;
1022
+ align-items: center;
1023
+ justify-content: space-between;
1024
+ padding: 3px;
1025
+ margin-right: 5px;
1026
+ margin-bottom: 5px;
1027
+ border-radius: 5px;
1028
+ cursor: pointer;
1029
+ font-size: 12px;
1030
+
1031
+ .libang_list_cell_left {
1032
+ margin-right: 5px;
1033
+ .libang_source_name {
1034
+ display: flex;
1035
+ align-items: center;
1036
+ height: 20px;
1037
+ margin-bottom: 2px;
1038
+ img {
1039
+ vertical-align: middle;
1040
+ // width: 16px;
1041
+ // height: 16px;
1042
+ margin: 0 3px;
1043
+ }
1044
+
1045
+ .libang_title_from {
1046
+ max-width: 226px;
1047
+ overflow: hidden;
1048
+ text-overflow: ellipsis;
1049
+ white-space: nowrap;
1050
+ line-height: 20px;
1051
+ }
1052
+ .upload_source {
1053
+ flex: none;
1054
+ }
1055
+ }
1056
+ .libang_source_floder {
1057
+ max-width: calc(226px - 24px);
1058
+ text-align: left;
1059
+ color: #366aff;
1060
+ overflow: hidden;
1061
+ text-overflow: ellipsis;
1062
+ white-space: nowrap;
1063
+ cursor: pointer;
1064
+ .iconfont {
1065
+ margin: 0 5px;
1066
+ font-size: 14px
1067
+ }
1068
+ }
1069
+ }
1070
+ i {
1071
+ font-size: 12px;
1072
+ }
1073
+ }
1074
+
1075
+ .ad-loadmore {
1076
+ width: 100%;
1077
+ height: 40px;
1078
+ display: flex;
1079
+ align-items: center;
1080
+ justify-content: center;
1081
+ // background: #FFFFFF;
1082
+ color: #366aff;
1083
+ font-size: 14px;
1084
+ margin-top: 8px;
1085
+ cursor: pointer;
1086
+ }
1087
+ }
1088
+ }</style>