askbot-dragon 1.5.46-beta → 1.5.46

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 (34) hide show
  1. package/package.json +3 -5
  2. package/public/index.html +7 -8
  3. package/src/assets/js/common.js +64 -0
  4. package/src/assets/js/hammer.js +2 -13
  5. package/src/assets/js/obsBrowser.js +63 -0
  6. package/src/assets/less/converSationContainer/common.less +0 -7
  7. package/src/components/ActionAlertIframe.vue +43 -1
  8. package/src/components/AiGuide.vue +2 -1
  9. package/src/components/AnswerDocknowledge.vue +81 -29
  10. package/src/components/ConversationContainer.vue +839 -990
  11. package/src/components/MyEditor.vue +349 -0
  12. package/src/components/answerRadio.vue +29 -28
  13. package/src/components/askVideo.vue +7 -3
  14. package/src/components/associationIntention.vue +7 -7
  15. package/src/components/chatContent.vue +1 -1
  16. package/src/components/formTemplate.vue +168 -148
  17. package/src/components/message/TicketMessage.vue +1 -1
  18. package/src/components/pdfPosition.vue +65 -99
  19. package/src/components/previewPdf.vue +13 -17
  20. package/src/components/recommend.vue +9 -18
  21. package/src/components/utils/ckeditor.js +19 -16
  22. package/src/components/welcomeKnowledgeFile.vue +271 -0
  23. package/src/components/welcomeLlmCard.vue +135 -0
  24. package/src/main.js +0 -3
  25. package/vue.config.js +0 -1
  26. package/src/components/newPdfPosition.vue +0 -878
  27. package/src/components/utils/ckeditorImageUpload/command.js +0 -110
  28. package/src/components/utils/ckeditorImageUpload/editing.js +0 -12
  29. package/src/components/utils/ckeditorImageUpload/plugin-image.js +0 -12
  30. package/src/components/utils/ckeditorImageUpload/toolbar-ui.js +0 -41
  31. package/src/components/utils/ckeditorfileUpload/common.js +0 -181
  32. package/src/components/utils/ckeditorfileUpload/editing.js +0 -12
  33. package/src/components/utils/ckeditorfileUpload/plugin_file.js +0 -12
  34. package/src/components/utils/ckeditorfileUpload/toolbar_ui.js +0 -34
package/package.json CHANGED
@@ -1,18 +1,17 @@
1
1
  {
2
2
  "name": "askbot-dragon",
3
- "version": "1.5.46-beta",
3
+ "version": "1.5.46",
4
4
  "scripts": {
5
5
  "serve": "vue-cli-service serve",
6
6
  "build": "vue-cli-service build",
7
7
  "lint": "vue-cli-service lint"
8
8
  },
9
9
  "dependencies": {
10
- "@ckeditor/ckeditor5-ui": "^10.1.0",
11
- "@ckeditor/ckeditor5-vue2": "^3.0.1",
12
10
  "ali-oss": "^6.2.1",
13
11
  "audio-loader": "^1.0.3",
14
- "ckeditor": "^4.12.1",
15
12
  "core-js": "^3.6.5",
13
+ "element-ui": "^2.15.14",
14
+ "esdk-obs-browserjs": "^3.23.5",
16
15
  "install": "^0.13.0",
17
16
  "jquery": "^3.5.1",
18
17
  "lodash": "^4.17.21",
@@ -30,7 +29,6 @@
30
29
  "@vue/cli-plugin-eslint": "~4.5.0",
31
30
  "@vue/cli-service": "~4.5.0",
32
31
  "babel-eslint": "^10.1.0",
33
- "element-ui": "^2.15.10",
34
32
  "eslint": "^6.7.2",
35
33
  "eslint-plugin-vue": "^6.2.2",
36
34
  "less": "^3.12.2",
package/public/index.html CHANGED
@@ -23,13 +23,12 @@
23
23
  });
24
24
  }
25
25
  </script>
26
- <script src="https://guoranopen-zjk.oss-cn-zhangjiakou.aliyuncs.com/ckeditor5-build-classic/0.4.4/ckeditor.js"></script>
26
+ <!-- <script src="https://askbot-uat.obs.cn-east-3.myhuaweicloud.com/npm-static/ckeditor5-build-classic/0.4.4/ckeditor.js"></script>-->
27
27
  <!-- 项目图标 -->
28
28
  <link rel="stylesheet" href="//at.alicdn.com/t/font_1566110_3hu6pyd938i.css"/>
29
29
  <!-- guoran图标 -->
30
30
  <link rel="stylesheet" href="//at.alicdn.com/t/c/font_2913049_qtm7orae3l.css"/>
31
31
  <script src="https://res.wx.qq.com/open/js/jweixin-1.2.0.js"></script>
32
- <!-- <script src="https://static.guoranbot.com/ckeditor5-build-classic/0.3.7/build/ckeditor.js"></script> -->
33
32
 
34
33
  <!-- vue -->
35
34
  <!-- <script src="https://static.guoranbot.com/vue/2.6.11/dist/vue.min.js"></script>
@@ -48,12 +47,12 @@
48
47
  <script src="https://cdnjs.cloudflare.com/ajax/libs/pdf.js/3.5.141/pdf.worker.min.js" integrity="sha512-6UHd2tcWIvg5hIYHXb3lnNO61tWfriGen6KddwGYTSUUazWGYESTHDDxJFEQkCy1cSL//yXKc1gcL+51/DTLFQ==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>
49
48
  <script src="https://cdnjs.cloudflare.com/ajax/libs/pdf.js/3.5.141/pdf_viewer.min.js" integrity="sha512-tYEGuMBQkCfSlBKJ3dNgS06wbb/MNE6nO2poZ1Y5brix8NajGcDcfEvuL38wJDOTkq0j5ojASNmrzv/8/wgGHQ==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>
50
49
  <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/pdf.js/3.5.141/pdf_viewer.min.css" integrity="sha512-Jf9DLkegLgARLR151csVkPvcVt4cOUhslrSZwiTAe9mqFL/BbYRDmxCOioCtbHifEgjsBFbrVhOMQ3mYPDLrqQ==" crossorigin="anonymous" referrerpolicy="no-referrer" /> -->
51
-
52
-
53
- <script src="https://guoranopen-zjk.oss-cn-zhangjiakou.aliyuncs.com/cdn-common/pdfJS2.1.266/pdf.min.js" referrerpolicy="no-referrer"></script>
54
- <script src="https://guoranopen-zjk.oss-cn-zhangjiakou.aliyuncs.com/cdn-common/pdfJS2.1.266/pdf.worker.min.js" referrerpolicy="no-referrer"></script>
55
- <script src="https://guoranopen-zjk.oss-cn-zhangjiakou.aliyuncs.com/cdn-common/pdfJS2.1.266/pdf_viewer.js" referrerpolicy="no-referrer"></script>
56
- <link rel="stylesheet" href="https://guoranopen-zjk.oss-cn-zhangjiakou.aliyuncs.com/cdn-common/pdfJS2.1.266/pdf_viewer_01.css" referrerpolicy="no-referrer" />
50
+
51
+
52
+ <script src="https://askbot-uat.obs.cn-east-3.myhuaweicloud.com/npm-static/pdfJS2.1.266/pdf.min.js" referrerpolicy="no-referrer"></script>
53
+ <script src="https://askbot-uat.obs.cn-east-3.myhuaweicloud.com/npm-static/pdfJS2.1.266/pdf.worker.min.js" referrerpolicy="no-referrer"></script>
54
+ <script src="https://askbot-uat.obs.cn-east-3.myhuaweicloud.com/npm-static/pdfJS2.1.266/pdf_viewer.js" referrerpolicy="no-referrer"></script>
55
+ <link rel="stylesheet" href="https://askbot-uat.obs.cn-east-3.myhuaweicloud.com/npm-static/pdfJS2.1.266/pdf_viewer_01.css" referrerpolicy="no-referrer" />
57
56
  <!-- hammer.js -->
58
57
  <!-- <script src="https://cdnjs.cloudflare.com/ajax/libs/hammer.js/2.0.8/hammer.min.js" integrity="sha512-UXumZrZNiOwnTcZSHLOfcTs0aos2MzBWHXOHOuB0J/R44QB0dwY5JgfbvljXcklVf65Gc4El6RjZ+lnwd2az2g==" crossorigin="anonymous" referrerpolicy="no-referrer"></script> -->
59
58
  <style>
@@ -9,4 +9,68 @@ export function isMobile() {
9
9
  bool = false
10
10
  }
11
11
  return bool
12
+ }
13
+
14
+ let imageTypeObj = {
15
+ PDF: 'pdf1',
16
+ pdf: 'pdf1',
17
+ TXT: 'txt1',
18
+ txt: 'txt1',
19
+ selfadd: 'selfadd1',
20
+ md: "md2",
21
+ html: 'selfadd1',
22
+ mode: "mode",
23
+ general: 'general',
24
+ word: "word1",
25
+ Word: "word1",
26
+ docx: "word1",
27
+ doc: "word1",
28
+ docm: "word1",
29
+ dotm: "word1",
30
+ dotx: "word1",
31
+ wpt: "word1",
32
+ wps: "word1",
33
+ WORD: "word1",
34
+ Excel: 'excel1',
35
+ EXCEL: 'excel1',
36
+ excel: 'excel1',
37
+ PPT: 'ppt1',
38
+ ppt: 'ppt1',
39
+ pptx: 'ppt1',
40
+ img: "image1",
41
+ image: "image1",
42
+ video: "video",
43
+ audio: 'audio',
44
+ link: "link",
45
+ wechat: "wechat",
46
+ mp4: "video",
47
+ MP4: "video",
48
+ xlsx: "excel1",
49
+ xls: "excel1",
50
+ csv: "excel1",
51
+ jpg: "image1",
52
+ JPG: "image1",
53
+ jpeg: "image1",
54
+ JPEG: "image1",
55
+ png: "image1",
56
+ PNG: "image1",
57
+ webp: "image1",
58
+ WEBP: "image1",
59
+ gif: "image1",
60
+ GIF: "image1",
61
+ svg: "image1",
62
+ bmp: "image1",
63
+ avi: "video",
64
+ mov: "video",
65
+ rmvb: "video",
66
+ wav: "audio",
67
+ mp3: "audio",
68
+ MOV: "video",
69
+ AIV: "video",
70
+ aiv: "video",
71
+ news:"news"
72
+ }
73
+
74
+ export {
75
+ imageTypeObj
12
76
  }
@@ -3,15 +3,6 @@ export function zoomElement (el) {
3
3
  let store = {
4
4
  scale: 1
5
5
  };
6
- if (!el){
7
- return
8
- }
9
- let scale = 1;
10
- if (el.style.transform){
11
- let transForm = el.style.transform;
12
- var values = transForm.split('(')[1].split(')')[0].split(',');
13
- scale = values[0] ? values[0] : 1
14
- }
15
6
  // 缩放事件的处理
16
7
  el.addEventListener('touchstart', function (event) {
17
8
  let touches = event.touches;
@@ -76,15 +67,13 @@ export function zoomElement (el) {
76
67
  newScale = 3;
77
68
  }
78
69
  // 最小缩放比例限制
79
- if(newScale < scale) {
80
- newScale = scale;
70
+ if(newScale < 1) {
71
+ newScale = 1;
81
72
  }
82
73
  // 记住使用的缩放值
83
74
  store.scale = newScale;
84
75
  // 图像应用缩放效果
85
76
  el.style.transform = 'scale(' + newScale + ')';
86
- el.style.transformOrigin = 'top left'
87
-
88
77
  }
89
78
  });
90
79
  document.addEventListener('touchend', function () {
@@ -0,0 +1,63 @@
1
+ // 创建ObsClient实例
2
+ import ObsClient from 'esdk-obs-browserjs';
3
+ const obsClient = new ObsClient({
4
+ access_key_id: "EE4MAFWH4YLQSQF7NNIP",
5
+ secret_access_key: "Dq9giqqwZoX77dqSIzhA1Yhhe9tarA3LRBGBF4eO",
6
+ server : 'https://obs.cn-east-3.myhuaweicloud.com',
7
+ timeout : 1000
8
+ });
9
+ let mainId = sessionStorage.getItem('_mainId') ? sessionStorage.getItem('_mainId') : "";
10
+ let IDX = 256, HEX = [], SIZE = 256, BUFFER;
11
+ while (IDX--) HEX[IDX] = (IDX + 256).toString(16).substring(1);
12
+ function uid(len) {
13
+ let i = 0, tmp = (len || 11);
14
+ if (!BUFFER || ((IDX + tmp) > SIZE * 2)) {
15
+ for (BUFFER = '', IDX = 0; i < SIZE; i++) {
16
+ BUFFER += HEX[Math.random() * 256 | 0];
17
+ }
18
+ }
19
+
20
+ return BUFFER.substring(IDX, IDX++ + tmp);
21
+ }
22
+
23
+ function dataFormat(fmt, date = new Date()) {
24
+ const o = {
25
+ "M+": date.getMonth() + 1, //月份
26
+ "d+": date.getDate(), //日
27
+ "h+": date.getHours(), //小时
28
+ "m+": date.getMinutes(), //分
29
+ "s+": date.getSeconds(), //秒
30
+ "q+": Math.floor((date.getMonth() + 3) / 3), //季度
31
+ "S": date.getMilliseconds() //毫秒
32
+ };
33
+ if (/(y+)/.test(fmt)) fmt = fmt.replace(RegExp.$1, (date.getFullYear() + "").substr(4 - RegExp.$1.length));
34
+ for (const k in o)
35
+ if (new RegExp("(" + k + ")").test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));
36
+ return fmt;
37
+ }
38
+ async function putObject(file,callback){
39
+ let fileUrl = ''
40
+ let objName = (process.env.VUE_APP_ENV === 'development' ? 'dev_' : 'pro_') + file.name;
41
+ let fileName = "front-oss/" + mainId + '/' + dataFormat("yyyy/MM/dd/hh/mm/") + uid(32) + "/" + objName;
42
+ await obsClient.putObject({
43
+ Bucket: 'askbot-uat',
44
+ Key : fileName,
45
+ SourceFile : file,
46
+ ACL : obsClient.enums.AclPublicRead,
47
+ ProgressCallback: callback
48
+ }).then(function(result) {
49
+ if(result.CommonMsg.Status < 300){
50
+ console.log('Create object:' + JSON.stringify(result) + ' successfully!\n',process.env.VUE_APP_ENV);
51
+ let domain = process.env.VUE_APP_ENV ==='development' ? 'https://askbot-uat.obs.cn-east-3.myhuaweicloud.com/' : ''
52
+ fileUrl = {
53
+ url: domain + fileName,
54
+ name:file.name
55
+ }
56
+ }
57
+ });
58
+ return fileUrl
59
+ }
60
+
61
+ export {
62
+ putObject
63
+ }
@@ -35,13 +35,6 @@
35
35
  border-radius: 6px;
36
36
  background-color: #bfceec !important;
37
37
  }
38
- @media screen and (max-width: 767px){
39
- ::-webkit-scrollbar {
40
- width: 0;
41
- height: 0;
42
- background-color:@system_bordercolor_4;
43
- }
44
- }
45
38
 
46
39
  // 弹窗body
47
40
  .el-dialog__body{
@@ -1,17 +1,39 @@
1
1
  <template>
2
2
  <div id="action_alert_iframe">
3
+ <div class="iframe-full-screen">
4
+ <span @click="showAskFullScreen = true" class="el-icon-full-screen"></span>
5
+ </div>
3
6
  <iframe
4
7
  class="grzh-iframe"
5
8
  :id="tampId"
6
9
  :data-name="tampId"
7
10
  :src="actionAlertIframe.template"
8
11
  :width="(actionAlertIframe.version == 1 && !phoneWidth100)?actionAlertIframe.width:'100%'"
9
- :height="actionAlertIframe.height"
12
+ :height="showAskFullScreen?'90%':actionAlertIframe.height"
10
13
  :scrolling="actionAlertIframe.scrolling"
11
14
  frameborder="no"
12
15
  border="0"
13
16
  ></iframe>
17
+
18
+ <div v-if="showAskFullScreen" class="ask-full-screen">
19
+ <div class="iframe-full-screen">
20
+ <br>
21
+ <span @click="showAskFullScreen = false" style="cursor: pointer;">
22
+ <svg t="1702295921525" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="39588" width="20" height="20"><path d="M257.706667 376.32H128c-11.946667 0-21.333333-9.386667-21.333333-21.333333s9.386667-21.333333 21.333333-21.333334h129.706667c35.413333 0 64-28.586667 64-64V128c0-11.946667 9.386667-21.333333 21.333333-21.333333s21.333333 9.386667 21.333333 21.333333v141.653333a106.666667 106.666667 0 0 1-106.666666 106.666667zM896 376.32h-129.706667a106.666667 106.666667 0 0 1-106.666666-106.666667V128c0-11.946667 9.386667-21.333333 21.333333-21.333333s21.333333 9.386667 21.333333 21.333333v141.653333c0 35.413333 28.586667 64 64 64H896c11.946667 0 21.333333 9.386667 21.333333 21.333334s-9.386667 21.333333-21.333333 21.333333z" fill="#666666" p-id="39589"></path><path d="M896 376.32h-129.706667a106.666667 106.666667 0 0 1-106.666666-106.666667V128c0-11.946667 9.386667-21.333333 21.333333-21.333333s21.333333 9.386667 21.333333 21.333333v141.653333c0 35.413333 28.586667 64 64 64H896c11.946667 0 21.333333 9.386667 21.333333 21.333334s-9.386667 21.333333-21.333333 21.333333zM257.706667 376.32H128c-11.946667 0-21.333333-9.386667-21.333333-21.333333s9.386667-21.333333 21.333333-21.333334h129.706667c35.413333 0 64-28.586667 64-64V128c0-11.946667 9.386667-21.333333 21.333333-21.333333s21.333333 9.386667 21.333333 21.333333v141.653333a106.666667 106.666667 0 0 1-106.666666 106.666667zM680.96 917.333333c-11.946667 0-21.333333-9.386667-21.333333-21.333333v-141.653333a106.666667 106.666667 0 0 1 106.666666-106.666667H896c11.946667 0 21.333333 9.386667 21.333333 21.333333s-9.386667 21.333333-21.333333 21.333334h-129.706667c-35.413333 0-64 28.586667-64 64V896c0 11.946667-9.386667 21.333333-21.333333 21.333333zM343.04 917.333333c-11.946667 0-21.333333-9.386667-21.333333-21.333333v-141.653333c0-35.413333-28.586667-64-64-64H128c-11.946667 0-21.333333-9.386667-21.333333-21.333334s9.386667-21.333333 21.333333-21.333333h129.706667a106.666667 106.666667 0 0 1 106.666666 106.666667V896c0 11.946667-9.813333 21.333333-21.333333 21.333333z" fill="#666666" p-id="39590"></path><path d="M343.04 917.333333c-11.946667 0-21.333333-9.386667-21.333333-21.333333v-141.653333c0-35.413333-28.586667-64-64-64H128c-11.946667 0-21.333333-9.386667-21.333333-21.333334s9.386667-21.333333 21.333333-21.333333h129.706667a106.666667 106.666667 0 0 1 106.666666 106.666667V896c0 11.946667-9.813333 21.333333-21.333333 21.333333zM680.96 917.333333c-11.946667 0-21.333333-9.386667-21.333333-21.333333v-141.653333a106.666667 106.666667 0 0 1 106.666666-106.666667H896c11.946667 0 21.333333 9.386667 21.333333 21.333333s-9.386667 21.333333-21.333333 21.333334h-129.706667c-35.413333 0-64 28.586667-64 64V896c0 11.946667-9.386667 21.333333-21.333333 21.333333z" fill="#666666" p-id="39591"></path></svg>
23
+ </span>
24
+ </div>
25
+ <iframe
26
+ class="grzh-iframe"
27
+ :src="actionAlertIframe.template"
28
+ width="100%"
29
+ height="95%"
30
+ :scrolling="actionAlertIframe.scrolling"
31
+ frameborder="no"
32
+ border="0"
33
+ ></iframe>
34
+ </div>
14
35
  </div>
36
+ <!-- https://blog.csdn.net/qq_16992475/article/details/130633117 -->
15
37
  </template>
16
38
  <script>
17
39
  export default {
@@ -38,6 +60,7 @@ export default {
38
60
  displayStyle:
39
61
  "iframe 样式(点击弹出/嵌入iframe 字符串类型后端未做限制)",
40
62
  },
63
+ showAskFullScreen: false,
41
64
  };
42
65
  },
43
66
  methods: {},
@@ -63,6 +86,7 @@ export default {
63
86
  } else {
64
87
  this.actionAlertIframe.template = this.actionAlertIframe.template + "&iframeId=" + this.tampId
65
88
  }
89
+ this.actionAlertIframe.template = this.actionAlertIframe.template.split("&amp;").join("&")
66
90
  },
67
91
  };
68
92
  </script>
@@ -73,6 +97,24 @@ export default {
73
97
  width: 100%;
74
98
  margin: 0 auto;
75
99
  overflow-x: auto;
100
+
101
+ .iframe-full-screen{
102
+ text-align: right;
103
+ padding-right: 12px;
104
+ .el-icon-full-screen{
105
+ cursor: pointer;
106
+ }
107
+ }
108
+
109
+ .ask-full-screen{
110
+ background-color: white;
111
+ position: fixed;
112
+ top: 0;
113
+ left: 0;
114
+ width: 100vw;
115
+ height: 100vh;
116
+ z-index: 9999999999999999999;
117
+ }
76
118
  .grzh-iframe {
77
119
  scrollbar-face-color: #9aa1c4;
78
120
  /* 滚动条滑块按钮的颜色 */
@@ -13,7 +13,7 @@
13
13
  v-show="aiGuide.content.descriptionVisible && aiGuide.content.description !== ''"
14
14
  class="ig-types-des"
15
15
  >
16
- {{ aiGuide.content.description }}
16
+ <span v-html="aiGuide.content.description"></span>
17
17
  </div>
18
18
  <!-- 一级分类 -->
19
19
  <div v-show="aiGuide.content.typesVisible" class="ig-types-f">
@@ -441,6 +441,7 @@ export default {
441
441
  color: #366aff;
442
442
  cursor: pointer;
443
443
  align-items: center;
444
+ text-align: left;
444
445
  span {
445
446
  display: flex;
446
447
  align-items: center;
@@ -38,6 +38,9 @@
38
38
  <div v-else class="alc-box-introduction">
39
39
  <img :src="item.expiredUrl" alt="" @click="lookAttach(item.url, item, $event)">
40
40
  </div>
41
+ <div v-if="item.previewImage" class="alc-box-introduction-previewImage">
42
+ <img :src="item.previewImage" alt="" @click="lookAttach(item.previewImage, {url: item.previewImage}, $event)">
43
+ </div>
41
44
  <div class="alc-updateTime">
42
45
  <div v-show="docSource[item.source]" class="upload-source">
43
46
  {{docSource[item.source]}}
@@ -66,6 +69,9 @@
66
69
  </div>
67
70
  </div>
68
71
  </div>
72
+ <div class="ad-loadmore" v-if="loadMoreFlag" @click="lazyLoadKnowledegList">
73
+ 查看更多
74
+ </div>
69
75
  </div>
70
76
  <previewPdf ref="previewPdf" :url="previewHref" :sourceFileType="sourceFileType" officePreviewType="pdf"></previewPdf>
71
77
  </div>
@@ -151,28 +157,29 @@ export default {
151
157
  MP3: "audio",
152
158
  yqhtml: "yqhtml",
153
159
  feishuhtml:"feishuhtml"
154
- }
160
+ },
161
+ allKnowledgeList:[],
162
+ loadMoreFlag:false
155
163
  }
156
164
  },
157
165
  props: ['msg','isAskLightning', 'isMessageRecord',"isApp"],
158
166
  beforeMounted() {
159
-
160
167
  },
161
168
  watch:{
162
- msg:{
163
- handler(n){
164
- console.log(n,'answerDocknowledge');
165
- n.content.list.forEach(element => {
166
- console.log(this.imageObj[element.format],1111);
167
- element.src = 'https://static.guoranbot.com/cdn-office-website/askbot_doc/' + this.imageObj[element.format] + '.png';
168
- if ((element.format === "txt" || element.format === "html") && element.source === "WECHAT") {
169
- element.src = 'https://static.guoranbot.com/cdn-office-website/askbot_doc/wechat.png';
170
- }
171
- });
172
- },
173
- deep:true,
174
- immediate:true
175
- }
169
+ msg:{
170
+ handler(n){
171
+ console.log(n,'answerDocknowledge');
172
+ n.content.list.forEach(element => {
173
+ console.log(this.imageObj[element.format],1111);
174
+ element.src = 'https://static.guoranbot.com/cdn-office-website/askbot_doc/' + this.imageObj[element.format] + '.png';
175
+ if ((element.format === "txt" || element.format === "html") && element.source === "WECHAT") {
176
+ element.src = 'https://static.guoranbot.com/cdn-office-website/askbot_doc/wechat.png';
177
+ }
178
+ });
179
+ },
180
+ deep:true,
181
+ immediate:true
182
+ }
176
183
  },
177
184
  created() {
178
185
  var system = {};
@@ -193,7 +200,17 @@ export default {
193
200
  // });
194
201
  },
195
202
  mounted() {
196
-
203
+ console.log(this.msg.content,'this.msg.content');
204
+ // if(this.msg.content.type == 1) {
205
+
206
+ // }
207
+ if(this.msg.content.list && this.msg.content.list.length > 0) {
208
+ this.loadMoreFlag = true
209
+ this.allKnowledgeList = JSON.parse(JSON.stringify(this.msg.content.list))
210
+ // console.log(this.allKnowledgeList.length, 'this.allKnowledgeList');
211
+ this.msg.content.list = []
212
+ this.lazyLoadKnowledegList()
213
+ }
197
214
  },
198
215
  methods: {
199
216
  //预览图片
@@ -244,18 +261,7 @@ export default {
244
261
  }
245
262
  this.$refs.previewPdf.fileType = type
246
263
  this.$refs.previewPdf.tagIds = item.tagIds
247
- this.$refs.previewPdf.isMessageRecord = this.isMessageRecord ? true : false ;
248
- let index = url.indexOf("?");
249
- let newFileInOssPath = url;
250
- if (index !== -1){
251
- newFileInOssPath = url.substring(0, url.indexOf("?"))
252
- }
253
- let fileName = newFileInOssPath.substring(newFileInOssPath.lastIndexOf('.'))
254
- if (fileName === '.doc' || fileName === '.docx' || fileName === '.txt'){
255
- this.$refs.previewPdf.fileName = fileName;
256
- } else {
257
- this.$refs.previewPdf.fileName = '';
258
- }
264
+ this.$refs.previewPdf.isMessageRecord = this.isMessageRecord ? true : false
259
265
  if(item.tagIds && item.tagIds.length != 0) {
260
266
  this.$refs.previewPdf.loading = false
261
267
  return
@@ -306,6 +312,21 @@ export default {
306
312
  // return res.data
307
313
  })
308
314
  // return imgurl
315
+ },
316
+ lazyLoadKnowledegList() {
317
+ if(this.allKnowledgeList.length !== 0) {
318
+ let arr = this.allKnowledgeList.splice(0, 5)
319
+ if(arr.length < 5) {
320
+ this.loadMoreFlag = false
321
+ this.msg.content.list = [...this.msg.content.list, ...arr]
322
+ return
323
+ }
324
+ if(this.allKnowledgeList.length == 0) {
325
+ this.loadMoreFlag = false
326
+ }
327
+ this.msg.content.list = [...this.msg.content.list, ...arr]
328
+ return
329
+ }
309
330
  }
310
331
  }
311
332
  }
@@ -415,6 +436,25 @@ export default {
415
436
  cursor: pointer;
416
437
  }
417
438
  }
439
+ .alc-box-introduction-previewImage {
440
+ overflow: hidden;
441
+ text-overflow: ellipsis;
442
+ display: -webkit-box;
443
+ -webkit-line-clamp:3;
444
+ -webkit-box-orient:vertical;
445
+ margin-top: 10px;
446
+ color: #616161;
447
+ // font-size: 12px;
448
+ line-height: 24px;
449
+ text-align: left;
450
+ img {
451
+ max-width: 300px;
452
+ width: 100%;
453
+ max-height: 150px;
454
+ margin: 10px;
455
+ cursor: pointer;
456
+ }
457
+ }
418
458
  .alc-updateTime{
419
459
  display: flex;
420
460
  align-items: center;
@@ -500,6 +540,18 @@ export default {
500
540
  }
501
541
  }
502
542
  }
543
+ .ad-loadmore {
544
+ width: 100%;
545
+ height: 40px;
546
+ display: flex;
547
+ align-items: center;
548
+ justify-content: center;
549
+ // background: #FFFFFF;
550
+ color: #366AFF;
551
+ font-size: 14px;
552
+ margin-top: 8px;
553
+ cursor: pointer;
554
+ }
503
555
  }
504
556
  }
505
557
  </style>